.page-kokohai_lite-content {
    .mainvisual {
        margin-bottom: 20px;
    }
    .sr-only {
        position: absolute;
        width: 1px;
        height: 1px;
        padding: 0;
        margin: -1px;
        overflow: hidden;
        clip: rect(0, 0, 0, 0);
        border: 0;
    }
}

.page-kokohai_lite__trouble {
    margin-bottom: 28px;

    .trouble-title {
        margin-bottom: 40px;
        color: #694420;
        text-align: center;
        font-size: 1.125rem;
        font-weight: 700;
        line-height: 1.4;
    }
    .trouble-slider {
        box-sizing: border-box;
        max-width: 822px;
        height: 500px;
        padding-top: 16px;
        background: transparent url(../images/kokohai_lite/kl_sp_01.png) center 0 no-repeat;
        background-size: 822px 491px;
        margin-inline: auto;
        overflow: hidden;
    }
    .trouble-slider-cover {
        position: absolute;
        top: 0;
        left: 0;
        z-index: 10;
        width: 822px;
        height: 491px;
        pointer-events: none;
    }
    .trouble-people {
        display: grid;
        place-content: center;
        height: 307px;
        overflow: hidden;
    }
    .trouble-people img {
        object-fit: cover;
        width: auto;
        height: 307px;
        background-size: cover;
    }

    .TroubleItem__textFrame {
        display: grid;
        place-content: center;
        width: 300px;
        min-height: 76px;
        padding-top: 3px;
        margin-inline: auto;
        margin-bottom: 8px;
        background: transparent url(../images/kokohai_lite/kl_sp_03.png) center center no-repeat;
        background-size: 100% 100%;
        color: #fff;
        transition: opacity 0.3s ease;
        opacity: var(--_TroubleItem__textFrame-opacity, 0);
    }
    .TroubleItem__text {
        text-align: center;
        font-size: 1.25rem;
        font-weight: 400;
        line-height: 1.3;
    }
    .TroubleItem__image {
        width: 300px;
        aspect-ratio: 1;
        overflow: hidden;
        border-radius: 8px;

        img {
            object-fit: cover;
            width: 100%;
            height: 100%;
        }
    }

    .splide__slide {
        display: grid;
        place-content: center;
        place-items: center;
    }
    .splide__slide.is-active {
        --_TroubleItem__textFrame-opacity: 1;
    }
    .splide__arrow {
        z-index: 20;
        background: none;
    }
    .splide__arrow.splide__arrow--prev {
        left: 20px;
    }
    .splide__arrow.splide__arrow--next {
        right: 20px;
        transform: translateY(-50%) scaleX(-1);
    }
    .splide__pagination {
        bottom: 60px;
        z-index: 20;
    }
    .splide__pagination__page {
        width: 13px;
        height: 13px;
        margin: 5px;
        border: 1px solid #3E5687;
        background: #fff;
    }
    .splide__pagination__page.is-active {
        background: #3E5687;
        transform: scale(1.1);
    }
}

.page-kokohai_lite__solution {
    overflow: hidden;
    background: #55BC97;

    .solution-inner {
        position: relative;
        z-index: 1;
        max-width: 480px;
        padding: 48px 12px 64px;
        margin-inline: auto;

        &::after {
            content: "";
            position: absolute;
            top: 54px;
            right: -20px;
            z-index: 1;
            display: block;
            width: 180px;
            aspect-ratio: 950 / 607;
            background: transparent url(../images/kokohai_lite/kl_bo.png) 0 0 no-repeat;
            background-size: cover;
            rotate: 12deg;
        }
    }
    .solution-text:is(p) {
        position: relative;
        z-index: 2;
        color: #FFF;
        font-size: 1rem;
        font-weight: 400;
        line-height: 1.5;
        letter-spacing: 1px;
        text-shadow: 1px 1px 0px rgba(128, 128, 128, 0.4);
    }
    .solution-text .attention {
        display: inline-block;
        padding-right: 0.0875em;
        color: #FF0;
        font-size: 1.125rem;
    }
}

.page-kokohai_lite__feature {
    margin-top: 0;
    padding-block: 56px;

    .feature-inner {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        gap: 24px;
        margin-bottom: 40px;
    }
    .feature-triangle {
        width: 27px;
        height: 45px;
        background-color: #009A67;
        clip-path: polygon(100% 50%, 0 100%, 0 0);
        transform: translateY(calc(56px - 100%));
        rotate: 90deg;
    }
    .FeatureItem__title {
        margin-bottom: 20px;
        color: #009A67;
        text-align: center;
        font-size: 1.125rem;
        font-style: normal;
        font-weight: 700;
        line-height: 1.2; /* 116.667% */
    }
    .FeatureItem__frame {
        position: relative;
        z-index: 1;
        width: 320px;
        height: 320px;
        margin-inline: auto;
        border-radius: 28px;
        border: 4px solid #009A67;

        img {
            object-fit: cover;
            width: 100%;
            height: 100%;
            overflow: hidden;
            border-radius: 28px;
        }
    }
    .FeatureItem__text {
        box-sizing: border-box;
        position: absolute;
        display: grid;
        place-items: center;
        width: 120px;
        padding-top: 0.3em;
        margin-bottom: 0;
        aspect-ratio: 1;
        border-radius: 50%;
        background-color: #009A67;
        color: #fff;
        text-align: center;
        font-size: 0.9375rem;
        font-weight: 400;
        line-height: 1.4;
    }
    .FeatureItem__text.-text-01 {
        top: -8px;
        left: -30px;
    }
    .FeatureItem__text.-text-02 {
        bottom: -21px;
        left: 36px;
    }
    .FeatureItem__text.-text-03 {
        top: 32px;
        right: -30px;
    }
    .feature-detail {
        display: grid;
        place-content: center;
    }
    .feature-detail-link {
        box-sizing: border-box;
        display: grid;
        place-items: center;
        width: 230px;
        padding: 6px 32px 3px;
        border-radius: 9999px;
        border: 2.5px solid #33457b;
        background: #33457b;
        text-decoration: none !important;
        user-select: none;
        transition: all 0.25s ease;

        color: #fff;
        text-align: center;
        font-size: 1.375rem;
        font-weight: 400;
        line-height: 1.5;
    }
}

.page-kokohai_lite__qa {
    padding: 56px 20px;
    background: #EFEFEF;

    .qa-inner {
        box-sizing: border-box;
        max-width: 820px;
        padding: 40px 5%;
        margin-inline: auto;
        border-radius: 20px;
        background: #FFF;
    }

    .QaItem {
        padding-inline: 72px 0;
        margin-bottom: 20px;
        background: transparent url(../images/kokohai_lite/kl_qa.png) 0 0 no-repeat;
        background-size: 54px auto;
    }
    .QaItem:last-child {
        margin-bottom: 0;
    }
    .QaItem__question {
        float: none;
        margin-bottom: 10px;
        color: #707070;
        font-size: 1rem;
        font-weight: 700;
        line-height: 1.4;
    }
    .QaItem__answer {
        float: none;
        color: #009A67;
        font-weight: 400;
        line-height: 1.5;

        a {
            color: #009A67;
            text-decoration: underline;
        }

        .text-large {
            display: inline-block;
            padding-bottom: 4px;
            font-size: 1rem;
        }

        .note-ref {
            font-size: 0.875rem;
            vertical-align: top;
        }

        .note {
            font-size: 0.8125rem;
        }
    }
}

.page-kokohai_lite__actions {
    max-width: 480px;
    padding-block: 60px;
    margin-inline: auto;

    .actions-image {
        display: grid;
        place-items: center;
        width: 100%;
        max-width: 820px;
        margin-bottom: 16px;
        overflow: hidden;
    }
    .actions-image img {
        object-fit: contain;
        width: 100%;
        height: 100%;
    }
    .actions-title {
        margin-bottom: 40px;
        color: #009A67;
        text-align: center;
        font-size: 1.375rem;
        font-weight: 400;
        line-height: 1.3;
    }
    .actions-links {
        display: grid;
        gap: 24px;
    }
    .actions-link {
        box-sizing: border-box;
        align-items: center;
        background: #009a5a;
        border-radius: 4px;
        box-shadow: 0 2px 0 #006c3f;
        color: #fff;
        display: inline-flex;
        font-size: .875rem;
        justify-content: center;
        padding: 8px 2.5%;
        position: relative;
        text-align: center;
        text-decoration: none;
        transition: opacity .1s cubic-bezier(.25, .46, .45, .94);

        &::after {
            border-color: transparent transparent transparent currentcolor;
            border-style: solid;
            border-width: 4px 8px;
            box-sizing: border-box;
            content: "";
            display: block;
            height: 8px;
            position: absolute;
            right: 2%;
            top: 50%;
            transform: translateY(-50%);
            width: 16px;
        }
    }
}


/* フェードイン処理 */
.js-fade-in-item {
    opacity: 0;
    transform: translateY(50px);
    transition: opacity 0.8s ease-out, transform 0.8s ease-out;
    will-change: opacity, transform;
}

.js-fade-in-item.is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* アクセシビリティ: モーション低減設定の尊重 */
@media (prefers-reduced-motion: reduce) {
    .js-fade-in-item {
        transition: opacity 0.3s ease-out;
        transform: none;
    }
    .js-fade-in-item.is-visible {
        transform: none;
    }
}
