/***************************************************/
/***************************************************/
/***************************************************/
/***************************************************/
/************** page01（トップページ）のみ **************/
/***************************************************/
/***************************************************/
/***************************************************/
/***************************************************/
.page01 .hdr {
    /* background: linear-gradient(to bottom, rgba(0, 0, 0, .1) 1%, rgba(0, 0, 0, .05) 75%, rgba(0, 0, 0, 0) 100%); 
    background: linear-gradient(to bottom, rgba(0, 0, 0, .4) 1%, rgba(0, 0, 0, .05) 85%, rgba(0, 0, 0, 0) 100%);*/
    padding: 12px 0;
    position: relative;
    z-index: 3;
}

.page01 .logo-hdr .sp {
    background-color: rgba(200, 200, 200, .32);
    color: #40a8c0;
    font-size: 11px;
    width: fit-content;
    margin: 0 auto 4px;
    padding: 4px 8px;
    text-align: center;
}

.page01 .logo-hdr picture {
    max-width: 90%;
    width: 296px;
    display: block;
    margin: 0 auto;
}

.kv-wrap {
    background-color: #ecf0f3;
}

.kv {
    padding-top: 128px;
    /*position: relative;*/
}

.kv::after {
    content: '';
    background-image: url(../img/top_kv.png);
    background-repeat: no-repeat;
    background-size: 200%;
    width: 90vw;
    height: 56vh;
    position: absolute;
    top: -16px;
    left: 0;
}

.kv_in01,
.kv_in02 {
    position: relative;
    z-index: 2;
}

.kv_in01 {
    /* margin-bottom: 64px;
    overflow: hidden; */
}

.kv_in01_in {
    background-color: rgba(0, 0, 0, .16);
    backdrop-filter: blur(1.6px);
    width: 88vw;
    margin: 0 0 0 auto;
    padding: 24px 32px;
    text-shadow: 2px 2px 4px rgba(0, 0, 0, .32);
}

.kv_in01_in .smile {
    display: block;
    color: #fff;
    letter-spacing: 0;
    margin-bottom: 8px;
    padding-right: 32px;
    text-align: right;
    position: relative;
}

.kv_in01_in .smile::after {
    content: '';
    background-image: url(../img/logo-slime02.svg);
    background-repeat: no-repeat;
    background-size: 100%;
    width: 24px;
    height: 16px;
    position: absolute;
    right: 0;
}

.kv_in01_in picture {
    display: block;
    margin-bottom: 40px;
    position: relative;
}

.kv_in01_in picture::after {
    content: '';
    background-image: url(../img/logo-line02short.svg);
    background-repeat: no-repeat;
    background-size: 100%;
    width: 408px;
    height: 80px;
    opacity: 0.8;
    position: absolute;
    top: 96%;
    left: -24%;
}

.kv_in01_in h1 {
    color: #fff;
    font-size: 4.8vw;
    font-weight: 300;
    text-align: right;
}

.kv_in01_in h1 .fs-sss {
    display: inline-block;
    border: solid 0.5px rgba(255, 255, 255, .8);
    border-radius: 1px;
    padding: 2px;
    padding-right: 1px;
    transform: scale(0.95);
}

.kv .notify, .top__mv .notify {
    background-color: #fff;
    border-top-right-radius: 12px;
    box-shadow: 4px -4px 12px -8px rgba(0, 0, 0, .32);
    padding: 16px 20px 4px 24px;
    width: calc(100% - 24px);
}

.kv .notify_in, .top__mv .notify_in {
    margin-bottom: 12px;
    display: flex;
    align-items: center;
    justify-content: flex-start;
}

.kv .note-child, .top__mv .note-child {
    margin-right: 16px;
}

.kv .note-date, .top__mv .note-date {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 8px;
    text-align: center;
}

.kv .date-yyyy, .top__mv .date-yyyy {
    font-size: 12px;
}

.kv .date-mmdd, .top__mv .date-mmdd {
    font-size: 13px;
    position: relative;
}

.kv .date-mmdd::before, .top__mv .date-mmdd::before {
    content: '';
    border-top: solid 1px #80c8d0;
    display: block;
    position: relative;
    top: -5px;
}

.kv .notify_in+a, .top__mv .notify_in+a {
    background-color: rgba(220, 220, 220, .5);
    border-radius: 3px;
    display: block;
    font-size: 12px;
    width: 80%;
    margin: 0 auto;
    padding: 3px;
    text-align: center;
}

.notify .btn-arrow {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-left: auto;
    margin-right: 8px;
}

.notify .arrow-prev,
.notify .arrow-next {
    border-top: solid 2px #80c8d0;
    border-left: solid 2px #80c8d0;
    display: block;
    width: 8px;
    height: 8px;
}

.notify .arrow-prev {
    transform: rotate(45deg);
}

.notify .arrow-next {
    transform: rotate(225deg);
}


/***********/
/***********/
/*** api ***/
/***********/
/***********/


.kv-calender {
    width: 100%;
}

.kv-scale {
    background-color: rgba(255, 255, 255, 1);
    padding: 16px 24px 56px;
}

.kv-scale_h {
    border-bottom: solid 1px rgba(200, 200, 200, .32);
    margin-bottom: 2px;
    padding-bottom: 8px;
}

.kv-scale_in,
.kv-scale_child,
.kv-scale_mago {
    display: flex;
}

.kv-scale_in {
    font-feature-settings: 'palt';
    letter-spacing: 0.05em;
    text-align: left;
    flex-direction: column;
}

.kv-scale div.kv-scale_in:first-of-type {
    width: 96%;
    margin: 0 auto;
}

.kv-scale_child {
    border-bottom: dashed 1px #ddd;
    font-size: 14px;
    padding: 10px 0 8px;
    align-items: center;
}

.kv-scale_mago {
    gap: 4px;
}

.kv-scale_mago .font-en01 .fs-lll {
    display: inline-block;
    transform: translateY(1px);
}

.kv-scale>.kv-scale_in:last-child {
    background-color: rgba(244, 244, 244, .8);
    margin-top: 8px;
    padding: 8px 16px 12px;
}

.kv-scale_in05 {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
}

.kv-scale_in05>span {
    background-color: #a8d8e0;
    border-radius: 3px;
    font-size: 0.69em;
    max-width: fit-content;
    padding: 4px 12px;
}

.icon-scale01,
.icon-scale02,
.icon-scale03,
.icon-scale04,
.icon-scale05,
.icon-scale06 {
    position: relative;
}

.icon-scale06 {
    margin-bottom: 4px;
    display: flex;
    align-items: center;
}

.icon-scale01::before,
.icon-scale02::before,
.icon-scale03::before,
.icon-scale04::before,
.icon-scale05::before,
.icon-scale06::before {
    content: '';
    background-repeat: no-repeat;
    background-size: 100%;
    display: inline-block;
    margin-right: 4px;
    width: 40px;
    height: 40px;
}

.icon-scale01::before,
.icon-scale02::before,
.icon-scale03::before,
.icon-scale04::before,
.icon-scale05::before {
    margin-top: -4px;
}

.icon-scale01::before {
    background-image: url(../img/icon-scale01.svg);
    height: 32px;
}

.icon-scale02::before {
    background-image: url(../img/icon-scale02.svg);
    height: 32px;
}

.icon-scale03::before {
    background-image: url(../img/icon-scale03.svg);
    width: 36px;
    height: 34px;
}

.icon-scale04::before {
    background-image: url(../img/icon-scale04.svg);
    background-position: center;
    background-size: contain;
    height: 28px;
}

.icon-scale05::before {
    background-image: url(../img/icon-scale05.svg);
    height: 28px;
}

.icon-scale06::before {
    background-image: url(../img/icon-scale06.svg);
    width: 38px;
    height: 36px;
}

.kv-scale_in01 .kv-scale_mago,
.kv-scale_in02 .kv-scale_mago {
    width: 50%;
}

.kv-scale_in01 .kv-scale_mago:last-child,
.kv-scale_in02 .kv-scale_mago:last-child {
    padding-left: 8px;
}

.kv-scale_in02 .kv-scale_mago:first-child {
    width: 52%;
}

.kv-scale_in02 .kv-scale_mago:last-child {
    width: 48%;
}

.kv-calender_in {
    /* background-color: rgba(244, 244, 244, .8); */
    padding: 48px 24px 24px;
    position: relative;
}

.kv-calender_in .btn-style {
    background-image: radial-gradient(circle 56px at 14% 50%, rgba(255, 255, 255, 0) 28px, rgba(64, 168, 192, .88) 0);
    filter: unset;
    width: 80%;
    max-width: 312px;
    min-height: 72px;
    margin: unset;
    padding-left: 80px;
    justify-content: flex-start;
    top: -36px;
    left: 10vw;
}

.kv-calender_in .btn-style {
    position: absolute;
}

.kv-calender_in .btn-style::before,
.kv-calender_in .btn-style::after {
    content: '';
    position: absolute;
    left: 14%;
    transform: translateX(-50%);
}

.kv-calender_in .btn-style::before {
    border-left: solid 1px rgba(64, 168, 192, .88);
    width: 1px;
    height: 12px;
    bottom: -11px;
}

.kv-calender_in .btn-style::after {
    background-color: rgba(64, 168, 192, .88);
    border-radius: 50%;
    width: 8px;
    height: 8px;
    bottom: -20px;
}

.kv-calender_in .btn-style_in {
    font-size: 13px;
    text-align: left;
}

.kv-calender_in .btn-style_in::before,
.kv-calender_in .btn-style_in::after {
    color: rgba(64, 168, 192, 1);
    left: 6%;
}

.api-tab {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
}

.api-tab>div {
    background-color: rgba(224, 224, 224, .48);
    border: solid 1px rgba(224, 224, 224, .56);
    border-bottom: none;
    border-top-left-radius: 4px;
    border-top-right-radius: 4px;
    display: block;
    font-size: 13px;
    width: calc(50% - 2px);
    opacity: 0.5;
    padding: 6px;
    text-align: center;
}

@media screen and (min-width: 768px) {
    .api-tab .api-tab-txt {
        font-size: 16px;
    }
}

.api-tab>div.active {
    background-color: rgba(255, 255, 255, .7);
    border-color: #fff;
    opacity: 1;
    padding: 8px;
}

.api-board {
    background-color: rgba(255, 255, 255, .7);
    border: solid 1px #fff;
    border-top: none;
    border-bottom-left-radius: 4px;
    border-bottom-right-radius: 4px;
    margin-bottom: 8px;
    padding: 4px 8px 8px;
}

.api-board01,
.api-board02 {
    display: none;
    /* visibility: hidden; */
}

.api-board01.active,
.api-board02.active {
    display: block;
    visibility: visible;
}

.api-table {
    width: 100%;
    table-layout: fixed;
}


.api-table th,
.api-table td {
    font-size: 14px;
    font-weight: 400;
    text-align: center;
    vertical-align: middle;
}

.api-table th {
    font-size: 18px;
}

.api-table thead th,
.api-table thead td {
    height: 48px;
}

.api-table thead th span,
.api-table thead td>span {
    width: 88%;
    height: 88%;
    margin: auto;
    padding: 4px 0;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
}

.api-table thead th>span {
    background-color: #F5F5F5;
}

.api-table thead td>span {
    background-color: #E8F0F0;
}

.api-table tbody th,
.api-table tbody td {
    height: 40px;
}

.api-table tbody th span,
.api-table tbody td span {
    width: 88%;
    height: 88%;
    margin: auto;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #555;
}

.api-table tbody th span {
    background-color: #E8F0F0;
    font-size: 15px;
    letter-spacing: 0;
}

.api-table tbody td span {
    background-color: #F5F5F5;
}

.api-table .api-mmdd {
    font-size: 12px;
    font-size: 2.8vw;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 3px;
}

.api-table .api-mm {
    position: relative;
}

.api-table .api-mm::after {
    content: '|';
    display: inline-block;
    font-size: 9px;
    transform: translateX(2px) translateY(-1px) rotate(25deg);
}

.api-table .api-mmdd+span {
    background-color: #fff;
    border-radius: 3px;
    display: block;
    font-size: 10px;
    width: 70%;
    margin: 4px auto 0;
    padding: 2px;
}

.cl-sat {
    color: #40a8c0;
}

.cl-sun {
    color: #cf6285;
}

.api-hours {
    font-size: 12px;
    display: flex;
    flex-wrap: wrap;
}
@media screen and (min-width: 768px) {
    .api-table tbody th span, .api-table tbody td span {
        font-size: 20px;
    }
    .api-table .api-mmdd+span {
        font-size: 13px;
        width: 40px;
    }
    .api-table tbody th,
    .api-table tbody td {
        height: 48px;
    }
    .api-table thead td>span {
        padding: 10px 0;
    }
}
@media screen and (min-width: 1280px) {
    .api-hours {
        font-size: 14px;
        gap: 16px;
    }
}

.api-hours>div {
    display: flex;
    align-items: stretch;
    justify-content: flex-start;
}

.api-hours_h {
    background-color: #fff;
    border: solid 1px #eee;
    margin-right: 8px;
    padding: 4px 0;
    width: 80px;
    height: 100%;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
}

.api-hours_open {
    margin-bottom: 2px;
}

.api-hours_open .api-hours_h {
    padding: 8px 0;
}

.api-hours_in {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    justify-content: center;
}

.api-hours_in>span {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}

.api-hours_in>span:last-of-type {
    gap: 16px;
}

.api-hours_in .hours_th {
    display: inline-block;
    font-size: 11px;
    width: 32px;
    margin-left: 0;
    margin-right: auto;
    text-align: center;
}

.layaut-wrap {
    padding-bottom: 0;
}

.layaut_in {
    display: flex;
    flex-direction: column-reverse;
}

.layaut_in .txt-box {
    background-color: #fff;
    width: calc(100vw - 32px);
    padding: 64px 24px 72px;
    margin-top: -120px;
    position: relative;
    z-index: 2;
}

.layaut-wrap>.layaut_in:nth-child(2n+1) .txt-box {
    padding-left: 32px;
    left: -16px;
}

.layaut-wrap>.layaut_in:nth-child(2n) .txt-box {
    padding-right: 32px;
    right: -16px;
}

.layaut_in .photo-area {
    width: calc(100vw - 32px);
    position: relative;
}

.layaut-wrap>.layaut_in:nth-child(2n+1) .photo-area {
    right: -16px;
}

.layaut-wrap>.layaut_in:nth-child(2n) .photo-area {
    left: -16px;
}

.layaut_in h2 {
    line-height: 1.28;
    text-align: left;
    margin-bottom: 56px;
}

.layaut_in p.subtitle {
    line-height: 1.36;
}

.layaut-wrap>.layaut_in:nth-child(2n) h2,
.layaut_in p.subtitle {
    font-feature-settings: 'palt';
    text-align: right;
}

.tab-content .tab-wrap {
    width: 100%;
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
}

.tab-content .tab {
    background-color: rgba(168, 216, 224, .72);
    background-repeat: no-repeat;
    background-size: cover;
    color: #fff;
    width: calc(100% / 3 - 1px);
    height: 112px;
    padding-top: 56px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 4px;
}

.tab-content .tab01 {
    background-image: url(../img/tab01-bg_sp.png);
}

.tab-content .tab02 {
    background-image: url(../img/tab02-bg_sp.png);
}

.tab-content .tab03 {
    background-image: url(../img/tab03-bg_sp.png);
}

.tab-content .tab.active {
    background-color: rgba(255, 255, 255, 1);
    background-image: none;
    border: solid 5px #a8d8e0;
    border-bottom: none;
    color: #80c8d0;
    font-size: 1.12em;
    height: 128px;
    height: 120px;
    padding-top: 0;
    padding-bottom: 8px;
    position: relative;
}

.tab-content .tab.active::before {
    content: '';
    background-image: url(../img/tab-arrow.svg);
    background-repeat: no-repeat;
    background-size: contain;
    width: 20px;
    height: 10px;
    position: absolute;
    bottom: 17%;
    left: 50%;
    transform: translateX(-50%);
}

.tab-content .tab .fs-s {
    font-size: 0.88em;
}

.tab-content .board-wrap {
    border: solid 5px #a8d8e0;
    border-top: none;
}

.tab-content .board {
    display: none;
    visibility: hidden;
}

.tab-content .board.active {
    display: block;
    visibility: visible;
}

.counseling {
    background-image: url(../img/sampleimg03.jpg);
    background-position: center top;
    background-repeat: no-repeat;
    background-size: cover;
}

.counseling_in {
    width: 100%;
    position: relative;
}

.counseling_in::before,
.counseling_in::after {
    content: '';
    width: 100%;
    position: absolute;
}

.counseling_in::before {
    background-image: url(../img/sampleimg03.jpg);
    background-position: center bottom;
    background-repeat: no-repeat;
    background-size: 302.8vw;
    filter: grayscale(100%);
    height: 36%;
    bottom: 0;
}

.counseling_in::after {
    background-color: rgba(64, 168, 192, .72);
    height: 64%;
    top: 0;
}

.cs-h,
.cs-txt,
.cs-board {
    margin-right: auto;
    margin-left: auto;
    position: relative;
    z-index: 1;
}

.cs-h,
.cs-txt {
    width: calc(100% - 16px);
}

.cs-h {
    line-height: 2.4em;
    margin-bottom: 32px;
}

.cs-h .fs-lll {
    display: inline-block;
    transform: scale(1.6);
    padding-right: 4px;
    position: relative;
    top: -14px;
}

.cs-txt {
    font-size: 16px;
    text-align: center;
}

.cs-board {
    width: calc(100% - 40px);
    counter-reset: cs-board;
    margin-top: 96px;
}

.cs-board>div {
    background-color: rgba(255, 255, 255, .88);
    counter-increment: cs-board;
    padding: 56px 40px 32px;
    display: flex;
    flex-direction: column;
    position: relative;
}

.cs-board>div:not(:last-of-type) {
    margin-bottom: 72px;
}

.cs-board>div::before,
.cs-board>div::after {
    position: absolute;
    left: 50%;
    transform: translateX(-50%) translateY(-50%);
}

.cs-board>div::before {
    content: '';
    background-color: #444;
    border-radius: 50%;
    width: 96px;
    height: 96px;
    top: -8px;
}

.cs-board>div::after {
    content: "0" counter(cs-board);
    color: rgba(64, 168, 192, 1);
    font-family: 'Merriweather', YuMincho, "Hiragino Mincho ProN", serif;
    font-size: 34px;
    line-height: 100%;
    width: 48px;
    height: 32px;
    text-align: center;
    top: -12px;
}

.cs-board .type-h4 {
    font-size: 5.6vw;
    margin-bottom: 16px;
}

@media screen and (min-width: 428px) {
    .kv_in01_in h1 {
        font-size: 24px;
    }

    .api-table .api-mmdd {
        font-size: 14px;
    }

    .cs-board .type-h4 {
        font-size: 28px;
    }
}

@media screen and (min-width: 768px) {
    .api-hours_in .hours_th {
        font-size: 14px;
        width: 40px;
    }
    .api-hours_in, .api-hours_in>span {
        font-size: 17px;
    }
    .api-hours_in>span {
        gap: 0;
        flex-wrap: wrap;
        width: 100%;
    }
    .api-table .api-mmdd {
        font-size: 20px;
    }
    .page01 .hdr {
        position: absolute;
        width: 100%;
        top: 0;
        left: 50%;
        transform: translate(-50%, 0);
        display: flex;
        align-items: center;
        justify-content: space-between;
    }

    .page01 .hdr {
        padding: 16px 0 8px;
    }

    .page01 .logo-hdr {
        display: block;
        width: calc(100% / 3 - 8px);
    }

    .page01 nav.pc {
        width: calc((100% / 3) * 2);
        padding-right: 8px;
        display: flex;
        align-items: center;
        justify-content: space-between;
    }

    .page01 nav.pc>a {
        font-size: 14px;
        text-align: center;
        width: calc((100% - 200px) / 3);
        position: relative;
    }

    .page01 nav.pc>a:not(:last-of-type) {
        height: 64px;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    .page01 nav.pc>a:not(:last-of-type)::before {
        content: '';
        background-color: rgba(255, 255, 255, .8);
        border-radius: 50%;
        width: 8px;
        height: 8px;
        position: absolute;
        bottom: -10px;
        left: 50%;
        transform: translateX(-50%);
    }

    .page01 nav.pc>a.active:not(:last-of-type),
    .page01 nav.pc>a:not(:last-of-type):hover {}

    .page01 nav.pc>a.active:not(:last-of-type)::after,
    .page01 nav.pc>a:not(:last-of-type):hover::after {
        content: '';
        background: radial-gradient(circle 8px at 50% 85%, rgba(255, 255, 255, 0) 4px, rgba(255, 255, 255, .8) 0);
        border-radius: 50%;
        filter: drop-shadow(2px 2px 4px rgba(104, 104, 104, .16));
        width: 88px;
        height: 88px;
        position: absolute;
        left: 50%;
        top: -8%;
        transform: translateX(-50%) translateY(0);
    }

    .page01 nav.pc>a.active:not(:last-of-type)::before,
    .page01 nav.pc>a:not(:last-of-type):hover::before {
        content: none;
    }

    .page01 nav.pc .nav-child {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 8px;
        position: relative;
        top: 2px;
        z-index: 1;
        color: #fff;
    }

    .page01 nav.pc a:hover .nav-child {
        color: #40a8c0;

    }

    .page01 nav.pc .icon01::before {
        width: 16px;
        height: 16px;
    }

    .page01 nav.pc .nav-child .font-en01 {
        color: #fff;
    }

    .page01 nav.pc a:hover .nav-child .font-en01,
    .page01 nav.pc>a.active .font-en01 {
        color: rgba(128, 200, 208, 1);
    }

    .page01 nav.pc .nav-btn {
        display: block;
        background-color: #40A8C0;
        border-radius: 4px;
        color: #fff;
        filter: drop-shadow(2px 2px 3px rgba(104, 104, 104, .16));
        width: 200px;
        padding: 18px 0 16px;
        top: 16px;
    }

    .page01 nav.pc .nav-btn:hover {
        background-color: #a8d8e0;
        filter: drop-shadow(-2px -2px 4px rgba(104, 104, 104, .16));
    }

    .page01 nav.pc .nav-btn::before,
    .page01 nav.pc .nav-btn::after {
        content: '';
        background-image: url(../img/btn-fukidashi.svg);
        width: 12px;
        height: 18px;
        position: absolute;
        top: -24px;
    }

    .page01 nav.pc .nav-btn::before {
        left: 0;
    }

    .page01 nav.pc .nav-btn::after {
        right: 0;
        transform: rotateY(180deg);
    }

    .page01 nav.pc .nav-btn>span {
        display: flex;
        flex-direction: column;
        gap: 4px;
        position: relative;
    }

    .page01 nav.pc .nav-btn>span::before {
        content: '口腔内スキャナー診断つき！';
        color: rgba(64, 168, 192, 1);
        font-size: 12px;
        width: 100%;
        height: 12px;
        text-align: center;
        position: absolute;
        top: -36px;
        left: 50%;
        transform: translateX(-50%);
    }

    .kv-wrap {
        background-color: #fff;
        position: relative;
    }

    .kv {
        padding-top: 112px;
    }

    .kv::after {
        height: 100%;
        top: -40px;
    }

    .kv_in01_in {
        background-color: rgba(255, 255, 255, .24);
        width: 80%;
        padding: 32px 40px;
        padding-left: 128px;
        text-shadow: unset;
    }

    .kv_in01_in h1 {
        color: #444;
        font-size: 32px;
    }

    .kv_in01_in h1 .fs-sss {
        border: none;
        padding: unset;
    }

    .kv_in01_in picture {
        margin-right: 0;
        margin-left: auto;
    }

    .kv_in01_in picture::after {
        background-image: url(../img/logo-line01.svg);
        width: 784px;
        height: 152px;
        top: 56%;
        left: -60%;
    }

    .kv_in01_in .smile {
        color: #444;
        font-size: 22px;
        margin-bottom: 24px;
        padding-left: 4px;
        text-align: left;
    }

    .kv_in01_in .smile::after {
        background-image: url(../img/logo-slime01.svg);
        right: unset;
        top: 8px;
        margin-left: 8px;
    }

    .kv_in02::after {
        content: '';
        background-color: rgba(255, 255, 255, 1);
        width: 100%;
        height: calc(100% - 84px);
        position: absolute;
        top: 84px;
    }

    .kv .notify,
    .top__mv .notify,
    .kv-calender {
        position: relative;
        z-index: 1;
    }

    .kv .notify, .top__mv .notify {
        width: 50%;
        max-width: 432px;
    }

    .kv-scale {
        background-color: rgba(255, 255, 255, 0);
        width: 50%;
        padding: 0;
    }

    .kv-scale>.kv-scale_in:last-child {
        background-color: rgba(255, 255, 255, .8);
        padding-bottom: 8px;
        display: flex;
        flex-direction: row;
        align-items: center;
        gap: 8px;
    }

    .kv-scale_child {
        border-bottom: none;
        font-size: 14px;
        padding: 10px 0 0;
    }

    .kv-scale_in05 {
        max-width: calc(100% - (120px + 24px));
        width: calc(60% - 24px);
    }

    .icon-scale06 {
        width: 40%;
        max-width: 120px;
    }

    .kv-calender {
        /* background-color: rgba(244, 244, 244, .8); */
        width: calc(100% - 32px);
        margin: 16px auto 0;
        padding: 0 24px;
        display: flex;
        gap: 16px;
    }

    @media screen and (min-width: 1280px) {

        .kv-calender {
            gap: 40px;
        }
    }

    @media screen and (min-width: 1480px) {
        .kv-calender {
            gap: 96px;
        }
    }

    .kv-calender_in {
        background-color: rgba(255, 255, 255, 0);
        width: 50%;
        padding: 0;
        top: 40px;
    }

    .kv-calender_in .btn-style {
        width: 92%;
        min-height: 68px;
        top: -80px;
        left: 8px;
    }

    .api-tab>div {
        padding: 12px;
    }

    .api-tab>div.active {
        padding: 16px;
        padding-bottom: 12px;
    }

    .page01 .sc01 {
        overflow: hidden;
    }

    .tab-content .tab {
        font-size: 18px;
        padding-top: 16px;
        gap: 8px;
    }

    .tab-content .tab.active {
        font-size: 1.28em;
    }

    .tab-content .tab01 {
        background-image: url(../img/tab01-bg_pc.png);
        background-position: left center;
        padding-left: 12%;
    }

    .tab-content .tab02 {
        background-image: url(../img/tab02-bg_pc.png);
        background-position: left center;
        padding-left: 12%;
    }

    .tab-content .tab03 {
        background-image: url(../img/tab03-bg_pc.png);
        background-position: right center;
        padding-right: 12%;
    }

    .tab-content .tab01.active,
    .tab-content .tab02.active,
    .tab-content .tab03.active {
        padding-left: unset;
        padding-right: unset;
    }

    .layaut-wrap {
        padding-bottom: 88px;
    }

    .layaut_in {
        flex-direction: column;
        position: relative;
    }

    .layaut_in .photo-area {
        width: 80%;
    }

    .layaut-wrap>.layaut_in:nth-child(2n+1) .photo-area {
        width: 95%;
        right: -112px;
        position: absolute;
    }

    .layaut-wrap>.layaut_in:nth-child(2n) .photo-area {
        left: -144px;
    }

    .layaut_in .txt-box {
        background-color: rgba(255, 255, 255, .8);
        width: 58%;
        margin-top: unset;
        padding: 40px;
        padding-bottom: 80px;
    }

    .layaut-wrap>.layaut_in:nth-child(2n+1) .txt-box {
        padding-left: 32px;
    }

    .layaut-wrap>.layaut_in:nth-child(2n) .txt-box {
        width: 64%;
        padding-top: 64px;
        position: absolute;
        top: 72px;
        right: -16px;
    }

    .layaut_in h2 {
        margin-bottom: 48px;
    }

    .layaut-wrap>.layaut_in:nth-child(2n) h2,
    .layaut_in p.subtitle {
        text-align: left;
    }

    .counseling {
        background-position: center center;
    }

    .counseling_in::before {
        background-position: center 85%;
        background-size: cover;
    }

    .cs-board {
        display: flex;
        justify-content: space-between;
    }

    .cs-board>div {
        width: calc(100% / 3 - 8px);
        padding: 56px 24px 24px;
    }

    .cs-board>div:not(:last-of-type) {
        margin-bottom: unset;
    }

    .cs-board .type-h4 {
        font-size: 17px;
    }
}

@media screen and (min-width: 1024px) {
    .page01 nav.pc {
        padding-right: 16px;
        max-width: 576px;
    }

    .page01 nav.pc .nav-btn {
        margin-left: 32px;
    }

    .page01 nav.pc>a {
        width: calc((100% - 232px) / 3);
    }

    .page01 .logo-hdr picture {
        max-width: 344px;
        width: 100%;
    }

    .kv::after {
        background-size: 120%;
        width: 80%;
        height: calc(100% + 40px);
    }

    .kv_in01_in {
        background-color: rgba(255, 255, 255, .48);
        width: 72%;
        padding: 48px 56px;
        padding-left: 184px;
    }

    .kv_in01_in h1>span {
        display: block;
    }

    .kv_in01_in h1>span:first-of-type {
        margin-bottom: 12px;
    }

    .kv_in01_in picture::after {
        width: 1024px;
        height: 200px;
        top: 56%;
        left: -76%;
    }

    .kv-scale>.kv-scale_in:last-child {
        width: 85%;
        gap: 24px;
    }

    .api-board {
        border-bottom-left-radius: 8px;
        border-bottom-right-radius: 8px;
    }

    .api-tab>div {
        border-top-left-radius: 8px;
        border-top-right-radius: 8px;
    }

    .layaut-wrap {
        padding-bottom: 104px;
    }

    .page01 .layaut-wrap .layaut_in:first-child {
        margin-bottom: 112px;
    }

    .layaut-wrap>.layaut_in:nth-child(2n+1) .photo-area {
        width: 90%;
    }

    .layaut-wrap>.layaut_in:nth-child(2n) .photo-area {
        width: 68%;
    }

    .layaut_in .txt-box {
        background-color: rgba(255, 255, 255, 1);
        padding: 40px 80px 72px;
        width: 50%;
        top: -32px;
    }

    .layaut-wrap>.layaut_in:nth-child(2n) .txt-box {
        width: 55%;
        padding-top: 80px;
        top: 50%;
        transform: translateY(-50%);
    }

    .layaut_in h2 {
        margin-bottom: 64px;
    }

    .tab-content .tab {
        height: 128px;
    }

    .tab-content .tab.active {
        height: 138px;
    }

    .tab-content .tab01 {
        padding-left: 16%;
    }

    .tab-content .tab02 {
        padding-left: 16%;
    }

    .tab-content .tab03 {
        padding-right: 16%;
    }

    .counseling_in::before {
        background-position: center 75.25%;
    }

    .cs-h {
        margin-bottom: 64px;
    }

    .cs-board {
        margin-top: 112px;
    }

    .cs-board .type-h4 {
        font-size: 24px;
    }
}

@media screen and (min-width: 1200px) {
    .page01 nav.pc {
        max-width: 632px;
    }

    .kv {
        padding-top: 88px;
        width: 1980px;
        max-width: 100%;
        margin-left: auto;
        margin-right: auto;
        position: static;
    }

    .kv-wrap {
        position: relative;
    }

    .kv_in01 {
        /* margin-bottom: 128px; */
    }

    .kv_in01_in picture {
        margin-bottom: 48px;
    }

    .kv_in01_in picture::after {
        width: 1280px;
        height: 248px;
    }

    .kv_in02::after {
        content: none;
    }

    .kv .notify, .top__mv .notify {
        width: calc(100% / 3);
    }

    .kv-scale>.kv-scale_in:last-child {
        width: 100%;
        gap: 16px;
    }

    .kv-scale_child {
        padding-top: 5px;
    }

    .kv-scale_in05 {
        width: calc(60% - 16px);
    }

    .kv-calender {
        /* width: calc((100% / 3) * 2 - 16px); */
        width: 1280px;
        max-width: 100%;
        margin: 0 auto;
        /* position: absolute; */
        /* right: 0;
                top: calc(72%); */
        /* transform: translateY(-50%); */
    }

    .kv-calender_in {
        top: 36px;
    }

    .page01 .layaut-wrap .layaut_in:first-child {
        margin-bottom: 144px;
    }

    .layaut-wrap>.layaut_in:nth-child(2n+1) .photo-area {
        width: 80%;
    }

    .layaut-wrap>.layaut_in:nth-child(2n) .photo-area {
        width: 64%;
    }

    .layaut-wrap>.layaut_in:nth-child(2n) .txt-box {}

    .layaut_in h2 {
        font-size: 32px;
    }

    .tab-content .tab {
        font-size: 22px;
    }

    .tab-content .tab.active {
        font-size: 24px;
    }

    .tab-content .tab.active,
    .tab-content .board-wrap {
        border-width: 8px;
    }

    .counseling_in::before {
        background-position: center 72%;
    }

    .cs-board>div {
        width: calc(100% / 3 - 16px);
        padding: 72px 48px 32px;
    }

    .cs-h {
        margin-bottom: 56px;
    }

    .cs-board .type-h4 {
        margin-bottom: 32px;
    }
}

@media screen and (min-width: 1280px) {
    .page01 nav.pc {
        max-width: 744px;
    }

    .page01 nav.pc>a:not(:last-of-type) {
        width: calc((100% - (256px + 24px)) / 3);
        height: 72px;
    }

    .page01 nav.pc .nav-btn {
        width: 256px;
        margin-left: 24px;
        padding: 20px 0;
    }

    .page01 nav.pc .nav-btn>span {
        gap: 8px;
    }

    .page01 nav.pc>a.active:not(:last-of-type)::after,
    .page01 nav.pc>a:not(:last-of-type):hover::after {
        background: radial-gradient(circle 8px at 50% 76%, rgba(255, 255, 255, 0) 4px, rgba(255, 255, 255, .8) 0);
        width: 104px;
        height: 104px;
    }

    .kv_in01_in {
        padding: 48px 104px 56px;
        padding-left: 208px;
    }

    .kv .notify, .top__mv .notify {
        padding: 24px 24px 8px 40px;
    }

    .kv .notify_in, .top__mv .notify_in {
        margin-bottom: 24px;
    }

    .kv .note-child, .top__mv .note-child {
        margin-right: 24px;
    }

    .kv-scale_child {
        padding-top: 8px;
    }

    .icon-scale06 {
        max-width: 136px;
    }

    .kv-calender {
        padding: 0 32px;
    }

    .api-board {
        margin-bottom: 16px;
    }

    .layaut_in .txt-box {
        padding: 56px 152px 88px;
    }

    .layaut-wrap>.layaut_in:nth-child(2n+1) .txt-box {
        padding-left: 96px;
    }

    .layaut-wrap>.layaut_in:nth-child(2n) .txt-box {
        width: 55%;
        padding-top: 80px;
        padding-right: 96px;
    }

    .layaut-wrap>.layaut_in:nth-child(2n+1) .photo-area {
        width: 85%;
        right: -16%;
    }

    .layaut-wrap>.layaut_in:nth-child(2n) .photo-area {
        width: 56%;
        left: 0;
    }

    .layaut_in p.subtitle {
        margin-bottom: 40px;
    }

    .tab-content .tab {
        height: 144px;
    }

    .tab-content .tab.active {
        height: 156px;
    }

    .counseling_in::before {
        background-position: center 72.8%;
    }

    .cs-board {
        margin-top: 128px;
    }

    .cs-board>div {
        width: calc(100% / 3 - 40px);
    }

    .cs-board .type-h4 {
        font-size: 25px;
        margin-bottom: 36px;
    }

    .cs-board>div::before {
        width: 104px;
        height: 104px;
    }
}

@media screen and (min-width: 1366px) {
    .page01 nav.pc {
        padding-right: calc((100% - 1280px) / 2);
    }

    .kv_in01_in {
        padding: 72px 0 64px;
        padding-right: calc((100vw - 1280px) / 2);
        padding-left: 256px;
    }

    .kv_in01_in picture::after {
        width: 1472px;
        height: 288px;
    }

    .kv-scale {
        width: calc(50% - 24px);
    }

    .kv-calender {
        /* right: 16px; */
        justify-content: space-between;
    }

    .layaut-wrap {
        padding-bottom: 120px;
    }

    .page01 .layaut-wrap .layaut_in:first-child {
        margin-bottom: 176px;
    }

    .tab-content .tab {
        height: 152px;
    }

    .tab-content .tab.active {
        height: 164px;
    }

    .counseling_in::before {
        background-position: center 70.32%;
    }
}

@media screen and (min-width: 1440px) {
    .page01 nav.pc {
        max-width: 872px;
    }

    .kv_in01_in picture::after {
        width: 1576px;
        height: 304px;
        top: 40%;
    }

    .tab-content .tab {
        font-size: 25px;
        height: 160px;
    }

    .tab-content .tab.active {
        font-size: 28px;
        height: 172px;
    }
}

@media screen and (min-width: 1479px) {
    .kv-calender_in {
        top: 18px;
    }
}

@media screen and (min-width: 1536px) {
    .kv_in01 picture::after {
        width: 1608px;
        height: 312px;
    }

    .kv-calender {
        /* width: calc((1280px / 3) * 2 + 5vw);
                right: calc((100% - 1280px) / 2); */
    }

    .counseling_in::before {
        background-position: center 67.64%;
    }
}

@media screen and (min-width: 1920px) {
    .page01 nav.pc {
        max-width: 1024px;
    }

    .kv .notify, .top__mv .notify {
        max-width: 456px;
    }

    .kv-calender {
        /* width: calc((1280px / 3) * 2 + 8vw); */
    }

    .api-tab>div {}

    .counseling_in::before {
        background-position: center 63.64%;
    }
}

.js__tab-btn {
    cursor: pointer;
}

@media screen and (min-width: 1280px) {
    .page01 .topic-slider {
        padding-top: 128px;
    }

    .page01 nav.pc>a {
        font-size: 16px;
    }

    .page01 nav.pc>a:nth-child(2),
    .page01 nav.pc>a:nth-child(3) {
        text-shadow: 0 0 8px rgba(0, 0, 0, .5);
    }
}

.sec-10__area {
    padding: 40px 0 0;

}

.sec-10__wrapper {
    padding: 40px 24px;
    background-color: #f8f8f8;
}
.first__image img {
    width: 100%;
    height: auto;
}

@media screen and (min-width: 768px) {
    .sec-10__wrapper {
        padding: 56px 24px;
    }

    .sec-10__area {
        padding: 56px 0 0;

    }
}

@media screen and (min-width: 768px) {
    .kv_in02 {
        position: absolute;
        bottom: 0;
        left: 0;
        display: block;
        width: 100%;
    }


    .kv-03__inner {
        background-color: rgba(255, 255, 255, .48);
        max-width: 90%;
        margin-right: 0;
        margin-left: auto;
        padding: 100px;
        padding-left: 190px;
        padding-right: 0;
        backdrop-filter: blur(4px);
    }
}

/** top__first **/
.top__first {
    padding: 14.359vw 0 22.564vw;
}

.top__first-heading {
    margin: 0 auto 18.462vw;
}

.top__first-eng {
    text-align: right;
    width: calc(100% - 6.154vw);
    padding-left: 0;
    padding-right: 6.154vw;
    padding-bottom: 2.051vw;
    font-size: 16.41vw;
    margin: 0 0 0 6.154vw;
    height: 15.385vw;
    gap: 4.103vw;
    line-height: 1;
    color: var(--color-01);
    border-bottom: 1px solid var(--color-01);
    display: flex;
    align-items: flex-end;
    flex-direction: column;
}

.top__first-large {
    position: relative;
    font-size: 7.179vw;
    color: #40A8C0;
    padding-top: 26.667vw;
    padding-right: 6.154vw;
    margin-bottom: 6.154vw;
    width: calc(100% - 6.154vw);
    margin-left: 6.154vw;
    text-align: left;
}
.top__first-large::before {
    content: "";
    position: absolute;
    background: url(/img/first-heading-sp.svg) no-repeat;
    width: 94.872vw;
    height: 29.231vw;
    left: -2.564vw;
    top: -2.051vw;
    background-size: 100%;
}
.top__first-large em {
        font-size: 4.615vw;
        display: block;
        color: #444;
}

.top__first-heading p {
    width: calc(100% - 12.308vw);
    margin: auto;
}

.top__first-flow {
    width: calc(100% - 10.256vw);
    margin: auto;
    display: flex;
    gap: 14.359vw;
    flex-direction: column;
    align-items: flex-start;
}

.top__first-flex {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 10.256vw;
    flex-wrap: wrap;
}

.top__first-flex:not(:first-child) {
    gap: 12.308vw;
}

.top__first-flex:nth-child(even) {
    align-items: flex-end;
}

.top__first-flex figure {
    width: 89%;
    position: relative;
}

.top__first-flex figure::before {
    content: "1";
    position: absolute;
    bottom: -3.128vw;
    left: 76.549vw;
    font-size: 12.359vw;
    font-family: 'Crimson_Text variant0', serif;
    z-index: 1;
    color: #40A8C0;
}

.top__first-flex figure::after {
    content: "";
    width: 18.462vw;
    height: 18.462vw;
    background: #333;
    position: absolute;
    bottom: -6.154vw;
    left: 70.641vw;
    border-radius: 50%;
}

.top__first-flex:nth-child(2) figure::before {
    content: "2";
    left: unset;
    bottom: -3.333vw;
    right: 75.897vw;
    color: #80C8D0;
}

.top__first-flex:nth-child(2) figure::after {
    bottom: -6.154vw;
    left: unset;
    right: 70.256vw;
    transform: rotate(21deg);
}

.top__first-flex:nth-child(3) figure::before {
    content: "3";
    bottom: -3.59vw;
    left: 76.923vw;
}

.top__first-flex:nth-child(3) figure::after {
    bottom: -6.154vw;
    left: 70.769vw;
    transform: rotate(36deg);
}

.top__first-flex:nth-child(4) figure::before {
    content: "4";
    bottom: -3.077vw;
    left: unset;
    right: 77.436vw;
    color: #80C8D0;
}

.top__first-flex:nth-child(4) figure::after {
    bottom: -6.154vw;
    left: unset;
    right: 71.282vw;
    transform: rotate(80deg);
}

.top__first-content {
        width: calc(100% - 6.154vw);
        margin: auto;
}

.top__first-title {
    font-size: 7.179vw;
    margin-bottom: 4.103vw;
    color: #40A8C0;
    text-align: left;
}

.top__first-blue {
    background: rgba(233, 241, 245, 0.72);
    padding: 8.205vw;
    margin-top: 10.256vw;
}

.top__first-blue p {
    color: #555;
}

.top__first-cost {
    margin: 16.41vw auto 0;
    width: calc(100% - 16.41vw);
    background: #fff;
    border: 1px solid #4E8BAD;
    border-image: linear-gradient(to right, rgba(128, 200, 208, 1), rgba(64, 168, 192, 0.32)) 1;
    padding: 10.256vw 10.256vw 12.308vw;
}

.top__first-cost-kome {
        margin-top: 4.103vw;
        display: block;
}

.top__first-cost-title {
    position: relative;
    text-align: center;
    color: #40A8C0;
    font-size: 8.205vw;
    line-height: 1.3;
    margin: 0 auto 16.41vw;
}

.top__first-cost-title::after {
    content: "";
    position: absolute;
    transform: translate(-50%, 0);
    width: 10.256vw;
    height: 0.256vw;
    background: #40A8C0;
    bottom: -8.205vw;
    left: 50%;
}

.top__first-cost-title em {
    font-size: 6.154vw;
}

.top__first-cost-kome::before {
    content: "※";
    color: #4E8BAD;
}

@media screen and (min-width: 390px) {
    .top__first {
        padding: 56px 0 88px;
    }
    .top__first-inner {
        max-width: 390px;
        margin: auto;
    }
    .top__first-heading {
        margin: 0 auto 72px;
    }

    .top__first-eng {
        width: calc(100% - 24px);
        padding-right: 24px;
        padding-bottom: 8px;
        font-size: 64px;
        margin: 0 0 0 24px;
        height: 60px;
        gap: 16px;
    }

    .top__first-large {
        font-size: 28px;
        padding-top: 104px;
        padding-right: 24px;
        margin-bottom: 24px;
        width: calc(100% - 24px);
        margin-left: 24px;
    }
    .top__first-large::before {
        width: 370px;
        height: 114px;
        left: -10px;
        top: -8px;
    }
    .top__first-large em {
        font-size: 18px;
    }

    .top__first-heading p {
        width: calc(100% - 48px);
    }

    .top__first-flow {
        width: calc(100% - 40px);
        gap: 56px;
    }

    .top__first-flex {
        gap: 40px;
    }
    .top__first-flex:not(:first-child) {
        gap: 48px;
    }

    .top__first-content {
        width: calc(100% - 24px);
    }

    .top__first-flex figure::before {
        bottom: -12px;
        left: 298px;
        font-size: 48px;
    }

    .top__first-flex figure::after {
        width: 72px;
        height: 72px;
        bottom: -24px;
        left: 275px;
    }

    .top__first-flex:nth-child(2) figure::before {
        right: 296px;
        bottom: -13px;
    }

    .top__first-flex:nth-child(2) figure::after {
        bottom: -24px;
        right: 274px;
    }

    .top__first-flex:nth-child(3) figure::before {
        bottom: -14px;
        left: 300px;
    }

    .top__first-flex:nth-child(3) figure::after {
        bottom: -24px;
        left: 276px;
    }

    .top__first-flex:nth-child(4) figure::before {
        bottom: -12px;
        right: 302px;
    }

    .top__first-flex:nth-child(4) figure::after {
        bottom: -24px;
        right: 278px;
    }

    .top__first-title {
        font-size: 28px;
        margin-bottom: 16px;
    }

    .top__first-blue {
        padding: 32px;
        margin-top: 40px;
    }

    .top__first-cost {
        margin: 64px auto 0;
        width: calc(100% - 64px);
        padding: 40px 40px 48px;
    }
    .top__first-cost-kome {
        margin-top: 16px;
    }
    .top__first-cost-title {
        font-size: 32px;
        margin: 0 auto 64px;
    }

    .top__first-cost-title::after {
        width: 40px;
        height: 1px;
        bottom: -32px;
    }

    .top__first-cost-title em {
        font-size: 24px;
    }
}

@media screen and (min-width: 1024px) {
    .top__first {
        padding: 294px 0 80px;
    }

    .top__first-inner {
        max-width: 1149px;
        width: calc(100% - 88px);
        position: relative;
        margin: auto;
    }

    .top__first-flow {
        width: 100%;
        gap: 56px;
    }

    .top__first-flex {
        flex-direction: row;
        width: calc(100% - 85px);
        justify-content: space-between;
        align-items: flex-start;
        gap: 0;
    }
    .top__first-flex:not(:first-child) {
        align-items: center;
        width: calc(100% - 59px);
    }
    .top__first-flex:nth-child(2) {
        width: calc(100% - 59px);
    }
    .top__first-flex:nth-child(3) {
        width: calc(100% - 88px);
    }
    .top__first-flex:nth-child(4) {
        margin-top: 48px;
        width: calc(100% - 59px);
    }

    .top__first-flex:nth-child(even) {
        flex-direction: row-reverse;
        margin-left: 64px;
    }

    .top__first-flex:nth-child(1) {
        align-items: flex-end;
        margin-bottom: 40px;
    }

    .top__first-flex figure {
        width: 48.8%;
        z-index: 1;
    }

    .top__first-content {
        width: 42.5%;
        margin: 0;
    }
    .top__first-flex:nth-child(2) .top__first-content {
        width: 38.4%;
    }
    .top__first-flex:nth-child(3) .top__first-content {
        width: 41.1%;
    }
    .top__first-flex:nth-child(4) .top__first-content {

    }

    .top__first-flex figure::before {
        font-size: 80px;
        left: unset;
        right: -30px;
        bottom: -20px;
    }

    .top__first-flex figure::after {
        width: 128px;
        height: 128px;
        bottom: -37px;
        right: -37px;
        left: unset;
    }
    .top__first-large::before {
        background: url(/img/first-heading-pc.svg) no-repeat;
        background-size: 100%;
        width: 1370px;
        height: 282px;
        left: -125px;
        top: 0;
        z-index: -1;
    }
    .top__first-large > span {
        width: 336px;
        padding-top: 120px;
        margin-left: auto;
        margin-bottom: 28px;
        display: block;
        text-align: right;
        transform: translateX(48px);
    }

    .top__first-flex:nth-child(2) figure {
        width: 41.5%;
    }
    .top__first-flex:nth-child(2) figure::before {
        right: unset;
        left: -7px;
        bottom: 98px;
    }
    .top__first-flex:nth-child(2) figure::after {
        right: unset;
        bottom: 85px;
        left: -78px;
    }

    .top__first-flex:nth-child(3) figure {
        width: 42.7%;
    }
    .top__first-flex:nth-child(3) figure::before {
        left: unset;
        right: -24px;
        bottom: 134px;
    }
    .top__first-flex:nth-child(3) figure::after {
        left: unset;
        right: -52px;
        bottom: 112px;
    }

    .top__first-flex:nth-child(4) figure {
        
    }
    .top__first-flex:nth-child(4) figure::before {
        border: unset;
        right: unset;
        top: 38px;
        left: 25px;
    }
    .top__first-flex:nth-child(4) figure::after {
        right: unset;
        left: -45px;
        bottom: unset;
        top: 0;
    }

    .top__first-title {
        font-size: 34px;
        margin-bottom: 24px;
    }

    .top__first-flex:nth-child(2) .top__first-title {
        margin-top: 0;
    }

    .top__first-flex:nth-child(3) .top__first-title {
        margin-top: 0;
    }

    .top__first-flex:nth-child(4) .top__first-title {
        margin-top: 0;
    }
    .top__first-blue {
        padding: 32px 64px;
        margin-top: 32px;
    }

    .top__first-flex:nth-child(1)::after {
        width: calc(100% - 64px);
        left: unset;
        right: 0;
        bottom: -64px;
        transform: translate(0, 0);
    }

    .top__first-flex:nth-child(2)::after,
    .top__first-flex:nth-child(3)::after {
        width: 100%;
        left: 0;
        bottom: 24px;
        transform: translate(0, 0);
    }

    .top__first-heading {
        position: absolute;
        width: 100%;
        right: 0;
        top: -186px;
        text-align: right;
        margin: 0;
    }

    .top__first-heading p {
        width: 100%;
        transform: translateX(48px);
    }

    .top__first-eng {
        padding-right: 0;
        width: 100%;
        margin: 0;
    }

    .top__first-large {
        width: 100%;
        padding: 0;
        margin: 0;
    }

    .top__first-eng {
        font-size: 104px;
        height: 80px;
    }

    .top__first-cost {
        margin: 96px auto 0;
        max-width: 1024px;
        padding: 64px 104px;
        text-align: center;
    }

    .top__first-cost-title {
        font-size: 32px;
        margin-bottom: 88px;
    }

    .top__first-cost-title em {
        font-size: 24px;
    }

    .top__first-cost-title::after {
        bottom: -40px;
    }
}
@media screen and (min-width: 1024px) and (max-width: 1426px) {
    .top__first-large::before {
        width: 92.073vw;
        height: 22.776vw;
        left: -3vw;
    }
    .top__first-large > span, .top__first-heading p {
        transform: unset;
    }
}
