.mv{ margin-bottom: 60px; }
.mv img{ display: block; width: 100%; }

.monitor{ margin-bottom: 70px; }
.monitor .bg-pic{ background: url(../images/bg-monitor01.jpg) no-repeat center/cover; border-radius: 40px 40px 0 0; padding-left: 30px; position: relative; }
.monitor .inner{ background: #fff; width: 283px; height: 493px; display: flex; justify-content: center; align-items: center; position: relative; }
.monitor .inner:before{ content: ''; width: 1px; height: 100%; background: #00aef1; position: absolute; left: 5px; top: 0; }
.monitor .inner:after{ content: ''; width: 1px; height: 100%; background: #00aef1; position: absolute; right: 5px; top: 0; }
.monitor .inner img{ display: block; width: 195px; margin: 0 auto; }
.monitor .inner h2{ font-size: 40px; text-align: center; font-weight: 700; line-height: 1.4; margin-bottom: 30px; }
.monitor .inner h2 span{ border-bottom: solid 1px; }
.monitor .inner h2 + p{ font-size: 26px; font-weight: 700; color: #00aef1; line-height: 1.2; display: table; margin: 0 auto; }
.monitor .inner h2 + p strong{ display: block; font-size: 46px; }
.monitor .inner h2 + p strong .lato{ font-size: 62px; }
.monitor .inner h2 + p small{ display: block; font-size: 14px; text-align: right; }
.monitor .inner02{ background: rgba(70,70,70,.45); border-radius: 20px 0 0 0; position: absolute; bottom: 20px; right: 0; padding: 1em 2em; }
.monitor .inner02 p{ color: #fff; font-size: 12px; }
.monitor .inner02 p span{ font-weight: 700; font-size: 18px; line-height: 1.4; }
.monitor .inner02 p span strong{ font-size: 24px; }

.resv-box{ background: #861b20; padding: 20px 0 36px; border-radius: 0 0 30px 30px; position: relative; }
.resv-box p{ color: #fff; text-align: center; font-size: 20px; margin-bottom: 20px; }
.resv-box p strong{ font-size: 28px; font-weight: 700; line-height: 1.4; }
.resv-box a{ width: 320px; height: 60px; border-radius: 30px; background: #fff; font-size: 22px; font-weight: 700; color: #861b20; display: flex; justify-content: center; align-items: center; margin: 0 auto; }
.resv-box a span{ padding-left: 33px; background: url(../images/icon-resv01.png) no-repeat left bottom .3em/26.6px; }

h2.general{ font-size: 28px; font-weight: 700; text-align: center; line-height: 1.6; padding: 33px 0; border-radius: 40px 40px 0 0; background: #861b20; color: #fff; width: 1100px; letter-spacing: .16em; }
.wrap h2.general{ margin-left: -100px; }
h2.general strong{ font-size: 36px; }
h2.general span{ position: relative; }
h2.general span:after{ content: ''; width: 100%; height: 4px; background: #ffff00; position: absolute; bottom: -6px; left: 0; }

.kossori{ margin-bottom: 120px; }
.kossori h2.general{ background: url(../images/bg-kossori01.jpg) no-repeat center/cover; margin-bottom: 95px; }
.kossori .row{ align-items: flex-start; position: relative; }
.kossori .row + .row{ margin-top: 65px; }
.kossori h3{ width: 420px; background: rgba(0,174,241,.8); padding: 50px 0; text-align: center; font-size: 24px; font-weight: 700; color: #ffff00; position: relative; z-index: 0; }
.kossori h3 span{ display: table; margin: 0 auto; font-size: 30px; color: #00aef1; background: #fff; line-height: 1.4; padding: 0 1em; margin-bottom: 1em; }
.kossori .row .img{ width: calc(50vw - 115px); height: 385px; background-repeat: no-repeat; background-size: cover; position: absolute; top: 270px; z-index: -1; box-shadow: 2px 2px 15px 1px rgba(70,70,70,0.2); }
.kossori .row:nth-of-type(1) .img{ background-image: url(../images/kossori02.jpg); left: calc(-50vw + 450px); border-radius: 0 0 40px 0; }
.kossori .row:nth-of-type(2) .img{ background-image: url(../images/kossori04.jpg); right: calc(-50vw + 450px); border-radius: 0 0 0 40px; }
.kossori .row:nth-of-type(odd) h3{ margin-left: -20px; border-radius: 40px 0 0 0; }
.kossori .row:nth-of-type(even) h3{ margin-right: -20px; border-radius: 0 40px 0 0; }
.kossori .content{ width: 50%; position: relative; }
.kossori .row:nth-of-type(1) .content:before{ content: ''; width: 450px; height: 250px; background: url(../images/kossori01.jpg) no-repeat center/contain; position: absolute; top: -80px; right: -210px; }
.kossori .row:nth-of-type(2) .content:before{ content: ''; width: 490px; height: 484px; background: url(../images/kossori03.png) no-repeat center/contain; position: absolute; left: -252px; top: -320px; }
.kossori .content h4{ font-size: 22px; font-weight: 700; color: #00aef1; position: relative; margin-bottom: 55px; }
.kossori .row:nth-of-type(even) .content h4{ margin-top: 240px; }
.kossori .content h4:after{ content: ''; width: 50vw; height: 6px; border-top: solid 1px; border-bottom: solid 1px; box-sizing: border-box; position: absolute; bottom: -6px; left: 0; }
.kossori .row:nth-of-type(even) .content h4:after{ left: auto; right: 0; }
.kossori .content h4 strong{ font-size: 28px; }
.kossori .content .marker{ margin: 160px 0 1em; }
.kossori .content .marker span{ font-size: 20px; color: #00aef1; background: #ffff00; padding: 0 .3em; display: inline-block; }
.kossori .content .marker br + span{ margin-top: .3em; }
.kossori .content .marker span small{ font-size: 12px; }
.kossori .content ol{ display: flex; justify-content: space-between; flex-wrap: wrap; counter-reset: point; }
.kossori .content ol li{ width: 220px; font-size: 18px; font-weight: 700; text-align: center; }
.kossori .content ol li:nth-of-type(n+3){ margin-top: 48px; }
.kossori .content ol li .no{ display: table; background: #00aef1; color: #fff; font-size: 20px; border-radius: 20px; line-height: 1.6; padding: 0 1em; margin: 0 auto; }
.kossori .content ol li .no strong{ font-size: 24px; }
.kossori .content ol li img{ width: 126px; display: block; margin: 0 auto; }

.dr{ margin-bottom: 80px; }
.dr h2.general{ background: url(../images/bg-dr01.jpg) no-repeat center/cover; margin-bottom: 88px; }
.dr .row{ position: relative; padding-top: 60px; justify-content: flex-start; }
.dr .row + .row{ margin-top: 60px; }
.dr .img{ position: absolute; top: 0; width: 50vw; height: 400px; background-repeat: no-repeat; background-size: cover; background-position: center; }
.dr .row:nth-of-type(odd) .img{ background-image: url(../images/bg-dr02.jpg); left: calc(-50vw + 450px); border-radius: 0 40px 0 0; }
.dr .row:nth-of-type(even) .img{ background-image: url(../images/bg-dr03.jpg); right: calc(-50vw + 450px); border-radius: 40px 0 0 0; }
.dr .row:nth-of-type(1) .img img{ display: block; width: 490px; position: absolute; bottom: 0; right: 60px; }
.dr .row:nth-of-type(2) .img img{ display: block; width: 550px; position: absolute; bottom: 0; left: 40px; }
.dr .content{ width: 490px; background: #fff; position: relative; z-index: 2; }
.dr .row:nth-of-type(odd) .content{ margin-left: auto; padding: 33px 0 33px 66px; border-radius: 40px 0 0 0; }
.dr .row:nth-of-type(even) .content{ padding: 33px 66px 33px 0; border-radius: 0 40px 0 0; }
.dr .content h3{ font-size: 36px; color: #861b20; position: relative; padding-bottom: .3em; margin-bottom: 24px; }
.dr .content h3:after{ content: ''; width: calc(50vw - 24px); height: 6px; border-top: solid 1px; border-bottom: solid 1px; box-sizing: border-box; position: absolute; bottom: 0; }
.dr .row:nth-of-type(odd) .content h3:after{ left: 0; }
.dr .row:nth-of-type(even) .content h3:after{ right: 0; }
.dr .content h3 + p{ font-size: 20px; font-weight: 700; color: #b67679; white-space: nowrap; margin-bottom: 1.3em; }
.dr .content table th{ font-size: 12px; white-space: nowrap; padding-right: 1em; line-height: 2; }
.dr .content table td{ font-size: 12px; line-height: 2; }

.worry{ padding: 50px 0 0; position: relative; z-index: 0; margin-bottom: 100px; }
.worry:before{ content: ''; width: 100%; height: 660px; background: url(../images/bg-worry01.jpg) no-repeat center/cover; position: absolute; top: 0; left: 0; z-index: -1; }
.worry h2{ margin-bottom: 50px; }
.worry .message{ border-radius: 40px 0 40px 0; overflow: hidden; box-shadow: 2px 2px 15px 1px rgba(70,70,70,0.2); margin-bottom: 100px; }
.worry .message .img{ width: 50%; background: url(../images/worry01.jpg) no-repeat center/cover; }
.worry .message .content{ background: #fff; width: 50%; padding: 50px 20px 25px; }
.worry .message .content .inner{ height: 470px; overflow-y: scroll; padding: 0 25px; }
.worry .message .content .inner::-webkit-scrollbar{ width: 6px; background: #f2f2f2; border-radius: 3px; }
.worry .message .content .inner::-webkit-scrollbar-thumb{ background: #b3b3b3; border-radius: 3px; }
.worry .message .content p{ text-align: center; }
.worry .message .content p + p{ margin-top: 2em; }
.worry .point{ width: 960px; margin-left: -30px; margin-bottom: 40px; position: relative; z-index: 0; }
.worry .point:before{ content: ''; width: 100vw; height: 380px; background: #f2f0e6; position: absolute; left: calc(-50vw + 480px); top: 90px; z-index: -1; }
.worry .point li{ width: 300px; border-radius: 30px 30px 0 0; overflow: hidden; box-shadow: 2px 2px 15px 1px rgba(70,70,70,0.2); background: #fff; padding-bottom: 30px; }
.worry .point li img{ display: block; width: 100%; margin-bottom: 20px; }
.worry .point li h3{ font-size: 18px; font-weight: 700; color: #861b20; text-align: center; line-height: 1.6; margin-bottom: 15px; }
.worry .point li p{ text-align: center; }

.type{ position: relative; z-index: 0; padding-top: 50px; padding-bottom: 90px; margin-bottom: 100px; }
.type:before{ content: ''; width: calc(50vw + 300px); height: 100%; background: #e5f7fe; position: absolute; top: 0; right: calc(-50vw + 450px); z-index: -1; border-radius: 40px 0 0 0; }
.type h2.general{ background: #00aef1; margin-bottom: 75px; }
.type .type-list{ flex-wrap: wrap; width: 830px; margin: 0 auto 64px; }
.type .type-list li{ width: 33.333%; text-align: center; font-weight: 700; font-size: 20px; color: #00aef1; }
.type .type-list li:nth-of-type(n+4){ margin-top: 40px; }
.type .type-list li img{ display: block; width: 160px; margin: 0 auto 15px; }
.type .type-list + p{ max-width: 800px; background: #fff; font-size: 20px; font-weight: 700; color: #00aef1; text-align: center; margin: 0 auto; padding: 1.2em; border-radius: 20px; }

.plan{ padding: 50px 0 60px; position: relative; z-index: 0; margin-bottom: 100px; }
.plan:before{ content: ''; width: calc(50vw + 345px); height: 100%; background: #f6f6f6; position: absolute; top: 0; left: 0; z-index: -1; border-radius: 0 40px 0 0; }
.plan h2{ margin-bottom: 110px; }
.plan .content{ width: 790px; background: #fff; position: relative; margin-left: auto; padding: 80px 77px 50px; border-radius: 0 0 0 40px; }
.plan .content + .content{ margin-top: 120px; }
.plan .content h3{ font-size: 24px; font-weight: 700; color: #fff; text-align: center; width: 260px; padding: 35px 0; position: absolute; top: -40px; left: -155px; background: #00aef1; border-radius: 40px 0 0 0; line-height: 1.4; }
.plan .content:nth-of-type(2) h3{ background: #464646; }
.plan .content h3 small{ font-size: 18px; line-height: 1.4; }
.plan .content .note{ position: absolute; top: -2em; right: 0; }
.plan .content table{ border-collapse: separate; border-spacing: 0 20px; margin-bottom: 20px; }
.plan .content table th{ text-align: right; padding-right: 1em; font-size: 16px; font-weight: 700; border-right: solid 1px #c7c7c7; }
.plan .content table td{ padding-left: 1em; font-size: 16px; }
.plan .content table td small{ font-size: 14px; }
.plan .content table + dl.row{ justify-content: flex-start; }
.plan .content:nth-of-type(2) p{ font-size: 18px; font-weight: 700; }

.flow{ position: relative; margin-bottom: 160px; }
.flow .img{ width: calc(50vw - 400px); height: 660px; position: absolute; top: 64px; left: calc(-50vw + 450px); transform:  }
.flow .img .image{ width: 100%; height: 200px; border-radius: 0 40px 40px 0; background-repeat: no-repeat; background-size: cover; background-position: center right; position: absolute; left: 0; }
.flow .img .image:nth-of-type(1){ top: 0; background-image: url(../images/flow01.jpg); }
.flow .img .image:nth-of-type(2){ top: 50%; transform: translateY(-50%); background-image: url(../images/flow02.jpg); }
.flow .img .image:nth-of-type(3){ bottom: 0; background-image: url(../images/flow03.jpg); }
.flow h2{ margin-bottom: 80px; }
.flow ul{ display: table; margin: 0 auto; }
.flow ul li{ display: flex; align-items: flex-start; position: relative; }
.flow ul li:not(:last-of-type){ padding-bottom: 38px; }
.flow ul li:not(:last-of-type):after{ content: ''; width: 10px; height: 100%; background: #e7d1d2; position: absolute; top: 0; left: 90px; z-index: -1; }
.flow ul li:nth-last-of-type(2){ padding-bottom: 50px; }
.flow ul li:nth-last-of-type(2):after{ height: calc(100% - 25px); }
.flow ul li:nth-last-of-type(2):before{ content: ''; width: 0; height: 0; border-style: solid; border-width: 22px 17px 0 17px; border-color: #e7d1d2 transparent transparent transparent; position: absolute; bottom: 3px; left: 78px; }
.flow ul li h3{ width: 190px; background: #f3e8e9; font-size: 20px; font-weight: 700; color: #861b20; padding: .6em .6em; border-radius: 10px; line-height: 1.6; position: relative; }
.flow ul li p{ padding-left: 30px; font-size: 16px; }

.faq{ padding-top: 50px; padding-bottom: 90px; position: relative; z-index: 0; margin-bottom: 100px; }
.faq:before{ content: ''; width: calc(50vw + 300px); height: 100%; background: #fcf7e5; border-radius: 0 40px 0 0; position: absolute; top: 0; left: calc(-50vw + 450px); z-index: -1; }
.faq h2{ margin-bottom: 80px; }
.faq .row{ flex-wrap: wrap; width: 1000px; margin-left: -50px; }
.faq .row dl{ width: 480px; border-radius: 10px; overflow: hidden; }
.faq .row dl + dl{ margin-top: 30px; }
.faq .row dl dt{ background: #464646; color: #fff; font-size: 16px; padding: 1.4em 50px 1.4em 30px; position: relative; cursor: pointer; }
.faq .row dl dt:before{ content: ''; width: 20px; height: 20px; background: url(../images/icon-faq01.png) no-repeat center/contain; position: absolute; top: 50%; right: 30px; transform: translateY(-50%); transition: .3s; }
.faq .row dl dt:after{ content: ''; width: 20px; height: 20px; background: url(../images/icon-faq02.png) no-repeat center/contain; position: absolute; top: 50%; right: 30px; transform: translateY(-50%); transition: .3s; opacity: 0; }
.faq .row dl dt.active:before{ opacity: 0; }
.faq .row dl dt.active:after{ opacity: 1; }
.faq .row dl dt span{ padding-left: 38px; position: relative; }
.faq .row dl dt span:before{ content: 'Q.'; color: #a2a2a2; font-size: 24px; font-family: 'Lato', sans-serif; font-weight: 700; position: absolute; left: 0; top: 50%; transform: translateY(-50%); }
.faq .row dl dd{ background: #fff; padding: 1em 50px 1em 30px; display: none; }
.faq .row dl dd span{ padding-left: 38px; position: relative; display: block; }
.faq .row dl dd span:before{ content: 'A.'; color: #a2a2a2; font-size: 24px; font-family: 'Lato', sans-serif; font-weight: 700; position: absolute; left: 0; top: -10px; }

.dentition{ margin-bottom: 75px; }
.dentition h2{ margin-bottom: 30px; }
.dentition h2 + p{ font-size: 16px; text-align: center; }

.clinic{ margin-bottom: 95px; }
.clinic .row{ position: relative; }
.clinic .row + .row{ margin-top: 120px; }
.clinic .content{ width: 435px; }
.clinic .row:nth-of-type(2) .content{ margin-left: auto; }
.clinic .content h2{ position: relative; color: #861b20; padding-bottom: 1em; margin-bottom: 1.4em; }
.clinic .content h2:after{ content: ''; width: calc(50vw - 10px); height: 6px; border-top: solid 1px; border-bottom: solid 1px; box-sizing: border-box; position: absolute; bottom: 0; }
.clinic .row:nth-of-type(1) .content h2:after{ right: 0; }
.clinic .row:nth-of-type(2) .content h2:after{ left: 0; }
.clinic .content h2 img{ display: block; width: 300px; }
.clinic .content .tel{ font-size: 30px; color: #861b20; padding-left: 34px; background: url(../images/icon-tel01.png) no-repeat left center/24px; }
.clinic .content table{ width: 400px; border: solid 1px; border-collapse: separate; margin-bottom: .4em; }
.clinic .content table thead{ background: #f6f6f6; }
.clinic .content table th,
.clinic .content table td{ text-align: center; vertical-align: middle; padding: .4em .6em; border-left: solid 1px #dadada; border-bottom: solid 1px #dadada; }
.clinic .content table tbody tr:last-of-type *,
.clinic .content table td[rowspan="2"]{ border-bottom: none; }
.clinic .map{ width: calc(50vw - 40px); height: 100%; position: absolute; top: 0; background: #f0f0f0; overflow: hidden; }
.clinic .row:nth-of-type(1) .map{ right: calc(-50vw + 450px); border-radius: 40px 0 0 0; }
.clinic .row:nth-of-type(2) .map{ left: calc(-50vw + 450px); border-radius: 0 40px 0 0; background: #d2ebf5; }
.clinic .map .inner{ width: 550px; height: 100%; position: absolute; top: 0; background-repeat: no-repeat; background-size: cover; }
.clinic .row:nth-of-type(1) .map .inner{ left: 0; background-image: url(../images/map01.jpg); }
.clinic .row:nth-of-type(2) .map .inner{ right: 0; background-image: url(../images/map02.jpg); }

.dr.wrap h3 span{font-size: 18px;}