@charset "utf-8";

/*基本設定
----------------------------------------------------*/
@font-face{
	font-family: 'din-bold';
	src:url(../fonts/DINPro-Bold.ttf) format('truetype')
}

body {
		margin:0;
		padding:0;
		font-family:"メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", sans-serif;
		color:#333;
		line-height:2;
		font-size:15px;
		-webkit-text-size-adjust: 100%;
		position: relative;
}

html {   
		overflow-y:scroll;   
}  


a {
		color:#1ea955;
		text-decoration:underline;
}

a:hover {
		color:#1ea955;
		text-decoration:none;
		opacity: 0.8;
}

img {
		border:0;
}

h1,h2,h3,h4,h5,p {
		margin:0;
		padding:0;
		font-weight:normal;
}

ul,li,dl,dt,dd {
		margin:0;
		padding:0;
		list-style-type:none;
}

table {
		width:100%;
		border:0;
}

figure{
	margin: 0;
	padding: 0;
	line-height: 0;
}

.clear {
		clear:both;
}

.fix:after {
		content: "."; 
		display:block; 
		clear:both;
		height:0;
		visibility:hidden;
}

.fix {
		min-height:1px;
}

* html .fix {
		height:1px;
		/*\*//*/
		height: auto;
		overflow: hidden;
		/**/
}

.red {
		color:#f46245;
}

.orange{
		color:#ff9522;
}


/*section p
----------------------------------------------------*/

.section {
		margin:0 0 30px 0;
		width:100%;
}
.inner {
		width:100%;
}
.ml30 {
		margin-left: 30px;
}
.mr30{
		margin-right: 30px;
}

.btm0 {
		margin-bottom: 0!important;
}

.btm5 {
		margin-bottom:5px!important;
}

.btm10 {
		margin-bottom:10px!important;
}

.btm15 {
		margin-bottom:15px!important;
}

.btm20 {
		margin-bottom:20px!important;
}

.btm25 {
		margin-bottom:25px!important;
}

.btm30 {
		margin-bottom:30px!important;
}

.btm40 {
		margin-bottom:40px!important;
}


.top5 {
		margin-top:5px;
}

.top10 {
		margin-top:10px;
}

.top20 {
		margin-top:20px;
}
.top30 {
		margin-top: 30px;
}

.f10 {
		font-size:10px;
}

.f12 {
		font-size:12px!important;
}

.f13 {
		font-size: 13px!important;
}

.f14 {
		font-size:14px;
}

.f18 {
		font-size:18px!important;
}

p.l11 {
		line-height:1.1;
}

p.l13 {
		line-height:1.3;
}

.m0 {
		margin:0!important;
}

.tar {
		text-align:right;
}

.tac {
		text-align:center;
}

.f-l {
		float:left;
}

.f-r {
		float:right;
}

.lh15{
		line-height: 1.5;
}

.hover a:hover{
 	   opacity: 0.7; 
 	   filter: alpha(opacity=70); 
  	  -moz-opacity: 0.7;
}

.list_disc{
		margin-left: 20px;
}

.list_disc li{
		list-style: disc;
}

.list_num{
		margin-left: 20px;
		margin-bottom: 20px;
}

.list_num li{
		list-style-type: decimal;
}

.marker{
	font-size: 1.5em;
	background: #ffdd22;
	display: inline;
	font-weight: bold;
}

.strong01{
	font-size: 1.5em;
	font-weight: bold;
}

.strong02{
	font-size: 1.4em;
	font-weight: bold;
	color: #1ea955;
}

.bold{
	font-weight: bold;
}


/*ヘッダー
----------------------------------------------------*/
#header{
	border-bottom: 3px solid #1ea955;
}

.h_wrap{
	width: 95%;
	max-width: 1050px;
	margin: 0 auto;
	padding: 0 2.5%;
}

.h_copy{
	margin-top: 7px;
	display: block;
}

.h_copy h1{
	font-size: 12px;
	line-height: 1.5;
	color: #919995;
}

.h_conts{
	margin-top: 15px;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
}

.h_logo{
	align-self: center;
}

.h_logo p img{
	vertical-align: bottom;
}

.h_strong{
	display: -webkit-flex;
	display: flex;
}

.h_strong p{
	margin-left: 15px;
}

.h_strong p:first-of-type{
	margin-left: 0;
}

.h_strong p img{
	height: 27px;
}

.h_tel_contact{
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: flex-end;
	justify-content: flex-end;
}

.h_tel_num{
	line-height: 0;
	margin-bottom: 10px;
}

.h_tel_num img{
	width: auto;
	max-width: 100%;
	height: auto;
}

.h_tel_text p{
	font-size: 12px;
	font-weight: bold;
	line-height: 18px;
	margin-top: 12px;
}

.h_tel_text p:first-of-type{
	margin-top: 0;
}

.h_tel_contact dl{
	display: -webkit-flex;
	display: flex;
	font-size: 12px;
	line-height: 1.5;
}

.h_tel_contact dl dt{
	width: 5em;
}

.h_contact{
	margin-left: 25px;
}

.h_contact_btn{
	display: block;
}

.h_contact_btn a img{
	vertical-align: bottom;
}

.h_map{
	background: url(../images/common/ico_h_map.png) 2px center no-repeat;
	font-size: 12px;
	font-weight: bold;
	line-height: 18px;
	margin-top: 5px;
	padding: 6px 0 6px 30px;
}

.h_access{
	background: url(../images/common/ico_h_access.png) left center no-repeat;
	font-size: 12px;
	font-weight: bold;
	line-height: 18px;
	margin-top: 0;
	padding: 6px 0 6px 30px;
}

#sp_head,
#sp_top{
	display: none;
}


/*ナビ
----------------------------------------------------*/

.h_nav{
	margin-top: 30px;
}

.h_nav ul{
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
}

.h_nav ul li{
	width: calc(100% / 7 - 1px);
	border-left: 1px dotted #aaa;
	text-align: center;
	padding: 5px 0;
}

.h_nav ul li:last-child{
	width: calc(100% / 7 - 2px);
	border-right: 1px dotted #aaa;
}

.h_nav ul li a{
	color: #333;
	text-decoration: none;
}



/*ナビ
----------------------------------------------------*/
#scroll_menu{
	width: 100%;
	background: #fff;
	border-bottom: 1px solid #1ea955;
	padding: 15px 0;
	height: 50px;
	position: fixed;
	top: -86px;
	z-index: 99999;
	opacity: 0;
	transition: top 0.15s linear 0s, opacity 0.15s linear 0s;

	display: flex;
	align-items: center;
}

.scroll_menu_wrap{
	width: 95%;
	max-width: 1050px;
	margin: 0 auto;
	padding: 0 2.5%;
	
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-align-items: center;
	align-items: center;
}

.scroll_logo p{
	line-height: 0;
}

.scroll_logo img{
	width: 100%;
	max-width: 220px;
	height: auto;
}

.scroll_menu ul{
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
}

.scroll_menu ul li{
	margin-left: 15px;
	line-height: 1.2;
}

.scroll_menu ul li a{
	font-size: 14px;
	color: #333;
	text-decoration: none;
}


/*main-image
----------------------------------------------------*/

#mainimage{
	background: url(../images/top/mainimg_bg.jpg) top center repeat;
	width: 100%;
	max-height: 100%;
}

#mainimage p{
	text-align: center;
	line-height: 0;
}

#mainimage p img{
	width: 100%;
	max-width: 1050px;
}

.mainimage_sp{
	display: none;
}

.mainimage_sp_tel{
	display: none;
}

/*common
----------------------------------------------------*/
#main{
	position: relative;
}

.bg_yellow{
	background: #fff7dd;
}

.bg_dgreen{
	background: #1ea955;
}

.bg_green{
	background: #e9f6ee;
}

.mainconts{
	padding: 50px 0 60px;
}

.main_conts_wrap{
	width: 95%;
	max-width: 1050px;
	padding: 0 2.5%;
	margin: 0 auto;
}

.main_conts_wrap p{
	margin-bottom: 25px;
}

.main_conts_wrap p:last-of-type{
	margin-bottom: 0;
}

.ttl01{
	font-size: 32px;
	font-weight: bold;
	text-align: center;
	letter-spacing: 0.05em;
	color: #fff;
	line-height: 1.5;
	margin-bottom: 50px;
}

.ttl01 span{
	position: relative;
}

.ttl01 span:before{
	content: "";
	display: block;
	width: 46px;
	height: 83px;
	background: url("../images/common/ttl01_l.png") no-repeat left center;
	position: absolute;
	left: -66px;
	top: 0;
}

.ttl01 span:after{
	content: "";
	display: block;
	width: 46px;
	height: 83px;
	
	background: url("../images/common/ttl01_r.png") no-repeat left center;
	
	position: absolute;
	right: -46px;
	top: 0;
}

.ttl02{
	font-size: 36px;
	font-weight: bold;
	text-align: center;
	letter-spacing: 0.05em;
	color: #333;
	line-height: 1.5;
	margin-bottom: 40px;
}

.ttl02-red{
	font-size: 60px;
	font-weight: bold;
	text-align: center;
	letter-spacing: 0.05em;
	color: #f00;
	line-height: 1.5;
	margin-bottom: 10px;
}


.ttl02_sub{
	border: 1px dotted #777;
	border-left: none;
	border-right: none;
	padding: 10px 0;
	font-size: 16px;
	font-weight: bold;
	text-align: center;
	color: #333;
	margin-bottom:35px!important;
}

.ttl03{
	font-size: 18px;
	font-weight: bold;
	color: #1ea955;
	line-height: 1.5;
	border-bottom:1px solid #1ea955;
	padding-bottom:5px;
	margin-bottom: 20px;
}

.ttl04{
	font-size: 36px;
	font-weight: bold;
	text-align: center;
	text-decoration:underline;
	color: #fff;
	line-height: 1.5;
	margin-bottom: 50px;
}

.ttl05{
	display:inline-block;
	font-size: 20px;
	border-bottom: solid 2px;
	padding-bottom: 4px;
	line-height: 1;
	margin-bottom: 10px;
}

.ttl06{
	display: inline-block;
	color: #ee600a;
	font-size: 20px;
	font-weight: bold;
	border-bottom: solid 2px;
	padding-bottom: 4px;
	line-height: 1;
	margin: 40px 0 10px;
	position: relative;
}

.ttl07{
	font-size: 38px;
	font-weight: bold;
	line-height: 1.5;
	border-bottom: 2px solid;
	color: #8dbd3e;
	margin-bottom: 20px;
}

.tbl01,
.tbl01 tbody{
	display: block;
}

.tbl01 tbody tr{
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	
	border-top:1px solid #e7e7e7;
}

.tbl01 tbody tr:last-of-type{
	border-bottom:1px solid #e7e7e7;
}

.tbl01 tbody tr th,
.tbl01 tbody tr td{
	padding: 20px;
	font-size: 18px;
}

.tbl01 tbody tr th{
	width: 10em;
	background: #8dbd3e;
	color: #fff;
}

.tbl01 tbody tr td{
	background: #fff;
	width: calc(100% - 10em);
}

/*トップページ
----------------------------------------------------*/

/* トップイメージ */
.topimage_pc{
	margin-bottom: 0!important;
}

.topimage_pc img{
	vertical-align: bottom;
	max-width:100%;
}

.topimage_sp{
	display:none;
}

/* メディア掲載 */
.media_conts{
	padding: 50px 0 60px
}

.media_wrap{
	width: 95%;
	max-width: 1050px;
	padding: 0 2.5%;
	margin: 0 auto;
}

.media_lr{
	display: -webkit-flex;
	display: flex;
	-webkit-flex-direction: row-reverse;
	flex-direction: row-reverse;
	-webkit-justify-content: space-between;
	justify-content: space-between;
}

.media_img{
	margin:0 auto;
	text-align:center;
}

.media_img img{
	width: 100%;
	max-width: 800px;
}

.media_text{
	margin-right: 30px;
}

.media_text p{
	font-size: 22px;
	font-weight: bold;
	color: #fff;
}


/* 患者様の声　一番上 */
.main_voice_wrap{
	width: calc(100% - 40px);
	max-width: 900px;
	margin: 0 auto;
	
	background: #fff;
	border-radius: 10px;
	padding: 20px;
}

.mainvoice{
	width: 100%;
	max-width: 700px;
	margin: 0 auto;
}

.mainvoice_ttl{
	margin: 0 auto;
	line-height: 1.5;
	font-size: 30px;
	font-weight: bold;
	color: #64cccb;
	text-align: center;
}

.mainvoice_movie{
	width: 100%;
	max-width: 700px;
	margin: 20px auto;
}

.mainvoice_movie iframe{
	width: 100%;
	max-width: 700px;
	height: 350px;
}

.mainvoice dl{
	margin-bottom: 30px;
}

.mainvoice dl:last-of-type{
	margin-bottom: 15px;
}

.mainvoice dt{
	font-size: 16px;
	background: #f1f9ff;
	padding: 10px 15px 10px 35px;
	border-radius: 5px;
	margin-bottom: 10px;
	line-height: 1.8;
}

.mainvoice dt:before{
	content: "Q";
	font-size: 1.2em;	
	color: #64cccb;	
	line-height: 1;	
	margin-right: 5px;	
	margin-left: -20px;
}


/* あなたは、こんな悩みはありませんか？ */
.nayami_wrap{
	padding-bottom: 0 !important;
}

.nayami_conts{
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
}

.nayami_img{
	width: 100%;
	max-width: 210px;
	margin-left: 30px;
	margin-top: 30px;
	display: -webkit-flex;
	display: flex;
	-webkit-align-items: flex-end;
	align-items: flex-end;
}

.nayami_img img{
	width: 100%;
}

.nayami_list{
	margin-bottom: 50px;
}

.nayami_list ul li{
	background: url("../images/top/ico_list01.png") no-repeat left top;
	padding-left: 40px;
	margin-bottom: 18px;	
}

/* その悩み、当院にお任せください */
.omakase_conts{
	text-align: center;
}

.omakase_conts p{
	font-size: 20px;
	font-weight: bold;
	text-align: center;
}

.omakase_list{
	margin-top: 70px;
}

.omakase_list ul{
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	
	border: 3px solid #f73609;
	background: #fff;
	padding: 20px 30px;
	border-radius: 5px;
}

.omakase_list ul li{
	background:  url("../images/top/icon_nayami.png") no-repeat left top;
	padding-left: 35px;
	line-height: 2;
	margin:10px 35px 10px 0;
	
	font-size: 16px;
	font-weight: bold;
}

/* 患者様の声 */
.voice_list{
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: flex-start;
	justify-content: flex-start;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
}

.voice_conts{
	width: calc(50% - 20px);
	max-width: 495px;
	box-shadow: 0 1px 5px #ddd;
	margin-left: 0;
	margin-right: 20px;
	margin-top: 40px;
}

.voice_conts:nth-child(1),
.voice_conts:nth-child(2){
	margin-top: 0;
}

.voice_conts:nth-child(2n){
	margin-right: 0;
	margin-left: auto;
}

.voice_ttl{
	background: #1ea955;
	padding: 15px 15px 10px;
	border-radius: 5px 5px 0 0;
	font-size: 18px;
	font-weight: bold;
	color: #fff;
	letter-spacing: 0.05em;
	line-height: 1.5;
	text-align: center;
}

.voice_ttl span{
	display: block;
	font-size: 0.8em;
	font-weight: normal;
	width: 100%;
}

.voice_ttl span::before{
	content:'';
	display: block;
	width:100%;
	margin: 10px auto;
	border-top: 1px solid #1a9048;
}

.voice_img{
	padding: 20px 23px;
}

.voice_img img{
	width: 100%;
}

.voice_img iframe{
	width: 100%;
	height: 27vw;
	max-height: 293px;
}

.voice_text{
	padding: 0 10px 10px;
}

.voice_q{
	font-size: 16px;
	background: #fff;
	padding: 5px 10px 10px 35px;
	border: 2px dotted #1ea955;
	border-radius: 5px;
	margin-bottom: 10px;
	line-height: 1.5;
}

.voice_q:before{
	content: "Q";
	font-size: 1.75em;
	font-family: 'din-bold';
	color: #1ea955;
	line-height: 1;
	margin-left: -1em;
	padding: 0 5px;
}

.voice_text p{
	padding: 0 15px 10px;
	margin-bottom: 5px;
}

.kj {
	font-size: 90%;
	color: #888;
}

div.kj {
	margin:30px 0;
}

p.kj {
	margin-top: -8px;
}



/* 院長プロフィール */
.profile_wrap{
	margin-top: 40px;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-flex-direction: row-reverse;
	flex-direction: row-reverse;
}

.profile_img{
	width: 250px;
	margin-left: 40px;
}

.profile_text{
	width: calc(100% - 290px);
}

.profile_name{
	margin-top: 20px;
	font-size: 16px;
	font-weight: bold;
	color: #1ea955;
	text-align: center;
	line-height: 1.5;
}

.profile_name span{
	font-size:1.3em;
}

.profile_license{
	margin-top:30px;
}

.profile_license img{
	margin-bottom:10px;
}

.profile_recommend{
	width: calc(100% - 10px);
	max-width: 1050px;
	margin: 50px auto 0;
	border: 5px solid #64cccb;
	background: #fff;
	border-radius: 10px;
}

.profile_recommend_wrap{
	width: calc(100% - 100px);
	padding: 30px 50px;
}

.profile_recommend_ttl{
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: center;
	justify-content: center;
	font-size: 34px;
	font-weight: bold;
	line-height: 1.5;
	color: #64cccb;
	margin-bottom: 75px;
	position: relative;
}

.profile_recommend_ttl:after{
	content: "";
	display: block;
	width: 100%;
	border-bottom: 2px dashed #64cccb;
	margin: 0 auto;
	position: absolute;
	left: 0;
	right: 0;
	bottom: -25px;
}

.profile_recoomend_conts{
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
}

.profile_recommend_img{
	width: 100%;
	max-width: 245px;
}

.profile_recommend_text{
	width: calc(100% - 245px);
	margin-left: 30px;
}

.profile_recommend_ttl02{
	font-size: 28px;
	font-weight: bold;
	padding-bottom: 7px;
	border-bottom: 3px solid;
	margin-bottom: 13px;
}

.profile_recommend_profile span{
	font-size: 1.4em;
	font-weight: bold;
}


/* スタッフ紹介 */
.staff_wrap{
	margin-top: 50px;
}

.staff_conts{
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	
	margin-top: 50px;
}

.staff_img{
	width: 277px;
}

.staff_img img{
	width: auto;
	max-width: 100%;
}

.staff_info{
	width: calc(100% - 307px);
	margin-left: 30px;
}

.staff_voice{
	background: #fff;
	padding: 10px 20px;
	border-radius: 5px;
	
	margin-bottom: 10px;
	
	font-size: 26px;
	font-weight: bold;
	color: #f9a109;
	line-height: 1.5;
	
	position: relative;
}

.staff_voice:before{
	content: "";
	display: block;
	
	width: 0;
	height: 0;
	border: 15px solid transparent;
	border-right: 15px solid #fff;
	
	position: absolute;
	left: -27px;
	top: 14px;
}

.staff_name{
	font-size: 24px;
	font-weight: bold;
}

.staff_info dl{
	display: -webkit-flex;
	display: flex;
}

.staff_info dl dt{
	margin-right: 5px;
}


/* 施術時間について */
.service_time{
	width: calc(100% - 62px);
	max-width: 780px;
	margin: 0 auto;
	background:#e9f6ee;
	padding: 30px;
	border-radius: 10px;
	display:-webkit-flex;
	display:flex;
}

.service_time_img{
	width:90px;
}

.service_time_text{
	width: calc(100% - 90px);
	margin-left: 40px;
}

.service_time_ttl01{
	display: block;
	font-size: 18px;
	font-weight: bold;
	color: #1ea955;
	margin-bottom: 15px !important;
	line-height: 1.5;
}

.service_time_text p{
	margin-bottom:0;
}

.service_time_conts{
	margin-top: 20px;
	color: #64cccb;
}

.service_time_conts:first-of-type{
	margin-top: 0;
}

.service_time_ttl02{
	font-size: 24px;
	font-weight: bold;
	color: #64cccb;
	letter-spacing: 0.04em;
	margin-bottom: 0 !important;
}


/* 施術の流れ */
.flow_conts_wrap{
	counter-reset: num;
}

.flow_conts{
	margin-top: 30px;
}

.flow_ttl01{
	font-size: 24px;
	font-weight: bold;
	line-height: 1.4;
	margin-bottom: 15px;
	position: relative;
}

.flow_ttl01:before{
	content: counter(num);
	counter-increment: num;
	font-size: 1.25em;
	line-height: 1.4;
	font-family:'din-bold';
	font-weight:500;
	margin-right: 20px;
	background-color: #1ea955;
	color: #fff;
	padding: 1px 15px;
}

.flow_conts_inline{
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-flex-direction: row;
	flex-direction: row;
	margin-top: 30px;
}

.flow_img{
	width: 100%;
	max-width: 350px;
}

.flow_text{
	width: calc(100% - 350px);
	margin-left: 30px
}

.message_text{
	padding: 30px 50px;
	border: 2px solid #f88600;
	border-radius: 10px;
	box-sizing: border-box;
	margin-top: 30px;
}

.message_text02{
	background: #f4eee6;
	padding: 30px 50px;
	border-radius: 10px;
	margin-top: 30px;
}


/*選ばれる7つの理由*/

.select_conts_wrap{
	counter-reset: selectnum;
}

.select_conts{
	margin-top: 80px;
	counter-increment: selectnum;
}

.select_conts:first-of-type{
	margin-top: 40px;
}

.select_ttl01{
	background: #ff9522;
	color: #fff;
	padding: 17px;
	border-radius: 5px;
	margin-bottom: 30px;
	font-size: 20px;
	font-weight: bold;
	padding-left: 118px;
	line-height: 1.5;
}

.select_ttl01:before{
	content: "理由" counter(selectnum);
	background: #fff;
	padding: 5px 7px;
	border-radius: 5px;
	margin-right: 1em;
	margin-left: -88px;
	font-weight: bold;
	color: #13a04a;
}

.select_conts .ttl06::before{
	content:url(../images/top/arrow_d.png);
	width:24px;
	height:26px;
	position: absolute;
	left: 0;
	top: -40px;
}

.select_conts_inline{
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	
}

.select_conts_lr{
	-webkit-flex-direction: row-reverse;
	flex-direction: row-reverse;
}

.select_conts_rl{
	-webkit-flex-direction: row;
	flex-direction: row;
}


.select_conts_lr .select_img,
.select_conts_rl .select_img{
	width: 250px;
}

.select_img img{
	width: auto;
	max-width: 100%;
}

.select_conts_lr .select_text{
	width: calc(100% - 250px);
	margin-right: 30px;
}

.select_conts_rl .select_text{
	width: calc(100% - 250px);
	margin-left: 30px;
}

.select_text .bold{
	font-size:1.1em;
}

.select_conts_tb{
	display: -webkit-flex;
	display: flex;
	-webkit-flex-direction: column;
	flex-direction: column;
}

.select_conts_tb .select_img{
	margin-top: 30px;
	min-height: 0%;
}

.select_conts_tb .select_img ul{
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
}

.select_conts_tb .select_img ul li{
	margin-left: 30px;
	width: calc(100% / 3 - 20px);
}

.select_conts_tb .select_img ul li:first-child{
	margin-left: 0;
}



.select_recommend{
	border: 3px solid #8dbd3e;
	background: #fff;
	padding: 20px;
	border-radius: 10px;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
}

.recommend_ttl01{
	font-size: 24px;
	font-weight: bold;
	color: #8dbd3e;
	border-bottom: 2px dashed;
	margin-bottom: 15px;
}

.recommend_voice{
	background: #8dbd3e;
	padding: 15px;
	border-radius: 10px;
	font-size: 20px;
	font-weight: bold;
	line-height: 1.7;
	color: #fff;
	position: relative;
}

.recommend_voice:before{
	content: "";
	display: block;
	width: 0;
	height: 0;
	border: 20px solid transparent;
	border-right: 20px solid #8dbd3e;
	position: absolute;
	left: -30px;
	top: 10px;
}

.recommend_text{
	width: 100%;
	margin-top: 30px;
}



/* 施術料金・初回特別割引 */

.price_tbl,
.price_tbl tbody{
	display: block;
}

.price_tbl tr{
	display: -webkit-flex;
	display: flex;
	border: 1px solid #bfcfc5;
}

.price_tbl tr:first-of-type{
	border-bottom: 0;
}

.price_tbl tr th{
	display: block;
	width: 15em;
	padding: 20px;
	text-align: center;
	font-weight: bold;
	background: #e9f6ee;
	border-right: 1px solid #bfcfc5;
	font-size: 18px;
}

.price_tbl tr td{
	display: block;
	width: calc(100% - 15em);
	padding: 20px;
	font-size: 18px;
}

.price_tbl tr td span{
	font-size: 1.2em;
}

.price_offer{
	margin-top: 50px;
}

.price_offer_text01{
	font-size: 35px;
	font-weight: bold;
	line-height: 1.5;
	text-align: center;
	color: #ee600a;
}

.price_offer_limit01{
	margin-top: 40px;
	
	border-top: 1px solid #282624;
	border-bottom: 1px solid #282624;
	padding: 25px 0 15px;
}

.price_offer_limit01 p{
	font-size: 30px;
	font-weight: bold;
	color: #282624;
	text-align: center;
	line-height: 1.5;
}

.price_offer_limit01 span{
	font-size: 55px;
	color: #fb1e1e;
}

.price_offer_mainimg{
	margin: 30px auto;
	text-align: center;
}

.price_offer_mainimg img{
	width: auto;
	max-width: 100%;
}

.price_offer_limit02{
	font-size: 30px;
	font-weight: bold;
	color: #282624;
	text-align: center;
	line-height: 1.5;
	
	background: #fff5cc;
	display: block;
	width: calc(100% - 40px);
	padding: 20px;
	border-radius: 5px;
}

.member_num_close{
	text-decoration: line-through;
}

.member_num_limit{
	font-size: 1.5em;
	text-decoration: underline;
	color: #f73609;
}

.offer_conts_line{
	margin-top: 30px;
}

.offer_conts_line_pc img{
	width: auto;
	max-width: 100%;
}

.offer_conts_line_sp{
	display: none;
}



/* なぜ、初回は */
.conts_divide{
	margin: 40px auto;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
}

.conts_divide_l,
.conts_divide_r{
	width: 47.5%;
	background: #fff;
	border-radius: 10px 10px 0 0;
}

.conts_divide_ttl{
	font-size: 18px;
	font-weight: bold;
	text-align: center;
	color: #fff;
	background: #1ea955;
	padding: 10px 20px;
	border-radius: 10px 10px 0 0;
}

.conts_divide_text{
	padding: 20px;
}

.conts_divide_false li{
	background: url("../images/top/ico_false.png") no-repeat left 4px;
	padding-left: 30px;
	margin-bottom: 12px;
}

.conts_divide_false li:last-child{
	margin-bottom: 0;
}

.conts_divide_true li{
	background: url("../images/top/ico_true.png") no-repeat left 4px;
	padding-left: 30px;
	margin-bottom: 12px;
}

.conts_divide_true li:last-child{
	margin-bottom: 0;
}

.first_recall{
	margin-top: 50px;
}


/* 来院特典 */

.specialgift{
	display: -webkit-flex;
	display: flex;
	justify-content:space-between;
}

.specialgift li{
	width:30%;
	text-align: center;
}

.specialgift li figure img{
	width:auto;
	max-width:100%;
	margin:0 auto;
}

.specialgift_ttl{
	font-size: 18px;
	font-weight: bold;
	line-height: 1.5;
	color: #1ea955;
	display: block;
	margin: 20px 0;
}

.specialgift_text p{
	text-align:left;
}


/* オファー */

.offer_conts01_ttl{
	font-size: 36px;
	font-weight: bold;
	line-height: 1.6;
	text-align: center;
	color: #fff;
	display: block;
}

.offer_conts01_ttl span{
	position:relative;
}

.offer_conts01_ttl span::before{
	content:'';
	display:block;
	width:68px;
	height:114px;
	background: url(../images/top/offer_ttl_l.png) left center no-repeat;
	position:absolute;
	top:5%;
	left:-15%;
}

.offer_conts01_ttl span::after{
	content:'';
	display:block;
	width:68px;
	height:114px;
	background:url(../images/top/offer_ttl_r.png) right center no-repeat;
	position:absolute;
	top:5%;
	right:-15%;
}

.offer_conts01_img{
	margin: 30px auto;
	text-align: center;
	width:100%;
}

.offer_conts01_img img{
	width: auto;
	max-width: 100%;
}

.offer_conts02{
	width: calc(100% - 42px);
	background: #fff;
	color: #282624;
	padding: 10px 20px;
	margin: 30px auto;
}

.offer_conts02 p{
	font-size: 42px;
	color: #282624;
	font-weight: bold;
	text-align: center;
	letter-spacing: 0.04em;
	line-height: 1.2;
}

.offer_conts02 p span{
	font-size: 1.3em;
	color: #f73609;
}


.offer_conts03_pc,
.offer_conts03_img{
	position: relative;
}

.offer_conts03_sp{
	display: none;
}

.offer_conts03_img img{
	width: auto;
	max-width: 100%;
}

.offer_telbtn{
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: flex-end;
	justify-content: flex-end;
	position: absolute;
	bottom: 2.6vw;
	right: 4.7%;
}

.offer_telbtn{
	width: 60%;
}

.offer_telbtn img{
	width: auto;
	vertical-align: bottom;
	max-width: 100%;
}

.offer_conts04{
	color: #fff;
	margin-top: 30px;
}

.offer_conts04 p{
	font-size: 13px;
	line-height: 2;
	margin-bottom: 0;
}

/* 施術メニュー */
.menulist_conts{
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	
	margin-top: 50px;
}

.menulist_conts:first-of-type{
	margin-top: 0;
}

.menulist_img{
	width: 200px;
}

.menulist_text{
	width: calc(100% - 230px);
	margin-left: 30px;
}


/* 整体院の紹介 */
.info-gaikan{
	margin: 30px 0 50px;
}

.info-gaikan ul{
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
}

.info-gaikan ul li{
	width: calc(100% - 25px);
	margin-right: 50px;
}

.info-gaikan ul li:last-child{
	margin-right: 0;
}

.info-gaikan ul li img{
	width: auto;
	max-width: 100%;
	height: auto;
}

.info-naikan{
	margin-top: 30px;
}

.info-naikan ul{
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
}

.info-naikan ul li{
	width: calc(100% / 3);
	max-width: 330px;
	margin-right: 30px;
}

.info-naikan ul li:last-child{
	margin-right: 0;
}

.info-naikan ul li figure{
	margin-bottom: 10px;
}

.info-naikan ul li figure img{
	width: auto;
	max-width: 100%;
}

.info-naikan ul li p{
	line-height: 1.8;
}


/* アクセス */
.access_info_wrap{
	margin-top: 40px;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
}

.access_map{
	width: 100%;
	max-width: 540px;
}

.access_map iframe{
	width: 540px;
	height: 395px;
}

.access_mapinfo{
	width: calc(100% - 540px);
	margin-left: 50px;
}

.access_map_conts{
	margin-bottom: 20px;
}

.access_map_conts p{
	margin-bottom: 0;
}

.access_mapinfo dl{
	display: -webkit-flex;
	display: flex;
	margin-bottom: 4px;
}

.access_mapinfo dl dt{
	width: 5em;
}

.access_mapinfo dl dd{
	width: calc(100% - 5em);
}

.access_mapinfo-openconts{
	margin-bottom: 8px;
}

.access_mapinfo-openconts:last-of-type{
	margin-bottom: 0;
}

.access_map_ttl01{
	font-size: 15px;
	font-weight: bold;
}

.access_route{
	margin-top: 50px;
}


.access_routelist{
	margin-top: 40px;
	counter-reset: guidenum;
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
}

.access_routelist li{
	width: calc(100% / 3 - 50px);
	max-width: 300px;
	position: relative;
	margin-bottom: 25px;
	text-align: center;
	vertical-align: top;
	margin-left: 75px;
}

.access_routelist li:nth-child(3n+1){
	margin-left: 0;
}


.access_routelist li:before {
	content: url("../images/top/arrow_r.png");
	width:26px;
	height:24px;
	position: absolute;
	left: -49px;
	top: 36%;
}

.access_routelist li:first-child:before,
.access_routelist li:nth-child(3n+1):before{
	content: none;
}

.access_routelist li img{
	width: auto;
	max-width: 100%;
}

.access_routelist_text{
	line-height: 1.5;
	margin: 10px 0 0 2em;
	text-align: left;
}

.access_routelist_text:before{
	color: #1ea955;
	content: counter(guidenum) ".";
	counter-increment: guidenum;
	font-size: 30px;
	font-family: 'din-bold';
	line-height: 1;
	margin-left: -1.25em;
	padding:0 6px;
}


/* よくある質問 */
.faq_conts{
	background: #fff;
	border-radius: 10px;
	padding: 30px;
	margin-bottom: 20px;
}

.faq_ttl{
	color: #ee600a;
	font-size:18px;
	font-weight: bold;
	line-height:30px;
	padding-left:60px;
	position:relative;
	margin-bottom:25px;
}

.faq_ttl::before{
	content:'';
	background:url(../images/top/ico_q.png) left center no-repeat;
	width:40px;
	height:40px;
	position:absolute;
	top:-5px;
	left:0;
}

.faq_text{
	padding-left:60px;
	position:relative;
}

.faq_text::before{
	content:'';
	background:url(../images/top/ico_a.png) left center no-repeat;
	width:40px;
	height:40px;
	position:absolute;
	top:-5px;
	left:0;
}

/* 最後に... */
.last_conts_wrap{
	margin-top: 40px;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-flex-direction: row;
	flex-direction: row;
}

.last_conts_img{
	width: 250px;
	margin: 0 40px 40px 0;
}

.last_conts_text{
	width: calc(100% - 290px);
}

.last_choice_wrap{
	margin-top: 40px;
}

.last_choice{
	counter-reset: guidenum;
	margin-bottom:30px;
}

.last_choice li{
	padding-left:40px;
	margin-bottom:10px;
}

.last_choice li::before{
	color: #1ea955;
	content: counter(guidenum) ".";
	counter-increment: guidenum;
	font-size: 28px;
	font-family: 'din-bold';
	line-height: 1;
	margin-left:-40px;
	margin-right:15px;
}


/* pagetop */
#pagetop{
	position: absolute;
	bottom: 10px;
	right: 2.5%;
	line-height: 0;
}

#pagetop img{
	width: auto;
	max-width: 100%;
}


/*下層ページ
----------------------------------------------------*/
#breadcrumb{
	width: 95%;
	max-width: 1050px;
	padding: 0 2.5%;
	margin: 5px auto 0;
}

#breadcrumb ul{
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
}

#breadcrumb ul li{
	font-size: 13px;
}

#breadcrumb ul li:before{
	content: ">";
	margin: 0 5px;
}

#breadcrumb ul li:first-child:before{
	content: none;
}


.contact_tel,
.contact_mail{
	margin-top: 40px;
}

.contact_tel p{
	margin-bottom: 5px;
}

.contact_telnum a{
	font-size: 1.5em;
	font-weight: bold;
}

.contact_tel dl{
	display: -webkit-flex;
	display: flex;
	margin-bottom: 10px;
}

.contact_tel dl dt{
	width: 5em;
}

.contact_tel dl dd{
	width: calc(100% - 5em);
}

.contact_form{
	width: calc(100% - 80px);
	background: #e9f6ee;
	padding: 30px 40px;
	margin-top: 40px;
}


.form_tbl tr{
	display: -webkit-flex;
	display: flex;
	-webkit-flex-direction: column;
	flex-direction: column;
	padding-bottom: 20px;
	border-bottom: 1px dashed #aaa;
	margin-bottom: 20px;
}

.form_tbl tr th{
	width: 100%;
	display: block;
	text-align: left;
	font-size: 18px;
	font-weight: normal;
	line-height: 1.5;
	margin-bottom: 5px;
}

.form_tbl tr td{
	width: 100%;
	display: block;
}

.form_tbl tr td input{
	font-size: 17px !important;
}

.required{
	background: #1ea955;
	padding: 0 5px;
	font-size: 0.8em;
	color: #fff;
	margin-left: 10px;
	display: inline-block;
}


.form_name{
	display: block;
	width: 100%;
	max-width: 25em;
}

.form_mail{
	display: block;
	width: 100%;
	max-width: 30em;
}

.form_tel{
	display: block;
	width: 100%;
	max-width: 10em;
}

.form_reserve01,
.form_reserve02,
.form_reserve03{
	width: 100%;
	max-width: 20em;
}

.form_textarea{
	display: block;
	width: 100%;
	min-height: 200px;
}

.form_confirm{
	font-size: 16px;
	text-align: center;
}

.form_submit{
	margin-top: 15px;
	text-align: center;
}

.form_submit input{
	width: 100%;
	max-width: 500px;
	padding: 20px 0;
	margin: 0 auto;
	font-size: 25px;
	font-weight: bold;
	color: #fff;
	letter-spacing: 0.05em;
	border: none;
	background: #ff9522;
	border-radius: 100px;
	-webkit-appearance: none;
	box-shadow: 0 4px 0 0 #e5861e;
}

.form_submit input[disabled]{
	background: #ccc;
	box-shadow: 0 4px 0 0 #ccc;
}

.wpcf7-form-control-wrap{
	max-width: inherit;
}


/*wordpress
----------------------------------------------------*/
.blog_conts{
	width: 95%;
	max-width: 1050px;
	padding: 20px 2.5%;
	margin: 0 auto 50px;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
}

.blog_main{
	width: calc(80% - 71px);
}

.single_date{
	background: #afc727 none repeat scroll 0 0;
	color: #fff;
	display: inline-block;
	font-size: 13px;
	padding: 1px 10px;
}

.s_ttl01{
	color: #1ea955;
	font-size: 32px;
	font-weight: bold;
	line-height: 1.2;
	margin: 15px 0;
	text-align: left;
}

.blog_cat{
	border-bottom: 1px dashed #aaa;
	margin-bottom: 20px;
	padding-bottom: 20px;
}


.blog_side{
	width: 20%;
	max-width: 250px;
	border-left: 1px solid #bfcfc5;
	padding-left: 35px;
	margin-left: 35px;
}

.side_blog_ttl{
	color: #333;
	font-size: 19px;
	font-weight: bold;
	margin-bottom: 5px !important;
}

.blog_single p{
	margin-bottom: 15px;
}

.blog_single img{
	width: auto;
	max-width: 100%;
	height: 100%;
}

.blog_single img.alignright{
	float: right;
	margin-left: 10px;
}

.blog_single img.alignleft{
	float: left;
		margin-right: 10px;
}


.blog_single .single_date{
	margin-bottom: 0;
}

.single_ttl{
	color: #1ea955;
	font-size: 32px;
	font-weight: bold;
	line-height: 1.2;
	margin: 15px 0;
	text-align: left;
	
	border-bottom: 1px dashed #e1d8cc;
}

.single_cat p{
	float: left;
}

.blog_single h3{
	border-left: 10px solid #1ea955;
	border-bottom: 1px solid #1ea955;
	font-size: 1.6em;
	font-weight: bold;
	color: #333;
	margin: 50px auto 25px;
	padding: 10px 0 10px 15px;
}

.blog_single h4{
	border-bottom: 1px dashed #bfcfc5;
	font-size: 1.4em;
	font-weight: bold;
	color: #1ea955;
	margin: 30px auto 15px;
	padding-bottom: 5px;
}

.blog_single ul{
	margin-bottom: 30px;
	background: #f2faf5;
	border: 1px solid #1ea955;
	padding: 15px;
	border-radius: 5px;
}

.blog_single li{
	background: url("../images/top/ico_list01.png") no-repeat left top;
	padding-left: 40px;
	margin-bottom: 0.8em;
	
	font-size: 1.2em;
	
	border-bottom: 1px dashed #1ea955;
}

.blog_single li:last-child{
	margin-bottom: 0;
}

.blog_single p {
	margin-bottom: 20px;
}

.wp-pagenavi{
	text-align: center;
}

.side_menu{
	margin-bottom: 30px;
}

.side_menu ul{
	border-top: 2px solid #1ea955;
	border-bottom: 1px solid #bfcfc5;
	padding: 5px 10px;
}

.side_menu li{
	border-bottom: 1px dashed #bfcfc5;
	margin-top: 8px;
	padding-bottom: 5px;
	padding-left: 1.3em;
	line-height: 1.6;
}

.side_menu li:before{
	content: url("../images/common/ico01.png");
	margin-left: -1.3em;
	margin-right: 5px;
	padding-top: 2px;
	vertical-align: middle;
}

.side_menu li:last-child{
	border-bottom: none;
	padding-bottom: 0;
}

.side_menu li a{
	text-decoration: none;
}



/*フッター
----------------------------------------------------*/

#sp_telbnr{
	display: block;
	width: 100%;
	line-height: 0;
	opacity: 1;
	position: fixed;
	left: 0;
	bottom: -200px;
	transition: all 0.4s linear 0s;
}

#footer{
	border-top: 6px solid #fff;
	background: #fcfaf8;
}

.f_wrap{
	width: 95%;
	max-width: 1050px;
	margin: 0 auto;
	padding: 40px 2.5%;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
}

.f_conts_l{
	font-size: 13px;
	color: #919995;
	line-height: 1.5;
}

.f_logo{
	margin-bottom: 20px;
}

.f_logo a:hover{
	opacity: 1;
}

.f_conts_l dl{
	display: -webkit-flex;
	display: flex;
	margin-bottom: 8px;
}

.f_conts_l dl dt{
	width: 4em;
}

.f_conts_l dl dd{
	width: calc(100% - 4em);
}

.f_conts_l dl dd .f_conts-openconts{
	margin-bottom: 8px;
}

.f_conts_l dl dd .f_conts-openconts:last-of-type{
	margin-bottom: 0;
}

.f_conts_r{
	display: -webkit-flex;
	display: flex;
	font-size:13px;
}

.f_conts_r dl {
	margin-left: 50px;
}

.f_conts_r dl dt{
	font-size: 14px;
	font-weight: bold;
	color: #919995;
}

.f_conts_r dl dd a{
	background: url("../images/common/ico01.png") no-repeat left 3px;
	padding-left: 20px;
	color: #919995;
	text-decoration: none;
}

.f_cr{
	width: 100%;
	font-size: 13px;
	color: #919995;
	background: #f4efe9;
	text-align: center;
	padding: 5px 0;
}