/*
Theme Name: sanseito01
Theme URI: https://sofnavi.com/
Description: このテーマは、「株式会社SOFNAVI」参政党員が作成しました。賛成党内に限定して無料でご利用ください。
*/
@charset "utf-8";
html {
	overflow: scroll;
	overflow: -moz-scrollbars-vertical;
	overflow-x: scroll;
	font-size:16px;
	font-family: "Zen Kaku Gothic New", sans-serif, Meiryo, メイリオ,'Lucida Grande';
}
body{
	-webkit-text-size-adjust: 100%;
	text-align:center;
	font-size:inherit;
	font:100%;
	line-height:1;
	margin:0px 0 0 0;
	padding: 0 0 0px 0;
}
div,span,pre,p,blockquote,form,fieldset,label,legend,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,
embed,object,form,caption,tbody,tfoot,thead,a,abbr,acronym,address,
small,strike,sub,sup,tt,var,del,u,i,center,big,cite,code,iframe,obect,applet{
	margin: 0;
	padding: 0;
	list-style:none;
	vertical-align: baseline;
	outline:0;
	border:0;
	font-style:normal;
	font-weight:normal;
}
table{margin:0 auto;}
th,td,input,textarea,select,option{
	margin: 0;
	padding: 0;
	font-style:normal;
	font-weight:normal;
	text-align:left;	
}
input,textarea,select,option{font-size:16px;}
a { 
	vertical-align: baseline;
	outline: none;
	overflow:hidden;
	outline:none;   
}
a img{border:none;}
a img:hover{
	opacity: 0.8;
	transition : all 0.5s ease 0s;
}
img.over{
	transition : all 0.5s ease 0s;
}
img.over:hover {
	opacity: 0.8;
	transition : all 0.5s ease 0s;
}
a:link,a:visited{
	color:#4D4D4D;
	text-decoration:none;
}
a:hover,a:active{
	color:#000;
	text-decoration:none;
}
.side_max{
	width:1300px;
	margin:0 auto;
	padding:0;
}
#contenter.side_max{
	width:1000px;
	margin:0 auto;
	padding:0 0 4rem;
}
.clearfix,.cf {zoom:1;}
.cf:before,
.cf:after {
  display: table;
  content: "";
  line-height: 0;
}
.clearfix:after,.cf:after {
  clear: both;
  display: block; 
}

.pull-left{float:left;}
.pull-right{float:right;}
.ffm {
    font-family: "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
    font-size: 2.4rem;
}
@media screen and (min-width: 769px)  {
/*PC 769以上*/
	.pchide{display:none;}
}
@media screen and (min-width: 0px) and (max-width: 768px) {
	#contenter.side_max{
		width:90%;
		margin: 0 auto;
	}
	.side_max{
		width:90%;
		margin: 0 auto;
	}
	.sphide{display:none;}
	.tabhide{display:none;}
}

/******************************************
ヘッダー　header
*******************************************/
.home #header{
    position: absolute;
}
#header{
	background:none;
	padding:20px 30px;
	left:0;
	top:0;
    z-index: 1000;
	width:calc(100% - 60px);
}
#header .header_side_max{
    margin:0 auto;
	position:relative;
}
#header_menu{
	float:right;
	width:100%;
	text-align:right;
}
#logo{
	float:left;
    width:294px;
    height:87px;
    display: block;
}
.home #logo{
    
}
#header_navimenu{
	float:right;
	overflow:hidden;
	margin-top:10px;
    color:#fff;
}
#header_navimenu ul li{
    padding:10px 20px;
    float:left;
    display:block;
    font-size: 0.8em;
}
#header_navimenu ul li a{
    color:#000;
}
.home #header_navimenu ul li a{
    color:#fff;
}
.main-visual {
    height: 100%;
    text-align: center;
    position: relative;
    overflow: hidden;
	background:url(images/top_main00.jpg) no-repeat;
	background-size: cover;
	background-position: center bottom;
}
 
.main-visual img {
    z-index: 2;
    position: absolute;
    bottom: 100px;
	right:100px;
}
 
.main-visual video {
    margin: 0 auto;
    z-index: 1;
    width: 100%;
}
.header-nav{
	width:70%;
	display:inline-block;
	position:absolute;
	left:360px;
	top:0;
}
.header-nav > ul{
	display:flex;
	margin:0;
	padding:0;
	list-style:none;
}
.header-nav ul > li{
	padding:36px;
	position:relative;
	overflow: visible; 
}
.home .header-nav ul li a{
	color:#fff;
	text-shadow:2px 2px 4px rgba(0,0,0,0.4);
	text-decoration:none;
}
.header-nav ul li a{
	color:#080808;
	text-shadow:none;
	text-decoration:none;
}

/* ===== サブメニューの初期状態 ===== */
.header-nav .sub-menu {
  position: absolute;
  top: 100%;
  left: 0;
  background: #444;
  list-style: none;
  margin: 0;
  padding: 0;
  min-width: 200px; /* 適度な幅に調整 */
  opacity: 0;
  visibility: hidden;
  transform: translateY(10px);
  transition: all 0.3s ease;
  z-index: 100;
}

/* hover時に表示 */
.header-nav li:hover > .sub-menu {
  opacity:1;
  visibility:visible;
  transform:translateY(0);
}

/* サブメニュー内の項目 */
.header-nav .sub-menu li {
  padding: 0;
  border-bottom: 1px solid #555;
}
.header-nav .sub-menu li:last-child {
  border-bottom: none;
}
.header-nav .sub-menu li a {
  display: block;
  padding: 10px 20px;
  color: #fff;
  text-decoration: none;
}
.header-nav .sub-menu li a:hover {
  background: #555;
}

@media screen and (min-width: 0px) and (max-width: 768px) {
	#header{overflow:hidden;height: 70px;}
	#logo{
        margin:0 auto;
        width:200px;
        margin-top:12px;
        margin-left:5px;
    }
	#logo img{
        width:100%;
    }
    .home #logo{
        
    }
}

/******************************************
ハンバーガーメニュー　hamburgermenu
*******************************************/

.menu {
  position: fixed;
  top: 0;
  right: -100%;
  width: 300px;
  height: 100%;
  background-color: #d8f2f0;
  color: #333;
  transition: right 0.3s ease; 
  padding: 20px;
  box-sizing: border-box;
  z-index: 10;
}

/* メニューが開いているとき */
.menu.open {
  right: 0;
}

/* ボタンのスタイル */
.hamburger {
  position: fixed;
  top: 38px;
  right: 20px;
  width: 30px;
  cursor: pointer;
  z-index: 20;
  padding: 10px;
  background-color: #000;
}

.hamburger span {
  display: block;
  height: 3px;
  width: 100%;
  background-color: #fff;
  margin: 5px 0;
  transition: 0.4s;
}

/* バツ印に変化するスタイル */
.hamburger.active span:nth-child(1) {
  transform: rotate(45deg) translate(5px, 5px);
}

.hamburger.active span:nth-child(2) {
  opacity: 0;
}

.hamburger.active span:nth-child(3) {
  transform: rotate(-45deg) translate(6px, -6px);
}

/* メニューリストのスタイル */
.menu > ul {
  list-style-type: none;
  padding: 0;
  margin-top: 80px;
}

.menu > ul > li {
  border-top: 1px solid #444;
}

.menu > ul > li > a {
  padding: 20px 0;
  color: #333;
  text-decoration: none;
  display: block;
  background-color: #e9e9e9;
}
.menu > ul > li > a:hover {
  background-color: #c7c7c7;
}
.menu > ul > li > ul > li{
  padding: 10px 0;
}
.menu > ul > li > ul > li > a{
  background-color: #2b2b2b;
  color: #fff;
  border-radius: 20px;
  padding: 10px;
  width: 90%;
  display: block;
}
.menu > ul > li > ul > li > a:hover{
  background-color: #000;
}


/******************************************
トップメイン
*******************************************/
/* 設定 */
.container {
	width: 100%; 
	height: 1000px;
	overflow-x: hidden;
}

@media screen and (min-width: 0px) and (max-width: 768px) {
	.sp_container {
		width: 100%;
	}
	.sp_container img{
		width: 100%;
	}
}
/******************************************
トップコンテンツ
*******************************************/
/* セクション共通 */

section h2 {
	font-size: 2.5rem;
	color: #ff6600;
	margin-bottom: 3rem;
	text-align: center;
	position: relative;
	padding-bottom: 1rem;
}
@media screen and (min-width: 0px) and (max-width: 768px) {
	section h2 {
		font-size: 1.5rem;
	}
}
/* 重点施策カード */
#policies{
	padding:4rem 0; 
}
.policy-cards {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: 2rem;
	margin-top: 3rem;
}

.policy-card {
	background: white;
	border-radius: 10px;
	padding: 2rem;
	box-shadow: 0 4px 15px rgba(0,0,0,0.1);
	transition : all 0.5s ease 0s;
	border-top: 5px solid #ff6600;
}

.policy-card:hover {
	transform: translateY(-5px);
	box-shadow: 0 8px 25px rgba(255,102,0,0.2);
}

.policy-card .number {
	display: inline-block;
	background: linear-gradient(135deg, #ff8c00, #ff6600);
	color: white;
	width: 50px;
	height: 50px;
	border-radius: 50%;
	text-align: center;
	line-height: 50px;
	font-size: 1.5rem;
	font-weight: bold;
	margin-bottom: 1rem;
}

.policy-card h3 {
	font-size: 1.5rem;
	color: #ff6600;
	margin-bottom: 1rem;
}

.policy-card p {
	color: #555;
	line-height: 1.8;
	text-align: left;
}
.top_policy_bt {
    margin: 4rem auto;
}
.top_policy_bt .section_policies_bt {
    padding: 0.8rem 4rem;
    color: #343434;
    border: 2px solid #343434;
    border-radius: 4rem;
}
.top_policy_bt .section_policies_bt:hover {
    background-color: #020202;
    transition: all 0.5s ease 0s;
    color: #fff;
}

/* プロフィールセクション */
#profile{
	padding:4rem 0; 
}
.profile {
	background: linear-gradient(to bottom, #fff, #fff5eb);
}

.profile-content {
	display: grid;
	grid-template-columns: 1fr 2fr;
	gap: 3rem;
	align-items: start;
}

.profile-image {
	background: linear-gradient(135deg, #ff8c00, #ff6600);
	height: auto;
	border-radius: 10px;
	display: flex;
	align-items: center;
	justify-content: center;
	color: white;
	font-size: 1.5rem;
	font-weight: bold;
}

.profile-box h3 {
	color: #ff6600;
	font-size: 2rem;
	margin-bottom: 1.5rem;
}

.profile-text {
	padding:1rem 2rem;
	color: #555;
	text-align: left;
	line-height: 1.8;
}

.profile-details {
	background: white;
	padding: 2rem;
	border-radius: 10px;
	margin-top: 2rem;
	box-shadow: 0 2px 10px rgba(0,0,0,0.1);
}
.profile-details p{
	margin-bottom: 1.5rem;
	color: #555;
	text-align: left;
	line-height: 1.8;
}

.profile-details h4 {
	color: #ff6600;
	margin-bottom: 2rem;
    font-size: 1.8rem;
}
.profile-sns{
	display: flex;
}
.profile-sns li{
	line-height: 1rem;
}
.profile-sns li:hover{
	margin-top:-5px;
	transition : all 0.5s ease 0s;
}
.profile-sns li img{
	margin-right:10px;
}
.profile-sns li a {
    display: flex; 
    align-items: center; 
    gap: 10px; 
    text-decoration: none;
    padding: 10px; 
}
/* 画像サイズを調整（任意） */
.profile-sns li a img {
    width: 30px; /* 画像のサイズ */
    height: 30px;
}

@media screen and (min-width: 0px) and (max-width: 768px) {
	.top_youtube {
		width: 90%; 
		max-width: 400px;
		margin: auto; 
	}
	.top_youtube iframe {
		aspect-ratio: 9 / 16;
		width: 100%;
		height: 100%;
	}
	.profile-text {
		padding: 1rem;
	}
}



/* 重点政策詳細セクション */
#main-policies {
	padding:4rem 0; 
}
.main-policies {
	background: #fff5eb;
}

.policy-grid {
	display: grid;
	gap: 2rem;
}

.policy-item {
	background: white;
	padding: 2.5rem;
	border-radius: 10px;
	box-shadow: 0 4px 15px rgba(0,0,0,0.1);
	border-left: 6px solid #ff6600;
}

.policy-item h3 {
	color: #ff6600;
	font-size: 1.8rem;
	margin-bottom: 1.5rem;
}

.policy-item ul {
	list-style: none;
	padding-left: 0;
}

.policy-item li {
	padding: 0.8rem 0;
	padding-left: 2rem;
	position: relative;
	color: #555;
	text-align: left;
}

.policy-item li::before {
	content: '▸';
	position: absolute;
	left: 0;
	color: #ff6600;
	font-weight: bold;
}

/* メッセージセクション */
.message {
	background:url(images/section_bg_logo01.png) no-repeat left top #f08200;
	padding:4rem 0;
}
section.message h2{
	color:#fff;
}
.message-box {
	background: linear-gradient(135deg, #fff5eb, #ffe4cc);
	padding: 3rem;
	border-radius: 10px;
	border: 3px solid #ff6600;
}

.message-box h3 {
	color: #ff6600;
	font-size: 1.8rem;
	margin-bottom: 1.5rem;
}

.message-box p {
	color: #333;
	line-height: 2;
	margin-bottom: 1rem;
	text-align: left;
	font-size: 1.2rem;
}


@media (max-width: 768px) {
	.hero h1 {
		font-size: 2rem;
	}
	
	.hero .tagline {
		font-size: 1.2rem;
	}
	
	.nav-links {
		flex-direction: column;
		gap: 1rem;
	}
	
	.profile-content {
		grid-template-columns: 1fr;
	}
	
	.policy-cards {
		grid-template-columns: 1fr;
	}
}

/* 三つの重点政策セクション */
.three-policies {
	background: #fff;
	margin: 4rem auto;
	padding:4rem 0;
}

.three-policy-cards {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	gap: 2rem;
	margin-top: 2rem;
}

.three-policy-card {
	background: linear-gradient(to bottom, #fff5eb, white);
	padding: 2rem;
	border-radius: 10px;
	box-shadow: 0 4px 15px rgba(0,0,0,0.1);
	text-align: center;
	border: 2px solid #ff6600;
}

.three-policy-card .policy-number {
	display: inline-block;
	background: linear-gradient(135deg, #ff8c00, #ff6600);
	color: white;
	width: 60px;
	height: 60px;
	border-radius: 50%;
	text-align: center;
	line-height: 60px;
	font-size: 2rem;
	font-weight: bold;
	margin-bottom: 1.5rem;
}

.three-policy-card h3 {
	color: #ff6600;
	font-size: 1.5rem;
	margin-bottom: 1rem;
}

.three-policy-card p {
	color: #555;
	line-height: 1.8;
	text-align: left;
}

/* 活動報告ーお知らせ　セクション */
#top_info {
	padding:4rem 0;
}
#top_info ul{
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
}
#top_info ul li{
	width:96%;
	margin:2%;
}
#top_info ul li img{
	width:100%;
}
.fpost_items-center{
	margin:0;
	padding:1rem 0;
}
.fpost_items-center span{
	display: block;
	margin:0;
	padding:1rem 0;
}
.top_info_bt{
	margin:3rem auto;
}
.top_info_bt .section_categori_bt{
	padding:0.8rem 4rem;
	color:#343434;
	border:2px solid #343434;
	border-radius:4rem;
}
.top_info_bt .section_categori_bt:hover{
	background-color: #020202;
	transition : all 0.5s ease 0s;
	color:#fff;
}
@media (max-width: 768px) {
	#top_info ul{
	display: grid;
	grid-template-columns: 1fr 1fr;
}
}


/******************************************
 固定ページ　contenter
*******************************************/
#contenter{
	overflow:hidden;
	margin-bottom:40px;
	color:#3f3f3f;
}
.page_title {
	background-color: #f08200;
	padding: 40px 0;
    margin-bottom: 50px;
    font-size: 2rem;
    color:#fff;
}
.section_title{
	background:url(images/title_bg.png) repeat-x bottom;
	padding:20px 0px 20px 0px;
	margin-bottom:45px;
	font-size:26px;
	font-weight:bold;
	text-align:left;
	color:#555;
}
#contenter h2 {
    font-size: 1.5em;
	font-weight:700;
    padding: 25px;
    background-color: #ecebeb;
	color:#555;
	text-align: left;
	margin-top: 1rem;
	margin-bottom: 1rem;
}
#contenter h3 {
    font-size: 1.4em;
	font-weight:700;
    padding: .5em 0 .5em .75em;
	border:1px solid #cfcfcf;
    border-left: 5px solid #8d4118;
    text-align: left;
	margin-top: 1rem;
    margin-bottom: 1rem;
    line-height:1.8;
	color:#555;
}
#contenter h4 {
    font-size: 1.4em;
	font-weight:700;
    padding: .4em;
    text-align: left;
	margin-top: 1rem;
    margin-bottom: 1rem;
    line-height:1.8;
	color:#555;
	border-top:1px solid #cfcfcf;
	border-bottom:1px solid #cfcfcf;
}
#contenter h5 {
    font-size: 1.4em;
	font-weight:700;
    padding: .4em;
    text-align: left;
	margin-top: 1rem;
    margin-bottom: 1rem;
    line-height:1.8;
	color:#555;
}
#contenter h6 {
    font-size: 1.3em;
	font-weight:700;
    padding: .4em;
    text-align: left;
	margin-top: 1rem;
    margin-bottom: 1rem;
    line-height:1.8;
	color:#555;
}
#contenter p {
    font-size: 1em;
    padding: 1rem;
    text-align: left;
	text-align: justify;
    line-height:1.8;
	color:#555;
}


.title{
	border-left:#d1c7b4 5px solid;
	color:#000;
	font-weight:bold;
	font-size:21px;
	padding:0;
	padding-left:20px;
	margin-bottom:30px;
	text-align:left;
	line-height:1.8;
}
.title_green{
	font-size:16px;
	color:#00613c;
	margin-bottom:20px;
	text-align:left;
	font-weight:bold;
}
#contenter ul {
	padding:1rem 1rem;
	list-style-type:none;
}
#contenter ul li {
	position:relative;
	padding: 1em;
    text-align: left;
    border-bottom:1px dotted #ccc;
}
#contenter ol {
    list-style: none;
    padding: 0;
    margin: 0;
    padding: 1rem 1rem;
    counter-reset: custom-counter; 
}
#contenter ol li {
    display: flex;
    align-items: flex-start; 
    margin-bottom: 15px;
    padding-left: 0; 
}
#contenter ol li::before {
    counter-increment: custom-counter;
    content: counter(custom-counter); 
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width: 28px;
    height: 28px;
    min-width: 28px;
    border-radius: 50%;
    background-color: #f08200;
    color: #ffffff;
    font-weight: bold;
    font-size: 14px;
    line-height: 1;
    margin-right: 15px; 
}




@media screen and (min-width: 0px) and (max-width: 768px) {
	/*スマホ用*/
	#contenter{
		padding:2%;
		width:96%;
		margin:0 auto;
	}
	.page_title {
		padding: 20px 0;
		margin-bottom: 10px;
		font-size: 1.2em;
	}
	#contenter h2 {
		font-size: 1.2em;
	}
	#contenter h3 {
		font-size: 1.2em;
	}
	#contenter h3 {
		font-size: 1.2em;
	}
	#contenter h4 {
		font-size: 1em;
	}
	#contenter h5 {
		font-size: 1em;
	}
	#contenter h6 {
		font-size: 1em;
	}
	
}

/******************************************
投稿ページ　single
*******************************************/

.meta{text-align:left;font-size:16px;color:#00613c;}
.meta span{float:right;}

#singlebox{
	background:#fff;
	padding:40px;
}
.single_title{
	text-align:left;
}


@media screen and (min-width: 0px) and (max-width: 768px) {
	#singlebox{
		width:100%;
		padding:0%;
		margin:0 auto;
	}
}

/******************************************
サイドバー　sidebar
*******************************************/



/* カテゴリーページ　関連記事 */
#contenter .sidebar ul.list_posts{
	width:100%;
}
#contenter .list_posts{
	display: grid;
	grid-template-columns: 1fr 1fr 1fr 1fr;
}
#contenter .list_posts li{
	padding:1rem;
}
#contenter .list_posts li img{
	width:100%;
}
#contenter .list_posts li time{
	display: block;
	padding:1rem 0;
}
#contenter .list_posts li h4{
	display: block;
	padding:1rem 0;
	margin:0;
	border:none;
	font-size: 1em;
    font-weight: 400;
}
@media screen and (min-width: 0px) and (max-width: 768px) {
	#sidebar{
		width:100%;
	}
	#contenter .list_posts{
		display: grid;
		grid-template-columns: 1fr 1fr;
	}
	#contenter .sidebar ul {
		padding: 1rem 0rem;
	}
	#contenter .list_posts li{
		width:96%;
		padding:2%;
	}
}

/******************************************
カテゴリー一覧　category_list
*******************************************/
#contenter .categori_lists{
	display: grid;
	grid-template-columns: 1fr 1fr 1fr 1fr;
}
#contenter .categori_lists li{
	width:96%;
	padding:2%;
}
#contenter .categori_lists li img{
	width:100%;
}
#contenter .categori_lists li time{
	display: block;
	padding: 1rem 0;
}
#contenter .categori_lists li h4{
	display: block;
    padding: 1rem 0;
    margin: 0;
    border: none;
    font-size: 1em;
    font-weight: 400;
}
@media screen and (min-width: 0px) and (max-width: 768px) {
	#contenter ul {
		padding: 1rem 0rem;
		list-style-type: none;
	}
	#contenter .categori_lists{
		display: grid;
		grid-template-columns: 1fr 1fr;
	}
	.category_list dd{
		min-height:40px;
	}
	.category_list dt,.category_list dd,.category_list dt img{
		width:100%;
		margin:0;
	}
}




/******************************************
メール送信フォーム　contact
*******************************************/
.rtable {
	width:100%;
	margin:20px auto 60px;
	clear:both;
	border-bottom:1px dotted #81c14b;
}
.rtable dt {
	width:24%;
	float:left;
	box-sizing: border-box;
	padding:1rem 1%;
	border-top:1px dotted #81c14b;
	font-weight:normal;
	line-height:1.8;
	text-align:left;
	}
.rtable dd {
	border-top:1px dotted #81c14b;
	float:left;
	padding:1rem 1%;
	width:76%;
	box-sizing: border-box;
	line-height:1.8;
	text-align:left;
	word-break:break-all;
}

.mustbox{
	border-bottom:1px dotted #81c14b;
	padding:2rem 0;
	color:#333333;
	font-weight:bold;
}

.rtable label{display:block;}
.rtable dd textarea{
	height:200px;
	margin-bottom:10px;
	border-radius: 3px;
	-webkit-border-radius: 3px;
	-moz-border-radius: 3px;
	border:1px #ccc solid;
    padding: 10px;
    color:#444;
	font-size: 1em;
	line-height: 1.6;
}
.rtable dd span{
	margin:0;
	padding:5px 0;
}
.rtable input{
	border-radius: 3px;
	-webkit-border-radius: 3px;
	-moz-border-radius: 3px;
	border:1px #ccc solid;
	padding: 10px;
    color:#444;
	font-size: 1em;
	line-height: 1.6;
}
.rtable .s{width:60px;}
.rtable .m{width:240px;}
.rtable .l{width:90%;}

.btn,a.btn{
	padding:20px;
	color:#fff;
	margin:0 auto 40px auto;
	display:block;
	width:50%;
	font-size:26px;
	background:#0f4ead;
	font-weight:bold;
	border-radius: 6px;
	-webkit-border-radius: 6px;
	-moz-border-radius: 6px;
	box-shadow:3px 3px 0px 0px #0b108c;
	-moz-box-shadow:3px 3px 0px 0px #0b108c;
	-webkit-box-shadow:3px 3px 0px 0px #0b108c;
	border:none;
	text-align:center;
}
.btn:hover,a.btn:hover{
	margin:2px auto 38px auto;
	text-decoration:none;
	box-shadow:3px 3px 0px 0px #0b108c;
	-moz-box-shadow:3px 3px 0px 0px #0b108c;
	-webkit-box-shadow:3px 3px 0px 0px #0b108c;
}
#contenter .btn_submit p{
	text-align:center;
}
#contenter .btn_submit input{
	background:url(images/btn_submit.png) no-repeat;
	width:240px;
	margin:40px auto 60px auto;
	height:48px;
	text-indent:-9999px;
	border:none;
}
.red{color:#fe0000;}

span.wpcf7-list-item {
    display: inline-block;
    width: 100%;
}
.must{
	background:#fe0000;
	color:#fff;
	padding:2px 5px;
	font-size:0.8em;
	margin:2px 5px;
	float:right;
}
.policy{
	background:#fff;
	margin:-30px auto 10px auto;
	padding:10px 30px;
	font-size:0.9em;
	text-align:left;
	line-height:1.8;
	height:230px;
	overflow-y: scroll;
	overflow-x: hidden;
	width:85%;
	color:#666;
	border: 5px #ccc solid;
}
.policy strong{
	display:block;
}

@media screen and (min-width: 0px) and (max-width: 768px) {
	/*スマホ用*/
	.must {
		margin: 0px 10px;
		float: none;
	}
	.rtable{width:100%}
	.rtable dt{width:100%;}
	.rtable dd{width:100%; border-left:none;border-top:none;padding-top:0;}
	.rtable dd .extext{
		padding:10px 0;
		display: block;
		font-size: 12px;
	}
	.ajax-loader{height:0px;}

}


/******************************************
ページネーション　Pagenation
*******************************************/
.pagenation {
    margin-bottom:40px;
}
.pagenation:after, .pagenation ul:after {
    clear: both;
    content: ".";
    display: block;
    height: 0;
    visibility: hidden;
}
.pagenation ul {
    margin: 0;
}
.pagenation li {
    float: left;
    list-style: none outside none;
    margin-left: 3px;
}
.pagenation li:first-child {
    margin-left: 0;
}
.pagenation li.active {
    background-color: #6fb92c;
    border-radius: 3px;
    color: #FFFFFF;
    cursor: not-allowed;
    padding: 10px 20px;
}
.pagenation li a,.pagenav a {
    background: none repeat scroll 0 0 #fff;
	border:1px solid #666;
    border-radius: 3px;
    color: #666;
    display: block;
    padding: 10px 20px;
    text-decoration: none;
    text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.2);
    float: left;
    margin-left: 2.5%;
    margin-right: 2.5%;

}
.pagenation li a:hover {
    background-color: #444444;
    color: #FFFFFF;
    opacity: 0.8;
    transition-duration: 500ms;
    transition-property: all;
    transition-timing-function: ease;
}
.pagenav{
	overflow: hidden;
	margin:0 auto;
	width:100%;
	margin-bottom:40px;
	display: grid;
	grid-template-columns: 1fr 1fr;
}

.pagenav a{
	width:90%;
	margin:5%;
	display:inline;
}
@media screen and (min-width: 0px) and (max-width: 768px) {
	.pagenav{
		width:100%;
	}
	.pagenav a{
		width: 90%;
		padding:5% 0%;
		margin:5%;
		font-size: 0.7em;
	}
}

/******************************************
フッターエリア
*******************************************/
.fotter_bana_wrap{
	display: grid;
	grid-template-columns: 1fr 1fr 1fr 1fr;
}
.footer_bana img{
	width:96%;
    margin:1% 2%;
}

#footer_contact{
	border-top:#e0ddd9 1px solid;
	background:url(images/header_bg.png) repeat;
	padding:42px 0;
}
#footer{
	background:#868687;
	color:#fff;
	padding:40px 0 40px 0;
}
section#footer h2{
	text-align: left;
	line-height:1.6;
	color:#fff;
	margin-bottom: 0;
	padding:1rem;
}
#footer a{
	color:#fff;
}
#footer p{
	text-align:left;
	line-height:2;
	font-size:1rem;
	padding:1rem;
}
#footer .pull-left{
	width:65%;
}
#footer .pull-right{width:30%;}

#footer .pull-left{
	text-align:left;
}
.footer_list{
	background:url(images/footer_line.png) repeat-x bottom;
	margin-bottom:40px;
	padding-bottom:40px;
}
#footer .footer-nav ul{
	width:100%;
	display: flex;
}
#footer .footer-nav ul li{
	background:url(images/footer_icon.png) no-repeat 0 12px;
	padding:10px 15px;
	margin-right:10px;
	font-size:16px;
}
.orange{color:#e88e19;}
.footer_bana_join img{
	width:100%;
}
.footer_bana_join img:hover{
	width:100%;
}
#footer .pull-right{
	text-align:left;
}

#footer .footer_logo img{
	width:100%;
	margin-bottom:20px;
}
#footer .footer_c img{
	width:70%;
	padding:5px 15%;
}

.copy{
	padding:10px 0;
	font-size:12px;
	background:#333;
	color:#fff;
	text-align:center;
}

@media screen and (min-width: 0px) and (max-width: 768px) {
	.fotter_bana_wrap {
		display: grid;
		grid-template-columns: 1fr;
	}
	#footer{overflow:hidden;width:100%;}
	.footer_logo{width:100%;margin:0 auto;margin-bottom:20px;}
	.footer_logo .pull-left{float:none;}
	.footer_c{width:100%;margin:0 auto;}
	.footer_c .pull-right{float:none;}
	.footer_c img{margin-right:20px;}
	.footer_list{margin-bottom:10px;padding-bottom:10px;}
	#footer .footer-nav ul {
		width: 100%;
		display: grid;
		grid-template-columns: 1fr;
	}
	#footer .pull-left{width:100%;}
	#footer .pull-right{width:100%;}
}

/******************************************
wysiwyg
*******************************************/

.aligncenter{
    margin:60px auto;
    display: block;
}
.size-full{
    max-width:100%;
}

/******************************************
ページ
*******************************************/

