  @charset "utf-8";

:root {
	--text-color: #5C4C2C;
    --main-color: #F2879B;
    --bdr-color: #D5CDC0;
}
/* 汎用 */
a img { transition: opacity .8s;}
a:hover img { opacity: 0.6; filter: alpha(opacity=60); -moz-opacity: 0.6;}
.mb10 { margin-bottom: 10px; }
.mb15 { margin-bottom: 15px; }
.mb20 { margin-bottom: 20px; }
.mb30 { margin-bottom: 30px; }
.mb40 { margin-bottom: 40px; }
.mb45 { margin-bottom: 45px; }
.mb50 { margin-bottom: 50px; }
.mb60 { margin-bottom: 60px; }
.mb70 { margin-bottom: 70px; }
.mb80 { margin-bottom: 80px; }
.mb90 { margin-bottom: 90px; }
.mb100 { margin-bottom: 100px; }
.mr10 { margin-right: 10px; }
.mr15 { margin-right: 15px; }
.mr20 { margin-right: 20px; }
.mr30 { margin-right: 30px; }
.mr40 { margin-right: 40px; }
.tal { text-align: left; }
.tac { text-align: center; }
.tar { text-align: right; }
.st { font-weight: bold; }
.fl { float: left; }
.fr { float: right; }
.fs16 { font-size: 16px; }
.fs18 { font-size: 18px; }
.fs20 { font-size: 20px; }
.fs22 { font-size: 22px; }
.fs24 { font-size: 24px; }
.fw300 { font-weight: 300; }
.fw400 { font-weight: 400; }
.fw500 { font-weight: 500; }
.fw600 { font-weight: 600; }
.fw700 { font-weight: 700; }
.fw800 { font-weight: 800; }
.flex { display: -webkit-flex; display: flex; -webkit-flex-wrap: wrap; flex-wrap: wrap; justify-content: space-between; }
.flex_not_justify { display: -webkit-flex; display: flex; -webkit-flex-wrap: wrap; flex-wrap: wrap; }

/* メインの日本語フォント */
.f_min { font-family: "游明朝", "Yu Mincho", "Hiragino Mincho Pro", serif; }
.f_hira { font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", sans-serif; }
.f_gothic { font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic M", "YuGothic", sans-serif; }
.f_hirago { font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", sans-serif; }
.f_zenkaku { font-family: "Zen Kaku Gothic New", sans-serif; }


/* 英字用フォント */
.f_times { font-family: TimesNewRoman, "Times New Roman", Times, Baskerville, Georgia, serif; }
.f_arial { font-family: Arial, "Helvetica Neue", Helvetica, sans-serif; }
.f_poppins { font-family: "Poppins", sans-serif; }

/* 画像フィット用 */
.fit_img { display: flex; justify-content: center; align-items: center; /*IE用*/ flex-direction: column; }
.fit_img img { max-width: 100%; max-height: 100%; width: auto; height: auto; }
.regacy_fit_img { display: relative; overflow: hidden; }
.regacy_fit_img img { position: absolute; left: -50%; right: -50%; top: -50%; bottom: -50%; margin: auto; max-width: 100%; max-height: 100%; width: auto; height: auto; }
.ofi { object-fit: cover; font-family: 'object-fit:cover; '; }

/*===========
inview
===========*/

.inview {
  opacity: 0;
  transform: translate(0, 20%);
  transition: 2s;
}
.inview.is-show {
  transform: translate(0, 0);
  opacity: 1;
}

/* ズレ表示用sample */



/*PC用*/
@media print, screen {
	.pc { display: block !important }
	.sp { display: none !important }
	.h_menu, #sp_global_nav { display: none; }


    /* 汎用ページ */
    .inner_1200 {
        margin: 0 auto;
        width: 1200px;
        max-width: 95%;
    }
    .inner h2 {
        font-size: 36px;
        font-weight: 700;
        letter-spacing: 0.04em;
        text-align: center;
    }
    .inner h2 .ttl_en {
        display: block;
        padding-bottom: 8px;
        color: var(--main-color);
        font-size: 18px;
        font-weight: 600;
        letter-spacing: 0.04em;
    }
    .follow_block {
        position: fixed;
        width: 510px;
        height: 118px;
        right: 24px;
        bottom: 24px;
        border-radius: 12px;
        border: 2px solid var(--text-color);
        z-index: 999;
        box-shadow: 6px 6px 0 rgba(191,186,176,.7);
        background: #fff;
    }
    .follow_block ul {
        padding: 15px 0 0 20px;
        width: 83%;
        background: #fff;
        border-radius:  12px 0 0 12px;
        justify-content: left;
        align-items: flex-start;
    }
    .follow_block ul li {
        position: relative;
    }
    .follow_block ul li::before {
        content:'';
        position: absolute;
        left: 0;
        top: 0;
        bottom: 0;
        margin: auto;
        width: 1px;
        height: 54px;
        background: var(--bdr-color);
    } 
    .follow_block ul li a {
        display: block;
        padding: 0 30px;
        font-size: 16px;
        font-weight: 700;
        text-align: center;
        letter-spacing: 0.04em;
    }
    .follow_block ul li:first-of-type a {
        padding: 0 26px;
    }
    .follow_block ul li:last-of-type a {
        padding: 0 16px;
    }
    .follow_block ul li a span {
        display: block;
        margin-bottom: 4px;
    }
    .follow_block ul li a img {
        transition: 0.5s;
    }

    .follow_block .link_top {
        position: relative;
        display: flex;
        justify-content: center;
        align-items: center;
        padding-top: 40px;
        width: 84px;
        color: #fff;
        font-size: 18px;
        font-weight: 600;
        letter-spacing: 0.04em;
        text-align: center;
        border-radius:  0 8px 8px 0;
        background: var(--text-color);
    }
    .follow_block .link_top::before {
        content:'';
        position: absolute;
        top: 30px;
        left: 0;
        right: 0;
        margin: auto;
        width: 26px;
        height: 27px;
        background: url(../../images/src/common/arrow_brown_top.svg) no-repeat left top / 100%;
    }
    .bnr_area {
        padding: 50px;
        background: url(../../images/src/common/bnr_bg.png);
        background-size: cover;
    }
    .bnr_area ul {
        gap: 30px;
        align-items: center;
        justify-content: center;
    }

    .cta_area {
        padding: 70px 0 90px;
        background: url(../../images/src/common/cta_bg.png);
        background-size: cover;
    }
    .cta_area .inner h2 {
        color: #fff;
    }
    .cta_area .inner h2 span {
        font-size: 46px;
        font-weight: 700;
        letter-spacing: 1.44px;
    }
    .cta_area .inner h2 .ttl_en {
        color: #fff;
        font-size: 20px;
    }
    .cta_area .inner h2 .quote {
        position: relative;
    }
    .cta_area .inner h2 .quote::before,
    .cta_area .inner h2 .quote::after {
        content:'';
        position: absolute;
        width: 27px;
        height: 21px;
    }
    .cta_area .inner h2 .quote::before {
        top: 6px;
        left: -21px;
        background: url(../../images/src/common/quote01.svg) no-repeat left top / 100%;
    }
    .cta_area .inner h2 .quote::after {
        bottom: -3px;
        right: -13px;
        background: url(../../images/src/common/quote02.svg) no-repeat left top / 100%;
    }
    .cta_area .inner .cta_txt {
        margin: 20px auto 0;
        color: #fff;
        font-size: 18px;
        font-weight: 700;
        letter-spacing: 0.04em;
    }
    .cta_area .inner .cta_block {
        margin-top: 52px;
    }
    .cta_area .inner .flex,
    #contact .cta_box .flex {
        justify-content: center;
        gap: 40px;
    }
    .cta_area .inner a {
        display: block;
    }
    .cta_area .inner .cta_box,
    #contact .cta_box {
        position: relative;
        display: flex;
        flex-direction: column;
        padding: 27px;
        width: 380px;
        border-radius: 12px;
        background: #fff;
        box-shadow: 10px 10px 0 #E0788C;
        transition: all 0.3s ease;
    }
    .cta_area.ft_cta .inner .cta_box,
    #contact .cta_box {
        width: 520px;
    }
    .cta_area .inner a.cta_box::after {
        content:'';
        position: absolute;
        bottom: 14px;
        right: 14px;
        width: 30px;
        height: 31px;
        background: url(../../images/src/common/arrow_pink_right01.svg) no-repeat left top / 100%;
        transition: .7s;
    }
    .cta_area .inner .cta_box .ico,
    #contact .cta_box .ico {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        height: 56px;
    }
    .cta_area .inner .cta_box .pink_tl,
    #contact .cta_box .pink_tl {
        color: var(--main-color);
        font-size: 20px;
        font-weight: 700;
        text-align: center;
        letter-spacing: 0.04em;
    }

    .cta_area.ft_cta .inner .cta_box .pink_tl,
    #contact .cta_box .pink_tl {
        font-size: 22px;
    }
    .cta_area .inner .cta_box .ttl,
    #contact .cta_box .ttl {
        font-size: 30px;
        font-weight: 700;
        letter-spacing: 0.04em;
        text-align: center;
        display: flex;
        flex-direction: column;
        justify-content: center;
        flex: 1;
    }
    .cta_area .inner .cta_box .ttl a,
    #contact .cta_box .ttl a {
        font-size: 38px;
        font-weight: 600;
        letter-spacing: 0.07em;
    }
    .cta_area.ft_cta  .inner .cta_box .ttl,
    #contact .cta_box .ttl {
        font-size: 34px;
    }
    .cta_area.ft_cta .inner .cta_box .ttl a,
    #contact .cta_box .ttl a {
        font-size: 44px;
    }
    .cta_area .inner .cta_box dl,
    #contact .cta_box dl {
        gap: 0 15px;
    }
    .cta_area .inner .cta_box dl dt,
    .cta_area .inner .cta_box dl dd,
    #contact .cta_box dl dt,
    #contact .cta_box dl dd {
        font-size: 14px;
        font-weight: 500;
        letter-spacing: 0.04em;
    }

    /*-------------
    TOP page
    ---------------*/
    .hero_block {
        position: relative;
        z-index: 10;
    }
    .hero_block .hero_txt_area {
        position: absolute;
        /*top: 179px;
        left: 104px;*/
        top: clamp(10.188rem, 6.063rem + 5.16vw, 12.25rem);
        left: clamp(1.625rem, -8.125rem + 12.19vw, 6.5rem);
        text-shadow: 2px 3px 1px #fff;
    }
    .hero_block .hero_txt_area p {
        font-size: 20px;
        font-weight: 500;
        letter-spacing:  0.04em;
        line-height: 2.6;
    }
    .hero_block .hero_txt_area .hero_text {
        font-size: clamp(1.901rem, 1.204rem + 0.87vw, 2.25rem);
        font-weight: 500;
        letter-spacing: 0.05em;
    }
    .hero_block .hero_txt_area .hero_text .quote {
        position: relative;
        font-size: clamp(2.257rem, 1.272rem + 1.23vw, 2.75rem);
        font-weight: 700;
    }
    .hero_block .hero_txt_area .hero_text .quote::before,
    .hero_block .hero_txt_area .hero_text .quote::after {
        content: '';
        position: absolute;
        width: 23px;
        height: 18px;
    }
    .hero_block .hero_txt_area .hero_text .quote::before {
        top: 0;
        left: -18px;
        background: url(../../images/src/top/quote01.svg) no-repeat left top / 100%;
    }
    .hero_block .hero_txt_area .hero_text .quote::after {
        bottom: 0;
        right: -9px;
        background: url(../../images/src/top/quote02.svg) no-repeat left top / 100%;
    }

    .hero_block .hero_txt_area h1 {
        margin: -17px 0 26px;
        color: var(--main-color);
        font-size: clamp(3.208rem, 1.874rem + 1.67vw, 3.875rem);
        font-weight: 700;
        letter-spacing: 0.04em;
    }
    .hero_block .hero_txt_area h1 span {
        font-size: clamp(2.614rem, 1.593rem + 1.28vw, 3.125rem);
        font-weight: 500;
        letter-spacing: 0;
    }
    .hero_block .hero_txt_area h1 .txtcolor {
        color: var(--text-color);
        font-size: clamp(3.208rem, 1.874rem + 1.67vw, 3.875rem);
        font-weight: 700;
        letter-spacing: -0.1em;
    }
    .hero_block .hero_txt_area .txt {
        margin-bottom: 43px;
        line-height: 2.23;
    }
    .hero_block .hero_txt_area .hero_btn {
        margin-left: -6px;
        width: 359px;
        text-shadow: none;
    }
    .hero_block .hero_txt_area .hero_btn a {
        position: relative;
        display: block;
        padding: 10px 0 13px 8px;
        width: 100%;
        color: #fff;
        font-size: 20px;
        font-weight: 700;
        letter-spacing: 0.04em;
        text-align: center;
        border-radius: 195px;
        border: 5px solid #FCE1E6;
        background: var(--main-color);
    }
    .hero_block .hero_txt_area .hero_btn a::before,
    .hero_block .hero_txt_area .hero_btn a::after {
        content:'';
        position: absolute;
        top: 0;
        bottom: 0;
        margin: auto;
    }
    .hero_block .hero_txt_area .hero_btn a::before {
        left: 28px;
        width: 42px;
        height: 42px;
        background: url(../../images/src/top/ico_clinic.svg) no-repeat left top / 100%;
    }
    .hero_block .hero_txt_area .hero_btn a::after {
        right: 22px;
        width: 26px;
        height: 27px;
        background: url(../../images/src/common/arrow_white_right01.svg) no-repeat left top / 100%;
    }
    .hero_block .hero_img {
        margin-left: auto;
        /*width: clamp(50.313rem, -23.188rem + 91.88vw, 87.063rem);*/
        width: 63.63583%;
    }
    .hero_block .hero_img img {
        /*object-position: left;*/
        /*height: clamp(45rem, 20.125rem + 31.09vw, 57.438rem);*/
        height: 919px;
        border-bottom-left-radius: 45px;
    }
    #hero--scroll {
        position: absolute;
        left: 39px;
        top: 102px;
        font-weight: 600;
        letter-spacing: 1px;
        height: 45px;
        line-height: 120%;
    }

    #hero--scroll span {
        display: inline-block;
        transform: rotate(-90deg);
        transform-origin: left top;
        position: absolute;
        top: -10px;
        font-size: 14px;
        color: var(--main-color);
    }

    #hero--scroll:before {
        content: "";
        position: absolute;
        left: .5rem;
        top: 0;
        height: 0;
        width: 1px;
        background-color: var(--main-color);
        -webkit-animation: scroll 2s cubic-bezier(1,0,0,1) 1s infinite;
        animation: scroll 2s cubic-bezier(1,0,0,1) 1s infinite;
        -webkit-animation-fill-mode: both;
        animation-fill-mode: both
    }

    @-webkit-keyframes scroll {
        0% {
            bottom: auto;
            top: 0;
            height: 0
        }
        50% {
            height: 45px
        }
        100% {
            top: auto;
            bottom: 0;
            height: 0
        }
    }
    @keyframes scroll {
        0% {
            bottom: auto;
            top: 0;
            height: 0
        }
        50% {
            height: 45px
        }
        100% {
            top: auto;
            bottom: 0;
            height: 0
        }
    }

    .top_sec01 {
        padding: 295px 0 90px;
        position: relative;
        margin-top: -205px;
        background: url(../../images/src/top/sec01_bg01.png);
    }
    .top_sec01 .information_block {
        margin: 0 auto;
        width: 1200px;
        max-width: 95%;
    }
    .top_sec01 .information_block .flex > div {
        padding: 35px;
        width: calc(50% - 20px);
        height: 492px;
        border-radius: 12px;
        border: 5px solid #fff;
        background: #fff;
    }
    .top_sec01 .information_block .ttl {
        margin-bottom: 14px;
        font-size: 26px;
        font-weight: 700;
        letter-spacing: 0.04em;
        text-align: center;
    }
    .top_sec01 .information_block .txt,
    .top_sec01 .information_block .txt02 {
        font-size: 16px;
        font-weight: 300;
        letter-spacing: 0.04em;
        text-align: center;
    }
    .top_sec01 .information_block .txt02 {
        font-weight: 500;
    }
    .top_sec01 .information_block .recp_block table {
        margin: 14px auto 16px;
    }

    /*.top_sec01 .information_block .recp_block table thead,
    .top_sec01 .information_block .recp_block table tbody,
    .top_sec01 .information_block .recp_block table tbody tr:nth-of-type(2) {
        border-bottom: 1px solid #D5CDC0;
    }
    .top_sec01 .information_block .recp_block table tbody tr:nth-of-type(1),
    .top_sec01 .information_block .recp_block table tbody tr:nth-of-type(3) {
        border-bottom: 2px dotted #D5CDC0;
    }*/
    .top_sec01 .information_block .recp_block table thead,
    .top_sec01 .information_block .recp_block table tbody,
    .top_sec01 .information_block .recp_block table tbody tr:nth-of-type(2) {
        border-bottom: 1px solid #D5CDC0;
    }
    .top_sec01 .information_block .recp_block table tbody tr:nth-of-type(1) td,
    .top_sec01 .information_block .recp_block table tbody tr:nth-of-type(3) td {
        border-bottom: 2px dotted #D5CDC0;
    }


    .top_sec01 .information_block .recp_block table thead th,
    .top_sec01 .information_block .recp_block table thead td,
    .top_sec01 .information_block .recp_block table tbody th {
        font-family: "Poppins", sans-serif;
        font-size: 16px;
        font-weight: 600;
        letter-spacing: 0.04em;
        text-align: center;
    }
    .top_sec01 .information_block .recp_block table thead th {
        padding-right: 10px;
    }
    .top_sec01 .information_block .recp_block table thead th i {
        display: inline-block;
        margin: 2px 0 0;
    }
    .top_sec01 .information_block .recp_block table thead td {
        padding-bottom: 13px;
        width: 64px;
    }
    .top_sec01 .information_block .recp_block table tbody th {
        text-align: center;
        vertical-align: middle;
        width: 112px;
    }
    .top_sec01 .information_block .recp_block table tbody td {
        position: relative;
        padding: 15px 0 8px;
        text-align: center;
        letter-spacing: 0.04em;
        white-space: nowrap;
    }
    .top_sec01 .information_block .recp_block table tbody td a {
        padding: 0 4px;
        color: var(--main-color);
        font-size: 16px;
        font-weight: 700;
        border: 2px solid var(--main-color);
        border-radius: 4px;
    }
    .top_sec01 .information_block .recp_block table tbody td small {
        display: block;
        font-size: 12px;
        font-weight: 900;;
    }
    
    .top_sec01 .information_block .recp_block table tbody td a.men {
        color: #87BBF2;
        border-color: #87BBF2;
    }


    .top_sec01 .information_block .flex .news_block {
        overflow-y: scroll;
    }
    .top_sec01 .information_block .flex .news_block .ttl {
        margin-bottom: 24px;
    }
    .top_sec01 .information_block .flex .news_block a dl {
        position: relative;
        padding: 16px 61px 24px 14px;
        border-top: 1px solid var(--bdr-color);
        transition: .7s;
    }
    .top_sec01 .information_block .flex .news_block a dl::before {
        content:'';
        position: absolute;
        top: 0;
        right: 14px;
        bottom: 0;
        margin: auto;
        width: 26px;
        height: 27px;
        background: url(../../images/src/common/arrow_pink_right01.svg) no-repeat left top / 100%;
        transition: .7s;
    }
    .top_sec01 .information_block .flex .news_block a:last-of-type dl {
        border-bottom: 1px solid var(--bdr-color);
    }

    .top_sec01 .information_block .flex .news_block a dl dt {
        margin-bottom: 8px;
        font-size: 18px;
        font-weight: 700;
        line-height: 1.6;
        letter-spacing: 0.04em;
    }
    .top_sec01 .information_block .flex .news_block a dl dt span {
        display: block;
        color: #AC916B;
        font-size: 14px;
        font-weight: 500;
        line-height: 2.5;
    }
    .top_sec01 .information_block .flex .news_block a dl dd {
        font-size: 16px;
        font-weight: 400;
        line-height: 1.625;
        letter-spacing: 0.04em;
    }

    .top_sec02 {
        padding: 120px 0 130px;
    }
    .top_sec02 .sec02_block + .sec02_block {
        margin-top: 130px;
    }
    .top_sec02 .box {
        margin-left: clamp(2.5rem, -12.5rem + 18.75vw, 10rem);
        width: 640px;
    }
    .top_sec02 .even .box {
        margin: 0 clamp(2.5rem, -12.5rem + 18.75vw, 10rem) 0 auto;
        width: 640px;
    }
    .top_sec02 .box h2 {
        margin-bottom: 15.5px;
        text-align: left;
        font-size: 48px;
    }
    .top_sec02 .box .txt {
        margin-bottom: 30px;
        font-size: 18px;
        font-weight: 400;
        line-height: 38px;
        letter-spacing: 0.04em;
    }
    .top_sec02 .box .list_btn {
        margin-bottom: 42px;
    }
    .top_sec02 .box .list_btn li a {
        display: block;
        width: 100%;
        border-top: 1px solid var(--bdr-color);
        position: relative;
        padding: 22px 0 22px 60px;
        font-size: 20px;
        font-weight: 700;
        letter-spacing: 0.04em;
        transition: .7s;
    }
    .top_sec02 .box .list_btn li:last-of-type a {
        border-bottom: 1px solid var(--bdr-color);
    }
    .top_sec02 .box .list_btn li a::before {
        content:'';
        position: absolute;
        top: 0;
        bottom: 0;
        left: 20px;
        margin: auto;
        width: 26px;
        height: 27px;
        background: url(../../images/src/common/arrow_pink_right01.svg) no-repeat left top / 100%;
        transition: .7s;
    }
    .top_sec02 .box .btn {
        margin-left: -6px;
        width: 280px;
    }
    .top_sec02 .box .btn a {
        display: block;
        position: relative;
        padding: 15px 0;
        width: 100%;
        text-indent: -1.2em;
        font-size: 20px;
        font-weight: 700;
        letter-spacing: 0.04em;
        text-align: center;
        border-radius: 180px;
        border: 6px solid #FCE1E6;
        background: #fff;
        transition: .7s;
    }
    .top_sec02 .box .btn a::before,
    .top_sec02 .box .btn a::after {
        content:'';
        position: absolute;
        top: 0;
        bottom: 0;
        margin: auto;
    }
    .top_sec02 .box .btn a::before {
        left: 22.5px;
        width: 19px;
        height: 17px;
        background: url(../../images/src/top/check_pink.svg) no-repeat left top / 100%;
    }
    .top_sec02 .box .btn a::after {
        right: 16px;
        width: 26px;
        height: 27px;
        background: url(../../images/src/common/arrow_pink_right01.svg) no-repeat left top / 100%;
        transition: .7s;
    }

    .top_sec02 .img {
        /*width: 53.125%;*/
        width: clamp(34.5rem, -24rem + 73.13vw, 63.75rem);
    }
    .top_sec02 .img img {
        object-position: center;
        height: 602px;
        border-radius: 12px 0 0 12px;
    }
    .top_sec02 .even .img img {
        object-position: center;
        height: 602px;
        border-radius: 0 12px 12px 0;
    }


    .top_sec03 {
        padding: 80px 0 128px;
        background: url(../../images/src/top/bg_orange.png);
    }
    .top_sec03 .flex {
        margin-top: 37px;
        justify-content: center;
        gap: 0 45px;
    }
    .top_sec03 .parts {
        position: relative;
        display: block;
        padding: 10px;
        width: 370px;
        border-radius: 12px;
        background: #fff;
        box-shadow: 8px 8px 0 rgba(169,146,123,.4);
        transition: all 0.3s ease;
    }
    .top_sec03 .parts::after {
        content: '';
        position: absolute;
        bottom: 20px;
        right: 20px;
        width: 30px;
        height: 31px;
        background: url(../../images/src/common/arrow_pink_right01.svg) no-repeat left top / 100%;
        transition: .7s;
    }
    .top_sec03 .parts .img img {
        border-radius: 12px 12px 0 0;
    }
    .top_sec03 .parts .ttl {
        margin: 26px 0 15px 20px;
        font-size: 26px;
        font-weight: 700;
        letter-spacing: 0.04em;
    }
    .top_sec03 .parts .txt {
        margin: 0 0 67px 20px;
        font-size: 18px;
        font-weight: 400;
        line-height: 1.88;
    }

    .top_swiper {
        width: 100%;
        height: 480px; /* 必要に応じて高さ調整 */
        overflow: hidden;
    }
    .top_swiper .swiper-wrapper {
        transition-timing-function: linear !important;
    }
    .top_swiper .swiper-slide {
        width: auto !important;
        height: 100%;
    }
    .top_swiper .swiper-slide img {
        height: 100%;
        width: auto;
        display: block; /* 余白防止 */
    }

    .top_sec04 {
        padding: 70px 0 120px;
    }
    .top_sec04 .inner {
        margin: 0 auto;
        width: 1202px;
        max-width: 95%;
    }
    .top_sec04 .inner .flex {
        margin-top: 37px;
    }
    .top_sec04 .inner .flex .img {
        width: 57.321%;
    }
    .top_sec04 .inner .flex .right {
        position: relative;
        width: 39.9334%;
    }
    .top_sec04 .inner .flex .right iframe {
        border-radius: 12px;
        width: 100%;
    }
    .top_sec04 .inner .flex .right .txt_btn a {
        display: block;
        position: relative;
        padding-right: 35px;
        font-size: 16px;
        font-weight: 700;
        letter-spacing: 0.04em;
        transition: .7s;
    }
    .top_sec04 .inner .flex .right .txt_btn a::after {
        content:'';
        position: absolute;
        top: 0;
        bottom: 0;
        right: 0;
        margin: auto;
        width: 26px;
        height: 27px;
        background: url(../../images/src/common/arrow_pink_right01.svg) no-repeat left top / 100%;
        transition: .7s;
    }
    .top_sec04 .inner .flex .right .circle_btn a {
        display: block;
        position: absolute;
        left: 0;
        bottom: 0;
        padding-top: 23px;
        width: 115px;
        height: 115px;
        font-size: 18px;
        font-weight: 700;
        line-height: 1.11;
        letter-spacing: 0.04em;
        text-align: center;
        border-radius: 50%;
        border: 7px solid #FCE1E6;
        background: #fff;
    }
    .top_sec04 .inner .flex .right .circle_btn a::after {
        content:'';
        position: absolute;
        left: 0;
        right: 0;
        bottom: 5px;
        margin: 0 auto;
        width: 26px;
        height: 27px;
        background: url(../../images/src/common/arrow_pink_right01.svg) no-repeat left top / 100%;
        transition: .7s;
    }
    

/* 下層
------------------*/
    .lower_mv {
        margin: 0 auto;
        width: 1920px;
        max-width: 100%;
    }
    .lower_mv .inner {
        position: relative;
        align-items: center;
    }
    .lower_mv .inner .left_text_area {
        position: absolute;
        left: clamp(30px, calc(30px + (116 * ((100vw - 1280px) / 640))), 146px);
        width: 582px;
    }
    
    .lower_mv .inner .left_text_area.privacy_text {
        width: 600px;

    }
    .lower_mv .inner .left_text_area .flex {
        margin-bottom: 16px;
        justify-content: left;
        align-items: center;
        gap: 0 26px;
    }
    .lower_mv .inner .left_text_area .img {
        width: 136px;
    }
    .lower_mv .inner .left_text_area .img img {
        transition-duration: 0.4s;
        opacity: 0;
        transform: scale(0);
    }
    body.body-js-loaded .lower_mv .inner .left_text_area img {
      transform: scale(1);
      opacity: 1;
    }
    .lower_mv .inner .left_text_area .ttl_en {
        color: var(--main-color);
        font-size: 18px;
        font-weight: 600;
        letter-spacing: 0.72px;
        text-transform: uppercase;
    }
    .lower_mv .inner .left_text_area h1 {
        font-size: 42px;
        font-weight: 700;
        line-height: 77.851px; /* 185.359% */
        letter-spacing: 0.04em;
        text-transform: uppercase;
    }
    .lower_mv .inner .left_text_area .mv_txt {
        font-size: 18px;
        font-weight: 700;
        line-height: 38px; /* 211.111% */
        letter-spacing: 0.04em;
    }
    .lower_mv .mv_img {
        margin-left: auto;
        width: 67.44%;
    }
    .lower_mv .mv_img img {
        object-position: left;
        height: 512px;
        border-radius: 0 0 0 70px;
    }

    /* breadcrumbs */
    .breadcrumbs {
        margin: 28px auto;
        padding: 0 30px 0 0;
        width: 1920px;
        max-width: 100%;
        text-align: right;
    }
    .breadcrumbs span {
        font-size: 16px;
        font-weight: 500;
        line-height: 38px; /* 237.5% */
        letter-spacing: 0.04em;
    }
    .breadcrumbs span a span {
        color: var(--main-color);
        font-size: 16px;
        font-weight: 700;
        line-height: 38px; /* 237.5% */
        letter-spacing: 0.04em;
    }

    /* page-navi */
    .wp-pagenavi {
        margin-top: 110px;
        text-align: center;
    }
    .wp-pagenavi a,
    .wp-pagenavi .current {
        display: inline-block;
        margin: 0 10px;
        font-size: 18px;
        font-weight: 700;
        width: 34px;
        height: 34px;
    }
    .wp-pagenavi .current{
        color: #fff;
        border-radius: 50%;
        background: var(--main-color); 
        line-height: 31px;
        text-align: center;
    }
    .wp-pagenavi .previouspostslink,
    .wp-pagenavi .nextpostslink {
        padding: 0 ;
    }

    .lower_section {
        margin: 0 auto;
        width: 1920px;
        max-width: 100%;
    }
    .lower_h2 {
        text-align: center;
    }
    .lower_h2 span {
        position: relative;
        font-size: 38px;
        font-weight: 700;
        letter-spacing: 0.04em;
    }
    .lower_h2 span::after {
        content:'';
        position: absolute;
        bottom: -20px;
        left: 0;
        right: 0;
        margin: auto;
        width: 80px;
        height: 3px;
        background: var(--main-color);
    }


    /* wysiwyg用 */
    .wysiwyg {}
    .wysiwyg p {
        margin-bottom: 70px;
        font-size: 18px;
        font-weight: 400;
        line-height: 2.1;
        letter-spacing: 0.04em;
    }
    .wysiwyg strong {
        color: var(--main-color);
        font-size:  1.444em;
        font-weight: 700;
    }
    .wysiwyg em {
        font-style: normal;
        font-weight: 700;
        background: #ffcdb5;
    }
    .wysiwyg img {
        border-radius: 14px;
    }
    .wysiwyg h2,
    #treatment h2 {
        position: relative;
        margin-bottom: 30px;
        padding: 24px 24px 24px 66px;
        font-size: 32px;
        font-weight: 700;
        border-radius: 7px;
        background: #FFEDF0;
    }
    .wysiwyg h2::before,
    #treatment h2::before {
        content:'';
        position: absolute;
        left: 40px;
        top: 24px;
        width: 4px;
        height: 50px;
        background: var(--main-color);
    }
    .wysiwyg h3,
    #treatment h3 {
        margin-bottom: 20px;
        padding-bottom: 26px;
        font-size: 28px;
        font-weight: 700;
        background: url(../../images/src/news/border.svg) no-repeat left bottom;
    }
    .wysiwyg h4,
    #treatment h4 {
        margin-bottom: 17px;
        padding-left: 15px;
        border-left: 3px solid var(--main-color);
        font-size: 22px;
        font-weight: 700;
        line-height: 1.72;
        letter-spacing: 0.04em;
    }
    .wysiwyg h5 ,
    #treatment h5 {
        display: inline-block;
        margin-bottom: 17px;
        padding: 4px 22px;
        color: #fff;
        font-size: 22px;
        font-weight: 700;
        letter-spacing: 0.04em;
        border-radius: 180px;
        background: var(--main-color);
    }
    .wysiwyg h6,
    #treatment h6 {
        color: var(--main-color);
        font-size: 20px;
        font-weight: 700;
        line-height: 1.9;
        letter-spacing: 0.04em;
    }
    .wysiwyg ul {
        margin-bottom: 40px;
    }
    .wysiwyg ol {
        counter-reset: number;
        margin-bottom: 40px;

    }
    .wysiwyg li {
        margin-bottom: 15px;
        font-size: 18px;
        font-weight: 400;
        letter-spacing: 0.04em;
    }
    .wysiwyg ul li {
        position: relative;
        padding-left: 22px;
    }
    .wysiwyg ul li::before {
        content:'';
        position: absolute;
        top: 0;
        left: 0;
        bottom: 0;
        margin: auto;
        width: 9px;
        height: 9px;
        border-radius: 50%;
        background: var(--text-color);
    }
    .wysiwyg ol li {
        counter-increment: number;
    }
    .wysiwyg ol li::before {
        content: counter(number, decimal-leading-zero);
        padding-right: 16px;
        color: var(--main-color);
        font-size: 22px;
        font-family: "Poppins", sans-serif;
        font-weight: 600;
        letter-spacing: 0.04em;
    }
    .wysiwyg table tr {
        border-top: 1px solid var(--bdr-color);
        border-bottom: 1px solid var(--bdr-color);
    }
    .wysiwyg table td {
        position: relative;
        padding: 38px 50px;
        font-size: 18px;
        font-weight: 400;
        letter-spacing: 0.04em;
    }
    .wysiwyg table tr td:first-of-type {
        width: 20%;
        font-weight: 700;
    }
    .wysiwyg table tr td:first-of-type:after {
        content:'';
        position: absolute;
        right: 0;
        top: 20px;
        bottom: 20px;
        margin: auto;
        width: 1px;
        background: var(--bdr-color);
    }

    /* ------------------------------------
    /  news お知らせ
    /-------------------------------------*/
    #news .inner_1000 {
        margin: 0 auto;
        width: 1000px;
        max-width: 95%;
    }
    #news .news_title_area {
        margin-bottom: 100px;
    }
    #news .news_title_area .date {
        color: #AC916B;
        font-size: 16px;
        font-weight: 500;
        line-height: 2.23;
        letter-spacing: 0.04em;
        text-align: center;
    }
    #news .news_title_area h2 {
        margin-bottom: 73px;
    }
    #news .news_title_area .eyecatch img {
        border-radius: 14px;
    }
    #news .news_content {
        margin-bottom: 120px;
    }
    /* ------------------------------------
    /  introduction クリニックのご紹介 
    /-------------------------------------*/

    #introduction h2.intro_ttl {
        font-size: 42px;
        font-weight: 700;
        letter-spacing: 0.04em;
        text-align: center;
    }
    #introduction .txt {
        font-size: 18px;
        font-weight: 400;
        line-height: 2.1;
        letter-spacing: 0.04em;
    }
    #introduction h2.intro_ttl span {
        color: var(--main-color);
        font-weight: 700;
    }
    #introduction h2.intro_ttl .up_txt {
        display: block;
        margin-bottom: 10px;
        font-size: 22px;
        font-weight: 700;
        letter-spacing: 0.04em;
    }
    #introduction .sec01 {
        margin-bottom: 140px;
        justify-content: left;
        align-items: center;
        gap: 0 90px;
    }
    #introduction .sec01 .img {
        width: 50%;
    }
    #introduction .sec01 .img img {
        border-radius: 0 12px 12px 0;
        object-position: left;
        height: 700px;
    }
    #introduction .sec01 .box {
        width: 540px;
        /*width: calc(30% - 30px);*/
    }
    #introduction .sec01 h2.intro_ttl {
        margin-bottom: 28px;
        font-size: 34px;
        line-height: 2;
        text-align: left;
    }
    #introduction .sec02 {
        margin: 0 calc(50% - 50vw);
        padding: 80px 0 140px;
        width: 100vw;
        background: url(../../images/src/introduction/bg01.png);
    }
    #introduction .sec02 .txt {
        margin: 35px 0 50px;
    }
    .intro_slide_block {
        width: 1200px;
        max-width: 70%;
        margin: 0 auto;
    }
    .intro_slide_block .mySwiper {
        overflow: visible;
    }
    .intro_slide_block .mySwiper .swiper-slide {
        width: 43.7%;
    }
    .intro_slide_block .mySwiper .swiper-slide img {
        border-radius: 14px 14px 0 0;
        width: 100%;
        height: auto;
    }
    .intorduction_slide_controls {
        position: relative;
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -webkit-align-items: center;
        -ms-flex-align: center;
        align-items: center;
        margin-top: 30px;
    }
    .intorduction_slide_btn {
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: justify;
        -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
        justify-content: space-between;
        width: 101px;
    }
    .intorduction_slide_btn .swiper-button-prev,
    .intorduction_slide_btn .swiper-button-next {
        position: relative;
        top: auto;
        right: auto;
        bottom: auto;
        left: auto;
        width: 44px;
        height: 44px;
        margin: 0;
        -webkit-transition: 0.3s;
        transition: 0.3s;
    }
    .intorduction_slide_btn .swiper-button-prev::after {
        content:'';
        width: 44px;
        height: 44px;
        background: url(../../images/src/common/arrow_brown_left.svg) no-repeat left top / 100%;
    }
    .intorduction_slide_btn .swiper-button-next::after {
        content:'';
        width: 44px;
        height: 44px;
        background: url(../../images/src/common/arrow_brown_right.svg) no-repeat left top / 100%;
    }
    .intorduction_slide_controls .swiper-pagination-progressbar.swiper-pagination-horizontal {
        position: relative;
        width: calc(100% - 147px);
        height: 7px;
        margin-left: auto;
        border-radius: 7px;
    }
    .intorduction_slide_controls .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
        background: var(--text-color);
        border-radius: 7px;
    }

    
    #introduction .sec03 {
        padding: 90px 0 120px;
    }
    #introduction .sec03 h2 {
        margin-bottom: 96px;
    }
    #introduction .sec03 .intro_equipment {
        justify-content: right;
        gap: 0 80px;
    }
    #introduction .sec03 .intro_equipment.even {
        margin: 123px 0;
        justify-content: left;
    }
    #introduction .sec03 .intro_equipment .img {
        width: 45.833333%;
    }
    #introduction .sec03 .intro_equipment .img img {
        object-position: center;
        width: 100%;
        height: 586px;
        border-radius: 12px 0px 0px 12px;
    }
    #introduction .sec03 .intro_equipment.even .img img {
        border-radius: 0px 12px 12px 0;
    }
    #introduction .sec03 .intro_equipment .box {
        display: flex;
        flex-direction: column;
        width: 600px;
    }
    #introduction .sec03 .intro_equipment .box h3 {
        margin-bottom: 14px;
        font-size: 40px;
        font-weight: 700;
        letter-spacing: 0.04em;
    }
    #introduction .sec03 .intro_equipment .box h3 span {
        padding-right: 24px;
        color: var(--main-color);
        font-size: 40px;
        font-weight: 500;
        letter-spacing: 0.04em;
        text-transform: uppercase;
    }

    #introduction .sec03 .intro_equipment .box .box_img {
        margin-top: auto;
    }
    #introduction .sec03 .intro_equipment .box .box_parts {
        margin-top: 20px;
        padding: 18px 17px 18px 26px;
        background: #F8EFE1;
    }
    #introduction .sec03 .intro_equipment .box .box_parts .ttl {
        font-size: 18px;
        font-weight: 700;
        line-height: 2.1;
        letter-spacing: 0.04em;
    }




 
    /* ------------------------------------
    /  treatment 診療内容 
    /-------------------------------------*/
    #treatment .txt {
        font-size: 18px;
        font-weight: 400;
        line-height: 2.11;
        letter-spacing: 0.04em;        
    }
    #treatment .sec01 {
        padding-bottom: 120px;
    }
    #treatment .sec01 .block_list {
        justify-content: left;
        gap: 24px;
    }
    #treatment .sec01 .block_list a {
        position: relative;
        display: flex;
        flex-direction: column;
        /*width: 282px;*/
        width: calc(25% - 18px);
        min-height: 116px;
        border: 1px solid var(--text-color);
        border-radius: 7px;
        background: #fff;
        box-shadow: 6px 6px rgba(92, 76, 44, .38);
    }
    #treatment .sec01 .block_list a::after {
        content:'';
        position: absolute;
        left: 0;
        right: 0;
        bottom: 14px;
        margin: auto;
        width: 24px;
        height: 24px;
        background: url(../../images/src/common/arrow_brown_bottom01.svg) no-repeat center bottom / 100%;
        transition: .4s;
    }
    #treatment .sec01 .block_list a p {
        padding: 15px 0 43px;
        font-size: 18px;
        font-weight: 700;
        letter-spacing: 0.04em;
        text-align: center;
        display: flex;
        justify-content: center;
        align-items: center;
        flex: 1 1 auto;
    }
    #treatment .sec02 {
        padding: 120px 0;
        background: url(../../images/src/top/sec01_bg01.png);
    }
    #treatment .sec02 .sec_block {
        position: relative;
        padding: 60px;
        border-radius: 14px;
        background: #fff;
    }
    #treatment .sec02 .sec_block + .sec_block {
        margin-top: 50px;
    }
    #treatment .sec02 .sec_block .show_box {
        margin-bottom: 40px;
    }
    #treatment .sec02 .sec_block .show_box .left_col {
        /*width: 520px;*/
        width: calc(50% - 20px);
    }
    #treatment .sec02 .sec_block .show_box .img {
        /*width: 500px;*/
        width: calc(50% - 40px);
    }
    #treatment .sec02 .sec_block .show_box .img img {
        border-radius: 12px;
    }
    #treatment .sec02 .sec_block .ttl {
        margin-bottom: 12px;
        font-size: 40px;
        font-weight: 700;
        letter-spacing: 0.04em;
    }
    #treatment .sec02 .sec_block .ttl span {
        padding-right: 24px;
        color: var(--main-color);
        font-size: 40px;
        font-weight: 500;
        letter-spacing: 0.04em;
    }
    #treatment .sec02 .sec_block .ttl span.st {
        padding-right: 0;
        color: var(--text-color);
        font-size: 28px;
        font-weight: 700;
    }
    
    #treatment .sec02 #sec02_10.sec_block .accordion .txt.mt20 {
        margin-top: 20px;
    }
    #treatment .sec02 .sec_block .accordion .txt a {
        text-decoration: underline;
    }
    
    #treatment .sec02 .sec_block .btn {
        position: absolute;
        left: 0;
        right: 0;
        bottom: 0;
        margin: auto;
    }
    #treatment .sec02 .sec_block .btn a {
        cursor: pointer;
        display: block;
        width: 100%;
        padding: 12px 0;
        text-align: center;
        border-radius: 0 0 14px 14px;
        background: var(--main-color);
    }
    #treatment .sec02 .sec_block .btn a span {
        position: relative;
        padding-right: 46px;
        color: #fff;
        font-size: 18px;
        font-weight: 700;
        line-height: 2.22;
        letter-spacing: 0.04em;
    }
    #treatment .sec02 .sec_block .btn a span::after {
        content: '';
        position: absolute;
        right: 0;
        top: 0;
        bottom: 0;
        width: 32px;
        height: 32px;
        background: url(../../images/src/common/ico_plus.svg) no-repeat left top / 100%;
    }
    
    #treatment .sec02 .sec_block .btn a span.close::after {
        background-image: url(../../images/src/common/ico_minus.svg);
    }
    #treatment .sec02 .sec_block .txt + .txt {
        margin-top: 15px;
    }
    #treatment .sec02 .sec_block .list_box {
        margin: 30px 0;
        padding: 30px;
        border-radius: 14px;
        background: #FFF2F4;
    }
    #treatment .sec02 .sec_block .list_box li {
        position: relative;
        padding-left: 22px;
        font-size: 18px;
        font-weight: 700;
        line-height: 2.11;
        letter-spacing: 0.04em;
    }
    #treatment .sec02 .sec_block .list_box li::before {
        content:'';
        position: absolute;
        top: 0;
        bottom: 0;
        left: 0;
        margin: auto;
        width: 10px;
        height: 10px;
        border-radius: 50%;
        background: var(--main-color);
    }
    #treatment .sec02 .sec_block .list_box li a {
        position: relative;
        padding-right: 27px;
        color: var(--main-color);
        font-weight: 700;
        text-decoration: underline;
    }
    #treatment .sec02 .sec_block .list_box li a::after {
        content:'';
        position: absolute;
        top: 0;
        bottom: 0;
        right: 0;
        margin: auto;
        width: 22px;
        height: 23px;
        background: url(../../images/src/common/arrow_pink_right01.svg) no-repeat right center / 100%;
        /*transition: .7s;*/
    }
    #treatment .sec02 .sec_block .accordion {
        margin-bottom: 40px;
        display: none;
    }
    #treatment h3 {
        font-size: 26px;
        background: url(../../images/src/treatment/border.svg) no-repeat left bottom;
    }
    #treatment h4 {
        margin-top: 40px;
    }
    #treatment h5 {
        font-size: 20px;
    }
    #treatment h6 {
        margin-top: 16px;
    }
    #treatment .ml30 {
        margin-left: 30px;
    }
    #treatment .sec02 .sec_block .accordion .flex {
        justify-content: left;
        gap: 0 19px;
    }
    #treatment .sec02 .sec_block .accordion .flex .txt {
        font-weight: 700;
    }
    #treatment .sec02 .circle li {
        position: relative;
        padding-left: 22px;
        font-size: 18px;
        font-weight: 400;
        line-height: 2.11;
        letter-spacing: 0.04em;
    }
    #treatment .sec02 .circle li::before {
        content:'';
        position: absolute;
        left: 0;
        top: 14.5px;
        width: 10px;
        height: 10px;
        border-radius: 50%;
        background: var(--main-color);
    }
    #treatment .sec02 .sec_block .accordion .ac_btn {
        margin: 18px 0 40px;
    }
    #treatment .sec02 .sec_block .accordion .ac_btn a {
        position: relative;
        padding: 12px 58.5px 12px 25.5px;
        font-size: 16px;
        font-weight: 700;
        letter-spacing: 0.04em;
        border-radius: 7px;
        border: 1.4px solid var(--text-color);
    }
    #treatment .sec02 .sec_block .accordion .ac_btn a::after {
        content:'';
        position: absolute;
        top: 0;
        bottom: 0;
        right: 15px;
        margin: auto;
        width: 24px;
        height: 24px;
        background: url(../../images/src/common/arrow_brown_right.svg) no-repeat left top / 100%;
    }
    #treatment .sec02 .sec_block .accordion table,
    #treatment .sec02 .sec_block .accordion table th,
    #treatment .sec02 .sec_block .accordion table td {
        border: 1px solid var(--bdr-color);
    }
    #treatment .sec02 .sec_block .accordion table tr:first-of-type td {
        padding: 15px 0;
        width: 256px;
    }
    #treatment .sec02 .sec_block .accordion table tr:first-of-type td.price {
        padding-right: 40px;
    }
    #treatment .sec02 .sec_block .accordion table th,
    #treatment .sec02 .sec_block .accordion table td {
        font-size: 18px;
        font-weight: 700;
        letter-spacing: 0.04em;
        vertical-align: middle;
    }
    #treatment .sec02 .sec_block .accordion table th {
        padding-left: 40px;
        width: 192px;
    }
    #treatment .sec02 .sec_block .accordion table td {
        padding: 19px 0 25px;
        text-align: center;
    }
    #treatment .sec02 .sec_block .accordion table td.price {
        text-align: right;
        padding-right: 40px;
    }
    #treatment .sec02 .sec_block .accordion .option_table {
        width: 75%;
    }
    #treatment .sec02 .sec_block .accordion .op02 {
        width: 100%;
    }
    #treatment .sec02 .sec_block .accordion table th {
        width: 60%;
        padding-left: 20px;
    }
    #treatment .sec02 .sec_block .accordion .op02 th {
        width: 22%;
    }
    #treatment .sec02 .sec_block .accordion .op02 td.price {
        width: 30%;
    }

    .treatment_btn {
        padding: 70px 0;
        justify-content: center;
        gap: 24px;
    }
    .meidcal_link_area {
        background: url(../../images/src/top/sec01_bg01.png);
    }
    .treatment_btn .parts {
        width: 384px;
    }
    .treatment_btn .parts a {
        position: relative;
        display: block;
        width: 100%;
        padding: 45px 0 45px 20px;
        border-radius: 12px;
        border: 7px solid #FCE1E6;
        background: #fff;
        font-size: 22px;
        font-weight: 700;
        text-align: center;
    }
    .treatment_btn .parts a::before,
    .treatment_btn .parts a::after {
        content:'';
        position: absolute;
        top: 0;
        bottom: 0;
        margin: auto;
        transition: .7s;
    }
    .treatment_btn .parts a.genom::before {
        left: 34px;
        width: 42px;
        height: 73px;
        background: url(../../images/src/treatment/ico_genom.svg) no-repeat left center / 100%;

    }
    .treatment_btn .parts a.herbal::before {
        left: 18px;
        width: 63px;
        height: 57px;
        background: url(../../images/src/treatment/ico_herbal.svg) no-repeat left center / 100%;

    }
    .treatment_btn .parts a.fetus::before {
        left: 37px;
        width: 46px;
        height: 86px;
        background: url(../../images/src/treatment/ico_fetus.svg) no-repeat left center / 100%;

    }
    .treatment_btn .parts a.insurance::before {
        left: 22px;
        width: 48px;
        height: 62px;
        background: url(../../images/src/treatment/ico_insurance.svg) no-repeat left center / 100%;

    }
    .treatment_btn .parts a.selfpay::before {
        left: 37px;
        width: 82px;
        height: 69px;
        background: url(../../images/src/treatment/ico_selfpay.svg) no-repeat left center / 100%;

    }
    .treatment_btn .parts a::after {
        right: 23px;
        width: 30px;
        height: 31px;
        background: url(../../images/src/common/arrow_pink_right01.svg) no-repeat right center / 100%;
    }
    
    /* ------------------------------------
    /  herbal 女性漢方 
    /-------------------------------------*/

    #herbal .txt {
        font-size: 18px;
        font-weight: 400;
        line-height: 2.1;
        letter-spacing: 0.04em;
    }
    #herbal .sec01 {
        margin-bottom: 120px;
        text-align: center;
    }
    #herbal .sec01 .img {
        width: 47.2445%;
    }
    #herbal .sec01 .img img {
        border-radius: 0 12px 12px 0;
        object-position: left;
        height: 600px;
    }
    #herbal .sec01 .box {
        max-width: 580px;
    }
    #herbal .sec01 h2.intro_ttl {
        margin-bottom: 28px;
        font-size: 34px;
        font-weight: 700;
        line-height: 2;
        letter-spacing: 0.04em;
    }
    #herbal .sec01 h2.intro_ttl span {
        display: block;
        color: var(--main-color);
        font-size: 46px;
        font-weight: 700;
    }
    #herbal .sec01 .txt + .txt {
        margin-top: 10px;
    }
    #herbal .sec01 .txt .marker {
        padding: 0 4px;
        font-weight: 700;
        background: #ffcdb5;
    }
    #herbal .sec01 .txt_box {
        display: inline-block;
        margin-top: 40px;
        padding: 18px 40px;
        background: #f6f6f6;
    }
    #herbal .sec01 .txt_box a {
        text-decoration: underline;
    }
    #herbal .sec02 {
        padding: 70px 0 100px;
        background: url(../../images/src/introduction/bg01.png);
    }
    #herbal .sec02 h2 {
        margin-bottom: 40px;
        font-size: 30px;
        font-weight: 700;
        letter-spacing: 0.04em;
        text-align: center;
    }
    #herbal .sec02 ul {
    }
    #herbal .sec02 ul li {
        width: 280px;
        display: flex;
        flex-direction: column;
        padding: 17px 20px 20px;
        border-radius: 14px;
        background: rgba(92, 76, 44, .16);
        text-align: center;
    }
    #herbal .sec02 ul li .ttl {
        margin-top: 7px;
        font-size: 20px;
        font-weight: 700;
        line-height: 1.6; /* 160% */
        letter-spacing: 0.04em;
        flex: 1 1 auto;
        display: flex;
        justify-content: center;
        align-items: center;
    }
    #herbal .sec02 ul li .txt {
        margin-left: -20px;
        white-space: nowrap;
    }
    #herbal .sec02 ul li .img {
        margin-top: auto;
    }
    #herbal .sec02 .list_img {
        margin-bottom: 30px;
    }
    #herbal .sec02 .list_img li {
        width: 380px;
    }
    #herbal .sec03 {
        padding: 70px 0 130px;
    }
    #herbal h2 {
        margin-bottom: 36px;
        text-align: center;
        font-size: 30px;
        font-weight: 700;
        letter-spacing: 0.04em;
    }
    #herbal h2 span.f_poppins {
        display: block;
        color: var(--main-color);
        font-size: 18px;
        font-weight: 600;
        letter-spacing: 0.04em;
        text-transform: uppercase;
    }
    #herbal .intorduction_slide_btn .swiper-button-next::after {
        width: 43px;
        background-image: url(../../images/src/common/arrow_pink_right01.svg);
    }
    #herbal .intorduction_slide_btn .swiper-button-prev::after {
        background-image: url(../../images/src/common/arrow_pink_left01.svg);
    }
    #herbal .swiper-pagination-progressbar {
        background-color: #FFEEF1;
    }
    #herbal .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
        background: var(--main-color);
    }
    #herbal .intro_slide_block .mySwiper .swiper-slide {
        position: relative;
        width: 30%;
    }
    #herbal .intro_slide_block .mySwiper .swiper-slide .img {
        position: relative;
    }
    #herbal .intro_slide_block .mySwiper .swiper-slide .img::after {
        content:'';
        position: absolute;
        top: 0;
        bottom: 0;
        right: -45px;
        margin: auto;
        width: 24px;
        height: 27px;
        background: url(../../images/src/common/triangle_pink.svg) no-repeat right top / 100%;
    }
    #herbal .intro_slide_block .mySwiper .swiper-slide:last-of-type .img::after {
        display: none;
    }
    #herbal .intro_slide_block .mySwiper .swiper-slide .num {
        position: absolute;
        top: -26px;
        left: -26px;
        width: 60px;
        height: 60px;
        color: var(--main-color);
        font-size: 24px;
        font-weight: 600;
        letter-spacing: 0.04em;
        border-radius: 50%;
        border: 4px solid #FCE1E6;
        background: #fff;
        display: flex;
        justify-content: center;
        align-items: center;
        z-index: 10;
    }
    #herbal .intro_slide_block .mySwiper .swiper-slide .ttl {
        margin: 27px 0 10px;
        font-size: 24px;
        font-weight: 700;
        line-height: 1.33;
        letter-spacing: 0.04em;
    }
    #herbal .sec04 {
        margin: 0 auto;
        padding: 70px 0 120px;
        width: 1760px;
        max-width: 90%;
        border-radius: 70px;
        background: url(../../images/src/top/sec01_bg01.png);
    }
    #herbal .sec04 .faq_acd {
        margin-top: 50px;
    }
    #herbal .sec04 .faq_acd dl + dl {
        margin-top: 38px;
    }
    #herbal .sec04 .faq_acd dl {
        position: relative;
        padding: 30px 40px;
        border-radius: 14px;
        background: #fff;
        box-shadow: 8px 8px #F2B3BC;
    }
    #herbal .sec04 .faq_acd dl dt,
    #herbal .sec04 .faq_acd dl dd {
        position: relative;
    }
    #herbal .sec04 .faq_acd dl dt::before,
    #herbal .sec04 .faq_acd dl dd::before {
        position: absolute;
        font-family: "Poppins", sans-serif;
        font-size: 36px;
        font-weight: 500;
        letter-spacing: 0.04em;
        line-height: 1;
    }
    #herbal .sec04 .faq_acd dl dt::before {
        content: 'Q';
        top: 0;
        left: 0;
        opacity: 1;
    }
    #herbal .sec04 .faq_acd dl::after,
    #faq .sec01 dl::after {
        content: '';
        position: absolute;
        right: 40px;
        top: 33px;
        width: 36px;
        height: 36px;
        background: url(../../images/src/common/plus_pink.svg) no-repeat left top / 100%;
        transition: .7s;
    }
    #herbal .sec04 .faq_acd dl.active::after,
    #faq .sec01 dl.active::after {
        background: url(../../images/src/common/minus_pink.svg) no-repeat left top / 100%;
    }
    #herbal .sec04 .faq_acd dl dd::before {
        content: 'A';
        top: 0;
        left: 24px;
        color: var(--main-color);
    }
    
    #herbal .sec04 .faq_acd dt {
        padding-left: 50px;
        cursor: pointer;
    }
    #herbal .sec04 .faq_acd dl dt p {
        font-size: 20px;
        font-weight: 700;
        line-height: 2;
        letter-spacing: 0.04em;
        transition: .7s;
    }
    #herbal .sec04 .faq_acd dl.active dt p {
        opacity: 0.5;
    }
    #herbal .sec04 .faq_acd dl dd {
        display: none;
        margin-top: 24px;
        padding-left: 70px;
        font-size: 18px;
        font-weight: 700;
        line-height: 2.11;
        letter-spacing: 0.04em;
    }
    #herbal .sec05 {
        padding: 120px 0 100px;
    }
    #herbal .sec05 .left_col {
        width: 520px;
    }
    #herbal .sec05 .left_col h2 {
        text-align: left;
    }
    #herbal .sec05 .left_col h2 span::after {
        left: 0;
        right: auto;
    }
    #herbal .sec05 .left_col h2 span.f_poppins::after {
        display: none;
    }
    #herbal .sec05 .txt {
        margin: 53px 0 45px;
        text-align: left;
    }
    
    #herbal .sec05 strong {
        font-weight: 700;
        background: #ffcdb5;
    }
    #herbal .sec05 .img {
        width: 670px;
    }
    

 
/* ------------------------------------
/  fetus 胎児ドック 
/-------------------------------------*/

    #fetus .txt {
        font-size: 18px;
        font-weight: 400;
        line-height: 2.1;
        letter-spacing: 0.04em;
    }
    #fetus .sec01 {
        margin-bottom: 120px;
    }
    #fetus .sec01 .flex {
        margin-top: 83px;
        justify-content: left;
        align-items: center;
        gap: 0 90px;
    }
    #fetus .sec01 .img {
        width: 47.2445%;
    }
    #fetus .sec01 .img img {
        border-radius: 0 12px 12px 0;
        object-position: left;
        height: 700px;
    }
    #fetus .sec01 .box {
        /*width: 540px;*/
        width: calc(30% + 9px);
    }
    
    #fetus .sec01 .txt + .txt {
        margin-top: 15px;
    }
    #fetus .sec01 .txt_box {
        margin-top: 40px;
        padding: 30px 40px;
        border-radius: 12px;
        border: 6px solid #FCE1E6;
        background: #fff;
    }
    #fetus .sec01 .staff_btn a {
        position: relative;
        margin: 90px auto;
        width: 640px;
        max-width: 100%;
        border-radius: 12px;
        border: 2px solid var(--text-color);
        box-shadow: 8px 8px rgba(92, 76, 44, 0.60);
        justify-content: left;
        align-items: center;
        gap: 0 40px;
    }
    #fetus .sec01 .staff_btn a::after {
        content: '';
        position: absolute;
        right: 12px; 
        bottom: 12px;
        width: 26px;
        height: 26px;
        background: url(../../images/src/common/arrow_brown_right.svg) no-repeat right bottom / 100%;
    }
    #fetus .sec01 .staff_btn a .img { 
        width: 280px;
    }
    #fetus .sec01 .staff_btn a .img img {  
        border-radius: 12px 0 0 12px;
        object-position: center;
        height: auto;
    }
    #fetus .sec01 .staff_btn a .right_col {
        width: 290px;
    }
    #fetus .sec01 .staff_btn a .right_col p {
        font-size: 28px;
        font-weight: 700;
        letter-spacing: 0.04em;
    }
    #fetus .sec01 .staff_btn a .right_col p span {
        padding-left: 15px;
        color: var(--main-color);
        font-size: 16px;
        font-weight: 600;
        letter-spacing: 0.04em;
        text-transform: uppercase;
    }
    #fetus .sec02 {
        padding: 90px 0 120px;
        background: url(../../images/src/top/sec01_bg01.png);
    }
    #fetus .sec02 h2 {
        margin-bottom: 83px;
    }
    #fetus .sec02 .parts {
        padding: 60px;
        border-radius: 14px;
        background: #fff;
    }
    #fetus .sec02 .parts + .parts {
        margin-top: 40px;
    }
    #fetus .sec02 .parts .img {
        width: 400px;
    }
    #fetus .sec02 .parts .img img {
        border-radius: 14px;
    }
    #fetus .sec02 .parts .right_col {
        width: 630px;
    }
    #fetus .sec02 .parts .right_col h3 {
        margin-bottom: 29px;
        padding-left: 17px;
        border-left: 5px solid var(--main-color);
        font-size: 28px;
        font-weight: 700;
        letter-spacing: 0.04em;
    }
    #fetus .sec02 .parts .right_col .price {
        margin-bottom: 30px;
        color: var(--main-color);
        font-size: 36px;
        font-weight: 700;
        line-height: 1.05;
        letter-spacing: 0.04em;
    }
    #fetus .sec02 .parts .right_col .price span {
        color: var(--text-color);
        font-size: 18px;
        font-weight: 700;
    }
    
    #fetus .sec03 {
        padding: 80px 0 70px;
    }
    
    #fetus .meidcal_link_area {
        background: #fff;
    }
    
    /* ------------------------------------
    /  genom ゲノム診療 
    /-------------------------------------*/

    #genom .txt {
        font-size: 18px;
        font-weight: 400;
        line-height: 2.1;
        letter-spacing: 0.04em;
    }
    #genom .sec01 {
        margin-bottom: 138px;
    }
    #genom .sec01 .lower_h2 {
        margin-bottom: 73px;
    }
    #genom .sec01 .flex {
        margin-top: 90px;
    }
    #genom .sec01 .flex .left_col {
        width: calc(50% - 80px);
    }
    #genom .sec01 .flex .left_col h3 {
        margin-bottom: 27px;
        padding-left: 24px;
        border-left: 5px solid var(--main-color);
        font-size: 30px;
        font-weight: 700;
        letter-spacing: 1.2px;
    }
    #genom .sec01 .flex .img {
        width: calc(50%);
    }
    #genom .sec01 .flex .img a {
        font-size: 18px;
        font-weight: 700;
        line-height: 2.11;
        letter-spacing: 0.72px;
        text-decoration: underline;
    }
    #genom .sec02 {
        padding:104px 0 0;
        background: url(../../images/src/common/bnr_bg.png);
    }
    #genom .sec02 h2 {
        margin-bottom: 63px;
    }
    #genom .sec02 .ttl01 {
        margin: 70px auto 40px;
        font-size: 30px;
        font-weight: 700;
        letter-spacing: 1.2px;
        text-align: center;
    }
    #genom .sec02 ul {
        margin-bottom: 90px;
    }
    #genom .sec02 ul li {
        width: 280px;
        display: flex;
        flex-direction: column;
        padding: 17px 18px 20px;
        border-radius: 14px;
        background: rgba(92, 76, 44, .16);
        text-align: center;
    }
    #genom .sec02 ul li .ttl {
        margin-top: 7px;
        font-size: 18px;
        font-weight: 700;
        line-height: 1.6; /* 160% */
        letter-spacing: 0.04em;
        flex: 1 1 auto;
        display: flex;
        justify-content: center;
        align-items: center;
    }
    #genom .sec02 ul li .txt {
        margin-left: -20px;
        white-space: nowrap;
    }
    #genom .sec02 ul li .img {
        margin-top: auto;
    }
    #genom .sec02 .white_block {
        margin: 0 auto 128px;
        width: 840px;
        max-width: 100%;
    }
    #genom .sec02 .white_block a {
        position: relative;
        display: block;
        padding: 40px 80px 44px;
        width: 100%;
        border-radius: 14px;
        background: #fff;
        box-shadow: 8px 8px rgba(92, 76, 44, 0.3);
        transition: .7s;
    }
    #genom .sec02 .white_block a::after {
        content: '';
        position: absolute;
        right: 26px;
        bottom: 22px;
        width: 32px;
        height: 32px;
        background: url(../../images/src/common/arrow_brown_right.svg) no-repeat right bottom / 100%;
        transition: .7s;
    }
    #genom .sec02 .white_block a .btn {
        margin: 0 auto 40px;
        padding: 45px 0 45px 80px;
        width: 537px;
        text-align: center;
        border-radius: 180px;
        border: 6px solid #F0E7D9;
        background: #fff;
        transition: .7s;
    }
    #genom .sec02 .white_block a .btn span {
        position: relative;
        font-size: 22px;
        font-weight: 700;
        letter-spacing: 0.04em;
    }
    #genom .sec02 .white_block a .btn span::after {
        content: '';
        position: absolute;
        left: -80px;
        top: 0;
        bottom: 0;
        margin: auto;
        width: 61px;
        height: 64px;
        background: url(../../images/src/common/ico_follow01.svg) no-repeat left center / 100%;
    }
    #genom .sec02 .white_block a .list {
        padding-top: 38px;
        border-top: 1px solid var(--bdr-color);
        justify-content: center;
        gap: 0 28px;
        transition: .7s;
    }
    #genom .sec02 .white_block a .list .circle {
        width: 110px;
        height: 110px;
        border-radius: 50%;
        display: flex;
        align-items: center;
        justify-content: center;
        border: 2.2px solid var(--text-color);
        font-size: 20px;
        font-weight: 700;
        letter-spacing: 0.8px;
    }
    #genom .sec02 .white_block a .list .right_col {
        width: 480px;
    }
    #genom .sec02 .white_block a .list dl {
        display: flex;
        justify-content: space-between;
        align-items: center;
    }
    #genom .sec02 .white_block a .list dl dt {
        font-size: 18px;
        font-weight: 700;
        letter-spacing: 0.04em;
    }
    #genom .sec02 .white_block a .list dl dd {
        color: var(--main-color);
        font-size: 28px;
        font-weight: 700;
        letter-spacing: 0.04em;
    }
    #genom .sec02 .white_block a .list dl dd span {
        font-size: 18px;
        font-weight: 700;
    }
    #genom .sec02 .sec02_02 {
        margin: 0 auto;
        padding: 73px 0 120px;
        width: 1760px;
        max-width: 100%;
        border-radius: 70px 70px 0 0;
        background: #fff;
    }
    #genom .sec02 .sec02_02 .box01 {
        margin: 80px auto 100px;
    }
    #genom .sec02 .sec02_02 .box01 .img {
        width: calc(50% - 20px);
    }
    #genom .sec02 .sec02_02 .box01 .right_col {
        width: calc(50% - 40px);
    }
    #genom .sec02 .sec02_02 .box01 .right_col h3 {
        margin-bottom: 27px;
        border-left: 5px solid var(--main-color);
        padding-left: 22px;
        font-size: 30px;
        font-weight: 700;
        letter-spacing: 0.04em;
    }
    #genom .sec02 .sec02_02 h2.ttl {
        margin-bottom: 40px;
        font-size: 34px;
        font-weight: 700;
        letter-spacing: 0.04em;
        text-align: center;
    }
    #genom .sec02 .sec02_02 h2.ttl span {
        display: block;
        color: var(--main-color);
        font-size: 20px;
        font-weight: 600;
        letter-spacing: 0.04em;
    }
    #genom .sec02 .sec02_02 .howto {
        margin-top: 47px;
    }
    #genom .sec02 .sec02_02 .howto .parts {
        position: relative;
        /*width: 360px;*/
        width: calc(32% - 24px);
    }
    #genom .sec02 .sec02_02 .howto .parts .num {
        position: absolute;
        top: -26px;
        left: -26px;
        width: 60px;
        height: 60px;
        color: var(--main-color);
        font-size: 24px;
        font-weight: 600;
        letter-spacing: 0.04em;
        border-radius: 50%;
        border: 4px solid #FCE1E6;
        background: #fff;
        display: flex;
        justify-content: center;
        align-items: center;
        z-index: 10;
    }
    #genom .sec02 .sec02_02 .howto .parts .img {
        position: relative;
    }
    #genom .sec02 .sec02_02 .howto .parts .img::after {
        content:'';
        position: absolute;
        top: 0;
        bottom: 0;
        right: -45px;
        margin: auto;
        width: 24px;
        height: 27px;
        background: url(../../images/src/common/triangle_pink.svg) no-repeat right top / 100%;
    }
    #genom .sec02 .sec02_02 .howto .parts:last-of-type .img::after {
        display: none;
    }
    #genom .sec02 .sec02_02 .howto .parts .img img {
        border-radius: 12px;
    }
    #genom .sec02 .sec02_02 .howto .parts .ttl {
        margin: 28px 0 10px;
        font-size: 24px;
        font-weight: 700;
        line-height: 1.33;
        letter-spacing: 0.04em;
    }
    
    #genom .sec02 .sec02_02 .howto .parts a {
        display: inline-block;
        margin-top: 18px;
        position: relative;
        padding: 12px 59px 13px 19px;
        font-size: 16px;
        font-weight: 700;
        letter-spacing: 0.04em;
        border-radius: 7px;
        border: 1.4px solid var(--text-color);
        background: #fff;
        transition: .7s;
    }
    #genom .sec02 .sec02_02 .howto .parts a::after {
        content:'';
        position: absolute;
        top: 0;
        right: 16px;
        bottom: 0;
        margin: auto;
        width: 24px;
        height: 26px;
        background: url(../../images/src/common/arrow_brown_right.svg) no-repeat right center / 100%;
    }

    /* ------------------------------------
    /  online オンライン診療
    /-------------------------------------*/
    #online .sec01 {
        margin: 0 auto;
        padding: 90px 0 120px;
        width: 1760px;
        max-width: 100%;
        border-radius: 70px 70px 0 0;
        background: url(../../images/src/top/sec01_bg01.png);
    }
    #online .sec01 .ttl {
        margin-bottom: 20px;
        color: var(--main-color);
        font-size: 22px;
        font-weight: 700;
        letter-spacing: 0.04em;
        text-align: center;
    }
    #online .sec01 .ttl02 {
        font-size: 26px;
        font-weight: 700;
        line-height: 2;
        letter-spacing: 0.04em;
        text-align: center;
    }
    #online .sec01 .ttl02 span {
        color: var(--main-color);
        font-size: 38px;
        font-weight: 700;
        letter-spacing: 0.04em;
    }
    #online .sec01 .block {
        margin-top: 60px;
    }
    #online .sec01 .block .img {
        width: 580px;
    }
    #online .sec01 .block .img img {
        border-radius: 14px;
    }
    #online .sec01 .block .right_col {
        width: 562px;
    }
    #online .sec01 .block .right_col p {
        margin-bottom: 18px;
        font-size: 24px;
        font-weight: 700;
        letter-spacing: 0.04em ;
    }
    #online .sec01 .block .right_col ul li {
        display: flex;
        align-items: center;
        position: relative;
        padding: 21px 0 21px 151px;
        min-height: 108px;
        font-size: 18px;
        font-weight: 700;
        line-height: 1.7; /* 177.778% */
        letter-spacing: 0.04em;
        border-radius: 14px;
        background: #fff;
    }
    #online .sec01 .block .right_col ul li + li {
        margin-top: 14px;
    }
    #online .sec01 .block .right_col ul li::before,
    #online .sec01 .block .right_col ul li::after {
        content:'';
        position: absolute;
        top: 0;
        bottom: 0;
        margin: auto;
    }
    #online .sec01 .block .right_col ul li::before {
        left: 24px;
        width: 28px;
        height: 28px;
        background: url(../../images/src/online/check.svg) no-repeat left top / 100%;
    }
    #online .sec01 .block .right_col ul li:first-of-type::after {
        left: 72px;
        width: 60px;
        height: 44px;
        background: url(../../images/src/online/sec01_ico01.svg) no-repeat left top / 100%;
    }
    #online .sec01 .block .right_col ul li:nth-of-type(2)::after {
        left: 72px;
        width: 35px;
        height: 35px;
        background: url(../../images/src/online/sec01_ico02.svg) no-repeat left top / 100%;
    }
    #online .sec01 .block .right_col ul li:last-of-type::after {
        left: 74px;
        width: 55px;
        height: 55px;
        background: url(../../images/src/online/sec01_ico03.svg) no-repeat left top / 100%;
    }
    #online .sec02 {
        padding: 90px 0 110px;
        background: url(../../images/src/common/bnr_bg.png);
    }
    #online .sec02 .txt {
        margin: 51px 0 43px;
        font-size: 20px;
        font-weight: 700;
        line-height: 2.3;
        letter-spacing: 0.04em;
        text-align: center;
    }
    #online .sec02 .txt span {
        color: #008E44;
        font-size: 28px;
        font-weight: 700;
        letter-spacing: 0.04em;
    }
    #online .sec02 .step_area {

    }
    #online .sec02 .step_area .parts {
        position: relative;
        width: 198px;
    }
    #online .sec02 .step_area .parts::after {
        content:'';
        position: absolute;
        top: 24%;
        right: -37px;
        width: 24px;
        height: 27px;
        background: url(../../images/src/common/triangle.svg) no-repeat left top / 100%;
    }
    #online .sec02 .step_area .parts:last-of-type::after {
        display: none;
    }
    #online .sec02 .step_area .parts .step {
        color: var(--main-color);
        text-align: center;
        font-size: 20px;
        font-weight: 600;
        letter-spacing: 0.04em;
    }   
    #online .sec02 .step_area .parts .step .num {
        display: block;
        font-size: 40px;
        font-weight: 600;
        line-height: 38px;
        letter-spacing: 0.04em;
    }
    #online .sec02 .step_area .parts .parts_icon {
        margin: -25px 0 30px;
        display: flex;
        justify-content: center;
        align-items: center;
        height: 198px;
        border: 7px solid #F0E7D9;
        border-radius: 50%;
        background: #fff;
    }
    #online .sec02 .step_area .parts .parts_ttl {
        margin-bottom: 14px;
        font-size: 20px;
        font-weight: 700;
        line-height: 1.6; /* 160% */
        letter-spacing: 0.04em;
        text-align: center;
    }
    #online .sec02 .step_area .parts .parts_txt {
        font-size: 18px;
        font-weight: 400;
        line-height: 1.7; /* 160% */
        letter-spacing: 0.04em;
    }
    #online .sec02 .use_code {
        margin: 30px auto 0;
        padding: 30px 16px 30px 0;
        width: 670px;
        border: 2px solid var(--text-color);
        border-radius: 14px;
        background:#fff;
        gap: 0 10px;
        justify-content: center;
    }
    #online .sec02 .use_code .code_ttl {
        font-size: 20px;
        font-weight: 700;
        line-height: 1.6; /* 160% */
        letter-spacing: 0.04em;
    }
    #online .sec02 .use_code .code_num {
        font-size: 42px;
        font-weight: 500;
        line-height: 0.76;
        letter-spacing: 0.04em;
    }
    #online .sec02 .use_code .code_num span {
        font-size: 16px;
        font-weight: 500;
        letter-spacing: 0.04em;
    }
    #online .sec03 {
        padding: 120px 0;
    }
    #online .sec03 .flow_parts {
        align-items: center;
        margin-bottom: 50px;
    }
    #online .sec03 .flow_parts:last-of-type {
        margin:0;
    }
    #online .sec03 .flow_parts .img {
        width: 450px;
    }
    #online .sec03 .flow_parts .right_col {
        width: calc(60% - 20px);
    }
    #online .sec03 .flow_parts .right_col .ttl {
        font-size: 30px;
        font-weight: 700;
        letter-spacing: 0.04em;
    }
    #online .sec03 .flow_parts .right_col .ttl span {
        padding-right: 18px;
        color: var(--main-color);
        font-size: 34px;
        font-weight: 500;
        letter-spacing: 0.04em;
    }
    #online .sec03 .flow_parts .right_col .txt {
        font-size: 18px;
        font-weight: 400;
        line-height: 2.1;
        letter-spacing: 0.04em;
    }
    #online .sec03 .flow_parts .right_col .txt + .txt {
        margin-top: 15px;
    }
    #online .sec04 {
        padding: 70px 0;
        background: url(../../images/src/top/sec01_bg01.png);
    }
    #online .sec04 .inner {
        margin: 0 auto;
        width: 1080px;
        max-width: 90%;
    }
    #online .sec04 a {
        position: relative;
        border: 3px solid var(--main-color);
        padding: 48px 50px;
        width: 520px;
        border-radius: 12px;
        background: #fff;
        align-items: center;
        justify-content: left;
        gap: 0 30px;
        box-shadow: 8px 8px 0 rgba(242, 135, 155, 0.32);
    }
    #online .sec04 a.curon_btn {
        border-color: #008E44;
        box-shadow: 8px 8px 0 rgba(0, 142, 68, .26);
    }
    #online .sec04 a::after {
        content:'';
        position: absolute;
        right: 25px;
        bottom: 10px;
        width: 30px;
        height: 31px;
        background: url(../../images/src/common/arrow_pink_right01.svg) no-repeat right bottom / 100%;
    }
    #online .sec04 a.curon_btn::after {
        background-image: url(../../images/src/common/arrow_green_right01.svg);
    }
    #online .sec04 a p {
        font-size: 22px;
        font-weight: 700;
        line-height: 1.54;
        letter-spacing: 0.04em;
    }
    



    /* ------------------------------------
    /  staff 医師紹介 
    -------------------------------------*/
    #staff .sec01 {
        margin: 0 auto 100px;
        width: 1080px;
        max-width: 90%;
    }
    #staff .sec01 h2 {
        margin-bottom: 74px;
    }
    #staff .sec01 p {
        font-size: 18px;
        font-weight: 500;
        line-height: 44px; /* 244.444% */
        letter-spacing: 0.04em;
        text-align: center;
    }
    #staff .staff_list {
        padding: 91px 0 115px;
        border-radius: 70px 70px 0px 0px;
        background: url(../../images/src/top/sec01_bg01.png);
    }
    #staff .sec02 {
        margin: 0 auto;
        width: 1760px;
        max-width: 100%;
    }
    #staff .staff_list h2 {
        margin-bottom: 83px;
    }
    #staff .staff_list .list_block {
        margin: 0 auto;
        width: 1200px;
        max-width: 95%;
        gap: 80px 27px;
        justify-content: left;
    }
    #staff .staff_list .list_block .parts {
        /*width: 280px;*/
        width: calc(25% - 21px);
    }
    #staff .staff_list .list_block .parts .img {
        width: 100%;
    }
    #staff .staff_list .list_block .parts .img img {
        width: 100%;
        height: 188px;
        border-radius: 12px;
    }
    #staff .staff_list .list_block .parts .staff_prof {
        position: relative;
        margin: -31px auto;
        padding: 20px;
        /*width: 530px;*/
        width: 86.4285714%;
        border-radius: 12px;
        background: #fff;
        z-index: 10;
        box-shadow: 6px 6px 0 rgba(242,135,155,0.3);
        transition: all 0.3s ease;
    }
    #staff .staff_list .list_block .parts .staff_prof::after {
        content:'';
        position: absolute;
        top: 0;
        right: 20px;
        bottom: 0;
        margin: auto;
        width: 26px;
        height: 27px;
        background: url(../../images/src/common/arrow_pink_right01.svg) no-repeat left top / 100%;
        transition: .7s;
    }
    #staff .staff_list .list_block .parts .staff_prof .staff_name {
        font-size: 20px;
        font-weight: 700;
        line-height: 20px; /* 83.333% */
        letter-spacing: 0.04em;
    }
    #staff .sec02 .list_block {
        width: 1160px;
    }
    #staff .sec02 .list_block .parts {
        /*width: 560px;*/
        width: calc(50% - 20px);
    }
    #staff .sec02 .list_block .parts .img {
        width: 94.6428571%;
    }
    #staff .sec02 .list_block .parts .img img {
        height: 356px;
    }
    #staff .sec02 .list_block .parts .staff_prof {
        margin: -48px 0 0 auto;
        padding: 36px 36px 54px;
        /*width: 530px;*/
        width: 94.6428571%;
        box-shadow: 10px 10px 0 rgba(242,135,155,0.3);
    }
    #staff .sec02 .list_block .parts .staff_prof::after {
        right: 20px;
        top: auto;
        bottom: 18px;
    }
    #staff .sec02 .list_block .parts .staff_prof .staff_name {
        margin-bottom: 16px;
        font-size: 24px;
    }
    #staff .staff_list .list_block .parts .staff_prof .staff_name span {
        padding-left: 19px;
        color: var(--main-color);
        font-size: 14px;
        font-weight: 600;
        letter-spacing: 0.04em;
        text-transform: uppercase;
        vertical-align: top;
    }
    #staff .staff_list .list_block .parts .staff_prof .txt {
        font-size: 18px;
        font-weight: 400;
        line-height: 34px; /* 188.889% */
    }


    #staff .detail_sec01 {
        margin-bottom: 74px;
    }
    #staff .detail_sec01 .photo {
        /*width: 694px;*/
        width: calc(60% - 26px);
    }
    #staff .detail_sec01 .photo img {
        object-position: center;
        width: 100%;
        height: 466px;
        border-radius: 12px;
    }
    #staff .detail_sec01 .right_col {
        /*width: 428px;*/
        width: calc(40% - 52px);
    }
    #staff .detail_sec01 .right_col h1 {
        margin-bottom: 26px;
        padding-left: 24px;
        border-left: 5px solid var(--main-color);
        font-size: 40px;
        font-weight: 700;
        line-height: 1.25;
        letter-spacing: 0.04em;
    }
    #staff .detail_sec01 .right_col h1 span {
        padding-left: 28px;
        color: var(--main-color);
        font-size: 20px;
        font-weight: 600;
        letter-spacing: 0.04em;
        text-transform: uppercase;
    }
    #staff .detail_sec02 {
        margin-bottom: 120px;
    }
    #staff .detail_sec02 h2 {
        margin-bottom: 36px;
        text-align: center;
        font-size: 30px;
        font-weight: 700;
        letter-spacing: 0.04em;
    }
    #staff .detail_sec02 h2 span {
        display: block;
        color: var(--main-color);
        font-size: 18px;
        font-weight: 600;
        letter-spacing: 0.04em;
        text-transform: uppercase;
    }
    #staff .detail_sec02 .bgcream {
        padding: 70px 0;
        border-radius: 30px;
        background: #F8EFE1;
    }
    #staff .detail_sec02 .career_block {
        margin-bottom: 80px;
        padding: 70px 140px;
    }
    #staff .detail_sec02 .career_block dl {
        display: flex;
        flex-wrap: wrap;
        justify-content: left;
        gap: 0 40px;
        margin-bottom: 10px;
    }
    #staff .detail_sec02 .career_block dl dt {
        font-size: 18px;
        font-weight: 700;
        line-height: 2; 
        letter-spacing: 0.04em;
    }
    #staff .detail_sec02 .career_block dl dd p {
        font-size: 18px;
        font-weight: 400;
        line-height: 2;
        letter-spacing: 0.04em;
    }
    
    #staff .detail_sec02 .other_block {
        width: calc(50% - 22px);
    }
    #staff .detail_sec02 .other_block ul {
        padding: 0 18px 0 40px;
    }
    #staff .detail_sec02 .other_block ul li {
        margin-bottom: 10px;
        padding-left: 18px;
        position: relative;
        font-size: 18px;
        font-weight: 400;
        line-height: 1.77;
        letter-spacing: 0.04em;
    }
    #staff .detail_sec02 .other_block ul li::before {
        content: '';
        position: absolute;
        left: 0;
        top: 12.5px;
        width: 9px;
        height: 9px;
        border-radius: 50%;
        background: var(--text-color);
    }


    
    /* ------------------------------------
    /  FAQ よくあるご質問
    /-------------------------------------*/
    #faq .txt {
        font-size: 18px;
        font-weight: 500;
        line-height: 2.44;
        letter-spacing: 0.04em;
    }
    
    #faq .sec01 {
        padding-bottom: 140px;
    }
    #faq .sec01 h2 {
        margin-bottom: 53px;
    }
    #faq .sec01 .faq_acd {
        margin-top: 40px;
    }
    #faq .sec01 .faq_acd dl {
        position: relative;
        padding: 30px 40px;
        border-top: 1px solid var(--bdr-color);
    }
    #faq .sec01 .faq_acd dl:last-of-type {
        border-bottom: 1px solid var(--bdr-color);
    }
    #faq .sec01 .faq_acd dl dt,
    #faq .sec01 .faq_acd dl dd {
        position: relative;
    }
    #faq .sec01 .faq_acd dl dt {
        padding: 0 50px;
        cursor: pointer;
    }
    #faq .sec01 .faq_acd dl dt p {
        font-size: 20px;
        font-weight: 700;
        line-height: 2;
        letter-spacing: 0.04em;

    }
    #faq .sec01 .faq_acd dl dt.active p {
        opacity: 0.5;
    }
    #faq .sec01 .faq_acd dl dt::before,
    #faq .sec01 .faq_acd dl dd::before  {
        position: absolute;
        font-family: "Poppins", sans-serif;
        font-size: 36px;
        font-weight: 500;
        letter-spacing: 0.04em;
        line-height: 1;
    }
    #faq .sec01 .faq_acd dl dt::before {
        content: 'Q';
        top: 0;
        left: 0;
        opacity: 1;
    }
    #faq .sec01 .faq_acd dl dd {
        display: none;
        margin-top: 24px;
        padding-left: 70px;
        font-size: 18px;
        font-weight: 700;
        line-height: 2.1;
        letter-spacing: 0.04em;
    }
    #faq .sec01 .faq_acd dl dd::before {
        content: 'A';
        top: 0;
        left: 24px;
        color: var(--main-color);
    }
    
    #contact {
        margin: 0 auto;
        padding: 91px 0 130px;
        width: 1760px;
        max-width: 100%;
        border-radius: 70px 70px 0 0;
        background: url(../../images/src/top/sec01_bg01.png);
    }
    #contact h2 {
        margin-bottom: 63px;
    }
    #contact .cta_box {
        margin: 0 auto 80px;
        box-shadow: 10px 10px 0 #F2B3BC;
    }
    #contact .contact_area {
        padding: 70px 100px 76px;
        border-radius: 12px;
        background: #fff;
        box-shadow: 10px 10px 0 #F2B3BC;
    }
    #contact .contact_area .ttl01 {
        margin: 22px 0 41px;
        color: var(--main-color);
        font-size: 22px;
        font-weight: 700;
        letter-spacing: 0.04em;
        text-align: center;
    }
    #contact .contact_area table th {
        padding: 11px 0;
        display: flex;
        align-items: center;
        width: 230px;
        font-size: 20px;
        font-weight: 700;
        letter-spacing: 0.04em;
        vertical-align: top;
    }
    #contact .contact_area table th span {
        margin-left: auto;
        padding: 0 4px;
        color: #fff;
        font-size: 14px;
        font-weight: 700;
        border-radius: 2px;
        background: #B20000;
    }
    #contact .contact_area table td {
        vertical-align: top;
        padding: 11px 0;
        width: 706px;
        font-size: 18px;
        font-weight: 400;
        letter-spacing: 0.04em;
    }
    
    #contact .contact_area table td input[type="text"],
    #contact .contact_area table td textarea {
        padding: 22px;
        width: 100%;
        border: 0;
        border-radius: 12px;
        box-sizing: border-box;
        background: #F6F5F2;
        font-size: 18px;
        font-weight: 400;
    }
    #contact .contact_area table td input::placeholder,
    #contact .contact_area table td textarea::placeholder {
        color: rgba(172, 145, 107, 0.60);
    }
    #contact .contact_area table td .file_btn {
        margin-top: 16px;
    }
    #contact .contact_area table td textarea {
        height: 200px;
    }
    #contact .sendbtn {
        text-align: center;
    }
    #contact .sendbtn .flex {
        justify-content: center;
        gap: 0 18px;
    }
    #contact .sendbtn p {
        width: 308px;
    }
    #contact .sendbtn .send {
        position: relative;
        border-radius: 180px;
        border: 6px solid #FCE1E6;
        background: var(--main-color);
    }
    #contact .sendbtn .comfirm_btn {
        margin: 0 auto;
    }
    #contact .sendbtn .back {
        position: relative;
        border-radius: 180px;
        border: 6px solid var(--bdr-color);
        background: #fff;
    }
    #contact .sendbtn input[type="submit"] {
        width: 100%;
        padding: 19px 0;
        color: #fff;
        font-size: 20px;
        font-weight: 700;
        letter-spacing: 0.04em;
        border: none;
        background: transparent;
        cursor: pointer;
    }
    #contact .sendbtn .back input[type="submit"] {
        color: var(--text-color);
    }
    #contact .sendbtn .comfirm_btn input[type="submit"] {
        margin-left: -24px;
    }
    
    #contact .sendbtn .send::after {
        content:'';
        position: absolute;
        top: 4px;
        bottom: 0;
        right: 22px;
        margin: auto;
        width: 26px;
        height: 27px;
        background: url(../../images/src/common/arrow_white_right01.svg) no-repeat left top / 100%;
    }
    #contact .sendbtn .back::after {
        content:'';
        position: absolute;
        top: 4px;
        bottom: 0;
        left: 22px;
        margin: auto;
        width: 26px;
        height: 27px;
        background: url(../../images/src/common/arrow_brown_left.svg) no-repeat left top / 100%;
    }
    

    /* ------------------------------------
    /  ACCESS アクセス
    /-------------------------------------*/
    #access .txt {
        font-size: 18px;
        font-weight: 400;
        line-height: 1.8;
        letter-spacing: 0.04em;
    }
    #access .txt .pc {
        display: inline !important;
    }
    #access .gmap {
        margin: 83px auto 13px;
    }
    #access .gmap iframe { 
        width: 100%;
        height: 476px;
    }
    #access .txt_btn {
        margin-bottom: 90px;
    }
    #access .txt_btn a {
        display: block;
        position: relative;
        padding-right: 35px;
        font-size: 16px;
        font-weight: 700;
        letter-spacing: 0.04em;
        transition: .7s;
    }
    #access .txt_btn a::after {
        content:'';
        position: absolute;
        top: 0;
        bottom: 0;
        right: 0;
        margin: auto;
        width: 26px;
        height: 27px;
        background: url(../../images/src/common/arrow_pink_right01.svg) no-repeat left top / 100%;
        transition: .7s;
    }
    #access .sec01 .movie {
        margin: 80px auto 30px;
    }
    #access .sec01 .txt + .txt {
        margin-top: 1em;
    }
    #access .sec02 {
        margin: 150px auto 120px;
    }
    #access .sec02 p {
        margin: 60px 0 33px;
        font-size: 22px;
        font-weight: 700;
        line-height: 2;
        letter-spacing: 0.04em;
        text-align: center;
        
    }
    #access .sec02 .img {
        margin: 0 auto;
        width: 756px;
        max-width: 100%;
    }
    



    /* ------------------------------------
    /  PRIVACY POLICY プライバシーポリシー
    /-------------------------------------*/
    #policy .txt {
        font-size: 18px;
        font-weight: 400;
        line-height: 2.44;
        letter-spacing: 0.04em;
    }
    #policy dl + dl {
        margin-top: 50px;
    }
    #policy dl dt {
        margin-bottom: 10px;
        font-size: 22px;
        font-weight: 700;
        line-height: 1.58;
        
    }
    #policy dl dt span {
        color: var(--main-color);
        font-size: 24px;
        font-weight: 600;
    }
    #policy dl dd {
        font-size: 18px;
        font-weight: 400;
        line-height: 2.1;
        letter-spacing: 0.04em;
    }
    #policy .box {
        margin:90px 0 140px;
    }
    #policy .box .ttl {
        font-size: 20px;
        font-weight: 700;
    }
    
}




@media screen and (max-width:1280px) {
    .hero_block .hero_img {
        width: 805px;
    }
    .hero_block .hero_img img {
        object-position: left;
        height: 720px;
    }
    .hero_block .hero_txt_area {
        top: 149px;
        left: 40px;
    }
    .hero_block .hero_txt_area p {
        font-size: 18px;
    }
    .hero_block .hero_txt_area .txt {
        margin-bottom: 31px;
        line-height: 2;
    }
    .hero_block .hero_txt_area .hero_btn {
        width: 301px;
    }
    .hero_block .hero_txt_area .hero_btn a {
        padding: 5px 0 5px 8px;
        font-size: 18px;
        border-width: 4px;
    }
    .hero_block .hero_txt_area .hero_btn a::before {
        width: 33px;
        height: 33px;
    }
    .hero_block .hero_txt_area .hero_btn a::after {
        width: 21px;
        height: 22px;
    }
    .top_sec01 {
        margin-top: -146px;
        padding-top: 236px;
    }
    .top_sec01 .information_block .recp_block .sp_scroll {
        overflow-x: scroll;
    }
    .top_sec01 .information_block .recp_block .sp_scroll  table {
        width: 500px;
    }
    .top_sec02 .box,
    .top_sec02 .even .box {
        width: clamp(25rem, -2.572rem + 53.22vw, 40rem);
    }
    .top_sec02 .img {
        width: clamp(22rem, -0.977rem + 44.35vw, 34.5rem);
    }
    .top_sec03 .parts {
        width: calc(30% - 14px);
    }

    #introduction .sec01 {
        gap: 0 45px;
    }
    #introduction .sec01 .box {
        width: clamp(25rem, 13.512rem + 22.17vw, 31.25rem);
    }
    #introduction .sec01 h2.intro_ttl {
        font-size: clamp(1.625rem, 0.706rem + 1.77vw, 2.125rem);
    }
    #introduction .sec03 .intro_equipment .box {
        width: clamp(25rem, 13.512rem + 22.17vw, 31.25rem);
    }
    #herbal .sec01 {
        gap: 0 45px;
    }
    #herbal .sec01 .box {
        width: 40%;
    }
    #herbal .sec01 h2.intro_ttl {
        font-size: 28px;
        line-height: 1.6;
    }
    #herbal .sec02 .list_img li {
        width: 31.67%;
    }
    #herbal .sec02 ul li .txt {
        white-space: wrap;
        line-height: 1.66;
    }
    #herbal .sec02 ul li,
    #genom .sec02 ul li {
        width: 23.3334%;
    }
    #fetus .sec02 .parts .img {
        width: 37.04%;
    }
    #fetus .sec02 .parts .right_col {
        width: 58.3%;
    }
    #online .sec01 .block .img {
        width: 48.33%;
    }
    #online .sec01 .block .right_col {
        width: 46.83%;
    }
    #online .sec01 .block .right_col ul li {
        padding: 15px 15px 15px 151px;
        min-height: 97px;
    }
}

@media screen and (max-width:1180px) {
    .top_sec01 .information_block .flex > div {
        padding: 15px 35px;
    }
    .top_sec01 .information_block .txt,
    .top_sec01 .information_block .txt02 {
        margin-left: -13px;
        font-size: 14px;
    }
    .top_sec01 .information_block .recp_block table tbody tr:nth-of-type(1), 
    .top_sec01 .information_block .recp_block table tbody tr:nth-of-type(3) {
        border-bottom-width: 1px;
    }
    #online .sec02 .step_area .parts::after {
        right: -27px;
        width: 20px;
        height: 23px;
    }
}
@media screen and (max-width:960px) {
    .hero_block .hero_txt_area h1 .txtcolor {
        display: block;
    }
    #introduction .sec03 .intro_equipment {
        gap: 0 40px;
    }
}
@media screen and (max-width:960px) {
    #introduction .sec01 .box {
        width: calc(44% - 1px);
    }
}
@media screen and (max-width:940px) {
    #introduction .sec01 .img {
        width: 40%;
    }
}




/*SP用*/
@media screen and (max-width:828px) {
	.pc { display: none !important }
	.sp { display: block !important }
	img { max-width: 100%; height: auto; width: auto; }
	body { min-width: auto !important; overflow: inherit !important; }
	.sp_tac { text-align: center !important; }
	.sp_tar { text-align: right !important; }
	div, p, dd, dl, dt, th, td, span, li { box-sizing: border-box; }
    /* 汎用ページ */
    .inner_1200 {
        margin: 0 auto;
        width: auto;
        max-width: initial;
    }
    .inner h2 {
        font-size: 5.556vw;
    }
    .inner h2 .ttl_en {
        padding-bottom: 0.966vw;
        font-size: 3.623vw;
    }

    .follow_block {
        width: 91.304vw;
        height: 17.633vw;
        right: 0;
        left: 0;
        margin: auto;
        bottom: 2.899vw;
        border-radius: 1.449vw;
        border-width: 0.242vw;
        box-shadow: 6px 6px 0 rgba(191,186,176,.7);
    }
    .follow_block ul {
        padding: 1.812vw 0 0 3.623vw;
        width: 73.671vw;
        border-radius:  1.449vw 0 0 1.449vw;
    }
    .follow_block ul li::before {
        width: 0.121vw;
        height: 6.522vw;
    } 
    .follow_block ul li a {
        padding: 0 5.314vw;
        font-size: 2.899vw;
    }
    .follow_block ul li:first-of-type a {
        padding: 0 4.6vw;
    }
    .follow_block ul li:last-of-type a {
        padding: 0 1.932vw;
    }
    .follow_block ul li a span {
        margin: 0 auto;
    }
    .follow_block ul li a span img {
        width: 6.159vw;
    }
    .follow_block ul li:first-of-type a span img {
        width: 8.937vw;
    }
    .follow_block ul li:last-of-type a span img {
        width: 11.111vw;
    }

    .follow_block .link_top {
        padding-top: 6.831vw;
        width: 16.425vw;
        font-size: 3.623vw;
        border-radius:  0 0.966vw 0.966vw 0;
    }
    .follow_block .link_top::before {
        top: 2.691vw;
        width: 5.193vw;
        height: 5.314vw;
    }
    
    .bnr-swiper {
        position: relative;
        padding: 9.662vw 0;
        background: url(../../images/src/common/bnr_bg.png);
        background-size: cover;
        overflow: hidden;
    }
    .swiper-button-next {
        right: 6.5vw !important;
    }
    
    .swiper-button-prev {
        left: 6.5vw !important;
    }
    .bnr-swiper .swiper-slide img {
        width: 100%;
    }
    .bnr-swiper .swiper-button-next:after {
        content:'';
        width: 7.488vw;
        height: 7.609vw;
        background: url(../../images/src/common/arrow_pink_right01.svg) no-repeat left top / 100%;
        transition: .7s;
    }
    .bnr-swiper .swiper-button-prev:after {
        content:'';
        width: 7.488vw;
        height: 7.609vw;
        background: url(../../images/src/common/arrow_pink_left01.svg) no-repeat left top / 100%;
        transition: .7s;
    }

    .cta_area {
        padding: 9.662vw 0 12.077vw;
    }
    .cta_area .inner h2 span {
        font-size: 7.005vw;
    }
    .cta_area .inner h2 .ttl_en {
        font-size: 3.865vw;
    }
    .cta_area .inner h2 .quote::before,
    .cta_area .inner h2 .quote::after {
        width: 3.502vw;
        height: 2.778vw;
    }
    .cta_area .inner h2 .quote::before {
        top: 0.725vw;
        left: -2.053vw;
        background: url(../../images/src/common/quote01.svg) no-repeat left top / 100%;
    }
    .cta_area .inner h2 .quote::after {
        bottom: -0.362vw;
        right: -1.57vw;
        background: url(../../images/src/common/quote02.svg) no-repeat left top / 100%;
    }
    .cta_area .inner .cta_txt {
        margin: 2.415vw auto 0;
        font-size: 3.865vw;
        line-height: 1.8125;
    }
    .cta_area .inner .cta_block {
        margin: 4.831vw 4.831vw 0;
    }
    .cta_area .inner .flex {
        gap: 4.831vw;
    }
    .cta_area .inner a {
        display: block;
    }
    .cta_area .inner .cta_box,
    #contact .cta_box {
        padding: 3.623vw 0;
        width: 100%;
        border-radius: 1.449vw;
        background: #fff;
        box-shadow: 1.449vw 1.449vw 0 #E0788C;
    }
    .cta_area .inner a.cta_box {
        width: calc(50% - 3vw);
    }
    .cta_area.ft_cta .inner .cta_box,
    #contact .cta_box {
        width: 100%;
    }
    .cta_area .inner a.cta_box::after {
        bottom: 1.932vw;
        right: 1.932vw;
        width: 5.314vw;
        height: 5.435vw;
    }
    .cta_area .inner .cta_box .ico,
    .cta_area .inner .cta_box .ico img {
        height: 9.3vw;
    }
    .cta_area .inner .cta_box .ico.mail,
    .cta_area .inner .cta_box .ico.faq {
        margin-bottom: 2vw;
    }
    .cta_area .inner .cta_box .ico.mail img {
        height: 5.314vw;
    }
    .cta_area .inner .cta_box .pink_tl {
        font-size: 3.865vw;
    }

    .cta_area.ft_cta .inner .cta_box .pink_tl {
        font-size: 3.865vw;
    }
    .cta_area .inner .cta_box .ttl {
        font-size: 4.831vw;
    }
    .cta_area .inner .cta_box .ttl a {
        font-size: 7.005vw;
    }
    .cta_area.ft_cta  .inner .cta_box .ttl {
        font-size: 4.831vw;
    }
    .cta_area.ft_cta .inner .cta_box .ttl a {
        font-size: 7.005vw;
    }
    .cta_area .inner .cta_box dl,
    #contact .cta_box dl.flex {
        gap: 0 1.812vw;
    }
    .cta_area .inner .cta_box dl dt,
    .cta_area .inner .cta_box dl dd,
    #contact .cta_box dl dt,
    #contact .cta_box dl dd {
        font-size: 3.14vw;
    }

    /*-------------
    TOP page
    ---------------*/
    .hero_block {
        position: relative;
        z-index: 10;
    }
    .hero_block .hero_txt_area {
        margin: 4.831vw 4.831vw 0;
        position: static;
    }
    .hero_block .hero_txt_area p {
        font-size: 3.865vw;
    }
    .hero_block .hero_txt_area .hero_text {
        font-size: 4.786vw;
    }
    .hero_block .hero_txt_area .hero_text .quote {
        font-size: 5.85vw;
    }
    .hero_block .hero_txt_area .hero_text .quote::before,
    .hero_block .hero_txt_area .hero_text .quote::after {   
        width: 3.261vw;
        height: 2.657vw;
    }
    .hero_block .hero_txt_area .hero_text .quote::before {
        left: -2.174vw;
    }
    .hero_block .hero_txt_area .hero_text .quote::after {
        right: -1.087vw;
    }

    .hero_block .hero_txt_area h1 {
        margin: -2.053vw 0 3.14vw;
        font-size: 8.937vw;
    }
    .hero_block .hero_txt_area h1 span {
        font-size: 7.729vw;
    }
    .hero_block .hero_txt_area h1 .txtcolor {
        display: block;
        font-size: 8.937vw;
    }
    .hero_block .hero_txt_area .txt {
        margin-bottom: 4.831vw;
        line-height: 2.23;
    }
    .hero_block .hero_txt_area .hero_btn {
        margin-left: -0.725vw;
        width: 66.184vw;
    }
    .hero_block .hero_txt_area .hero_btn a {
        padding: 1.932vw 0 2.657vw 0.966vw;
        font-size: 3.865vw;
        border-radius: 36.957vw;
        border-width: 0.966vw;
    }
    .hero_block .hero_txt_area .hero_btn a::before {
        left: 5.435vw;
        width: 7.85vw;
        height: 7.85vw;
    }
    .hero_block .hero_txt_area .hero_btn a::after {
        right: 3.623vw;
        width: 5.314vw;
        height: 5.435vw;
    }
    .hero_block .hero_img {
        margin: 6.159vw 0 0 auto;
        width: 95.169vw;
    }
    .hero_block .hero_img img {
        height: auto;
    }
    #hero--scroll {
        left: auto;
        right: 7.415vw;
        top: -24vw;
        height: 45px;
        z-index: 100;
    }

    #hero--scroll span {
        display: inline-block;
        transform: rotate(-90deg);
        transform-origin: left top;
        position: absolute;
        top: -10px;
        font-size: 14px;
        color: var(--main-color);
    }

    #hero--scroll:before {
        content: "";
        position: absolute;
        left: .5rem;
        top: 0;
        height: 0;
        width: 1px;
    }

    .top_sec01 {
        padding: 65.942vw 0 12.077vw;
        margin-top: -53.865vw;
    }
    .top_sec01 .information_block {
        margin: 0 4.831vw;
        width: auto;
        max-width: initial;
    }
    .top_sec01 .information_block .flex > div {
        padding: 5vw 3vw;
        width: 100%;
        height: auto;
        border-radius: 1.859vw;
        overflow: hidden;
    }
    .top_sec01 .information_block .ttl {
        margin-bottom: 4.348vw;
        font-size: 4.589vw;
    }

    .top_sec01 .information_block .txt,
    .top_sec01 .information_block .txt02 {
        font-size: 3.382vw;
        font-weight: 400;
        text-align: left;
    }
    .top_sec01 .information_block .txt {
        text-indent: -3.382vw;
        margin-left: 3.382vw;
        white-space: normal;
    }
    .top_sec01 .information_block .txt02 {
        font-weight: 500;
        white-space: nowrap;
        margin-left: 0;
    }
    .top_sec01 .information_block .recp_block .sp_scroll {
        margin-bottom: 4.348vw;
        overflow-x: scroll;
        /*width: 90.338vw;*/
        width: 100%;
    }
    .top_sec01 .information_block .recp_block .sp_scroll table {
        width: auto;
        min-width: 450px; 
        margin: 3.865vw auto 4.348vw;
    }

    
    .top_sec01 .information_block .recp_block table thead,
    .top_sec01 .information_block .recp_block table tbody,
    .top_sec01 .information_block .recp_block table tbody tr:nth-of-type(2) {
        border-bottom: 2px solid #D5CDC0;
    }
    .top_sec01 .information_block .recp_block table tbody tr:nth-of-type(1) td,
    .top_sec01 .information_block .recp_block table tbody tr:nth-of-type(3) td {
        border-bottom: 2px dotted #D5CDC0;
    }
    .top_sec01 .information_block .recp_block table thead th,
    .top_sec01 .information_block .recp_block table thead td,
    .top_sec01 .information_block .recp_block table tbody th {
        font-size: 3.382vw;
    }
    .top_sec01 .information_block .recp_block table thead th {
        padding-right: 10px;
    }
    .top_sec01 .information_block .recp_block table thead th i {
        margin: 0.242vw 0 0;
        width: 5.314vw;
    }
    .top_sec01 .information_block .recp_block table thead td {
        padding-bottom: 13px;
        width: 64px;
    }
    .top_sec01 .information_block .recp_block table tbody th {
        width: 24.155vw;
    }
    .top_sec01 .information_block .recp_block table tbody td {
        padding: 1.329vw 0 2.778vw;
    }
    .top_sec01 .information_block .recp_block table tbody td a {
        padding: 0;
        font-size: 3.382vw;
        border-width: 0.302vw;
        border-radius: 0.604vw;
    }
    .top_sec01 .information_block .recp_block table tbody td small {
        margin: 0;
        font-size: 2.415vw;
    }


    .top_sec01 .information_block .flex .news_block {
        margin-top: 6.039vw;
        overflow-y: scroll;
        height: 100.242vw;
    }
    .top_sec01 .information_block .flex .news_block .ttl {
        margin-bottom: 4.831vw;
    }
    .top_sec01 .information_block .flex .news_block a dl {
        padding: 4.348vw 13.043vw 5.556vw 2.415vw;
        border-top-width: 0.121vw;
    }
    .top_sec01 .information_block .flex .news_block a dl::before {
        right: 2.415vw;
        width: 5.314vw;
        height: 5.435vw;
    }
    .top_sec01 .information_block .flex .news_block a:last-of-type dl {
        border-bottom-width: 0.121vw;
    }

    .top_sec01 .information_block .flex .news_block a dl dt {
        margin-bottom: 1.087vw;
        font-size: 3.623vw;
    }
    .top_sec01 .information_block .flex .news_block a dl dt span {
        font-size: 3.14vw;
        line-height: 1.34;
    }
    .top_sec01 .information_block .flex .news_block a dl dd {
        font-size: 3.382vw;
        line-height: 1.6428;
    }

    .top_sec02 {
        padding: 12.077vw 0 13.285vw;
    }
    .top_sec02 .sec02_block + .sec02_block {
        margin-top: 14.493vw;
    }
    .top_sec02 .box,
    .top_sec02 .even .box {
        order: 2;
        margin: 7.246vw 4.831vw 0;
        width: auto;
    }
    .top_sec02 .box h2 {
        margin-bottom: 15.5px;
        text-align: left;
        font-size: 7.246vw;
    }
    .top_sec02 .box .txt {
        margin-bottom: 2.415vw;
        font-size: 3.623vw;
        line-height: 1.933;
    }
    .top_sec02 .box .list_btn {
        margin-bottom: 7.246vw;
    }
    .top_sec02 .box .list_btn li a {
        border-top-width: 0.121vw;
        padding: 2.657vw 0 2.657vw 7.729vw;
        font-size: 3.865vw;
    }
    .top_sec02 .box .list_btn li:last-of-type a {
        border-bottom-width: 0.121vw;
    }
    .top_sec02 .box .list_btn li a::before {
        left: 0;
        width: 5.314vw;
        height: 5.435vw;
    }
    .top_sec02 .box .btn {
        width: 50vw;
    }
    .top_sec02 .box .btn a {
        padding: 3.382vw 0;
        font-size: 3.865vw;
        border-radius: 21.739vw;
        border-width: 1.087vw;
        text-indent: -1em;
    }
    .top_sec02 .box .btn a::before {
        left: 4.167vw;
        width: 3.623vw;
        height: 3.261vw;
    }
    .top_sec02 .box .btn a::after {
        right: 1.932vw;
        width: 5.314vw;
        height: 5.435vw;
    }

    .top_sec02 .img {
        order: 1;
        margin-left: auto;
        width: 95.169vw;
    }
    .top_sec02 .even .img {
        margin-left: 0;
    }
    .top_sec02 .img img,
    .top_sec02 .even .img img {
        height: auto;
    }

    .top_sec03 {
        padding: 10.87vw 0 13.285vw;
    }
    .top_sec03 .flex {
        margin: 4.831vw 4.831vw 0;
        gap: 6.039vw 0;
    }
    .top_sec03 .parts {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        padding: 3.623vw 3.623vw 6.884vw;
        width: 100%;
        border-radius: 1.449vw;
        box-shadow: 1.449vw 1.449vw 0 rgba(169,146,123,.4);
    }
    .top_sec03 .parts::after {
        bottom: 2.415vw;
        right: 2.415vw;
        width: 5.314vw;
        height: 5.435vw;
    }
    .top_sec03 .parts .img {
        width: 42.271vw;
    }
    .top_sec03 .parts .img img {
        border-radius: 1.449vw 1.449vw 0 0;
    }
    .top_sec03 .parts .ttl {
        margin: 0 0 0 5.797vw;
        font-size: 4.589vw;
    }
    .top_sec03 .parts .txt {
        width: 100%;
        margin: 2.415vw 0 0;
        font-size: 3.623vw;
        line-height: 1.8;
    }
    .top_swiper {
        height: 57.971vw;
    }

    .top_sec04 {
        padding: 10.87vw 0 18.116vw;
    }
    .top_sec04 .inner {
        margin: 0 4.831vw;
        width: auto;
        max-width: initial;
    }
    .top_sec04 .inner .flex {
        margin-top: 4.831vw;
    }
    .top_sec04 .inner .flex .img {
        width: 100%;
    }
    .top_sec04 .inner .flex .right {
        margin-top: 4.831vw;
        width: 100%;
    }
    .top_sec04 .inner .flex .right iframe {
        border-radius: 1.449vw;
        width: 100%;
        height: 57.729vw;
    }
    .top_sec04 .inner .flex .right .txt_btn a {
        padding-right: 6.643vw;
        font-size: 3.623vw;
    }
    .top_sec04 .inner .flex .right .txt_btn a::after {
        width: 5.314vw;
        height: 5.435vw;
    }
    .top_sec04 .inner .flex .right .circle_btn a {
        left: 3.623vw;
        bottom: -3.623vw;
        padding-top: 5.797vw;
        width: 24.758vw;
        height: 24.758vw;
        font-size: 3.623vw;
        line-height: 1.13;
        border-width: 1.449vw;
    }
    .top_sec04 .inner .flex .right .circle_btn a::after {
        width: 5.314vw;
        height: 5.435vw;
    }

/* 下層
------------------*/
    .lower_mv {
        margin: 8.696vw auto 13.285vw;
        width: auto;
        max-width: initial;
    }
    .lower_mv .inner {
        position: relative;
        align-items: center;
    }
    .lower_mv .inner .left_text_area {
        margin: -8.937vw 4.831vw 0;
        order: 2;
        position: static;
        width: auto;
    }
    .lower_mv .inner .left_text_area.privacy_text {
        width: auto;
    }
    .lower_mv .inner .left_text_area .ttl_en {
        text-align: center;
    }

    .lower_mv .inner .left_text_area .flex {
        margin-bottom: 1.449vw;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        gap: 3.502vw 0;
    }
    .lower_mv .inner .left_text_area .img {
        width: 16.425vw;
    }
    .lower_mv .inner .left_text_area .ttl_en {
        font-size:3.623vw;
    }
    .lower_mv .inner .left_text_area h1 {
        font-size: 6.522vw;
        line-height: 1.44;
        text-align: center;
    }
    .lower_mv .inner .left_text_area .mv_txt {
        font-size: 3.623vw;
        line-height: 1.9;
        text-align: center;
    }
    .lower_mv .mv_img {
        order: 1;
        margin-left: 0;
        width: 100%;
    }
    .lower_mv .mv_img img {
        object-position: left;
        height: auto;
        border-radius: 0;
    }

    /* breadcrumbs */
    .breadcrumbs {
        position: absolute;
        top: 16.7vw;
        left: 0;
        margin: 0;
        padding: 0 0 0 3.623vw;
        width: 100%;
        max-width: initial;
        text-align: left;
    }
    .breadcrumbs span {
        font-size: 3.382vw;
        line-height: 1.3;
    }
    .breadcrumbs span a span {
        font-size: 3.382vw;
        line-height: 1.3;
    }

    /* page-navi */
    .wp-pagenavi {
        margin-top: 110px;
        text-align: center;
    }
    .wp-pagenavi a,
    .wp-pagenavi .current {
        display: inline-block;
        margin: 0 10px;
        font-size: 18px;
        font-weight: 700;
        width: 34px;
        height: 34px;
    }
    .wp-pagenavi .current{
        color: #fff;
        border-radius: 50%;
        background: var(--main-color); 
        line-height: 31px;
        text-align: center;
    }
    .wp-pagenavi .previouspostslink,
    .wp-pagenavi .nextpostslink {
        padding: 0 ;
    }

    .lower_section {
        margin: 0 auto;
        width: auto;
        max-width: initial;
    }
    .lower_h2 span {
        font-size: 6.039vw;
        display: inline-block;
    }
    .lower_h2 span::after {
        bottom: -3.749vw;
        width: 9.662vw;
        height: 0.483vw;
    }


    /* wysiwyg用 */
    .wysiwyg {}
    .wysiwyg p {
        margin-bottom: 12.077vw;
        font-size: 3.623vw;
        line-height: 1.93;
    }
    .wysiwyg strong {
        font-size: 5.072vw;
    }
    .wysiwyg img {
        border-radius: 1.691vw;
    }
    .wysiwyg h2,
    #treatment h2 {
        margin-bottom: 3.623vw;
        padding: 3.382vw 8.213vw 3.865vw;
        font-size: 5.314vw;
        border-radius: 0.845vw;
    }
    .wysiwyg h2::before,
    #treatment h2::before {
        left: 4.831vw;
        top: 3.382vw;
        width: 0.604vw;
        height: 8.454vw;
    }
    .wysiwyg h3,
    #treatment h3 {
        margin-bottom: 5.556vw;
        padding-bottom: 2.053vw;
        font-size: 4.589vw;
        background-size: 100%;
        background: url(../../images/src/treatment/sp/border.svg) no-repeat left bottom / 100%;
    }
    .wysiwyg h4,
    #treatment h4 {
        margin-bottom: 2.053vw;
        padding-left: 2.295vw;
        border-left-width: 0.604vw;
        font-size: 4.589vw;
    }
    .wysiwyg h5 ,
    #treatment h5 {
        margin-bottom: 1.449vw;
        padding: 0.845vw 3.261vw;
        font-size: 3.865vw;
        border-radius: 21.739vw;
    }
    .wysiwyg h6,
    #treatment h6 {
        font-size: 3.865vw;
        line-height: 1.8;
    }
    .wysiwyg ul {
        margin-bottom: 4.831vw;
    }
    .wysiwyg ol {
        margin-bottom: 4.831vw;

    }
    .wysiwyg li {
        margin-bottom: 1.812vw;
        font-size: 3.623vw;
    }
    .wysiwyg ul li {
        padding-left: 4.348vw;
    }
    .wysiwyg ul li::before {
        top: 2.1vw;
        bottom: auto;
        width: 2.053vw;
        height: 2.053vw;
    }
    .wysiwyg ol li {
        padding-left: 7.246vw;
    }
    .wysiwyg ol li::before {
        position: absolute;
        left: 4.831vw;
        font-size: 4.106vw;
    }
    .wysiwyg table td {
        display: block;
        padding: 0 3.623vw 3.623vw;
        font-size: 3.623vw;
    }
    .wysiwyg table tr td:first-of-type {
        padding: 3.623vw;
        width: auto;
    }
    .wysiwyg table tr td:first-of-type:after {
        display: none;
    }
    /* ------------------------------------
    /  news お知らせ
    /-------------------------------------*/
    #news .inner_1000 {
        margin: 0 4.831vw;
        width: auto;
        max-width: initial;
    }
    #news .news_title_area {
        margin-bottom: 12.077vw;
    }
    #news .news_title_area .date {
        font-size: 3.382vw;
        line-height: 1.27;
    }
    #news .news_title_area h2 {
        margin-bottom: 8.937vw;
    }
    #news .news_title_area .eyecatch img {
        border-radius: 1.691vw;
    }
    #news .news_content {
        margin-bottom: 14.493vw;
    }



    /* ------------------------------------
    /  introduction クリニックのご紹介 
    /-------------------------------------*/

    #introduction h2.intro_ttl {
        font-size: 6.522vw;
    }
    #introduction .txt {
        font-size: 3.623vw;
        line-height: 1.93;
    }
    #introduction h2.intro_ttl .up_txt {
        margin-bottom: 3.623vw;
        font-size: 4.106vw;
    }
    #introduction .sec01 {
        margin-bottom: 12.077vw;
        gap: 6.039vw 0;
    }
    #introduction .sec01 .img {
        order: 2;
        width: 95.169vw;
    }
    #introduction .sec01 .img img {
        /*border-radius: 0;*/
        height: auto;
    }
    #introduction .sec01 .box {
        order: 1;
        margin: 0 4.831vw;
        width: auto;
    }
    #introduction .sec01 h2.intro_ttl {
        margin-bottom: 2.415vw;
        font-size: 5.556vw;
        line-height: 1.78;
    }
    #introduction .sec02 {
        margin: 0;
        padding: 10.87vw 4.831vw 12.077vw;
        width: auto;
    }
    #introduction .sec02 .txt {
        margin: 3.623vw 0 7.246vw;
        text-align: left !important;
    }
    .intro_slide_block {
        width: auto;
        max-width: initial;
        margin: 0 auto;
    }
    .intro_slide_block .mySwiper .swiper-slide {
        width: 81.522vw;
    }
    .intro_slide_block .mySwiper .swiper-slide img {
        border-radius: 1.691vw 1.691vw 0 0;
    }
    .intorduction_slide_controls {
        margin-top: 4.469vw;
    }
    .intorduction_slide_btn {
        width:24.638vw;
    }
    .intorduction_slide_btn .swiper-button-prev,
    .intorduction_slide_btn .swiper-button-next {
        position: relative;
        top: auto;
        right: auto;
        bottom: auto;
        left: auto;
        width: 10.749vw;
        height: 10.749vw;
        margin: 0;
        -webkit-transition: 0.3s;
        transition: 0.3s;
    }
    .intorduction_slide_btn .swiper-button-prev {
        left: 0 !important;
    }
    .intorduction_slide_btn .swiper-button-next {
        right: 0 !important;
    }
    .intorduction_slide_btn .swiper-button-prev::after,
    .intorduction_slide_btn .swiper-button-next::after {
        width: 10.749vw;
        height: 10.749vw;
    }
    .intorduction_slide_controls .swiper-pagination {
        position: relative;
        width: calc(100% - 31.754vw);
        height: 1.449vw;
        border-radius: 1.449vw;
    }
    .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
        border-radius: 1.449vw;
    }

    
    #introduction .sec03 {
        padding: 10.87vw 4.831vw 14.493vw;
    }
    #introduction .sec03 h2 {
        margin-bottom: 4.831vw;
    }
    #introduction .sec03 .intro_equipment {
        gap: 0;
    }
    #introduction .sec03 .intro_equipment.even {
        margin: 8.454vw 0;
    }
    #introduction .sec03 .intro_equipment .img {
        margin-top: 3.382vw;
        order: 2;
        width: 100%;
    }
    #introduction .sec03 .intro_equipment .img img {
        height: auto;
        border-radius: 1.449vw;
    }
    #introduction .sec03 .intro_equipment.even .img img {
        border-radius: 1.449vw;
    }
    #introduction .sec03 .intro_equipment .box {
        order: 1;
        display: flex;
        flex-direction: column;
        width: 100%;
    }
    #introduction .sec03 .intro_equipment .box h3 {
        margin-bottom: 2.415vw;
        font-size: 6.28vw;
    }
    #introduction .sec03 .intro_equipment .box h3 span {
        padding-right: 2.415vw;
        font-size: 6.28vw;
    }

    #introduction .sec03 .intro_equipment .box .box_img {
        margin-top: 4.831vw;
    }
    #introduction .sec03 .intro_equipment .box .box_parts {
        margin-top: 4.831vw;
        padding: 4.831vw;
    }
    #introduction .sec03 .intro_equipment .box .box_parts .ttl {
        font-size: 3.623vw;
        line-height: 1.93;
    }



    
/* ------------------------------------
/  treatment 診療内容 
/-------------------------------------*/
    #treatment .txt {
        font-size: 3.623vw;
        line-height: 1.93;      
    }
    #treatment .sec01 {
        padding-bottom: 14.493vw;
    }
    #treatment .sec01 .block_list {
        margin: 0 4.831vw;
        justify-content: space-between;
        gap: 4.348vw 0;
    }
    #treatment .sec01 .block_list a {
        width: 42.995vw;
        min-height: 16.425vw;
        border-width: 0.121vw;
        border-radius: 0.845vw;
        box-shadow: 0.725vw 0.725vw rgba(92, 76, 44, .38);
    }
    #treatment .sec01 .block_list a::after {
        left: auto;
        right: 2.415vw;
        top: 0;
        bottom: 0;
        width: 4.831vw;
        height: 4.831vw;
    }
    #treatment .sec01 .block_list a p {
        padding: 3.14vw 0 3.14vw 3.623vw;
        font-size: 3.623vw;
        text-align: left;
        justify-content: left;
    }
    #treatment .sec02 {
        padding: 12.077vw 4.831vw 23.551vw;
    }
    #treatment .sec02 .sec_block {
        padding: 6.039vw 4.831vw;
        border-radius: 1.691vw;
    }
    #treatment .sec02 .sec_block + .sec_block {
        margin-top: 7.246vw;
    }
    #treatment .sec02 .sec_block .show_box {
        margin-bottom: 6.039vw;
    }
    #treatment .sec02 .sec_block .show_box .left_col {
        width: 100%;
    }
    #treatment .sec02 .sec_block .show_box .img {
        margin-top: 3.14vw;
        width: 100%;
    }
    #treatment .sec02 .sec_block .show_box .img img {
        border-radius: 1.449vw;
    }
    #treatment .sec02 .sec_block .ttl {
        margin-bottom: 2.415vw;
        font-size: 5.797vw;
    }
    #treatment .sec02 .sec_block .ttl span {
        padding-right: 2.657vw;
        font-size: 6.28vw;
    }
    #treatment .sec02 .sec_block .ttl span.st {
        font-size: 5.797vw;
    }
    #treatment .sec02 .sec_block .btn a {
        padding: 1.449vw 0;
        border-radius: 0 0 1.691vw 1.691vw;
    }
    #treatment .sec02 .sec_block .btn a span {
        padding-right: 8.092vw;
        font-size: 3.623vw;
        line-height: 1.33;
    }
    #treatment .sec02 .sec_block .btn a span::after {
        width: 4.831vw;
        height: 4.831vw;
    }
    
    #treatment .sec02 .sec_block .btn a span.close::after {
        background-image: url(../../images/src/common/ico_minus.svg);
    }
    #treatment .sec02 .sec_block .txt + .txt {
        margin-top: 15px;
    }
    #treatment .sec02 .sec_block .list_box {
        margin: 3.623vw 0;
        padding: 3.623vw;
        border-radius: 1.691vw;
    }
    #treatment .sec02 .sec_block .list_box li {
        padding-left: 4.106vw;
        font-size: 3.623vw;
        line-height: 2.13;
    }
    #treatment .sec02 .sec_block .list_box li::before {
        top: 3vw;
        bottom: auto;
        width: 2.053vw;
        height: 2.053vw;
    }
    #treatment .sec02 .sec_block .list_box li a {
        padding-right: 4.952vw;
    }
    #treatment .sec02 .sec_block .list_box li a::after {
        width: 4.348vw;
        height: 4.469vw;
    }
    #treatment .sec02 .sec_block .accordion {
        margin-bottom: 40px;
        display: none;
    }
    #treatment h3 {
        font-size: 4.589vw;
        background-size: 100%;
    }
    #treatment h4 {
        margin-top: 5.676vw;
    }
    #treatment h5 {
        font-size: 3.865vw;
    }
    #treatment h6 {
        margin-top: 4.831vw;
    }
    #treatment .ml30 {
        margin-left: 0;
    }
    #treatment .sec02 .sec_block .accordion .flex {
        justify-content: left;
        gap: 0 19px;
    }
    #treatment .sec02 .circle li {
        padding-left: 4.106vw;
        font-size: 3.623vw;
        line-height: 1.93;
    }
    #treatment .sec02 .circle li::before {
        top: 3vw;
        width: 2.053vw;
        height: 2.053vw;
    }
    #treatment .sec02 .sec_block .accordion .ac_btn {
        margin: 2.899vw 0 7.246vw;
    }
    #treatment .sec02 .sec_block .accordion .ac_btn a {
        padding: 3.019vw 11.655vw 3.019vw 6.039vw;
        font-size: 3.382vw;
        border-radius: 0.845vw;
        border-width: 0.169vw;
    }
    #treatment .sec02 .sec_block .accordion .ac_btn a::after {
        right: 3.744vw;
        width: 4.831vw;
        height: 4.831vw;
    }
    #treatment .sec02 .sec_block .accordion .sp_scroll {
        margin-bottom: 4.831vw;
        overflow-x: scroll;
        display: block;
    }
    #treatment .sec02 .sec_block .accordion table th,
    #treatment .sec02 .sec_block .accordion table td {
        white-space: nowrap;
    }
    #treatment .sec02 .sec_block .accordion table,
    #treatment .sec02 .sec_block .accordion table th,
    #treatment .sec02 .sec_block .accordion table td {
        border: 1px solid var(--bdr-color);
    }
    #treatment .sec02 .sec_block .accordion table tr:first-of-type td {
        padding: 4.227vw 4.831vw;
        width: auto;
    }
    #treatment .sec02 .sec_block .accordion table tr:first-of-type td.price {
        padding-right: 4.831vw;
    }
    #treatment .sec02 .sec_block .accordion table th,
    #treatment .sec02 .sec_block .accordion table td {
        font-size: 3.623vw;
    }
    #treatment .sec02 .sec_block .accordion table th {
        padding: 4.227vw 4.831vw;
        width: auto;
    }
    #treatment .sec02 .sec_block .accordion table td {
        padding: 2.295vw 4.831vw 3.019vw;
    }
    #treatment .sec02 .sec_block .accordion table td.price {
        padding-right: 4.831vw;
    }
    #treatment .sec02 .sec_block .accordion .option_table {
        width: 100%;
    }
    #treatment .sec02 #sec02_12.sec_block .accordion .option_table {
        width: 100%;
    }
    #treatment .sec02 #sec02_12.sec_block .accordion .option_table.mb40 {
        margin-bottom: 0;
    }
    #treatment .sec02 .sec_block .accordion .option_table th {
        width: 70%;
    }
    #treatment .sec02 #sec02_09.sec_block .accordion table th {
        width: auto;
    }
    #treatment .sec02 #sec02_12.sec_block .accordion table th {
        width: auto;
        padding-left: 2.415vw;
    }
    #treatment .sec02 #sec02_12.sec_block .accordion table td {
        padding-right: 1.208vw;
    }
    #treatment .sec02 #sec02_09.sec_block .accordion table td {
        padding-left: 4.831vw;
    }
    .treatment_btn {
        padding: 8.454vw 0;
        gap: 2.657vw;
    }
    .treatment_btn .parts {
        display: flex;
        flex-direction: column;
        width: 28.261vw;
    }
    .treatment_btn .parts a {
        position: relative;
        display: block;
        width: 100%;
        padding: 19.928vw 0 2.778vw;
        height: 42.754vw;
        border-radius: 1.449vw;
        border-width: 0.845vw;
        font-size: 3.865vw;
    }
    .treatment_btn .parts a::before,
    .treatment_btn .parts a::after {
        right: 0;
    }
    .treatment_btn .parts a::before {
        bottom: auto;
    }
    .treatment_btn .parts a::after {
        top: 0;
    }
    .treatment_btn .parts a.genom::before {
        top: 5.435vw;
        left: 0;
        width: 7.126vw;
        height: 12.319vw;

    }
    .treatment_btn .parts a.herbal::before {
        top: 6.763vw;
        left: 0;
        width: 10.628vw;
        height: 9.662vw;

    }
    .treatment_btn .parts a.fetus::before {
        top: 4.348vw;
        left: 0;
        width: 7.609vw;
        height: 14.372vw;

    }
    .treatment_btn .parts a.insurance::before {
        top: 6.401vw;
        left: 0;
        width: 8.092vw;
        height: 10.386vw;

    }
    .treatment_btn .parts a.selfpay::before {
        left: 0;
        width: 0.966vw;
        height: 8.333vw;

    }
    .treatment_btn .parts a::after {
        bottom: -30vw;
        left: 0;
        right: 0;
        width: 5.314vw;
        height: 5.435vw;
    }




     /* ------------------------------------
    /  online オンライン診療
    /-------------------------------------*/
    #online .sec01 {
        margin: 0 4.831vw;
        padding: 10.87vw 4.831vw 13.285vw;
        width: auto;
        max-width: initial;
        border-radius: 8.454vw 8.454vw 0 0;
    }
    #online .sec01 .ttl {
        margin-bottom: 3.14vw;
        font-size: 4.106vw;
    }
    #online .sec01 .ttl02 {
        font-size: 4.589vw;
        line-height: 1.94;
        text-align: left;
    }
    #online .sec01 .ttl02 span {
        font-size: 6.039vw;
    }
    #online .sec01 .block {
        margin-top: 6.039vw;
    }
    #online .sec01 .block .img {
        width: 100%;
    }
    #online .sec01 .block .img img {
        border-radius: 1.691vw;
    }
    #online .sec01 .block .right_col {
        margin-top: 7.246vw;
        width: 100%;
    }
    #online .sec01 .block .right_col p {
        margin-bottom: 2.899vw;
        font-size: 4.348vw;
    }
    #online .sec01 .block .right_col ul li {
        padding: 3.14vw 4.831vw 3.14vw 25.242vw;
        min-height: inherit;
        font-size: 3.623vw;
        border-radius: 1.691vw;
    }
    #online .sec01 .block .right_col ul li + li {
        margin-top: 3.623vw;
    }
    #online .sec01 .block .right_col ul li::before {
        left: 2.899vw;
        width: 4.831vw;
        height: 4.831vw;
    }
    #online .sec01 .block .right_col ul li:first-of-type::after {
        left: 10.749vw;
        width: 10.99vw;
        height: 8.092vw;
    }
    #online .sec01 .block .right_col ul li:nth-of-type(2)::after {
        left: 13.043vw;
        width: 6.401vw;
        height: 6.159vw;
    }
    #online .sec01 .block .right_col ul li:last-of-type::after {
        left: 11.111vw;
        width: 10.145vw;
        height: 10.266vw;
    }
    #online .sec02 {
        padding: 10.87vw 4.831vw 12.077vw;
    }
    #online .sec02 .txt {
        margin: 7.367vw 0;
        font-size: 3.865vw;
        line-height: 1.5;
    }
    #online .sec02 .txt span {
        font-size: 5.314vw;
    }
    #online .sec02 .sp_scroll {
        overflow-x: scroll;
        width: 100%;
    }
    #online .sec02 .sp_scroll .step_area {
        width: auto;
        min-width: 1050px;
    }
    #online .sec02 .step_area .parts {
        width: 50.725vw;
    }
    #online .sec02 .step_area .parts::after {
        top: 25%;
        right: -4.623vw;
        width: 6.039vw;
        height: 7.401vw;
    }
    #online .sec02 .step_area .parts .step {
        font-size: 3.865vw;
    }   
    #online .sec02 .step_area .parts .step .num {
        font-size: 6.28vw;
        line-height: 1;
    }
    #online .sec02 .step_area .parts .parts_icon {
        margin: -4.227vw auto 3.382vw;
        width: 31.401vw;
        height: 31.401vw;
        border-width: 0.845vw;
    }
    #online .sec02 .step_area .parts .parts_ttl {
        margin-bottom: 2.415vw;
        font-size: 3.865vw;
    }
    #online .sec02 .step_area .parts .parts_txt {
        font-size: 3.623vw;
    }
    #online .sec02 .use_code {
        margin: 8.454vw auto 0;
        padding: 3.623vw 0 3.865vw;
        width: 100%;
        border-width: 0.362vw;
        border-radius: 1.691vw;
        gap: 0 4.831vw;
        align-items: center;
    }
    #online .sec02 .use_code .code_ttl {
        font-size: 3.865vw;
        text-align: center;
    }
    #online .sec02 .use_code .code_num {
        font-size: 6.522vw;
    }
    #online .sec02 .use_code .code_num span {
        font-size: 16px;
        font-weight: 500;
        letter-spacing: 0.04em;
    }
    #online .sec03 {
        padding: 10.87vw 4.831vw 14.493vw;
    }
    #online .sec03 .flow_parts {
        margin-bottom: 7.246vw;
        gap: 3.744vw 0;
    }
    #online .sec03 .flow_parts .img {
        margin: 0 auto;
        width: 66.184vw;
    }
    #online .sec03 .flow_parts .right_col {
        width: 100%;
    }
    #online .sec03 .flow_parts .right_col .ttl {
        margin-bottom: 2.415vw;
        font-size: 5.072vw;
    }
    #online .sec03 .flow_parts .right_col .ttl span {
        padding-right: 2.536vw;
        font-size: 5.556vw;
    }
    #online .sec03 .flow_parts .right_col .txt {
        font-size: 3.623vw;
        line-height: 1.93;
    }
    #online .sec03 .flow_parts .right_col .txt + .txt {
        margin-top: 15px;
    }
    #online .sec04 {
        padding: 12.077vw 4.831vw;
    }
    #online .sec04 .inner {
        margin: 0 auto;
        width: auto;
        max-width: initial;
        gap: 6.039vw 0;
    }
    #online .sec04 a {
        border-width: 0.483vw;
        padding: 4.831vw 6.039vw;
        width: 100%;
        border-radius: 1.449vw;
        gap: 0 3.865vw;
        box-shadow: 1.208vw 1.208vw 0 rgba(242, 135, 155, 0.32);
    }
    #online .sec04 a.curon_btn {
        box-shadow: 1.208vw 1.208vw 0 rgba(0, 142, 68, .26);
    }
    #online .sec04 a::after {
        right: 4.831vw;
        bottom: 0;
        top: 0;
        margin: auto;
        width: 5.314vw;
        height: 5.435vw;
    }
    #online .sec04 a .img {
        width: 7.005vw;
    }
    #online .sec04 a.curon_btn .img {
        width: 36.353vw;
    }
    #online .sec04 a p {
        font-size: 4.106vw;
        line-height: 1.52;
    }
    

    /* ------------------------------------
    /  herbal 女性漢方 
    /-------------------------------------*/

    #herbal .txt {
        font-size: 3.623vw;
        line-height: 1.93;
    }
    #herbal .sec01 {
        margin: 0 4.831vw 12.077vw;
        text-align: left;
    }
    #herbal .sec01 .img {
        order: 2;
        width: 95.169vw;
    }
    #herbal .sec01 .img img {
        border-radius: 0 0 1.691vw 0;
        height: 70.894vw;
    }
    #herbal .sec01 .box {
        margin: 0 4.831vw;
        order: 1;
        width: 100%;
        max-width: iniital;
    }
    #herbal .sec01 h2.intro_ttl {
        margin-bottom: 2.415vw;
        font-size: 5.556vw;
        line-height: 1.91;
        text-align: left;
    }
    #herbal .sec01 h2.intro_ttl span {
        display: inline;
        font-size: 7.005vw;
    }
    #herbal .sec01 .txt + .txt {
        margin-top: 3.623vw;
    }
    #herbal .sec01 .txt .marker {
        padding: 0 4px;
    }
    #herbal .sec01 .txt_box {
        margin: 4.831vw 0 6.039vw;
        padding: 3.623vw;
    }
    #herbal .sec02 {
        padding: 10.87vw 4.831vw 14.493vw;
    }
    #herbal .sec02 h2 {
        margin-bottom: 4.831vw;
        font-size: 5.072vw;
    }
    #herbal .sec02 ul {
        gap: 2.415vw 0;
    }
    #herbal .sec02 ul li {
        width: 43.961vw;
        padding: 2.174vw 0 3.744vw;
        border-radius: 1.691vw;
    }
    #herbal .sec02 ul li .sp_txt {
        width: 40.097vw;
        display: flex;
        flex-direction: column;
    }
    #herbal .sec02 ul li .ico {
        margin: 0 auto;
        width: 5.556vw;
    }
    #herbal .sec02 ul li .ttl {
        margin-top: 1.077vw;
        font-size: 3.865vw;
        line-height: 1.3;
    }
    #herbal .sec02 ul li .txt {
        margin-left: 0;
        white-space: nowrap;
    }
    #herbal .sec02 ul li .img {
        margin-top: auto;
        width: 38.647vw;
    }
    #herbal .sec02 .list_img {
        margin-bottom: 2.415vw;
    }
    #herbal .sec02 .list_img li {
        width: 100%;
        padding: 2.174vw 3.623vw 3.744vw;
        flex-direction: initial;
        justify-content: space-between;
    }
    #herbal .sec03 {
        padding: 9.662vw 4.831vw 12.077vw;
    }
    #herbal h2 {
        margin-bottom: 6.522vw;
        font-size: 5.556vw;
    }
    #herbal h2 span.f_poppins {
        font-size: 3.865vw;
    }
    #herbal .intorduction_slide_btn .swiper-button-next::after {
        width: 10.87vw;
    }
    #herbal .intro_slide_block .mySwiper .swiper-slide {
        position: relative;
        width: 65%;
    }
    #herbal .intro_slide_block .mySwiper .swiper-slide .img::after {
        right: -6.435vw;
        width: 4.106vw;
        height: 4.469vw;
    }
    #herbal .intro_slide_block .mySwiper .swiper-slide .num {
        top: 1.208vw;
        left: 1.208vw;
        width: 10.266vw;
        height: 10.266vw;
        font-size: 4.348vw;
        border-width: 0.676vw;
    }
    #herbal .intro_slide_block .mySwiper .swiper-slide .ttl {
        margin: 4.831vw 0 2.174vw;
        font-size: 4.348vw;
        line-height: 1.44;
    }
    #herbal .sec04 {
        margin: 0 4.831vw;
        padding: 9.662vw 4.831vw 12.077vw;
        width: auto;
        max-width: initial;
        border-radius: 8.454vw;
    }
    #herbal .sec04 .faq_acd {
        margin-top: 4.831vw;
    }
    #herbal .sec04 .faq_acd dl + dl {
        margin-top: 4.831vw;
    }
    #herbal .sec04 .faq_acd dl {
        padding: 4.831vw 3.623vw;
        border-radius: 1.691vw;
        box-shadow: 1.208vw 1.208vw #F2B3BC;
    }
    #herbal .sec04 .faq_acd dl dt::before,
    #herbal .sec04 .faq_acd dl dd::before {
        font-size: 5.797vw;
    }
    #herbal .sec04 .faq_acd dl::after,
    #faq .sec01 dl::after {
        top: 04.8vw;
        right: 3.623vw;
        width: 5.314vw;
        height: 5.314vw;
        transition: background 0.3s ease;
    }
    #herbal .sec04 .faq_acd dl dd::before {
        left: 0;
    }
    
    #herbal .sec04 .faq_acd dt {
        padding: 0  5.614vw 0 6.28vw;
    }
    #herbal .sec04 .faq_acd dl dt p {
        font-size: 3.865vw;
        line-height: 1.37;
    }
    #herbal .sec04 .faq_acd dl dd {
        margin-top: 3.14vw;
        padding-left: 6.28vw;
        font-size: 3.623vw;
        line-height: 1.33;
    }
    #herbal .sec05 {
        padding: 12.077vw 4.831vw;
    }
    #herbal .sec05 .left_col {
        width: 100%;
    }
    #herbal .sec05 .txt {
        margin: 9.42vw 0 4.227vw;
        text-align: left;
    }
    
    #herbal .sec05 strong {
        font-size: 4.106vw;
    }
    #herbal .sec05 .img {
        width: 100%;
    }
    

 
/* ------------------------------------
/  fetus 胎児ドック 
/-------------------------------------*/

    #fetus .txt {
        font-size: 3.623vw;
        line-height: 1.93;
    }
    #fetus .sec01 {
        margin-bottom: 13.285vw;
    }
    #fetus .sec01 .flex {
        margin-top: 7.367vw;
        gap: 7.246vw 0;
    }
    #fetus .sec01 .img {
        order: 2;
        width: 95.169vw;
    }
    #fetus .sec01 .img img {
        border-radius: 0 1.691vw 1.691vw 0;
        height: auto;
    }
    #fetus .sec01 .box {
        order: 1;
        padding: 0 4.831vw;
        width: 100%;
    }
    
    #fetus .sec01 .txt + .txt {
        margin-top: 3.623vw;
    }
    #fetus .sec01 .txt_box {
        margin-top: 4.831vw;
        padding: 3.623vw;
        border-radius: 1.449vw;
        border-width: 0.725vw;
    }
    #fetus .sec01 .staff_btn a {
        margin: 10.87vw 4.831vw 0 4.831vw;
        width: auto;
        max-width: initial;
        border-radius: 1.449vw;
        border-width: 0.242vw;
        box-shadow: 1.144vw 1.144vw rgba(92, 76, 44, 0.60);
        gap: 0 4.952vw;
    }
    #fetus .sec01 .staff_btn a::after {
        right: 1.932vw; 
        bottom: 1.932vw;
        width: 4.831vw;
        height: 4.831vw;
    }
    #fetus .sec01 .staff_btn a .img { 
        order: 1;
        width: 40.097vw;
    }
    #fetus .sec01 .staff_btn a .img img {  
        border-radius: 1.449vw 0 0 1.449vw;
    }
    #fetus .sec01 .staff_btn a .right_col {
        order: 2;
        width: 42.271vw;
    }
    #fetus .sec01 .staff_btn a .right_col p {
        font-size: 4.831vw;
    }
    #fetus .sec01 .staff_btn a .right_col p span {
        display: block;
        padding-left: 0;
        font-size: 3.382vw;
    }
    #fetus .sec02 {
        padding: 10.87vw 4.831vw 12.077vw;
    }
    #fetus .sec02 h2 {
        margin-bottom: 7.367vw;
    }
    #fetus .sec02 .parts {
        padding: 4.831vw 4.831vw 6.039vw;
        border-radius: 1.691vw;
    }
    #fetus .sec02 .parts + .parts {
        margin-top: 7.246vw;
    }
    #fetus .sec02 .parts .img {
        margin-bottom: 4.831vw;
        width: 100%;
    }
    #fetus .sec02 .parts .img img {
        border-radius: 1.691vw;
    }
    #fetus .sec02 .parts .right_col {
        width: 100%;
    }
    #fetus .sec02 .parts .right_col h3 {
        margin-bottom: 4.831vw;
        padding-left: 2.536vw;
        border-left-width: 0.604vw;
        font-size: 4.831vw;
    }
    #fetus .sec02 .parts .right_col .price {
        margin-bottom: 4.831vw;
        font-size: 7.005vw;
        line-height: 0.65;
    }
    #fetus .sec02 .parts .right_col .price span {
        font-size: 3.623vw;
    }
    
    #fetus .sec03 {
        padding: 10.87vw 4.831vw;
    }
    
    
    /* ------------------------------------
    /  genom ゲノム診療 
    /-------------------------------------*/

    #genom .txt {
        font-size: 3.623vw;
        line-height: 1.93;
    }
    #genom .sec01 {
        padding: 0 4.831vw;
        margin-bottom: 12.077vw;
    }
    #genom .sec01 .lower_h2 {
        margin-bottom: 7.367vw;
    }
    #genom .sec01 .flex {
        margin-top: 7.729vw;
    }
    #genom .sec01 .flex .left_col {
        width: 100%;
    }
    #genom .sec01 .flex .left_col h3 {
        margin-bottom: 4.589vw;
        padding-left: 2.899vw;
        border-left-width: 0.604vw;
        font-size: 5.072vw;
    }
    #genom .sec01 .flex .img {
        margin-top: 4.831vw;
        width: 100%;
    }
    #genom .sec01 .flex .img a {
        font-size: 3.623vw;
        line-height: 1.93;
    }
    #genom .sec02 {
        padding: 10.87vw 4.831vw 0;
    }
    #genom .sec02 h2 {
        margin-bottom: 7.367vw;
    }
    #genom .sec02 .ttl01 {
        margin: 8.454vw auto 3.623vw;
        font-size: 5.072vw;
    }
    #genom .sec02 ul {
        margin-bottom: 9.662vw;
        gap: 2.415vw 0;
    }
    #genom .sec02 ul li {
        width: 100%;
        display: flex;
        flex-direction: row;
        padding: 3.623vw;
        border-radius: 1.691vw;
        align-items: center;
        text-align: left;
        gap: 0 3.019vw;
    }
    #genom .sec02 ul li .ico {
        width: 5.435vw;
    }
    #genom .sec02 ul li .ttl {
        margin-top: 0;
        font-size: 3.865vw;
        line-height: 1.56;
        display: block;
    }
    #genom .sec02 ul li .txt {
        margin-left: -20px;
        white-space: nowrap;
    }
    #genom .sec02 ul li .img {
        margin-top: auto;
    }
    #genom .sec02 .white_block {
        margin: 0 auto 13.285vw;
        width: 100%;
        max-width: initial;
    }
    #genom .sec02 .white_block a {
        padding: 6.039vw 3.623vw 8.213vw;
        width: 100%;
        border-radius: 1.691vw;
        box-shadow: 1.208vw 1.208vw rgba(92, 76, 44, 0.3);
    }
    #genom .sec02 .white_block a::after {
        right: 2.415vw;
        bottom: 2.415vw;
        width: 5.314vw;
        height: 5.314vw;
    }
    #genom .sec02 .white_block a .btn {
        margin: 0 auto 4.831vw;
        padding: 5.435vw 0 5.435vw 18.72vw;
        width: 66.184vw;
        border-radius: 21.739vw;
        border-width: 0.725vw;
    }
    #genom .sec02 .white_block a .btn span {
        font-size: 4.106vw;
    }
    #genom .sec02 .white_block a .btn span::after {
        left: -12.681vw;
        width: 9.058vw;
        height: 9.541vw;
    }
    #genom .sec02 .white_block a .list {
        padding-top: 4.831vw;
        justify-content: left;
        gap: 0 2.415vw;
    }
    #genom .sec02 .white_block a .list .circle {
        width: 7.005vw;
        height: 19.324vw;
        border-radius: 21.739vw;
        border-width: 0.362vw;
        font-size: 3.865vw;
        writing-mode: vertical-rl;
        text-orientation: upright;
    }
    #genom .sec02 .white_block a .list .right_col {
        width: 72.773vw;
    }
    #genom .sec02 .white_block a .list dl {
        display: flex;
        justify-content: space-between;
        align-items: center;
    }
    #genom .sec02 .white_block a .list dl dt {
        font-size: 3.623vw;
    }
    #genom .sec02 .white_block a .list dl dt .fs20 {
        font-size: 4.589vw;
    }
    #genom .sec02 .white_block a .list dl dd {
        font-size: 4.831vw;
        white-space: nowrap;
    }
    #genom .sec02 .white_block a .list dl dd span {
        font-size: 3.623vw;
    }
    #genom .sec02 .sec02_02 {
        margin: 0 auto;
        padding: 10.87vw 4.831vw 14.493vw;
        width: auto;
        max-width: initial;
        border-radius: 8.454vw 8.454vw 0 0;
    }
    #genom .sec02 .sec02_02 .txt {
        text-align: left;
    }
    #genom .sec02 .sec02_02 .box01 {
        margin: 7.85vw 0 12.077vw;
    }
    #genom .sec02 .sec02_02 .box01 .img {
        order: 2;
        margin-top: 4.831vw;
        width: 100%;
    }
    #genom .sec02 .sec02_02 .box01 .right_col {
        order: 1;
        width: 100%;
    }
    #genom .sec02 .sec02_02 .box01 .right_col h3 {
        margin-bottom: 4.227vw;
        border-left-width: 0.604vw;
        padding-left: 2.415vw;
        font-size: 5.072vw;
    }
    #genom .sec02 .sec02_02 h2.ttl {
        margin-bottom: 3.623vw;
        font-size: 5.556vw;
    }
    #genom .sec02 .sec02_02 h2.ttl span {
        font-size: 3.865vw;
    }
    #genom .sec02 .sec02_02 .howto {
        margin-top: 6.039vw;
        overflow-x: scroll;
        display: flex;
    }
    #genom .sec02 .sec02_02 .howto .sp_scroll {
        width: auto;
        max-width: 1000px;
        display: flex;
        flex-wrap: nowrap;
        -webkit-flex-wrap: nowrap;
        gap: 0 10.507vw;
    }
    #genom .sec02 .sec02_02 .howto .parts {
        width: 61.836vw;
    }
    #genom .sec02 .sec02_02 .howto .parts .num {
        top: 1.208vw;
        left: 1.208vw;
        width: 10.386vw;
        height: 10.386vw;
        font-size: 4.348vw;
        border-width: 0.688vw;
    }
    #genom .sec02 .sec02_02 .howto .parts .img::after {
        right: -7.6vw;
        width: 4.589vw;
        height: 5.193vw;
    }
    #genom .sec02 .sec02_02 .howto .parts .img img {
        border-radius: 1.449vw;
    }
    #genom .sec02 .sec02_02 .howto .parts .ttl {
        margin: 4.952vw 0 2.174vw;
        font-size: 4.348vw;
        line-height: 1.44;
    }
    
    #genom .sec02 .sec02_02 .howto .parts a {
        margin-top: 3.623vw;
        padding: 1.208vw 7.246vw 1.932vw 3.14vw;
        width: 100%;
        font-size: 3.382vw;
        border-radius: 0.845vw;
        border-width: 0.169vw;
    }
    #genom .sec02 .sec02_02 .howto .parts a::after {
        right: 2.778vw;
        width: 4.831vw;
        height: 4.831vw;
    }


   
    /* ------------------------------------
    /  staff 医師紹介 
    -------------------------------------*/
    #staff .sec01 {
        margin: 0 4.831vw 12.077vw;
        width: auto;
        max-width: initial;
    }
    #staff .sec01 h2 {
        margin-bottom: 7.367vw;
    }
    #staff .sec01 p {
        font-size: 3.623vw;
        line-height: 1.93;
        text-align: left;
    }
    #staff .staff_list {
        margin: 0 4.831vw;
        width: auto;
        max-width: initial;
        padding: 10.87vw 4.831vw 13.889vw;
        border-radius: 8.454vw 8.454vw 0px 0px;
    }
    #staff .staff_list h2 {
        margin-bottom: 10.99vw;
    }
    #staff .staff_list .list_block {
        margin: 0 auto;
        width: 100%;
        flex-direction: column;
        max-width: initial;
        gap: 8.696vw 0;
        justify-content: center;
    }
    #staff .staff_list .list_block .parts {
        /*width: 280px;*/
        width: 100%;
    }
    #staff .staff_list .list_block .parts a {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
    }
    #staff .staff_list .list_block .parts .img {
        width: 42.029vw;
    }
    #staff .staff_list .list_block .parts .img img {
        width: 100%;
        height: auto;
        border-radius: 1.724vw;
    }
    #staff .staff_list .list_block .parts .staff_prof {
        margin: 0 0 0 -4.831vw;
        padding: 6.039vw 6.039vw 6.039vw 3.623vw;
        width: 43.478vw;
        border-radius: 1.449vw;
        box-shadow: 6px 6px 0 rgba(242,135,155,0.3);
    }
    #staff .staff_list .list_block .parts .staff_prof::after {
        right: 3.623vw;
        width: 5.314vw;
        height: 5.435vw;
    }
    #staff .staff_list .list_block .parts .staff_prof .staff_name {
        font-size: 4.348vw;
        line-height: 1;
    }
    #staff .sec02 .list_block {
        width: auto;
    }
    #staff .sec02 .list_block .parts {
        /*width: 560px;*/
        width: 100%;
    }
    
    #staff .sec02 .list_block .parts a {
        display: block;
    }
    #staff .sec02 .list_block .parts .img {
        width: 76.087vw;
    }
    #staff .sec02 .list_block .parts .img img {
        height: auto;
    }
    #staff .sec02 .list_block .parts .staff_prof {
        margin: -6.884vw 0 0 auto;
        padding: 4.831vw 9.179vw 5.797vw 4.831vw;
        /*width: 64.01vw;*/
        width: 76.087vw;
        box-shadow: 1.329vw 1.329vw 0 rgba(242,135,155,0.3);
    }
    #staff .sec02 .list_block .parts .staff_prof::after {
        right: 2.174vw;
        top: auto;
        bottom: 2.174vw;
    }
    #staff .sec02 .list_block .parts .staff_prof .staff_name {
        margin-bottom: 2.778vw;
        font-size: 4.348vw;
    }
    #staff .staff_list .list_block .parts .staff_prof .staff_name span {
        padding-left: 3.623vw;
        font-size: 3.14vw;
    }
    #staff .staff_list .list_block .parts .staff_prof .txt {
        font-size: 3.623vw;
        line-height: 1.66;
    }


    #staff .detail_sec01 {
        margin: 9.783vw 4.831vw 0;
    }
    #staff .detail_sec01 .photo {
        margin-bottom: 6.039vw;
        width: 100%;
    }
    #staff .detail_sec01 .photo img {
        width: 100%;
        height: auto;
        border-radius: 1.449vw;
    }
    #staff .detail_sec01 .right_col {
        width: 100%;
    }
    #staff .detail_sec01 .right_col h1 {
        margin-bottom: 3.623vw;
        padding-left: 3.623vw;
        border-left-width: 0.725vw;
        font-size: 6.28vw;
    }
    #staff .detail_sec01 .right_col h1 span {
        padding-left: 3.14vw;
        font-size: 3.865vw;
    }
    #staff .detail_sec02 {
        margin-bottom: 12.077vw;
    }
    #staff .detail_sec02 h2 {
        margin-bottom: 4.831vw;
        font-size: 5.072vw;
    }
    #staff .detail_sec02 h2 span {
        font-size: 3.623vw;
    }
    #staff .detail_sec02 .bgcream {
        margin: 0 4.831vw;
        padding: 8.454vw 4.831vw;
        border-radius: 1.691vw;
    }
    #staff .detail_sec02 .career_block {
        margin-bottom: 0;
        padding: 8.454vw 4.831vw;
    }
    #staff .detail_sec02 .career_block dl {
        display: block;
        margin-bottom: 5.314vw;
    }
    #staff .detail_sec02 .career_block dl dt {
        font-size: 3.623vw;
    }
    #staff .detail_sec02 .career_block dl dd p {
        font-size: 3.623vw;
        line-height: 1.46;
    }
    
    #staff .detail_sec02 .other_block {
        margin-top: 9.662vw;
        width: 100%;
    }
    #staff .detail_sec02 .other_block ul {
        padding: 0;
    }
    #staff .detail_sec02 .other_block ul li {
        margin-bottom: 3.623vw;
        padding-left: 4.106vw;
        font-size: 3.623vw;
        line-height: 1.77;
    }
    #staff .detail_sec02 .other_block ul li::before {
        top: 3vw;
        width: 2.053vw;
        height: 2.053vw;
    }

    /* ------------------------------------
    /  FAQ よくあるご質問
    /-------------------------------------*/
    #faq .txt {
        font-size: 3.623vw;
        line-height: 1.33;
    }
    
    #faq .sec01 {
        margin: 0 4.831vw;
        padding-bottom: 12.077vw;
    }
    #faq .sec01 h2 {
        margin-bottom: 8.575vw;
    }
    #faq .sec01 .faq_acd {
        margin-top: 6.039vw;
    }
    #faq .sec01 .faq_acd dl {
        padding: 5.314vw 0;
    }
    #faq .sec01 .faq_acd dl dt {
        padding: 0 6.039vw;
    }
    #faq .sec01 .faq_acd dl dt p {
        font-size: 3.865vw;
        line-height: 1.37;

    }
    #faq .sec01 .faq_acd dl dt::before,
    #faq .sec01 .faq_acd dl dd::before  {
        font-size: 5.797vw;
    }
    #faq .sec01 .faq_acd dl dd {
        display: none;
        margin-top: 5.797vw;
        padding-left: 6.039vw;
        font-size: 3.623vw;
        line-height: 1.33;
    }
    #faq .sec01 .faq_acd dl dd::before {
        left: 0;
    }
    
    #contact {
        margin: 0 4.831vw;
        padding: 10.87vw 4.831vw 15.7vw;
        width: auto;
        max-width: initial;
        border-radius: 8.454vw 8.454vw 0 0;
    }
    #contact h2 {
        margin-bottom: 9.783vw;
    }
    #contact .cta_box {
        margin: 0 auto 7.246vw;
        box-shadow: 1.208vw 1.208vw 0 #F2B3BC;
    }
    #contact .cta_box .ico,
    #contact .cta_box .ico img {
        height: 9.903vw;
    }
    #contact .cta_box .pink_tl {
        font-size: 4.106vw;
    }
    #contact .cta_box .ttl a {
        font-size: 7.488vw;
    }
    #contact .contact_area {
        padding: 8.213vw 4.831vw 10.87vw;
        border-radius: 1.812vw;
        box-shadow: 1.208vw 1.208vw 0 #F2B3BC;
    }
    #contact .contact_area .ico.mail {
        margin: 0 auto;
        width: 7.609vw;
    }
    #contact .contact_area .ttl01 {
        margin: 3.744vw 0 4.952vw;
        font-size: 4.106vw;
    }
    #contact .contact_area table th {
        display: block;
        padding: 0 0 2.415vw;
        width: auto;
        font-size: 3.865vw;
    }
    #contact .contact_area table th span {
        margin-left: 3.623vw;
        padding: 0 0.483vw;
        font-size: 2.899vw;
        border-radius: 0.362vw;
    }
    #contact .contact_area table td {
        display: block;
        padding: 0 0 6.039vw;
        width: auto;
        font-size: 3.623vw;
    }
    
    #contact .contact_area table td input[type="text"],
    #contact .contact_area table td textarea {
        padding: 2.415vw 3.623vw;
        border-radius: 1.449vw;
        font-size: 16px;
    }
    #contact .contact_area table td .file_btn {
        margin-top: 16px;
    }
    #contact .contact_area table td textarea {
        height: auto;
    }
    #contact .sendbtn {
        text-align: center;
    }
    #contact .sendbtn .flex {
        justify-content: center;
        gap: 4.831vw 0;
    }
    #contact .sendbtn p {
        width: 57.729vw;
    }
    #contact .sendbtn .send {
        border-radius: 21.739vw;
        border-width: 0.966vw;
    }
    #contact .sendbtn .comfirm_btn {
        margin: 0 auto;
    }
    #contact .sendbtn .back {
        border-radius: 21.739vw;
        border-width: 0.966vw;
    }
    #contact .sendbtn input[type="submit"] {
        padding: 3.019vw 0;
        font-size: 3.865vw;
    }
    #contact .sendbtn .comfirm_btn input[type="submit"] {
        margin-left: -24px;
    }
    
    #contact .sendbtn .send::after {
        top: 1vw;
        right: 3.623vw;
        width: 5.314vw;
        height: 5.435vw;
    }
    #contact .sendbtn .back::after {
        top: 1vw;
        left: 3.623vw;
        width: 5.314vw;
        height: 5.435vw;
    }
    
    /* ------------------------------------
    /  ACCESS アクセス
    /-------------------------------------*/
    #access .txt {
        font-size: 4.831vw;
        line-height: 1.6;
    }
    #access .txt .pc {
        display: none !important;
    }
    #access .txt.kome {
        margin-left: 4.831vw;
        text-indent: -4.831vw;
    }
    #access .gmap {
        margin: 8.575vw 0 2.415vw;
    }
    #access .gmap iframe { 
        width: 100%;
        height: 57.488vw;
    }
    #access .inner_1200 {
        margin: 0 4.831vw;
    }
    #access .txt_btn {
        margin-bottom: 8.816vw;
    }
    #access .txt_btn a {
        padding-right: 6.643vw;
        font-size: 3.623vw;
    }
    #access .txt_btn a::after {
        width: 5.314vw;
        height: 5.435vw;
    }
    #access .sec01 .movie {
        margin: 80px auto 30px;
    }
    #access .sec01 .txt + .txt {
        margin-top: 1em;
    }
    #access .sec02 {
        margin: 14.493vw 4.831vw;
    }
    #access .sec02 p {
        margin: 8.454vw 0 7.246vw;
        font-size: 4.106vw;
        line-height: 1.35;
        
    }
    #access .sec02 .img {
        margin: 0 auto;
        width: auto;
        max-width: initial;
    }
    

    /* ------------------------------------
    /  PRIVACY POLICY プライバシーポリシー
    /-------------------------------------*/
    #policy .inner_1200 {
        margin: 0 4.831vw;
    }
    #policy .txt {
        font-size: 3.623vw;
        line-height: 1.93;
    }
    #policy dl + dl {
        margin-top: 4.831vw;
    }
    #policy dl dt {
        margin-bottom: 1.208vw;
        font-size: 4.106vw;
        
    }
    #policy dl dt span {
        font-size: 4.348vw;
    }
    #policy dl dd {
        font-size: 3.623vw;
    }
    #policy .box {
        margin:10.87vw 0 16.908vw;
    }
    #policy .box .ttl {
        font-size: 4.106vw;
    }



}




/* pcのみのhoverアクションはここ */
@media (hover: hover) and (pointer: fine) {
	
    .follow_block ul li a:hover {
        color: var(--main-color);
    }
    
    .follow_block ul li a:hover img {
        opacity: 1;
        transform: translate(0, -8px);
    }
    .follow_block .link_top:hover {
        opacity: 0.6;
    }
    .cta_area .inner a.cta_box:hover  {
        transform: translate(10px, 10px);
        box-shadow: none;
        opacity: .8;
    }
    .cta_area .inner a.cta_box:hover::after {
        background: url(../../images/src/common/arrow_white_right02.svg) no-repeat left top / 100%;
    }
    .hero_block .hero_txt_area .hero_btn a:hover {
        opacity: 0.8;
    }
    .top_sec01 .information_block .recp_block table tbody td a:hover {
        color: #fff;
        background-color: var(--main-color);
    }
    .top_sec01 .information_block .recp_block table tbody td a.men:hover {
        background-color: #87BBF2;
    }
    .top_sec01 .information_block .flex .news_block a:hover dl {
        background: #FFF6F8;
    }
    .top_sec01 .information_block .flex .news_block a:hover dl::before {
        background: url(../../images/src/common/arrow_white_right02.svg) no-repeat left top / 100%;
    }
    .top_sec02 .box .list_btn li a:hover {
        background: #FFF6F8;
    }
    .top_sec02 .box .list_btn li a:hover::before {
        background: url(../../images/src/common/arrow_white_right02.svg) no-repeat left top / 100%;
    }
    .top_sec02 .box .btn a:hover {
        color: #fff;
        background: var(--main-color);
    }
    .top_sec02 .box .btn a:hover::before {
        background: url(../../images/src/top/check_white.svg) no-repeat left top / 100%;
    }
    .top_sec02 .box .btn a:hover::after {
        background: url(../../images/src/common/arrow_white_right01.svg) no-repeat left top / 100%;
    }
    .top_sec03 .parts:hover {
        transform: translate(8px, 8px);
        box-shadow: none;
        opacity: .8;
    }
    .top_sec03 .parts:hover::after {
        background: url(../../images/src/common/arrow_white_right02.svg) no-repeat left top / 100%;
    }
    .top_sec04 .inner .flex .right .circle_btn a:hover {
        color: #fff;
        background-color: var(--main-color);
    }
    .top_sec04 .inner .flex .right .circle_btn a:hover::after {
        background: url(../../images/src/common/arrow_white_right02.svg) no-repeat left top / 100%;
    }
    .top_sec04 .inner .flex .right .txt_btn a:hover {
        color: var(--main-color);
    }
    .top_sec04 .inner .flex .right .txt_btn a:hover::after {
        background: url(../../images/src/common/arrow_white_right02.svg) no-repeat left top / 100%;
    }
    .breadcrumbs span a:hover span {
        text-decoration: underline;
    }
    .wp-pagenavi a:hover {
        color: #fff;
        border-radius: 50%;
        background: var(--main-color); 
        line-height: 31px;
        text-align: center;
    }
    #staff .staff_list .list_block .parts a:hover .staff_prof {
        transform: translate(6px, 6px);
        box-shadow: none;
        opacity: .8;
    }
    #staff .sec02 .list_block .parts a:hover .staff_prof {
        transform: translate(10px, 10px);
    }
    #staff .staff_list .list_block .parts a:hover .staff_prof::after {
        background-image: url(../../images/src/common/arrow_white_right02.svg);
    }
    .follow_block ul li a:hover img {
        opacity: 1;
        transform: translate(0, -8px);
    }
    #access .txt_btn a:hover {
        color: var(--main-color);
    }
    #access .txt_btn a:hover::after {
        background: url(../../images/src/common/arrow_white_right02.svg) no-repeat left top / 100%;
    }
    
    #online .sec04 a:hover {
        transform: translate(8px, 8px);
        box-shadow: none;
    }
    
    #treatment .sec01 .block_list a:hover {
        transform: translate(6px, 6px);
        box-shadow: none;
        color: #fff;
        background: var(--text-color);
    }
    #treatment .sec01 .block_list a:hover::after {
        background-image: url(../../images/src/common/arrow_brown_bottom02.svg);
    }    
    #treatment .sec02 .sec_block .list_box li a:hover {
        text-decoration: none;
    }
    #treatment .sec02 .sec_block .list_box li a:hover::after {
        background-image: url(../../images/src/common/arrow_white_right02.svg);
    }
    #treatment .sec02 .sec_block .btn a:hover {
        background: rgba(242,135,155,.8);
    }
    #treatment .sec02 .sec_block .accordion .ac_btn a:hover {
        color: #fff;
        background: var(--text-color);
    }
    #treatment .sec02 .sec_block .accordion .txt a:hover {
        text-decoration: none;
    }
    .treatment_btn .parts a:hover {
        color: #fff;
        background: var(--main-color);
    }
    .treatment_btn .parts a:hover::after {
        background-image: url(../../images/src/common/arrow_white_right01.svg);
    }
    .treatment_btn .parts a.genom:hover::before {
        background: url(../../images/src/treatment/ico_genom_hv.svg) no-repeat left center / 100%;

    }
    .treatment_btn .parts a.herbal:hover::before {
        background: url(../../images/src/treatment/ico_herbal_hv.svg) no-repeat left center / 100%;

    }
    .treatment_btn .parts a.fetus:hover::before {
        background: url(../../images/src/treatment/ico_fetus_hv.svg) no-repeat left center / 100%;
    }
    .treatment_btn .parts a.insurance:hover::before {
        background: url(../../images/src/treatment/ico_insurance_hv.svg) no-repeat left center / 100%;

    }
    .treatment_btn .parts a.selfpay:hover::before {
        background: url(../../images/src/treatment/ico_selfpay_hv.svg) no-repeat left center / 100%;
    }
    #genom .sec02 .white_block a:hover .list,
    #genom .sec02 .white_block a:hover::after {
        opacity: 0.5;
    }
    #genom .sec02 .white_block a:hover .btn {
        color: #fff;
        background: var(--text-color);
    }
    #genom .sec02 .white_block a:hover .btn span::after {
        background-image: url(../../images/src/common/ico_follow01_hv.svg);
    }
    #genom .sec02 .sec02_02 .howto .parts a:hover {
        color: #fff;
        background: var(--text-color);
    }
    #herbal .sec01 .txt_box a:hover {
        text-decoration: none;
    }
}
  
 /*IE11用に以下のコードも追加 最後に上のhoverコピペ*/
@media (-ms-high-contrast: none), (-ms-high-contrast: active) {
	
}




/* 印刷用 */
@media print {
	body { zoom: 0.6; -webkit-print-color-adjust: exact; }
}

/* 印刷用 IE10以上 */
@media print and (-ms-high-contrast:none) {
	@page { size: A4; margin: 12.7mm 9.7mm; }
	body { zoom: 1.8; width: 1200px; transform: scale(0.5); transform-origin: 0 0; }
}