@charset "utf-8";
/*
Theme Name: '25 スマイルコンセプト
Theme URI: https://www.mmm_ooo.com/
Description: Versions 2.0.x
Version: 2.0
Author: Dental Promotion.INC
*/
@keyframes fadeIn {
0% {opacity: 0}
100% {opacity: 1}
}
@-webkit-keyframes fadeIn {
0% {opacity: 0}
100% {opacity: 1}
}


html, body, div, span, object, iframe,h1, h2, h3, h4, h5, h6, p, blockquote, pre,abbr, address, cite, code,del, dfn, em, img, ins, kbd, q, samp,small, strong, sub, sup, var,b, i,dl, dt, dd, ol, ul, li,fieldset, form, label, legend,table, caption, tbody, tfoot, thead, tr, th, td,article, aside, dialog, figure, footer, header,hgroup, menu, nav, section,time, mark, audio, video{margin:0;padding:0;border:0;outline:0;font-size:100%;vertical-align:baseline;background:transparent;}body {line-height:1;}article, aside, dialog, figure, footer, header,hgroup, nav, section {display:block;}ul,ol{list-style:none;}blockquote, q {quotes:none;}blockquote:before, blockquote:after,q:before, q:after {content:'';content:none;}a {margin:0;padding:0;border:0;font-size:100%;vertical-align:baseline;background:transparent;}ins {background-color:#ff9;color:#000;text-decoration:none;}mark {background-color:#ff9;color:#000;font-style:italic;font-weight:600;}del {text-decoration: line-through;}abbr[title], dfn[title] {border-bottom:1px dotted #000;cursor:help;}table {border-collapse:collapse;border-spacing:0;}hr {display:block;height:1px;border:0;border-top:1px solid #cccccc;margin:1em 0;padding:0;}input, select {vertical-align:middle;}

html{
    max-width: 100%;
    scroll-behavior: smooth;
    overflow-y: auto;
}
@media screen and (max-width: 768px) {
html{
    width: 100%;
    max-width: 100%;
    font-size: 62.5%;
    -webkit-text-size-adjust: 100%;
}
}
body{
    position: relative;
    margin: 0;
    padding: 0;
    text-align: center;
    background: #fff;
    color: #333;
    font-family: "ヒラギノ角ゴ ProN W3","HiraKakuProN-W3","ヒラギノ角ゴ Pro W3","HiraKakuPro-W3","メイリオ",Meiryo,"ＭＳ Ｐゴシック","MS Pgothic","Osaka",sans-serif,Helvetica, Helvetica Neue, Arial, Verdana;
    font-size: calc(14px + (20 - 16) * ((100vw - 300px) / (1600 - 300)));
	word-wrap : break-word;
	overflow-wrap : break-word;
    line-height: 1.8em;
    letter-spacing: 1.2pt;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    animation: fadeIn 2s ease 0s 1 normal;
    -webkit-animation: fadeIn 2s ease 0s 1 normal;
}

h1,h2,h3,h4,h5,h6{
    margin: 0;
    font-weight: 100;
}
*, *:before, *:after{
    box-sizing: border-box;
}
/*
::selection{
    background: #f5f0e5;
    color: #333;
    text-shadow: 1px 1px 2px rgba(240, 240, 200, 1);
}
::-moz-selection{
    background: #f5f0e5;
    color: #333;
    text-shadow: 1px 1px 2px rgba(240, 240, 200, 1);
}
*/
a{
    text-decoration:none;
    outline:none;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    -webkit-transition:all .3s linear;
    -moz-transition:all .3s linear;
    transition:all .3s linear;
}
a:link, a:visited{
   color: #333;
/*   color: #5c5737;*/
}
a:active, a:hover{
    color: #413c1e;
    text-decoration: none;
}
a:link img, a:visited img{
    -webkit-transition: opacity .5s ease-out;
    -moz-transition: opacity .5s ease-out;
    -ms-transition: opacity .5s ease-out;
    transition: opacity .5s ease-out;
}
a:hover img{
    opacity: .7;
    -webkit-opacity: .7;
    -moz-opacity: .7;
    display: inline-block;
    backface-visibility: hidden;
}
p{margin:0;}
table{
    border-collapse:collapse;
    table-layout: fixed;
    word-break: break-all;
    word-wrap: break-all;
}
img{
    max-width: 100%;
    height: auto;
    vertical-align: middle;
    border: none;
    font-style: italic;
    background-repeat: no-repeat;
    background-size: cover;
    shape-margin: .75rem;
}
img.alpha50{
    opacity: .5;
    filter: alpha(opacity=50);
    -ms-filter: "alpha( opacity=50 )";
}

.cf{zoom:100%;}
.cf:after{
    content:"";
    clear:both;
    height:0;
    display:block;
    visibility:hidden;
}
.oz{
    overflow: hidden;
    _zoom: 1;
}
.al{text-align:left;}
.ac{text-align:center;}
.ar{text-align:right;}

.imgL, .s_imgL, .txtL{float:left;}
.imgR, .s_imgR, .txtR{float:right;}
.co{clear:both;}
.fwn{font-weight:100;}
.fwb{font-weight:600;}
.fs12{font-size:67%;}
.fs13{font-size:72%;}
.fs14{font-size:67%;}
.fs15{font-size:78%;}
.fs16{font-size:88%;}
.fs17{font-size:94%;}
.fs18{font-size:100%;}
.fs19{font-size:106%;}
.fs20{font-size:111%;}
.fs21{font-size:117%;}
.fs22{font-size:122%;}
.fs23{font-size:128%;}
.fs24{font-size:133%;}


.su{
    opacity:0;
    transform: translateY(10px);
    -ms-filter: blur(1px);
    filter: blur(1px);
}
.fiu{
    transition: all .5s ease-in-out;
    transform: translateY(0);
    opacity: 1 !important;
    -ms-filter: blur(0);
    filter: blur(0);
}

.mt8{margin-top:8px;}
.mt16{margin-top:16px;}
.mt24{margin-top:24px;}
.mt32{margin-top:32px;}
.mt40{margin-top:40px;}

.mb0{margin-bottom:0;}
.mb4{margin-bottom:4px;}
.mb8{margin-bottom:8px;}
.mb16{margin-bottom:16px;}
.mb24{margin-bottom:24px;}
.mb32{margin-bottom:32px;}
.mb40{margin-bottom:40px;}
.mb56{margin-bottom:56px;}
.mb64{margin-bottom:64px;}
.mb80{margin-bottom:80px;}
.mb120{margin-bottom:120px;}
.mb160{margin-bottom:160px;}
@media screen and (max-width: 540px) {
.sp_mb24{margin-bottom:24px;}
}


.pt16{padding-top:16px;}
.pt24{padding-top:24px;}
.pt32{padding-top:32px;}
.pt40{padding-top:40px;}
.pb40{padding-bottom:40px;}
.pb80{padding-bottom:80px;}


.pl8{padding-left:8px;}
.pl16{padding-left:16px;}
.pl24{padding-left:24px;}

.fc_gold{color: #b28b56;}
.fc_blk{color: #000;}
.fc_red{color: #e6462e;}
.fc_wine{color: #d74487;}

.ff_mincho{
    font-family: "Noto Serif JP", "游明朝体", "游明朝", YuMincho, "Yu YuMincho", "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
}

strong{
	background: linear-gradient(transparent 60%, #eba1c3 60%);
}
b{
	color: #9a001a;
}


.blocklink{
    position: relative;
}
.blocklink a{
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
}
.blocklink a:hover{
    background: #fff;
    opacity: .5;
    filter: alpha(opacity=50);
    -ms-filter: "alpha( opacity=50 )";
}
.more a{
    position: relative;
    display: block;
    margin-left: auto;
    margin-right: auto;
    padding: 16px;
    background: #fff url("../../../img/asset/common/svg/arrow.svg") no-repeat 95% center;
    background-size: 16px auto;
    color: #675329;
    border: 1px solid;
    text-align: center;
    line-height: 1.3;
    border-radius: 32px;
    letter-spacing: 0;
}
.more a:hover{
    background: #e7e7e7 url("../../../img/asset/common/svg/arrow.svg") no-repeat 98% center;
    background-size: 16px auto;
}
a.more-link{
    display: block;
    width: 280px;
    margin-top: 0;
    margin-left: auto;
    margin-right: auto;
    padding: 1em .5em;
    background: #f2d43d url("../img/asset/common/svg/arrow.svg") no-repeat 97% center;
    background-size: 10px auto;
    color: #675b1f;
    border: 2px solid #fff;
    text-align: center;
    line-height: 1;
    border-radius: 8px;
}
a.more-link:hover{
    background: #cda053 url("../img/asset/common/svg/arrow.svg") no-repeat 99% center;
    color: #675b1f;
    background-size: 10px auto;
    border: 2px solid #fff;
}

.w20{width: 20%;margin-left: auto;margin-right: auto;}
.w30{width: 30%;margin-left: auto;margin-right: auto;}
.w40{width: 40%;margin-left: auto;margin-right: auto;}
.w50{width: 50%;margin-left: auto;margin-right: auto;}
.w60{width: 60%;margin-left: auto;margin-right: auto;}
.w70{width: 70%;margin-left: auto;margin-right: auto;}
.w80{width: 80%;margin-left: auto;margin-right: auto;}
.w90{width: 90%;margin-left: auto;margin-right: auto;}
@media screen and (max-width: 767px) {
.w20,.w30,.w40,.w50,.w60,.w70,.w80,.w90{width: 100%;}
}

figure{
    text-align: center;
}
figcaption{
    padding-top: 8px;
    text-align: left;
}
.fade{
	opacity: 0;
	transform: translateY(30px);
	transition: opacity 1s, transform .5s;
}
.fade.active{
	opacity: 1;
	transform: translateY(0px);
}
.yt_mov_area{
    width: 100%;
    max-width: 880px;
    margin-left: auto;
    margin-right: auto;
    padding-bottom: 40px;
    text-align: center;
}
.yt_mov iframe{
    width: 100%;
    height: auto;
    aspect-ratio: 16 / 9;
}
.yt_mov_area .hd{
    margin-bottom: 16px;
    font-size: 20px;
    font-weight: 600;
}
@media screen and (max-width: 540px) {
.yt_mov_area{
/*    width: 96%;*/
}
.yt_mov iframe {
    max-width: 100%;
    min-height: 300px;
    max-height: 400px;
}
}


.pc_ac{
    text-align: center;
}
.spc{
    display: none;
}
.dn{
    display: block;
}
@media screen and (max-width: 820px) {
.pc_ac{
    text-align: left;
}
.dn{
    display: none;
}
.spc{
    display: inherit;
}
}

header{
    position: sticky;
    top: 0;
    z-index: 1000;
    width: 100%;
    background: #fff;
}
.header_inner{
    position: relative;
    display: flex;
    width: 100%;
    align-items: center;
    justify-content: flex-end;
    height: 96px;
}
.site_logo{
    position: absolute;
    width: 40%;
    max-width: 300px;
    left: 2%;
    padding-right: 16px;
}
@media screen and (max-width: 1080px) {
.header_inner{
    height: 77px;
}
@media screen and (max-width: 540px) {
.site_logo{
    width: 70%;
    max-width: 240px;
}
}
}

.nav__container{
    position: relative;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 4px;
    width: 75%;
    text-align: center;
    font-size: 16px;
    line-height: 1;
}
@media screen and (max-width: 820px) {
.nav__container{
    display: none;
}
}

.icon_instagram{
    width: 6%;
}
.phone_number{
    display: flex;
    width: 30%;
    max-height: 96px;
    justify-content: flex-end;
}
.phone_number img{
    width: 100%;
    height: auto;
}
#gnav{
    width: 64%;
    text-align: center;
    line-height: 1;
    font-size: 90%;
    letter-spacing: 0;
}
#gnav ul{
    display: flex;
    width: 100%;
    height: 64px;
    margin: auto;
    gap: 4px;
}
#gnav ul li{
    position: relative;
    display: block;
    width: calc(100% / 6);
    margin: auto;
    text-align: center;
    transition: all .3s linear;
}
#gnav ul li a{
    position: relative;
    display: inline-block;
}
#gnav ul li a::after{
    position: absolute;
    bottom: 0;
    left: 0;
    content: '';
    width: 100%;
    height: 3px;
    background: #4d4d4d;
    transform: scale(0, 1);
    transform-origin: right top;
    transition: transform .3s;
}
#gnav ul li a:hover::after{
    transform-origin: left top;
    transform: scale(1, 1);
}
#gnav ul::after{
    display: block;
    clear: both;
    content: '';
}
#gnav ul li:not(:first-child){
    border-left: none;
}
#gnav ul li a{
    width: 100%;
    display: block;
    padding: 8px 0 16px;
    text-align: center;
}
#gnav ul li a:hover,
#gnav ul li a.ov{
    text-decoration: none;
}
#gnav ul li li a{
    display: block;
    padding: 16px 8px;
    background: #fff;
    color: #333;
    font-weight: 300;
    text-decoration: none;
    text-align: left;
}
#gnav ul ul{
    height: inherit;
    margin: 0;
    gap: inherit;
    display: block;
    position: absolute;
    top: 100%;
    left: -1px;
    border-left: 0;
}
#gnav ul ul li{
    display: block;
    width: 280px;
    border: 0;
}
#gnav ul ul li a{
    position: relative;
    display: block;
    border: 0;
}
#gnav ul ul li:not(:first-child) {
    border-top: none;
}
#gnav ul ul ul{
    position: absolute;
    top: 0;
    left: 100%;
}
#gnav ul ul{
    visibility: hidden;
    opacity: 0;
    transition: .3s ease-in-out;
    transform: translateY(-10px);
    z-index: 50;
}
#gnav ul li:hover > ul {
    visibility: visible;
    opacity: 1;
    transform: translateY(0);
}
@media screen and (max-width: 819px) {
#gnav{
    display: none;
}
}


#upper_toggle{
    display: none;
}
.modal_wrap{
    position: relative;
    display: none;
}
.close_button{
    position: fixed;
    top: 20px;
    right: 15px;
    font-size: 40px;
    cursor: pointer;
    color: #fff;
}
@media screen and (max-width: 1024px) {
#upper_toggle{
    display: block;
    position: fixed;
    width: 40px;
    height: 40px;
    top: 10px;
    right: 10px;
    z-index: 8000;
    cursor: pointer;
}
#upper_toggle span{
    display: block;
    position: absolute;
    height: 2px;
    width: 60%;
    margin: auto;
    background: #000;
    left: 0;
    right: 0;
    -webkit-transition: .3s ease-in-out;
    -moz-transition: .3s ease-in-out;
    transition: .3s ease-in-out;
}
.modal_wrap{
    display: block;
}
.modal_wrap input{
    display: none;
}
.modal_overlay{
    display: flex;
    justify-content: center;
    overflow: auto;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 9000;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.4);
    opacity: 0;
    transition: opacity .5s, transform 0s .5s;
    transform: scale(0);
}
.modal_trigger{
    position: absolute;
    width: 100%;
    height: 100%;
}
.modal_content{
    position: relative;
    width: 100%;
    height: 94%;
    overflow-y: auto;
    margin: 0 auto;
    padding: 40px 0;
    box-sizing: border-box;
    background: #fff;
    line-height: 1.4em;
    transform: translateY(-30%);
    transition: .3s;
}
.modal_logo{
    width: 92%;
    margin: 0 auto 24px;
    text-align: left;
}
.tab{
    width: 92%;
    margin: 0 auto;
}
.tab li{
    width: calc(50% - 2px);
    color: #66583d;
    text-align: center;
    font-weight: bold;
    border-top-left-radius: 4px;
    border-top-right-radius: 4px;
}
.tab li:nth-child(1){
    background: #e8e8e8;
}
.tab li:nth-child(2){
    background: #f6e7de;
}
.tab_sub{
    width: 100%;
    margin: 0 auto;
    padding: 0;
    display: flex;
    list-style: none;
}
.tab_sub li{
    width: calc( 20% - 4px );
    margin-bottom: 8px;
}
.tab_sub li.active{
} 
.list{
    width: 92%;
    margin-left: auto;
    margin-right: auto;
}
.sp_clinic_nav{
    padding: 16px 8px;
    background: #675329;
}
.sp_guide_nav{
    padding: 16px 8px;
    background: #f0eadd;
}

.list .hd{
    width: 60%;
    margin: 0 auto 8px;
    padding: 8px;
    background: #fff;
    border-radius: 24px;
    text-align: center;
}
.list .inner,
.list .inner,
.list .thirdtree,
.list .inner table{
    display:none;
}
.list .inner.active{
    display:block;
}
.list .inner .thirdtree.active,
.list .inner table.active{
    display: table;
}
.childnav{
    margin-bottom: 24px;
    padding: 8px 8px 0;
}
.childnav_box{
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
}
.childnav_box .grid{
    width: calc(33% - 4px);
    margin-bottom: 8px;
}
.childnav_box::after{
    content: "";
    display: block;
    width: calc( 33% - 4px );
}


.modal_wrap input:checked ~ .modal_overlay{
    opacity: 1;
    transform: scale(1);
    transition: opacity .3s;
}
.modal_wrap input:checked ~ .modal_overlay .modal_content{
    transform: scale(1);
}
.modal_nav label{
    position: relative;
    display: block;
    margin: 0 0 5px;
    padding: 1em;
    color: #000;
    border-bottom: 1px solid #46517b;
    border-radius: 1px;
    cursor :pointer;
    transition: all .5s ease;
    letter-spacing: 0;
    text-align: left;
}
.modal_nav label a{
    display: block;
    color :#000;
}
.modal_nav label span{
    font-size: 12px;
}
@media screen and (max-width: 540px) {
#upper_toggle{
    width: 40px;
    height: 40px;
    top: 16px;
    right: 10px;
}
.tab_sub li{
    width: calc( 33% - 4px );
    margin-bottom: 8px;
}
@media screen and (max-width: 360px) {
#upper_toggle{
    width: 32px;
    height: 32px;
}
}
}
}
.sp_nav_logo{
    width: 92%;
    margin: 0 auto 24px;
    text-align: left;
}



#bookingbox{
    position: fixed;
    width: 72px;
    height: 336px;
    padding: 24px 16px 0;
    background: #fff;
    right: 0;
    top: 120px;
    z-index: 1000;
    border-top-left-radius: .4em;
    border-bottom-left-radius: .4em;
    text-align: right;
}
#bookingbox .inner{
    writing-mode: vertical-rl;
    display: inline-block;
/*    text-orientation: upright;*/
}
#bookingbox .inner img{
    padding-right: 8px;
}
@media screen and (max-width: 540px) {
#bookingbox{
    display: none;
    width: 40px;
    height: 240px;
    padding: 16px 8px 0;
    top: 88px;
}
#bookingbox .inner img{
    width: 32px;
    height: auto;
}
}



#mv{
    position: relative;
    width: 100%;
    text-align: center;
}
#mv .inner{
    width: 100%;
    max-width: 1120px;
    margin: auto;
    padding: 40px 0 0;
    text-align: left;
}
#mv img{
    width: 100%;
    height: auto;
}



.index__wrap{
    position: relative;
    padding: 0 0 40px;
}



.index__first_area{
    padding: 40px 0;
    background: url("../../../img/asset/fabg_L_pc.jpg") no-repeat 0 0,
    url("../../../img/asset/fabg_R_pc.jpg") no-repeat right 0;
    background-size: contain, contain;
}
.index__first_area .inner{
    padding: 0 4% 0 30%;
    text-align: left;
}
.index__first_area h1{
    margin-bottom: 16px;
    padding: 80px 0 0;
    background: url("../../../img/asset/h1_01.svg") no-repeat 0 10px,
    url("../../../img/asset/common/svg/logo_star.svg") no-repeat 80% 0;
    background-size: 207px auto, 130px auto;
    font-size: 250%;
    font-weight: 600;
    font-family: "Noto Serif JP", "游明朝体", "游明朝", YuMincho, "Yu YuMincho", "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
    line-height: .9;
    color: #805500;
}
.index__first_area h1 span{
    font-size: 80%;
    font-weight: 500;
}
@media screen and (max-width: 820px) {
.index__first_area .inner{
    padding: 0 4% 25%;
}
.index__first_area{
    padding: 40px 0 0;
    background: url("../../../img/asset/fabg_L_pc.jpg") no-repeat 0 bottom,
    url("../../../img/asset/fabg_R_pc.jpg") no-repeat right 0;
    background-size: 50% auto, 50% auto;
}
.index__first_area h1{
    padding: 10% 0 0;
    background: url("../../../img/asset/h1_01.svg") no-repeat 0 5%,
    url("../../../img/asset/common/svg/logo_star.svg") no-repeat 90% 0;
    background-size: 40% auto, 20% auto;
    line-height: 1.2;
}
@media screen and (max-width: 540px) {
.index__first_area h1{
    padding: 18% 0 0;
    background: url("../../../img/asset/h1_01.svg") no-repeat 0 5%,
    url("../../../img/asset/common/svg/logo_star.svg") no-repeat right 0;
    background-size: 55% auto, 30% auto;
}
}
}





.index__tokuchou{
    position: relative;
}
.tokuchou__circle{
    position: absolute;
    top: -240px;
    left: 3%;
}
.index__tokuchou .our_feature_title{
    position: absolute;
    top: -28px;
    right: 10%;
}
.index__tokuchou h2{
    margin-bottom: 16px;
    color: #805500;
    font-size: 250%;
    font-weight: 600;
    font-family: "Noto Serif JP", "游明朝体", "游明朝", YuMincho, "Yu YuMincho", "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
    line-height: 1.2;
    text-shadow: 0 0 4px #f0eadd;
}
.index__tokuchou #index__tokuchou_section01 h2 span:first-of-type
{
    display: inline-block;
    font-size: 150%;
    transform: scale(1.2, 1);
}
.index__tokuchou #index__tokuchou_section01 h2 span:nth-of-type(3),
.index__tokuchou #index__tokuchou_section01 h2 span:nth-of-type(5)
{
    font-size: 80%;
}
#index__tokuchou_section01{
    background: url("../../../img/asset/tokuchou01bg_pc.jpg") no-repeat 0 0,url("../../../img/asset/our_features01.svg") no-repeat right 50%;
    background-size: 60% auto, 37px auto;
    background-color: #f0e9dd;
}
#index__tokuchou_section01 .inner{
    padding: 80px 10% 0 40%;
    text-align: left;
}
#index__tokuchou_section01 .tokuchou_photo,
#index__tokuchou_section03 .tokuchou_photo{
    text-align: right;
}
#index__tokuchou_section02{
    background: url("../../../img/asset/tokuchou02bg_pc.jpg") no-repeat right 60px,url("../../../img/asset/our_features02.svg") no-repeat 0 0;
    background-size: 60% auto, 37px auto;
    background-color: #f0e9dd;
}
#index__tokuchou_section02 .inner{
    padding: 80px 58% 80px 8%;
    text-align: left;
}
.index__tokuchou #index__tokuchou_section02 h2 span:first-of-type
{
    display: inline-block;
    font-size: 150%;
    transform: scale(1.2, 1);
}
.index__tokuchou #index__tokuchou_section02 h2 span:nth-of-type(4),
.index__tokuchou #index__tokuchou_section02 h2 span:nth-of-type(6)
{
    font-size: 80%;
}
.index__tokuchou #index__tokuchou_section03 h2 span:first-of-type
{
    display: inline-block;
    font-size: 150%;
    transform: scale(1.2, 1);
}
.index__tokuchou #index__tokuchou_section03 h2 span:nth-of-type(2)
{
    font-size: 80%;
}
#index__tokuchou_section03{
    background: url("../../../img/asset/tokuchou03bg_pc.jpg") no-repeat 0 0,url("../../../img/asset/our_features03.svg") no-repeat right 0;
    background-size: 60% auto, 37px auto;
    background-color: #f0e9dd;
}
#index__tokuchou_section03 .inner{
    padding: 120px 10% 0 40%;
    text-align: left;
}
#index__tokuchou_section04{
    background: url("../../../img/asset/tokuchou04bg_pc.jpg") no-repeat right 60px,url("../../../img/asset/our_features04.svg") no-repeat 0 0;
    background-size: 60% auto, 37px auto;
    background-color: #f0e9dd;
}
#index__tokuchou_section04 .inner{
    padding: 80px 58% 40px 8%;
    text-align: left;
}
.index__tokuchou #index__tokuchou_section04 h2 span:first-of-type
{
    display: inline-block;
    font-size: 150%;
    transform: scale(1.2, 1);
}
.index__tokuchou #index__tokuchou_section04 h2 span:nth-of-type(4),
.index__tokuchou #index__tokuchou_section04 h2 span:nth-of-type(6)
{
    font-size: 80%;
}
@media screen and (max-width: 1280px) {
#index__tokuchou_section01 .inner{
    padding: 80px 5% 0 40%;
}
#index__tokuchou_section02 .inner{
    padding: 80px 55% 80px 5%;
}
#index__tokuchou_section03 .inner{
    padding: 120px 5% 0 40%;
}
#index__tokuchou_section04 .inner{
    padding: 80px 55% 40px 5%;
}
@media screen and (max-width: 1080px) {
.tokuchou__circle{
    position: absolute;
    width: 280px;
    top: -200px;
    left: 2%;
}
#index__tokuchou_section01 .inner{
    padding: 20px 5% 0 40%;
}
#index__tokuchou_section02 .inner{
    padding: 60px 55% 40px 5%;
}
#index__tokuchou_section03 .inner{
    padding: 0 5% 0 40%;
}
#index__tokuchou_section04 .inner{
    padding: 60px 50% 40px 5%;
}
@media screen and (max-width: 820px) {
.tokuchou__circle{
    position: absolute;
    width: 280px;
    margin: 0 auto;
    top: -140px;
    left: 2%;
}
.index__tokuchou .our_feature_title{
    right: 5%;
}
#index__tokuchou_section01{
    background: url("../../../img/asset/tokuchou01bg.jpg") no-repeat 0 bottom,url("../../../img/asset/our_features01.svg") no-repeat right 40px;
    background-size: 100% auto, 37px auto;
    background-color: #f0e9dd;
}
#index__tokuchou_section01 .inner{
    padding: 20% 4% 55%;
}
#index__tokuchou_section01 .inner .ar img{
    width: 100%;
    height: auto;
}
#index__tokuchou_section01 .tokuchou_photo{
    text-align: center;
}
#index__tokuchou_section02{
    background: url("../../../img/asset/tokuchou02bg.jpg") no-repeat 0 bottom,url("../../../img/asset/our_features02.svg") no-repeat right 40px;
    background-size: 100% auto, 37px auto;
    background-color: #f0e9dd;
}
#index__tokuchou_section02 .inner{
    padding: 40px 4% 50%;
}
#index__tokuchou_section02 .tokuchou_photo{
    text-align: center;
}
.tokuchou_photo img{
    width: 100%;
    height: auto;
}
#index__tokuchou_section03{
    background: url("../../../img/asset/tokuchou03bg.jpg") no-repeat 0 bottom,url("../../../img/asset/our_features03.svg") no-repeat right 40px;
    background-size: 100% auto, 37px auto;
    background-color: #f0e9dd;
}
#index__tokuchou_section03 .inner{
    padding: 40px 4% 60%;
}
#index__tokuchou_section04{
    background: url("../../../img/asset/tokuchou04bg.jpg") no-repeat 0 bottom,url("../../../img/asset/our_features04.svg") no-repeat right 0;
    background-size: 100% auto, 37px auto;
    background-color: #f0e9dd;
}
#index__tokuchou_section04 .inner{
    padding: 40px 4% 60%;
}
#index__tokuchou_section04 .tokuchou_photo{
    text-align: center;
}
#index__tokuchou_section04 .tokuchou_photo img{
    width: 80%;
    height: auto;
}
@media screen and (max-width: 540px) {
.tokuchou__circle{
    width: 48%;
    top: -80px;
}
.index__tokuchou .our_feature_title{
    width: 30%;
    top: -28px;
    right: 10%;
}
#index__tokuchou_section01 .inner{
    padding: 28% 4% 55%;
}
}
}
}
}


.index__guides{
    padding: 40px 0 40px;
}
.index__guides .inner{
    width: 92%;
    margin: 0 auto;
    text-align: left;
}
.index__guides h2{
    margin-bottom: 40px;
    padding-top: 56px;
    background: url("../../../img/asset/h2_worried_pc.svg") no-repeat center 0;
    background-size: 609px auto;
    color: #805500;
    font-size: 188%;
    font-weight: 500;
    font-family: "Noto Serif JP", "游明朝体", "游明朝", YuMincho, "Yu YuMincho", "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
    text-align: center;
}
.index__guides .ortho__block{
    margin: 0 0 24px;
    padding: 80px 0 40px;
    background: #e5f2fe url("../../../img/asset/orthbg_pc.jpg") no-repeat right 0;
    background-size: 90% auto;
}
.index__guides .ortho__block .inner{
    width: 60%;
    max-width: 640px;
    margin: 0 0 0 5%;
}
.index__guides .block{
    width: calc(50% - 8px);
    padding: 20% 80px 40px;
}
.index__guides .hotetsu__block{
    background: #ffe7e6 url("../../../img/asset/hotetsubg_pc.jpg") no-repeat 0 0;
    background-size: 80% auto;
}
.index__guides .caremenu__block{
    background: #fbf6c9 url("../../../img/asset/carebg_pc.jpg") no-repeat 0 0;
    background-size: 100% auto;
}
.index__guides h3{
    margin-bottom: 24px;
    color: #805500;
    font-size: 156%;
    font-weight: 500;
    font-family: "Noto Serif JP", "游明朝体", "游明朝", YuMincho, "Yu YuMincho", "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
    text-align: center;
}
.index__guides h3 span{
    font-size: 56%;
}
.index__guides .icons{
    display: flex;
    gap: 8px;
    justify-content: center;
    align-items: center;
}
.index__guides .ortho__block .icons{
    flex-wrap: wrap;
    gap: 0;
    align-items: flex-start;
}
.index__guides .ortho__block .icons a{
    display: inline-block;
    width: calc(20% - 4px);
}
.index__guides .caremenu__block .icons{
    width: 50%;
    margin: auto;
}
.treatment-icons a img{
    width: 169px;
    height: auto;
}
@media screen and (max-width: 820px) {
.index__guides .block{
    padding: 20% 16px 24px;
}
@media screen and (max-width: 540px) {
.index__guides .block{
    width: 100%;
    padding: 40% 16px 24px;
}
.index__guides .ortho__block{
    margin: 0 0 24px;
    padding: 120px 0 24px;
    background: #e5f2fe url("../../../img/asset/orthbg.jpg") no-repeat right 0;
    background-size: 100% auto;
}
.index__guides .ortho__block .inner{
    width: 92%;
    max-width: 540px;
    margin: 0 auto;
}
.index__guides .ortho__block .icons a{
    width: calc(33% - 4px);
}
.index__guides .hotetsu__block{
    margin-bottom: 24px;
}
.index__guides h3{
    margin-bottom: 16px;
}
}
}



.index__flow{
    padding: 80px 0 40px;
    background: url("../../../img/asset/flowbg_pc.jpg") no-repeat 0 0;
    background-size: cover;
}
.index__flow .inner{
    width: 92%;
    margin: 0 auto;
    text-align: left;
}
.index__flow h2{
    margin-bottom: 40px;
    color: #333;
    font-size: 400%;
    font-weight: 600;
    font-family: "Noto Serif JP", "游明朝体", "游明朝", YuMincho, "Yu YuMincho", "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
    line-height: .8;
}
.index__flow h2 span{
    font-size: 50%;
    font-weight: 500;
}
#swiper{
    position: relative;
    overflow-y: hidden !important;
}
#swiper .swipe_hint{
    display: none;
    position: absolute;
    width: 90px;
    height: 60px;
    margin: auto;
    top: 0;
    bottom: 0;
    left: 40%;
    z-index: 9999;
}
.swiper{
    width: 90%;
    margin: 0 auto 24px;
    padding-bottom: 28px;
}
.swiper_group{
    height: 24px;
}
.swiper-slide{
    display: flex;
    width: 100%;
    height: 100%;
    justify-content: center;
    align-items: center;
}
.swiper-slide{
    height: 100%;
}
.swiper .box{
    min-height: 560px;
    padding: 24px;
    margin-bottom: 8px;
    background: #fff;
}
.swiper-slide h3{
    margin: 0 0 8px;
    font-size: 22px;
    font-weight: 600;
    color: #805500;
}
@media screen and (max-width: 820px) {
.swiper .box{
    min-height: 460px;
    margin-bottom: 8px;
    padding: 16px;
}
#swiper .swipe_hint{
    display: block;
}
@media screen and (max-width: 540px) {
.index__flow{
    padding: 80px 0 40px;
    background: url("../../../img/asset/flowbg_pc.jpg") no-repeat 0 0;
    background-size: cover;
}
.swiper-slide{
    height: 90%;
}
.swiper .box{
    min-height: 440px;
}
}
}



.index__clinictour{
    padding: 80px 0;
    background: #4d4d4d;
    color: #fff;
}
.index__clinictour .inner{
    width: 80%;
    max-width: 1600px;
    margin: 0 auto;
    text-align: left;
}
.index__clinictour h2{
    margin-bottom: 24px;
    font-size: 320%;
    font-weight: 600;
    font-family: "Noto Serif JP", "游明朝体", "游明朝", YuMincho, "Yu YuMincho", "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
    line-height: .6;
}
.index__clinictour h2 span{
    font-size: 50%;
}
.index__clinictour .slider_for{
    width: 100%;
    margin-bottom: 24px;
}
.index__clinictour .slider_for img{
    width: 100%;
    height: auto;
}
.index__clinictour .slider_nav{
    width: 100%;
    margin-bottom: 40px;
}
.index__clinictour .slider_nav div{
    padding: 0 2px;
}
.index__clinictour .slider_nav div img{
    cursor: pointer;
}
.index__clinictour .more a{
    width: 30%;
}
@media screen and (max-width: 1080px) {
.index__clinictour h2{
    width: 92%;
}
.index__clinictour .inner{
    width: 92%;
}
.index__clinictour .more a{
    width: 40%;
}
@media screen and (max-width: 820px) {
.index__clinictour .more a{
    width: 50%;
}
@media screen and (max-width: 540px) {
.index__clinictour{
    padding: 64px 0;
}
.index__clinictour .more a{
    width: 100%;
}
}
}
}



.index__faq{
    background: url("../../../img/asset/faqbg_pc.jpg") no-repeat 0 0;
    background-size: cover;
}
.index__faq .grid:first-child{
    width: 35%;
    padding: 160px 0;
    background: rgba(128,102,51,.6);
    color: #fff;
    text-align: center;
}
.index__faq .grid:first-child .box{
    width: 88%;
    margin: 0 auto;
    text-align: left;
}
.index__faq .grid .more a{
    font-size: 85%;
}
.index__faq .grid:first-child .more a{
    margin: 0 auto 16px;
}
.index__faq .grid:last-child{
    width: 65%;
    padding: 40px 0;
    background: rgba(255,255,255,.5);
}
.index__faq h2{
    margin-bottom: 40px;
    font-size: 155%;
    font-weight: 500;
    font-family: "Noto Serif JP", "游明朝体", "游明朝", YuMincho, "Yu YuMincho", "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
    line-height: .8;
}
.index__faq .notes{
    width: 80%;
    margin: 0 auto 16px;
    padding: 56px;
    text-align: left;
}
.index__faq .notes_bg_long{
    background: #fff url("../../../img/asset/faq_long.jpg") no-repeat 16px 16px;
    background-size: 64px auto;
}
.index__faq .notes_bg_short{
    background: #fff url("../../../img/asset/faq_short.jpg") no-repeat 16px 16px;
    background-size: 64px auto;
}
.index__faq dt{
    min-height: 56px;
    margin-bottom: 8px;
    padding: 12px 0 0 64px;
    background: url("../../../img/asset/common/svg/faq_q.svg") no-repeat 0 8px;
    background-size: 45px auto;
    font-size: 120%;
    font-weight: 600;
}
.index__faq dd div:first-of-type{
    min-height: 56px;
    padding: 12px 0 0 64px;
    background: url("../../../img/asset/common/svg/faq_a.svg") no-repeat 0 center;
    background-size: 45px auto;
    color: #9a001a;
    font-size: 110%;
    font-weight: 600;
}
.index__faq dd div:last-child{
    padding-left: 64px;
}
.index__faq .more__area{
    width: 72%;
    margin: auto;
    text-align: left;
}
.index__faq .more__area .more{
    width: calc(50% - 8px);
}
@media screen and (max-width: 1080px) {
.index__faq .grid:first-child{
    width: 40%;
    }
.index__faq .grid:last-child{
    width: 60%;
}
.index__faq .notes{
    width: 92%;
    padding: 48px 56px;
}
@media screen and (max-width: 820px) {
.index__faq{
    background: url("../../../img/asset/faqbg.jpg") no-repeat 0 0;
    background-size: cover;
}
.index__faq .grid:first-child{
    width: 100%;
    padding: 40px 0;
}
.index__faq .grid:last-child{
    width: 100%;
    padding: 40px 0;
}
.index__faq .notes{
    width: 90%;
    margin: 0 auto 16px;
    background-color: rgba(255,255,255,.6);
}
.index__faq .more a{
    width: 50%;
    margin-bottom: 16px;
}
@media screen and (max-width: 540px) {
.index__faq .more__area{
    width: 100%;
}
.index__faq .more a{
    width: 100%;
    margin-bottom: 16px;
}
.index__faq .more__area .more:last-child{
    width: 100%;
    margin-bottom: 0;
}
}
}
}




.index__greeting{
    padding: 64px 0;
    background: url("../../../img/asset/greetingbg_pc.jpg") no-repeat -20% 0;
    background-size: 60% auto;
}
.index__greeting .inner{
    padding: 0 8% 0 55%;
}
.index__greeting h2{
    margin-bottom: 24px;
    font-size: 280%;
    font-weight: 500;
    font-family: "Noto Serif JP", "游明朝体", "游明朝", YuMincho, "Yu YuMincho", "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
    line-height: .9;
    text-align: right;
}
.index__greeting h2 span{
    font-size: 50%;
}
.index__greeting .president_photo{
    margin: 0 0 24px;
    text-align: right;
}
.index__greeting .president__detail{
    margin-bottom: 16px;
    text-align: left;
}
.index__greeting .more{
    display: flex;
    justify-content: flex-end;
}
.index__greeting .more a{
    width: 30%;
    margin: 0 8% 0 0;
}
@media screen and (max-width: 1280px) {
.index__greeting{
    background: url("../../../img/asset/greetingbg_pc.jpg") no-repeat -30% center;
    background-size: 65% auto;
}
.index__greeting .inner{
    padding: 0 4% 0 50%;
}
.index__greeting .more a{
    width: 30%;
    margin: 0 4% 0 0;
}
@media screen and (max-width: 1080px) {
.index__greeting{
    background: url("../../../img/asset/greetingbg_pc.jpg") no-repeat -35% bottom;
    background-size: 65% auto;
}
.index__greeting .inner{
    padding: 0 4% 0 55%;
}
@media screen and (max-width: 820px) {
.index__greeting .more a{
    width: 40%;
}
@media screen and (max-width: 540px) {
.index__greeting{
    padding: 64px 0 80%;
    background: url("../../../img/asset/greetingbg_u.jpg") no-repeat 0 0,
     url("../../../img/asset/greetingbg_b.jpg") no-repeat 0 bottom;
    background-size: 100% auto, 100% auto;
}
.index__greeting .inner{
    padding: 0 4% 16px 40%;
}
.index__greeting .more a{
    width: 88%;
    margin: 0 auto;
}
}
}
}
}




.foot__start{
    padding: 36% 0 0;
    background: url("../../../img/asset/footbg_pc.jpg") no-repeat 0 0;
    background-size: 100% auto;
}
.foot__start .hd{
    width: 80%;
    max-width: 1280px;
    margin: 0 auto;
    padding: 40px 24px 0;
    background: #fff;
    text-align: center;
    font-size: 240%;
    font-weight: 500;
    font-family: "Noto Serif JP", "游明朝体", "游明朝", YuMincho, "Yu YuMincho", "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
    line-height: 1.3;
}
.foot__start .hd span{
    font-size: 85%;
}
@media screen and (max-width: 820px) {
.foot__start{
    padding: 60% 0 0;
    background: url("../../../img/asset/footbg.jpg") no-repeat 0 0;
    background-size: 100% auto;
}
.foot__start .hd{
    width: 92%;
}
@media screen and (max-width: 540px) {
.foot__start{
    padding: 50% 0 0;
    background: url("../../../img/asset/footbg.jpg") no-repeat 0 0;
    background-size: 100% auto;
}
}
}




.all__news{
    padding: 80px 0;
}
.all__news .inner{
    width: 92%;
    max-width: 1080px;
    margin: 0 auto;
    text-align: left;
}
.all__news .hd{
    margin-bottom: 24px;
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
    font-size: 320%;
    line-height: 1;
    text-align: center;
}
.all__news .hd span{
    font-size: 60%;
}
.all__news li{
    margin-bottom: 24px;
    padding-bottom: 8px;
    border-bottom: 1px solid #eee;
}
.all__news .more a{
    width: 20%;
}
@media screen and (max-width: 820px) {
.all__news .more a{
    width: 60%;
}
@media screen and (max-width: 540px) {
.all__news{
    padding: 40px 0;
}
.all__news .more a{
    width: 92%;
}
}
}



.all__counseling{
    padding: 0 0 40px;
    background: url("../../../img/asset/counselingbg_pc.jpg") no-repeat 0 0;
    background-size: 100% auto;
}
.all__counseling dl{
    width: 40%;
    margin-bottom: 32px;
}
.all__counseling dt{
    margin: 0 32px 16px 0;
}
.all__counseling dd{
    margin: 0 0 16px 32px;
}
.all__counseling .inner{
    width: 92%;
    max-width: 1440px;
    margin: 0 auto;
    text-align: left;
}
.all__counseling .hd{
    margin-bottom: 24px;
    padding: 32px 0 0;
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
    font-size: 320%;
    line-height: 1.2;
    color: #fff;
}
.all__counseling .hd span{
    font-size: 70%;
}
.all__counseling .hd02{
    margin-bottom: 24px;
    padding-top: 40px;
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
    font-size: 280%;
    line-height: .8;
    text-align: center;
}
.all__counseling .hd02 span{
    font-size: 50%;
}
.all__counseling .hd03{
    margin-bottom: 24px;
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
    font-size: 320%;
    line-height: 1.6;
    text-align: center;
}
.all__counseling .hd03 span{
    font-size: 70%;
}
.all__counseling .box_inner{
    border: 1px solid #e5e5e5;
    box-shadow: 0 0 24px #eee;
    border-radius: 8px;
}
.all__counseling .all__counseling__txt{
    margin-bottom: 32px;
    text-align: center;
}
.all__counseling ol{
    width: 90%;
    margin: 0 auto;
    padding: 4em;
}
.all__counseling ol li{
	width: calc( 33% - 8px);
}
.all__counseling ol li img{
	width: 100%;
    height: auto;
}
@media screen and (max-width: 1080px) {
.all__counseling{
    padding: 0 0 40px;
    background: url("../../../img/asset/counselingbg_pc.jpg") no-repeat right 0;
    background-size: 130% auto;
}
.all__counseling dl{
    width: 50%;
}
@media screen and (max-width: 820px) {
.all__counseling{
    padding: 55% 0 40px;
    background: url("../../../img/asset/counselingbg.jpg") no-repeat 0 0;
    background-size: 100% auto;
}
.all__counseling .inner{
    text-align: left;
}
.all__counseling dl{
    width: 100%;
    margin-bottom: 16px;
}
.all__counseling .notes_white{
    padding: 40px;
}
.all__counseling ol{
    width: 88%;
    margin: 0 auto;
    padding: 24px 0;
}
@media screen and (max-width: 540px) {
.all__counseling{
    padding: 55% 0 24px;
    background: #fff url("../../../img/asset/counselingbg.jpg") no-repeat right 0;
    background-size: 100% auto;
}
.all__counseling dt{
    margin: 0 24px 8px 0;
}
.all__counseling dd{
    margin: 0 0 8px 24px;
}
.all__counseling .notes_white{
    padding: 24px 0;
}
.all__counseling .hd{
    font-size: 250%;
}
.all__counseling .hd02{
    padding-top: 16px;
}
.all__counseling .box_inner{
    padding: 24px 24px 0;
}
.all__counseling ol{
    width: 100%;
}
.all__counseling ol li{
	width: 100%;
    margin-bottom: 16px;
}
}
}
}


footer{
    padding: 0;
    background: #fff;
}
/*
footer .inner{
    width: 100%;
    max-width: 1120px;
    margin: 0 auto 40px;
    padding: 40px 0 0;
    text-align: center;
}
*/
footer .train{
    width: 100%;
    max-width: 300px;
    min-height: 44px;
    margin: 0 auto 40px;
    padding: 0 0 0 56px;
    background: url("../../../img/asset/common/svg/train.svg") no-repeat 0 center;
    background-size: 44px auto;
    display: flex;
    align-items: center;
}
footer .foot_cfp{
    margin-bottom: 24px;
}
footer .foot_cfp li{
    width: 52%;
    padding-right: 16px;
}
footer .foot_cfp li:nth-child(2),
footer .foot_cfp li:nth-child(3){
    width: 24%;
    padding-right: 0;
}
footer .foot_cfp li:nth-child(2) img,
footer .foot_cfp li:nth-child(3) img{
    width: 100%;
    height: auto;
}
.gmap{
    width: 100%;
    height: 480px;
    margin-left: auto;
    margin-right: auto;
}
@media screen and (max-width: 820px) {
@media screen and (max-width: 540px) {
}
}

.foot__instagram{
    margin-bottom: 80px;
    padding: 80px 0;
    background: #4d4d4d;
    color: #fff;
}
.foot__instagram .box{
    width: 100%;
    max-width: 1280px;
    margin: 0 auto;
    text-align: left;
}
.foot__instagram .box a{
    color: #fff;
}
@media screen and (max-width: 960px) {
.foot__instagram .box{
    width: 92%;
}
}



.sitelinks{
    padding: 40px 0;
    letter-spacing: 0;
    font-size: 13px;
}
.sitelinks .fx{
    width: 92%;
    margin: 0 auto;
}
.sitelinks .fx .box{
    width: calc(20% - 1%);
    padding: 8px 0;
}
.sitelinks li a::before{
    content: "- ";
}
.sitelinks li a{
    position: relative;
    display: inline-block;
    padding: 4px 0;
    color: #333;
    text-decoration: none;
    letter-spacing: 0;
}
.sitelinks li a::after{
    position: absolute;
    bottom: 0;
    left: 0;
    content: '';
    width: 100%;
    height: 1px;
    background: #42b0a9;
    transform: scale(0, 1);
    transform-origin: right top;
    transition: transform .3s;
}
.sitelinks li a:hover::after{
    transform-origin: left top;
    transform: scale(1, 1);
}
.sitelinks li img{
    vertical-align: baseline;
}
.sitelinks div div:nth-child(2) dl dd div{
    width: calc(50% - 4px);
}
@media screen and (max-width: 1280px) {
.sitelinks .fx{
    width: 92%;
}
@media screen and (max-width: 540px) {
.gmap{
    height: 400px;
}
.sitelinks{
    font-size: 15px;
}
.sitelinks .fx .box{
    width: 100%;
    padding: 0;
    border-right: 0;
}
.sitelinks .fx .box:nth-child(1){
    width: 100%;
}
.sitelinks .fx .box:nth-child(2){
    width: 100%;
}
.sitelinks .fx .box{
    width: 100%;
    padding: 0;
}
.sitelinks .fx .box:nth-child(2){
    width: 100%;
    padding: 0;
}
.sitelinks ol.fx .grid{
    width: 100%;
}
.sitelinks div div:nth-child(2) dl dd div{
    width: 100%;
}
}
}


.sitelinks dl{
    padding: 0 0 8px;
    border-bottom: 1px dashed #333;
}
.sitelinks div a,
.sitelinks p a{
    position: relative;
    display: inline-block;
    display: block;
    margin-bottom: 16px;
    padding: 0 0 8px;
    color: #333;
    border-bottom: 1px dashed #251e1c;
    text-align: left;
}
.sitelinks div div:nth-child(3) div:nth-child(9) a{
    border-bottom: 0;
}
.sitelinks div a::after,
.sitelinks p a::after{
    position: absolute;
    bottom: -2px;
    left: 0;
    content: '';
    width: 100%;
    height: 2px;
    background: #4d4d4d;
    transform: scale(0, 1);
    transform-origin: right top;
    transition: transform .3s;
}
.sitelinks div div:nth-child(3) div:nth-child(9) a::after{
    background: #fff;
}
.sitelinks dl dd div li{
    margin-bottom: 16px;
}
.sitelinks dl dd div li ul li{
    margin-bottom: 0;
}
.sitelinks div a:hover::after,
.sitelinks p a:hover::after{
    bottom: -1px;
    transform-origin: left top;
    transform: scale(1, 1);
}
.sitelinks li a{
    margin: 0;
    padding-bottom: 0;
    border-bottom: 0;
}
.ft_nav{
    margin-bottom: 16px;
    padding: 0 0 8px;
    color: #000;
    text-align: left;
}
.ft_hd{
	position: relative;
	padding: 0;
    color: #333;
    text-align: left;
}
.ft_btn{
	position: absolute;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
	background: #fff;
	display: block;
	width: 32px;
	height: 32px;
	text-indent: 100%;
	white-space: nowrap;
	overflow: hidden;
	border-radius: 50%;
    transition:all .3s linear;
}
.ft_nav dd{
    padding: 0 16px 8px;
}
.ft_nav dd li li{
    padding-left: 16px;
}
@media screen and (max-width: 540px) {
.sitelinks div a,
.sitelinks dl,
.sitelinks p a{
    padding: 0 0 4px;
    border-bottom: 1px solid #5f5f5e;
}
.sitelinks li a{
    padding: 4px 0 0;
}
.sitelinks ul,
.sitelinks ol{
    padding-top: 8px;
}
.sitelinks ol ol{
    padding-top: 0;
}
.ft_nav{
    border-bottom: 1px solid #f1f1f1;
}
.ft_btn:before, .ft_btn:after{
	display: block;
	content: '';
	background: #5f5f5e;
	position: absolute;
	width: 10px;
	height: 2px;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}
.ft_hd{
	cursor: pointer;
}
.ft_btn:before{
	width: 2px;
	height: 10px;
}
.ft_hd.selected .ft_btn:before {
	content: normal;
}
.ft_nav dd{
	display: none;
}
}




#copyright{
    padding: 16px;
    background: #4d4d4d;
    color: #fff;
    text-align: center;
    letter-spacing: 0;
    font-size: 12px;
}
#copyright a{
    color: #fff;
}
@media screen and (max-width: 820px) {
#copyright{
    padding: 16px 0 80px;
}
}

.bottomnav{
    position: fixed;
    display: none;
    width: 100%;
    height: 69px;
    padding: 8px 0 0;
    bottom: 0;
    z-index: 9999;
/*    background: #f6e7de;*/
    background: linear-gradient(90deg,#4d4d4d 0%, #4d4d4d 33.333%, #fff 33.333%, #fff 66.666%, #9a001a 66.666%);
}
.bottomnav li{
    width: 33.333%;
}
@media screen and (max-width: 820px) {
.bottomnav{
    display: block;
}
@media screen and (max-width: 540px) {
.bottomnav{
    height: 64px;
}
@media screen and (max-width: 360px) {
}
}
}


/* ▼▼▼▼▼▼▼▼▼▼▼▼ 共通項目 ▼▼▼▼▼▼▼▼▼▼▼▼ */



.breadcrumbs{
    margin-bottom: 40px;
    padding: 24px 0;
    background: #fff;
    text-align: left;
}
.breadcrumbs div{
    width: 92%;
    max-width: 1280px;
    margin-right: auto;
    margin-left: auto;
}
#wrap{
    padding: 80px 0;
    text-align: left;
}
#sub__wrap{
    padding-bottom: 80px;
    background: #fff;
    text-align: left;
}
#wrap article{
    padding: 0 0 80px;
/*    background: #fff;*/
}
#wrap section,
#wrap .section,
#wrap .mw_section{
    width: 92%;
    max-width: 1280px;
    margin-right: auto;
    margin-left: auto;
    background: #fff;
}
.entry section{
    margin: 0 0 80px;
}
.section_inner{
    padding: 0 16px 24px;
}
#wrap h2{
    margin-bottom: 24px;
    padding: 24px;
    background: #f0e9dd;
    font-size: 133%;
    font-weight: 600;
    text-align: left;
}
#wrap h3{
    position: relative;
    margin-bottom: 24px;
    padding: 0 0 .5em;
    font-size: 117%;
    font-weight: 600;
}
#wrap article h3::after{
    position: absolute;
    content: "";
    display: inline-block;
    width: 4em;
    height: 1px;
    background: #7f7f7f;
    left: 0;
    bottom: 0;
}
#wrap h4{
    position: relative;
    margin-bottom: 24px;
    padding-left: 32px;
    font-size: 18px;
    font-weight: 600;
}
#wrap h4:before{
    position: absolute;
    content: " ";
    display: block;
    width: 16px;
    bottom: 44%;
    left: 0;
    border-bottom: 5px solid #e6462e;
}
#wrap h5{
    margin-bottom: 16px;
    font-size: 18px;
    font-weight: 600;
}
.fx{
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
}
.fx_c{
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
}
.fx_r{
    display: flex;
    flex-direction: row-reverse;
    flex-wrap: wrap;
    justify-content: space-between;
}
.fx_e{
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-end;
}
.two_columns,
.two_block,
.three_columns,
.four_columns,
.five_columns
{
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
}
.three_columns::after{
    content: "";
    display: block;
	width: calc( 33% - 8px);
}
.two_block .box{
	width: calc( 50% - 16px);
}
.two_columns .box{
	width: calc( 50% - 16px);
}
.three_columns .box{
	width: calc( 33% - 8px);
}
.four_columns .box,
.four_columns::after
{
	width: calc( 25% - 8px);
}
.four_columns::after{
    content: "";
    display: block;
}
.five_columns .box{
	width: calc( 20% - 4px);
}
.oz .imgL,
.oz .s_imgL{
    max-width: 48%;
    margin-right: 24px;
}
.oz .imgR,
.oz .s_imgR{
    max-width: 48%;
    margin-left: 24px;
}
.exclamation{
    padding-left: 32px;
    background: url("../../../img/asset/common/svg/exclamation.svg") no-repeat 0 0;
    background-size: 22px auto;
}
.notes{
    padding: 24px;
}
.notes_white{
    background: #fff;
}
.notes_gray{
    background: #efefef;
}
.notes_pyellow{
    background: #fffdeb;
}
.notes_pyellow span{
    font-size: 18px;
    font-weight: bold;
}
.note_blue{
    background: #cde7ef;
}
.notes_pblue{
    background: #e6fafa;
    text-align: left;
}
.notes_attention{
    padding: 32px;
    background: #efefef url("../../../img/asset/common/svg/attention.svg") no-repeat center center;
    background-size: 200px auto;
    border: 1px solid #4d4d4d;
}
.notes_border{
    padding: 1.3em;
    border: 1px solid #4d4d4d;
}
.notes_pyellow span{
    font-size: 18px;
    font-weight: bold;
}


/*

.meritbox{
    padding: 40px 24px 16px;
    background: #ffefe5;
}
.meritbox .hd{
    margin-bottom: 24px;
    padding: 40px 0 0;
    background: url("../../../img/asset/common/svg/merit.svg") no-repeat center 0;
    background-size: 129px auto;
    font-size: 18px;
    font-weight: bold;
    text-align: center;
}
.meritbox li{
    margin-bottom: 8px;
    padding: 8px 8px;
    background: #fff;
}
.meritbox li div:first-child{
    margin-bottom: 8px;
    padding: 0 0 0 32px;
    background: url("../../../img/asset/common/svg/o.svg") no-repeat 0 6px;
    background-size: 18px auto;
}
.meritbox dt{
    margin-bottom: 8px;
    padding: 0 0 0 32px;
    background: url("../../../img/asset/common/svg/o.svg") no-repeat 0 6px;
    background-size: 18px auto;
}
.meritbox dd:last-child{
    margin-bottom: 0;
}
.demeritbox{
    padding: 40px 24px 16px;
    background: #d9d9d9;
}
.demeritbox .hd{
    margin-bottom: 24px;
    padding: 40px 0 0;
    background: url("../../../img/asset/common/svg/demerit.svg") no-repeat center 0;
    background-size: 188px auto;
    font-size: 18px;
    font-weight: bold;
    text-align: center;
}
.demeritbox li{
    margin-bottom: 8px;
    padding: 8px;
    background: #fff;
}
.demeritbox li div:first-child{
    margin-bottom: 8px;
    padding: 0 0 0 32px;
    background: url("../../../img/asset/common/svg/x.svg") no-repeat 8px 8px;
    background-size: 11px auto;
}
.demeritbox li div:last-child{
}
.demeritbox dt{
    margin-bottom: 8px;
    padding: 0 0 0 32px;
    background: url("../../../img/asset/common/svg/x.svg") no-repeat 8px 8px;
    background-size: 11px auto;
}
.demeritbox dd{
}
.demeritbox dd:last-child{
    margin-bottom: 0;
}
*/
.merits__demerits{
    margin-bottom: 0;
}
.merits__demerits .merits__box{
    margin-bottom: 24px;
    padding: 24px 16px;
    background: #f0e9dd;
}
.merits__demerits .demerits__box{
    margin-bottom: 24px;
    padding: 24px 16px;
    background: #d9d9d9;
}
.cause__box{
    margin-bottom: 24px;
    padding: 24px 16px;
    background: #cde7ef;
}
.merits__demerits .grid:nth-of-type(1){
    width: 20%;
    text-align: center;
}
.merits__demerits .grid:nth-of-type(2){
    width: 80%;
}
.merits__demerits li{
    margin-bottom: 8px;
}
.merits__demerits li::before{
    content: "・ ";
    color: #9a001a;
    font-size: 122%;
    line-height: 1;
    font-weight: bold;
}
@media screen and (max-width: 540px) {
.merits__demerits .merits__box{
    padding: 16px 8px;
}
.merits__demerits .demerits__box{
    padding: 16px 8px;
}
.merits__demerits .cause__box{
    padding: 16px 8px;
}
.merits__demerits .grid:nth-of-type(1){
    width: 30%;
}
.merits__demerits .grid:nth-of-type(2){
    width: 70%;
}
}



.faq__area dl{
}
.faq__area dt{
    min-height: 50px;
    margin-bottom: 24px;
    padding: 16px 0 0 48px;
    background: url("../../../img/asset/common/svg/faq_q.svg") no-repeat 0 4px;
    background-size: 30px auto;
    font-weight: 600;
}
.faq__area dd{
    margin: 0 0 48px;
}
.faq__area .hd__answer{
    min-height: 50px;
    margin-bottom: 16px;
    padding: 16px 0 0 48px;
    background: url("../../../img/asset/common/svg/faq_a.svg") no-repeat 0 center;
    background-size: 29px auto;
    color: #f0eadd;
    font-weight: 600;
}
.faq__area .detail__box{
    padding: 24px;
    background: #fff;
}
@media screen and (max-width: 540px) {
.faq__area dt{
    margin-bottom: 8px;
}
.faq__area dd{
    margin: 0 0 40px;
}
}


.checklists li{
    margin-bottom: 4px;
    padding: 4px 8px 4px 32px;
    background: url("../../../img/asset/common/svg/check.svg") no-repeat 8px center;
    background-size: 16px auto;
}
.dot_list li,
.dot_list_g li{
    margin-left: 0;
}
.dot_list li::before{
    content: '・ ';
    color: #4d4d4d;
    font-size: 120%;
    font-weight: bold;
}
.dot_list li li::before{
    margin-left: 24px;
    content: '';
}
.external{
    background: url("img/external.svg") no-repeat right center;
    background-size: 10px auto;
}
.external_b{
    background: url("img/external_blue.svg") no-repeat right center;
    background-size: 10px auto;
}
@media screen and (max-width: 1080px) {
#wrap{
    padding: 40px 0;
}
@media screen and (max-width: 1023px) {
#wrap article{
    padding: 40px 0 80px;
}
#wrap section,
#wrap .section{
    width: 92%;
}
#wrap section .inner,
#wrap .section .inner{
    padding: 0;
}
section .block {
    padding: 16px;
}
.four_columns .box{
	width: 100%;
}
.three_columns .box,
ol.three_columns li,
.three_columns_li li{
	width: calc( 33% - 4px);
}
.sbi_photo_wrap{
    width: 100%;
    height: 100%;
}
.sbi_photo:hover{
    transform: scale(1.1);
}

@media screen and (max-width: 540px) {
.breadcrumbs div{
    width: 92%;
}
#wrap h2{
    padding: 16px;
}
.oz .imgL{
    float: none;
    max-width: 100%;
    margin-right: 0;
    text-align: center;
}
.oz .imgR{
    float: none;
    max-width: 100%;
    margin-left: 0;
    text-align: center;
}
.oz .s_imgR{
    margin-bottom: 4px;
}
.two_columns .box,
.two_columns_li li,
.two_columns li{
    width: 100%;
}
.three_columns .box,
.three_columns_li li,
ol.three_columns li{
    width: 100%;
}
.five_columns .box{
	width: calc( 50% - 2px);
}
.sub_fv .grid{
    width: 100%;
}
.sub_fv .grid:nth-child(2){
    width: 100%;
    padding-top: 0;
}
.faq_area dl{
    padding: 16px;
}
.dot_list li{
    background: url("../../../img/asset/common/svg/dots.svg") no-repeat 0 12px;
    background-size: 6px auto;
}
}
}
}




#submv{
    margin: 0;
    padding: 120px 0;
    background: #f6e7de url("../../../img/asset/submvbg_pc.jpg") repeat center 0;
    font-size: 144%;
    font-family: "Noto Serif JP", "游明朝体", "游明朝", YuMincho, "Yu YuMincho", "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
    background-size: 100% auto;
    font-weight: bold;
    line-height: 1.5;
}
#submv h1.clinictour{
    background: url("../../../img/asset/common/svg/eye__clinictour.svg") no-repeat center 0;
    background-size: 266px auto;
}
#submv h1.price{
    padding: 16px 0 0;
    background: url("../../../img/asset/common/svg/eye__price.svg") no-repeat center 0;
    background-size: 232px auto;
}
#submv h1.tokuchou{
    padding: 16px 0 0;
    background: url("../../../img/asset/common/svg/eye__tokuchou.svg") no-repeat center 0;
    background-size: 341px auto;
}
#submv h1.access{
    padding: 16px 0 0;
    background: url("../../../img/asset/common/svg/eye__access.svg") no-repeat center 0;
    background-size: 169px auto;
}
#submv h1.ortho{
    background: url("../../../img/asset/common/svg/eye__ortho.svg") no-repeat center 0;
    background-size: 327px auto;
}
@media screen and (max-width: 540px) {
#submv{
    background: #f6e7de url("../../../img/asset/submvbg.jpg") repeat center 0;
}
}



.tokuchou .hd{
    margin-bottom: 40px;
    color: #805500;
    font-size: 200%;
    font-family: "Noto Serif JP", "游明朝体", "游明朝", YuMincho, "Yu YuMincho", "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
    font-weight: 500;
    line-height: 1.2;
    text-shadow: 1px 0 4px rgba(80, 64, 32, .5);
}
.tokuchou .hd span:first-of-type{
    display: inline-block;
    font-size: 334%;
    font-weight: 100;
    transform: scale(1, .9);
}
.tokuchou .hd span:nth-child(n+2){
    font-size: 86%;
}







#wrap .scroll table{
    width: 100%;
}
@media screen and (max-width: 1023px) {
#wrap .scroll{
    padding-bottom: 2%;
    overflow: auto;
}
#wrap .scroll::-webkit-scrollbar{
    height: 10px;
}
#wrap .scroll::-webkit-scrollbar-track{
    background: #eee;
}
#wrap .scroll::-webkit-scrollbar-thumb {
    background: #bbb;
}
#wrap .scroll table{
    width: 180%;
}
@media screen and (max-width: 800px) {
#wrap .scroll table{
    width: 120%;
}
@media screen and (max-width: 540px) {
#wrap .scroll table{
    width: 200%;
}
@media screen and (max-width: 360px) {
#wrap .scroll table{
    width: 240%;
}
}
}
}
}



#calendar,
#jump01,
#jump02,
#jump03,
#jump04,
#i,
#i-2,
#i-3,
#i-4,
#i-5,
#i-6,
#i-7,
#i-8,
#i-9,
#i-10,
#i-11,
#i-12
{
    margin-top: -80px;
    padding-top: 80px;
}
@media screen and (max-width: 800px) {
#jump01,
#jump02,
#jump03,
#jump04,
#i,
#i-2,
#i-3,
#i-4,
#i-5,
#i-6,
#i-7,
#i-8,
#i-9,
#i-10,
#i-11,
#i-12
{
    margin-top: 0;
    padding-top: 0;
}
}
@media screen and (max-width: 540px) {
span.wpcf7-list-item{
	display: block !important;
}
}
.wpcf7-validates-as-date{
	background-color: #fff;
	color: #333;
	border: 1px solid #ddd;
	font-size: 17px;
	padding: .5em;
	border-radius:8px;
	box-shadow:2px 2px 4px rgba(0,0,0,.1) inset;
}
input{
	-webkit-transition:all .3s linear;
	-moz-transition:all .3s linear;
	transition:all .3s linear;
}

input[type="text"],
input[type="email"],
input[type="url"],
input[type="tel"],
textarea
{
	width: 80%;
    margin: auto;
	padding: .5em;
	background: #fff;
	border: 1px solid #ddd;
	border-radius: 8px;
	box-shadow: 2px 2px 4px rgba(0,0,0,.1) inset;
	font-size: 18px;
}
input[type="radio"],
input[type="checkbox"]
{
	width: 28px;
	vertical-align: middle;
}
select{
	background: #fff;
	border: 1px solid #ddd;
	font-size: 18px;
	padding: .5em;
	border-radius: 8px;
	box-shadow: 2px 2px 4px rgba(0,0,0,.1) inset;
	line-height: 2;
}
input[type="submit"] ,
input[type="reset"] {
    width: 100%;
	margin: 0;
	padding: 16px 0;
    background: #5c5737;
	color: #fff;
	font-size: 20px;
	font-weight: 700;
	box-shadow: 0 0 1px rgba(0,0,0,.2);
	border-radius: 0;
	-webkit-box-sizing: content-box;
	-webkit-appearance: button;
	appearance: button;
	border: none;
	box-sizing: border-box;
	cursor: pointer;
}
input[type="submit"]:hover{
    background: #4c4638;
}
@media screen and (max-width: 540px) {
input[type="submit"] ,
input[type="reset"] {
    width: 100%;
}
input[type="text"],
input[type="email"],
input[type="url"],
input[type="tel"],
textarea {
	width: 90%;
    margin: auto;
}
select,
textarea
{
	width: 100%;
    margin: auto;
}
}

.datepicker{
    width: 40%;
    max-width: 200px;
}
#zip{
    width: 50%;
    max-width: 200px;
}
#age{
    width: 25%;
    max-width: 80px;
}
@media screen and (max-width: 767px) {
#zip,
#age{
    width: 50%;
    max-width: 100%;
}
}




span.wpcf7-not-valid-tip {
	font-size: 80%;
}
#sitemap_list li{
    font-size: 18px !important;
}
#sitemap_list li li{
    font-size: 16px !important;
}
/* ▲▲▲▲▲▲▲▲▲▲ 共通項目 ▲▲▲▲▲▲▲▲▲▲ */




.first_area{
    width: 100%;
    max-width: 1120px;
    margin-right: auto;
    margin-left: auto;
}

.first_area .lead{
    margin-bottom: 16px;
    padding-bottom: 8px;
    border-bottom: 1px dashed;
    font-size: 23px;
    font-weight: bold;
}
.first_area .lead span{
    color: #d74487;
}
@media screen and (max-width: 1080px) {
.first_area{
    width: 92%;
}
@media screen and (max-width: 540px) {
}
}







.tc3070 .grid:nth-child(odd){
    width: 30%;
}
.tc3070 .grid:nth-child(even){
    width: 70%;
    padding-left: 1.2em;
}
.tc4060 .grid:nth-child(odd){
    width: 40%;
}
.tc4060 .grid:nth-child(even){
    width: 60%;
    padding-left: 1.2em;
}
.tc4060 .grid img{
    width: 100%;
    height: auto;
}
.tc6040 .grid:nth-child(odd){
    width: 60%;
    padding-right: 24px;
}
.tc6040 .grid:nth-child(even){
    width: 40%;
}
.fx_r.tc4060 .grid:nth-child(1){
    width: 40%;
    padding-left: 24px;
}
.fx_r.tc4060 .grid:nth-child(2){
    width: 60%;
    padding-left: 0;
}
@media screen and (max-width: 1080px) {
@media screen and (max-width: 540px) {
.tc3070 .grid:nth-child(odd),
.tc4060 .grid:nth-child(odd),
.tc6040 .grid:nth-child(odd){
    width: 100%;
    padding-right: 0;
}
.tc3070 .grid:nth-child(even),
.tc4060 .grid:nth-child(even),
.tc6040 .grid:nth-child(even){
    width: 100%;
    padding-left: 0;
}
.fx_r.tc4060 .grid:nth-child(1){
    width: 100%;
    padding-left: 0;
    margin-bottom: 24px;
}
.fx_r.tc4060 .grid:nth-child(2){
    width: 100%;
}
}
}




.required{
    font-size: 13px;
    color: red;
}
.form table{
    width: 100%;
    margin: 0 0 40px;
}
.form td{
    padding: 16px;
    vertical-align: middle;
    border-bottom: 1px solid #f1f1f1;
}
.form td:nth-child(odd){
    width: 32%;
    font-weight: 100;
}
.form td:nth-child(even){
    width: 68%;
}
.form td p{
    margin-bottom: 0;
}
@media screen and (max-width: 540px) {
.form td{
    padding: 16px 8px;
    vertical-align: top;
    border-bottom: 1px solid #f1f1f1;
}
.form td:nth-of-type(odd){
    display: block;
    width: 100%;
    padding-bottom: 8px;
    border-bottom: 1px dashed #f1f1f1;
}
.form td:nth-of-type(even){
    display: block;
    width: 100%;
}
}














.entry p{
    margin-bottom: 32px;
}
.entry img{
    width: 100%;
    max-width: 100%;
    height: auto;
}

iframe.youtube_16_9{
    width: 100%;
    max-height: 100%;
    aspect-ratio: >16 / 9;
    max-width: 600px;
    display: block;
    margin: auto;
}
.youtube_mov{
    height: 400px;
}



.poic_effects li{
    width: calc(20% - 4px);
    text-align: center;
}
@media screen and (max-width: 540px) {
.poic_effects li{
    width: calc(50% - 4px);
    margin-bottom: 8px;
}
}
.poic_checks li{
    width: calc(50% - 4px);
    margin-bottom: 8px;
    padding: 8px 8px 8px 32px;
    background-color: #fffbdc;
}
@media screen and (max-width: 540px) {
.poic_checks li{
    width: 100%;
}
}


.tokuchou__grids section .tc4060 .grid:nth-child(even){
    padding-top: 3%;
}
.tokuchou__grids .two_block{
    width: 50%;
}
.tokuchou__grids .two_block li{
    width: calc(50% - 4px);
}
.tokuchou__grids .four_block li{
    width: calc(25% - 4px);
    margin-bottom: 8px;
}
.tokuchou__grids .two_block li:nth-child(n-2){
    margin-bottom: 8px;
}
@media screen and (max-width: 540px) {
.tokuchou__grids .two_block{
    width: 100%;
}
.tokuchou__grids section .tc4060 .grid:nth-child(even){
    padding-top: 24px;
}
.tokuchou__grids .four_block li{
    width: calc(50% - 4px);
}
}


.guide_pages .two_columns .box{
	width: calc( 50% - 16px);
    margin-bottom: 40px;
}
.guidesmenu__grid{
    padding: 8% 8% 4%;
    background: #f6e7de;
}
.guidesmenu__grid::after{
    display: block;
    content: '';
    width: calc(33% - 8px);
}
.guidesmenu__grid li{
    width: calc(33% - 8px);
    margin-bottom: 16px;
}
@media screen and (max-width: 540px) {
.guide_pages .two_columns .box{
	width: 100%;
}
.guidesmenu__grid{
    padding: 4% 4% 2%;
}
.guidesmenu__grid li{
    width: calc(33% - 4px);
    margin-bottom: 8px;
}
}



.case__block{
    padding: 40px;
    background: #e6f9fa;
}
.case__hd{
    padding: 16px;
    background: #45b3b3;
    color: #fff;
    font-size: 22px;
    font-weight: 600;
    line-height: 1.2;
}
.case__block dl{
    margin: 0 0 24px;
    padding: 24px;
    background: #fff;
}
.case__block dt{
    width: 32%;
    margin-bottom: 16px;
    padding-bottom: 8px;
    background: #fff;
    color: #328282;
    border-bottom: 1px solid #ccc;
}
.case__block dd{
    width: 68%;
    margin-bottom: 16px;
    padding-bottom: 8px;
    border-bottom: 1px solid #ccc;
}


#sub__wrap .cases section{
    background: #e6f9fa;
}
.cases .fx{
    padding: 0 40px 40px;
}
.cases .fx .grid:nth-of-type(odd){
    width: 45%;
}
.cases .fx .grid:nth-of-type(even){
    width: 55%;
    padding-left: 32px;
}
.cases .fx dl{
    padding: 24px;
    background: #fff;
    border: 0;
}
.cases .fx dt{
    width: 32%;
    margin-bottom: 16px;
    padding-bottom: 8px;
    background: #fff;
    color: #328282;
    border-bottom: 1px solid #ccc;
}
.cases .fx dd{
    width: 68%;
    margin-bottom: 16px;
    padding-bottom: 8px;
    border-bottom: 1px solid #ccc;
}
@media screen and (max-width: 540px) {
.cases .fx{
    padding: 0 16px 16px;
}
.cases .fx .grid:nth-of-type(odd){
    width: 100%;
    margin-bottom: 24px;
}
.cases .fx .grid:nth-of-type(even){
    width: 100%;
    padding-left: 0;
}
.cases .fx dl{
    padding: 16px;
}
.cases .fx dt{
    width: 100%;
    padding: 0 0 8px;
}
.cases .fx dd{
    width: 100%;
    margin-bottom: 24px;
    padding: 0;
    border-bottom: 0;
}
}


.la_briller_osusume_grid li{
    width: calc(25% - 4px);
    margin-bottom: 8px;
}
.osusume_grids .grid{
    width: 50%;
}
@media screen and (max-width: 540px) {
.la_briller_osusume_grid li{
    width: calc(50% - 4px);
    margin-bottom: 8px;
}
.for_sp{
    overflow-x: auto;
    padding-bottom: 10px;
    -webkit-overflow-scrolling: touch;
}
.for_sp img{
    max-width: 200%;
    min-width: 800px;
    vertical-align: top;
}
}


#pmtc__kouka .tc4060 .grid:nth-child(even){
    padding-top: 44px;
}
@media screen and (max-width: 540px) {
#pmtc__kouka .tc4060 .grid:nth-child(even){
    padding-top: 0;
}
}


#perio__tokuchou ol::after{
    width: calc(20% - 5px);
    content: "";
    display: block;
}
#perio__tokuchou li{
    width: calc(20% - 5px);
    margin-bottom: 16px;
}
@media screen and (max-width: 540px) {
#perio__tokuchou ol::after{
    width: calc(50% - 5px);
}
#perio__tokuchou li{
    width: calc(50% - 5px);
}
}



.toc_list li a{
    position: relative;
    display: block;
    margin-bottom: 16px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 32px;
    background: url("../../../img/asset/common/svg/arrow02.svg") no-repeat 1% center;
    background-size: 16px auto;
    line-height: 1.3;
    letter-spacing: 0;
}
.toc_list li:last-child a{
    margin-bottom: 0;
}
.toc_list li a:hover{
    background: url("../../../img/asset/common/svg/arrow.svg") no-repeat 1% center;
    background-size: 16px auto;
}


.price__list table{
    width: 100%;
    border-top: 1px solid #bfbfbf;
}
.price__list table td{
    padding: 24px;
    border-bottom: 1px solid #bfbfbf;
    border-top: 0;
    vertical-align: middle;
}
.price__list table td:nth-of-type(odd){
    width: 55%;
    background: #fffdeb;
    text-align: left;
}
.price__list table td:nth-of-type(even){
    width: 45%;
    text-align: right;
}
@media screen and (max-width: 540px) {
.price__list table td{
    display: block;
}
.price__list table td:nth-of-type(odd){
    width: 100%;
}
.price__list table td:nth-of-type(even){
    width: 100%;
    text-align: left;
}
}


.clinic__information dt{
    margin-bottom: 8px;
    padding: 0 0 8px 16px;
    border-left: 2px solid #d74487;
    border-bottom: 1px dashed #ccc;
    font-weight: 600;
}
.clinic__information dd{
    margin-bottom: 24px;
}




.price__list ul{
    width: 100%;
    border-top: 1px solid #bfbfbf;
}
.price__list ul li{
    width: 50%;
    padding: 24px;
    border-bottom: 1px solid #bfbfbf;
}
.price__list li:nth-of-type(odd){
    background: #e6e6e6;
    text-align: left;
    font-weight: bold;
}
.price__list li:nth-of-type(even){
    text-align: right;
}
@media screen and (max-width: 540px) {
.price__list ul li{
    width: 100%;
    padding: 24px 16px;
}
}


#wrap .access__box h3{
    margin-bottom: 8px;
}
#wrap .access__cards{
    width: calc(33% - 8px);
    margin-bottom: 16px;
    padding: 1.5em;
    background: #e5e5e5;
}
#wrap .access__cards:last-of-type{
    margin-bottom: 0;
}
#wrap .how_to_access::after{
    content: "";
    display: block;
    width: calc(33% - 8px);
}
@media screen and (max-width: 1080px) {
#wrap .access__cards{
    width: calc(50% - 8px);
}
#wrap .how_to_access::after{
    width: calc(50% - 8px);
}
@media screen and (max-width: 540px) {
#wrap .access__cards{
    width: 100%;
}
#wrap .how_to_access::after{
    width: 100%;
}
}
}





.kyoseikiso__merits{
    margin-bottom: 80px;
    padding: 80px 0;
    background: #f0e9dd;
}
.kyoseikiso__merits .inner{
    width: 92%;
    max-width: 1280px;
    margin-right: auto;
    margin-left: auto;
}
.kyoseikiso__merits .merits__area{
    padding: 24px 0;
    background: #fff;
    border-radius: 16px;
    border: 1px solid #805500;
}
.kyoseikiso__merits .merits__area .hd{
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0 0 24px;
    padding: 24px 24px 0;
    border-bottom: 1px solid;
    color: #805500;
    font-size: 122%;
    font-weight: bold;
}
.kyoseikiso__merits .merits__area .hd picture{
    padding-right: 24px;
}
.kyoseikiso__merits .box{
    padding: 24px;
}
.kyoseikiso__merits dl{
    width: calc(33.333% - 16px);
    margin-bottom: 24px;
    padding: 0 8px 8px;
    border-bottom: 1px dashed #805500;
}
.kyoseikiso__merits .box .fx::after{
    width: calc(33.333% - 16px);
    display: block;
    content: "";
}
.kyoseikiso__merits dt{
    margin-bottom: 8px;
    padding: 0 0 0 32px;
    background: url("../../../img/asset/common/svg/o.svg") no-repeat 0 6px;
    background-size: 23px auto;
    font-size: 111%;
    font-weight: bold;
}
@media screen and (max-width: 540px) {
.kyoseikiso__merits{
    padding: 40px 0;
}
.kyoseikiso__merits .merits__area{
    padding: 8px 0;
}
.kyoseikiso__merits .merits__area .hd{
    margin: 0 0 8px;
}
.kyoseikiso__merits dl{
    width: 100%;
}
.kyoseikiso__merits .box .fx::after{
    width: 100%;
}
}

.ortho__merits{
    padding: 80px 0;
    background: #f0e9dd;
}
.ortho__merits .inner{
    width: 92%;
    max-width: 1280px;
    margin-right: auto;
    margin-left: auto;
}
.ortho__merits .merits__area{
    padding: 24px 0;
    background: #fff;
    border-radius: 16px;
    border: 1px solid #805500;
}
.ortho__merits .merits__area .hd{
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0 0 24px;
    padding: 24px 24px 0;
    border-bottom: 1px solid;
    color: #805500;
    font-size: 122%;
    font-weight: bold;
}
.ortho__merits .merits__area .hd picture{
    padding-right: 24px;
}
.ortho__merits .box{
    padding: 24px;
}
.ortho__merits dl{
    width: calc(33.333% - 16px);
    margin-bottom: 24px;
    padding: 0 8px 8px;
    border-bottom: 1px dashed #805500;
}
.ortho__merits .box .fx::after{
    width: calc(33.333% - 16px);
    display: block;
    content: "";
}
.ortho__merits dt{
    margin-bottom: 8px;
    padding: 0 0 0 32px;
    background: url("../../../img/asset/common/svg/o.svg") no-repeat 0 6px;
    background-size: 23px auto;
    font-size: 111%;
    font-weight: bold;
}
@media screen and (max-width: 540px) {
.ortho__merits{
    padding: 40px 0;
}
.ortho__merits .merits__area{
    padding: 8px 0;
}
.ortho__merits .merits__area .hd{
    margin: 0 0 8px;
}
.ortho__merits dl{
    width: 100%;
}
.ortho__merits .box .fx::after{
    width: 100%;
}
}
.ortho__demerits{
    padding: 80px 0;
    background: #d9d9d9;
}
.ortho__demerits .inner{
    width: 92%;
    max-width: 1280px;
    margin-right: auto;
    margin-left: auto;
}
.ortho__demerits .merits__area{
    padding: 24px 0;
    background: #fff;
    border-radius: 16px;
    border: 1px solid #805500;
}
.ortho__demerits .merits__area .hd{
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0 0 24px;
    padding: 24px 24px 0;
    border-bottom: 1px solid;
    color: #805500;
    font-size: 122%;
    font-weight: bold;
}
.ortho__demerits .merits__area .hd picture{
    padding-right: 24px;
}
.ortho__demerits .box{
    padding: 24px;
}
.ortho__demerits dl{
    width: calc(33.333% - 16px);
    margin-bottom: 24px;
    padding: 0 8px 8px;
    border-bottom: 1px dashed #805500;
}
.ortho__demerits .box .fx::after{
    width: calc(33.333% - 16px);
    display: block;
    content: "";
}
.ortho__demerits dt{
    margin-bottom: 8px;
    padding: 0 0 0 32px;
    background: url("../../../img/asset/common/svg/x.svg") no-repeat 0 6px;
    background-size: 23px auto;
    font-size: 111%;
    font-weight: bold;
}
@media screen and (max-width: 540px) {
.ortho__demerits{
    padding: 40px 0;
}
.ortho__demerits .merits__area{
    padding: 8px 0;
}
.ortho__demerits .merits__area .hd{
    margin: 0 0 8px;
}
.ortho__demerits dl{
    width: 100%;
}
.ortho__demerits .box .fx::after{
    width: 100%;
}
}




.otonakyosei__risks .box{
    margin-bottom: 24px;
    padding: 24px 16px;
    background: url("../../../img/asset/ortho/otonakyosei/riskbg.svg") no-repeat center 20%;
    background-size: 163px auto;
    border: 1px solid #805500;
    border-radius: 8px;
}
.otonakyosei__risks .mini_hd{
    position: relative;
    width: 90%;
    margin: 0 auto 24px;
    padding: 16px;
    background: #4d4d4d;
    color: #fff;
    text-align: center;
    border-radius: 8px;
    font-size: 78%;
    letter-spacing: 0;
    line-height: 1;
}
.otonakyosei__risks .mini_hd::before{
    content: '';
    position: absolute;
    bottom: -28px;
    left: 50%;
    margin-left: -14px;
    border: 14px solid transparent;
    border-top-color: #4d4d4d;
}
.otonakyosei__risks .hd{
    margin: 0 0 16px;
    padding: 0 0 16px;
    border-bottom: 1px solid;
    color: #805500;
    font-size: 156%;
    font-family: "Noto Serif JP", "游明朝体", "游明朝", YuMincho, "Yu YuMincho", "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
    text-align: center;
}
.for__adults__ortho dl{
    margin-bottom: 24px;
    border: 1px solid #805500;
    border-radius: 8px;
}
.for__adults__ortho dt{
    padding: 16px;
    border-bottom: 1px solid;
    background: #805500;
    color: #fff;
    font-size: 122%;
    text-align: center;
}
.for__adults__ortho dd{
    padding: 16px;
}

.aftermaintenance__hotei{
    background: #e6fafa url("../../../img/asset/ortho/aftermaintenance/bg.svg") no-repeat center center;
    background-size: 252px auto;
    text-align: left;
}
.aftermaintenance__teikikenshin dl{
    margin-bottom: 24px;
    padding: 24px;
    background: #f0f0f0;
}
.aftermaintenance__teikikenshin dt{
    height: 42px;
    margin-bottom: 16px;
    padding: 4px 8px 8px 56px;
    background: #fff url("../../../img/asset/ortho/aftermaintenance/icon_check.svg") no-repeat 0 center;
    background-size: 42px auto;
    text-align: left;
    font-size: 111%;
    font-weight: bold;
}
.aftermaintenance__timing{
    margin-top: 24px;
    padding: 24px 0;
    border-top: 1px solid #ccc;
    border-bottom: 1px solid #ccc;
}
@media screen and (max-width: 540px) {
.aftermaintenance__timing{
    border-bottom: 0;
}
.aftermaintenance__timing .box{
    margin-bottom: 40px;
    padding: 0 24px 24px;
    border-bottom: 1px solid #ccc;
}
}







