@charset "utf-8";

.yoyaku {
	margin-bottom:40px;
}

.yoyaku iframe {
	width: 100%;
    height: 210px;
}

/*
.yoyaku iframe {
	width: -webkit-fill-available;
    height: 210px;
}
*/


/* Base
----------------------------------------------------*/


body {
	font-family: 'Noto Serif JP', serif;
	font-weight: 400;
	color: #575755;
	font-size: 17px;
	line-height: 1.7em;
}

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, font, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td{
    margin: 0;
    padding: 0;
    vertical-align: baseline;
    font-family: 'Noto Serif JP', serif;
	font-weight: 400;
}

h1, h2, h3, h4, h5, h6{
line-height:1.3;
font-weight:normal;
font-size:100%;
}

p,
li,
dt, dd,
th, td{
}

ul, ol{
list-style-type:none;
list-style-position:outside;
}

img{
	vertical-align: bottom;
}

a img{
	border: 0;
}


/* メインメニュー　PC用
------------------------------------------------------------*/
@media only screen and (min-width: 481px){

.spDisp {
	display: none;
}

.spHide {
	display:block;
}
.pcHide {
	display:none;
}

.midashi1_g {
	font-family: 'Noto Serif JP', serif;
	font-weight: 400;
	font-size: 40px;
	margin-bottom: 6%;
	text-align: center;
	color: #747472;
}

.midashi1_g span{
	font-family: 'Noto Serif JP', serif;
	font-weight: 400;
	font-size: 20px;
	text-align: center;
	color: #888985;
}

.midashi1_w {
	font-family: 'Noto Serif JP', serif;
	font-weight: 400;
	font-size: 40px;
	margin-bottom: 6%;
	text-align: center;
	color: #E1E1D8;
}

.midashi2 {
	font-family: 'Noto Serif JP', serif;
	font-weight: 400;
	font-size: 28px;
	margin-bottom: 30px;
	color: #646561;
}

.midashi3 {
	display: flex;
	align-items: center;
	gap: 18px;           /* 見出しと線の間隔 */
	font-size: 18px;
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
	margin-bottom: 20px;
}

.midashi3::after{
	content: "";
	flex: 1;             /* ここで右側を伸ばす */
	height: 1px;    /* 線の色 */
	border-radius: 1px;
	background-color: #D2D2D2;
}

.midashi4 {
	font-family: 'Noto Serif JP', serif;
	font-weight: 400;
	font-size: 23px;
	border-left-width: 4px;
	border-left-style: solid;
	border-left-color: #888985;
	padding-left: 20px;
}

.min1200 {
	min-width:1200px;
	position: relative;
}


/*　ヘッダー　*/


header {

}

.toph1 {
	display:none;
}

.header_back {
	background-image: url(../img/main_imgb.webp);
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size:cover;
	padding-top: 120px;
}

.head_cont {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-right: 5%;
	margin-left: 5%;
	padding-top:2%;
}

.header_logo {
	width: 340px;
}

.header_logo img{
	width:100%;
	height:auto;
}

.header_info {
	width: 120px;
}

.header_info img{
	width:100%;
	height:auto;
}


/*　グローバルナビ　*/



/*　メインイメージ　*/

.main_img {
	width:38%;
	padding:5% 0 8% 7%;
}

.main_img img{
	width:100%;
	height:auto;
}

.main1_wrap {
	min-width: 1200px;
	background: linear-gradient(1deg, #fdfefe, #e9e0d8);
	margin-top:-11em;
	padding-top:9.5em;
}

.main1 {
	background-image: url(../img/main1_back.webp);
	background-repeat: no-repeat;
	background-position: right bottom;
	background-size: 40%;
}

.main1 h2 {
	font-family: quiche-sans, sans-serif;
	font-weight: 300;
	font-style: normal;
	font-size: 112px;
	text-align: center;
	color: #C5CBCD;
	margin-bottom:20px;
}

.main1_1 {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 80px;
}

.main1_1t {
	width:46%;
	display: flex;
	justify-content: center;
	align-items: center;
	margin-left:5%;
}

.main1_1t h3{
	font-size: 20px;
	color: #76776C;
	font-family: 'Noto Serif JP', serif;
	font-weight: 400;
	width: 100%;
	margin-bottom: 70px;
}

.main1_1t p{
	color: #76776C;
	font-family: 'Noto Serif JP', serif;
	font-weight: 400;
	width: 100%;
	line-height: 2.5em;
}

.main1_1p {
	width:46%;
}

.main1_1p img{
	width:100%;
	height:auto;
}

.main1_2 {
	width: 90%;
	margin-right: auto;
	margin-left: auto;
	padding-bottom:100px;
}

.main1_2 h3{
	font-family: "Noto Serif JP", serif;
	font-weight: 400;
	font-size: 57px;
	color: #8F8F92;
	text-align: center;
	margin-bottom: 5px;
}

.main1_2 h4{
	font-family: "Noto Serif JP", serif;
	font-weight: 500;
	font-size: 18px;
	color: #8F8F92;
	text-align: center;
	margin-bottom: 80px;
}

.main1_2 ul {
	display: flex;
	justify-content: center;
	align-items: flex-start;
	flex-wrap: wrap;
	margin-bottom:30px;
}

.main1_2 ul li {
	border-top-width: 2px;
	border-top-style: solid;
	border-top-color: #CFCEC1;
	width:360px;
	margin:0 3% 5% 3%;
	padding-top:30px;
}

.main1_2 ul li h3 {
	color: #B8BEC1;
	font-size: 15px;
	font-family: 'Noto Serif JP', serif;
	font-weight: 400;
	text-align: center;
	margin-bottom:30px;
}

.main1_2 ul li h3 span{
	color: #B8BEC1;
	font-size: 21px;
	margin-right:15px;
	font-family: 'Noto Serif JP', serif;
	font-weight: 400;
}

.main1_2 ul li div {
	display: flex;
	justify-content: center;
	align-items: center;
	height:80px;
}

.main1_2 ul li p{
	color: #8F8F92;
	font-size: 25px;
	text-align: center;
	font-family: 'Noto Serif JP', serif;
	font-weight: 400;
	line-height: 1.6em;
}

.main1_btn {
	display: flex;
	justify-content: center;
	width: 300px;
	text-align: center;
	text-decoration: none;
	margin-right: auto;
	margin-left: auto;
	padding-top: 25px;
	padding-bottom: 30px;
	border: 1px solid #8F8F92;
}

.main1_btn p{
	font-size: 20px;
	color: #7D7D80;
	font-family: 'Noto Serif JP', serif;
	font-weight: 400;
}

.main1_btn:hover {
	background-color: #F1F1EF;
	border: 1px solid #F1F1EF;
}

.main2 {
	min-width: 1200px;
	background-color: #EFEFEF;
	background-image: url(../img/main2_back.webp);
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size:100%;
}

.main2_c {
	width: 90%;
	margin-right: auto;
	margin-left: auto;
	padding:5% 0;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.main2_pic {
	width: 30%;
	padding: 5%;
}

.main2_pic img {
	width:100%;
	height:auto;
	transition: opacity 0.4s ease;
}

.main2_pic img.fade {
  opacity:0.3;
}

.main2_list {
	width:55%;
}

.main2_list ul {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	flex-wrap: wrap;
}

.main2_list ul li{
	width: 48%;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #BABEB6;
}

.main2_list ul li a{
	display: block;
	padding: 30px 0px 30px 10px;
	text-decoration: none;
	color: #8F8F92;
	font-family: "Noto Serif JP", serif;
	font-weight: 400;
	font-size: 21px;
	background-image: url(../img/main2_arr.svg);
	background-repeat: no-repeat;
	background-position: right center;
	background-size: 35px;
}

.main2_list ul li a:hover{
	 opacity:0.3;
}

.main3 {
	min-width: 1200px;
	background-image: linear-gradient(2deg, #c9d2d7, #94acb6 48%, #aabac3);
	padding-top: 70px;
}

.main3_1 {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom:70px;
}

.main3_1 div:nth-child(1){
	width:500px;
	margin-left:5%;
	margin-right:5%;
}

.main3_1 div:nth-child(1) h4{
	font-family: quiche-sans, sans-serif;
	font-weight: 300;
	font-style: normal;
	font-size: 92px;
	color: #FCFBEF;
}

.main3_1 div:nth-child(2){
	flex: 1;
}

.main3_1 div:nth-child(2) ul{
	display: flex;
	justify-content: space-between;
	align-items: stretch;
	margin-right:0.5%;
}

.main3_1 div:nth-child(2) ul li{
	width:33%;
}

.main3_1 div:nth-child(2) ul li img{
	width:100%;
	height:auto;
}

.main3_back {
	background-image: url(../img/main3_back.webp);
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size:100%;
}

.main3_2 {
	width: 90%;
	margin-right: auto;
	margin-left: auto;
	margin-bottom: 80px;
}

.main3_2 h4{
	font-family: "Noto Serif JP", serif;
	font-weight: 400;
	font-size: 57px;
	color: #EFEFEF;
	margin-bottom:40px;
}

.main3_2 ul {
	display: flex;
	justify-content: space-between;
	align-items: stretch;
	flex-wrap: wrap;
}

.main3_2 ul li{
	width:16%;
	padding:0 3%;
	margin-bottom:1.5%;
}

.main3_2 ul li img{
	width:100%;
	height:auto;
	margin-bottom:20px;
}

.main3_2 ul li p{
	font-size:15px;
	line-height:1.4em;
}

.main3_3 {
	width: 90%;
	margin-right: auto;
	margin-left: auto;
	display: flex;
	justify-content: space-between;
	align-items: stretch;
	padding-bottom:120px;
}

.main3_3 div{
	width:46%;
}

.main3_3 div h4{
	font-family: quiche-sans, sans-serif;
	font-weight: 300;
	font-style: normal;
	font-size: 79px;
	color: #FCFBEF;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #FFFFFC;
	padding-bottom:20px;
}

.main3_3 div h4 span{
	font-family: 'Noto Serif JP', serif;
	font-weight: 400;
	font-size: 16px;
	color: #FCFBEF;
	margin-left:20px;
}

.main3_3 div p{
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #FFFFFC;
	padding:40px 20px;
	color: #FCFBEF;
}

footer {
	min-width: 1200px;
	background-color: #B1BFC8;
	color: #FFF;
	padding-top: 70px;
}

.footer_c {
	display: flex;
	justify-content:flex-start;
	align-items: flex-start;
	width: 90%;
	margin-right: auto;
	margin-left: auto;	
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #FFF;
	padding-bottom:60px;
	margin-bottom:60px;
}

.foot1_1 {
	width: 450px;
}

.foot1_1 img{
	width:100%;
	height:auto;
}

.foot1_2 {
	flex: 1;
}

.foot_logo {
	width:280px;
	margin-bottom: 40px;
	margin-left:5%;
}

.foot_logo img{
	width:100%;
	height:auto;
}

.foot_map {
	margin-bottom:30px;
}

.foot_map a {
	font-size: 18px;
	color: #FFF;
	text-decoration: none;
	padding-bottom: 10px;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #FFF;
	background-image: url(../img/foot_gm.svg);
	background-repeat: no-repeat;
	background-position: right center;
	background-size:20px;
	padding-right:30px;
	letter-spacing:0.1em;
}

.foot_map a:hover {
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #D9D9D9;
	color: #D9D9D9;
	background-image: url(../img/foot_gm-h.svg);
}

.foot_phone {
	width: 220px;
	display: flex;
	justify-content: center;
	align-items: center;
	border: 1px solid #FFF;
	border-radius: 5px;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
	padding:15px 0;
}
	
.foot_phone.menubox {
	width: 220px;
	display: flex;
	justify-content: center;
	align-items: center;
	border: 1px solid #FFF;
	border-radius: 5px;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
	padding:15px 0;
	    margin: 18px auto 0;
    padding: 14px 18px;
    width: min(280px, 92%);
	border: 1px solid #bfb6a3;
    color: #504b44;
}

.foot_phone p{
	background-image: url(../img/foot_phone.svg);
	background-repeat: no-repeat;
	background-position: left center;
	background-size:13px;
	padding-left:25px;
	font-size: 18px;
	letter-spacing:0.05em;
}

.foot_phone p a{
	color: #FFF;
	text-decoration: none;
}
.foot_phone.menubox p a{
	color: #504b44;
	text-decoration: none;
}	

.foot_hour {
	margin-bottom: 20px;
	border-collapse: collapse;
	width: 677px;
	margin-top:-20px;
}

.foot_hour th{
	vertical-align: middle;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #FFF;
	text-align: left;
	font-size: 18px;
	padding-left:20px;
	letter-spacing:0.1em;
}

.foot_hour td{
	text-align: center;
	vertical-align: middle;
	width: 60px;
	padding-right: 5px;
	padding-left: 5px;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #FFF;
	font-size: 18px;
	line-height: 1em;
	height: 70px;
}

.foot_hour td span{
	font-size: 12px;
}

.foot_nwrap {
	width: 90%;
	margin-right: auto;
	margin-left: auto;
	display: flex;
	justify-content: space-between;
	padding-bottom: 50px;
}

.footn_1 {
	flex: 1;
	display: flex;
	justify-content:flex-start;
}

.footn_2 {
	width: 250px;
}

.foot_btn {
	display: flex;
	justify-content: center;
	width: 200px;
	text-align: center;
	text-decoration: none;
	border-radius: 5px;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	padding-top: 10px;
	padding-bottom: 15px;
	border: 1px solid #FFF;
}

.foot_btn p{
	font-size: 18px;
	color: #FFFFFF;
	letter-spacing:0.05em;
}

.foot_btn p span{
	font-size: 16px;
	color: #FFFFFF;
	margin-right:20px;
	letter-spacing:0.1em;
}

.foot_btn:hover {
	background-color: #E5E5E5;
}

.foot_nav1 {
	width:180px;
}

.foot_nav1 ul {
}

.foot_nav1 li {
	margin-bottom:20px;
}

.foot_nav1 ul li a {
	color: #FFFFFF;
	text-decoration: none;
	font-size:16px;
	letter-spacing:0.2em;
}

.foot_nav1 ul li a:hover {
	color: #E9E9E9;
	text-decoration: none;
	font-size: 16px;
}

.foot_nav2 {
	margin-left: 50px;
}

.foot_nav2in {
	display: flex;
	justify-content:flex-start;
}

.foot_nav2 p {
	margin-bottom:20px;
}

.foot_nav2 p a{
	color: #FFFFFF;
	text-decoration: none;
	font-size:16px;
}

.foot_nav2 ul {
	width:240px;
}

.foot_nav2 li {
	margin-bottom:10px;
}

.foot_nav2 ul li a {
	color: #FFFFFF;
	text-decoration: none;
	font-size:15px;
	letter-spacing:0.2em;
}

.foot_nav2 ul li a:hover {
	color: #E9E9E9;
	text-decoration: none;
	font-size: 15px;
}

.copyright {
	padding-bottom: 20px;
	color: #FFF;
	font-size: 12px;
	text-align: center;
}

/*　中ページ　*/

.page_wrap {
	background: url(../img/page_back1.webp),url(../img/page_back2.webp),linear-gradient(1deg, #d7dee3, #c3d1d9 36%, #fefefd 74%, #dad1ca);
	background-position:top right,bottom left;
	background-size: 50%,100%,cover;
	background-repeat:no-repeat, no-repeat;
	padding-bottom:120px;
	min-width:1200px;
	padding-top:126px;
}

.page_title {
	width: 90%;
	margin-right: auto;
	margin-left: auto;
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	padding-top: 100px;
	padding-bottom: 100px;
}

.page_title div:nth-child(1){
	width:70%;
}

.page_title div:nth-child(2){
	width:30%;
}

.page_title h3 {
	font-size: 110px;
	font-family: "quiche-sans", sans-serif;
	font-weight: 300;
	font-style: normal;
	color: #7E7D70;
	letter-spacing: -0.05em;
	line-height: 0.9em;
	margin-bottom: 20px;
}

.page_title h4 {
	font-size: 23px;
	font-family: 'Noto Serif JP', serif;
	font-weight: 400;
	color: #80807B;
}

.page_title h5 {
	font-size: 20px;
	color: #707061;
	font-family: 'Noto Serif JP', serif;
	font-weight: 400;
	text-align: right;
	line-height: 1.6em;
}

.page_cont {
	margin-bottom: 100px;
}

.page_area {
	width: 80%;
	margin-right: auto;
	margin-left: auto;
}

.page_main {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 8%;
}

.page_main div:nth-child(1){
	order: 2;
	width:45%;
}

.page_main div:nth-child(1) img{
	width:100%;
	height:auto;
}

.page_main div:nth-child(2){
	order: 1;
	width:55%;
}

.page_main div:nth-child(2) p{
	margin:0 10%;
}

.cont_jmp {
	margin-bottom: 8%;
}

.cont_jmp ul{
	display: flex;
	justify-content: center;
	align-items: center;
}

.cont_jmp li{
	padding: 10px 30px 30px 30px;
	text-align: center;
	display:block;
	background-image: url(../img/jump_arr.svg);
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size: 25px;
}

.cont_jmp li+ li {
	border-left-width: 1px;
	border-left-style: solid;
	border-left-color: #ABABA7;
}

.cont_jmp li a{
	color: #72726D;
	font-size: 23px;
	padding-bottom: 20px;
	text-decoration: none;
}

.cont_jmp li a:hover{
	opacity: 0.6;
    filter: alpha(opacity=60);
    -moz-opacity: 0.6;
}

.page_section {
	margin-bottom: 8%;
}

.page_se80 {
	width: 80%;
	margin-right: auto;
	margin-left: auto;
}

.page_number {
	display: flex;
	justify-content: space-between;
	align-items: stretch;
	flex-wrap: wrap;
	margin-bottom: 100px
}

.page_number img{
	width:100%;
	height:auto:
}

.page_nb {
	width: 46%;
	margin-bottom: 6%;

}

.nb_midashi {
	display: flex;
	justify-content: flex-start;
	align-items: center;
	margin-bottom: 40px;
}

.nb_midashi p:nth-child(1){
	font-family: 'Noto Serif JP', serif;
	font-weight: 400;
	font-size: 75px;
	line-height:1.0em;
	padding-bottom:5px;
	margin-right: 15px;
}

.nb_midashi p:nth-child(2){
	font-family: "Noto Serif JP", serif;
	font-weight: 400;
	font-size: 25px;
	line-height: 1.5em;
	letter-spacing:0.05em;
}

.nb_txt {
	line-height: 1.8em;	
}

.page_flow {

}


.page_flow ul {
	display: flex;
	justify-content: space-between;
	align-items: stretch;
	flex-wrap: wrap;
}

.page_flow ul li{
	background-color: #F8F7F5;
	padding: 3% 2% 2% 2%;
	width: 20%;
	margin-bottom:1.5%;
}

.page_flow ul li h4{
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #9E9F99;
	font-size: 20px;
	text-align: center;
	margin-bottom: 30px;
	padding-bottom: 30px;
	height:45px;
	display: flex;
	justify-content: center;
	align-items: center;
}

.page_price {
	background-color: #FAFCFB;
	width: 96%;
	margin-right: auto;
	margin-left: auto;
	padding-top: 2%;
	padding-right: 2%;
	padding-bottom: 3%;
	padding-left: 2%;
}

.page_price dl{
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #D3D3D2;
	display: flex;
	justify-content: space-between;
	align-items: stretch;
}

.page_price dl dt{
	font-size: 19px;
	color: #878672;
	padding:20px 10px 10px 10px;
	flex: 1;
}

.page_price dl dd{
	font-size: 19px;
	color: #878672;
	text-align: right;
	padding: 25px 10px 10px 10px;
	width: 300px;
}

.page_price p {
	font-size: 19px;
	color: #7B8A93;
	padding-top: 40px;
	padding-bottom: 40px;
	text-align: center;
	line-height:1.8em;
}



/*　要素　*/

.page_cl1 {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 50px;
}

.page_cl1 div:nth-child(1){
	width:60%;
}

.page_cl1 div:nth-child(2){
	width:35%;
}

.page_cl1 div:nth-child(2) img{
	width:100%;
	height:auto;
}

.page_cl2 {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 50px;
}

.page_cl2 div:nth-child(1){
	width:60%;
	order: 2;
}

.page_cl2 div:nth-child(2){
	width:35%;
	order: 1;
}

.page_cl2 div:nth-child(2) img{
	width:100%;
	height:auto;
}

.page_cl3 {

}

.page_cl3 ul{
	display: flex;
	justify-content: space-between;
	align-items: stretch;
	flex-wrap: wrap;
}

.page_cl3 ul li{
	width: 29%;
	margin-bottom: 30px;
}

.page_cl3 ul li img{
	width:100%;
	height:auto;
	margin-bottom:30px;
}

.page_cl3 ul li h3 {
	font-family: 'Noto Serif JP', serif;
	font-weight: 400;
	font-size: 28px;
	margin-bottom: 30px;
	color: #888985;
	text-align: center;
}

.page_cls {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	margin-bottom:30px;
}

.page_cls div:nth-child(1){
	width:25%;
}

.page_cls div:nth-child(1) img{
	width:100%;
	height:auto;
}

.page_cls div:nth-child(2){
	width:70%;
}


/* 中ページ　*/

.guide_y {
	background-color: #F4F4F4;
	padding: 3%;
	border-radius: 10px;
	-webkit-border-radius: 10px;
	-moz-border-radius: 10px;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	width: 94%;
	margin-right: auto;
	margin-left: auto;
}

.guide_y ul {
	margin-bottom:20px;
}

.guide_y ul li {
	font-size: 17px;
	font-weight: bold;
	text-align: left;
	margin-bottom:10px;
}

.guide_li {
	margin-bottom: 150px;
}

.guide_li ul li{
	text-indent: -1em;
	padding-left: 1em;
	list-style-type: none;
	margin-bottom:10px;
}

.guide_y p {
	width:100%;
	text-align:center;
}

.doctor_c1 {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	margin-bottom:40px;
	width: 84%;
	margin-right: auto;
	margin-left: auto;
}

.doctor_c1 div:nth-child(1){
	width:400px;
	margin-right:40px;
}

.doctor_c1 div:nth-child(1) img{
	width:100%;
	height:auto;
}

.doctor_c1 div:nth-child(2){
	flex: 1;
}

.doctor_c1 div:nth-child(2) h4{
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
	font-size:32px;
	margin-bottom:20px;
	letter-spacing:0.1em;
}

.doctor_c1 div:nth-child(2) h4 span{
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
	font-size:20px;
	margin-right:20px;
}

.doctor_c1 div:nth-child(2) h5{
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
	font-size:20px;
	margin-bottom:15px;
	letter-spacing:0.1em;
}

.doctor_c1 table {
	border-collapse:collapse;
}

.doctor_c1 table th{
	font-size: 16px;
	width: 120px;
	text-align: left;
}

.doctor_c1 table td{
	font-size:16px;
}

.doctor_c2 {
	background-color: #f3f2f2;
	padding: 2%;
	width: 80%;
	margin-right: auto;
	margin-left: auto;
	border-radius: 5px;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
}

.doctor_c2 ul{
	display: flex;
	justify-content: space-between;
	align-items: stretch;
	flex-wrap: wrap;
}

.doctor_c2 ul li{
	width:30%;
	text-indent:-1em;
	padding-left:1em;
	margin-bottom:10px;
	font-size:16px;
}

.doctor_c2 ul li a{
	color: #575755;
	text-decoration: underline;
}

.doctor_c3 {
	width: 85%;
	margin-right: auto;
	margin-left: auto;
	margin-bottom:8%;
}

.book_wrap {
	display: flex;
	justify-content: space-between;
	align-items: stretch;
	flex-wrap: wrap;
}

.book {
	display: flex;
	justify-content: space-between;
	width: 48%;
	margin-bottom: 30px;
}

.book div:nth-child(1){
	width:150px;
	margin-right:20px;
}

.book div:nth-child(1) img{
	width:100%;
	height:auto;
	margin-bottom:10px;
}

.book div:nth-child(2){
	flex: 1;
}

.book_btn {
	display: flex;
	justify-content: center;
	width: 100%;
	text-align: center;
	text-decoration: none;
	margin-right: auto;
	margin-left: auto;
	border: 1px solid #575755;
}

.book_btn p{
	font-size: 16px;
	color: #575755;
	font-family: 'Noto Serif JP', serif;
	font-weight: 400;
}

.book_btn:hover {
	background-color: #F1F1EF;
	border: 1px solid #F1F1EF;
}

.book h6{
	font-family: 'Noto Serif JP', serif;
	font-weight: 700;
	margin-bottom: 19px;
}

.book p{
	font-size: 14px;
}

.acc_1 {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 8%;
}

.acc_1 div:nth-child(1){
	order: 2;
	width:45%;
}

.acc_1 div:nth-child(1) img{
	width:100%;
	height:auto;
}

.acc_1 div:nth-child(2){
	order: 1;
	width:55%;
}

.acc_1 div:nth-child(2) h3{
	margin-bottom:50px;
	margin-right: 10%;
	margin-left: 10%;
	font-size:30px;
	letter-spacing:0.05em;
}

.acc_1 div:nth-child(2) dl{
	display: flex;
	justify-content: flex-start;
	align-items: stretch;
	margin-right: 10%;
	margin-bottom: 15px;
	margin-left: 10%;
}

.acc_1 div:nth-child(2) dl dt{
	width:120px;
	font-size:19px;
}

.acc_1 div:nth-child(2) dl dt dd{
	flex: 1;
	font-size:19px;
}

.acc_hour {
	border-collapse: collapse;
	width: 100%;
	margin-bottom:20px;
}

.acc_hour th{
	vertical-align: middle;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #AAA99E;
	text-align: center;
	font-size: 18px;
	padding-left:20px;
	letter-spacing:0.1em;
}

.acc_hour td{
	text-align: center;
	vertical-align: middle;
	width: 11.5%;
	padding-right: 5px;
	padding-left: 5px;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #AAA99E;
	font-size: 18px;
	line-height: 1em;
	height: 90px;
}

.acc_hour td span{
	font-size: 12px;
}

.acc_hourt {
	text-align: right;
}

.acc_2 {
	display: flex;
	justify-content:center;
	align-items: stretch;
	flex-wrap: wrap;
}

.acc_2in {
	width:29%;
	margin:0 2% 5% 2%;
}

.acc_2in h4{
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
	font-size: 20px;
	margin-bottom: 20px;
	padding-bottom: 15px;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #FFF;
}

.acc_2in p{
	padding-top:10px;
}

.map iframe {
  -webkit-filter: grayscale(100%);
  -moz-filter: grayscale(100%);
  -ms-filter: grayscale(100%);
  -o-filter: grayscale(100%);
  filter: grayscale(100%);
}

.acc_3 {
	display: flex;
	justify-content: space-between;
	align-items: stretch;
	flex-wrap: wrap;
}

.acc_3in{
	width:46%;
}

.acc_3in img{
	width: 100%;
	height: auto;
	margin-bottom: 40px;
}

.acc_3in h4{
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
	font-size: 20px;
	margin-bottom: 30px;
	padding-bottom: 20px;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #FFF;
}


.acc_4 {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	width: 80%;
	margin-right: auto;
	margin-left: auto;
}

.acc_4l {
	flex: 1;
}

.acc_4r {
	width:50%;
	margin-left:3%;
}

.acc_4r p{
	padding-top:10px;
	text-align:center;
}

.acc_btn {
	display: flex;
	justify-content: center;
	width: 300px;
	text-align: center;
	text-decoration: none;
	padding-top: 5px;
	padding-bottom: 10px;
	border: 1px solid #575755;
}

.acc_btn p{
	font-size: 17px;
	color: #575755;
	font-family: 'Noto Serif JP', serif;
	font-weight: 400;
}

.acc_btn:hover {
	background-color: #F1F1EF;
	border: 1px solid #F1F1EF;
}

.infe_cl1 {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 60px;
}

.infe_cl1 div:nth-child(1){
	width:60%;
}

.infe_cl1 div:nth-child(2){
	width:35%;
}

.infe_cl1 div:nth-child(2) img{
	width:100%;
	height:auto;
}

.infe_cl2 {
	margin-bottom: 30px;
}

.infe_cl2 ul{
	display: flex;
	justify-content: space-between;
	align-items: stretch;
	flex-wrap: wrap;
}

.infe_cl2 ul li{
	width: 31%;
	margin-bottom: 30px;
}

.infe_cl2 ul li img{
	width:100%;
	height:auto;
	margin-bottom:30px;
}

.infe_cl2 ul li h3 {
	font-family: "Noto Serif JP", serif;
	font-weight: 400;
	font-size: 23px;
	margin-bottom: 30px;
	color: #6C6D69;
	text-align: center;
}

.infe_c3 {
	display: flex;
	justify-content: space-between;
	align-items: stretch;
}

.infe_c3 div{
	width:47%;
}

.infe_c3 div h4{
	font-family: 'Noto Serif JP', serif;
	font-weight: 400;
	font-size: 28px;
	border-left-width: 4px;
	border-left-style: solid;
	border-left-color: #888985;
	padding-left:20px;
	margin-bottom:30px; 
}

.gummy_c1 {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 50px;
}

.gummy_c1 div{
	width:48%;
}

.gummy_c1 div img{
	width:100%;
	height:auto;
}

.gummy_c2 {
	background-color: #F0EDEE;
	padding: 3%;
}

.gummy_c2 h3{
	font-size: 32px;
	color: #7F7564;
	margin-bottom: 50px;
	text-align: center;
}

.gummy_c2 ul {
	display: flex;
	justify-content:center;
	align-items: stretch;
	flex-wrap: wrap;
}

.gummy_c2 ul li{
	width: 450px;
	font-size: clamp(18px, 1.8vw, 23px);
	color: #7F7564;
	margin-bottom:20px;
}

.gummy_c3 {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	margin-bottom: 30px;
}

.gummy_c3 ul{
	list-style: none;
	padding: 0;
}

.gummy_c3 ul li{
	margin-bottom: 20px;
	font-size: 18px;
}

.gummy_c4 {
	background-color: #FFF;
	margin-bottom: 8%;
	padding-top: 5%;
	padding-right: 4%;
	padding-bottom: 5%;
	padding-left: 4%;
}

.gummy_c4 h4{
	font-size: 35px;
	font-family: 'Noto Serif JP', serif;
	font-weight: 300;
	margin-bottom:30px;
}

.gummy_4in {
	background-color: #F0EDEE;
	padding: 4%;
	display: flex;
	justify-content: space-between;
	align-items: stretch;
	margin-bottom: 50px;
}

.gummy_4in div:nth-child(1){
	width: 45%;
	border-right-width: 1px;
	border-right-style: solid;
	border-right-color: #898989;
	padding-right:4%;
}

.gummy_4in div:nth-child(2){
	width: 46%;
	padding-left:3%;
}

.gummy_4in h5 {
	color: #575652;
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
	margin-bottom: 30px;
}

.gummy_4p {
	margin-left:20px;
}

.gummy_4in3 {
	background-color: #F0EDEE;
	padding: 4%;
	display: flex;
	justify-content: space-between;
	align-items: stretch;
	margin-bottom: 50px;
}

.gummy_4in3 div:nth-child(2){
	width: 29%;
	border-right-width: 1px;
	border-right-style: solid;
	border-right-color: #898989;
	border-left-width: 1px;
	border-left-style: solid;
	border-left-color: #898989;
	padding-right:3%;
	padding-left:3%;
}

.gummy_4in3 div:not(:nth-child(2)){
	width: 29%;
}

.gummy_4in3 h5 {
	color: #575652;
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
	margin-bottom: 30px;
}

.gummy_c5 {
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #FFF;
	margin-bottom: 50px;
	padding-bottom: 50px;
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
}

.gummy_c5 div:nth-child(1){
	width: 400px;
	text-align: center;
}

.gummy_c5 div:nth-child(1) h3{
	font-size: 23px;
}

.gummy_c5 div:nth-child(1) h3 span{
	font-size: 16px;
}

.gummy_c5 div:nth-child(2){
	flex: 1;
}

.gummy_c5 div:nth-child(2) p{
	font-size: 16px;
	line-height: 1.9em;
}

.gummy_c6 {
	border: 1px solid #898989;
	padding: 2% 5%;
}

.gummy_6in {
	padding: 5% 0;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.g6_border {
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #898989;
}

.gummy_6in div:nth-child(1){
	flex: 1;
	margin-right:30px;
}

.gummy_6in div:nth-child(2){
	width:25%;
}

.gummy_6in div:nth-child(2) img{
	width:100%;
	height:auto;
}

.gummy_6in div:nth-child(1) h4{
	font-size: 30px;
	margin-bottom:30px;
}

.gummy_6in div:nth-child(1) p{
	font-size: 19px;
	line-height: 1.9em;
}

.cav_c1 {
	background-color: #F0EDEE;
	padding: 4% 3% 3% 3%;
}

.cav_c1 h3{
	font-size: 32px;
	color: #7F7564;
	margin-bottom: 50px;
	text-align: center;
}

.cav_c1 ul {
	display: flex;
	justify-content: space-between;
	align-items: stretch;
	flex-wrap: wrap;
}

.cav_c1 ul li{
	width: 46%;
	font-size: clamp(18px, 1.8vw, 23px);
	color: #7F7564;
	margin-bottom:20px;
	text-indent:-1em;
	padding-left:1em;
	line-height:1.8em;
}

.bre_c1 {
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #FFF;
	margin-bottom: 50px;
	padding-bottom: 50px;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.bre_c1 div:nth-child(1){
	width: 150px;
	text-align: center;
}

.bre_c1 div:nth-child(1) h3{
	font-size: 23px;
}

.bre_c1 div:nth-child(1) h3 span{
	font-size: 16px;
}

.bre_c1 div:nth-child(2){
	flex: 1;
}

.bre_c1 div:nth-child(2) p{
	font-size: 16px;
	line-height: 1.9em;
}

.qa_c {
    padding: 36px 40px 44px;
    background: #FAFCFB;
    border: 1px solid #e7e3df;
    border-radius: 10px;
	margin-bottom:10px;
}

.qa_q {
	font-size: 21px;
	font-weight: 600;
	margin-bottom:30px;
}

.qa_q span{
	font-size: 23px;
	font-weight: 600;
	color: #c2a26a;
	margin-right:10px;
}

.qa_a {
	padding-left:30px;
}

.qa_a ul li{
	text-indent:-1em;
	padding-left:1em;
}

.ortho_c1 {
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #FFF;
	margin-bottom: 50px;
	padding-bottom: 50px;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.ortho_c1 div:nth-child(1){
	width: 320px;
	text-align: center;
}

.ortho_c1 div:nth-child(1) h3{
	font-size: 23px;
	line-height:1.6em;
}

.ortho_c1 div:nth-child(2){
	flex: 1;
}

.ortho_c1 div:nth-child(2) p{
	font-size: 16px;
	line-height: 1.9em;
}

.perio_1 {
	display: flex;
	justify-content: space-between;
	align-items: center;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #898989;
	padding-top: 50px;
	padding-bottom: 50px;
}

.perio1_1 {
	width:250px;
}

.perio1_1 img{
	width:100%;
	height:auto;
}

.perio1_2 {
	width:300px;
	text-align: center;
}

.perio1_2 p {
	font-family: "Noto Serif JP", serif;
	font-weight: 500;
	font-size: 27px;
	color: #333;
	line-height:2em;
}

.perio1_2 p span{
	font-family: 'Noto Serif JP', serif;
	font-weight: 400;
	font-size:20px;
	color: #333;
}

.perio1_3 {
	flex: 1;
}

.perio1_3 ul {
	display: flex;
	justify-content:flex-start;
	align-items: center;
	margin-bottom:40px;
}

.perio1_3 ul li{
	margin-right:15px;
}

.perio1_3 ul li span{
	color: #333;
	border: 1px solid #7A7A7C;
	padding:15px 20px;
	border-radius: 9999px;
	font-family: "Noto Serif JP", serif;
	font-weight: 500;
	letter-spacing:0.2em;
}

.cera1 {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.cera1_pic {
	width:350px;
	margin-right:50px;
}

.cera1_pic img {
	width:100%;
	height:auto;
}

.cera1_txt {
	background-color: #F0EDEE;
	padding:3%;
	flex: 1;
	display: flex;
	align-items: center;
}

.cera1_txt h4{
	font-size:30px;
	margin-bottom:30px;
}

.cera1_txt ul li {
	margin-bottom:10px;
}

.cera2 ul{
	display: flex;
	justify-content:flex-start;
	align-items: stretch;
	flex-wrap: wrap;
}

.cera2 ul li{
	width:28%;
	margin:0 2.6% 40px 2.6%;
}

.cera2 ul li img{
	width: 80%;
	height: auto;
	margin-bottom: 20px;
	margin-right: 10%;
	margin-left: 10%;
}

.cera2 ul li h3 {
	font-size: 21px;
	text-align: center;
	margin-bottom: 20px;
	height: 60px;
	display: flex;
	justify-content: center;
	align-items: center;
	color: #333;
	font-family: 'Noto Serif JP', serif;
	font-weight: 600;
}

.cera2 ul li p {
	font-size:16px;
}

.cera2 ul li p span {
	font-size:11px;
	line-height:1.3em;
	display:block;
	padding-top:10px;
}

.cera3 {
}

.cera3 table {
	width: 100%;
	border-collapse: collapse;
	background-color: #F0EDEE;
}

.cera3 th,
.cera3 td {
  text-align: left;
  padding: 3%;
  vertical-align: top;
}

.cera3 th {
  border-bottom: 1px solid #C6C1C2;
  font-family: 'Noto Serif JP', serif;
	font-weight: 500;
}

.cera3 td {
  border-bottom: 1px solid #C6C1C2;
}

/* ▼ 左側のセルデザイン調整 ▼ */
.cera3 td:first-child {
  border-right: 1px solid #C6C1C2; 
}

.cera3 th:first-child {
  border-right: 1px solid #C6C1C2; 
  width: 300px;                       
}

/* 最後の行の下線を消す */
.cera3 tr:last-child td {
  border-bottom: none;
}

.imp1 {
	display: flex;
	justify-content: space-between;
	margin-bottom: 80px;
}

.imp1 div{
	width:46%;
}

.imp1 div img{
	width:100%;
	margin-bottom:30px;
}

.imp1 div h4 {
	font-size: 25px;
	text-align: center;
	margin-bottom: 30px;
	height: 67px;
	display: flex;
	justify-content: center;
	align-items: center;
}

.imp2 {
	background-color: #F0EDEE;
	padding: 4%;
}

.imp2 div {
	display: flex;
	justify-content: center;
	align-items: center;
}

.dock_1 {
	display: flex;
	justify-content: space-between;
	align-items: center;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #898989;
	padding-top: 50px;
	padding-bottom: 50px;
}

.dock1_1 {
	width:250px;
}

.dock1_1 img{
	width:100%;
	height:auto;
}

.dock1_2 {
	width:330px;
	text-align: center;
}

.dock1_2 p {
	font-family: "Noto Serif JP", serif;
	font-weight: 500;
	font-size: 25px;
	color: #333;
	line-height:2em;
}

.dock1_2 p span{
	font-family: 'Noto Serif JP', serif;
	font-weight: 400;
	font-size:20px;
	color: #333;
}

.dock1_3 {
	flex: 1;
}

.dock1_3 ul {
	display: flex;
	justify-content:flex-start;
	align-items: center;
	margin-bottom:40px;
}

.dock1_3 ul li{
	margin-right:15px;
}

.dock1_3 ul li span{
	color: #333;
	border: 1px solid #7A7A7C;
	padding:15px 20px;
	border-radius: 9999px;
	font-family: "Noto Serif JP", serif;
	font-weight: 500;
	letter-spacing:0.2em;
}

.brux_1 {
	width: 94%;
    margin: 40px auto;
    padding: 30px 4%;
    background: #f3f0eb;
    border: 1px solid #c9c6be;
	display: flex;
	align-items:center;
}

.brux1_m {
	width:300px;
}

.brux1_m h4{
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
	font-size:23px;
}

.brux1_t{
	flex: 1;
}

.brux1_t ul li:not(:nth-child(3)){
	margin-bottom:15px;
	font-size:19px;
}

.brux1_t ul li:last-child {
	font-size:19px;
}

.white_1 {
	display: flex;
	justify-content: space-between;
	align-items: stretch;
	margin-bottom:40px;
}

.white_1in {
	width: 48%;
	border: 1px solid #FFFFFF;
}

.white_1in h4{
	background-color: #FFFFFF;
	padding: 3% 4%;
	color: #666;
	text-align: center;
}

.white_1in p {
	padding:4%;
}
	
.white2 {
	padding: 5%;
	border-radius: 10px;
	-webkit-border-radius: 10px;
	-moz-border-radius: 10px;
	background-color: #F9F8F4;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.white2 div:nth-child(1){
	width:56%;
}

.white2 div:nth-child(2){
	width:40%;
}

.white2 div img{
	width:100%;
	height:auto;
}

.white2 h3{
	text-align:center;
	font-size:40px;
	margin-bottom:30px;
	line-height:1.4em;
}

.white2 h4{
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
	text-align:center;
	margin-bottom:20px;
	line-height:1.4em;
}

.white2 h5{
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
	text-align:center;
	padding:30px 0;
	font-size:23px;
	line-height:1.4em;
}

.painless1 {
	margin: 40px auto;
	border: 1px solid #FFF;
	padding: 20px;
}

.painless1_in {
	display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  padding: 30px 0;
  border-top: 1px solid #FFF;
}

.painless1_in:first-child {
  border-top: none;
}

.painless1_in div:nth-child(1){
	flex: 1;
  margin-right: 30px;
}

.painless1_in div:nth-child(2){
	width: 280px;
}

.painless1_in div:nth-child(2) img{
	width:100%;
	height:auto;
}

.painless1_in div:nth-child(1) h3{
	font-size: 20px;
	margin-bottom: 20px;
	color: #333;
}

.painless1_in div:nth-child(1) p{
	font-size: 16px;
	padding-left:20px;
}

.dock1 {
	margin: 40px auto;
	border: 1px solid #FFF;
	padding: 20px;
}

.dock1_in {
  padding: 30px 0;
  border-top: 1px solid #FFF;
}

.dock1_in:first-child {
  border-top: none;
}

.dock1_in div h3{
	font-size: 20px;
	margin-bottom: 20px;
	color: #333;
}

.dock1_in div p{
	font-size: 16px;
	padding-left:20px;
}

.acc_pic {
	margin-bottom:8%;
}

.acc_pic ul{
	display: flex;
	justify-content: space-between;
	align-items: stretch;
}

.acc_pic ul li{
	width:32%;
}

.acc_pic ul li img{
	width:100%;
	height:auto;
}
	
}

/* 予約タブ追加 */
.tab{
	width: 90%;
	margin: -30vh auto 0 auto;
	height: 45vh;
    display: flex;
    flex-wrap: wrap;
	justify-content:flex-end;
	align-items: flex-end;
	z-index: 10;
    position: relative;
}

.tab .iframe {
  aspect-ratio: 16 / 9;
}
.tab .iframe iframe {
  width: 100%;
  height: 100%;
}

.tab-3 {
    display: flex;
    flex-wrap: wrap;
	flex-direction: column;
	flex: 0 0 570px;
	width: 570px;
	position: relative;
	box-shadow: 4px 0 12px rgba(0,0,0,.15);
	min-height: 250px;
	background: #dccfc4;
}

.tab-3 > label {
    flex: 1 1;
    order: -1;
    padding: 10px 5px;
    background-color: #dccfc4;
    color: #bab29e;
    font-weight: bold;
    text-align: center;
    cursor: pointer;
	font-size: 12px;
	width: 140px;
	line-height: 1.2;
}
.tab-3 .icon{
	border: 1px solid #dccfc4;
	display: inline-block;
	padding: 1px 2px;
	margin: 0 2px 0 0;
	font-size: 0.9em;
}

.tab-3 > label:hover {
    filter: brightness(1.1);
}

.tab-3 input {
    display: none;
}

.tab-3 > .tab-content {
    background-color: #fff;
	line-height: 1.2;
	font-size: 13px;
	width: 420px;
	height: 100%;
	position: absolute;
	right: 0;
	overflow-y: scroll;
	opacity: 0;
	pointer-events: none;
	transition: 0.5s ease-in all;
}
.tab-3 > .tab-content .heading{
	border-bottom: 2px solid #dccfc4;
	margin: 1em 1em 0 1em;
	color: #dccfc4;
	font-size: 15px;
	font-weight: bold;
	padding: 0 0 .45em 0;
}
.tab-3 iframe{
	border: 0;
}

.tab-3 label:has(:checked) {
    color: #3088a1;
	background: #dccfc4;
	color: #FFF;
}
.tab-3 label:has(:checked) .icon{
	border: 1px solid #FFF;
}

.tab-3 label:has(:checked) + .tab-content {
	opacity: 1;
	pointer-events:auto;
}


.balloon {
	position: relative;
	display: inline-block;
	margin: 1.0em 0;
	padding: 5px 5px;
	min-width: 100px;
	max-width: 100%;
	color: #555;
	font-size: 16px;
	background: #bcbeb3;
	text-align: center;
	border-radius: 5px;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
}

.balloon:before {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -10px;
  border: 10px solid transparent;
  border-top: 10px solid #3088a1;
}

.balloon p {
	margin: 0;
	padding: 0;
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 700;
	color: #FFF;
}

/* === 治療方法ボックス === */

.infobox {
	width: 94%;
	background-color: #FFFFFF;
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-right: auto;
	margin-bottom: 50px;
	margin-left: auto;
	padding-top: 30px;
	padding-right: 4%;
	padding-bottom: 30px;
	padding-left: 4%;
}

.infobox_label {
	font-size: 20px;
	font-weight: 500;
	color: #333;
	font-family: "Noto Serif JP", serif;
	font-weight: 500;
	width: 180px;
}

.infobox_body {
	flex: 1;
	border-left-width: 2px;
	border-left-style: solid;
	border-left-color: #E3E3E3;
	padding-left:40px;
}

.dotCols{
  list-style:none;
  margin:0 0 14px;
  padding:0;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px 48px;
}
.dotCols li{
  position:relative;
  padding-left:20px;
  line-height:1.9;
  color:#333;
  font-size:16px;
}

.dotCols li::before{
	content: "";
	position: absolute;
	left: 0;
	top: 0.74em;
	width: 8px;
	height: 8px;
	border-radius: 999px;
	background-color: #8BA9BA;
}

.infobox_note {
  margin:6px 0 0;
  color:#666;
  line-height:2;
  font-size:16px;
}



  
/* === 比較表 === */
.table-hikaku {
	width: 100%;    
	margin: 0 auto 60px;  
	border-collapse: collapse;
	table-layout: fixed;
	border: none;

}

.table-hikaku th,
.table-hikaku td {
  border: 1px solid #f0f0f0;
  padding: 20px 28px;
  vertical-align: top;
}

.table-hikaku th {
  background: #fafafa;
  text-align: center;
  font-weight: 600;
  font-size: 17px;
}

.table-hikaku td {
  font-size: 15px;
  line-height: 1.8;
}

.table-hikaku tbody th {
  background: #fff;
  text-align: center;
  font-weight: 600;
  width: 20%;
}

.table-hikaku thead th {
  background: #fff;
  border-top: none;
  border-bottom: 2px solid #eee;
}

.table-hikaku tbody tr:first-child th,
.table-hikaku tbody tr:first-child td {
  border-top: none;
}


/* コンテナ */
.exam-chips{
  max-width: 1200px;        /* 画像の見た目に近い横幅 */
  margin: 24px auto;
  padding: 16px 24px;
  background: #f3f2f2;      /* 薄いグレー台座 */
  border-radius: 6px;
}

/* チップ群 */
.chip-list{
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  justify-content:center;
  flex-wrap: wrap;
  gap: 16px 24px;           /* 行間・列間 */
}

/* 個々のチップ */
.chip{
  display: inline-block;
  padding: 12px 28px;
  border: 1px solid #dddddd;
  border-radius: 9999px;    /* 楕円のピル形状 */
  background: #ffffff;
  color: #111827;
  font-size: 16px;
  line-height: 1;
  white-space: nowrap;      /* 折り返し防止（長文を崩したくない場合） */
}

/* === 流れ === */

.timeline {
  position: relative;
  padding-left: 100px;
  margin: 0 auto 80px auto;
}
.timeline::before {
  content: "";
  position: absolute;
  top: 0;
  left: 48px;
  width: 2px;
  height: calc(100% - 36px); /* 円の半径分短く */
  background: #F7F4F2;
}
.step {
  position: relative;
  margin-bottom: 80px;
}
.circle {
  position: absolute;
  left: -85px;
  top: 0;
  width: 72px;
  height: 72px;
  border-radius: 50%;
  color: #82725d;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  font-size: 20px;
  background-color: #F7F4F2;
}
.content h3 {
  font-size: 22px;
  font-weight: 600;
  color: rgba(117,107,91,0.89);
  margin-bottom: 12px;
}
.content p {
  color: rgba(99,94,74,0.93);
  line-height: 1.8;
  margin-bottom: 24px;
}



/* ========== 治療期間の目安 ========== */
.period{
	margin: 40px auto 64px;
	padding: 36px 40px 44px;
	background: #f3f1f0;         /* ほんのりグレー背景 */
	border: 1px solid #e7e3df;
	border-radius: 6px;
	color: #4b4b4b;
}

.period__title{
  margin:0 0 20px;
  text-align:center;
  font-weight:600;
  font-size:28px;
  letter-spacing:.06em;
  color:#6b6460;
}

.period__text{
  margin:0 0 24px;
  line-height:1.9;
  font-size:16px;
  color:#5b5b5b;
}
.period__text p{ margin:0 0 .6em; }

/* 下の囲みラベル */
.period__note{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:22px;
  padding:18px 24px;
  border:2px solid #bfb8b2;
  border-radius:3px;
  color:#4a4947;
  font-size:18px;
  letter-spacing:.02em;
}
.period__note i{
  width:1px;
  height:22px;
  background:#bfb8b2;  /* 仕切り線 */
  display:inline-block;
}



/* ========== 診療内容：唇が原因 ========== */
.svc-lips{
  max-width: 1200px;
  margin: 40px auto 72px;
  padding: 28px 28px 36px;
  border: 1px solid #e6e2dc;   /* 外枠 */
  background: #fff;
}
.svc-lips__title{
  margin: 0 0 18px;
  text-align: center;
  font-weight: 600;
  font-size: 32px;
  letter-spacing: .06em;
  color: #8a877f;              /* 見出しの淡いグレー */
}

/* 行（左テキスト＋右画像） */
.svc-lips__row{
  display: grid;
  grid-template-columns: 1fr 360px; /* 左右比率 */
  gap: 36px 48px;
  align-items: start;
  padding: 28px 16px 36px;
  border-top: 1px solid #e7e4df;    /* 行の区切り線 */
}
.svc-lips__row:first-of-type{ border-top: none; }

.svc-lips__heading{
  margin: 6px 0 14px;
  font-size: 22px;
  font-weight: 600;
  color: #6a665d;
  letter-spacing: .02em;
}
.svc-lips__text p{
  margin: 0;
  line-height: 1.85;
  color: #4d4d4d;
  font-size: 16px;
}

/* 画像（ダミー枠） */
.svc-lips__media{
  margin: 0;
  width: 100%;
  aspect-ratio: 4 / 3;         /* 画像比率（必要に応じて変更） */
  background: #8c8a82;         /* 画像のプレースホルダー色 */
  border: 1px solid #9a968f;
}

/* 画像を実際に入れる場合（任意） */
.svc-lips__media > img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border: 1px solid #9a968f;
}


/* ===== Base ===== */
.ba-slider{
  --pos:50%;                    /* 初期位置（左=0%〜右=100%） */
  position: relative;
  width: 100%;
  max-width: 620px;             /* 必要に調整 */
  aspect-ratio: 4 / 3;          /* 画像比率に合わせて変更可 */
  overflow: hidden;
  border-radius: 6px;
  height: fit-content;
}

/* 画像 */
.ba-img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  user-select: none;
  -webkit-user-drag: none;
}
.ba-img--after{
  position: absolute;
  inset: 0;
}

/* Beforeレイヤー（上に被せて横幅で切る） */
.ba-before{
  position: absolute;
  inset: 0;
  width: var(--pos);
  overflow: hidden;
  transition: width .05s linear;
}
.ba-before .ba-img{ display:block; }

/* 仕切り線（中央ライン） */
.ba-divider{
  position: absolute;
  top: 0; bottom: 0;
  left: var(--pos);
  width: 1px;
  background: rgba(0,0,0,.65);
  transform: translateX(-.5px);
  pointer-events: none;
}

/* ハンドル */
.ba-handle{
  position: absolute;
  top: 50%;
  left: var(--pos);
  transform: translate(-50%,-50%);
  width: 64px; height: 64px;
  border-radius: 50%;
  border: 0;
  background: rgba(255,255,255,.92);
  box-shadow: 0 1px 8px rgba(0,0,0,.18);
  display: grid;
  place-items: center;
  cursor: ew-resize;
}
.ba-handle:focus-visible{ outline: 2px solid #7aa7ff; }

/* 矢印 */
.ba-arrow{ font-size: 22px; line-height: 1; color:#444; }
.ba-arrow--left{ margin-right: 8px; }
.ba-arrow--right{ margin-left: 8px; }

/* ラベル */
.ba-label{
  position: absolute;
  bottom: 14px;
  padding: 8px 14px;
  font-size: 14px;
  color: #fff;
  background: rgba(0,0,0,.35);
  border-radius: 6px;
  pointer-events: none;
  backdrop-filter: blur(1px);
}
.ba-label--before{ left: 14px; }
.ba-label--after{ right: 14px; }


/* ===== 3列レイアウト ===== */
.ba-gallery {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;                /* 間の余白 */
  max-width: 1200px;
  margin: 60px auto;
  padding: 0 20px;
  flex-wrap: wrap;
}

.ba-item {

}
.flex_out {
	text-align: left;
}


/* ===== 診療紹介２：Missionヒーロー ===== */
/* 固定背景 */
* ステージ自体をスタッキングコンテキスト化＆はみ出しを抑制 */
.shinryo2-stage{
  position: relative;
  isolation: isolate;   /* 子の z-index を外に漏らさない */
  overflow: clip;       /* ブラウザが古い場合は overflow: hidden; */
}

/* ここを fixed → sticky に変更（区間内だけ貼り付く） */
.shinryo2-fixed-bg{
  position: sticky;
  top: 0;
  height: 100vh;            /* 画面いっぱいに見せる */
  background-size: cover;
  background-position: center;
  opacity: 0;               /* 初期は非表示 */
  transition: opacity .35s ease;
  z-index: 0;               /* 区間内で最背面 */
  pointer-events: none;     /* クリック妨げ無し */
}


/* ステージが見えている間だけ背景を出す（ふわっと表示） */
.shinryo2-stage.is-active .shinryo2-fixed-bg{
  opacity: 1;
}

/* コンテンツは背景より前面へ */
.shinryo2-hero__wrap,
.shinryo2-hero__card{
  position: relative;
  z-index: 1;
}

/* 念のため：ヘッダー/フッターは最前面 ※※※ここで予約が背面に行っている
header, footer{
  position: relative;
  z-index: 10;
}*/

/* 各ヒーローの高さ（好みで調整） */
.shinryo2-hero{
  min-height: 90vh;   /* 80–100vh くらいで */
  display: grid;
  place-items: center;
}index: 10;
}

/* ===== Shinryo2 Hero Card Style ===== */
.shinryo2-hero {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 80px 20px;
  box-sizing: border-box;
}

.shinryo2-hero__wrap {
  max-width: 1200px;
  width: 100%;
  margin: 0 auto;
}

.shinryo2-hero__card {
  background: rgba(255, 255, 255, 0.88);
  backdrop-filter: blur(8px);
  border-radius: 16px;
  padding: 40px 50px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.1);
  color: #333;
  line-height: 1.8;
}

.shinryo2-hero__mission {
  font-family: 'Rubik', sans-serif;
  font-size: 14px;
  letter-spacing: 0.05em;
  color: #888;
  margin-bottom: 10px;
  text-transform: uppercase;
}

.shinryo2-hero__mission span {
  display: inline-block;
  color: #c79b63; /* ゴールド系アクセント */
  font-weight: 600;
}

.shinryo2-hero__title {
  font-family: 'Noto Serif JP', serif;
  font-size: 26px;
  font-weight: 600;
  color: #111;
  margin-bottom: 20px;
  line-height: 1.4;
}

.shinryo2-hero__lead {
  font-size: 16px;
  color: #333;
  margin-bottom: 10px;
}

/* 背景固定部分との重なりを確保 */
.shinryo2-hero__wrap,
.shinryo2-hero__card {
  position: relative;
  z-index: 1;
}
