@charset "utf-8";
/* CSS Document */

/* ##### font ##### */

@font-face {
    font-family: 'TheSecret';
    src: url(/import/tenant_1/160.16.107.177/html/fonts/TheSecret-Regular.woff) format('woff'),
        url(/import/tenant_1/160.16.107.177/html/fonts/TheSecret-Regular.otf) format('otf'),
        url(/import/tenant_1/160.16.107.177/html/fonts/TheSecret-Regular.ttf) format('truetype');
    font-weight: normal;
    font-style: normal;
}

.f-ts {
    font-family: 'TheSecret';
}

.f-smg {
    font-family: 'Sorts Mill Goudy',
        serif;
    letter-spacing: 2px;
}

.f-yugo {
    font-family: "游ゴシック", YuGothic, Hiragino Sans, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic Pro", Hiragino Kaku Gothic ProN, "メイリオ", Meiryo, 'ＭＳ Ｐゴシック', sans-serif;
}

/* ##### font end ##### */

/* ##### reset.css上書き ##### */

body,
div,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
form,
input,
button,
p {
    color: #454545;
    font-weight: normal;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-weight: normal;
}

body {
    position: relative;
}

* {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

@media only screen and (max-width: 1024px) {}

@media only screen and (max-width: 599px) {
    .fs30 {
        font-size: 20px;
    }

    .fs16 {
        font-size: 14px;
    }

}

/* ##### reset.css上書きここまで ##### */

/* ##### 共通 ##### */

a {
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
}


#wrapper[data-element-id] {
    padding-top: 0 !important;
}

.sp-only {
    display: none;
}

.fs10 {
    font-size: 10px;
}

.fs48 {
    font-size: 48px;
}

.fs50 {
    font-size: 50px;
}

.tex {
    line-height: 30px;
}

.tc {
    text-align: center;
}

.tr {
    text-align: right;
}

.tl {
    text-align: left;
}

.mt10 {
    margin-top: 10px;
}

.mb10 {
    margin-bottom: 10px;
}

.mt20 {
    margin-top: 20px;
}

.mb20 {
    margin-bottom: 20px;
}

.mt30 {
    margin-top: 30px;
}

.mb30 {
    margin-bottom: 30px;
}

.mb50 {
    margin-bottom: 50px;
}

.mt50 {
    margin-top: 50px;
}

.pad50 {
    padding: 50px 0;
}

.pt50 {
    padding-top: 50px;
}

.pb50 {
    padding-bottom: 50px;
}

.mt80 {
    margin-top: 80px;
}

.mb80 {
    margin-bottom: 80px;
}

.mauto {
    margin: 0 auto;
}

.z1 {
    position: relative;
    z-index: 1;
}

.ctex {
    position: absolute;
    top: 50%;
    left: 50%;
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    margin: 0;
    padding: 0;
    z-index: 1;
}

.Blink a {
    display: block;
}

.more {
    text-align: center;
    margin: 50px auto 0 auto;
    width: 100%;
    max-width: none;
    border: solid 1px #939897;
}

.more a {
    display: block;
    padding: 10px 20px;
    background: unset;
    color: #454545;
    position: relative;
    width: 100%;
    height: 100%;
}
[data-element-id] .more a {
  width: auto;
  height: auto;
}

.more.arrow a:hover:after {
    right: 10px;
}

.more.arrow a:after {
    position: absolute;
    background: url(/import/tenant_1/160.16.107.177/html/images/09_tr_white/arrow.png) no-repeat;
    content: "";
    top: 43%;
    right: 25px;
    width: 56px;
    height: 7px;
    z-index: 2;
    -webkit-transition: all 0.5s;
    transition: all 0.5s;
    background-size: contain;
}

.more.back-arrow a:after {
    position: absolute;
    content: "";
    background: url(/import/tenant_1/160.16.107.177/html/images/17_blog/arrow.png) no-repeat;
    width: 60px;
    height: 6px;
    left: 60px;
    top: 43%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
    -webkit-transition: all 0.5s;
    transition: all 0.5s;
    background-size: contain;
}

.more.back-arrow a:hover:after {
    left: 40px;
}


.bgimg {
    position: absolute;
    top: 0;
    left: 50%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
    width: 100%;
    height: 100%;
}

.bgimg img {
    width: 100%;
    height: 100% !important;
    -o-object-fit: cover;
    object-fit: cover;
}

.of_img {
    width: 100%;
    overflow: hidden;
    height: 100%;
}

.of_img img {
    width: auto !important;
    height: 100% !important;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: center center;
    object-position: center center;
    font-family: 'object-fit: cover; object-position: center center;';
}


.ofimg {
    width: 100%;
    overflow: hidden;
}

.ofimg img {
    width: 100%;
    height: 100% !important;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: center center;
    object-position: center center;
    font-family: 'object-fit: cover; object-position: center center;';
}

.of {
    position: relative;
}

.of:before {
    content: "";
    display: block;
}

.of img {
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
}

.of15:before {
    padding-top: 15%;
}

.of20:before {
    padding-top: 20%;
}

.of25:before {
    padding-top: 25%;
}

.of30:before {
    padding-top: 30%;
}

.of35:before {
    padding-top: 35%;
}

.of40:before {
    padding-top: 40%;
}

.of45:before {
    padding-top: 45%;
}

.of48:before {
    padding-top: 48%;
}


.of50:before {
    padding-top: 50%;
}

.of55:before {
    padding-top: 55%;
}

.of60:before {
    padding-top: 60%;
}

.of65:before {
    padding-top: 65%;
}

.of70:before {
    padding-top: 70%;
}

.of74:before {
    padding-top: 74%;
}

.of75:before {
    padding-top: 75%;
}

.of80:before {
    padding-top: 80%;
}

.of85:before {
    padding-top: 85%;
}

.of90:before {
    padding-top: 90%;
}

.of95:before {
    padding-top: 95%;
}

.of100:before {
    padding-top: 100%;
}

.of105:before {
    padding-top: 105%;
}

.of110:before {
    padding-top: 110%;
}

.of115:before {
    padding-top: 115%;
}

.of120:before {
    padding-top: 120%;
}

.c-w {
    color: #fff;
}

.c-gr {
    color: #2bb397;
}

.bg-green {
    background: #e2ebe9;
}

.bg-w {
    background: #fff;
}

.db {
    display: block;
}

.texY {
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
}

.circle.pic span {
    border-radius: 50%;
}

.reverse {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -webkit-flex-direction: row-reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
}

.c {
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
}

.cc {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
}

.row2 {
    width: 48%;
    margin: 0 1% 6%;
}

.row3 {
    width: 31.333%;
    margin: 0 1% 6%;
}

.row4 {
    width: 23%;
    margin: 0 1% 6%;
}

.row5 {
    width: 18%;
    margin: 0 1% 6%;
}

.w20 {
    width: 20%;
}

.w75 {
    width: 75%;
}

.w90 {
    width: 90%;
}

.w80 {
    width: 80%;
}

@media only screen and (max-width: 1024px) {
    .sp-only {
        display: block;
    }

    .pc-only {
        display: none;
    }

    .tex.tc {
        text-align: left;
    }

    .more.arrow a:after {
        width: 30px;
    }
}

@media only screen and (max-width: 599px) {
    .mb80 {
        margin-bottom: 50px;
    }

    .row2 {
        width: 98%;
        margin: 0 1% 10%;
    }

    .row3 {
        width: 48%;
        margin: 0 1% 10%;
    }

    .row4 {
        width: 48%;
        margin: 0 1% 10%;
    }

    .row5 {
        width: 31.333%;
        margin: 0 1% 10%;
    }

    .w75 {
        width: 100%;
    }

    .sp-c {
        text-align: center;
    }

    .w90 {
        width: 100%;
    }

    .w20 {
        width: 90%;
        margin: 50px auto;
    }

    .of_img img {
        width: 100% !important;
        height: auto !important;
    }

}

/* ##### 共通ここまで ##### */

/* ##### header ##### */
.logo h1 {
    font-size: 12px;
    font-weight: normal;
    display: block;
}

h1[data-element-id] {
    display: block;
}

/* ##### header ##### */

header {
    position: absolute;
    left: 0;
    top: 0;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    z-index: 10;
    width: 100%;
}

.header01 {
    /* max-width: 1360px; */
    margin: auto;
}

.header01in {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    padding-bottom: 10px;
}

.header01 .logo {
    margin-right: auto;
}

.logo {
    width: 500px;
    height: auto;
    margin-top: 20px;
    padding: 0 20px;
}

.logo h1 {
    font-size: 12px;
    font-weight: normal;
    display: block;
}

.logo .sp {
    display: none;
}

h1[data-element-id] {
    display: block;
}

.header-info {
    width: 333px;
    background: #fff;
    padding: 10px 20px;
}

.header-info .t-box span {
    font-size: 11px;
}

/**/
table.time-tagle {
    width: 100%;
    margin-bottom: 5px;
}

table.time-tagle,
.time-tagle td,
.time-tagle th {
    border-collapse: collapse;
    font-size: 11px;
    color: #4f4f4f;
}

.time-tagle td,
.time-tagle th {
    padding: 3px 0;
    border-bottom: 1px solid #b9b9b9;
    letter-spacing: 1px;
}

.time-tagle th {
    width: 30%;
}

.time-tagle td {
    width: 10%;
}

.foot-fix {
    display: none;
}

.foot-fix .ul_dot {
  padding-bottom: 5px;
}

[data-element-id] .foot-fix {
    display: block;
    width: 300px;
}

@media only screen and (max-width: 1024px) {

    .header-info {
        width: 302px;
        padding: 5px 10px 10px 10px;
    }

    .header-info .time-tagle {
        width: calc(100% - 50px);
        margin-right: auto;
    }

    .logo {
        padding: 10px 20px;
    }

    .foot-fix {
        display: block;
        position: fixed;
        right: 10px;
        bottom: 2%;
    }

    .foot-fix dl {
        background: #fff;
        padding: 10px 10px;
    }
    .foot-fix dl.Btype {
        background: rgba(199, 235, 227, 1);
    }

    .foot-fix dt,
    .foot-fix dd {
        font-size: 12px;
        text-align: center;
        margin-bottom: 10px;
    }

    .foot-fix dd+dd {
        margin-bottom: 0;
    }

    .foot-fix dt,
    .foot-fix dd img {
        margin-right: 10px;
    }
}

@media only screen and (max-width: 599px) {
    header {
        position: relative;
    }

    .header01in {
        -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

    .logo {
        width: 100%;
        padding: 0;
        margin-bottom: 30px;
    }

    .logo .pic {
        display: block;
        max-width: 220px;
        margin: auto;
    }

    .logo .sp {
        display: block;
    }

    .logo .pc {
        display: none;
    }

    .header-info {
        width: 100%;
        display: block;
        width: 320px;
        margin: auto;
    }

    .header-info .time-tagle {
        width: 300px;
        margin: auto;
    }

    .foot-fix {
        right: 0;
        bottom: 0;
        width: 100%;
    }

    .foot-fix dt,
    .foot-fix dd {
        font-size: 10px;
    }
}

/* ##### header end ##### */

/* ##### nav ##### */
#gnav {
    padding: 20px 0;
    border-bottom: 2px solid #f6f6f6;
}

#gnav .toggle {
    background: #4f4f4f;
}

#gnav li {
    display: inline-block;
}

#dropmenu {
    width: 100%;
    margin-top: 10px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    margin: auto;
    max-width: 1000px;
}

#dropmenu[data-element-id] {
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

#dropmenu li a {
    letter-spacing: 1px;
    font-size: 16px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    padding: 20px 10px;
    position: relative;
}

#dropmenu li a:after {
    content: "";
    position: absolute;
    background: url(/import/tenant_1/160.16.107.177/html/images/01_index/maru.png) no-repeat;
    width: 6px;
    height: 5px;
    right: -10px;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
}

#dropmenu li.nomark a:after,
#dropmenu li.tel-box a:after {
    content: none;
}

#dropmenu li.index-link span {
    display: none;
}

#dropmenu span.drop-btn {
    letter-spacing: 1px;
    font-size: 16px;
    display: block;
    text-align: left;
    border: none;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    position: relative;
}

.dropmenu {
    *zoom: 1;
}

.dropmenu .dropdown {
    position: relative;
}

#dropmenu .dropdown:hover {
    cursor: pointer;
}

.dropmenu .dropdown ul {
    position: absolute;
    z-index: 9999;
    top: 100%;
    left: 0;
    width: 100%;
    display: block;
    padding-top: 20px;
}

#dropmenu[data-element-id] .dropdown ul li {
    overflow: visible;
    height: 45px;
}

#dropmenu .dropdown ul li {
    overflow: hidden;
    width: 100%;
    height: 0;
    -webkit-transition-property: all;
    -webkit-transition: 0.3s linear;
    transition-property: all;
    transition: 0.3s linear;
}

#dropmenu .dropdown ul li a {
    display: block;
    color: #000;
    width: 240px;
    height: 100%;
    padding: 10px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    background: #fff;
}

#dropmenu .dropdown ul li a:after {
    content: none;
}

#dropmenu .dropdown:hover ul li {
    overflow: visible;
    height: 45px;
    width: 200px;
}

.sab-nav {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 200px;
}

.sab-nav li a {
    width: 100%;
}

#dropmenu .sp-only {
    display: none;
}

#dropmenu[data-element-id] .sp-only {
    display: block;
}

#gnav.fixed {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 200;
    background: #fff;
    padding: 10px 0;
    -webkit-box-shadow: 0px 4px 2px -2px rgba(0, 0, 0, 0.2);
    box-shadow: 0px 4px 2px -2px rgba(0, 0, 0, 0.2);
}

#gnav.fixed[data-element-id] {
    position: static !important;
}

#dropmenu li.tel-box {
    background: rgba(255, 255, 255, 1);
    margin-top: -45px;
    position: relative;
    z-index: 10;
    padding: 10px;
}

#dropmenu li.tel-box dt,
#dropmenu li.tel-box dd {
    font-size: 10px;
    text-align: center;
}

#dropmenu li.tel-box .ul_dot {
    margin-top: 5px;
    margin-bottom: 5px;
    padding-bottom: 5px;
    display: inline-block;
}

#dropmenu li.tel-box .ul_dot img {
    margin-right: 10px;
}

#gnav.fixed #dropmenu li.tel-box {
    margin-top: 0;
    padding: 0 10px;
}

#gnav.fixed #dropmenu {
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
}



@media only screen and (max-width: 1024px) {

    #gnav {
        width: 100%;
        border-bottom: none;
    }

    #gnav .accordion-body {
        background: rgba(226, 235, 233, 1);
    }

    #gnav.action .accordion-body {
        width: 60%;
        margin-left: 40%;
    }


    #gnav .accordion-inner {
        height: 100vh;
    }

    .accordion-inner .sns li {
        display: inline-block;
    }

    #dropmenu {
        display: block;
        padding-bottom: 80px;

    }
    #gnav li {border-bottom: 1px solid #333;}

/*     #gnav ul li a {
    color: #fff;
} */

    #gnav ul li span {
        height: auto;
       background-color: rgba(255, 255, 255, 0.2);
        display: block;
        padding: 10px;
    }

    .dropmenu .dropdown ul {
        padding-top: 0;
        position: static;
        background-color: rgba(78, 69, 64, 0);
    }

    #dropmenu .dropdown ul li {
        overflow: visible;
        height: auto;
        padding-left: 30px;
    }

    #dropmenu .dropdown ul li:last-of-type {
        border-bottom: none;
    }

    #dropmenu .dropdown ul li a {
      width: 100%;
        background-color: rgba(78, 69, 64, 0);
/*         color: #fff;
 */    }

    #dropmenu li.index-link img {
        display: none;
    }

    #gnav ul li.index-link span {
        display: block;
        background: none;
    }

/*     #dropmenu span.drop-btn {
    color: #fff;
}
 */
 #dropmenu span.drop-btn a {
   padding: 0;
 }
    #dropmenu span.drop-btn:after {
        content: none;
    }

    #dropmenu .dropdown:hover ul li {
        height: auto;
        width: 100%;
    }

    #gnav.fixed {
        background: none;
        -webkit-box-shadow: none;
        box-shadow: none;
        padding: 0;

    }

    #gnav {
        padding: 0;
    }

    #dropmenu .sp-only {
        display: block;
    }

    #dropmenu li a::after {
        display: none;
    }

    #dropmenu li.tel-box a {
        color: #454545;
    }

    #gnav.action #dropmenu li.tel-box dl {
        margin: auto;
        padding: 10px;
        width: 300px;
        background: rgba(255, 255, 255, 1);
    }

    #gnav.action #dropmenu li.tel-box {
        margin: 50px auto;
        background: unset;
        padding: 0;
        border-bottom: none;
    }
    #gnav #dropmenu li.tel-box .ul_dot a {
      display: inline-block;
      padding: 0;
    }
        #gnav ul li span {
       background-color: rgba(255, 255, 255, 0.5);
    }
}

@media (max-width: 599px) {
    #gnav.action .accordion-body {
        width: 100%;
        margin-left: 0;
    }
}

/* ##### nav end ##### */

/* ##### footer ##### */
footer {
    background: #e3e3e3;
    padding-bottom: 50px;
    overflow: hidden;
}

footer * {
    color: #787872;
}

footer .inner {
    position: relative;
}

footer .footimg {
    max-width: 360px;
    right: -200px;
    bottom: -45px;
    position: absolute;
}

.footinfo {
    width: 31%;
}

.footinfo .pic {
    max-width: 235px;
    margin-bottom: 20px;
}

.footinfo dl * {
    font-size: 12px;
}

.footinfo dl {
    margin-bottom: 30px;
}

.footinfo dl dt {
    margin-bottom: 5px;
}

.footinfo .header-info {
    background: unset;
    padding: 0;
    margin-bottom: 20px;
    width: 100%;
}

.footinfo .header-info table {
    border-top: 2px solid #adadaa;
}

.footnav {
    -webkit-align-self: flex-end;
    -ms-flex-item-align: end;
    align-self: flex-end;
    width: 55.5%;
    position: relative;
    z-index: 5;
}

.footnav li {
    font-size: 12px;
    margin: 20px 0;
}

.footnav li.f-navimg {
  max-width: 325px;
}

.footnav .copy {
    margin-top: 30px;
    font-size: 10px;
}

footer .map:after {
    padding-top: 70%;
}

@media only screen and (max-width: 1024px) {
  footer {
    padding-bottom: 100px;
}
    footer .footimg {
        right: -63px;
    }

    .footnav {
        width: 100%;
        margin-top: 50px;
    }

    .footnav ul {
        width: 48%;
    }

    .footinfo {
        width: 100%;
    }

    .footinfo .pic {
        margin: 0 auto 30px;
    }

    .footinfo dl * {
        text-align: center;
        font-size: 14px;
    }

    .footinfo dl dt {
        margin-bottom: 15px;
    }

    .footinfo dl dd.tel a {
        font-size: 20px !important;
    }

    footer .map:after {
        padding-top: 40%;
    }

    .footinfo .header-info table {
        width: 100%;
    }
    
    .footinfo .time-tagle td, .footinfo .time-tagle th, .footinfo .header-info .t-box span {
    line-height: unset;
}

}

@media only screen and (max-width: 599px) {
    .footnav li {
        font-size: 10px;
    }footer .map:after {
    padding-top: 80%;
}
     .time-tagle td, .time-tagle th, .header-info .t-box span {
    line-height: unset;
}

}

/* ##### footer end ##### */

/* ##### top ##### */
.main-content {
    margin-top: 80px;
}

.sub {
    display: block;
    line-height: 0;
    margin-top: 10px;
    color: #2bb397;
    font-size: 12px;
}

.itlic {
    font-style: italic;
}

.tit02 {
    font-size: 50px;
    color: #2bb397;
}

.bg_blue {
    background: #8599b3;
}

.bg_gry {
    background: #e7ebe6;
}

/* トップメインイメージ */
.mainimg {
    position: relative;
}

.mainimg .uk-slidenav-position:after {
    padding-top: 55%;
}

@media (max-width: 1024px) {
    .mainimg .uk-slidenav-position:after {}

    .tit02 {
        font-size: 40px;
    }
}

@media (max-width: 599px) {
    .mainimg .uk-slidenav-position:after {}
}

.mainimg .uk-slideshow {
    width: 100%;
}

/*top-news*/
.top-news {
    position: absolute;
    bottom: 20px;
    left: 50%;
    -webkit-transform: translatex(-50%);
    -ms-transform: translatex(-50%);
    transform: translatex(-50%);
}

.top-news .in {
    width: 580px;
    background: #fff;
    border-radius: 25px;
    padding: 10px 20px 10px 10px;
}

.top-news h3 {
    border-right: 1px dotted #d0c9c2;
    padding: 0 15px 0 10px;
    margin-bottom: 0;
    letter-spacing: 1px;
}

.top-news dl {
    width: auto;
    padding-bottom: 5px;
}

.top-news dt {
    width: 80px;
    padding-left: 10px;
}

.top-news dd.tit {
    display: inline-block;
    width: 74%;
    margin-left: 0;
    padding-left: 10px;
    box-sizing: border-box;
}

.top-news .more {
    text-align: center;
    margin: 0;
    width: 76px;
}

.top-news .more a {
    display: block;
    background: #8599b3;
    color: #fff;
    padding: 2px 0;
    font-size: 10px;
}

/* top-clinic */

.gallery .main-image {
    width: 100%;
}

.gallery ul {
    width: 100%;
    max-width: 385px;
    margin-left: auto;
    margin-top: -15px;
    position: relative;
    z-index: 5;
    margin-right: 10px;
}

.gallery .thumb-img {
    width: calc(33.33333% - 10px);
    -webkit-transition: 0.3s linear;
    transition: 0.3s linear;
    border: 2px solid #fff;
}

.gallery .thumb-img:nth-of-type(2) {
    margin: 0 10px;
}

.gallery .thumb-img:hover {
    cursor: pointer;
    opacity: 0.8;
}

.top-clinic .t-box {
    position: relative;
}

.top-clinic .t-box:after {
    position: absolute;
    content: "";
    width: 130%;
    height: 105%;
    right: 0;
    top: 50px;
    background: #e2ebe9;
    z-index: -1;
}

.top-clinic .t-box .in {
    width: 98%;
    max-width: 500px;
    padding-right: 10px;
    margin-right: auto;
}

.top-clinic .t-box .more {
    max-width: 360px;
    margin: 50px 0 0;
}

/*top-list*/

.top-list.inner {
    padding: 150px 0 0;
}

.top-list li {
    margin: 0 1% 6%;
}

.top-list li:nth-of-type(-n+2) {
    width: 47%;
}

.top-list li:nth-last-of-type(-n+3) {
    width: 31%;
}

.top-list li h4 {
    position: relative;
    z-index: 5;
    padding-left: 10px;
    text-shadow: #fff 1px 1px 10px,
        #fff -1px 1px 10px,
        #fff 1px -1px 10px,
        #fff -1px -1px 10px;
}

.top-list li .img {
    position: relative;
    margin-top: -65px;
    margin-bottom: 20px;
}

.top-list li .img span {
    display: block;
}

.top-list li .img:after {
    position: absolute;
    content: "";
    width: 100%;
    height: 100%;
    background: #8599b3;
    z-index: -1;
    left: 5px;
    top: 5px;
}

.top-list li .no {
    width: 50px;
    border-right: 1px dotted #d0d0d0;
    display: block;
}

.top-list li .no .db {
    font-size: 11px;
    letter-spacing: normal;
}

.top-list li .tit {
    display: block;
    width: calc(100% - 70px);
    margin-left: 20px;
}

.top-list li dt {
    margin-bottom: 10px;
}

.top-list li .tex {
    line-height: normal;
}

.top-list li .more {
    margin: 20px auto;
}

/*top-promise*/

.iconbox .icon {
    margin-bottom: 40px;
    position: relative;
}

.iconbox .icon:after {
    position: absolute;
    content: "";
    border: 1px dotted #d0d0d0;
    width: 100%;
    left: 0;
    top: 50%;
    -webkit-transform: rotateY(-50%);
    transform: rotateY(-50%);
    z-index: -1;
}

.iconbox .icon .pic {
    width: 50px !important;
    background: #fff;
    margin: auto;
    padding: 0 10px;
}

.iconbox .icon .pic img {
    width: auto;
}

.top-promise .sen {
    position: relative;
    padding-bottom: 20px;
}

.top-promise .sen:after {
    position: absolute;
    content: "";
    background: url(/import/tenant_1/160.16.107.177/html/images/01_index/tensen.png) no-repeat;
    width: 4px;
    height: 15px;
    left: 50%;
    top: 100%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
}

.top-promise ul {
    margin-top: 50px;
}

.top-promise li {
    background: #8599b3;
    width: 178px;
    height: 178px;
    border-radius: 50%;
    position: relative;
    margin: 0 1% 6%;
}

.top-promise li .in {
    margin: 5px;
    border-radius: 50%;
    border: 1px solid #fff;
}

.top-promise li .pic {
    max-width: 57px;
    height: 55px;
    margin: auto;
    text-align: center;
}

.top-promise li .pic img {
    width: auto;
    margin: auto;
    text-align: center;
}

.top-promise li .in:before {
    content: "";
    display: block;
    padding-top: 0;
    /* 高さを幅の75%に固定 */
}

.top-promise li .in {
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
}

.top-promise li .in dd {
    text-align: center;
    margin-top: 5px;
}

.top-promise .more {
    margin-top: 0;
}

/*top-flow*/
.top-flow ul {
    margin-top: 50px;
    /* align-items: baseline; */
}

.top-flow li {
    width: 17.55555%;
    border: 1px solid #808080;
    text-align: center;
    position: relative;
    background: #fff;
    float: left;
}

.top-flow li+li {
    margin: 0 1.2%;
}

.top-flow li .in {
    padding: 20px 10px;
    position: relative;
    width: 100%;
    height: 100%;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
}

.top-flow li:after {
    position: absolute;
    content: "";
    width: 100%;
    height: 100%;
    background: #8599b3;
    left: 5px;
    top: 5px;
    z-index: -1;
}

.top-flow li .no {
    position: absolute;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: 1px solid #808080;
    background: #fff;
    left: -15px;
    top: -15px;
}

.top-flow li .in:before {
    position: absolute;
    content: "";
    border-bottom: 1px dotted #d0d0d0;
    height: 1px;
    top: 50%;
    left: 100%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    width: 100%;

}

.top-flow li:nth-of-type(1) {
    margin: 0 1.2%;
}

.top-flow li:nth-of-type(2) .in:before {
    top: 30%;
    -webkit-transform: none;
    -ms-transform: none;
    transform: none;
}

.top-flow li:nth-of-type(3) .in:after {
    position: absolute;
    content: "";
    border-bottom: 1px dotted #d0d0d0;
    height: 1px;
    width: 200%;
    left: -50%;
    top: 140%;
    z-index: -1;
}

.top-flow li:nth-of-type(5) .in:before {
    content: none;
}


/*top-child*/
.top-child {
    margin-top: 80px;
}

.top-child .inner {
    margin-top: -130px;
    position: relative;
    z-index: 5;
}

.top-child .t-box {
    background: #fff;
    position: relative;
    z-index: 5;
    padding-right: 40px;
}

.top-child .t-box:before {
    position: absolute;
    content: "";
    width: 100%;
    height: 100%;
    left: -50px;
    top: 0;
    background: #fff;
    z-index: -1;
}

.top-child .t-box h3 {
    margin-top: -40px;
    margin-bottom: 30px;
}

.top-child .itembox h3 {
    text-decoration: underline;
    display: inline-block;
    width: 70px;
}

.top-child .itembox .pointbox {
    width: calc(100% - 100px);
    margin-top: 130px;
}

.top-child .itembox li {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    border-bottom: 1px solid #d0d0d0;
    padding-bottom: 10px;
}

.top-child .itembox li .pic {
    margin-bottom: 10px;
}

.top-child .itembox li .pic img {
    width: auto;
}

.top-child .itembox li dd {
    text-align: center;
    font-size: 13px;
}

/*top-elmo*/

.top-elmo dl {
    position: absolute;
    left: 50%;
    top: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}

.top-elmo dl {
    width: 356px;
    padding: 30px;
    background: #fff;
}

.top-elmo dl dt .pic {
    margin: 10px 0;
    display: block;
}

.top-elmo dl dd.more {
    margin: 30px 0 0;
}

.top-faq {
    border-top: 1px solid #7f7f7f;
    border-bottom: 1px solid #7f7f7f;
}

.faqlist dl {
    border-bottom: 1px dotted #d0d0d0;
    margin-bottom: 25px;
    padding-bottom: 25px;
}

.faqlist dl dt {
    font-size: 18px;
    color: #5fb29c;
    padding-left: 1em;
    text-indent: -1em;
    margin-bottom: 10px;
}

.faqlist dl dt .q {
    margin-right: 5px;
}

.faqlist dl:last-of-type {
    border-bottom: none;
}

.faqlist dl dd {
    padding-left: 1.5em;
}

.bannerbox {
    margin-bottom: 50px;
}

.bannerbox .t-box {
    width: 38%;
    padding: 30px;
    background: #7c928f;
}

.bannerbox .t-box * {
    color: #fff;
}

.bannerbox .ofimg {
    width: 62%;
}

.bannerbox .t-box .tex {
    line-height: normal;
}

.bannerbox .more {
    margin: 30px auto 0 auto;
    border: solid 1px #fff;
}

.bannerbox .more.arrow a:before {
    border-bottom: 5px solid #fff;
}

.bannerbox .more.arrow a:after {
    background: url(/import/tenant_1/160.16.107.177/html/images/01_index/arow_w.png) no-repeat;
    background-size: contain;
}

/*top-blog*/

.top-blog h3 span {
    border-left: 1px dotted #d0d0d0;
    margin-left: 20px;
    padding-left: 20px;
}

.top-blog li a {
    display: block;
}

.top-blog li dl {
    margin-top: 10px;
}

.top-blog li dt p span {
    color: #5fb29c;
    font-size: 12px;
    padding-left: 5px;
}

.top-blog li dt p span.category {
    margin-left: 5px;
}

.top-blog li dt span.category {
    font-size: 12px;
}

.top-blog li dd {
    margin-top: 10px;
    text-decoration: underline;
}

/*top-elmo*/

.top-recruit {
    margin: 50px auto;
}

.top-recruit.top-elmo dl {
    position: absolute;
    left: unset;
    right: 10%;
    top: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(0, -50%);
}

@media only screen and (max-width: 1024px) {
    .main-content {
        margin-top: 80px;
    }

    .top-news .in {
        width: 555px;
    }

    .top-clinic.flexb {
        width: 100%;
        max-width: none;
    }
.top-child .of25:before {
    padding-top: 40%;
}
.top-child .inner {
    margin-top: -80px;}
.top-child .itembox li dd br {
  display: none;
}
    .top-list.inner {
        padding: 150px 0 50px;
    }

    .top-list li h4 {
        font-size: 32px;
    }

    .top-list li {
        width: 47% !important;
    }

    .top-flow li {
        width: 15.55555%;
    }

    .top-flow li .in {
        font-size: 10px;
    }

    .top-flow li:nth-of-type(3) .in:after {
        top: 120%;
    }

    .top-flow li+li {
        margin: 0 2.2%;
    }

    .top-flow li:nth-of-type(1) {
        margin: 0 2.2%;
    }

    .top-child .itembox {
        margin-top: -100px;
    }

    .top-child .itembox h3 {
        margin-bottom: 0;
        text-shadow:
          #fff 1px 1px 10px, #fff -1px 1px 10px,
    #fff 1px -1px 10px, #fff -1px -1px 10px;
    }

    .top-child .itembox .pointbox {
        width: 100%;
        margin-top: 0px;
    }

    .top-child .t-box h3 {
        margin-top: -27px;
    }

    .top-elmo dl .pic img {
        width: 90%;
    }

    .top-elmo dl {
        width: 280px;
        padding: 15px;
    }

    .bannerbox .t-box {
        width: 100%;
    }

    .bannerbox .ofimg {
        width: 100%;
    }

    .bannerbox .of50:before {
        padding-top: 70%;
    }

    .top-blog li.row4 {
        width: 48%;
    }

    .top-blog h3 {
        text-align: center;
    }

    .top-blog h3 span {
        border-left: none;
        margin-left: 0;
        padding-left: 0;
        text-align: center;
        display: block;
    }

    .top-recruit.top-elmo .of40:before {
        padding-top: 55%;
    }

}

@media only screen and (max-width: 599px) {
    .main-content {
        margin-top: 20px;
    }

    .top-news {
        position: relative;
        bottom: unset;
        left: unset;
        -webkit-transform: none;
        -ms-transform: none;
        transform: none;
    }

    .top-news .in {
        width: 100%;
    }

    .top-news h3 {
        border-right: none;
        width: 100%;
        text-align: center;
        padding: 0 15px 0 10px;
        font-size: 20px;
        margin-bottom: 20px;
    }.top-news dt {
    padding-left: 0;
}

    .top-news dd.tit {
        width: 100%;
        padding-left: 0;
    }

    .top-news .more {
        margin: 30px auto 0;
        width: 150px;
    }

    .top-news .more a {
        padding: 10px 0;
        font-size: 14px;
    }

    .top-news dl {
        width: 100%;
    }

 .gallery ul {
   padding-left: 10px;
 }

    .top-flow li {
        width: 95%;
        margin-bottom: 30px !important;
        margin-left: auto !important;
        float: none;
    }

    .top-flow li:nth-of-type(3) {
        width: 50%;
    }

    .heightLine-flow,
    .heightLine-gra {
        height: auto !important;
    }

    .top-flow li .in {
        font-size: 12px;
    }

    .top-child .itembox {
        margin-top: -50px;
    }

    .top-child .itembox h3 {
        margin-bottom: 50px;
        -webkit-writing-mode: unset;
        -ms-writing-mode: unset;
        writing-mode: unset;
    }

    .top-flow li:nth-of-type(3) .in:after {
        content: none;
    }

    .top-flow li:before {
        content: "";
        position: absolute;
        width: 1px;
        height: 150%;
        border-left: 1px dotted #d0d0d0;
        z-index: -1;
        left: 50%;
        top: 50%;
        -webkit-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
        transform: translateX(-50%);
    }

    .top-flow li:nth-of-type(5):before,
    .top-flow li .in:before {
        content: none;
    }

    .top-flow li:nth-of-type(2):before {
        left: 20%;
        height: 200%;
    }

    .top-flow li:nth-of-type(3):before {
        height: 250%;
        top: -50%;
    }

    .top-child .itembox h3 {
        width: 100%;
    }

    .top-child .t-box {
        padding-right: 0;
    }

    .top-child .t-box h3 {
        margin-top: 0;
        text-align: center;
    }

    .top-child .t-box h4 {
        text-align: center;
    }

    .top-clinic .t-box .in {
        margin: 10px;
    }

    .top-child .inner {
        margin-top: -20px;
    }

    .top-list li {
        width: 100% !important;
    }

    .heightLine-tex {
        height: auto !important;
    }

    .top-elmo dl {
        position: relative;
        top: unset;
        left: unset;
        -webkit-transform: none;
        -ms-transform: none;
        transform: none;
        margin: auto;
        width: 100%;
    }

    .top-elmo dl dt .pic {
        margin: auto;
    }

    .top-recruit.top-elmo dl {
        position: relative;
        left: unset;
        right: unset;
        top: unset;
        -webkit-transform: none;
        -ms-transform: none;
        transform: none;
    }

    .top-recruit.top-elmo .of40:before {
        padding-top: 40%;
    }

    .bannerbox .t-box {
        padding: 20px 10px;
    }

}


/* ##### トップここまで ##### */

/* ##### 下層ページ共通 ##### */

.ul_dot {
    border-bottom: 1px dotted #d0d0d0;
}

.subtit h2 {
    font-size: 48px;
    position: absolute;
    left: 50%;
    top: 50%;
    text-shadow: #fff 2px 0px 2px,
        #fff -2px 0px 2px,
        #fff 0px -2px 2px,
        #fff -2px 0px 2px,
        #fff 2px 2px 2px,
        #fff -2px 2px 2px,
        #fff 2px -2px 2px,
        #fff -2px -2px 2px,
        #fff 1px 2px 2px,
        #fff -1px 2px 2px,
        #fff 1px -2px 2px,
        #fff -1px -2px 2px,
        #fff 2px 1px 2px,
        #fff -2px 1px 2px,
        #fff 2px -1px 2px,
        #fff -2px -1px 2px,
        #fff 1px 1px 2px,
        #fff -1px 1px 2px,
        #fff 1px -1px 2px,
        #fff -1px -1px 2px;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}

.b-shado {
    position: relative;
}

.b-shado:after {
    position: absolute;
    content: "";
    width: 100%;
    height: 100%;
    background: #8599b3;
    z-index: -1;
    left: 5px;
    top: 5px;
}

.indent {
    padding-left: 1em;
    text-indent: -1em;
}

.bl-gr {
    border-left: 5px solid #2bb397;
    padding-left: 20px;
}

.marker-c20 {
    background: -webkit-gradient(linear, left top, left bottom, color-stop(65%, transparent), color-stop(65%, rgba(250, 250, 99, 1)));
    background: -webkit-linear-gradient(transparent 65%, rgba(250, 250, 99, 1) 65%);
    background: linear-gradient(transparent 65%, rgba(250, 250, 99, 1) 65%);
}

@media only screen and (max-width: 1024px) {
    .subtit h2 {
        font-size: 30px;
    }
    .subtit .of35:before {
    padding-top: 50%;
}
}

@media only screen and (max-width: 599px) {
    .subtit h2 {
        font-size: 20px;
    }

    h3.fs32 {
        font-size: 20px;
    }    .subtit .of35:before {
    padding-top: 35%;
}

}

/* ##### 下層ページ共通ここまで ##### */

/* ##### ブログ共通 ##### */
.one-line {
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    display: block;
}

.blog-list .category span {
    display: inline-block;
    font-size: 10px;
    border: #c9c9c9 solid 1px;
    background: #fff;
    padding: 3px 15px;
    color: #555;
    margin: 0 5px 10px 0;
}

.blog-list li .more {
    margin: 20px auto 0;
}

.side {
    width: 23%;
}

.side-nav {
    margin-bottom: 50px;
    width: 100%;
}

.side-nav dt h4 {
    background: #8599b3;
    color: #fff;
    text-align: center;
    padding: 20px 0;
    margin-bottom: 0;
}

.news .side-nav dt h4 {
    background: #7c928f;
}

.side-nav dd a {
    padding: 10px 0;
    font-size: 16px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    display: block;
    color: #686868;
    text-align: center;
    border-bottom: 1px solid #737373;
}

/*ページャー*/
.pagenav {
    padding-top: 30px;
}

.pagenav li {
    margin: 0 5px;
}

.pagenav li a {
    display: inline-block !important;
    width: 40px;
    line-height: 20px;
    text-align: center;
    font-size: 20px;
    font-weight: bold;
    color: #585858;
}

.pagenav li.st a {
    position: relative;
}

.pagenav li.st a:after {
    position: absolute;
    content: "";
    left: 50%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
    bottom: -5px;
    width: 10px;
    height: 1px;
    border-bottom: 2px solid #63b49e;
}

.pagenav li.prev a,
.pagenav li.next a {
    color: #000;
    font-size: 12px;
}

.pagenav li.prev a {
    text-align: right;
}

.pagenav li.next a {
    text-align: left;
}

.details .top-blog li dt span.category {
    font-size: 12px;
    padding-left: 10px;
}

.details .top-blog li dd {
    text-decoration: none;
}

.details .top-blog li dd.tex {
    border-top: 1px solid #737373;
    padding: 20px 0;
    border-bottom: 1px solid #737373;
    margin-bottom: 50px;
}

.details .more {
    max-width: 365px;
    margin: 0;
}

.details .top-blog li dl {
    margin-top: 0;
}

.details .top-blog .recommend li dt span.category {
    padding-left: 0;
}

@media only screen and (max-width: 1024px) {
    .main.w75 {
        width: 100%;
        margin-bottom: 50px;
    }

    .blog-list .category span {
        font-size: 8px;
        margin-bottom: 5px;
        padding: 0px 8px;
    }

    .blog-list .category {
        margin-bottom: 10px;
    }

    .side {
        width: 100%;
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        -webkit-box-pack: justify;
        -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
        justify-content: space-between;
    }

    .side .side-nav {
        width: 48%;
    }
}

@media only screen and (max-width: 599px) {
    .side-nav {
        width: 45%;
    }

    .pagenav li a {
        width: 32px;
    }
}

/*ブログ共通(ニュース一覧部分)*/
.blog-list.news li {
    padding-bottom: 10px;
    margin-bottom: 10px;
    border-bottom: #999 solid 1px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}


/* ##### ブログ共通ここまで ##### */

/* ##### 【料金表　1　】 ##### */
.menubox1 dl {
    border-bottom: 1px solid #000;
    padding: 10px 0;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.menubox1 dd {
    text-align: right;
}

@media only screen and (max-width: 599px) {
    .menubox1 div {
        margin-bottom: 30px;
    }
}

/* ##### 【料金表　1　】ここまで ##### */
/* ##### 【料金表　2　】 ##### */
.menubox2 {
    margin-bottom: 50px;
}

.menubox2 h3 {
    text-align: center;
    border-bottom: 1px solid #000;
    margin-bottom: 10px;
}

.menubox2 dd dl {
    border-bottom: 1px solid #000;
    padding: 10px 0;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.menubox2 dd dl dd {
    text-align: right;
}

@media (max-width: 599px) {
    .menubox2 h4 {
        text-align: center;
        margin-bottom: 0;
    }
}

/* ##### 【料金表　2　】ここまで ##### */
/* ##### 【左右のカラムが交互に代わるブロック】 ##### */
.crossbox li {
    margin-bottom: 80px;
}

.crossbox li span.no {
    display: block;
    line-height: 100%;
}

.crossbox li:nth-of-type(odd) {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -webkit-flex-direction: row-reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
}

@media (max-width: 599px) {
    .crossbox li:nth-of-type(odd) {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -webkit-flex-direction: column;
        -ms-flex-direction: column;
        flex-direction: column;
    }

    .crossbox .t-box {
        margin-top: 20px;
    }

    .crossbox li span.no {
        font-size: 30px;
    }
}

/* ##### 【左右のカラムが交互に代わるブロック】ここまで ##### */


/* ##### よくある質問 ##### */
.faq-box {
    padding-top: 80px;
}

.qa-list {
    margin-bottom: 50px;
}

.qa-q {
    font-size: 28px;
    font-weight: bold;
    color: #fff;
    background: #000;
    margin-right: 10px;

    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    text-align: center;
    display: block;
    width: 40px;
    height: 40px;
    padding-top: 8px;
}

.qa-list dt div {
    font-size: 24px;
    -webkit-box-sizing: border-box;
    position: relative;
    color: #000;
    font-weight: bold;
    display: inline-block;
    width: calc(100% - 50px);
}

.qa-list dt:hover {
    cursor: pointer;
}

.qa-list dd {
    font-size: 14px;
    padding: 20px 0;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    position: relative;
}

.qa-list .tex {
    display: inline-block;
    width: calc(100% - 50px);
}

.qa-list dd .qa-q {
    background: #999;
}

@media only screen and (max-width: 1024px) {}

@media only screen and (max-width: 599px) {
    .qa-list dt div {
        font-size: 18px;
    }
}

/* ##### よくある質問 ここまで ##### */

/* ##### お問い合わせ ##### */
.contact-list {
    margin-bottom: 20px;
    padding-bottom: 20px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    border-bottom: #9b9b9b solid 1px;
}

.contact-list dt {
    width: 250px;
    font-size: 18px;
    font-weight: bold;
}

.contact-list dd {
    width: calc(100% - 250px);
}

.contact-list input,
.contact-list textarea,
.contact-list select {
    border: none;
    background: #e6e6e6;
    width: 100%;
    padding: 10px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.contact-btn button {
    text-align: center;
    margin: 50px auto 0 auto;
    width: 240px;
    /* border: solid 1px #000; */
    display: block;
    background: #000;
    color: #fff;
    padding: 15px 0;
}

.contact-btn button:hover {
    opacity: 0.6;
    cursor: pointer;
}

@media only screen and (max-width: 1024px) {
    .contact-list dt {
        margin-bottom: 10px;
    }

    .contact-list dt,
    .contact-list dd {
        width: 100%;
    }

    .contact-list .must {
        display: inline-block;
        margin-left: 10px;
    }

}

@media only screen and (max-width: 599px) {}

/* ##### お問い合わせ　ここまで ##### */

/* ##### 医院について ##### */
.about .box01 {
    padding: 50px 0 80px;
}

.about .box01 .t-box * {
    text-align: center;
}

.about .box01 .t-box .pic {
    max-width: 235px;
    display: block;
    margin: 10px auto;
}

.about .box01 .t-box dd span.tel {
    font-weight: normal;
}

.about .box02 .bg-w {
    padding: 30px 0;
}

.about .box02 .header-info {
    width: 52%;
    max-width: 516px;
    margin: auto;
    padding: 0;
}

.about .box02 .header-info table.time-tagle {
    border-top: 3px solid #8d8e8e;
}

.about .box02 .time-tagle td,
.about .box02 .time-tagle th {
    font-size: 18px;
    color: #787872;
    padding: 20px 0;
}

.about .box02 .header-info .t-box span {
    color: #787872;
}

@media only screen and (max-width: 1024px) {
  .time-tagle td, .time-tagle th {
    line-height: 12px;
        padding: 5px 0;
  }
  .header-info .t-box span {
    line-height: 15px;
  }
    .about .box02 .header-info table.time-tagle {
        width: 100%;
    }

    .about .box02 .header-info {
        width: 95%;
        max-width: 600px;
    }

    .about .box03 .w60 {
        width: 100%;
    }

    .about .box03 .w60 .pic {
        max-width: 600px;
        margin: auto;
    }

    .about .box03 .t-box {
        width: 100%;
        margin-top: 20px;
    }


}

@media only screen and (max-width: 599px) {

    .about .box02 .time-tagle td,
    .about .box02 .time-tagle th {
        font-size: 12px;
        padding: 10px 0;
    }

    .about .box02 .bg-w {
        padding: 20px 0;
    }

}

/* ##### 医院について　ここまで ##### */

/* ##### 院長紹介 ##### */
.greeting .box01 .t-box h3 span {
    padding-right: 20px;
}

.greeting .box02 {
    padding: 70px 100px;
    overflow: hidden;
    position: relative;
}

.greeting .box02 .pic {
    width: 119px;
    position: absolute;
    right: -12px;
    bottom: -10px;
}

.greeting .box02 li {
    margin-bottom: 50px;
}

.greeting .box03 h3 {
    letter-spacing: 5px;
    margin-top: 30px;
}

.greeting .box03 h3 .pic {
    width: 64px;
    display: inline-block;
    margin-left: 10px;
    vertical-align: middle;
}

@media only screen and (max-width: 1024px) {
    .greeting .box02 {
        padding: 30px 20px;
    }
}

@media only screen and (max-width: 599px) {
    .greeting .box01 .t-box {
        margin-top: 30px;
    }

    .greeting .box03 .tit02 {
        font-size: 16px;
    }

    .greeting .box03 h3 .pic {
        width: 30px;
        margin-left: 5px;
    }
}

/* ##### 院長紹介　ここまで ##### */

/* ##### 診察の流れ ##### */
.treatment .box02 {
    position: relative;
    z-index: 1;
}

/* .treatment .box02 ul.flow {
    width: 1000px;
} */

.treatment .box02 ul.flow>li {
    margin-bottom: 80px;
}

.treatment .box02 li li.tex {
    max-width: 526px;
    width: 48%;
    margin: 0 40px;
}

.treatment .box02 li li.item {
    max-width: 357px;
    width: 48%;
    border: 1px solid #808080;
    text-align: center;
    position: relative;
    background: #fff;
    position: relative;
}

.treatment .box02 .flow li:nth-of-type(3) li.item {
    max-width: 253px;
    margin-left: auto;
}

.treatment .box02 li li.item .in {
    padding: 20px 10px;
    position: relative;
    width: 100%;
    height: 100%;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
}

.treatment .box02 li li.item .in:after {
    content: "";
    position: absolute;
    width: 1px;
    height: 200%;
    border-left: 1px dotted #d0d0d0;
    z-index: -1;
    left: 50%;
    top: 50%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
}

.treatment .box02 .flow li:nth-of-type(2) li.item .in:after {
    left: 25%;
    height: 300%;
}

.treatment .box02 .flow li:nth-of-type(3) li.item .in:after {
    top: -100%;
    height: 300%;
    left: 40%;
}

.treatment .box02 .flow li:nth-of-type(5) li.item .in:after {
    content: none;
}

.treatment .box02 li li.item .no {
    position: absolute;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: 1px solid #808080;
    background: #fff;
    left: -15px;
    top: -15px;
}

.treatment .box02 li li.item:before {
    position: absolute;
    content: "";
    width: 100%;
    height: 100%;
    background: #8599b3;
    left: 5px;
    top: 5px;
    z-index: -1;
}

.treatment .box02 li li.item .heading {
    font-size: 20px;
    font-weight: bold;
    font-family: "游ゴシック",
        YuGothic,
        Hiragino Sans,
        "ヒラギノ角ゴ ProN W3",
        "Hiragino Kaku Gothic Pro",
        Hiragino Kaku Gothic ProN,
        "メイリオ",
        Meiryo,
        'ＭＳ Ｐゴシック',
        sans-serif;
}

.treatment .box02 .red {
    display: none;
}
.treatment .box02 .rings_sub {
  display: none;
}
.treatment[data-element-id] .box02 .rings_sub {
  display: block;
}

.hoge{
  position: relative;
}

.hoge a{
  display: block;
  position: absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
}

.splink {
  display: none;
}
.treatment .box02 li li.item .heading {
  position: relative;
}


@media only screen and (max-width: 1024px) {
 /*    .treatment .box02 .red {
     display: block;
 } */

    .treatment .box02 ul.flow .flex,
    .treatment .inner {
        max-width: none;
        width: 95%;
    }


/*     .scr {
    overflow: scroll;
    white-space: nowrap;
    padding: 20px;
} */
    .treatment .box02 li li.item .heading {
    font-size: 14px;}
    .treatment .box02 li li.item {
    width: 37%;}
    .treatment .box02 .flow li:nth-of-type(3) li.item {
    max-width: 125px;}
    .treatment .box02 li li.tex {
    margin: 0 0 0 20px;
}
.treatment .box02 li li.tex {
    max-width: 526px;
    width: 59%;}
    .treatment .box02 li li.item .in:after {
    height: 119%;}
        .treatment .box02 li:nth-of-type(4) li.item .in:after {
    height: 250%;}
}

@media only screen and (max-width: 599px) {
  .treatment .box02 .rings_sub {
  display: block;
}
 .treatment .box02 .rings_sub dt span.en {
     display: inline-block;
    padding-left: 0;
}
.treatment .box02 li li.tex {
  display: none;
}
.treatment .box02 li li.item {
  width: 100%;
  max-width: none;
}
.treatment .box02 .flow li:nth-of-type(3) li.item {
    max-width: 50%;
}
.treatment .box02 li li.item .in:after {
    height: 150%;
}
.treatment .box02 .flow li:nth-of-type(3) li.item .in:after {
    top: -143%;
    height: 391%;}
    .treatment .box02 li li.item .heading {
    font-size: 12px;
}
.treatment .box02 ul.flow>li {
    margin-bottom: 30px;
}
.splink {
  display: block;
}

.treatment .box02 li li.item .heading:after {
    position: absolute;
    content: "";
    border-top: 5px solid #333;
    border-right: 5px solid transparent;
    border-bottom: 5px solid transparent;
    border-left: 5px solid transparent;
    left: 50%;
    top: 103%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
}

}

/* ##### 診察の流れ　ここまで ##### */

/* ##### for_reservation ##### */
.for_reservation .box01 {
    position: relative;
    padding: 50px 0 150px;
}

.for_reservation .box01 .pic {
    max-width: 360px;
    position: absolute;
    right: -33px;
    bottom: 0;
}

.for_reservation .box01 ul {
    border: dotted 1px #c6c6c6;
    padding: 20px;
}

.for_reservation .box01 ul * {
    font-family: "游ゴシック", YuGothic, Hiragino Sans, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic Pro", Hiragino Kaku Gothic ProN, "メイリオ", Meiryo, 'ＭＳ Ｐゴシック', sans-serif;
}

.for_reservation .box01 ul li {
    margin-bottom: 50px;
}

.for_reservation .box01 ul li.tex01 {
    color: #2458c1;
}

.for_reservation .box01 ul li.tex01 span {
    text-decoration: underline;
}

.for_reservation .box01 ul li.tex02 {
    color: #1b4b7c;
    width: 85%;
}

.for_reservation .box01 ul li.tex03 {
    color: #205047;
    width: 70%;
}


@media only screen and (max-width: 1024px) {
    .for_reservation .box01 .pic {
        max-width: 286px;
    }

    .for_reservation .box01 ul li.tex02 br {
        display: none;
    }

    .for_reservation .box01 ul li.tex02 {
        width: 100%;
    }

    .for_reservation .box01 ul li.tex03 {
        width: 100%;
        font-size: 20px;
    }
}

@media only screen and (max-width: 599px) {
    .for_reservation .box01 ul li.tex03 br {
        display: none;
    }

    .for_reservation .box01 .pic {
        right: 3px;
    }

    .for_reservation .box01 {
        padding: 50px 0 210px;
    }

    .for_reservation .box01 ul li.tex01 {
        font-size: 18px;
    }
}

/* ##### for_reservation ここまで ##### */

/* ##### tr_ippan ##### */
.trouble-box {
    position: relative;
    z-index: 0;
}

.trouble-box .t-box li {
    font-size: 16px;
    margin: 20px 0;
    position: relative;
    padding-left: 30px;
}

.trouble-box .t-box li:before {
    content: "";
    position: absolute;
    background: url(/import/tenant_1/160.16.107.177/html/images/06_tr_ippan/check.png);
    margin-right: 10px;
    width: 19px;
    height: 15px;
    left: 0;
    top: 3px;
}

.pickup-box {
    border: 1px solid #2bb397;
    background: #fff;
    padding: 40px;
    margin-bottom: 50px;
}

.pickup-box dt {
    margin-bottom: 15px;
}

.subbox h4 {
    padding-bottom: 10px;
    border-bottom: 1px solid #454545;
}

.equipment li {
    margin-bottom: 50px;
}

.equipment li dt {
    margin-bottom: 20px;
    line-height: unset;
}

@media only screen and (max-width: 1024px) {}

@media only screen and (max-width: 599px) {
    .pickup-box {
        padding: 20px 10px;
    }

    .equipment li .pic {
        margin-bottom: 30px;
    }
}

/* ##### tr_ippan　ここまで ##### */

/* ##### tr_syoni ##### */

.glow-box li {
    margin-bottom: 120px;
    position: relative;
    background: #fff;
    border-radius: 15px;
    -webkit-box-shadow: 2px 2px 0px 1px #c9c9c9;
    box-shadow: 2px 2px 0px 1px #c9c9c9;
}

.glow-box li:after {
    position: absolute;
    content: "";
    bottom: -130px;
    left: 50%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
    border-top: 45px solid #e7ebe6;
    border-right: 60px solid transparent;
    border-bottom: 60px solid transparent;
    border-left: 60px solid transparent;
}

.glow-box li:last-of-type:after {
    content: none;
}

.glow-box li dl {
    height: 100%;
}

.glow-box li:last-of-type {
    margin-bottom: 50px;
}

.glow-box li dt {
    width: 20%;
    background: #fecf86;
    border-top-left-radius: 15px;
    border-bottom-left-radius: 15px;
    height: 100%;
    padding: 20px 5px;
    text-align: center;
    min-height: 150px;
    font-size: 34px;
    font-family: "游ゴシック",
        YuGothic,
        Hiragino Sans,
        "ヒラギノ角ゴ ProN W3",
        "Hiragino Kaku Gothic Pro",
        Hiragino Kaku Gothic ProN,
        "メイリオ",
        Meiryo,
        'ＭＳ Ｐゴシック',
        sans-serif;
    font-weight: bold;
}

.glow-box li dt .age {
    font-size: 22px;
    padding-left: 5px;
}

.glow-box li:nth-of-type(2) dt {
    background: #feadac;
}

.glow-box li:nth-of-type(3) dt {}

.glow-box li:nth-of-type(4) dt {
    background: #85d7ff;
}

.glow-box li:nth-of-type(5) dt {
    background: #d1ff77;
}

.glow-box li dd.tex {
    width: 60%;
    padding-left: 15px;
}

.glow-box li dd.pic {
    max-width: 20%;
    margin-top: -65px;
}

@media only screen and (max-width: 1024px) {
  .glow-box li dd.pic {
    margin-top: -20px;
  }
      .glow-box li dt {
        font-size: 27px;
        min-height: 190px;
}
}

@media only screen and (max-width: 599px) {
    .glow-box li dt {
        width: 100%;
        border-bottom-left-radius: 0;
        border-top-right-radius: 15px;
        border-bottom-right-radius: 0;
        min-height: auto;
        margin-bottom: 20px;
    }

    .glow-box li dd.tex {
        width: 100%;
        padding: 0 15px 15px;
    }

    .glow-box li dd.pic {
        max-width: 40%;
        margin: 0 0 20px auto;
    }
}

/* ##### tr_syoni　ここまで ##### */

/* ##### tr_white ##### */
.tr_white .box02 {
    padding: 50px 0 80px;
}

.tr_white .box02 .space {
    float: right;
    /*画像の位置を右下にしたい場合はright*/
    height: 17.5em
        /*画像上の余白の高さ*/
}

.tr_white .box02 .t-box .pic {
    max-width: 190px;
    float: right;
    /*画像の位置を右下にしたい場合はright*/
    clear: both;
    /*.spaceのfloat解除*/
    margin: 5px 0 0 10px;
    /*画像の周りの余白*/
}

.tr_white .box02 .pickup-box {
    padding: 20px 40px 30px;
    margin-bottom: 10px;
}

.tr_white .box02 .pickup-box dd {
    padding: 10px;
    border: 1px solid #c9c9c9;
}

.tr_white .box02 .pickup-box dl {
    position: relative;
}

.tr_white .box02 .pickup-box dl:last-of-type:after {
    content: none;
}

.tr_white .box02 .pickup-box dl:after {
    content: "";
    position: absolute;
    border-top: 25px solid transparent;
    border-bottom: 25px solid transparent;
    border-left: 18px solid #e2ebe9;
    top: 50%;
    left: 110%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
}

.tr_white .box03 .plice-box dt strong {
    border-bottom: 2px solid #2bb397;
    position: relative;
    padding-bottom: 10px;
}

.tr_white .box03 .plice-box dt strong span+span {
    padding-left: 20px;
}

.tr_white .box03 .plice-box dt strong:after {
    position: absolute;
    content: "";
    background: #2bb397;
    width: 100%;
    height: 1px;
    left: 0;
    bottom: -6px;
}

.step-box li dl {
    background: #e2ebe9;
    margin-top: -15px;
}

.step-box li dl dt {
    margin: 0;
}

.step-box li dl dd {
    padding: 10px;
}

.step-box li {
    margin-bottom: 80px;
}

.step-box li:last-of-type {
    margin-bottom: 50px;
}

.step-box li span.no {
    position: relative;
    z-index: 5;
    display: block;
    padding: 0 10px;
}

.step-box li:nth-of-type(even) span.no {
    text-align: right;
}

.step-box li:nth-of-type(even) dl {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -webkit-flex-direction: row-reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;

}

.step-box li dl h4 {
    margin-bottom: 0;
}

.tr_white .box04 .w80 {
    margin-left: auto;
    margin-bottom: 20px;
}

.tr_white .box04 .more span {
    line-height: 0;
    margin-bottom: 10px;
}

@media only screen and (max-width: 1024px) {
    .tr_white .box02 .pickup-box {
        padding: 15px 15px 20px;
    }

    .tr_white .box02 h4 {
        text-align: center;
    }

    .tr_white .box02 .w48 {
        width: 100%;
    }

    .tr_white .box02 .w48.picbox .pic {
        max-width: 400px;
        margin: 0 auto 30px;
    }

    .tr_white .box03 .plice-box dt strong .fs48 {
        font-size: 36px;
    }

}

@media only screen and (max-width: 599px) {
    .tr_white .box02 .pickup-box dl:after {
        top: 110%;
        left: 50%;
        -webkit-transform: translateY(-50%) rotate(90deg);
        -ms-transform: translateY(-50%) rotate(90deg);
        transform: translateY(-50%) rotate(90deg);
    }

    .tr_white .box02 .t-box {
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

    .tr_white .box02 .space {
        display: none;
    }

    .tr_white .box02 .t-box .pic {
        float: none;
        -webkit-box-ordinal-group: 3;
        -webkit-order: 2;
        -ms-flex-order: 2;
        order: 2;
        margin: 20px 10px 50px auto;
    }

    .tr_white .box02 .pickup-box {
        padding: 10px 0px 20px;
    }

    .tr_white .box02 .pickup-box dl:first-of-type {
        position: relative;
        margin-bottom: 60px;
    }

    .step-box li span.no {
        font-size: 36px;
    }

    .step-box li dl h4 {
        font-size: 16px;
    }

    .tr_white .box04 .flexb {
        margin-top: 0;
    }
}

/* ##### tr_white　ここまで ##### */

/* ##### tr_sports ##### */
.tr_sports .box02 dl {
    margin-bottom: 30px;
}

.tr_sports .box02 dl dd {
    margin: 10px auto 0;
}

.dot-box {
    background: #fff;
    padding: 40px 50px;
    border: 1px dotted #2bb397;
    margin-bottom: 50px;
}

.dot-box li {
    width: 80%;
    margin: 0 auto;
    padding: 20px 0;
}

.dot-box li .no {
    padding-right: 10px;
}

@media only screen and (max-width: 1024px) {
    .dot-box li {
        width: 90%;
    }

    .dot-box {
        padding: 10px 10px;
    }
}

@media only screen and (max-width: 599px) {}

/* ##### tr_sports　ここまで ##### */

/* ##### english ##### */
.english .box02 .t-box {
    padding: 20px;
}

.table dl {
    margin-bottom: 20px;
}

.table dl dt {
    padding: 20px;
    width: 264px;
    background: #e2ebe9;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    text-align: center;
}

.table dl dd {
    padding: 20px;
    width: calc(100% - 275px);
}

.table dl dd div {
    width: 100%;
    margin-top: 30px;
}

.tabnav li {
    width: 266px;
    padding: 20px;
    text-align: center;
    border: 1px solid #454545;
    margin-bottom: 30px;
    font-size: 20px;
}

.tabnav li+li {
    margin-left: 10px;
}

.tabnav li.on {
    background: #8599b3;
    color: #fff;
    border: 1px solid #8599b3;

}

@media only screen and (max-width: 1024px) {
    .table dl {
        width: 100%;
    }

    .table dl dt {
        width: 250px;
        font-size: 20px;
    }

    .table dl dd {
        width: calc(100% - 260px);
    }
}

@media only screen and (max-width: 599px) {

    .table dl dt,
    .table dl dd {
        width: 100%;
    }

    .table dl dt {
        margin-bottom: 10px;
    }
}

/* ##### english-class　ここまで ##### */
/* ##### recruit ##### */
.melit-box li {
    position: relative;
}
.melit-box.c4c5w48 li:nth-of-type(4n+4) {
    width: 47%;
}
.melit-box.c4c5w48 li:nth-of-type(5n+5) {
    width: 47%;
}

.melit-box li .meit {
    position: absolute;
    background: #8599b3;
    color: #fff;
    width: 83px;
    padding-bottom: 10px;
    height: 83px;
    right: -5px;
    top: 0;
    z-index: 5;
}

.melit-box li .meit .no {
    font-size: 52px;
}

.recruit .box02 .flexb {
    padding: 30px;
}

.recruit .box04 .tel-box {
    width: 78%;
    margin: auto;
    margin-top: 10px;
    border: 1px dotted #a2a2a2;
    padding: 20px;
}

.recruit .box04 .tel-box .tel {
    font-size: 60px;
    padding-left: 20px;
}
.recruit .table dl dd a {
  padding-left: 10px;
  text-decoration: underline;
}
@media only screen and (max-width: 1024px) {
  .melit-box li {
    width: 46%;
  }
/*     .recruit .flexb {
    padding: 0 30px;
    -webkit-box-align: baseline;
    -webkit-align-items: baseline;
    -ms-flex-align: baseline;
    align-items: baseline;
} */

    .recruit .box04 .tel-box {
        width: 100%;
    }
}

@media only screen and (max-width: 599px) {
    .recruit .box04 .tel-box .tel {
        font-size: 24px;
    }  
    .melit-box li {
    width: 100%;
  }
    .melit-box.c4c5w48 li:nth-of-type(4n+4) {
    width: 100%;
    }
    .melit-box.c4c5w48 li:nth-of-type(5n+5) {
    width: 100%;
    }
    .melit-box li .pic {
    width: 100%;
  }
.melit-box li .meit {
    width: 65px;
    height: 60px;
}
}

/* ##### recruit　ここまで ##### */


/* ##### clinic ##### */


.clinic .txt1 {
    text-align: center;
    padding-bottom: 20px
}

.clinic .inner {
    padding-bottom: 122px
}

.clinic .inner.box01 {
    max-width: 1160px;
}

.clinic .inner .ringwap.pc {
    padding-top: 93px;
    width: 100%;
    max-width: 1160px;
    min-height: 1060px;
    position: relative;
    margin: 0 auto;
    background: url(/import/tenant_1/160.16.107.177/html/images/11_clinic/bg.png) no-repeat top;
    height: 100%;
}

.clinic .inner .ringwap.pc .tit {
    position: absolute;
    text-align: center;
    left: 50%;
    top: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}

.clinic .inner .ringwap.pc .tit h3 {
    margin: 20px 0 10px;
}

.clinic .inner .ringwap.pc .tit .pic {
    max-width: 82px;
    margin: auto;
}

.clinic .inner .ringwap.pc .ih-item.circle.effect {
    position: absolute;
}

.clinic .inner .ringwap.pc .ring1 {
    top: 0;
    left: 50%;
    margin-left: -160px;
    z-index: 9;
}

.clinic .inner .ringwap.pc .ring2 {
    top: 278px;
    right: 0;
}

.clinic .inner .ringwap.pc .ring3 {
    bottom: 61px;
    right: 168px
}

.clinic .inner .ringwap.pc .ring4 {
    bottom: 61px;
    left: 168px
}

.clinic .inner .ringwap.pc .ring5 {
    top: 278px;
    left: 0
}

.clinic .inner .ringwap.pc .img h3 {
    font-size: 28px;
    text-align: center;
    font-weight: normal;
    color: #000;
    padding-top: 40px
}

.clinic .inner .ringwap.pc .img p {
    padding-bottom: 30px;
    color: #f36191
}

.clinic .inner .ringwap.pc .img li {
    font-size: 18px;
    padding-bottom: 5px;
    color: #000
}

.ring1 .img {
    background: #8599b3
}

.clinic .inner .ringwap.pc .ring1 .img p {
    color: #FFF
}

.ring1 .info {
    background: #f0a8aa
}

.ih-item.circle.effect .info .tex {
    padding: 20px 70px 20px 30px;
}

.ring2 .img {
    background: #8599b3
}

.ring3 .img {
    background: #8599b3
}

.ih-item.circle.effect.ring4 .img {
    background: #8599b3
}

.ring5 .img {
    background: #8599b3;
}

/**/

.ih-item.circle {
    position: relative;
    width: 320px;
    height: 320px;
    border-radius: 50%
}

.ih-item.circle .img {
    position: relative;
    width: 320px;
    height: 320px;
    border-radius: 50%
}

.ih-item.circle.effect .img {
    z-index: 11;
    -webkit-transition: all 0.35s ease-in-out;
    transition: all 0.35s ease-in-out;
    text-align: center
}

.ih-item.circle.effect.colored .info {
    background: #f6f6f6
}

.ih-item.circle.effect .info {
    -webkit-transition: all 0.35s ease-in-out;
    transition: all 0.35s ease-in-out;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    width: 320px;
    height: 320px;
    border-radius: 50%;
    background: #f0a8aa;
}

.ih-item.circle.effect .info .tex {
    color: #fff;
}

.ih-item.circle.effect .info p {
    font-size: 18px;
    color: #FFF;
    -webkit-transition: all 0.35s ease-in-out;
    transition: all 0.35s ease-in-out;
    padding-left: 40px
}

.ih-item.circle.effect.left_to_right .img {
    -webkit-transform-origin: 95% 40%;
    -ms-transform-origin: 95% 40%;
    transform-origin: 95% 40%
}

.ih-item.circle.effect.left_to_right .img:after {
    content: "";
    width: 8px;
    height: 8px;
    position: absolute;
    border-radius: 50%;
    top: 40%;
    left: 95%;
    margin: -4px 0 0 -4px
}

.ih-item.circle.effect.left_to_right span:hover .img {
    -webkit-transform: rotate(-120deg);
    -ms-transform: rotate(-120deg);
    transform: rotate(-120deg)
}

.ih-item.circle.effect.right_to_left .img {
    -webkit-transform-origin: 5% 40%;
    -ms-transform-origin: 5% 40%;
    transform-origin: 5% 40%
}

.ih-item.circle.effect.right_to_left .img:after {
    content: "";
    width: 8px;
    height: 8px;
    position: absolute;
    border-radius: 50%;
    top: 40%;
    left: 5%;
    margin: -4px 0 0 -4px;
    background: rgba(0, 0, 0, 0.8);
    -webkit-box-shadow: 0 0 1px rgba(255, 255, 255, 0.9);
    box-shadow: 0 0 1px rgba(255, 255, 255, 0.9)
}

.ih-item.circle.effect.right_to_left span:hover .img {
    -webkit-transform: rotate(120deg);
    -ms-transform: rotate(120deg);
    transform: rotate(120deg)
}

.ih-item.circle.effect.left_to_right .img {
    padding: 10px;
}

.ih-item.circle.effect.left_to_right .img .in {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    border: 1px solid #fff;
}

.ih-item.circle.effect.left_to_right .img .pic {
    max-width: 96px;
    margin: auto;
}

.ih-item.circle.effect.left_to_right .img dd {
    color: #fff;
    margin-top: 20px;
}

.clinic .inner .ringwap.sp {
    display: none;
}

.clinic .inner .ringwap.sp[data-element-id] {
    display: block;
}
    .clinic .inner .ringwap.sp .img li {
        font-size: 18px
    }

    .clinic .inner .ringwap.sp .icon-sp {
        max-width: 50px;
        margin: 0 auto 10px;
    }
    .rings_sub {
        padding: 0 20px;
        text-align: left;
    }

    .rings_sub dl {
        padding-bottom: 10px;
        margin-bottom: 20px;
        border-bottom: 1px dotted #333;
    }

    .rings_sub dt {
        font-size: 18px;
        font-weight: normal;
        color: #000;
    }

    .rings_sub dd ul li {
        padding-left: 20px;
        margin-bottom: 10px;
        background: url(/import/tenant_1/160.16.107.177/html/images/bred_next_2.png) 5px center no-repeat;
        background-size: 10px auto;
    }

    .rings_sub dt span.en {
        font-size: 13px;
        color: #2bb397;
        padding-left: 10px;
    }
    .clinic .top-promise li a {
    display: block;
    width: 100%;
    height: 100%;
}

    .clinic .top-promise li dl {
        position: relative;
    }

    .clinic .top-promise li dl:after {
        position: absolute;
        content: "";
        border-top: 5px solid #fff;
        border-right: 5px solid transparent;
        border-bottom: 5px solid transparent;
        border-left: 5px solid transparent;
        left: 50%;
        top: 103%;
        -webkit-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
        transform: translateX(-50%);
    }
    .top-promise .more {
      margin-top: 40px;
    }
.top-promise[data-element-id] .imgalt {
    margin-top: -100px;
}
@media only screen and (max-width: 1159px) {
    .ih-item.circle {
        width: 290px;
        height: 290px;
    }

    .ih-item.circle .img {
        width: 290px;
        height: 290px;
    }

    .ih-item.circle.effect .info {
        width: 290px;
        height: 290px;
    }

    .clinic .inner .ringwap.pc .ring2 {
        right: -15px;
    }

    .clinic .inner .ringwap.pc .ring5 {
        left: -15px;
    }

    .clinic .inner .ringwap.pc .ring3 {
        right: 90px;
    }

    .clinic .inner .ringwap.pc .ring4 {
        left: 80px;
    }

}

@media only screen and (max-width: 1024px) {
    .clinic .inner {
        padding-bottom: 80px;
    }

    .clinic .inner .ringwap.sp {
        display: block;
    }

    .clinic .inner .ringwap.pc {
        display: none;
    }



}

@media only screen and (max-width: 599px) {
    .rings_sub dt span.en {
        display: block;
        padding-left: 0;
    }   
    .clinic .box02 li.w45 {
        width: 50%;
    }

    .bl-gr {
        padding-left: 10px;
    }
}

/* ##### clinic　ここまで ##### */


/* ##### elmo_piccolo ##### */
.elmo_piccolo .box01 {
    margin-bottom: 100px;
}

.elmo_piccolo .box01 .t-box {
    margin-left: auto;
    margin-right: -5%;
    width: 40%;
}

.elmo_piccolo .box01 .t-box dl {
    max-width: 535px;
    background: #fff;
    padding: 50px 20px 20px;
    position: relative;
    margin-left: auto;
    margin-top: 50%;
}

.elmo_piccolo .box01 .t-box dl dt {
    margin-bottom: 50px;
}

.elmo_piccolo .box01 .t-box dl dt .pic {
    max-width: 276px;
    margin: 10px 0;
    display: block;
}

.elmo_piccolo .box01 .t-box dl:before {
    position: absolute;
    content: "";
    background: #8599b3;
    width: 100%;
    height: 70%;
    left: -106%;
    top: -64%;
    z-index: -1;
}

.elmo_piccolo .box01 .t-box dl:after {
    position: absolute;
    content: "";
    background: #8599b3;
    width: 120%;
    height: 100%;
    left: -6%;
    top: 6%;
    z-index: -1;
}

.elmo_piccolo .box02 .step-box dd.w70 {
    width: 74%;
}

.elmo_piccolo .box02 .step-box li dl dd {
    padding: 20px;
}

.elmo_piccolo .box02 .step-box dd.w70 div {
    margin-top: 30px;
    line-height: 30px;

}

.elmo_piccolo .box02 .step-box dd.w70 div .tel img {
    margin-top: 10px;
    margin-right: 10px;
}

.elmo_piccolo .box03 .bg-w {
    padding: 30px;
}

.elmo_piccolo .box03 li {
    font-size: 16px;
    margin: 20px 0;
    position: relative;
    padding-left: 1em;
    text-indent: -1em;
}

.elmo_piccolo .box03 li span {
    color: #df8083;
    padding-right: 10px;
}


@media only screen and (max-width: 1024px) {
    .elmo_piccolo .box01 .w60 {
        width: 100%;
    }

    .elmo_piccolo .box01 .t-box,
    .elmo_piccolo .box01 .t-box dl {
        max-width: none;
        width: 100%;
    }

    .elmo_piccolo .box01 .t-box dl {
        margin-top: 0;
    }

    .elmo_piccolo .box01 .t-box {
        margin-left: 0;
        margin-right: 0;
    }
}

@media only screen and (max-width: 599px) {
    .elmo_piccolo .box02 .step-box dd.w70 {
        width: 100%;
    }

}

/* ##### elmo_piccolo ここまで ##### */

/* ##### preventive ##### */

.scrol-nav li .span {
    line-height: 0;
}

.preventive .box03 {
    margin: 50px 0;
}


.preventive .box03 .inner {
    position: relative;
    z-index: 10;
}

.preventive .box03:before {
    position: absolute;
    content: "";
    width: 100%;
    height: 100%;
    background: rgba(255, 255, 255, 0.2);
    top: 0;
    left: 0;
    z-index: 1;
}

.preventive .box03:after {
    position: absolute;
    content: "";
    width: 70%;
    height: 100%;
    left: 0;
    top: 0;
    background: rgb(255, 255, 255);
    background: -webkit-gradient(linear, left top, right top, color-stop(44%, rgba(255, 255, 255, 1)), to(rgba(255, 255, 255, 0)));
    background: -webkit-linear-gradient(left, rgba(255, 255, 255, 1) 44%, rgba(255, 255, 255, 0) 100%);
    background: linear-gradient(90deg, rgba(255, 255, 255, 1) 44%, rgba(255, 255, 255, 0) 100%);
}

/* .preventive .box03 .t-box {
    position: absolute;
    left: calc(50% - 500px);
    top: 50%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    max-width: 400px;

} */

.preventive .box04 .flexs {
    -webkit-box-align: end;
    -webkit-align-items: flex-end;
    -ms-flex-align: end;
    align-items: flex-end;
}

.menu-step li {
    border: 1px solid #808080;
    text-align: center;
    position: relative;
    background: #fff;
    padding: 20px;
    margin-bottom: 20px;
}

.menu-step li:after {
    position: absolute;
    content: "";
    width: 100%;
    height: 100%;
    background: #8599b3;
    left: 5px;
    top: 5px;
    z-index: -1;
}

.menu-step li dt {
    width: 80px;
    border-right: 1px dotted #d0d0d0;
    line-height: 20px;
}

.menu-step li dt .no {
    margin-left: -10px;
}

.menu-step li dd {
    width: calc(100% - 80px);
    padding-left: 20px;
}

.preventive .box04 .pickup-box {
    width: 88%;
    margin: 0 auto 30px;
}

.preventive .box04 .pickup-box li {
    margin: 10px 20px;
}

.preventive .box05 .benefits ul.bg-w {
    padding: 30px;
}

.preventive .box05 .benefits li.w45 {
    margin-bottom: 30px;
}

.preventive .box05 .benefits li .pic {
    max-width: 37px;
    margin: 0 auto 20px;
}

.preventive .box04 .pickup-box li ul li {
    margin: 5px 0;
}

.preventive .box05 .benefits .w30.pic {
    margin-top: -200px;
}

.item-end {
    -webkit-box-align: end;
    -webkit-align-items: flex-end;
    -ms-flex-align: end;
    align-items: flex-end;
}

.preventive .box05 .more .db,
.scrol-nav li span.db {
    line-height: 0;
    margin: 10px 0;
}

@media only screen and (max-width: 1024px) {
    .menu-step li dt {
        font-size: 30px;
    }

    .menu-step li dt .fs16 {
        font-size: 12px;
    }

    .menu-step li dt {
        width: 60px;
    }

    .menu-step li dd {
        width: calc(100% - 60px);
        padding-left: 10px;
    }

    .menu-step li {
        padding: 10px;
    }

    .preventive .box05 .benefits .w30.pic {
        margin-top: -170px;
    }

    .preventive .box04 .sec02 .fs24 {
        font-size: 16px;
    }

}

@media only screen and (max-width: 599px) {
    .preventive .box05 .benefits .w30.pic {
        margin-top: 20px;
    }
}

/* ##### preventive　ここまで ##### */

/*2020/06/15*/

.qa00 {
  width: 1200px;
  display: flex;
  margin: 50px auto;
}

@media only screen and (max-width: 1049px) {
  .qa00 {
    width: 100%;
    display: block;
    margin-top: 50px;
    }
    
  .qa00 p {
    width: 80%;
    margin: 50px auto;
  }
}

@media only screen and (max-width: 599px) {
  .qa00 {
    margin-top: 0;
    }
    
  .qa00 p {
    width: 90%;
  }
}

.notes01 {
    width: 70%;
}

@media only screen and (max-width: 1024px) {
  .notes01 {
    width: 100% !important;
}
}

.bor000 {
  border: 1px solid #000;
}

/* 2023.07.20 */

.gaikan01{
  display: flex;
}

.gaikan01 p{
  margin: 0 10px 0;
}

.gaikan01 span{
  padding-top: 136% !important;
}

.setsubiimg span{
  padding-top: 129% !important;
}

.setsubiimg02 span{
  padding-top: 146% !important;
}

@media only screen and (max-width: 599px) {
.img04box li dl{
  margin-left: 17px;
}

.pic02{
  width: 90%;
}

.pic03{
  width: 100%;
}
}

.rentalurl a{
  color: #0831ab;
}

.step03img{
  height: 200px;
}

.step03seed{
      width: 100%;
    margin-bottom: 60px;
}

.campain{
      width: 66%;
    margin: 60px auto 100px;
}

.campain p{
      font-size: 26px;
    text-align: center;
}

.campain img{
  width: 100%;
  padding-top: 20px;
}

.campain span{
  text-align: center;
}


@media only screen and (max-width: 1024px) {
.campain {
    width: 93%;
}

.step03img {
    height: 150px;
}

.step03seed {
    margin-bottom: 30px;
}
}

@media only screen and (max-width: 599px) {
.campain p {
    font-size: 20px;
}
}


.youtube01{
  margin-top: 40px;
}


@media only screen and (max-width: 1024px) {
  .youtube01{
    width: 73%;
    margin: 40px auto;
  }
}

@media only screen and (max-width: 599px) {
.youtube01 {
    width: 94%;
    margin: 40px auto;
}

.youtube01 iframe{
  height: 230px;
}
}


/* 2024.02.15x */

.h2andarpetitluxe{
  font-size: 16px;
}

.petit-h2{
  line-height: 0.6;
}

.howtoluxe{
  text-align: center;
    margin-bottom: 10px;
    font-size: 20px;
}

.toha-luxe{
  text-align: center;
  font-size: 16px;
}

.dental-space{
  font-size: 16px;
    border: 1px solid #e2ebe9;
    padding: 7px 10px;
    border-radius: 20px;
    background: #e2ebe9;
}

.what-p{
  margin-top: 40px;
  color: #3d9784;
  font-size: 30px;
    margin-bottom: 10px;
}


.rental-prace p, .kuwashiku{
  text-align: center;
  font-size: 16px;
}

.day-p{
  border-top: 1px dotted;
    padding-bottom: 80px;
}

.qr-box li{
  width: 20%;
}

.qr-box li img{
  width: 100%;
  background: #fff;
}

/* .qr-03li{
  width: 18% !important;
} */

.qr-box{
  width: 80%;
    margin: 30px auto 0;
}

.bg-pink{
  background: #f1e6ed;
}

.kuwashiku{
  margin-top: 20px;
}

.howto-img{
  width: 80%;
    margin: 0 auto 20px;
}

.howto-img img{
  width: 100%;
}

.map-02box{
  display: flex;
  justify-content: space-between;
}

.map-iframe{
  width: 47%;
}

.accese-img{
  width: 49%;
}

.access-p02{
  margin-top: 10px;
}

.rental-topbox{
  margin-top: -70px;
}


@media only screen and (max-width: 599px) {
.dental-space {
    font-size: 14px;
}

.rental-topbox {
    margin-top: -10px;
    line-height: 2;
}

.petit-h2 {
    line-height: 1.2;
}

.toha-luxe {
    text-align: left;
    font-size: 14px;
}

.howto-img {
    width: 98%;
}

.what-p {
    margin-top: 5px;
    font-size: 24px;
}

.melit-box li {
    margin-bottom: 50px;
}

.rental-prace p, .kuwashiku {
    text-align: left;
    font-size: 14px;
}

.qr-box {
    width: 98%;
}

.qr-box li {
    width: 31%;
}

.map-02box {
    display: block;
}

.accese-img {
    width: 98%;
    margin: 0 auto 25px;
}

.map-iframe {
    width: 98%;
    margin: auto;
}

.poccolo-box{
  flex-direction: column-reverse
}

.luxe-time{
  text-align: center !important;
}
}

.petit-box{
  background: #93868e !important;
}

.logo-img img{
  width: 240px !important;
}


.breadcrumb__list {
    display: flex;
}

.bread-box li {
    padding: 6px 0px;
    font-size: 18px;
    line-height: 1.3;
}

.breadcrumbs-thispage::before {
    content: "";
    width: 0.5em;
    height: 0.5em;
    display: inline-block;
    margin: 0 1em 2px 0.5em;
    border-top: 2px solid;
    border-right: 2px solid;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}

.bread-box{
 width: 92%;
 max-width: 1000px;
 margin: auto;
    }
    
    
@media only screen and (max-width: 599px) {
.logo {
        width: 96%;
        margin: 7px auto 30px;
}

.bread-box li {
  font-size: 12px;
}



}

/* 2024.09.03 */

.top-concept{
  bottom:330px !important;
  left: 40%;
}

.top-concept h3{
  color: #fff;
    margin-bottom: 20px;
    font-size: 44px;
}

.top-concept p{
  color: #fff;
  font-size: 18px;
}

.mainimg img {
  filter: brightness(0.7);
}

.tab-sp-concept{
  display: none;
}

@media only screen and (max-width: 1300px) {
  .top-concept {
    bottom: 270px !important;
    left: 50%;
  }
  
  .top-concept h3{
    font-size: 42px;
}
}


@media only screen and (max-width: 1150px) {
  .top-concept {
    bottom: 220px !important;
    left: 50%;
  }
  
  .top-concept h3{
    font-size: 40px;
}

.top-concept p{
  color: #fff;
  font-size: 16px;
}
}

@media only screen and (max-width: 1024px) {
  .top-concept {
    display: none;
  }
  
  .tab-sp-concept{
    display: block;
    width: 90%;
        margin: 0 auto 40px;
}

.top-message{
  margin: 80px auto 50px;
}
}


.reason-03{
  width: 33%;
  padding: 0 1.2%;
}

.reason-flex{
  display: flex;
}

.reason-p01{
  font-size: 22px;
    text-align: center;
    margin-bottom: 3px;
}

.reason-03 img{
  width: 100%;
  margin-bottom: 5px;
}


@media only screen and (max-width: 1024px) {
  .inner {
        max-width: 800px !important;
  }
}

@media only screen and (max-width: 599px) {
  .reason-flex {
    display: block;
}

.reason-03 {
    width: 100%;
    padding: 0 1.1%;
    margin-bottom: 40px;
}
}

.mt-nico{
  margin-top: 20px !important;
}

.nico-teen{
  display: flex;
  justify-content: space-between;
  margin-bottom: 40px;
  border: 1px solid;
    border-radius: 20px;
    padding: 20px;
}

.nicoteen01{
  display: block;
  width: 52%;
  margin-top: 30px;
}

.nicoteen02{
  display: block;
  width: 45%;
  margin-top: 30px;
}

.nico-img{
  width: 75%;
    margin: auto;
}

.nico-img img{
  width: 100%;
}

.nico-p{
  text-align: center;
}

.nicoteen01 p{
  font-size: 18px;
  font-weight: bold;
  border-bottom: 1px solid;
    margin-bottom: 10px;
}

.pack-p01{
  border: 1px solid;
    padding: 20px;
    text-align: center;
    margin: 20px auto;
    font-weight: bold;
    font-size: 18px;
    background: #e5e5e5;
}

.pack-p02{
  font-size: 16px;
    margin-bottom: 30px;
}

.pc-none{
  display: none;
}

.kuwashiku02{
  text-align: right;
    font-size: 18px;
}


@media only screen and (max-width: 599px) {
  .pc-none{
  display: block;
}

    .top-list.inner {
        padding: 60px 0 50px;
    }
    
.top-reason{
  padding-top: 0 !important;
}

.pack-p01 {
    font-size: 16px;
}

.nico-teen {
    display: block;
    padding: 15px;
}

.nicoteen01 {
    display: block;
    width: 100%;
}

.nicoteen02 {
    display: block;
    width: 100%;
}

.kuwashiku02 {
    text-align: left;
    font-size: 16px;
}
}

.reception{
  display: flex;
    justify-content: space-between;
}

.reception div{
  width: 50%;
    margin: 0 2%;
}

.staff-02box{
  display: flex;
  justify-content: space-between;
  margin-bottom: 7rem;
}

.man-staff{
  display: block;
    width: 47%;
}

.p02{
  font-size: 14px;
    margin: 10px 5px;
}

.p01 {
  line-height: 1.2;
  margin-bottom: 5px;
}

.p01 .post{
  padding-bottom: 5px;
}

.icon-incho{
  display: flex;
}

.incho-com:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 100%;
  margin-top: -15px;
  border: 15px solid transparent;
  border-left: 15px solid #e0edff;
}

.incho-com{
  position: relative;
  display: inline-block;
  margin: 1.5em 15px 0.5em 0;
  padding: 7px 10px;
  min-width: 120px;
  max-width: 100%;
  color: #555;
  font-size: 16px;
  background: #e0edff;
}

.incho-com p{
  padding: 10px;
}

.incho-com02{
  background: #ffeef3;
}

.incho-com02:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 100%;
  margin-top: -15px;
  border: 15px solid transparent;
  border-left: 15px solid #ffeef3;
}

.staff-03box{
  flex-wrap: wrap;
    justify-content: center;
}

.woman-box{
  margin-bottom: 50px;
  width: 50%;
}

.woman-box .icon-incho{
  margin-top: -20px;
}



@media only screen and (max-width: 599px) {
  .staff-02box {
    display: block;
    justify-content: space-between;
    margin-bottom: 5rem;
}

.man-staff {
    display: block;
    width: 100%;
    margin-bottom: 20px;
}

.incho-com {
    position: relative;
    display: inline-block;
    margin: 1.5em 10px 0.5em 0;
    padding: 7px 0px;
    width: 80%;
}

.icon-egusa{
  margin-top: 35px;
  width: 20%;
}

.incho-com p {
    padding: 8px;
    font-size: 13px;
    text-align: center;
}

.p01 {
  width: 80%;
    margin: 0 auto 5px;
    text-align: center;
}

.p02 {
    font-size: 14px;
    margin: 10px 10px;
}

.man02-img{
  width: 80%;
    margin: auto;
}

.woman-box {
    margin-bottom: 50px !important;
}
}


/* 2024.12.09 */

.note-li{
  width: 80px;
}

.footer-note{
 width:140px;
}

.note-h3{
  padding-right: 60px;
}

#dropmenu{
  max-width: 1100px !important;
}

#dropmenu li a {
    align-items: center;
    display: flex;
    letter-spacing: 1px;
    font-size: 16px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    padding: 0px 10px;
    position: relative;
}

.note-h3 {
    padding-right: 110px;
}


@media only screen and (max-width: 1024px) {
.note-li a{
    width: 120px !important;
}
}


@media only screen and (max-width: 599px) {
.note-li a{
        width: 130px !important;
    }
    
    .note-h3 {
    width: 200px;
    }
    
    .footer-note {
    width: 100px;
}
}


.ta-c{
  text-align: center;
}



/* 2025.03.18 */

.top-message{
  width: 76%;
    margin: auto;
    padding-top: 3rem;
}

.top-message-img{
 width: 88%;
    margin: auto;
}

.top-message-img img{
  width: 100%;
}

.top-message-text{
  width: 88%;
    margin: 1px auto 2rem;
    background: #e9e8e8;
    padding: 30px;
}


@media only screen and (max-width: 1024px) {
  .top-message-text, .top-message-img {
    width: 100%;
  }
}

@media only screen and (max-width: 599px) {
.top-message {
    width: 94%;
}

.top-message-text {
    padding: 20px;
}
}


.shisetsu{
  width: 217px;
    background: #fff;
    margin: 15px auto 0;
    padding: 15px 30px;
    border-radius: 30px;
}

.shisetsu p{
  font-size: 18px;
}


@media only screen and (max-width: 599px) {
.shisetsu p{
  font-size: 14px;
}

.shisetsu {
    width: 183px;
}
}

/* 2025/05/30 */
/* おとなの矯正ぺージ */
.top-flow.ver02 ul {
  display: flex;
  flex-wrap: wrap;
}

.top-flow.ver02 li {
  float: none;
  height: auto;
}

.top-flow.ver02 li .text {
  padding: 10px;
  text-align: left;
  font-size: 16px;
}

.top-flow.ver02 li .in {
  height: auto;
}

@media(max-width:599px){
.top-flow.ver02 li {
  width: 100%;
}    
}

.list-price li{
  display: flex;
  align-items: center;
  position: relative;
}

.list-price li .ttl{
  width: 7.5em;
  font-size: 16px;
}

.list-price li .ttl::after{
  content: "▶";
  display: block;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 8em;
  z-index: 1;
}

.list-price li .price{
  width: 50%;
  flex-grow: 1;
  color: #c20d0d;
  margin-left: 1em;
  font-size: 30px;
}

.list-price li .price .small{
  font-size: 0.5em;
}

/* こどもの矯正ぺージ */
.ort_ttl{
  font-family: "Noto Sans JP", sans-serif;
  font-weight: bold;
  display: flex;
  justify-content: center;
  align-items: center;
  background: linear-gradient(transparent 80%, #F1A1A5 30%);
  width: fit-content;
  margin-left: auto;
  margin-right: auto;  
}

.ort_ttl::before{
  content: "";
  display: block;
  background-image: url('/upload/tenant_1/b19df5055ecdee7c6b30780c54054da2.webp');
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  width: 80px;
  height: 110px;
  flex-shrink: 0;
}

.ort_ttl.ver02{
  flex-direction: row-reverse;
  color: #454545;
  background: linear-gradient(transparent 80%, #70BFD7 30%);
}

.ort_ttl.ver02::before{
  background-image: url('/upload/tenant_1/6b425c0ba184d5e4517ee1097027af8f.webp');
}

.ort_ttl.ver03{
  background: linear-gradient(transparent 80%, #FFF064 30%);
}

.ort_ttl.ver03::before{
  background-image: url('/upload/tenant_1/82de8915415a787bd6b3e463db95a7e1.webp');
}

.ort{
  font-family: "Noto Sans JP", sans-serif;
}

.tex_w{
  color: #fff;
}

.ort_bgimage01{
/*   background-color: #ffffff;
background-image: radial-gradient(circle, #06b6d4 1px, transparent 1px), radial-gradient(circle, #06b6d4 1px, transparent 1px);
background-position: 0 0, 6px 12px;
background-size: 12px 24px; */
  background-color: #FFDAE1;
  background-image: radial-gradient(circle, #edb3be 1px, transparent 1px), radial-gradient(circle, #edb3be 1px, transparent 1px);
  background-position: 0 0, 6px 12px;
  background-size: 12px 24px;
}

.ort_bgimage02{
  background-image: linear-gradient(0deg, transparent calc(100% - 1px), #f0f0f0 calc(100% - 1px)),
                    linear-gradient(90deg, transparent calc(100% - 1px), #f0f0f0 calc(100% - 1px));
  background-size: 16px 16px;
  background-repeat: repeat;
  background-position: center center;
}

.ort_bgimage03{
  background-color: #FFFBE0;
  background-image: radial-gradient(circle, #FFFFFF 1px, transparent 1px), radial-gradient(circle, #FFFFFF 1px, transparent 1px);
  background-position: 0 0, 6px 12px;
  background-size: 12px 24px;
}

.ort_img{
  border-radius: 20px;
  overflow: hidden;
  border: 5px solid #f1a1a5;
}

.trouble-box.ort .t-box ul {
    padding: 20px;
    background-color: #fff;
    border-radius: 20px;
}

.trouble-box.ort .t-box li:before {
    content: "■";
    background: none;
    width: 19px;
    height: 15px;
}

.ort_obi{
  border: 5px solid #70BFD7;
  font-weight: bold;
  padding: 0.5em;
}

.fwb{
  font-weight: bold;
}

.fit{
  width: fit-content;
}

.nico-container{
  background-color: #fff;
  padding: 20px;
}

.nico01{
  font-size: 42px;
  border: 5px solid #6FBFD8;
  background-color: #fff;
  box-shadow: 10px 10px #6FBFD8;
  text-align: center;
  margin-bottom: 20px;
}

.nico02{
  display: flex;
}

.nico02 .in01{
  width: 30%;
  background-color: #FDC0C5;
  font-size: 24px;
  text-align: center;
  line-height: 1;
  padding: 0.5em 0;
}

.nico02 .in01 .mini,
.nico02 .in02 .mini{
  font-size: 70%;
}

.nico02 .in02{
  width: 70%;
  background-color: #FFF064;
  font-size: 24px;
  text-align: center;
  line-height: 1;
  padding: 0.5em 0;
}

.nico02 .in02.ver02{
  width: 100%;
}

.nico03{
  display: flex;
  justify-content: center;
  align-items: center;
}

.nico03 .in{
  width: 120px;
  height: 120px;
  border: 3px solid #FDC0C5;
  border-radius: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
}

.nico03 .in.in02{
  border: none;
}

.nico03 .in.in03{
  border: 3px solid #FBF2B6;
}

.nico04 li{
  padding-left: 1em;
  text-indent: -1em;
}

.nico04 li::before{
  content: "・";
}

/* .border-yajirushi{
  border-bottom: 3px solid #4198B2;
} */

@media(max-width:599px) {
.ort_ttl::before{
  width: 50px;
  height: 75px;
}

.nico01{
  font-size: 30px;
}

.nico02 .in01 {
  font-size: 20px;
}

.nico02 .in02 {
  font-size: 20px;
}

.nico02 .in02 {
  width: 100%;
}

.nico03 .in.in02 {
  width: fit-content;
  margin-right: 10px;
  margin-left: 10px;
}
}

/* 2025/06/02 */
.w-fit{
  width: fit-content;
  margin: 0 auto 20px;
}

/* 2025/06/04 */

.sp-br{
  display: none;
}

.pc-none{
  display: none;
}

.sp-none{
  display: block;
}

.nicoprice{
  color: #6fbfd8;
  font-weight: bold;
  font-size: 30px;
  text-align: center;
  border-left: 1px dotted;
  border-right: 1px dotted;
}

.nicoprice .strong{
  font-size: 1.5em;
}

.meritdemerit-container{
  background-color: #fff;
  border-radius: 20px;
  padding: 20px;
}

.list-merit{
  border: 2px solid #fdc0c5;
  padding: 20px;
  border-radius: 20px;
}

.list-merit.ver02{
  border: 2px solid #C4C4C4;
  flex-grow: 1;
}

.list-merit li{
  padding-left: 1em;
  text-indent: -1em;
}

.list-merit li::before{
  content: "・";
}

.meritbox{
  border: 2px solid #C4C4C4;
  padding: 20px;
  border-radius: 20px;
  flex-grow: 1;
}

.meritttl{
  background: linear-gradient(transparent 80%, #6fbfd8 30%);
  width: fit-content;
  margin: 0 auto;
}

.grow{
  display: flex;
  flex-direction: column;
}

.w31{
  width: 31%;
}

.w49{
  width: 49%;
}

@media(max-width:599px) {
.sp-br{
  display: block;
}

.pc-none{
  display: block;
}

.sp-none{
  display: none;
}

.meritdemerit-container>div .item1 {
  order: 2;
}

.meritdemerit-container>div .item2 {
  order: 1;
}

.meritdemerit-container>div .item3{
  order: 3;
}

.w31{
  width: 100%;
}

.w49{
  width: 100%;
}

.meritttl{
  margin: 0 auto 20px;
}
}

/* 2025/06/09 */
.nico03{
  margin-top: 20px;
}

.nico03 .in.in03 {
  position: relative;
}

.nico03 .in.in03::before {
  content: "【5年間保証】";
  position: absolute;
  top: -30px;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  font-weight: bold;
}

.nico03 .in.in03.ver02::before {
  content: "【1年半保証】";
  position: absolute;
  top: -30px;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
}

.nico02 .in02.ver02 {
  width: 100%;
}


/* 2025.09.10 */

.sp-none{
  display: block;
  margin-top: 3rem;
}

.insta-03{
  display: flex;
  justify-content: space-between;
  margin: 2rem auto 3rem;
}

.insta-03 div{
  width: 30%;
}

.insta-more a, .insta-more02 a{
  background: #f1e5ed;
}

@media(max-width:599px) {
  .sp-none{
  display: none;
}

.pc-none{
  display: block;
}

.insta-box02{
  margin-top: 3rem;
}

.insta-02{
  display: flex;
  justify-content: space-between;
  margin: 1rem auto 2rem;
}

.insta-02 div{
  width: 47%;
}

}

