@charset "UTF-8";
:root {
    /* 画面375px時の各フォントサイズ */
    --fz-6: clamp(6px, 1.6vw, 18px); /* 6px */
    --fz-10: min(calc((10 / 375) * 100vw), 30px);
    --fz-12: min(calc((12 / 375) * 100vw), 36px);
    --fz-14: min(calc((14 / 375) * 100vw), 42px);
    --fz-16: min(calc((16 / 375) * 100vw), 48px);
    --fz-18: min(calc((18 / 375) * 100vw), 54px);
    --fz-20: min(calc((20 / 375) * 100vw), 60px);
    --fz-22: min(calc((22 / 375) * 100vw), 66px);
    --fz-32: min(calc((32 / 375) * 100vw), 94px);
    --fz-35: min(calc((35 / 375) * 100vw), 105px);
    --num-6: min(calc((6 / 375) * 100vw), 18px);
    --num-8: min(calc((8 / 375) * 100vw), 24px);
    --num-10: min(calc((10 / 375) * 100vw), 30px);
    --num-12: min(calc((12 / 375) * 100vw), 36px);
    --num-14: min(calc((14 / 375) * 100vw), 42px);
    --num-15: min(calc((15 / 375) * 100vw), 45px);
    --num-16: min(calc((16 / 375) * 100vw), 48px);
    --num-18: min(calc((18 / 375) * 100vw), 54px);
    --num-20: min(calc((20 / 375) * 100vw), 60px);
    --num-25: min(calc((25 / 375) * 100vw), 75px);
    --num-30: min(calc((30 / 375) * 100vw), 90px);
    --num-35: min(calc((35 / 375) * 100vw), 105px);
    --num-40: min(calc((40 / 375) * 100vw), 120px);
    --ls-05: 0.05em;
    --ls-n05: -0.05em;
    --lh-135: 1.35;
    --lh-115: 1.15;
}
@media screen and (min-width: 1025px) {
    :root {
        /* PC時の各フォントサイズ */
        --fz-12: min(calc((12 / 1140) * 100vw), 12x);
        --fz-16: min(calc((16 / 1140) * 100vw), 16x);
        --fz-18: min(calc((18 / 1140) * 100vw), 18x);
        --fz-20: min(calc((20 / 1140) * 100vw), 20x);
        --fz-22: min(calc((22 / 1140) * 100vw), 22x);
        --fz-25: min(calc((25 / 1140) * 100vw), 25x);
        --fz-28: min(calc((28 / 1140) * 100vw), 28x);
        --fz-30: min(calc((30 / 1140) * 100vw), 30x);
        --fz-32: min(calc((32 / 1140) * 100vw), 32x);
        --fz-35: min(calc((35 / 1140) * 100vw), 35x);
        --fz-45: min(calc((45 / 1140) * 100vw), 45x);
        --fz-63: min(calc((63 / 1140) * 100vw), 63x);
        --num-6: min(calc((6 / 1140) * 100vw), 12px);
        --num-8: min(calc((8 / 1140) * 100vw), 8px);
        --num-10: min(calc((10 / 1140) * 100vw), 10px);
        --num-12: min(calc((12 / 1140) * 100vw), 12px);
        --num-14: min(calc((14 / 1140) * 100vw), 14px);
        --num-15: min(calc((15 / 1140) * 100vw), 15px);
        --num-16: min(calc((16 / 1140) * 100vw), 16px);
        --num-18: min(calc((18 / 1140) * 100vw), 18px);
        --num-20: min(calc((20 / 1140) * 100vw), 20px);
        --num-25: min(calc((25 / 1140) * 100vw), 25px);
        --num-30: min(calc((30 / 1140) * 100vw), 30px);
        --num-35: min(calc((35 / 1140) * 100vw), 35px);
        --num-40: min(calc((40 / 1140) * 100vw), 40px);
    }
}
body {
    font-family: "Noto Sans JP", serif;
    font-optical-sizing: auto;
    font-weight: 400;
    font-style: normal;
    font-size: var(--fz-14);
    line-height: 1.5;
}
@media screen and (min-width: 1025px) {
    body {
        font-size: 18px;
    }
}
img {
    width: 100%;
}
a {
    text-decoration: none;
}
ul {
    list-style: none;
    padding: 0;
}
.section_box {
    padding-top: var(--num-25);
    padding-bottom: var(--num-30);
}
.inner {
    padding-left: var(--num-35);
    padding-right: var(--num-35);
}
@media screen and (min-width: 1025px) {
    .inner {
        max-width: min(calc((1020 / 1120) * 100vw), 1020px);
        margin-left: auto;
        margin-right: auto;
        padding-left: 10px;
        padding-right: 10px;
    }
}
.inner-wide {
    max-width: min(calc((1120 / 1120) * 100vw), 1120px);
}
.pc_only {
    display: none;
}
.break_pc {
    display: none;
}
@media screen and (min-width: 1025px) {
    .break_sp {
        display: none;
    }
    .break_pc {
        display: block;
    }
    .pc_only {
        display: block;
    }
    .sp_only {
        display: none;
    }
}
h2 {
    font-size: min(calc((26 / 375) * 100vw), 78px);
    font-weight: 900;
    letter-spacing: var(--ls-05);
    line-height: var(--lh-135);
    text-align: center;
}
@media screen and (min-width: 1025px) {
    h2 {
        font-size: 45px;
    }
}
.txt-angle {
    transform: rotate(-2.09deg);
    position: relative;
    display: inline-block;
    line-height: 1;
}
.txt-angle::after {
    content: "";
    display: block;
    width: 100%;
    height: min(calc((17 / 375) * 100vw), 51px);
    background-color: #000;
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: -1;
    transform: rotate(2.09deg);
}

@media screen and (min-width: 1025px) {
    .txt-angle::after {
        height: 30px;
    }
}
.marker {
    background: linear-gradient(transparent 70%, #f1e14a 70%);
}
.btn-line {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: min(calc((70 / 375) * 100vw), 210px);
    background: url(../img/btn_line_bg.webp) no-repeat top center / contain;
    color: #fff;
    font-weight: 700;
    line-height: var(--lh-135);
    letter-spacing: var(--ls-05);
}
.btn-line .btn-line__inner {
    text-align: center;
}
.btn-line .btn-line__txt--large {
    font-weight: 900;
    font-size: var(--fz-18);
}
@media screen and (min-width: 1025px) {
    .btn-line {
        width: 733px;
        height: 87px;
        margin: 0 auto;
        background: url(../img/btn_line_bg_pc.webp) no-repeat top center / contain;
        font-size: 30px;
    }
    .btn-line .btn-line__txt--large {
        font-size: 45px;
    }
}
.fv {
    position: relative;
    padding: 0;
}

.fv::after {
    content: "";
    width: min(calc((220 / 375) * 100vw), 660px);
    height: min(calc((245 / 375) * 100vw), 735px);
    background: url(../img/fv_ceo.webp) no-repeat center center / contain;
    position: absolute;
    bottom: 0;
    right: 0;
    z-index: 3;
}
@media screen and (min-width: 1025px) {
    .fv::after {
        content: "";
        width: min(calc((526 / 1440) * 100vw), 600px);
        height: min(calc((492 / 1440) * 100vw), 550px);
        background: url(../img/fv_ceo_pc.webp) no-repeat center bottom / contain;
        right: auto;
        bottom: -62px;
        left: calc(50% + 10px);
    }
}
.fv .fv__header {
    padding: min(calc((9 / 375) * 100vw), 27px) min(calc((13 / 375) * 100vw), 39px);
    margin-bottom: var(--num-20);
}
.fv .fv__header-logo img {
    width: min(calc((57 / 375) * 100vw), 171px);
}
@media screen and (min-width: 1025px) {
    .fv .fv__header {
        display: flex;
        justify-content: space-between;
        padding: 0;
        margin-bottom: 60px;
        box-shadow: 0 4px 10px rgb(0 0 0 / 20%);
    }
    .fv .fv__header-logo {
        display: flex;
        align-items: center;
        padding-left: min(calc((82 / 1440) * 100vw), 82px);
    }
    .fv .fv__header-logo img {
        width: 76px;
    }
    .fv .fv__header .btn-line {
        width: 302px;
        height: 66px;
        background: #30ad3b;
        font-size: 15px;
        box-shadow: 0 4px 10px rgb(0 0 0 / 20%);
    }
    .fv .fv__header .btn-line__txt--large {
        font-size: 22.5px;
    }
    .fv .fv__header .btn-line__inner {
        position: relative;
        left: -6px;
    }
    .fv .fv__header .btn-line__inner::after {
        content: "";
        display: block;
        width: 25px;
        height: 23px;
        background: url(../img/fv_btn_deco.webp) no-repeat center center / contain;
        position: absolute;
        bottom: 42%;
        left: 100%;
        z-index: 1;
    }
}
.fv .fv__ttl {
    font-weight: 700;
    font-size: var(--fz-18);
    text-align: center;
    letter-spacing: var(--ls-05);
    line-height: 1;
}
.fv .fv__ttl--hasbg {
    display: inline-block;
    padding: min(calc((4 / 375) * 100vw), 12px) 0 min(calc((4 / 375) * 100vw), 12px) min(calc((8 / 375) * 100vw), 24px);
    background: #f1e14a;
    transform: rotate(-4.47deg);
    position: relative;
    left: -4px;
}
.fv .fv__ttl--large {
    display: block;
    font-weight: 900;
    margin: var(--num-20) auto min(calc((18 / 375) * 100vw), 54px);
    font-size: min(calc((40 / 375) * 100vw), 120px);
    letter-spacing: unset;
}
.fv .fv__ttl-parentheses {
    font-weight: 300;
    letter-spacing: -0.1em;
}
@media screen and (min-width: 1025px) {
    .fv .fv__ttl {
        max-width: 1110px;
        padding-left: 10px;
        margin: 0 auto 40px;
        font-size: min(calc((30 / 1440) * 100vw), 30px);
        text-align: left;
        white-space: nowrap;
    }
    .fv .fv__ttl--hasbg {
        padding: 12px 1px 12px 12px;
        margin-bottom: min(calc((20 / 1440) * 100vw), 20px);
        left: -24px;
    }
    .fv .fv__ttl--large {
        display: inline-block;
        margin: 0;
        font-size: min(calc((80 / 1440) * 100vw), 80px);
        position: relative;
        left: max(calc((60 / 1440) * -100vw), -60px);
        letter-spacing: 0.06em;
    }
    .fv .fv__ttl--large + span {
        position: relative;
        left: max(calc((98 / 1440) * -100vw), -98px);
    }
}
@media screen and (min-width: 1025px) and (max-width: 1150px) {
    .fv .fv__ttl--hasbg {
        left: -4px;
    }
}
.fv .fv__txt {
    position: relative;
    z-index: 3;
}
@media screen and (min-width: 1025px) {
    .fv .fv__txt {
        max-width: 1110px;
        margin: 0 auto;
        padding-left: 10px;
    }
    .fv .fv__txt::after {
        content: "";
        display: block;
        width: 50vw;
        height: min(calc((209 / 1440) * 100vw), 209px);
        background: #2fb8ab;
        position: absolute;
        right: 97%;
        bottom: 1px;
        transform: rotate(-2.6deg);
        transform-origin: center right;
        z-index: -1;
    }
    .fv .fv__txt img {
        width: min(calc((766 / 1440) * 100vw), 766px);
    }
}
.fv__video-wrap {
    width: 100%;
    height: min(calc((232 / 375) * 100vw), 696px);
    overflow: hidden;
    margin-top: max(calc((25 / 375) * -100vw), -75px);
    background: #ead933;
    filter: contrast(140%);
    position: relative;
}
.fv__video-wrap::before {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    background: #e1d132;
    position: absolute;
    top: 0;
}
.fv__video-wrap video {
    width: 100%;
    overflow: hidden;
    transform: scale(1.4);
    transform-origin: 70% 65%;
    filter: grayscale(100%);
    opacity: 0.8;
}
@media screen and (min-width: 1025px) {
    .fv__video-wrap {
        width: 100%;
        height: min(calc((333 / 1440) * 100vw), 666px);
        overflow: hidden;
        margin-top: -146px;
        margin-bottom: 62px;
        background: #fff;
        filter: contrast(140%);
        position: relative;
        opacity: 0.8;
    }
    .fv__video-wrap::before {
        content: "";
        display: block;
        width: 100%;
        height: 100%;
        background: linear-gradient(to right, #f1e14a, #f1e14a 64%, #f1e14a 80%);
        position: absolute;
        top: 0;
    }
    .fv__video-wrap::after {
        content: "";
        display: block;
        width: 100%;
        height: 100%;
        background: linear-gradient(to right, transparent, #d0c7741f 15%, #d0c774 65%, #d4cc81 80%);
        position: absolute;
        top: 0;
    }
    .fv__video-wrap video {
        width: 80vw;
        overflow: hidden;
        transform: scale(1.1);
        transform-origin: 40% 160%;
        filter: grayscale(100%) contrast(1.5);
    }
}
@media screen and (min-width: 1025px) and (max-width: 1150px) {
    .fv .fv__video-wrap video {
        transform: scale(1.06);
        transform-origin: 40% 120%;
    }
}
.lead {
    padding-top: 0;
    padding-bottom: 0;
    background: #605c53;
    color: #fff;
}
.lead .inner--white {
    background: #fff;
    max-width: none;
    padding-top: var(--num-10);
    padding-bottom: var(--num-10);
    margin-bottom: var(--num-25);
    color: #3c4453;
    text-align: center;
    font-weight: 700;
    font-size: var(--fz-16);
    line-height: var(--lh-135);
    letter-spacing: 0.1em;
}
@media screen and (min-width: 1025px) {
    .lead .inner--white {
        display: flex;
        align-items: center;
        width: 100%;
        height: 62px;
        margin-bottom: 55px;
        font-size: min(calc((30 / 1440) * 100vw), 30px);
        position: relative;
        top: -62px;
    }
    .lead .inner--white p {
        width: 1100px;
        margin: 0 auto;
        text-align: left;
    }
}
.lead .lead__ttl {
    margin-bottom: var(--num-20);
    font-size: var(--fz-20);
    letter-spacing: var(--ls-n05);
    line-height: var(--lh-135);
    font-weight: 900;
}
.lead .lead__ttl .txt-angle {
    margin-top: var(--num-10);
    font-size: var(--fz-35);
    color: #f1e14a;
}
.lead .lead__ttl .txt-angle::after {
    background: #000;
}
@media screen and (min-width: 1025px) {
    .lead .lead__ttl {
        margin-top: -62px;
        font-size: 35px;
        white-space: nowrap;
    }
    .lead .lead__ttl .txt-angle {
        margin-top: 0;
        font-size: 63px;
    }
}
.lead .lead__list {
    display: flex;
    margin-top: min(calc((47 / 375) * 100vw), 141px);
    margin-bottom: min(calc((37 / 375) * 100vw), 111px);
}
@media screen and (min-width: 1025px) {
    .lead .lead__list {
        margin: 100px auto 86px;
        max-width: 720px;
    }
}
.lead .lead__list-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: calc(100% / 3);
    position: relative;
    font-weight: 700;
}
.lead .lead__list-item::after {
    content: "";
    display: block;
    width: min(calc((117 / 375) * 100vw), 351px);
    height: min(calc((117 / 375) * 100vw), 351px);
    border-radius: 50%;
    border: 1px solid #fff;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

@media screen and (min-width: 1025px) {
    .lead .lead__list-item::after {
        width: 256px;
        height: 256px;
    }
}
.lead .lead__list-item span {
    font-size: var(--fz-12);
}
.lead .lead__list-item .lead__list-txt01-1,
.lead .lead__list-item .lead__list-txt02-3 .txt-large {
    font-size: var(--fz-16);
}

.lead .lead__list-item .lead__list-txt03-2 {
    font-size: var(--fz-35);
    line-height: 1;
}
@media screen and (min-width: 1025px) {
    .lead .lead__list-item span {
        font-size: 25px;
    }
    .lead .lead__list-item .lead__list-txt01-1,
    .lead .lead__list-item .lead__list-txt02-3 .txt-large {
        font-size: 35px;
    }
    .lead .lead__list-item .lead__list-txt02-2 {
        font-size: 20px;
    }
    .lead .lead__list-item .lead__list-txt03-2 {
        font-size: 75px;
    }
}
.lead .lead__list-note {
    margin-bottom: var(--num-20);
    font-size: var(--fz-6);
    line-height: var(--lh-115);
    letter-spacing: 0.1em;
    font-weight: 500;
    text-align: center;
}
@media screen and (min-width: 1025px) {
    .lead .lead__list-note {
        margin-bottom: 46px;
        font-size: 10px;
    }
}
.lead .lead_pic-wrap {
    margin-bottom: var(--num-12);
}
@media screen and (min-width: 1025px) {
    .lead .lead_pic-wrap {
        margin-bottom: 50px;
    }
}
.lead .lead__txt {
    margin-bottom: var(--num-8);
    font-size: var(--fz-16);
    font-weight: 700;
    letter-spacing: var(--ls-05);
    text-align: center;
}
@media screen and (min-width: 1025px) {
    .lead .lead__txt {
        margin-bottom: 30px;
        font-size: min(calc((25 / 1120) * 100vw), 25px);
        white-space: nowrap;
    }
}
.lead .btn-wrap {
    position: relative;
    top: var(--num-30);
}
@media screen and (min-width: 1025px) {
    .lead .btn-wrap {
        top: 44px;
    }
}
.success {
    padding-top: min(calc((55 / 375) * 100vw), 165px);
    background: url(../img/success_bg.webp) no-repeat top center / 100%;
}
@media screen and (min-width: 1025px) {
    .success {
        padding-top: 78px;
        padding-bottom: 74px;
        background: url(../img/success_bg_pc.webp) no-repeat top center / 100%;
    }
}
.success .success__ttl {
    margin-bottom: var(--num-8);
    font-size: var(--fz-35);
    letter-spacing: var(--ls-n05);
}
.success .txt-angle::after {
    background: #f1e14a;
}
@media screen and (min-width: 1025px) {
    .success .success__ttl {
        margin-bottom: 24px;
        font-size: 63px;
    }
}
.success .success__lead {
    margin-bottom: var(--num-12);
    font-size: var(--fz-16);
    font-weight: 700;
    letter-spacing: var(--ls-05);
    text-align: center;
}
.success .success__lead-note {
    margin-bottom: var(--num-35);
    font-size: var(--fz-6);
    letter-spacing: 0.1em;
    text-align: center;
}
@media screen and (min-width: 1025px) {
    .success .success__lead {
        font-size: 25px;
    }
    .success .success__lead-note {
        margin-bottom: 58px;
        font-size: 12px;
    }
}
.success .success__list {
    display: flex;
    flex-direction: column;
    gap: min(calc((22 / 375) * 100vw), 66px);
    margin-bottom: var(--num-10);
}
.success .success__list-item {
    background: #44413b;
    padding: var(--num-20) min(calc((27 / 375) * 100vw), 81px) var(--num-18) min(calc((27 / 375) * 100vw), 81px);
    border: 3px solid #fff;
    border-radius: var(--num-16);
    box-shadow: 7px 7px 4px rgb(0 0 0 / 10%);
    filter: drop-shadow(0 0 5px rgb(0 0 0 / 50%));
    color: #fff;
    letter-spacing: var(--ls-05);
    line-height: var(--lh-135);
}
.success .success__list-item h3 {
    padding-bottom: var(--num-14);
    border-bottom: 1px solid #fff;
    font-size: var(--fz-18);
    font-weight: 700;
    letter-spacing: var(--ls-05);
}
.success .success__list-txt {
    padding-top: var(--num-15);
    margin-bottom: var(--num-14);
    font-weight: 500;
    letter-spacing: var(--ls-05);
}
.success .success__list-person {
    display: flex;
    align-items: flex-end;
    gap: var(--num-10);
    position: relative;
    left: max(calc((10 / 375) * -100vw), -20px);
}
.success .success__list-person-pic {
    width: min(calc((79 / 375) * 100vw), 237px);
    height: min(calc((79 / 375) * 100vw), 237px);
    flex-shrink: 0;
    background: #d9d9d9;
    border-radius: 50%;
}
.success .success__list-person-attribute {
    padding-bottom: min(calc((6 / 375) * 100vw), 18px);
    font-size: var(--fz-12);
    font-weight: 400;
    white-space: nowrap;
}
@media screen and (min-width: 1025px) {
    .success .success__list {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
        gap: 20px min(6%, 60px);
        margin-bottom: 33px;
    }
    .success .success__list-item {
        display: grid;
        grid-template-rows: subgrid;
        grid-template-columns: inherit;
        grid-row: span 3;
        width: 100%;
        margin: 0;
        padding: 30px 40px;
        border-radius: 18px;
        box-shadow: 10px 10px 6px rgb(0 0 0 / 10%);
        filter: drop-shadow(0 0 8px rgb(0 0 0 / 50%));
    }
    .success .success__list-item h3 {
        align-self: self-end;
        padding-bottom: 20px;
        font-size: 28px;
    }
    .success .success__list-txt {
        padding-top: 4px;
        margin-bottom: 0;
    }
    .success .success__list-person {
        display: flex;
        align-items: flex-end;
        gap: 16px;
        left: -8px;
    }
    .success .success__list-person-pic {
        width: 122px;
        height: 122px;
    }
    .success .success__list-person-attribute {
        padding-bottom: min(calc((6 / 375) * 100vw), 18px);
        font-size: var(--fz-12);
        font-weight: 400;
        white-space: nowrap;
    }
}
.success .success__list-note {
    font-size: var(--fz-6);
    letter-spacing: 0.1em;
    line-height: var(--lh-115);
    text-align: center;
}
@media screen and (min-width: 1025px) {
    .success .success__list-note {
        font-size: 12px;
    }
}
@media screen and (min-width: 1025px) {
    .message01 {
        padding-top: 80px;
        padding-bottom: 78px;
    }
}
.message01 {
    background: #f0f0f0;
}
@media screen and (min-width: 1025px) {
    .message01 {
        padding-top: 60px;
        padding-bottom: 88px;
    }
}
.message01 .message01__ttl {
    margin-bottom: var(--num-12);
    line-height: var(--lh-135);
    letter-spacing: var(--ls-n05);
    font-size: var(--fz-20);
}
.message01 .message01__ttl-line02 {
    display: inline-block;
    padding: var(--num-10) 0;
}
.message01 .message01__ttl .txt-angle {
    font-size: var(--fz-35);
}
.message01 .message01__ttl .txt-angle::after {
    background: #f1e14a;
    left: max(calc((6 / 375) * -100vw), -12px);
}
@media screen and (min-width: 1025px) {
    .message01 .message01__ttl {
        margin-bottom: 93px;
        font-size: 35px;
    }
    .message01 .message01__ttl .txt-angle {
        font-size: 63px;
    }
    .message01 .message01__ttl .txt-angle::after {
        left: 0;
    }
    .message01 .message01__ttl-line03 {
        font-size: 65px;
    }
}
.message01 .message01__pic {
    margin-bottom: var(--num-25);
}
@media screen and (min-width: 1025px) {
    .message01 .message01__cont {
        display: flex;
        gap: 5%;
    }
    .message01 .message01__pic {
        width: 52%;
        margin-bottom: 0;
    }
    .message01 .message01__txt {
        width: 43%;
        font-size: 22px;
    }
}
.demand {
    background: url(../img/demand_bg.webp) no-repeat top center / cover;
}
@media screen and (min-width: 1025px) {
    .demand {
        padding-top: 74px;
        padding-bottom: 102px;
        background: url(../img/demand_bg_pc.webp) no-repeat top center / cover;
        position: relative;
    }
    .demand__pic {
        width: min(calc((436 / 1120) * 100vw), 436px);
        position: absolute;
        bottom: 70px;
        left: calc(50vw + 10%);
    }
}
@media screen and (min-width: 1140px) {
    .demand__pic {
        left: calc(50vw + 108px);
    }
}
.demand .demand__ttl {
    margin-bottom: var(--num-6);
}
@media screen and (min-width: 1140px) {
    .demand .demand__ttl {
        margin-bottom: 40px;
    }
}
.demand .demand__list {
    display: flex;
    flex-direction: column;
    margin-bottom: var(--num-20);
}
.demand .demand__list-item {
    display: flex;
    gap: min(calc((7 / 375) * 100vw), 21px);
    position: relative;
    padding: var(--num-10) 0;
    background: url(../img/dotted_line.webp) repeat-x bottom left / 716px;
    line-height: var(--lh-135);
}
.demand .demand__list-item::before {
    content: "×";
    margin-top: max(calc((8 / 375) * -100vw), -9px);
    color: #d90000;
    font-size: var(--fz-20);
    display: inline-block;
    padding-top: min(calc((3 / 375) * 100vw), 4px);
    font-weight: 900;
}
.demand .demand__list-item:last-of-type {
    padding-bottom: 0;
    background: none;
    white-space: nowrap;
}
@media screen and (min-width: 1025px) {
    .demand .demand__list {
        margin-bottom: 108px;
    }
    .demand .demand__list-item {
        display: flex;
        gap: 12px;
        width: fit-content;
        padding: 21px 0 16px;
        background: url(../img/dotted_line_demand.webp) repeat-x bottom left / 472px;
        font-size: 25px;
    }
    .demand .demand__list-item::before {
        font-size: 35px;
    }
}
.demand .demand_estimate .txt-angle {
    transform: rotate(-5.03deg);
    font-weight: 700;
    font-size: var(--fz-16);
    line-height: var(--lh-135);
    letter-spacing: var(--ls-05);
    background: #f1e14a;
    padding: min(calc((2 / 375) * 100vw), 6px) min(calc((6 / 375) * 100vw), 18px);
}
.demand .demand_estimate .txt-angle::after {
    content: none;
}
@media screen and (min-width: 1025px) {
    .demand .demand_estimate .txt-angle {
        padding: 8px 18px;
        font-size: 31px;
        top: 1px;
        left: -5px;
    }
}
.demand .demand_estimate-main {
    display: flex;
    align-items: flex-end;
    justify-content: end;
    gap: var(--num-10);
}
.demand .demand_estimate-txt01 {
    padding: var(--num-15);
    background-color: #686868;
    background-image: url(../img/demand_txt01_bg.webp);
    background-repeat: no-repeat;
    background-position: bottom center;
    background-size: min(calc((168 / 375) * 100vw), 504px);
}
.demand .demand_estimate-txt01 img {
    width: min(calc((168 / 375) * 100vw), 504px);
}
.demand .demand_estimate-txt02 {
    padding-bottom: 5px;
}
.demand .demand_estimate-txt02 img {
    width: min(calc((31 / 375) * 100vw), 93px);
}
@media screen and (min-width: 1025px) {
    .demand .demand_estimate-main {
        justify-content: flex-start;
        gap: 17px;
        padding-left: 154px;
    }
    .demand .demand_estimate-txt01 {
        padding: 28px;
        background-color: #686868;
        background-image: url(../img/demand_txt01_bg.webp);
        background-repeat: no-repeat;
        background-position: top 12px center;
        background-size: 322px;
    }
    .demand .demand_estimate-txt01 img {
        width: 323px;
    }
    .demand .demand_estimate-txt02 {
        padding-bottom: 2px;
    }
    .demand .demand_estimate-txt02 img {
        width: 60px;
    }
}
@media screen and (min-width: 1025px) {
    .growth {
        padding-top: 65px;
        padding-bottom: 82px;
    }
}
.growth .growth__ttl {
    margin-bottom: var(--num-16);
}
@media screen and (min-width: 1025px) {
    .growth .growth__ttl {
        margin-bottom: 6px;
    }
}
.growth .growth__lead {
    margin-bottom: var(--num-14);
    font-size: var(--fz-18);
    line-height: var(--lh-115);
    letter-spacing: var(--ls-05);
    text-align: center;
}
.growth .growth__lead-num {
    font-size: min(calc((24 / 375) * 100vw), 72px);
    font-weight: 700;
}
@media screen and (min-width: 1025px) {
    .growth .growth__lead {
        margin-bottom: 70px;
        font-size: 30px;
    }
    .growth .growth__lead-num {
        font-size: 57px;
    }
}
.growth .growth_pic {
    margin-bottom: var(--num-25);
    transform-origin: top right;
    transform: scale(1.04);
}
@media screen and (min-width: 1025px) {
    .growth .growth_pic {
        max-width: 640px;
        margin: 0 auto 36px;
        transform: none;
    }
}
.growth .growth__txt {
    padding: 0 var(--num-6);
    margin-bottom: min(calc((8 / 375) * 100vw), 24px);
    font-weight: 500;
}
.growth .growth__note {
    font-size: min(calc((9 / 375) * 100vw), 27px);
}
@media screen and (min-width: 1025px) {
    .growth .growth__txt {
        padding: 0;
        margin-bottom: 12px;
        font-size: 22px;
        text-align: center;
    }
    .growth .growth__note {
        font-size: min(calc((9 / 375) * 100vw), 27px);
        font-size: 16px;
        text-align: center;
    }
}
.beforeafter {
    background: #f0f0f0;
    padding-bottom: 0;
}
@media screen and (min-width: 1025px) {
    .beforeafter {
        padding-top: 86px;
        padding-bottom: 32px;
    }
}
.beforeafter .beforeafter__ttl {
    margin-bottom: var(--num-20);
    font-size: var(--fz-20);
    letter-spacing: var(--ls-n05);
}
.beforeafter .beforeafter__ttl .txt-angle {
    margin-top: var(--num-8);
    font-size: var(--fz-35);
}
.beforeafter .beforeafter__ttl .txt-angle::after {
    background: #f1e14a;
}
@media screen and (min-width: 1025px) {
    .beforeafter .beforeafter__ttl {
        margin-bottom: 55px;
        font-size: 35px;
    }
    .beforeafter .beforeafter__ttl .txt-angle {
        margin-top: 6px;
        font-size: 63px;
    }
}
.beforeafter .beforeafter__txt {
    margin-bottom: var(--num-35);
}
@media screen and (min-width: 1025px) {
    .beforeafter .beforeafter__txt {
        font-size: 25px;
        text-align: center;
        margin-bottom: 92px;
    }
}
.beforeafter .beforeafter__list-ttl {
    padding-top: min(calc((3 / 375) * 100vw), 9px);
    padding-bottom: min(calc((4 / 375) * 100vw), 12px);
    margin-right: var(--num-35);
    color: #fff;
    background: linear-gradient(to right, transparent, transparent 64%, #333 80%);
    text-align: right;
    font-size: var(--fz-10);
    line-height: var(--lh-135);
    font-weight: 900;
}
.beforeafter .beforeafter__list-item.item01 .beforeafter__list-ttl {
    padding-right: min(calc((11 / 375) * 100vw), 33px);
}
.beforeafter .beforeafter__list-item.item02 .beforeafter__list-ttl {
    padding-right: min(calc((24 / 375) * 100vw), 72px);
    position: relative;
    right: max(calc((5 / 375) * -100vw), -10px);
}
.beforeafter .beforeafter__list-item.item03 .beforeafter__list-ttl {
    padding-right: min(calc((7 / 375) * 100vw), 21px);
}
.beforeafter .beforeafter__list-item.item03 .beforeafter__list-ttl span {
    font-size: var(--fz-6);
}
.beforeafter .beforeafter__list-item.item04 .beforeafter__list-ttl {
    padding-right: var(--num-15);
    position: relative;
    right: max(calc((5 / 375) * -100vw), -10px);
}
.beforeafter .beforeafter__list-item .beforeafter__list-pic {
    position: relative;
}
.beforeafter .beforeafter__list-item.item01 .beforeafter__list-pic {
    top: max(calc((30 / 375) * -100vw), -60px);
}
.beforeafter .beforeafter__list-item.item02 .beforeafter__list-pic {
    top: max(calc((30 / 375) * -100vw), -60px);
}
.beforeafter .beforeafter__list-item.item03 .beforeafter__list-pic {
    top: max(calc((30 / 375) * -100vw), -60px);
}
.beforeafter .beforeafter__list-item.item04 .beforeafter__list-pic {
    top: max(calc((30 / 375) * -100vw), -60px);
}
@media screen and (min-width: 1025px) {
    .beforeafter .beforeafter__list {
        max-width: 1126px;
        margin: 0 auto;
        display: grid;
        grid-template-columns: 1fr 1fr;
        grid-template-rows: 1fr 1fr;
        gap: 0 54px;
    }
    .beforeafter .beforeafter__list-item.item02,
    .beforeafter .beforeafter__list-item.item04 {
        padding-top: 25px;
        position: relative;
        top: 25px;
        right: 12px;
    }
    .beforeafter .beforeafter__list-ttl {
        padding-top: 5px;
        padding-bottom: 8px;
        margin-right: 0;
        background: linear-gradient(to right, transparent, transparent 60%, #333 78%);
        font-size: 16px;
    }
    .beforeafter .beforeafter__list-item.item01 .beforeafter__list-ttl {
        padding-right: 17px;
        margin-right: 18px;
    }
    .beforeafter .beforeafter__list-item.item02 .beforeafter__list-ttl {
        padding-right: 45px;
        position: relative;
        right: 0;
    }
    .beforeafter .beforeafter__list-item.item03 .beforeafter__list-ttl {
        padding-right: 13px;
        margin-right: 18px;
    }
    .beforeafter .beforeafter__list-item.item03 .beforeafter__list-ttl span {
        font-size: 10px;
    }
    .beforeafter .beforeafter__list-item.item04 .beforeafter__list-ttl {
        padding-right: 23px;
        position: relative;
        right: 10px;
    }
    .beforeafter .beforeafter__list-item .beforeafter__list-pic {
        position: relative;
    }
    .beforeafter .beforeafter__list-item.item01 .beforeafter__list-pic {
        top: -42px;
    }
    .beforeafter .beforeafter__list-item.item02 .beforeafter__list-pic {
        top: -54px;
    }
    .beforeafter .beforeafter__list-item.item03 .beforeafter__list-pic {
        top: -44px;
    }
    .beforeafter .beforeafter__list-item.item04 .beforeafter__list-pic {
        top: -48px;
    }
}
@media screen and (min-width: 1025px) {
    .feature {
        padding-top: 98px;
        padding-bottom: 90px;
    }
}
.feature .feature__ttl {
    letter-spacing: var(--ls-n05);
    font-size: var(--fz-20);
    margin-bottom: var(--num-20);
}
.feature .feature__ttl .txt-angle {
    font-size: var(--fz-35);
}
.feature .feature__ttl .txt-angle::after {
    background: #f1e14a;
}
.feature .feature__ttl .txt-angle--small {
    font-size: var(--fz-20);
}
.feature .feature__ttl-line02 {
    display: inline-block;
    margin: var(--num-8) 0;
}
.feature .feature__ttl-line03 .txt-angle {
    font-size: min(calc((28 / 375) * 100vw), 84px);
}
.feature .feature__ttl-line03 .txt-angle::after {
    bottom: max(calc((6 / 375) * -100vw), -18px);
}
@media screen and (min-width: 1025px) {
    .feature .feature__ttl {
        font-size: 35px;
        margin-bottom: 100px;
    }
    .feature .feature__ttl .txt-angle {
        font-size: 63px;
    }
    .feature .feature__ttl .txt-angle--small {
        font-size: 35px;
    }
    .feature .feature__ttl-line02 {
        margin-bottom: 20px;
    }
    .feature .feature__ttl-line03 .txt-angle {
        font-size: 63px;
    }
    .feature .feature__ttl-line03 .txt-angle::after {
        bottom: 0;
    }
}
.feature .feature__lead {
    margin-bottom: var(--num-25);
    font-size: var(--fz-18);
    letter-spacing: var(--ls-05);
    font-weight: 500;
    text-align: center;
}
@media screen and (min-width: 1025px) {
    .feature .feature__lead {
        margin-bottom: 58px;
        font-size: 30px;
    }
}
.feature .feature__list-wrap {
    position: relative;
}
.feature .feature__list-wrap::after {
    content: "";
    width: 100%;
    height: 100%;
    border: 2px solid #231815;
    background: #e5e5e7;
    position: absolute;
    top: min(calc((7 / 375) * 100vw), 21px);
    left: min(calc((7 / 375) * 100vw), 21px);
    z-index: 1;
}
.feature .feature__list {
    padding: min(calc((24 / 375) * 100vw), 72px) var(--num-12);
    border: 2px solid #231815;
    background: #fff;
    position: relative;
    z-index: 2;
}
.feature .feature__list::before {
    content: "";
    width: min(calc((37 / 375) * 100vw), 111px);
    height: min(calc((45 / 375) * 100vw), 135px);
    background: url(../img/feature_clip.svg) no-repeat center center / cover;
    position: absolute;
    top: max(calc((-6 / 375) * 100vw), -18px);
    right: min(calc((17 / 375) * 100vw), 51px);
    z-index: 1;
}
.feature .feature__list::after {
    content: "";
    width: min(calc((16 / 375) * 100vw), 48px);
    height: min(calc((67 / 375) * 100vw), 201px);
    background: url(../img/feature_arrow.svg) no-repeat center center / contain;
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    z-index: 1;
}
.feature .feature__list-item {
    display: flex;
    align-items: baseline;
    gap: min(calc((7 / 375) * 100vw), 21px);
    position: relative;
    padding: var(--num-10) 0;
    background: url(../img/dotted_line.webp) repeat-x bottom left / 100%;
    line-height: var(--lh-135);
    font-weight: 500;
}
.feature .feature__list-item::before {
    content: "×";
    color: #d90000;
    font-size: var(--fz-20);
    line-height: 1;
    font-weight: 900;
    position: relative;
    top: 2px;
}
.feature .feature__list-item:first-of-type {
    padding-top: 0;
}
.feature .feature__list-item:last-of-type {
    padding-bottom: 0;
    background: none;
}
@media screen and (min-width: 1025px) {
    .feature .feature__list-wrap {
        width: fit-content;
        margin: 0 auto;
    }
    .feature .feature__list-wrap::after {
        top: 20px;
        left: 15px;
        border: 3px solid #231815;
    }
    .feature .feature__list {
        max-width: 820px;
        padding: 46px 40px 60px;
        position: relative;
        right: 6px;
        border: 3px solid #231815;
    }
    .feature .feature__list::before {
        width: 60px;
        height: 72px;
        top: -9px;
        right: 52px;
    }
    .feature .feature__list::after {
        width: 26px;
        height: 178px;
        background: url(../img/feature_arrow_pc.svg) no-repeat center center / contain;
    }
    .feature .feature__list-item {
        width: fit-content;
        gap: 11px;
        padding: 17px 0 14px;
        font-size: 25px;
        background: url(../img/dotted_line_245.webp) repeat-x bottom left / 730px;
    }
    .feature .feature__list-item::before {
        font-size: 32px;
        top: 2px;
    }
}
.curriculum01 {
    padding-top: var(--num-16);
    padding-bottom: 0;
    background: #f1e14a;
}
@media screen and (min-width: 1025px) {
    .curriculum01 {
        padding-top: 88px;
        padding-bottom: 216px;
        position: relative;
    }
    .curriculum01::after {
        content: "";
        position: absolute;
        display: block;
        width: 100%;
        height: min(calc((314 / 1440) * 100vw), 2880px);
        clip-path: polygon(100% 0, 0% 100%, 100% 100%);
        background: #605c53;
        bottom: -1px;
    }
}
.curriculum01 .curriculum01__icon {
    padding-left: var(--num-20);
    margin-bottom: var(--num-20);
    background: #f1e14a;
}
.curriculum01 .curriculum01__icon img {
    width: min(calc((60 / 375) * 100vw), 180px);
}
.curriculum01 .curriculum01__logo {
    padding-bottom: var(--num-10);
    margin-bottom: var(--num-10);
    border-bottom: 1px solid #000;
    text-align: center;
}
.curriculum01 .curriculum01__logo img {
    display: inline-block;
    width: min(calc((150 / 375) * 100vw), 450px);
}
@media screen and (min-width: 1025px) {
    .curriculum01 .curriculum01__icon {
        max-width: 1010px;
        padding-left: 10px;
        margin: 0 auto 34px;
    }
    .curriculum01 .curriculum01__icon img {
        width: 137px;
    }
    .curriculum01 .curriculum01__logo {
        padding-bottom: 28px;
        margin-bottom: 42px;
    }
    .curriculum01 .curriculum01__logo img {
        width: 244px;
    }
}
.curriculum01 .curriculum01__ttl {
    margin-bottom: var(--num-40);
    font-size: var(--fz-35);
    letter-spacing: var(--ls-n05);
}
.curriculum01 .curriculum01__ttl--small {
    font-size: min(calc((25 / 375) * 100vw), 75px);
}
.curriculum01 .curriculum01__ttl .txt-angle::after {
    background: #fff;
}
@media screen and (min-width: 1025px) {
    .curriculum01 .curriculum01__ttl {
        margin-bottom: 90px;
        font-size: 50px;
    }
    .curriculum01 .txt-angle {
        font-size: 63px;
    }
    .curriculum01 .curriculum01__ttl--small {
        font-size: 35px;
    }
}
.curriculum01 .curriculum01__list {
    display: flex;
    flex-direction: column;
    gap: var(--num-20);
    counter-reset: curriculmcount;
    padding: 0;
    list-style-type: none;
}
@media screen and (min-width: 1025px) {
    .curriculum01 .curriculum01__list {
        position: relative;
        gap: 95px;
        background: url(../img/curriculum01__list-pic_pc.webp) no-repeat top right / min(calc((432 / 1200) * 100vw), 432px);
    }
    .curriculum01 .curriculum01__list-item {
        max-width: 510px;
    }
}
.curriculum01 .curriculum01__list-item::marker {
    content: none;
}
.curriculum01 .curriculum01__list-ttl {
    display: flex;
    gap: var(--num-10);
    align-items: baseline;
    padding-bottom: var(--num-10);
    margin-bottom: var(--num-12);
    background: url(../img/dotted_line.webp) repeat-x bottom center / 100%;
    counter-increment: curriculmcount;
    font-size: var(--fz-18);
}
.curriculum01 .curriculum01__list-ttl::before {
    content: counter(curriculmcount);
    background: #fff;
    width: min(calc((32 / 375) * 100vw), 96px);
    height: min(calc((32 / 375) * 100vw), 96px);
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    flex-shrink: 0;
    font-family: "Francois One", sans-serif;
}
@media screen and (min-width: 1025px) {
    .curriculum01 .curriculum01__list-ttl {
        gap: 16px;
        padding-bottom: 20px;
        margin-bottom: 20px;
        background: url(../img/dotted_line_245.webp) repeat-x bottom center / 730px;
        font-size: 30px;
    }
    .curriculum01 .curriculum01__list-ttl::before {
        width: 52px;
        height: 52px;
        font-size: 32px;
    }
}
.curriculum01 .curriculum01__list-item.item01 .curriculum01__list-pic {
    padding-bottom: var(--num-6);
}
.curriculum01 .curriculum01__list-item.item01 .curriculum01__list-pic img {
    transform: scale(1.03);
    transform-origin: top center;
}
.curriculum01 .curriculum01__list-item.item02 .curriculum01__list-pic img {
    width: min(calc((214 / 375) * 100vw), 642px);
    margin-left: auto;
}
.curriculum01 .curriculum01__list-item:not(:last-of-type) .curriculum01__list-txt {
    margin-bottom: var(--num-12);
}
@media screen and (min-width: 1025px) {
    .curriculum01 .curriculum01__list-item .curriculum01__list-txt {
        font-size: 22px;
    }
    .curriculum01 .curriculum01__list-item:not(:last-of-type) .curriculum01__list-txt {
        margin-bottom: 0;
    }
}
.curriculum01 .curriculum01__pic {
    position: relative;
}
.curriculum01 .curriculum01__pic img {
    position: relative;
    z-index: 1;
}
.curriculum01 .curriculum01__pic::after {
    content: "";
    position: absolute;
    display: block;
    width: 100%;
    height: min(calc((180 / 375) * 100vw), 540px);
    clip-path: polygon(0 81%, 100% 0, 100% 100%, 0% 100%);
    background: #605c53;
    bottom: -1px;
}
@media screen and (min-width: 1025px) {
    .curriculum01 .curriculum01__pic img {
        width: min(calc((693 / 1440) * 100vw), 693px);
        position: absolute;
        top: max(calc((224 / 1440) * -100vw), -224px);
        left: 50%;
    }
    .curriculum01 .curriculum01__pic::after {
        content: none;
    }
}
.curriculum02 {
    background: #605c53;
    color: #fff;
}
.curriculum02 .curriculum02__ttl {
    margin-bottom: var(--num-16);
    font-size: var(--fz-18);
    font-weight: 700;
}
.curriculum02 .curriculum02__txt {
    margin-bottom: var(--num-20);
}
@media screen and (min-width: 1025px) {
    .curriculum02 {
        padding-top: 52px;
        padding-bottom: 93px;
        position: relative;
    }
    .curriculum02::after {
        content: "";
        position: absolute;
        display: block;
        width: min(calc((222 / 1440) * 100vw), 444px);
        height: min(calc((480 / 1440) * 100vw), 960px);
        clip-path: polygon(100% 0, 0% 100%, 100% 100%);
        background: #f1e14a;
        bottom: -1px;
        right: 0;
    }
    .curriculum02 .curriculum02__ttl {
        margin-bottom: 52px;
        font-size: 30px;
    }
    .curriculum02 .curriculum02__txt {
        width: 660px;
        margin: 0 auto 22px;
        font-size: 22px;
    }
    .curriculum02 .curriculum02__txt:last-of-type {
        margin-bottom: 77px;
    }
}
.message02 {
    background: #f0f0f0;
    padding-top: 0;
}
@media screen and (min-width: 1025px) {
    .message02 {
        padding-bottom: 78px;
        overflow: hidden;
    }
}
.message02 .message02__catch {
    background: url(../img/message02__catch_bg.webp) no-repeat top center / cover;
    padding-top: var(--num-30);
    padding-left: var(--num-35);
    padding-right: var(--num-35);
    padding-bottom: var(--num-20);
    margin-bottom: var(--num-30);
}
@media screen and (min-width: 1025px) {
    .message02 .message02__catch {
        max-width: 1120px;
        background: none;
        padding: 0 10px 0 22px;
        margin: 0 auto 40px;
        position: relative;
    }
    .message02 .message02__catch::before {
        content: "";
        display: block;
        width: calc(((100vw - 1000px) / 2) + 1000px);
        height: 771px;
        background: url(../img/message02__catch_bg_pc.webp) no-repeat top center / cover;
        position: absolute;
        top: 0;
        left: 50px;
    }
}
.message02 .message02__ttl {
    display: flex;
    flex-direction: column;
    gap: var(--num-15);
    writing-mode: vertical-rl;
    font-size: var(--fz-20);
    line-height: 1.1;
    white-space: nowrap;
}
.message02 .message02__ttl span {
    background: #fff;
    display: block;
    height: fit-content;
    padding: 8px;
    letter-spacing: 0.1em;
}
.message02 .message02__catch-name {
    color: #fff;
    text-align: right;
    margin-top: max(calc((16 / 375) * -100vw), -48px);
}
.message02 .message02__catch-name--large {
    font-size: var(--fz-16);
}
@media screen and (min-width: 1025px) {
    .message02 .message02__ttl {
        gap: 30px;
        font-size: 41px;
        position: relative;
        z-index: 2;
    }
    .message02 .message02__ttl span {
        padding: 23px 16px 12px;
    }
    .message02 .message02__catch-name {
        margin-top: 0;
        font-size: 20px;
        position: absolute;
        bottom: 156px;
        right: 10px;
        z-index: 2;
    }
    .message02 .message02__catch-name--large {
        font-size: 25px;
    }
}
.message02 .message02__txt:not(:last-of-type) {
    margin-bottom: var(--num-20);
}
@media screen and (min-width: 1025px) {
    .message02 .message02__txt {
        width: 840px;
        margin: auto;
        font-size: 22px;
    }
    .message02 .message02__txt:not(:last-of-type) {
        margin-bottom: 36px;
    }
}
.voice {
    background: url(../img/voice_bg.webp) no-repeat top center / cover;
}
@media screen and (min-width: 1025px) {
    .voice {
        padding-top: 68px;
        padding-bottom: 100px;
        background: url(../img/voice_bg_pc.webp) no-repeat top center / cover;
        overflow: hidden;
    }
}
.voice .voice__ttl {
    margin-bottom: var(--num-6);
}
.voice .voice__subttl {
    margin-bottom: var(--num-30);
    font-size: var(--fz-20);
    line-height: var(--lh-135);
    font-weight: 700;
    text-align: center;
    letter-spacing: var(--ls-05);
}
@media screen and (min-width: 1025px) {
    .voice .voice__ttl {
        margin-bottom: 15px;
    }
    .voice .voice__subttl {
        margin-bottom: 44px;
        font-size: 25px;
    }
}
.voice .voice__list {
    display: flex;
    flex-direction: column;
    gap: min(calc((32 / 375) * 100vw), 96px);
}
.voice .voice__list-item {
    position: relative;
}
.voice .voice__list-item::after {
    content: "";
    width: 100%;
    height: 100%;
    border: 2px solid #231815;
    background: #e5e5e7;
    position: absolute;
    top: min(calc((7 / 375) * 100vw), 21px);
    left: min(calc((7 / 375) * 100vw), 21px);
    z-index: -1;
}
.voice .voice__list-box {
    padding: var(--num-15) var(--num-20) var(--num-25);
    border: 2px solid #231815;
    background: #fff;
    position: relative;
    z-index: 2;
}
.voice .voice__list-person {
    display: flex;
    align-items: flex-end;
    gap: var(--num-15);
    margin-bottom: var(--num-12);
}
.voice .voice__list-person-pic {
    flex-shrink: 0;
    width: min(calc((74 / 375) * 100vw), 222px);
    height: min(calc((74 / 375) * 100vw), 222px);
}
.voice .voice__list-person-txt {
    width: 100%;
    padding-bottom: min(calc((9 / 375) * 100vw), 27px);
    margin-bottom: var(--num-12);
    background: url(../img/dotted_line.webp) repeat-x bottom center / 100%;
}
@media screen and (min-width: 1025px) {
    .voice .voice__list {
        flex-direction: row;
        gap: min(calc((50 / 1120) * 100vw), 50px);
        margin-bottom: 70px;
    }
    .voice .voice__list-item {
        position: relative;
        width: calc(100% / 3);
    }
    .voice .voice__list-item::after {
        top: 10px;
        left: 7px;
    }
    .voice .voice__list-box {
        padding: 16px 20px 22px;
        height: 100%;
    }
    .voice .voice__list-person {
        gap: 16px;
        margin-bottom: 12px;
    }
    .voice .voice__list-person-pic {
        width: 80px;
        height: 80px;
    }
    .voice .voice__list-person-txt {
        padding-bottom: 16px;
        margin-bottom: 10px;
        background: url(../img/dotted_line_voice.webp) repeat-x bottom center / 194px;
    }
    .voice .voice__list-txt {
        font-size: 16px;
    }
}
.voice .voice__data.data01 {
    padding-top: min(calc((24 / 375) * 100vw), 72px);
    padding-bottom: var(--num-30);
    background: url(../img/voice_data01_bg.webp) no-repeat center center / 100%;
}
.voice .voice__data.data02 {
    padding-top: min(calc((26 / 375) * 100vw), 78px);
    padding-bottom: var(--num-30);
    margin-bottom: var(--num-10);
    background: url(../img/voice_data02_bg.webp) no-repeat center center / 100%;
    position: relative;
    z-index: 1;
    margin-top: max(calc((40 / 375) * -100vw), -120px);
}
.voice .voice__data-box {
    width: fit-content;
    margin: 0 auto;
    color: #fff;
    text-align: center;
    position: relative;
}
.voice .voice__data.data01 .voice__data-box {
    transform: rotate(-2.6deg);
}
.voice .voice__data.data02 .voice__data-box {
    transform: rotate(3.22deg);
}
.voice .voice__data-box::before,
.voice .voice__data-box::after {
    content: "";
    width: min(calc((38 / 375) * 100vw), 114px);
    height: min(calc((88 / 375) * 100vw), 264px);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}
.voice .voice__data-box::before {
    background-image: url(../img/voice_data_left.webp);
    right: 102%;
}
.voice .voice__data-box::after {
    background-image: url(../img/voice_data_right.webp);
    left: 100%;
}
.voice .voice__data-box span {
    line-height: 1.4;
}
.voice .voice__data.data01 .voice__data-txt02,
.voice .voice__data.data01 .voice__data-txt03,
.voice .voice__data.data02 .voice__data-txt03,
.voice .voice__data.data02 .voice__data-txt04 {
    color: #f1e14a;
}
.voice .voice__data.data01 .voice__data-txt01,
.voice .voice__data.data01 .voice__data-txt03,
.voice .voice__data.data01 .voice__data-txt04 {
    font-size: var(--fz-20);
    font-weight: 700;
    letter-spacing: var(--ls-05);
}
.voice .voice__data.data01 .voice__data-txt02 {
    font-size: min(calc((45 / 375) * 100vw), 135px);
    font-weight: 700;
    line-height: 1;
}
.voice .voice__data.data01 .voice__data-txt05 {
    font-size: var(--fz-18);
    font-weight: 500;
}
.voice .voice__data.data02 .voice__data-txt01,
.voice .voice__data.data02 .voice__data-txt04 {
    font-size: var(--fz-20);
    font-weight: 700;
    letter-spacing: var(--ls-05);
}
.voice .voice__data.data02 .voice__data-txt02 {
    font-size: var(--fz-16);
    font-weight: 500;
}
.voice .voice__data.data02 .voice__data-txt03 {
    font-size: min(calc((45 / 375) * 100vw), 135px);
    font-weight: 700;
    line-height: 1;
}
.voice .voice__data.data02 .voice__data-txt05 {
    font-size: var(--fz-18);
    font-weight: 500;
}
@media screen and (min-width: 1025px) {
    .footer {
        padding-top: 70px;
        padding-bottom: 50px;
    }
}
@media screen and (min-width: 1025px) {
    .voice__data_wrap {
        display: flex;
        width: 1120px;
        margin: auto;
    }
    .voice .voice__data.data01 {
        width: 50%;
        padding-top: 65px;
        padding-bottom: 0;
        background: url(../img/voice_data01_bg_pc.webp) no-repeat right -40px center / 799px;
        position: relative;
        right: -36px;
    }
    .voice .voice__data.data01::after {
        content: "";
        display: block;
        width: 50vw;
        height: 184px;
        background: #2fb8ab;
        position: absolute;
        right: 99%;
        bottom: 21px;
        transform: rotate(-2.6deg);
        transform-origin: center right;
    }
    .voice .voice__data.data02 {
        width: 50%;
        padding-top: 40px;
        padding-bottom: 0;
        margin-bottom: 0;
        margin-top: 0;
        background: url(../img/voice_data02_bg_pc.webp) no-repeat left -42px top / 805px;
        position: relative;
        left: -40px;
        top: 20px;
    }
    .voice .voice__data.data02::after {
        content: "";
        display: block;
        width: 50vw;
        height: 185px;
        background: #000;
        position: absolute;
        left: 99%;
        bottom: 0;
        transform: rotate(3.22deg);
        transform-origin: center left;
    }
    .voice .voice__data-box {
        padding: 0 64px;
    }
    .voice .voice__data.data01 .voice__data-box {
        transform: rotate(-2.6deg) translateY(-44px);
        margin: 0 auto 0 10px;
    }
    .voice .voice__data.data02 .voice__data-box {
        transform: rotate(3.22deg);
        margin: 0 10px 0 auto;
    }
    .voice .voice__data-box::before,
    .voice .voice__data-box::after {
        content: "";
        width: 64px;
        height: 150px;
        background-repeat: no-repeat;
        background-size: cover;
        background-position: center;
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
    }
    .voice .voice__data-box::before {
        right: calc(100% - 64px);
    }
    .voice .data02 .voice__data-box::before {
        right: calc(100% - 52px);
    }
    .voice .voice__data-box::after {
        left: calc(100% - 64px);
    }
    .voice .voice__data.data01 .voice__data-txt01,
    .voice .voice__data.data01 .voice__data-txt03,
    .voice .voice__data.data01 .voice__data-txt04 {
        font-size: 34px;
    }
    .voice .voice__data.data01 .voice__data-txt02 {
        font-size: 77px;
    }
    .voice .voice__data.data01 .voice__data-txt05 {
        font-size: 31px;
    }
    .voice .voice__data.data02 .voice__data-txt01,
    .voice .voice__data.data02 .voice__data-txt04 {
        font-size: 34px;
    }
    .voice .voice__data.data02 .voice__data-txt02 {
        font-size: 27px;
        font-weight: 500;
    }
    .voice .voice__data.data02 .voice__data-txt03 {
        font-size: 77px;
    }
    .voice .voice__data.data02 .voice__data-txt05 {
        font-size: 31px;
    }
}
@media screen and (min-width: 1025px) and (max-width: 1100px) {
    .voice .voice__data {
        transform: scale(0.9);
    }
    .voice .voice__data.data02 {
        left: -80px;
    }
}
.consultation01 {
    background: #f1e14a;
}
@media screen and (min-width: 1025px) {
    .consultation01 {
        padding-top: 68px;
        padding-bottom: 0;
    }
}
.consultation01 .consultation01__ttl {
    margin-bottom: var(--num-25);
    font-size: min(calc((24 / 375) * 100vw), 72px);
}
.consultation01 .consultation01__ttl .marker {
    background: linear-gradient(transparent 70%, #fff 70%);
}
@media screen and (min-width: 1025px) {
    .consultation01 .consultation01__ttl {
        margin-bottom: 64px;
        font-size: min(calc((45 / 1060) * 100vw), 45px);
        white-space: nowrap;
    }
    .consultation01 .consultation01__ttl .marker {
        background: linear-gradient(transparent 70%, #fff 70%);
    }
}
.consultation01 .consultation01__list {
    display: flex;
    flex-direction: column;
    margin-bottom: var(--num-15);
}
.consultation01 .consultation01__list-item {
    display: flex;
    align-items: baseline;
    gap: min(calc((7 / 375) * 100vw), 21px);
    position: relative;
    padding: min(calc((5 / 375) * 100vw), 15px);
    background: url(../img/dotted_line.webp) repeat-x bottom left / 100%;
}
.consultation01 .consultation01__list-item::before {
    content: "";
    display: block;
    width: var(--num-12);
    height: var(--num-12);
    border-radius: 50%;
    margin-top: max(calc((8 / 375) * -100vw), -9px);
    background: #fff;
    flex-shrink: 0;
}
.consultation01 .consultation01__list-item:first-of-type {
    padding-top: 0;
}
@media screen and (min-width: 1025px) {
    .consultation01 .consultation01__list {
        margin: 0 auto;
        max-width: 855px;
    }
    .consultation01 .consultation01__list-item {
        gap: 10px;
        width: fit-content;
        padding: 20px 0 16px;
        background: url(../img/dotted_line_consultation01.webp) repeat-x bottom left / 852px;
        font-size: 25px;
    }
    .consultation01 .consultation01__list-item::before {
        width: 20px;
        height: 20px;
        margin-top: 0;
    }
    .consultation01 .btn-wrap {
        position: relative;
        top: 44px;
    }
}
.consultation02 {
    background: url(../img/consultation02_bg.webp) no-repeat top center / cover;
}
@media screen and (min-width: 1025px) {
    .consultation02 {
        padding-top: 122px;
        padding-bottom: 134px;
        background: url(../img/consultation02_bg_bg.webp) no-repeat top center / cover;
    }
}
.consultation02 .consultation02__ttl {
    margin-bottom: min(calc((22 / 375) * 100vw), 66px);
}

.consultation02 .consultation02__lead {
    margin-bottom: min(calc((26 / 375) * 100vw), 78px);
    text-align: center;
    font-weight: 700;
    letter-spacing: var(--ls-05);
    font-size: var(--fz-16);
}
@media screen and (min-width: 1025px) {
    .consultation02 .consultation02__ttl {
        margin-bottom: 17px;
    }
    .consultation02 .consultation02__lead {
        margin-bottom: 56px;
        font-size: 25px;
    }
}
.consultation02 .consultation02__pic {
    margin-bottom: var(--num-20);
}
.consultation02 .consultation02__txt {
    margin-bottom: var(--num-15);
}
@media screen and (min-width: 1025px) {
    .consultation02 .consultation02__main {
        display: flex;
        align-items: center;
        margin-bottom: 42px;
        justify-content: space-between;
        position: relative;
        left: -50px;
    }
    .consultation02 .consultation02__pic {
        margin-bottom: 0;
        width: 46.5%;
    }
    .consultation02 .consultation02__txt {
        margin-bottom: 0;
        width: 48%;
        font-size: 20px;
        line-height: 1.6;
    }
}
.consultation02 .consultation02__note {
    font-size: var(--fz-12);
    font-weight: 500;
}
@media screen and (min-width: 1025px) {
    .consultation02 .consultation02__note {
        font-size: 16px;
        text-align: center;
    }
}
@media screen and (min-width: 1025px) {
    .company {
        padding-top: 76px;
        padding-bottom: 86px;
    }
}
.company .company__ttl {
    margin-bottom: var(--num-15);
}
@media screen and (min-width: 1025px) {
    .company .company__ttl {
        margin-bottom: 42px;
        margin-right: 110px;
    }
}
.company .company__overview {
    margin-bottom: min(calc((8 / 375) * 100vw), 24px);
}
.company .company__overview-item {
    display: flex;
}
.company .company__overview-item:nth-of-type(5) {
    margin-bottom: min(calc((16 / 375) * 100vw), 48px);
}
.company .company__overview-ttl {
    width: min(calc((87 / 375) * 100vw), 261px);
}
.company .company__list-item {
    display: flex;
    align-items: baseline;
    gap: min(calc((7 / 375) * 100vw), 21px);
    position: relative;
}
.company .company__list-item::before {
    content: "";
    display: block;
    width: var(--num-12);
    height: var(--num-12);
    border-radius: 50%;
    background: #f1e14a;
    flex-shrink: 0;
}
@media screen and (min-width: 1025px) {
    .company .company__overview {
        margin: 0 auto 42px;
        max-width: 690px;
    }
    .company .company__overview-item {
        display: flex;
        margin-bottom: 4px;
    }
    .company .company__overview-item:nth-of-type(5) {
        margin-bottom: 30px;
    }
    .company .company__overview-ttl {
        width: 184px;
        padding-left: 27px;
    }
    .company .company__list {
        max-width: 690px;
        margin: 0 auto;
    }
    .company .company__list-item {
        gap: 12px;
    }
    .company .company__list-item::before {
        width: 15px;
        height: 15px;
    }
}
.closing {
    background: #f1e14a;
    padding-top: var(--num-25);
    padding-bottom: var(--num-10);
}
@media screen and (min-width: 1025px) {
    .closing {
        padding-top: 80px;
        padding-bottom: 40px;
    }
}
.closing .inner {
    padding-top: 0;
}
.closing .closing__ttl {
    margin-bottom: var(--num-20);
    color: #fff;
    font-size: var(--fz-22);
    line-height: 1.1;
    letter-spacing: var(--ls-n05);
}
.closing .closing__ttl-line {
    display: block;
    width: fit-content;
    background: #000;
    padding-top: min(calc((5 / 375) * 100vw), 10px);
    padding-bottom: min(calc((5 / 375) * 100vw), 10px);
}
.closing .closing__ttl-line.line01 {
    margin-right: auto;
    margin-bottom: var(--num-10);
    padding-left: var(--num-40);
    padding-right: min(calc((22 / 375) * 100vw), 66px);
}
.closing .closing__ttl-line.line02 {
    margin-left: auto;
    padding-left: min(calc((22 / 375) * 100vw), 66px);
    padding-right: var(--num-35);
}
.closing .closing__ttl--colored {
    color: #f1e14a;
}
.closing .closing__ttl-parentheses {
    font-weight: 300;
}
@media screen and (min-width: 1025px) {
    .closing .closing__ttl {
        margin: 0 auto 44px;
        font-size: 40px;
        text-align: center;
        background: #000;
        padding-top: 10px;
        padding-bottom: 16px;
        max-width: 1000px;
    }
    .closing .closing__ttl-line {
        display: inline-block;
        width: fit-content;
        background: none;
    }
    .closing .closing__ttl-line.line01 {
        margin: 0;
        padding: 0;
    }
    .closing .closing__ttl-line.line02 {
        margin: 0;
        padding: 0;
    }
    .closing .closing__ttl--colored {
        color: #f1e14a;
    }
}
.closing .closing__txt:not(:last-of-type) {
    margin-bottom: var(--num-16);
}
@media screen and (min-width: 1025px) {
    .closing .closing__txt {
        margin-bottom: 32px;
    }
    .closing .closing__txt:not(:last-of-type) {
        margin-bottom: 32px;
    }
}
.closing .btn-wrap {
    position: relative;
    top: var(--num-40);
}
@media screen and (min-width: 1025px) {
    .closing .btn-wrap {
        position: unset;
    }
}
.faq {
    padding-top: min(calc((65 / 375) * 100vw), 195px);
}
@media screen and (min-width: 1025px) {
    .faq {
        padding-top: 67px;
        padding-bottom: 0;
    }
}
.faq .faq__ttl {
    margin-bottom: min(calc((5 / 375) * 100vw), 15px);
}
.faq .faq__subttl {
    margin-bottom: min(calc((32 / 375) * 100vw), 96px);
    text-align: center;
    font-size: var(--fz-20);
    letter-spacing: var(--ls-05);
    line-height: var(--lh-135);
}
@media screen and (min-width: 1025px) {
    .faq .faq__ttl {
        margin-bottom: 12px;
    }
    .faq .faq__subttl {
        margin-bottom: 62px;
        font-size: 25px;
    }
}
.faq .faq__list {
    display: flex;
    flex-direction: column;
    gap: var(--num-30);
    margin-bottom: var(--num-18);
}
.faq .faq__question {
    display: flex;
    align-items: baseline;
    gap: min(calc((13 / 375) * 100vw), 39px);
    padding-bottom: var(--num-12);
    margin-bottom: var(--num-12);
    background: url(../img/dotted_line.webp) repeat-x bottom center / 100%;
    font-size: var(--fz-18);
    line-height: 1.3;
    font-weight: 700;
}
.faq .faq__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: min(calc((32 / 375) * 100vw), 96px);
    height: min(calc((32 / 375) * 100vw), 96px);
    background: #f1e14a;
    flex-shrink: 0;
}
.faq .faq__icon img {
    width: min(calc((9 / 375) * 100vw), 27px);
}
@media screen and (min-width: 1025px) {
    .faq .faq__list {
        gap: 56px;
        margin-bottom: 10px;
    }
    .faq .faq__question {
        gap: 24px;
        padding-bottom: 14px;
        margin-bottom: 16px;
        background: url(../img/dotted_line_faq.webp) repeat-x bottom center / 922px;
        font-size: 30px;
    }
    .faq .faq__icon {
        width: 58px;
        height: 58px;
    }
    .faq .faq__icon img {
        width: 20px;
    }
    .faq .btn-wrap {
        position: relative;
        top: 44px;
    }
}
.footer {
    background-color: #3f3f3f;
    padding-top: 11.1111111111vw;
    padding-bottom: 11.1111111111vw;
}
@media screen and (min-width: 1025px) {
    .footer {
        padding-top: 90px;
        padding-bottom: 50px;
    }
}
.footer * {
    width: fit-content;
    margin-right: auto;
    margin-left: auto;
    color: #f1f2ed;
}
.footer .footer__logo-link {
    display: block;
    margin-bottom: 6.9444444444vw;
}
.footer .footer__logo-image {
    display: block;
    width: 38.8888888889vw;
    height: 14.5944444444vw;
    transform: translateX(-2.7777777778vw);
}
@media screen and (min-width: 1025px) {
    .footer .footer__logo-link {
        margin-bottom: 30px;
    }
    .footer .footer__logo-image {
        width: 220px;
        height: 82.56px;
        transform: translateX(-19px);
    }
}
.footer .footer__address-wrap {
    margin-bottom: 5vw;
    font-size: 2.7083333333vw;
    line-height: 2;
    letter-spacing: 0.14em;
}
@media screen and (min-width: 1025px) {
    .footer .footer__address-wrap {
        margin-bottom: 10px;
        font-size: 13px;
    }
}
.footer .footer__c-name {
    font-size: 1.15em;
}
.footer .footer__policy {
    margin-bottom: 5.5555555556vw;
    font-size: var(--fz-10);
}
@media screen and (min-width: 1025px) {
    .footer .footer__policy {
        margin-bottom: 8px;
        font-size: 13px;
    }
}
.footer .footer__copy {
    font-size: min(calc((8 / 375) * 100vw), 24px);
}
@media screen and (min-width: 1025px) {
    .footer .footer__copy {
        font-size: 10px;
    }
}
