@charset "utf-8";
/*
Theme Name: インプラントサイト 2022
Theme URI: http://www.leilani-ds.com/implant/
Description: Versions 1.0.x
Version: 1.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: #4c4638;
    font-family: 'Segoe UI', YuGothic, 'Yu Gothic Medium', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', Meiryo, sans-serif;
/*    font-size: 16px;*/
    font-size: clamp(0.75rem, 2vw + 1rem, 1rem);
	word-wrap : break-word;
	overflow-wrap : break-word;
    line-height: 1.8em;
    letter-spacing: 1.6pt;
    -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: 540px) {
body{
    min-width: 100%;
/*    font-size: 1.6rem;*/
}
}
h1,h2,h3,h4,h5,h6{
    margin: 0;
    font-weight: 100;
}
*, *:before, *:after{
    box-sizing: border-box;
}
::selection {
    background: #024caa;
    color: #fff;
    text-shadow: 1px 1px 2px rgba(240, 240, 200, 1);
}
::-moz-selection {
    background: #024caa;
    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: #000;
}
a:active, a:hover{
    color: #000;
    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;
    border: none;
    vertical-align: middle;
}
.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:12px;}
.fs13{font-size:13px;}
.fs14{font-size:14px;}
.fs15{font-size:15px;}
.fs16{font-size:16px;}
.fs17{font-size:17px;}
.fs18{font-size:18px;}
.fs19{font-size:19px;}
.fs20{font-size:20px;}
.fs21{font-size:21px;}
.fs22{font-size:22px;}
.fs23{font-size:23px;}
.fs24{font-size:24px;}

.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;}
.mb64{margin-bottom:64px;}
.mb80{margin-bottom:80px;}
.mb120{margin-bottom:120px;}
.mb160{margin-bottom:160px;}

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

.fc_blue{color: #024caa;}

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

strong{
	background: linear-gradient(transparent 40%, #fff755 40%);
}
b{
/*	color: #e07070;*/
	color: #01a4a7;
}


.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: 0.5;
    filter: alpha(opacity=50);
    -ms-filter: "alpha( opacity=50 )";
}

.more a{
    position: relative;
    display: block;
    margin-left: auto;
    margin-right: auto;
    padding: 24px 24px;
    background: #fff;
    color: #024caa;
    text-align: center;
    line-height: 1.3;
    border: 1px solid #024caa;
    border-radius: 4em;
    letter-spacing: 0;
}
.more a:hover{
    background: #024caa;
    color: #fff;
}
.more a::after{
    position: absolute;
    top: 50%;
    right: .5em;
    content: '';
    margin-top: -5px;
    border: 7px solid transparent;
    border-top-width: 5px;
    border-bottom-width: 5px;
    border-left-color: #024caa;
}
.more a:hover::after {
  animation: arrow .4s;
    border-left-color: #fff;
}
@keyframes arrow {
  50% {
    right: -.05em;
  }
  100% {
    right: .5em;
  }
}


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;
}


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


header{
	position: -webkit-sticky;
	position: sticky;
	top: 0;
    z-index: 1000;
    width: 100%;
    margin: auto;
    text-align: left;
    background: rgba(255,255,255,1);
}
#upper{
    position: relative;
    width: 100%;
    max-width: 1440px;
    height: 164px;
    margin: auto;
}
#upper .inner{
    position: relative;
    height: 90px;
    margin: auto;
    transition: all .5s ease-in;
}
#upper .logo{
    position: absolute;
    width: 445px;
    height: 56px;
    margin: auto;
    top: 10px;
    left: 0;
    text-align: center;
}
#upper .logo div:first-of-type{
    width: 27%;
}
#upper .logo div:nth-child(2){
    width: 18%;
}
#upper .logo div:last-of-type{
    width: 55%;
    text-align: center;
}
#upper .logo div:last-of-type img{
    width: 80%;
    height: auto;
}

#upper .inner ul{
    position: absolute;
    width: 100%;
    max-width: 50%;
    height: 80px;
    margin: 0;
    right: 0;
    top: 0;
    text-align: center;
}
#upper .inner .dn li{
    text-align: left;
}
#upper .inner .dn li:nth-child(odd){
    width: 30%;
}
#upper .inner .dn li:nth-child(even){
    width: 20%;
}
/*
#upper .inner li:nth-of-type(2){
    width: 150px;
    text-align: center;
}
#upper .inner li:nth-of-type(3){
    display: none;
    padding: 8px 0;
    background: #fff;
}
*/
@media screen and (max-width: 1024px) {
header{
	position: inherit;
    background: rgba(255,255,255,0);
}
#upper{
    width: 92%;
    max-width: 960px;
    height: 80px;
}
#upper .inner{
    width: 100%;
    height: 100%;
}
#upper .inner ul{
    position: fixed;
    width: 100%;
    height: 60px;
    margin: 0;
    left: 0;
    right: 0;
    top: inherit;
    bottom: 0;
}
#upper .inner li:first-of-type{
    width: 50%;
    padding: 8px 0;
    background: #024caa;
}
#upper .inner li:nth-of-type(2){
    width: 50%;
    padding: 8px 0;
/*    background: #fff755;*/
}
@media screen and (max-width: 821px) {
#upper .inner ul{
    width: 100%;
    max-width: 821px;
    height: 80px;
    background: rgb(255,255,255);
    background: linear-gradient(90deg, #024caa 0%, #024caa 50%, #00b6ed 50%, #00b6ed 80%, #00b6ed 80%, #00b6ed 100%);
}
#upper .inner .spc li:first-of-type{
    width: 50%;
    padding: 0;
}
#upper .inner .spc li:nth-of-type(2){
    width: 50%;
    padding: 0;
}
/*
#upper .inner .spc li:last-child{
    display: none;
    padding: 0;
}
*/
@media screen and (max-width: 540px) {
#upper{
    width: 100%;
    height: 64px;
}
#upper .logo{
    width: 280px;
    height: 30px;
    left: 10px;
}
#upper .inner ul{
    height: 51px;
    background: rgb(255,255,255);
    background: linear-gradient(90deg, #024caa 0%, #024caa 50%, #00b6ed 50%, #00b6ed 100%);
}
#upper .inner .spc li:first-of-type{
    width: 50%;
    padding: 0;
}
#upper .inner .spc li:nth-of-type(2){
    width: 50%;
    padding: 0;
}
/*
#upper .inner .spc li:last-child{
    display: block;
    width: 20%;
    padding: 0;
}
*/
}
}
}
@media screen and (max-width: 359px) {
#upper .logo{
    width: 80%;
}
}

#gnav{
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    text-align: center;
/*    font-weight: 600;*/
}
#gnav ul{
    width: 100%;
    height: 64px;
    margin: auto;
    letter-spacing: 0;
}
#gnav ul li{
    position: relative;
    width: calc(100% / 8);
    margin: auto;
    letter-spacing: 0;
    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: 1px;
    background: #01a4a7;
    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: 16px 0;
    color: #333;
    text-align: center;
}
#gnav ul li a:hover,
#gnav ul li a.ov{
    text-decoration: none;
}
#gnav ul li li a{
    padding: 8px;
    background: #fff;
/*    font-weight: 100;*/
    text-decoration: none;
    text-align: left;
}
#gnav ul li li a:hover{
    padding: 8px;
}
#gnav ul ul{
    position: absolute;
    top: 100%;
    height: inherit;
    left: -1px;
    border-left: 0;
/*    background: #f7e7cd;*/
}
#gnav ul ul li{
    display: block;
    width: 240px;
    border: 0;
}
#gnav > ul > li:nth-child(3) > ul > li{
    width: 460px;
}
#gnav ul ul li a{
    display: block;
    border: 0;
}
#gnav ul ul li:not(:first-child) {
    border-top: none;
}
#gnav ul ul ul{
    position: absolute;
    top: -2px;
    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: 1024px) {
#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: 9999;
    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;
}
#upper_toggle span:nth-child(1) {
    top: 10px;
}
#upper_toggle span:nth-child(2) {
    top: 18px;
}
#upper_toggle span:nth-child(3) {
    top: 26px;
}
.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: 9999;
    width: 100%;
    height: 94%;
    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: 100%;
    overflow-y: auto;
    margin: 0;
    padding: 64px 0 0;
    box-sizing: border-box;
    background: #024caa;
    line-height: 1.4em;
    transform: translateY(-30%);
    transition: .3s;
}
.modal_content .logo{
    margin-bottom: 16px;
    text-align: center;
}


.tab{
    width: 100%;
    margin: 0 auto 24px;
    border-bottom: 1px solid #ccc;
}
.tab li{
    width: calc(50% - 4px);
    padding: 16px 0;
    color: #5c5737;
    text-align: center;
    font-weight: bold;
    border-top-left-radius: 4px;
    border-top-right-radius: 4px;
}
.tab li:nth-child(1){
    background: #fcaa2c;
}
.tab li:nth-child(2){
    background: #58b8a8;
}

.tab_sub{
    width: 100%;
    margin: 0;
    padding:0;
    display: flex;
    list-style: none;
}
.tab_sub li{
    width: calc(33% - 2px);
    margin-bottom: 4px;
    text-align: center;
}
.tab_sub li.active{
}
.list{
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 24px;
}
.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{
    width: 92%;
    margin: 0 auto 4px;
    padding: 24px;
    background: #fff;
    border-radius: 8px;
    border: 1px solid #e9e9d8;
    overflow-y: auto;
}
.childnav_box{
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
}
.childnav_box .grid{
    width: calc(33% - 2px);
    margin-bottom: 3px;
}
.childnav_box::after{
    content: "";
    display: block;
    width: calc(33% - 2px);
}






.modal_content ul{
    width: 92%;
    margin: auto;
    text-align: center;
}
.modal_content ul li{
}
.modal_content ul li:last-of-type{
}
.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;
/*    font-weight: 600;*/
    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;
}
#upper_toggle span{
    height: 2px;
    width: 60%;
}
@media screen and (max-width: 360px) {
#upper_toggle{
    width: 32px;
    height: 32px;
}
}
}
}

.sitelinks{
    background: #fff;
    letter-spacing: 0;
    color: #000;
    font-size: 14px;
}
.modal_content .sitelinks{
    margin-top: 40px;
    background: #024caa;
}
.sitelinks .three_columns{
    width: 100%;
    max-width: 1280px;
    margin: auto;
}
.sitelinks .three_columns .box{
    width: 33.333%;
    padding: 8px 24px;
}
.sitelinks li a::before{
    content: "- ";
}
.sitelinks li a{
    position: relative;
    display: inline-block;
    padding: 4px 0;
    color: #000;
    text-decoration: none;
    letter-spacing: 0;
}
.sitelinks li a::after{
    position: absolute;
    bottom: 0;
    left: 0;
    content: '';
    width: 100%;
    height: 1px;
    background: #01a4a7;
    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;
}
@media screen and (max-width: 820px) {
.sitelinks .three_columns .box{
    width: 50%;
    padding: 8px;
}
@media screen and (max-width: 540px) {
.sitelinks{
    font-size: 15px;
}
.sitelinks .three_columns{
    width: 92%;
}
.sitelinks .three_columns .box{
    width: 100%;
    padding: 0;
    border-right: 0;
}
}
}


.sitelinks dl{
    padding: 0 0 8px;
    border-bottom: 1px solid #ddd;
}
.sitelinks div a,
.sitelinks p a{
    position: relative;
    display: inline-block;
    display: block;
    margin-bottom: 16px;
    padding: 0 0 8px;
/*    font-weight: 600;*/
    color: #000;
    border-bottom: 1px solid #ddd;
    text-align: left;
}
.modal_content .ft_hd,
.modal_content .sitelinks div a,
.modal_content .sitelinks p a,
.modal_content .sitelinks li a{
    color: #fff;
}
.sitelinks div a::after,
.sitelinks p a::after{
    position: absolute;
    bottom: -2px;
    left: 0;
    content: '';
    width: 100%;
    height: 1px;
    background: #01a4a7;
    transform: scale(0, 1);
    transform-origin: right top;
    transition: transform .3s;
}
.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;
/*    font-weight: 100;*/
}


.ft_nav{
    margin-bottom: 16px;
    padding: 0 0 8px;
    color: #000;
    text-align: left;
}
.ft_hd{
	position: relative;
	padding: 0;
    font-weight: 600;
    color: #000;
    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;
}
.modal_content .ft_btn{
	background: #024caa;
}
.ft_nav dd{
    padding: 8px 16px;
}
.ft_nav dd li li{
    padding-left: 16px;
}
@media screen and (max-width: 540px) {
.sitelinks div a,
.sitelinks p a{
    padding: 0 0 8px;
}
.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: #e0c7bc;
	position: absolute;
	width: 10px;
	height: 2px;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}
.modal_content .ft_btn:before, .modal_content .ft_btn:after{
	background: #fff;
}
.ft_hd{
	cursor: pointer;
}
.ft_btn:before{
	width: 2px;
	height: 10px;
}
.ft_hd.selected .ft_btn:before {
	content: normal;
}
.ft_nav dd{
	display: none;
}
}


#mv{
    width: 100%;
    max-width: 1440px;
    margin: auto;
}
@media screen and (max-width: 540px) {
#mv{
    margin-bottom: 40px;
}
}


.reasonable{
    width: 100%;
    max-width: 960px;
    margin: 0 auto 40px;
    text-align: center;
}
@media screen and (max-width: 540px){
.reasonable{
    width: 92%;
    margin: 0 auto 40px;
}
}



.tokuchou{
    padding: 80px 0;
    background: #07499d url("img/tokuchoubg_pc.webp") no-repeat 0 0;
    background-size: 100% auto;
    counter-reset: number 0;
}
.tokuchou h1,
.tokuchou .hd{
    margin-bottom: 40px;
    padding: 80px 0 0;
    background: url("img/feature.svg") no-repeat center 0;
    background-size: 164px auto;
    font-size: 23px;
    color: #fff;
    font-weight: 600;
    text-align: center;
}
.tokuchou h1 br,
.tokuchou .hd br{
    display: none;
}
.tokuchou .inner{
    width: 100%;
    max-width: 1080px;
    margin: auto;
}
.tokuchou .group{
	position: relative;
    padding: 40px 64px;
    background: #fff;
}
.tokuchou .fx,
.tokuchou .fx_r{
    width: 100%;
    max-width: 1280px;
    margin: 0 auto 40px;
}
.tokuchou .fx_r:last-of-type{
    margin-bottom: 0;
}
.tokuchou .grid{
	position: relative;
    width: calc(50% - 24px);
}
.tokuchou .group:before{
	content: "";
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	border-right: 40px solid transparent;
	border-top: 40px solid #01a4a7; 
}
.tokuchou .details{
    padding: 8px 24px 24px;
}
.tokuchou h2,
.tokuchou .subhd{
    margin-bottom: 16px;
    font-size: 19px;
    font-weight: 600;
}
.tokuchou h2::before,
.tokuchou .subhd::before{
    display: block;
    margin-bottom: 16px;
    color: #01a4a7;
    font-size: 30px;
    counter-increment: number 1;
    content: "0"counter(number)" _";
    font-family: Arial, Helvetica, "sans-serif";
    letter-spacing: 0;
}
.tokuchou .more{
    width: 80%;
    margin: 0;
}
.tokuchou .more br{
    display: none;
}
#wrap > div.tokuchou > div.inner > div.group.fx.su.fiu > div:nth-child(1) > div.more > a > br{
    display: block;
}


@media screen and (max-width: 540px) {
.tokuchou{
    padding: 40px 0;
}
.tokuchou h1 br{
    display: block;
}
.tokuchou .group{
	position: relative;
    padding: 24px 16px;
    background: #fff;
    margin-bottom: 40px;
}
.tokuchou .fx,
.tokuchou .fx_r{
    width: 88%;
    max-width: 540px;
}
.tokuchou .grid{
    width: 100%;
}
.tokuchou .more{
    width: 100%;
    margin-bottom: 24px;
}
.tokuchou .more br{
    display: block;
}
.tokuchou .more a{
    width: 100%;
    margin-bottom: 24px;
}
}


.kenkoujumyou{
    width: 100%;
    padding: 80px 0 40px;
    background: #e8f8fb url("img/kenkoujumyoubg_pc.jpg") no-repeat 0 0;
    background-size: 49% auto;
}
.kenkoujumyou .inner{
    width: 100%;
    max-width: 1080px;
    margin: auto;
}
.kenkoujumyou .grid{
    width: calc(50% - 24px);
}
#wrap > div.kenkoujumyou > div > div.fx_r > div:nth-child(1){
    margin-bottom: 40px;
}
#wrap > div.kenkoujumyou > div > div.fx_r > div:nth-child(2){
    margin-bottom: 40px;
    padding-top: 80px;
    text-align: center;
}
.kenkoujumyou h2{
    margin-bottom: 24px;
    font-size: 19px;
    letter-spacing: 0;
    font-weight: 600;
}
.kenkoujumyou .kakaku_plate{
    width: 100%;
    max-width: 560px;
    margin: 0 auto 24px;
}
.kenkoujumyou .kakaku_plate .hd{
    margin-bottom: 24px;
    color: #07499d;
    font-weight: 600;
    font-size: 20px;
}
@media screen and (max-width: 540px) {
.kenkoujumyou{
    padding: 64px 0 40px;
    background: rgb(164,206,218);
    background: linear-gradient(180deg, rgba(164,206,218,1) 0%, rgba(255,255,255,1) 0%, rgba(255,255,255,1) 70%, rgba(232,248,251,1) 70%, rgba(165,206,217,1) 5665%);
}
.kenkoujumyou .inner{
    width: 100%;
}
.kenkoujumyou .grid{
    width: 88%;
    margin: 0 auto 40px;
}
#wrap > div.kenkoujumyou > div > div.fx_r > div:nth-child(1){
    margin-bottom: 40px;
}
#wrap > div.kenkoujumyou > div > div.fx_r > div:nth-child(2){
    width: 100%;
    margin-bottom: 24px;
    padding-top: 40px;
    background: #e8f8fb url("img/kenkoujumyoubg_pc.jpg") no-repeat 0 0;
    background-size: 100% auto;
    text-align: center;
}
#wrap > div.kenkoujumyou > div > div.fx_r > div:nth-child(2) img{
    width: 90%;
    height: auto;
}
.kenkoujumyou .kakaku_plate{
    width: 100%;
    margin: 0 auto 24px;
    padding: 0 20px;
}
.kenkoujumyou .kakaku_plate .hd{
    margin-bottom: 24px;
    color: #07499d;
    font-weight: 600;
    font-size: 20px;
}
.kenkoujumyou .more.w40{
    width: 88%;
    margin: auto;
}

}



.kouzou{
    padding: 80px 0;
    background: #75a6d0;
}
.kouzou .fx{
    width: 100%;
    max-width: 1080px;
    margin: auto;
}
.kouzou .grid{
    width: 40%;
}
.kouzou .grid:first-of-type{
    width: 59%;
}
.kouzou ol{
    padding: 24px;
    background: #fff;
}
.kouzou li{
    margin-bottom: 8px;
    padding-bottom: 8px;
    border-bottom: 1px dashed #ddd;
    font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
.kouzou li:last-of-type{
    margin-bottom: 0;
    border-bottom: 0;
}
.kouzou li::first-letter{
    color: #e57754;
    font-size: 20px;
}
.kouzou .more a{
    width: 20%;
    margin: auto;
}
@media screen and (max-width: 540px) {
.kouzou{
    padding: 40px 0;
}
.kouzou .fx_r{
    width: 88%;
}
.kouzou .grid{
    width: 100%;
}
.kouzou .fx{
    width: 88%;
    max-width: 1080px;
    margin: auto;
}
.kouzou .grid{
    width: 100%;
}
.kouzou .grid:first-of-type{
    width: 100%;
}
.kouzou .more a{
    width: 88%;
    margin: auto;
}
}




.top__cases{
    padding: 80px 0 40px;
    background: #eaeff3;
}
.top__cases .inner{
    width: 100%;
    max-width: 1080px;
    margin: 0 auto 40px;
    padding: 40px 80px 80px;
    background: #fff;
    border-top: 4px solid #0e4998;
}
.top__cases h2{
    margin-bottom: 24px;
    padding: 64px 0 0;
    background: url("img/case.svg") no-repeat center 0;
    background-size: 90px auto;
    color: #1e55d0;
    font-size: 22px;
    font-weight: 600;
    text-align: center;
}
.top__cases h3{
    margin-bottom: 16px;
    color: #1e55d0;
    font-size: 20px;
    font-weight: 600;
}
.cases dt{
    width: 25%;
    margin-bottom: 24px;
    padding: 0 0 8px 24px;
    border-bottom: 1px solid #ccc;
    font-weight: 600;
}
.cases dd{
    width: 75%;
    margin-bottom: 24px;
    padding-bottom: 8px;
    border-bottom: 1px solid #ccc;
}
.cases dt:last-of-type,
.cases dd:last-of-type
{
    margin-bottom: 0;
}
.top__cases .more{
    width: 30%;
    margin: 0 auto 80px;
}
@media screen and (max-width: 540px) {
.top__cases{
    padding: 40px 0;
}
.top__cases .inner{
    width: 88%;
    max-width: 540px;
    padding: 24px 16px 40px;
    background: #fff;
    border-top: 4px solid #0e4998;
}
.top__cases .grid{
    width: 100%;
}
.cases dt{
    width: 100%;
    margin-bottom: 8px;
    padding: 0;
    border-bottom: 0;
}
.cases dd{
    width: 100%;
    margin-bottom: 24px;
    padding-bottom: 16px;
    border-bottom: 1px solid #ccc;
}
.top__cases .more{
    width: 88%;
    margin: 0 auto;
}
}



.cases__box .grid:nth-child(odd){
    width: 35%;
    margin-bottom: 24px;
}
.cases__box .grid:nth-child(even){
    width: 65%;
    margin-bottom: 24px;
    padding-left: 24px;
}
.cases__box dt{
/*    width: 40%;*/
    margin-bottom: 8px;
    padding: 0 8px 8px;
    border-bottom: 1px dashed #ccc;
    font-weight: 600;
}
.cases__box dd{
/*    width: 60%;*/
    margin-bottom: 16px;
    padding: 0 8px 8px;
    border-bottom: 1px solid #ccc;
}
.cases__box dt:last-of-type,
.cases__box dd:last-of-type
{
    margin-bottom: 0;
}
@media screen and (max-width: 540px) {
.cases__box .grid:nth-child(odd){
    width: 100%;
}
.cases__box .grid:nth-child(even){
    width: 100%;
    padding-left: 0;
}
.cases__box dt{
    width: 100%;
    margin-bottom: 8px;
    padding: 0;
    border-bottom: 0;
}
.cases__box dd{
    width: 100%;
    margin-bottom: 24px;
    padding-bottom: 16px;
    border-bottom: 1px solid #ccc;
}
}




.type_of_implant{
    padding: 0 0 40px;
    background: #eaeff3;
}
.type_of_implant h2{
    margin-bottom: 24px;
    padding: 64px 0 0;
    background: url("img/typeof.svg") no-repeat center 0;
    background-size: 166px auto;
    color: #1e55d0;
    font-size: 22px;
    font-weight: 600;
    text-align: center;
}
.type_of_implant h2 br{
    display: none;
}
.type_of_implant h3{
    position: relative;
    margin-bottom: 16px;
    padding-bottom: 8px;
    background-image: linear-gradient(90deg, #000 0 40px, #fff 40px);
    background-repeat: no-repeat;
    background-size: 100% 3px;
    background-position: bottom;
    color: #000;
    font-size: 20px;
    font-weight: 600;
}
.type_of_implant .fx{
    width: 100%;
    max-width: 1080px;
    margin: 0 auto;
}
.type_of_implant .grid{
    width: calc(50% - 16px);
    margin-bottom: 40px;
    padding: 40px;
    background: #fff;
}
.type_of_implant .more{
    width: 60%;
    margin: auto;
}
@media screen and (max-width: 540px) {
.type_of_implant{
    padding: 0;
    background: #eaeff3;
}
.type_of_implant h2 br{
    display: block;
}
.type_of_implant .fx{
    width: 88%;
    max-width: 540px;
    margin: 0 auto;
}
.type_of_implant .grid{
    width: 100%;
    padding: 24px 16px;
}
.type_of_implant .more{
    width: 100%;
}
}

.implant__gbr{
    padding: 80px 0;
    background: #3c54ac url("img/gbr_bg.webp") no-repeat center 0;
    background-size: 100% auto;
    background-size: cover;
    color: #fff;
}
.implant__gbr h2{
    margin-bottom: 24px;
    padding: 0;
    background: none;
    color: #fff;
    font-size: 22px;
    font-weight: 600;
    text-align: center;
}
.implant__gbr h2 br{
    display: none;
}
.gbr_inner{
    width: 100%;
    max-width: 800px;
    margin: 0 auto 40px;
    text-align: center;
}
.implant__gbr .more{
    width: 30%;
    margin: auto;
}
@media screen and (max-width: 540px) {
.implant__gbr .inner{
    width: 88%;
}
.gbr_inner{
    width: 88%;
}
.implant__gbr h2 br{
    display: block;
}
.implant__gbr .more{
    width: 88%;
    margin: auto;
}
}

.guarantee_system{
    padding: 80px 0;
    background: #4a3e28 url("img/guarantee_bg.webp") no-repeat right 0;
    background-size: 1400px auto;
    color: #24245c;
}
.guarantee_system .inner{
    width: 100%;
    max-width: 640px;
    margin: 0 auto 40px;
    background: #fff;
    text-align: center;
}
.guarantee_system .more{
    width: 30%;
    margin: auto;
}
@media screen and (max-width: 540px) {
.guarantee_system{
    background: #4a3e28 url("img/guarantee_bg.webp") no-repeat right 0;
    background-size: 100% auto;
}
.guarantee_system .inner{
    width: 88%;
    padding: 0;
}
.guarantee_system .more{
    width: 88%;
    margin: auto;
}
}


.top__device{
    padding: 80px 0;
    background: #e8f8fb;
}
.top__device h2{
    margin-bottom: 24px;
    padding: 64px 0 0;
    background: url("img/device.svg") no-repeat center 0;
    background-size: 135px auto;
    color: #1e55d0;
    font-size: 22px;
    font-weight: 600;
    text-align: center;
}
.top__device h2 br{
    display: none;
}
.top__device h3{
    margin-bottom: 16px;
    padding-bottom: 8px;
    color: #000;
    font-size: 22px;
    font-weight: 600;
}
.top__device .fx,
.top__device .fx_r{
    width: 100%;
    max-width: 1080px;
    margin: 0 auto 40px;
}
.top__device .fx_c h3{
    width: 60%;
}
.top__device .fx_c div{
    width: 40%;
}
.top__device .grid{
    width: calc(50% - 16px);
    margin-bottom: 40px;
}
.top__device .more a{
    width: 30%;
}
#ct > div:nth-child(2),
#ope > div:nth-child(2){
    padding: 0 40px;
}

/*
.top__device .grid:first-of-type{
    width: 36%;
    margin-bottom: 40px;
}
.top__device .grid:last-of-type{
    width: 64%;
    padding-left: 8px;
    margin-bottom: 40px;
}
*/
@media screen and (max-width: 540px) {
.top__device{
    padding: 40px 0;
}
.top__device h2 br{
    display: block;
}
.top__device .fx,
.top__device .fx_r{
    width: 88%;
    max-width: 540px;
    margin: 0 auto;
}
.top__device .grid{
    width: 100%;
}
.top__device .more a{
    width: 92%;
}
#ct > div:nth-child(2),
#ope > div:nth-child(2){
    padding: 0;
}
#ope > div:nth-child(2){
    margin: 0 0 24px;
}
}




.top__entries{
    padding: 80px 0 40px;
    background: #eceff2;
}
.top__entries .inner{
    width: 100%;
    max-width: 1120px;
    margin: 0 auto 40px;
    padding: 40px 0 0;
}
.top__entries .grid{
    width: calc(25% - 8px);
}
.top__entries .inner::after{
    content: "";
    display: block;
    width: calc(50% - 8px);
}
.top__entries .grid_inner{
    padding: 0 16px 24px;
}
.top__entries time{
    color: #1e55d0;
    letter-spacing: 0;
    font-size: 13px;
}
.top__entries h2{
    margin-bottom: 24px;
    padding: 64px 0 0;
    background: url("img/column.svg") no-repeat center 0;
    background-size: 150px auto;
    color: #1e55d0;
    font-size: 22px;
    font-weight: 600;
    text-align: center;
}
.top__entries .more{
    width: 30%;
    margin: 0 auto 80px;
}
@media screen and (max-width: 540px) {
.top__entries{
    padding: 40px 0;
}
.top__entries .inner{
    width: 92%;
}
.top__entries .grid{
    width: calc(50% - 4px);
}
.top__entries .more{
    width: 88%;
    margin: 0 auto;
}
}








.cv_area{
    background: #f2ede3;
    font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
.cv_area .inner{
    width: 100%;
    max-width: 1120px;
    margin: auto;
    padding: 80px 0;
    background: #f2ede3 url("../../../img/asset/common/cvbg_pc.webp") no-repeat center 0;
    background-size: 100% auto;
}
.cv_area dl{
    max-width: 748px;
    margin: 24px auto 0;
}
.cv_area .hd{
    margin-bottom: 24px;
    padding: 24px 0 0;
    background: url("../../../img/asset/hd_contact.svg") no-repeat center 0;
    background-size: 78px auto;
    font-size: 22px;
    font-weight: 600;
}
@media screen and (max-width: 540px) {
.cv_area .inner{
    background: #f2ede3 url("../../../img/asset/common/cvbg.webp") no-repeat center 0;
    background-size: cover;
}
.cv_area dl{
    width: 92%;
    max-width: 400px;
    margin: 24px auto 0;
}
.cv_area dt{
    margin-bottom: 16px;
}
}





footer{
    padding: 80px 0 0;
    background: #fff;
}
footer .inner{
    width: 100%;
    max-width: 1080px;
    margin: 0 auto 80px;
}
footer dl{
    padding: 80px 0;
}
footer dl img{
    width: 100%;
    height: auto;
}
footer .inner dt{
    width: 66%;
}
footer .inner dd{
    width: 34%;
}
footer .grid{
    text-align: left;
    font-size: 15px;
    letter-spacing: 0;
}
footer .grid:first-of-type{
    width: 49%;
}
footer .grid:last-of-type{
    width: 49%;
}
footer .grid a.external_b{
    padding-right: 24px;
}
.gmap{
    width: 100%;
    height: 400px;
}
@media screen and (max-width: 820px) {
footer .inner{
    width: 92%;
}
footer .grid{
    width: calc(50% - 16px);
}
.gmap{
    height: 400px;
}
@media screen and (max-width: 540px) {
footer{
    padding: 40px 0 0;
}
footer .grid{
    width: 100%;
}
footer .grid:first-of-type{
    width: 100%;
    margin-bottom: 24px;
}
footer .grid:last-of-type{
    width: 100%;
}
.gmap{
    height: 280px;
}
}
}


#copyright{
    padding: 16px 0;
    text-align: center;
    letter-spacing: 0;
    font-size: 12px;
}
@media screen and (max-width: 820px) {
#copyright{
    padding: 16px 0 60px;
}
}



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



.breadcrumbs{
    width: 100%;
    max-width: 1120px;
    margin: auto;
    margin-bottom: 24px;
    padding-top: 24px;
    text-align: left;
}
#wrap{
    text-align: left;
}
#wrap article{
    padding: 40px 0;
    background: #e5f4ff;
}
#wrap section,
#wrap .section,
#wrap .mw_section{
    width: 100%;
    max-width: 1120px;
    margin-right: auto;
    margin-left: auto;
}
#wrap section{
    background: #fff;
}
p{
    margin-bottom: 26px;
}
#wrap article h1{
    position: relative;
    width: 88%;
    max-width: 1120px;
    margin: auto;
    margin-bottom: 24px;
    padding: 24px;
    background: #01a4a7;
    color: #fff;
    text-align: center;
    font-size: 23px;
    font-weight: 600;
    line-height: 1.5;
}
.lead{
    margin-bottom: 32px;
    color: #024caa;
    font-size: 22px;
    font-weight: 600;
    text-align: center;
}
#wrap article h2{
    padding: 16px;
    background: #024caa;
    color: #fff;
    font-size: 21px;
    font-weight: 600;
}
#wrap article h2 a{
    color: #333;
}
#wrap article h3{
    margin-bottom: 24px;
    padding-bottom: 8px;
    border-bottom: 2px solid;
    color: #024caa;
    font-size: 19px;
    font-weight: 600;
}
#wrap article h4{
    margin-bottom: 16px;
    padding: 16px;
    background: #e5f4ff;
    color: #024caa;
    font-size: 18px;
    font-weight: 600;
}
section .block{
    padding: 40px 80px;
}
.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;
}


.tc4060,
.two_columns,
.two_block,
ol.two_columns,
.three_columns,
ol.three_columns,
.four_columns,
.five_columns
{
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
}
.three_columns::after,
ol.three_columns::after,
.three_columns_li::after
{
    content: "";
    display: block;
	width: calc( 33% - 24px);
}
.tc4060 .grid:nth-of-type(odd){
	width: 40%;
}
.tc4060 .grid:nth-of-type(even){
	width: 60%;
    padding-left: 24px;
}
.two_block .grid,
.two_block .box,
.two_columns .box,
.two_columns_li li{
	width: calc( 50% - 24px);
}
.three_columns .box,
ol.three_columns li,
.three_columns_li li{
	width: calc( 33% - 24px);
}
.four_columns .box,
.four_columns::after
{
	width: calc( 25% - 16px);
}
.four_columns::after{
    content: "";
    display: block;
}
.five_columns .box{
	width: calc( 20% - 4px);
}
.oz .imgL,
.oz .s_imgL{
    max-width: 48%;
    margin-right: 40px;
}
.oz .imgR,
.oz .s_imgR{
    max-width: 48%;
    margin-left: 40px;
}
.exclamation{
    padding-left: 32px;
    background:  url("../../../img/asset/common/svg/exclamation.svg") no-repeat 0 0;
    background-size: 22px auto;
}
.notes{
    padding: 24px;
}
.notes_beige{
    background: #faf7e6;
}
.notes_gray{
    background: #f1f1f1;
}
.notes_white{
    background: #fff;
}
.notes_pblue{
    background: #e6fafa;
}
.notes_pink{
    background: #fcefed;
}
.notes li{
    margin: 0 0 8px;
}
.notes li:last-of-type{
    margin-bottom: 0;
}
ol.numlist li{
    margin-left: 2em;
    list-style-type: decimal;
}
.merit .hd{
    padding: 16px;
    background: #f88778;
    color: #fff;
    text-align: center;
    font-size: 18px;
    font-weight: 600;
}
.demerit .hd{
    padding: 16px;
    background: #bbb9b9;
    color: #fff;
    text-align: center;
    font-size: 18px;
    font-weight: 600;
}
.merit li{
    padding-left: 28px;
    background: url("../../../img/asset/common/svg/o.svg") no-repeat 0 7px;
    background-size: 21px auto;
}
.demerit li{
    padding-left: 28px;
    background: url("../../../img/asset/common/svg/x.svg") no-repeat 0 4px;
    background-size: 21px auto;
}
.checklists li{
    padding-left: 24px;
    background: url("img/check.svg") no-repeat 0 4px;
    background-size: 16px auto;
    color: #024caa;
}
.square_list li,
.disc_list li,
.dot_list li,
.dot_list_g li{
    margin-left: 0;
}
.dot_list li{
    content: "・ ";
    padding-left: 16px;
}
.dot_list_g li{
    padding-left: 16px;
    background:  url("../../../img/asset/common/svg/dot_g.svg") no-repeat 0 9px;
    background-size: 9px auto;
}
.disc_list li::before{
    content: "・ ";
}
.square_list li::before{
    content: "▇ ";
    font-size: 10px;
}
.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;
}
.doctor_point_01{
    padding-bottom: 200px;
    background: url("../../../img/asset/common/svg/doctor_01.svg") no-repeat right bottom;
    background-size: 161px auto;
}
.doctor_point_02{
    padding-bottom: 180px;
    background: url("../../../img/asset/common/svg/doctor_02.svg") no-repeat right bottom;
    background-size: 150px auto;
}
@media screen and (max-width: 1080px) {
#wrap{
    width: 100%;
    margin-left: auto;
    margin-right: auto;
}
@media screen and (max-width: 1023px) {
#wrap section,
#wrap .section{
    width: 88%;
}
#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% - 16px);
}
@media screen and (max-width: 540px) {
.breadcrumbs{
    width: 88%;
    max-width: 88%;
    margin-bottom: 40px;
    letter-spacing: 0;
}
#wrap article h1:before {
    position: absolute;
    content: '';
    top: 0;
    left: 0;
    width: 80px;
    height: 1px;
    background: #c49834;
}
#wrap article h1:before {
    position: absolute;
    content: '';
    top: 0;
    left: calc(50% - 40px);
    width: 80px;
    height: 1px;
    background: #c49834;
}
.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,
.two_columns_li li,
.two_columns li{
    width: 100%;
}
.tc4060 .grid:nth-of-type(odd),
.tc4060 .grid:nth-of-type(even){
	width: 100%;
    padding-left: 0;
}
.two_block .grid{
    width: calc( 50% - 5px );
}
.three_columns .box,
.three_columns_li li,
ol.three_columns li{
    width: 100%;
}
}
}
}


#submv{
    padding: 80px 0;
    background: #024caa;
    color: #fff;
    font-size: 25px;
    letter-spacing: 0;
    line-height: 1.4;
    font-weight: 600;
    text-align: center;
}
#submv h1 span{
    display: block;
    font-size: 18px;
}
@media screen and (max-width: 1023px) {
#submv{
    padding: 80px 8px;
    font-size: 23px;
}
}






#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%;
}
}
}
}
}



#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: -200px;
    padding-top: 200px;
}
@media screen and (max-width: 800px) {
#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;
}
}


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




.implant__toha dt{
    margin-bottom: 16px;
    font-weight: 600;
}
.implant__toha dt::before{
    content: "● ";
    color: #024caa;
}
.implant__toha dd{
    margin-bottom: 40px;
}
.implant__anzen dt{
    margin-bottom: 16px;
    padding: 16px 0;
    background: #f9f9f9;
    border-top: 1px solid #d9dbdc;
    border-bottom: 1px solid #d9dbdc;
    text-align: center;
    font-weight: 600;
}
.implant__anzen dd{
    margin-bottom: 40px;
}
#wrap .implant__anzen div div:nth-child(4) dl dd{
    margin-bottom: 0;
}







.toggle_contents{
    padding: 0 0 8px;
}
.faqarea{
    text-align: left;
}
.toggle_title{
	position: relative;
	padding: 16px;
    background: #e5f4ff;
    color: #024caa;
    font-weight: 600;
}
.toggle_btn{
    display: none;
	position: absolute;
	top: 50%;
	right: 10px;
	transform: translateY(-50%);
	background: #024caa;
	width: 32px;
	height: 32px;
	text-indent: 100%;
	white-space: nowrap;
	overflow: hidden;
	border-radius: 50%;
    transition:all .3s linear;
}
.toggle_contents dd{
    padding: 16px 0 0;
    border: 1px solid #fff;
}
.faqarea .toggle_contents dd div:first-of-type{
    margin-bottom: 16px;
    font-weight: 600;
}
@media screen and (max-width: 800px) {
.toggle_btn{
    display: block;
}
.toggle_btn:before, .toggle_btn:after{
	display: block;
	content: '';
	background: #fff;
	position: absolute;
	width: 18px;
	height: 2px;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}
.toggle_title{
	padding: 16px 40px 16px 16px;
	cursor: pointer;
}
/*
.faqarea .toggle_title{
	padding: 16px 40px 16px 48px;
    background: #f6efe0 url("../../../img/asset/implant/faq/q.svg") no-repeat 10px 16px;
    background-size: 32px auto;
    font-weight: 600;
}
*/
.toggle_btn:before{
	width: 2px;
	height: 18px;
}
.toggle_title.selected .toggle_btn:before{
	content: normal;
}
.toggle_contents dd{
	display: none;
}
section:first-of-type .toggle_contents:first-of-type　dd{
	display: block;
}
.selected{
	display: block;
}
}

.md_area dl:first-of-type{
    margin-bottom: 40px;
}
.md_area dt{
    margin-bottom: 16px;
    padding: 16px 0;
    color: #fff;
    font-weight: 600;
    text-align: center;
}
.md_area dl div{
    margin-bottom: 8px;
    padding: 8px 0 0 24px;
}
.md_area dl:nth-child(1) div{
    background: url("img/o.svg") no-repeat 0 12px;
    background-size: 16px auto;
}
.md_area dl:nth-child(2) div{
    background: url("img/x.svg") no-repeat 0 12px;
    background-size: 16px auto;
}


.md_area dl:first-of-type dt{
    background: #ed95c0;
}
.md_area dl:last-of-type dt{
    background: #8e96a8;
}




.allon4_osusume dt{
    margin-bottom: 16px;
    font-size: 17px;
    font-weight: 600;
}
.allon4_osusume dt:before{
    content: "● ";
    color: #024caa;
}
.allon4_osusume dd{
    margin-bottom: 40px;
}
.allon4_osusume dd:last-of-type{
    margin-bottom: 0;
}


.sokujitsu_osusume li:before{
    content: "● ";
    color: #024caa;
}



.pricelist li{
    margin-bottom: 24px;
    padding: 0 16px 8px;
    border-bottom: 1px solid #ccc;
    letter-spacing: 0;
}
.pricelist li div:nth-of-type(odd){
    width: 70%;
}
.pricelist li div:nth-of-type(even){
    width: 30%;
    text-align: right;
}
.pricelist li div:nth-of-type(odd) br{
    display: none;
}
.price_ex{
    margin-bottom: 16px;
    letter-spacing: 0;
}
.price_ex dl{
    padding: 16px 8px;
    border-top: 1px solid #ddd;
}
.price_ex dd{
    font-weight: 600;
}
.price_ex .total{
    padding-top: 16px;
    border-top: 2px solid #024caa;
    text-align: right;
    font-size: 20px;
    font-weight: 600;
    color: #024caa;
}
.price_ex .total span{
    font-size: 14px;
    font-weight: 100;
    color: #000;
}
.tax{
    margin-bottom: 16px;
    font-size: 12px;
    letter-spacing: 0;
}
@media screen and (max-width: 540px) {
.pricelist{
    font-size: 14px;
    letter-spacing: 0;
}
.pricelist li{
    margin-bottom: 24px;
    padding: 0 0 8px;
    border-bottom: 1px solid #ccc;
    letter-spacing: 0;
}
.pricelist li div:nth-of-type(odd){
    width: 50%;
}
.pricelist li div:nth-of-type(even){
    width: 50%;
}
section:nth-child(3) .pricelist li:nth-child(1) div:nth-child(1){
    width: 70%;
}
section:nth-child(3) .pricelist li:nth-child(1) div:nth-child(2){
    width: 30%;
}

.pricelist li div:nth-of-type(odd) br{
    display: block;
}
}

.entry article p{
    margin: 0 !important;
    margin-bottom: 0 !important;
}
.entry article span{
    display: none;
}
.entries_block{
    width: 100%;
    max-width: 1120px;
    margin: auto;
    padding: 40px 0;
}
.entries_block .grid{
    width: calc(25% - 4px);
    margin-bottom: 40px;
}
@media screen and (max-width: 540px) {
.entries_block{
    width: 92%;
    max-width: 1120px;
    margin: auto;
}
.entries_block .grid{
    width: calc(50% - 4px);
}
}



.next_back{
    padding: 0 0 40px;
    background: #e5f4ff;
}