@charset "utf-8";
/*
Theme Name: インプラントサイトallon4
Theme URI: https://ehime-implant.com/allon4/
Description: Versions 1.0.x
Version: 1.0
Author: Dental Promotiona
*/

.aaa{
    font-size: 20px;
    font-weight: 600;
    color: red;
}


@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;}nav ul {    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:bold;}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{
    overflow: auto;
}
@media screen and (max-width: 768px) {
html{
    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: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Segoe UI', YuGothic, 'Yu Gothic Medium', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', Meiryo, sans-serif;
    font-size: 16px;
	word-wrap : break-word;
	overflow-wrap : break-word;
    line-height: 1.8em;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    animation: fadeIn 2s ease 0s 1 normal;
    -webkit-animation: fadeIn 2s ease 0s 1 normal;
}
@media screen and (max-width: 768px) {
body{
    min-width: 100%;
    font-size: 1.6rem;
}
}
h1,h2,h3,h4,h5,h6{
    margin: 0;
    font-weight: 700;
}

*, *:before, *:after{
    box-sizing: border-box;
}

::selection {
    background: #78c5be;
    color: #fff;
    text-shadow: 1px 1px 2px rgba(240, 240, 200, 1);
}
::-moz-selection {
    background: #78c5be;
    color: #fff;
    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: #12c;
}
a:active, a:hover{
    color: #04c;
    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;}
i,em{font-style:normal;}
img{
    max-width: 100%;
    height: auto;
    border:none;
    vertical-align:middle;
}

ul, ol, li{
    margin:0;
    padding:0;
    list-style:none;
}

.cf{zoom:100%;}
.cf:after{
    content:"";
    clear:both;
    height:0;
    display:block;
    visibility:hidden;
}
.oz{
    overflow: hidden;
    _zoom: 1;
}

@media screen and (max-width: 767px) {iframe{max-width: 100%;min-height: 300px;max-height: 400px;}}

.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:700;}
.fs15{font-size:15px;}
.fs16{font-size:16px;}
.fs17{font-size:17px;}
.fs18{font-size:18px;}
.fs19{font-size:19px;}
.fs20{font-size:20px;}

.su{
    opacity:0;
    transform: translateY(20px);
    -ms-filter: blur(1px);
    filter: blur(1px);
}
.zu{
    opacity: 0;
    transform: scale(.8,.8);;
    -ms-filter: blur(1px);
    filter: blur(1px);
}
.sl{
    opacity:0;
    transform: translateX(-20px);
    -ms-filter: blur(1px);
    filter: blur(1px);
}
.fi{
    transition: all .5s ease-in-out;
    transform: translateY(0);
    opacity: 1;
    -ms-filter: blur(0);
    filter: blur(0);
}
.fiz{
    transition: all .6s ease-in-out;
    transform: scale(1,1);;
    opacity: 1;
    -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;}
.mb64{margin-bottom:64px;}
.mb80{margin-bottom:80px;}
.mb120{margin-bottom:120px;}
.mb160{margin-bottom:160px;}
.pt24{padding-top:24px;}
.pt32{padding-top:32px;}
.pt40{padding-top:40px;}


.fc_coral{color: #eb7779;}

.ff_mincho{
    font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
.lead{
    font-size: 24px;
    font-weight: 700;
}

.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{
    display: block;
    margin-left: auto;
    margin-right: auto;
    padding: 24px;
    background: #fff url("img/common/svg/arrow.svg") no-repeat 95% center;
    background-size: 19px auto;
    color: #e5007f;
    border: 1px solid #e5007f;
    font-weight: 700;
    text-align: center;
    line-height: 1;
}
.more a:hover{
    background: #ffcde9 url("img/common/svg/arrow.svg") no-repeat 97% center;
    background-size: 19px auto;
    color: #333;
}
.entry a{
    display: block;
    margin-left: auto;
    margin-right: auto;
    padding: 24px;
    background: #2eb3dc url("../../../img/asset/common/svg/arrow_g.svg") no-repeat 4% center;
    background-size: 24px auto;
    color: #fff;
    border: solid 2px #fff;
    border-radius: 6px;
    font-weight: 700;
    text-align: center;
    line-height: 1;
}
.entry a:hover{
    background: #497f9e url("../img/asset/common/svg/arrow.svg") no-repeat 6% center;
    background-size: 24px auto;
}
.external a{
    display: block;
    margin-left: auto;
    margin-right: auto;
    padding: 1.5em 1em;
    background: #01a2d5 url("../img/asset/common/svg/external.svg") no-repeat 96% center;
    background-size: 12px auto;
    color: #fff;
    box-shadow: inset 0 2px 0 rgba(255,255,255,0.2), inset 0 -2px 0 rgba(0, 0, 0, 0.05);
    border: solid 2px #fff;
    border-radius: 6px;
    font-size: 17px;
    font-weight: 700;
    text-align: center;
    line-height: 1;
}
.external a:hover{
    background: #4c92a8 url("../img/asset/common/svg/external.svg") no-repeat 96% center;
    background-size: 12px 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: 19px 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: 19px auto;
    border: 2px solid #fff;
}

.more_box{
    width: 30%;
    margin-right: auto;
    margin-left: auto;
}
.exclamation{
    padding-left: 32px;
    background: url("img/common/svg/exclamation.svg") no-repeat 0 5px;
    background-size: 19px auto;
}
@media screen and (max-width: 800px) {
.more_box{
    width: 50%;
}
@media screen and (max-width: 540px) {
.more_box{
    width: 92%;
}
}
}


.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: 1023px) {
.w20,.w30,.w40,.w50{width: 50%;}
}
@media screen and (max-width: 767px) {
.w20,.w30,.w40,.w50,.w60,.w70,.w80,.w90{width: 100%;}
}

figure{
/*    text-align: center;*/
}
figcaption{
    text-align: left;
    padding-top: 16px;
}


.spc{
    display: none;
}
@media screen and (max-width: 767px) {
.dn{
    display: none;
}
.spc{
    display: inherit;
}
}





header{
	position: -webkit-sticky;
	position: sticky;
	top: 0;
    z-index: 1000;
    width: 100%;
    max-width: 1920px;
    margin-left: auto;
    margin-right: auto;
    text-align: left;
    background: rgba(255,255,255,.5);
}
#upper{
    position: relative;
    width: 100%;
    max-width: 1120px;
    height: 88px;
    margin: auto;
    transition: all .5s ease-in;
}
.logo{
    position: absolute;
    width: 224px;
    height: 54px;
    margin: auto 0;
    top: 16px;
    left: 0;
    text-align: center;
    z-index: 9990;
}
#upper dl{
    position: fixed;
    width: 380px;
    height: 56px;
    margin: auto 0;
    top: 16px;
    right: 10%;
    text-align: center;
    z-index: 9990;
}
#upper dt,
#upper dd{
    width: 50%;
    text-align: center;
}
@media screen and (max-width: 820px) {
.logo{
    margin: auto 0;
    top: 0;
    bottom: 0;
    left: 24px;
}
#upper dl{
    right: 0;
}
@media screen and (max-width: 540px) {
header{
	position: inherit;
    background: rgba(255,255,255,0);
}
#upper{
    height: 48px;
}
.logo{
    width: 141px;
    height: 34px;
    left: 8px;
}
#upper dl{
    position: fixed;
    width: 97px;
    height: 48px;
    margin: 0;
    top: 0;
    bottom: 0;
    right: 0;
    text-align: center;
}
#upper dl img{
    width: 48px;
    height: 48px;
}
#upper dt,
#upper dd{
    width: 50%;
    text-align: center;
}
@media screen and (max-width: 320px) {
.logo{
    width: 140px;
    height: 54px;
}
}
}
}





#mv{
    background: url("img/fvbg_pc.webp") repeat-y bottom;
    background-size: 100% auto;
}
#mv .fv{
    text-align: center;
}
#mv .fv_photo{
    z-index: 1;
    margin-top: -24px;
}
#mv .attention{
    padding: 8px 0;
    background: #f1f1b5;
}
#mv .scroll{
    padding: 8px 0;
    background: #fff;
}
@media screen and (max-width: 820px) {
#mv{
    margin-top: -88px;
}
#mv .fv_photo{
    margin-top: -16px;
    z-index: 1;
}
@media screen and (max-width: 540px) {
#mv{
    margin-top: -48px;
    background: url("img/fvbg.webp") repeat-y bottom;
    background-size: 100% auto;
}
#mv .fv_photo{
    width: 96%;
    margin-right: auto;
    margin-left: auto;
}

}
}



.recommend{
    background: #ffffe5;
}
.recommend h2{
    padding: 24px 0;
    text-align: center;
    background: #eded6f;
}
.recommend dl{
    width: 816px;
    margin: auto;
    padding: 40px 0;
}
.recommend dt,
.recommend dd{
    width: calc(25% - 16px);
    text-align: center;
}
@media screen and (max-width: 820px) {
.recommend dl{
    width: 92%;
    margin: auto;
    padding: 40px 0;
}
@media screen and (max-width: 540px) {
.recommend dl{
    padding: 32px 0 24px;
}
.recommend dt,
.recommend dd{
    width: calc(50% - 16px);
    margin-bottom: 16px;
}
}
}





.about{
    padding: 80px 0 0;
    text-align: center;
}
.about .inner{
    width: 100%;
    max-width: 1120px;
    margin: auto;
    text-align: center;
}
.about h2{
    margin-bottom: 40px;
    text-align: center;
}
.about .grid:first-of-type{
    width: 60%;
}
.about .grid:last-of-type{
    width: 40%;
    text-align: left;
    z-index: 1;
}
@media screen and (max-width: 820px) {
.about .grid:first-of-type{
    width: 50%;
}
.about .grid:last-of-type{
    width: 45%;
    padding: 16px 24px 0 0;
}
@media screen and (max-width: 540px) {
.about .grid:first-of-type{
    width: 100%;
}
.about .grid:last-of-type{
    width: 92%;
    margin: auto;
    margin-top: -80px;
    padding: 0;
    z-index: 1;
}
}
}



.cv_area{
    padding: 40px 0;
    background: linear-gradient(180deg, #fdf2de 0%, #ffe5e6 100%);
    background-size: 100% 100%;
    animation: gradationAnim 10s ease infinite;
}
@keyframes gradationAnim {
    0% { background-position: 50% 100% }
    50% { background-position: 50% 0% }
    100% { background-position: 50% 100% }
}
.cv_area ul{
    width: 60%;
    max-width: 640px;
    margin: auto;
}
.cv_area li{
    width: calc(50% - 8px);
}
@media screen and (max-width: 540px) {
.cv_area{
    padding: 40px 0 24px;
}
.cv_area ul{
    width: 92%;
    max-width: 92%;
}
.cv_area li{
    width: 100%;
    margin-bottom: 16px;
}
}




.cases{
    padding: 80px 0;
    background: #e5e5e5 url("img/case_bg_pc.webp") no-repeat;
    background-size: 100% auto;
    text-align: center;
}
.cases h2{
    margin-bottom: 48px;
}
.cases .inner{
    width: 100%;
    max-width: 1120px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 80px;
    padding: 80px 120px;
    background: #fff;
    border-radius: 16px;
}
.cases .inner dl{
    text-align: left;
}
.cases .inner dt{
    margin-bottom: 16px;
    padding-bottom: 8px;
    border-bottom: 1px dashed #000;
    font-weight: 600;
}
.cases .inner dd{
    margin-bottom: 40px;
}
@media screen and (max-width: 820px) {
.cases .inner{
    width: 92%;
    margin-bottom: 40px;
    padding: 40px 24px;
    background: #fff;
    border-radius: 16px;
}
.cases .inner:last-of-type{
    margin-bottom: 0;
}
@media screen and (max-width: 540px) {
.cases{
    padding: 80px 0 40px;
    background: #e5e5e5 url("img/case_bg.webp") no-repeat right 0;
    background-size: 100% auto;
}
.cases .inner dd{
    margin-bottom: 24px;
}
}
}


.reasons{
    padding: 80px 0 0;
    text-align: center;
}
.reasons h2{
    margin-bottom: 48px;
}
.reasons .box{
    background: linear-gradient(90deg, #e7f0cb 0%, #eef2da 50%, #f2efcc 100%);
    background-size: 100% 100%;
    animation: reasonsgradationAnim 5s ease infinite;
}
@keyframes reasonsgradationAnim{
    0% { background-position: 0% 50% }
    50% { background-position: 100% 50% }
    100% { background-position: 0% 50% }
}
#reasons01{
    padding-top: 24%;
    background: url("img/reasonsbg01_pc.webp") no-repeat center 0;
    background-size: 100% auto;
    text-align: center;
}
#reasons02{
    padding-top: 24%;
    background: url("img/reasonsbg02_pc.webp") no-repeat center 0;
    background-size: 100% auto;
    text-align: center;
}
#reasons03{
    padding-top: 24%;
    background: url("img/reasonsbg03_pc.webp") no-repeat center 0;
    background-size: 100% auto;
    text-align: center;
}
.reasons .box .hd{
    margin-bottom: 24px;
}
.reasons .box .hd::after{
    display: block;
    content: "|";
    font-size: 480%;
    line-height: 1.3;
    font-weight: 100;
}
#reasons01 .inner{
    background: url("img/reasons0102_pc.webp") no-repeat 0 bottom;
    background-size: 55% auto;
    text-align: left;
}
#reasons02 .inner{
    background: url("img/reasons0202_pc.webp") no-repeat 0 bottom;
    background-size: 55% auto;
    text-align: left;
}
#reasons03 .inner{
    background: url("img/reasons0302_pc.webp") no-repeat 0 bottom;
    background-size: 55% auto;
    text-align: left;
}
.reasons .inner_box{
    width: 100%;
    max-width: 1120px;
    margin: auto;
    padding: 0 0 160px 35%;
}
.reasons ul{
    margin-bottom: 16px;
    padding: 16px;
    background: rgba(255,255,255,.5);
}
.reasons ul li{
    min-height: 20px;
    padding: 0 0 0 32px;
    background: url("img/common/svg/check.svg") no-repeat 0 5px;
    background-size: 20px auto;
}
.reasons .indent{
    padding: 0 0 0 80px;
    font-size: 14px;
}
@media screen and (max-width: 1280px) {
.reasons .inner_box{
    padding: 0 0 80px 45%;
}
@media screen and (max-width: 820px) {
.reasons .inner_box{
    width: 100%;
    max-width: 800px;
    margin: auto;
    padding: 0 0 80px 40%;
}
.reasons .indent{
    padding: 0 0 0 40px;
}
#reasons01 .inner{
    background: url("img/reasons0102_pc.webp") no-repeat 0 80px;
    background-size: 360px auto;
    text-align: left;
}
#reasons02 .inner{
    background: url("img/reasons0202_pc.webp") no-repeat 0 80px;
    background-size: 360px auto;
    text-align: left;
}
#reasons03 .inner{
    background: url("img/reasons0302_pc.webp") no-repeat 0 80px;
    background-size: 360px auto;
    text-align: left;
}
@media screen and (max-width: 540px) {
#reasons01{
    padding-top: 75%;
    background: url("img/reasonsbg01.webp") no-repeat center 0;
    background-size: 100% auto;
    text-align: center;
}
#reasons02{
    padding-top: 75%;
    background: url("img/reasonsbg02.webp") no-repeat center 0;
    background-size: 100% auto;
    text-align: center;
}
#reasons03{
    padding-top: 75%;
    background: url("img/reasonsbg03.webp") no-repeat center 0;
    background-size: 100% auto;
    text-align: center;
}
#reasons01 .inner{
    background: url("img/reasons0102.webp") no-repeat 0 0;
    background-size: 35% auto;
}
#reasons02 .inner{
    background: url("img/reasons0202.webp") no-repeat 0 0;
    background-size: 35% auto;
}
#reasons03 .inner{
    background: url("img/reasons0302.webp") no-repeat 0 0;
    background-size: 35% auto;
}
.reasons .inner_box{
    width: 100%;
    margin: 0;
    padding: 24px 0 80px 10%;
}
.reasons .indent{
    width: 100%;
    padding: 0;
}
}
}
}



.chronic_disease{
    padding: 80px 0;
    background: #d9f2d4 url("img/chronic_disease_bg_pc.webp") no-repeat center center;
    background-size: 1200px auto;
    text-align: center;
}
.chronic_disease .hd{
    margin: 0 0 24px;
    padding: 24px 0 0;
    text-align: center;
    font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    font-size: 24px;
    font-weight: 600;
}
.chronic_disease .inner{
    width: 100%;
    max-width: 800px;
    margin-left: auto;
    margin-right: auto;
}
.chronic_disease p{
    font-size: 20px;
    font-weight: 600;
}
@media screen and (max-width: 820px) {
.chronic_disease .inner{
    width: 92%;
    max-width: 800px;
    text-align: left;
}
@media screen and (max-width: 540px) {
.chronic_disease{
    padding: 40px 0;
    background: #d9f2d4 url("img/chronic_disease_bg.webp") no-repeat center center;
    background-size: 100% auto;
}
.chronic_disease .inner{
    max-width: 500px;
}
}
}



.flow{
    padding: 96px 0;
    background: #ffffe5;
    text-align: center;
}
.flow .inner{
    width: 100%;
    max-width: 1120px;
    margin-left: auto;
    margin-right: auto;
}
.flow .grid:first-of-type{
    width: 55%;
    color: #5b8054;
    font-size: 18px;
    font-weight: 600;
}
.flow .grid:last-of-type{
    width: 42%;
    padding-top: 24px;
}
#step01{
    padding: 80px 0 40px 128px;
    background: url("img/step01.svg") no-repeat 0 0,url("img/flowline.webp") repeat-y 42px 0;
    background-size: 85px auto, 2px auto;
    text-align: left;
}
#step02{
    padding: 80px 0 40px 128px;
    background: url("img/step02.svg") no-repeat 0 0,url("img/flowline.webp") repeat-y 42px 0;
    background-size: 85px auto, 2px auto;
    text-align: left;
}
#step03{
    padding: 80px 0 40px 128px;
    background: url("img/step03.svg") no-repeat 0 0,url("img/flowline.webp") repeat-y 42px 0;
    background-size: 85px auto, 2px auto;
    text-align: left;
}
#step04{
    padding: 80px 0 40px 128px;
    background: url("img/step04.svg") no-repeat 0 0,url("img/flowline.webp") repeat-y 42px 0;
    background-size: 85px auto, 2px auto;
    text-align: left;
}
#step05{
    padding: 80px 0 0 128px;
    background: url("img/step05.svg") no-repeat 0 0,url("img/flowline.webp") repeat-y 42px 0;
    background-size: 85px auto, 2px auto;
    text-align: left;
}
@media screen and (max-width: 820px) {
.flow .inner{
    width: 92%;
    max-width: 800px;
}
#step01{
    padding: 80px 0 40px 80px;
}
#step02{
    padding: 80px 0 40px 80px;
}
#step03{
    padding: 80px 0 40px 80px;
}
#step04{
    padding: 80px 0 40px 80px;
}
#step05{
    padding: 80px 0 40px 80px;
}
.flow .grid:last-of-type{
    padding-top: 24px;
}
@media screen and (max-width: 540px) {
.flow{
    padding: 96px 0 48px;
}
.flow .inner{
    max-width: 500px;
}
.flow .grid:first-of-type{
    width: 100%;
    color: #5b8054;
    font-size: 18px;
    font-weight: 600;
}
.flow .grid:last-of-type{
    width: 100%;
    padding-top: 24px;
}
}
}


.price{
    padding: 80px 0 0;
    text-align: center;
}
.price h2{
    margin-bottom: 48px;
}
.price .inner{
    width: 100%;
    max-width: 960px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 80px;
    padding: 80px;
    border: 1px solid #009ccc;
}
.price .ao4_price{
    margin-bottom: 40px;
    padding: 40px 0;
    background: #daf2f2;
}
.price .grid{
    width: 48%;
}
.price .grid:first-of-type p{
    color: #009ccc;
    font-weight: 600;
}
.price .koujo{
    padding: 80px 0;
    background: #daf2f2;
}
.price .koujo h3{
    margin-bottom: 40px;
    color: #009ccc;
    font-size: 24px;
    font-weight: 600;
}
.price .koujo h4{
    margin-bottom: 24px;
    font-size: 22px;
    font-weight: 600;
    text-align: center;
}
.price .koujo .box{
    width: 100%;
    max-width: 1120px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 80px;
}
.price .koujo .boxL{
    width: 48%;
}
.price .koujo .boxR{
    width: 48%;
    text-align: left;
}
.price .koujo_box{
    width: 100%;
    max-width: 960px;
    margin-right: auto;
    margin-left: auto;
    margin-bottom: 40px;
    padding: 40px 80px;
    background: #fff;
    text-align: left;
}
.price .koujo_box dt,
.price .koujo_box dd{
    width: 48%;
    padding: 24px;
    background: #f5f5f5;
    text-align: center;
    font-size: 20px;
}
@media screen and (max-width: 820px) {
.price .inner{
    width: 92%;
    max-width: 800px;
    margin-bottom: 40px;
    padding: 40px;
}
.price .koujo .boxR{
    width: 48%;
    padding-right: 24px;
    text-align: left;
}
.price .koujo_box{
    width: 92%;
    max-width: 800px;
    margin-bottom: 40px;
}
.price .koujo_box:last-of-type{
    margin-bottom: 0;
}
@media screen and (max-width: 540px) {
.price .inner{
    max-width: 500px;
    padding: 24px;
}
.price .grid{
    width: 100%;
    margin-bottom: 40px;
}
.price .grid:last-of-type{
    width: 100%;
    margin-bottom: 0;
}
.price .koujo{
    padding: 40px 0;
}
.price .koujo .box{
    margin-bottom: 40px;
}
.price .koujo .boxL{
    width: 92%;
    margin-bottom: 24px;
}
.price .koujo .boxR{
    width: 92%;
    margin: auto;
    padding-right: 0;
}
.price .koujo_box{
    width: 92%;
    max-width: 500px;
    margin-bottom: 40px;
    padding: 24px 16px;
}
.price .koujo_box dt,
.price .koujo_box dd{
    width: 100%;
    margin-bottom: 16px;
    padding: 16px;
}
}
}




.faq_area{
    padding: 80px 0;
    background: #d9f2d4 url("img/faqbg_pc.webp") no-repeat center center;
    background-size: cover;
    text-align: center;
}
.faq_area h2{
    margin-bottom: 48px;
}
.faq_area dl{
    width: 100%;
    max-width: 1120px;
    margin-left: auto;
    margin-right: auto;
    text-align: left;
}
.faq_area dt{
    min-height: 56px;
    margin-bottom: 16px;
    padding: 0 0 0 80px;
    background: url("img/faq_q.svg") no-repeat 16px 0;
    background-size: 51px auto;
}
.faq_area dd{
    margin-bottom: 40px;
    padding: 24px 80px;
    background: url("img/faq_a.svg") no-repeat 16px 24px, url("img/faq_note.jpg") repeat 0 0;
    background-size: 51px auto, 7px auto;
}
@media screen and (max-width: 820px) {
.faq_area dl{
    width: 92%;
    max-width: 800px;
}
.faq_area dd{
    margin-bottom: 40px;
    padding: 24px 24px 24px 80px;
    background: url("img/faq_a.svg") no-repeat 16px 24px, url("img/faq_note.jpg") repeat 0 0;
    background-size: 51px auto, 7px auto;
}
.faq_area dd:last-of-type{
    margin-bottom: 0;
}
@media screen and (max-width: 540px) {
.faq_area{
    padding: 40px 0;
}
}
}


.greeting{
    padding: 80px 0 0;
    text-align: center;
}
.greeting .inner{
    width: 100%;
    max-width: 1120px;
    margin-left: auto;
    margin-right: auto;
    text-align: left;
}
.greeting h2{
    margin-bottom: 48px;
}
.greeting p{
    margin-bottom: 24px;
    font-size: 21px;
    font-weight: 600;
}
@media screen and (max-width: 820px) {
.greeting .greeting_txt{
    width: 92%;
    max-width: 800px;
    margin: auto;
}
}


footer{
    padding: 40px 0 0;
    background: #eee;
}
footer .logo{
    width: 60%;
    margin: auto;
    margin-bottom: 24px;
}
.clinicinfo{
    width: 50%;
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
    text-align: left;
}
#gmap{
    width: 100%;
    height: 500px;
}
#gmap iframe{
    vertical-align: bottom;
}
footer .official{
    padding: 40px 0;
    text-align: center;
}
@media screen and (max-width: 821px) {
footer .official{
    width: 96%;
    margin: auto;
}
@media screen and (max-width: 540px) {
footer{
    padding: 40px 0 80px;
}

.clinicinfo{
    width: 92%;
    text-align: left;
}
footer .official{
    width: 92%;
}
}
}





#copyright{
    padding: 16px 0;
    background: #eded6f;
    color: #000;
    text-align: center;
    font-size: 12px;
}
#copyright a{
    color: #000;
}


#footnavs{
    display: none;
    z-index: 999;
}
@media screen and (max-width: 540px) {
#footnavs{
    display: inherit;
    position: fixed;
    width: 100%;
    height: 88px;
    padding: 0 8px;
    left: 0;
    bottom: 0;
    padding-top: 12px;
    background: rgba(255,244,244,.5);
}
#footnavs li{
    width: calc(33% - 4px);
}
}





/*reserve_btn*/

.modal_reserve input{
    display: none;
}
.modal_r_overlay{
    display: flex;
    justify-content: center;
    overflow: auto;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 9999;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,.7);
    opacity: 0;
    transition: opacity .3s, transform 0s .3s;
    transform: scale(0);
}
.modal_r_trigger{
    position: absolute;
    width: 100%;
    height: 100%;
}
.modal_r_content{
    position: relative;
    width: 56%;
    height: 100%;
    overflow-y: auto;
    margin: auto;
    padding: 40px;
    box-sizing: border-box;
    background: #fff;
    line-height: 1.6;
    transform: scale(.3);
    transition: .3s;
    text-align: left;
    font-size: 13px;
}
.open_button{
    cursor: pointer;
}
.close_button{
    position: fixed;
    top: 10px;
    right: 10px;
    font-size: 24px;
    cursor: pointer;
}
.modal_reserve input:checked ~ .modal_r_overlay{
    opacity: 1;
    transform: scale(1);
    transition: opacity .3s;
}
.modal_reserve input:checked ~ .modal_r_overlay .modal_r_content{
    transform: scale(1);
}
.modal_reserve span{
    color: red;
}
.modal_reserve .hd{
    margin-bottom: 16px;
    text-align: center;
    font-size: 18px;
}
@media screen and (max-width: 540px) {
.modal_r_content{
    width: 100%;
    height: 100%;
    padding: 16px;
}
}







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

#wrap{
    width: 100%;
    max-width: 1920px;
    margin-left: auto;
    margin-right: auto;
    padding: 0;
    text-align: left;
}
#wrap section,
#wrap .section{
    width: 92%;
    max-width: 1280px;
    margin-right: auto;
    margin-left: auto;
}
#wrap .mw_section{
    width: 100%;
    max-width: 1920px;
    margin-right: auto;
    margin-left: auto;
}
#wrap .mw_section .mw_inner{
    width: 92%;
    max-width: 1280px;
    margin-right: auto;
    margin-left: auto;
}
#wrap article{
    margin-bottom: 120px;
}
#wrap .breadcrumbs{
    width: 92%;
    max-width: 1280px;
    margin-right: auto;
    margin-left: auto;
    margin-bottom: 24px;
    padding: 24px 0;
}
#wrap article h1{
    width: 92%;
    max-width: 1280px;
    margin-right: auto;
    margin-left: auto;
    margin-bottom: 24px;
    padding: 24px 0;
    background: #f9b912;
    font-size: 23px;
    font-weight: bold;
    text-align: center;
}
#wrap article h2{
    margin-bottom: 24px;
    padding: 16px;
    background: #f9de97;
    font-size: 22px;
    font-weight: bold;
    text-align: left;
}
#wrap article h3{
    min-height: 20px;
    margin-bottom: 24px;
    padding: 0 16px 16px 32px;
    background: url("img/common/svg/h3.svg") no-repeat 0 5px;
    background-size: 20px auto;
    border-bottom: 1px dashed #000;
    font-size: 21px;
    font-weight: bold;
    text-align: left;
}
p{
    margin-bottom: 20px;
}
#wrap strong{
	background: linear-gradient(transparent 70%, #ffcde9 70%);
}
#wrap b{
    color: #e5007f;
}
#wrap .notes{
    padding: 24px;
}
#wrap .notes_blue{
    background: #ceedef;
    border: 1px solid #60adb2;
}
#wrap .notes_orange{
    background: #f9ebc7;
    border: 1px solid #f9b912;
}
/*
#wrap b{
    color: #f28f1d;
}
*/
.fx{
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
}
.fx_c{
    align-items: center;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
}
.fx_r{
    display: flex;
    flex-direction: row-reverse;
    flex-wrap: wrap;
    justify-content: space-between;
}

.two_columns,
.two_block,
ol.two_columns,
.three_columns,
ol.three_columns,
.four_columns,
.five_columns,
.six_columns
{
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
}
.three_columns::after,
ol.three_columns::after
{
    content: "";
    display: block;
	width: calc( 33% - 16px);
}
.two_block .box,
.two_columns .box,
ol.two_columns li{
	width: calc( 50% - 16px);
}
.three_columns .box,
ol.three_columns li{
	width: calc( 33% - 16px);
}
.four_columns .box{
	width: calc( 25% - 16px);
}
.five_columns .box{
	width: calc( 20% - 16px);
}
.six_columns .box{
	width: calc( 16.666% - 4px);
}
figcaption{
    padding-top: .5em;
}
.oz .imgL,
.oz .s_imgL{
    max-width: 48%;
    margin-right: 1em;

}
.oz .imgR,
.oz .s_imgR{
    max-width: 48%;
    margin-left: 1em;
}
#wrap .txt_box{
    width: 880px;
    margin-left: auto;
    margin-right: auto;
}
.checklists li{
    padding-left: 24px;
    padding-bottom: 8px;
    background:  url("img/common/svg/check.svg") no-repeat 0 7px;
    background-size: 16px auto;
}
.disc_list li,
.dot_list li{
    margin-left: 0;
}
.disc_list li::before{
    content: "● ";
    color: #4e807b;
    font-size: 10px;
}
.dot_list li::before{
    content: "・ ";
}




@media screen and (max-width: 1080px) {
@media screen and (max-width: 1023px) {
#wrap{
    width: 100%;
}
#wrap section,
#wrap .section{
    width: 92%;
    max-width: 960px;
}
.three_columns .box,
.four_columns .box{
	width: calc( 50% - 16px);
}
.six_columns .box{
	width: calc( 33% - 4px);
}
#wrap .txt_box{
    width: 92%;
    margin-left: auto;
    margin-right: auto;
}
@media screen and (max-width: 540px) {
#wrap section,
#wrap .section{
    width: 92%;
    max-width: inherit;
}
#wrap .mw_section .inner{
    width: 92%;
    margin-right: auto;
    margin-left: auto;
}
.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;
}
.two_columns .box,
ol.two_columns li{
    width: 100%;
}
.two_block .box,
.six_columns .box{
    width: calc( 50% - 5px );
}
.three_columns .box,
ol.three_columns li{
    float: none;
    width: 100%;
}
.four_columns .box{
	width: 100%;
}
}
}
}



/* ▲▲▲▲▲▲▲▲▲▲ 共通項目 ▲▲▲▲▲▲▲▲▲▲ */




#wrap,
#c_s,
#i,
#i-2,
#i-3,
#i-4,
#i-5,
#i-6,
#i-7
{
    margin-top: -88px;
    padding-top: 88px;
}
@media screen and (max-width: 1024px) {
#wrap,
#c_s,
#i,
#i-2,
#i-3,
#i-4,
#i-5,
#i-6,
#i-7
{
    margin-top: -88px;
    padding-top: 88px;
}
@media screen and (max-width: 540px) {
#wrap,
#c_s,
#i,
#i-2,
#i-3,
#i-4,
#i-5,
#i-6,
#i-7
{
    margin-top: 0;
    padding-top: 0;
}
}
}



.mushiba_flow{
    background: #f9f2e1;
}
.mushiba_flow .inner{
    width: 92%;
    max-width: 960px;
    margin: auto;
    padding: 80px 0;
}
.mushiba_flow .hd{
    margin-bottom: 24px;
    font-size: 26px;
    text-align: center;
    color: #f28f1d;
    font-weight: bold;
}
.mushiba_flow .hd span{
    text-decoration: underline;
    text-decoration-style: dotted;
    text-decoration-thickness: 3px;
    text-decoration-color: #f28f1d;
}

.mushiba_flow .grid:nth-of-type(odd){
    width: 20%;
}
.mushiba_flow .grid:nth-of-type(even){
    width: 80%;
    padding: 0 8px;
}
@media screen and (max-width: 540px) {
.mushiba_flow .grid:nth-of-type(odd){
    width: 30%;
}
.mushiba_flow .grid:nth-of-type(even){
    width: 70%;
    padding: 0 8px;
}
}





.pricelist table{
    width: 100%;
    max-width: 800px;
    margin: auto;
    border-collapse: collapse;
/*    border: 1px solid #f9de97;*/
    border-bottom: 1px solid #f9de97;
}
.pricelist table th{
    display: block;
    width: 100%;
    padding: 8px 24px;
    background: #eee;
    border: 1px solid #f9de97;
    border-bottom: 0;
    font-weight: 100;
}
.pricelist table td{
    display: block;
    width: 100%;
    padding: 8px 24px;
    border: 1px solid #f9de97;
    border-bottom: 0;
    font-weight: 100;
    text-align: right;
}




.merit{
    padding: 32px;
    background: #f7e6d2;
}
.merit li{
    width: calc(50% - 8px);
    padding: 16px;
    background: #fff;
}
.merit li div:first-of-type{
    margin-bottom: 8px;
    padding-left: 32px;
    background:  url("img/common/svg/o.svg") no-repeat 0 5px;
    background-size: 21px auto;
    color: #cf7b1d;
    font-weight: bold;
}
.demerit{
    padding: 32px;
    background: #eee;
}
.demerit li{
    width: calc(33% - 8px);
    padding: 16px;
    background: #fff;
}
.demerit li div:first-of-type{
    margin-bottom: 8px;
    padding-left: 32px;
    background:  url("img/common/svg/x.svg") no-repeat 0 5px;
    background-size: 19px auto;
    color: #5b5b5b;
    font-weight: bold;
}
@media screen and (max-width: 540px) {
.merit,
.demerit{
    padding: 24px 16px;
}
.merit li,
.demerit li{
    width: 100%;
}

}


