@charset "UTF-8";
/*!
 * File Info: setting
 * Copyright: キッズツリーハウス 内部ページテンプレート
*/
/*
 * 定数
*/
/* ---------- CSS Variables ---------- */
:root {
    /* ================================================
* カラー
* ============================================= */
    --color-sky: #8ec5ef;
    --color-mission-bg: #f0e9d3;
    /* ================================================
* フォント
* ============================================= */
    /* ================================================
* viewport
* ============================================= */
    --content-width: 1200px;
    --content-padding: 0 0;
}

/* ---------- Section Heading Component ---------- */
.section-heading {
    text-align: center;
    margin-bottom: 48px;
}

.section-heading--left {
    text-align: left;
}

.section-heading__en {
    position: relative;
    font-family: var(--font-dot);
    font-size: 64px;
    color: var(--color-blue);
    line-height: 1.1;
    letter-spacing: -0.05em;
    padding-top: 5px;
    margin-bottom: 32px;
    z-index: 1;
}

.section-heading__en::after {
    position: absolute;
    content: "";
    top: 50%;
    left: 50%;
    width: 302px;
    height: 62px;
    background: var(--color-white);
    transform: rotate(-3deg) translate(-50%, -50%);
    pointer-events: none;
    border-radius: 2px;
    z-index: -1;
}

.section-heading__en span {
    color: var(--color-orange);
}

.movie .section-heading,
.information .section-heading {
    text-align: left;
    margin-bottom: 24px;
}

.movie .section-heading .section-heading__en {
    width: 302px;
    text-align: center;
}

.information .section-heading .section-heading__en {
    width: fit-content;
    text-align: center;
}

.movie .section-heading .section-heading__en::after,
.information .section-heading .section-heading__en::after {
    background: var(--color-cream);
}

.section-heading__ja {
    font-family: var(--font-main);
    font-weight: var(--font-bold);
    font-size: 36px;
    color: var(--color-brown);
    line-height: 1.5;
    letter-spacing: 2.4px;
    margin-top: 8px;
}

/* ---------- BtnTopPrimary Component ---------- */
.btn-top-primary {
    display: inline-flex;
    align-items: center;
    gap: 0;
    cursor: pointer;
    transition: opacity 0.2s;
}

.btn-top-primary:hover {
    opacity: 0.8;
}

.btn-top-primary__circle {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    background: var(--color-red);
    border-radius: 50%;
    flex-shrink: 0;
    margin-right: 4px;
}

.btn-top-primary__circle-icon {
    width: 28px;
    height: 28px;
}

.btn-top-primary__text {
    font-family: var(--font-main);
    font-weight: var(--font-bold);
    font-size: 20px;
    color: var(--color-red);
    letter-spacing: 0.8px;
    white-space: nowrap;
}

.btn-top-primary__arrow {
    width: 24px;
    height: 24px;
    margin-left: 16px;
    flex-shrink: 0;
}

/* ---------- BtnTextLink Component ---------- */
.btn-text-link {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    font-family: var(--font-main);
    font-weight: var(--font-bold);
    font-size: 20px;
    color: var(--color-brown);
    letter-spacing: 1.2px;
    cursor: pointer;
    transition: opacity 0.2s;
}

.btn-text-link:hover {
    opacity: 0.8;
}

.btn-text-link--red {
    color: var(--color-red);
}

.btn-text-link__arrow {
    width: 24px;
    height: 24px;
    flex-shrink: 0;
}

/* ---------- Button Component ---------- */
.btn {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    width: fit-content;
    padding-right: 16px;
    border-radius: 50px;
    font-family: var(--font-main);
    font-weight: var(--font-bold);
    font-size: 16px;
    color: var(--color-red);
    cursor: pointer;
    border: none;
    z-index: 1;
}

.btn-arrow {
    display: grid;
    place-content: center;
    flex-shrink: 0;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background-color: var(--color-red);
}

.btn-arrow img {
    width: 20px;
    height: auto;
}

.btn * {
    z-index: 1;
}

.btn span {
    white-space: nowrap;
}

.btn::before {
    position: absolute;
    content: "";
    top: 0;
    left: 0;
    width: 64px;
    height: 64px;
    border-radius: 32px;
    background-color: var(--color-red);
    transition: all 0.2s;
    z-index: 0;
}

.btn:hover {
    color: var(--color-white);
}

.btn:hover::before {
    width: 100%;
}

/* ぴょこんアニメ */
.pyokonAnime {
    animation-fill-mode: both;
    animation-duration: 0.2s;
    animation-delay: 0;
    animation-name: pyokonAnime;
    visibility: visible !important;
}

.pyokonAnime2 {
    animation-fill-mode: both;
    animation-duration: 0.2s;
    animation-delay: 0.4s;
    animation-name: pyokonAnime;
    visibility: visible !important;
}

.pyokonAnime3 {
    animation-fill-mode: both;
    animation-duration: 0.2s;
    animation-delay: 0.2s;
    animation-name: pyokonAnime;
    visibility: visible !important;
}

@keyframes pyokonAnime {
    0% {
        transform: translateY(0);
    }

    100% {
        transform: translateY(-20px);
    }
}

/* ================================================
   FV / HERO
   ================================================ */

/* ========== KV (Hero) ========== */
.mv {
    overflow: hidden;
    padding: 156px 20px 50px 40px;
    background: url(../images/png/kv-bg2560.jpg) no-repeat center center/cover;
}

.mv__container {
    position: relative;
    width: 100%;
    align-items: start;
}

/* Award badge */
.mv__award {
    position: absolute;
    top: -14px;
    right: 0;
}

/* Scene */
.mv__scene {
    position: relative;
    display: flex;
    width: 100vw;
    padding-top: 16px;
}

.mv__scene-img {
    /* max-width: clamp(1210px, 100%, 980px); */
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.mv_kid1 {
    position: absolute;
    bottom: 15.702vw;
    left: 41.653vw;
    width: 3.451vw;
    height: 4.046vw;
    animation: rotateAnime 0.8s ease-in-out infinite alternate;
}

.mv_kid2 {
    position: absolute;
    bottom: 15.702vw;
    left: 46.413vw;
    width: 3.333vw;
    height: 3.273vw;
}
.mv_kid3 {
    position: absolute;
    bottom: 19.752vw;
    left: 43.081vw;
    width: 3.333vw;
    height: 6.665vw;
    animation: runAnime 0.8s ease-in-out infinite alternate;
}
.mv_kid4 {
    position: absolute;
    bottom: 21.66vw;
    left: 46.77vw;
    width: 7.498vw;
    height: 5.474vw;
}
.mv_kid5 {
    position: absolute;
    bottom: 13.329vw;
    right: 37.369vw;
    width: 3.689vw;
    height: 9.283vw;
    animation: junpAnime 1s ease-out infinite alternate;
}
.mv_kid6 {
    position: absolute;
    bottom: 16.899vw;
    right: 31.775vw;
    width: 4.046vw;
    height: 5.236vw;
}
.mv_kid7 {
    position: absolute;
    bottom: 16.185vw;
    right: 24.397vw;
    width: 5.831vw;
    height: 7.498vw;
    animation: rotateAnime 0.8s ease-in-out infinite alternate;
}

@keyframes junpAnime {
    0% {
        transform: translateY(0);
    }

    100% {
        transform: translateY(-10px);
    }
}

@keyframes rotateAnime {
    0% {
        transform: rotate(3deg);
    }

    100% {
        transform: rotate(-3deg);
    }
}

@keyframes runAnime {
    0% {
        transform: translate(0, 0) rotate(3deg);
    }

    100% {
        transform: translate(-5px, 5px) rotate(-3deg);
    }
}

/* Look buttons */
.lookbtn {
    position: absolute;
    width: 56px;
    height: 58px;
    background: transparent;
    border: 0;
    cursor: pointer;
    transition:
        transform 0.2s ease,
        box-shadow 0.2s ease;
}

.lookbtn:first-of-type {
    top: -6%;
    left: 68.7%;
}

.lookbtn:nth-of-type(2) {
    top: 20%;
    left: 43%;
}

.lookbtn:nth-of-type(3) {
    top: 17%;
    left: 69%;
}
.lookbtn:nth-of-type(4) {
    top: 31%;
    left: 39%;
}

.lookbtn:last-of-type {
    top: 7%;
    left: 55%;
}

.lookbtn img {
    width: 100%;
    height: 100%;
    display: block;
}
.lookbtn::before,
.lookbtn::after {
    content: none;
}
.lookbtn:hover {
    transform: translatey(-4px) scale(1.08);
}

/* Card */
.pickup-card {
    position: absolute;
    top: 0;
    left: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    max-width: 427px;
    text-align: center;
    background: var(--color-white);
    border-radius: 20px;
    box-shadow: 2px 4px 4px rgba(0, 0, 0, 0.15);
    padding: 24px 32px;
    z-index: 1;
}

.mv__card.active {
    display: none;
    transition: all 0.2s;
}

.mv__card-icon img {
    position: relative;
    width: 100%;
    max-width: 220px;
    height: auto;
    margin-bottom: 8px;
}

.mv__card-tag {
    margin: 0;
    color: var(--color-red);
    font-family: var(--font-daruma);
    font-size: 24px;
    letter-spacing: 0.1em;
    line-height: 1.2;
}

.mv__card-title {
    margin: 4px 0 8px;
    color: var(--color-red);
    font-family: var(--font-daruma);
    font-weight: 400;
    letter-spacing: 0.08em;
    line-height: 1.2;
}
.mv__card-title-lg {
    font-size: 48px;
}
.mv__card-title-sm {
    font-size: 36px;
}
.mv__card-desc {
    margin: 8px 0 0;
    letter-spacing: 0.03em;
    text-align: left;
}

/* ========== Pickup Card ========== */
.lookbtn + .pickup-card {
    display: none;
}
.lookbtn.active + .pickup-card {
    display: block;
}

/* --- head (tag + title) --- */
.pickup-card__head {
    display: flex;
    flex-direction: column;
    width: 100%;
}

.pickup-card__tag {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    height: 58px;
    width: 100%;
}

/* 斜めに流れた下敷き（擬似要素） */
.pickup-card__tag::before {
    content: "";
    position: absolute;
    left: 50%;
    top: 50%;
    width: 304px;
    height: 34px;
    transform: translate(-50%, -50%) rotate(-3deg);
    background: var(--color-bg1, var(--color-cream));
    border-radius: 2px;
    z-index: -1;
    pointer-events: none;
}

.pickup-card__bino {
    position: relative;
    z-index: 1;
    width: 44px;
    height: 30px;
    flex-shrink: 0;
}

.pickup-card__tag-text {
    position: relative;
    z-index: 1;
    color: var(--color-red);
    font-weight: var(--font-bold);
    font-size: 18px;
    text-align: left;
    line-height: 1.4;
    letter-spacing: 0.08em;
}

.pickup-card__title {
    margin: 0;
    width: 100%;
    color: var(--color-red);
    font-family: var(--font-daruma);
    font-weight: 400;
    font-size: 56px;
    line-height: 1.2;
    letter-spacing: 0.08em;
    text-align: center;
}

/* --- image --- */
.pickup-card__img {
    width: 100%;
    margin: 0;
    aspect-ratio: 417 / 271;
    overflow: hidden;
    border-radius: 8px;
    background: #eee;
}
.pickup-card__img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

/* --- description --- */
.pickup-card__desc {
    margin: 0;
    color: var(--color-dark);
    font-family: var(--font-main);
    font-weight: var(--font-nomal);
    font-size: 16px;
    line-height: 1.6;
    letter-spacing: 0.03em;
    text-align: left;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    overflow: hidden;
    text-overflow: ellipsis;
    padding: 4px 0;
}

/* --- more button --- */
.pickup-card__btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: 8px 16px;
    background: var(--color-red);
    color: var(--color-white);
    font-family: var(--font-daruma);
    font-size: 24px;
    line-height: 1.2;
    letter-spacing: 0.1em;
    text-align: center;
    border-radius: 4px;
    transition:
        opacity 0.2s ease,
        transform 0.2s ease;
}
.pickup-card__btn:hover {
    opacity: 0.88;
    transform: translateY(-1px);
}

/* ========== Responsive ========== */
@media (max-width: 767px) {
    .pickup-card {
        padding: 20px 20px;
        border-radius: 16px;
    }
    .pickup-card__tag {
        height: auto;
        min-height: 52px;
        padding-block: 6px;
    }
    .pickup-card__tag::before {
        width: 92%;
        height: 30px;
    }
    .pickup-card__tag-text {
        font-size: 15px;
    }
    .pickup-card__bino {
        width: 38px;
        height: 26px;
    }
    .pickup-card__title {
        font-size: 42px;
    }
    .pickup-card__desc {
        font-size: 14px;
    }
    .pickup-card__btn {
        font-size: 20px;
    }
}

@media (max-width: 400px) {
    .pickup-card {
        padding: 18px 18px;
    }
    .pickup-card__title {
        font-size: 36px;
    }
    .pickup-card__tag-text {
        font-size: 14px;
    }
}

/* ========== Responsive ========== */
@media (min-width: 1440px) {
    .mv__container {
        width: 1210px;
        margin-left: auto;
        margin-right: auto;
    }
    .mv__scene {
        width: 1210px;
        margin-left: auto;
        margin-right: auto;
    }

    .mv_kid1 {
        bottom: 190px;
        left: 504px;
        width: 41.76px;
        height: 48.96px;
    }

    .mv_kid2 {
        bottom: 190px;
        left: 561.6px;
        width: 40.32px;
        height: 39.6px;
    }
    .mv_kid3 {
        bottom: 239px;
        left: 521.28px;
        width: 40.32px;
        height: 80.64px;
    }
    .mv_kid4 {
        bottom: 262.08px;
        left: 565.92px;
        width: 90.72px;
        height: 66.24px;
    }
    .mv_kid5 {
        bottom: 161.28px;
        right: 452.16px;
        width: 44.64px;
        height: 112.32px;
    }
    .mv_kid6 {
        bottom: 204.48px;
        right: 384.48px;
        width: 48.96px;
        height: 63.36px;
    }
    .mv_kid7 {
        bottom: 195.84px;
        right: 295.2px;
        width: 70.56px;
        height: 90.72px;
    }
}

/* Tablet (~1199px) */
@media (max-width: 1199px) {
    .mv__container {
        padding-bottom: 40px;
    }
    .mv__card,
    .pickup-card {
        max-width: 380px;
    }
    .mv__card-title-lg {
        font-size: 38px;
    }
    .mv__card-title-sm {
        font-size: 28px;
    }
    .mv__card-icon {
        width: 180px;
        height: 192px;
    }
}

@media (max-width: 980px) {
    /* .mv {
        height: auto;
    } */
    .mv__container {
        padding-bottom: 350px;
    }

    .pickup-card {
        top: auto;
        bottom: -330px;
        width: 380px;
        max-width: none;
        padding: 20px 20px 24px;
        margin-top: -170px;
    }

    .mv__award {
        top: -44px;
    }
}

/* Mobile (~767px) */
@media (max-width: 767px) {
    .mv {
        padding: 200px 20px 50px 20px;
    }
    .mv__container {
        padding-bottom: 330px;
        width: 200%;
        transform: translateX(-34%);
    }

    .mv__scene {
        width: 100%;
    }

    .mv_kid1 {
        bottom: 32.5%;
        left: 42%;
        width: 3.024%;
        height: auto;
    }

    .mv_kid2 {
        bottom: 33%;
        left: 46.5%;
        width: 3.405%;
        height: auto;
    }

    .mv_kid3 {
        bottom: 40%;
        left: 43%;
        width: 3.1%;
        height: auto;
    }

    .mv_kid4 {
        bottom: 45%;
        left: 47.4%;
        width: 6.55%;
        height: auto;
    }

    .mv_kid5 {
        bottom: 27%;
        right: 37%;
        width: 3.85%;
        height: auto;
    }

    .mv_kid6 {
        bottom: 35%;
        right: 32%;
        width: 3.65%;
        height: auto;
    }

    .mv_kid7 {
        bottom: 32.8%;
        right: 24.5%;
        width: 5.5%;
        height: auto;
    }

    .pickup-card {
        width: 100%;
        max-width: 50%;
        left: 34%;
        margin-top: -90px;
    }

    .pickup-card {
        bottom: -350px;
    }

    .mv__card-icon {
        width: 160px;
        height: 170px;
        max-width: 70%;
    }
    .mv__card-tag {
        font-size: 20px;
    }
    .mv__card-title-lg {
        font-size: 34px;
    }
    .mv__card-title-sm {
        font-size: 26px;
    }
    .mv__card-desc {
        font-size: 14px;
    }

    .mv__award {
        top: -120px;
        right: 16%;
    }
}

/* ~375px */
@media (max-width: 400px) {
    .mv__card-title-lg {
        font-size: 28px;
    }
    .mv__card-title-sm {
        font-size: 22px;
    }
    .pickup-card {
        padding: 16px 16px 20px;
    }
}

/* ========== Childcare Banner ========== */
.banner-wrapper {
    display: flex;
    justify-content: flex-end;
    padding: 22px 30px 0;
    padding-right: 30px;
    background: var(--color-mission-bg) url(../images/png/bg-object-l.png)
        no-repeat left center/contain;
}
.childcare-banner {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 35px;
    width: fit-content;
    min-height: 105px;
    padding: 0 40px;
    background: var(--color-white);
    border-radius: 12px;
    font-family: var(--font-main);
    text-decoration: none;
    transition:
        box-shadow 0.2s ease,
        transform 0.2s ease;
}
.childcare-banner:hover {
    box-shadow: 2px 4px 10px rgba(0, 0, 0, 0.08);
    transform: translateY(-1px);
}

/* 左側のはみ出す写真 */
.childcare-banner__img {
    top: -22px;
    left: 37.5px;
    width: 132px;
    height: 121px;
    margin-top: -30px;
    margin-bottom: 10px;
    overflow: hidden;
    pointer-events: none;
}
.childcare-banner__img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

/* 右側テキスト群 */
.childcare-banner__body {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
}

.childcare-banner__en {
    margin: 0;
    font-family: var(--font-dot);
    font-size: 20px;
    line-height: 1.2;
    letter-spacing: 0.08em;
    color: var(--color-blue);
}
.childcare-banner__en-last {
    color: var(--color-red);
}

.childcare-banner__row {
    display: flex;
    align-items: center;
    gap: 16px;
}
.childcare-banner__ja {
    margin: 0;
    color: var(--color-blue);
    font-family: var(--font-main);
    font-weight: var(--font-bold);
    font-size: 20px;
    line-height: 1.6;
    letter-spacing: 0.08em;
    white-space: nowrap;
}
.childcare-banner__arrow {
    flex-shrink: 0;
    width: 24px;
    height: 24px;
    display: inline-grid;
    place-items: center;
    transition: transform 0.2s ease;
}
.childcare-banner__arrow svg {
    width: 100%;
    height: 100%;
}
.childcare-banner:hover .childcare-banner__arrow {
    transform: translateX(2px);
}

/* ========== Responsive ========== */
@media (max-width: 767px) {
    .childcare-banner {
        gap: 16px;
        padding: 0 20px;
        min-height: 88px;
        /* max-width: none; */
    }
    .childcare-banner__img {
        top: -16px;
        left: 16px;
        width: 100px;
        height: 92px;
    }
    .childcare-banner__en {
        font-size: 16px;
    }
    .childcare-banner__ja {
        font-size: 16px;
    }
    .childcare-banner__arrow {
        width: 22px;
        height: 22px;
    }
}

@media (max-width: 400px) {
    .childcare-banner {
        justify-content: center;
        padding: 0 16px;
        min-height: 80px;
        width: 100%;
    }
    .childcare-banner__img {
        width: 80px;
        height: 74px;
        left: 12px;
    }
    .childcare-banner__ja {
        font-size: 14px;
    }
    .childcare-banner__row {
        gap: 10px;
    }
}

/* ================================================
   SEPARATOR
   ================================================ */

/* ---------- Wave Separator ---------- */
.wave-separator.white {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
}
.wave-separator.grass-left,
.wave-separator.grass-right,
.wave-separator.kids {
    position: relative;
    z-index: 1;
}

.wave-separator.grass-left::after,
.wave-separator.grass-right::after,
.wave-separator.kids::before,
.wave-separator.kids::after {
    position: absolute;
    content: "";
    background-repeat: no-repeat;
    background-position: center center;
    background-size: contain;
}

.wave-separator.grass-left::after {
    top: -13vw;
    left: 0;
    width: 33vw;
    height: 26vw;
    background-image: url(../images/png/bg-object-kids.png);
}

.wave-separator.grass-right::after {
    top: 0;
    right: 0;
    width: 38vw;
    height: 15vw;
    background-image: url(../images/png/bg-object-r.png);
}

.wave-separator.kids::before {
    top: 0.6vw;
    left: 11.3vw;
    width: clamp(136px, 21vw, 311px);
    height: clamp(101px, 16vw, 232px);
    transform: rotate(-9.8deg);
    background-image: url(../images/png/bg_kids.png);
    z-index: 2;
}

.wave-separator.kids::after {
    top: 7.4vw;
    left: 6.9vw;
    width: clamp(305px, 52vw, 749px);
    height: clamp(93px, 16vw, 230px);
    background-image: url(../images/svg/news-bg1.svg);
    z-index: 1;
}

/* ================================================
   MISSION SECTION
   ================================================ */
.mission {
    background: var(--color-mission-bg);
    padding: 64px 0 20px;
}

.mission__inner {
    /* max-width: var(--content-width); */
    margin: 0 auto;
    /* padding: var(--content-padding); */
    position: relative;
    z-index: 1;
}

.mission__cards {
    display: flex;
    gap: 40px;
    justify-content: center;
    margin-top: 48px;
    flex-wrap: wrap;
}

.mission__card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    max-width: 374px;
    max-height: 374px;
    width: 26vw;
    height: 26vw;
    box-shadow: 2px 4px 4px rgba(0, 0, 0, 0.1);
    background: var(--color-white);
    padding: 32px 24px 24px;
    margin-top: 20px;
}

.mission__card--pink {
    transform: rotate(-7deg);
}

.mission__card--orange {
    transform: rotate(0deg);
}

.mission__card--green {
    transform: rotate(7deg);
}

.mission__card-photo {
    margin-top: -70px;
}

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

.mission__card-label {
    font-family: var(--font-daruma);
    font-size: clamp(3rem, 5.4vw, 5rem);
    letter-spacing: 0.08em;
    line-height: 1;
}

.mission__card--pink .mission__card-label {
    color: #d381ab;
}

.mission__card--orange .mission__card-label {
    color: var(--color-orange);
}

.mission__card--green .mission__card-label {
    color: var(--color-green);
}

.mission__bg-deco {
    position: absolute;
    right: -80px;
    bottom: -40px;
    width: 340px;
    opacity: 0.35;
    pointer-events: none;
}

/* ================================================
   MISSION MESSAGE
   ================================================ */
.mission-msg {
    position: relative;
    background: url(../images/png/mission-bottom-bg.png) no-repeat top
        center/cover var(--color-cream);
    padding: 120px 0 130px;
}

.mission-msg__inner {
    max-width: var(--content-width);
    margin: 0 auto;
    padding: var(--content-padding);
    display: flex;
    flex-direction: column;
    gap: 64px;
    align-items: center;
}

.mission-msg__text-col {
    max-width: 600px;
}

.mission-msg__title {
    color: var(--color-blue);
    font-family: var(--font-daruma);
    font-size: 3rem;
    line-height: 1.4;
    letter-spacing: 0.08em;
    text-align: center;
}

.mission-msg p {
    line-height: 1.8;
    margin-bottom: 40px;
    text-align: center;
}

.mission-msg p:last-of-type {
    margin-bottom: 0;
}

.mission-msg__highlight {
    font-weight: var(--font-bold);
    color: var(--color-red);
    background-color: var(--color-white);
}

/* ================================================
   FEATURE CARDS (horizontal scroll)
   ================================================ */
.features {
    padding: 64px 0;
}

.features__scroll-wrap {
    display: flex;
    overflow: hidden;
    gap: 80px;
}

.features__scroll-wrap ul:last-of-type {
    margin-right: 80px;
}

.features__track {
    display: flex;
    gap: 80px;
    width: max-content;
    margin: 0;
    padding: 0;
    list-style: none;
}

.feature-card {
    display: flex;
    flex-direction: column;
    width: 373px;
    height: 455px;
    overflow: hidden;
    transition: all 0.2s;
}

.feature-card:nth-of-type(2n) .feature-card__img {
    order: 2;
}

.feature-card:nth-of-type(2n) .feature-card__img {
    order: 1;
}

.feature-card:nth-of-type(1),
.feature-card:nth-of-type(4) {
    --card-label-color: #e37b6d;
}

.feature-card:nth-of-type(2),
.feature-card:nth-of-type(5) {
    --card-label-color: #f79054;
}

.feature-card:nth-of-type(3),
.feature-card:nth-of-type(6) {
    --card-label-color: #3a84c8;
}

.feature-card:nth-of-type(1) .feature-card__label-box,
.feature-card:nth-of-type(4) .feature-card__label-box {
    background: #ffeeec;
}

.feature-card:nth-of-type(2) .feature-card__label-box,
.feature-card:nth-of-type(5) .feature-card__label-box {
    background: #fbf7e7;
}

.feature-card:nth-of-type(3) .feature-card__label-box,
.feature-card:nth-of-type(6) .feature-card__label-box {
    background: #e4f0fc;
}

.feature-card:nth-of-type(1) .feature-card__label-box {
    margin-top: -20px;
}

.feature-card:nth-of-type(2) .feature-card__label-box {
    margin-bottom: -79px;
    margin-top: 15px;
}

.feature-card:nth-of-type(3) .feature-card__label-box {
    margin-top: -90px;
}

.feature-card:nth-of-type(4) .feature-card__label-box {
    margin-bottom: -19px;
    margin-top: 15px;
}

.feature-card:nth-of-type(5) .feature-card__label-box {
    margin-top: -67px;
}

.feature-card:nth-of-type(6) .feature-card__label-box {
    margin-bottom: -55px;
    margin-top: 15px;
}

.feature-card__img {
    width: 100%;
}

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

.feature-card__label-box {
    width: 330px;
    transform: rotate(-6deg);
    padding: 16px 16px 20px;
    margin: 0 auto;
    border-radius: 8px;
}

.feature-card__label {
    font-family: var(--font-daruma);
    font-weight: 400;
    font-size: 2.25rem;
    color: var(--card-label-color, #333);
    text-align: center;
    letter-spacing: 2px;
    line-height: 1.3;
    margin-bottom: 8px;
}

.feature-card__sub {
    font-family: var(--font-main);
    font-weight: var(--font-nomal);
    color: var(--color-brown);
    text-align: center;
    letter-spacing: 0.3px;
    line-height: 1.5;
}

/* 無限スクロール */
.scroll-infinity__list--left {
    animation: infinity-scroll-left 80s infinite linear 0.5s both;
}

@keyframes infinity-scroll-left {
    from {
        transform: translateX(0);
    }
    to {
        transform: translateX(-100%);
    }
}

/* ================================================
   ABOUT SECTION
   ================================================ */
.about {
    position: relative;
    background: var(--color-blue-bg);
    padding: 24px 0;
    z-index: 0;
}

.about::before {
    position: absolute;
    content: "";
    bottom: -20px;
    left: 50%;
    transform: translateX(-50%);
    width: 90%;
    height: 7.2vw;
    background: url(../images/svg/deco_draw.svg) no-repeat left bottom/contain;
    z-index: -1;
}

.about::after {
    position: absolute;
    content: "";
    bottom: -20px;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    height: 7.2vw;
    background: url(../images/svg/deco_draw.svg) no-repeat 75% bottom/contain;
    z-index: -1;
}

.about__inner {
    max-width: var(--content-width);
    margin: 0 auto;
    padding: var(--content-padding);
}

.about__header {
    margin-bottom: 48px;
}

.about__header .section-heading {
    margin-bottom: 12px;
    text-align: left;
    flex-shrink: 0;
}

.about__header .section-heading .section-heading__en {
    width: 302px;
    text-align: center;
}

.about__cards {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
}

.about-card {
    display: block;
    transition:
        transform 0.2s,
        box-shadow 0.2s;
}

.about-card:nth-of-type(1),
.about-card:nth-of-type(4) {
    margin-top: 40px;
}

.about-card:hover .about-card__img {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.14);
}

.about-card__img {
    width: 100%;
    border-radius: 12px;
    overflow: hidden;
}

.about-card__img img {
    width: 100%;
    height: 100%;
    min-height: 151px;
    object-fit: cover;
}

.about-card__footer {
    position: relative;
    display: block;
    padding: 16px 24px;
}

.about-card__footer::after {
    position: absolute;
    content: "";
    top: 50%;
    transform: translateY(-50%);
    right: 24px;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: url(../images/svg/chevron-right.svg) no-repeat center / 75%;
    background-color: var(--color-red);
}

.about-card__label {
    font-family: var(--font-main);
    font-weight: var(--font-bold);
    font-size: 1rem;
    color: var(--color-brown);
    letter-spacing: 1px;
}

.about__building-image {
    position: relative;
    display: block;
    width: 70%;
    margin: -2vw auto -8vw;
}

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

.about__kids1-image {
    position: absolute;
    bottom: 0.6vw;
    left: 4.2vw;
    width: 6.6vw;
    height: 13.9vw;
}

.about__kids2-image {
    position: absolute;
    bottom: -1.3vw;
    right: 3.1vw;
    width: 10vw;
    height: 12vw;
    transform: rotate(2.059deg);
}

/* ================================================
   MOVIE SECTION
   ================================================ */
.movie {
    padding: 60px 0 80px;
}

.movie__inner {
    max-width: var(--content-width);
    margin: 57px auto 0;
    padding: var(--content-padding);
    display: flex;
    justify-content: center;
    gap: 72px;
    align-items: flex-start;
}

.movie__wrapper {
    position: relative;
    width: 54.5vw;
    max-width: 786px;
}

.movie__wrapper::before {
    position: absolute;
    content: "";
    top: -9vw;
    left: 50%;
    width: 10.4vw;
    height: 9.1vw;
    transform: translateX(-33%);
    background: url(../images/svg/videoHead.svg) no-repeat center center/100%
        100%;
}

.movie__player {
    position: relative;
    background: #619bd1;
    border-radius: 48px;
    padding: 48px;
    max-width: 786px;
    width: 100%;
}

/* tab */
.movie__tabs {
    position: relative;
    display: flex;
    gap: 16px;
    padding: 0 60px;
    margin-top: 24px;
}
.movie__tabs::before {
    position: absolute;
    content: "";
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    width: 50px;
    height: 50px;
    background-color: var(--color-orange);
    border-radius: 50%;
}

.movie__tabs::after {
    position: absolute;
    content: "";
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    width: 50px;
    height: 50px;
    background-color: var(--color-orange);
    border-radius: 50%;
}

.movie__tab {
    width: 50%;
}

.tab-label {
    display: block;
    flex: 1;
    width: 100%;
    background: #619bd1;
    border: solid 2px var(--color-white);
    border-radius: 50px;
    padding: 13px;
    cursor: pointer;
    font-weight: var(--font-bold);
    font-size: 1rem;
    color: var(--color-white);
    text-align: center;
    transition: background 0.2s;
    transition: all 0.2s;
}

.tab-label:hover {
    transform: scale(1.04);
}

.tab.active .tab-label {
    background-color: var(--color-white);
    color: #619bd1;
}

.content {
    display: none; /*必須*/
}

.content.show {
    display: block; /*必須*/
}

/* 選択されたタブの見た目 */

.movie__video-wrap {
    position: relative;
    border-radius: 14px;
    overflow: hidden;
    width: 100%;
    aspect-ratio: 16/9;
}

.movie__video-wrap iframe {
    width: 100%;
    height: 100%;
}

/* ================================================
   LIKE A HOME
   ================================================ */
.likehome {
    background: var(--color-cream);
    padding: 80px 0;
}
.likehome__inner {
    max-width: var(--content-width);
    margin: 0 auto;
    padding: var(--content-padding);
    display: flex;
    flex-direction: column;
    gap: 48px;
}
.likehome__top {
    display: flex;
    flex-wrap: wrap;
    gap: 40px;
    align-items: flex-start;
}
.likehome__left {
    flex: 1;
    min-width: 300px;
    display: flex;
    flex-direction: column;
    gap: 20px;
}
.likehome__logo-icon {
    width: 64px;
    height: auto;
}
.likehome__title {
    font-family: var(--font-main);
    font-weight: var(--font-bold);
    font-size: clamp(1.5rem, 3vw, 2.5rem);
    color: var(--color-brown);
    line-height: 1.6;
    letter-spacing: 3px;
}
.likehome__deco-title {
    font-family: var(--font-dot);
    font-size: clamp(2rem, 4vw, 4rem);
    color: #ab8871;
    letter-spacing: -0.05em;
    line-height: 1.1;
}
.likehome__body {
    font-size: 15px;
    line-height: 1.8;
    color: var(--color-dark);
    letter-spacing: 0.6px;
    max-width: 680px;
}
.likehome__right {
    flex-shrink: 0;
    width: clamp(343px, 33vw, 477px);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
}

.likehome-title-image {
    width: 80%;
}

.likehome__family-photo {
    width: 100%;
    display: block;
    border-radius: 12px;
}

.likehome__feature-cards {
    display: flex;
    gap: clamp(32px, 2.7vw, 40px) clamp(16px, 2.7vw, 40px);
    justify-content: center;
    flex-wrap: wrap;
}
.likehome__feature-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
    background: transparent;
    width: clamp(163px, 18vw, 270px);
    cursor: pointer;
    transition: opacity 0.2s;
    border-radius: 12px;
}
.likehome__feature-card:hover {
    opacity: 0.8;
}

.likehome__feature-circle {
    width: clamp(163px, 15vw, 222px);
    height: clamp(163px, 15vw, 222px);
}

.likehome__feature-bottom {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    width: 100%;
    height: stretch;
}

.likehome__feature-label {
    position: relative;
    font-family: var(--font-main);
    font-weight: var(--font-bold);
    font-size: 18px;
    color: var(--color-brown);
    letter-spacing: 1px;
    line-height: 1.5;
    text-align: left;
}

/* ================================================
   INFORMATION
   ================================================ */
.information {
    background: #fff;
    padding: 80px 0;
}

.information__inner {
    max-width: var(--content-width);
    margin: 0 auto;
    padding: var(--content-padding);
    display: flex;
    gap: 40px;
    align-items: center;
}

.information__photo {
    flex-shrink: 0;
    width: calc(50% - 20px);
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 6px 24px rgba(0, 0, 0, 0.1);
}

.information__photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.information__content {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.information__content .section-heading {
    margin-bottom: 0;
}

.information__text {
    font-size: 16px;
    color: var(--color-dark);
    line-height: 1.8;
    letter-spacing: 0.48px;
}

/* ================================================
   NEWS
   ================================================ */
.news {
    background: var(--color-blue-bg);
    padding: 80px 0;
    overflow: hidden;
    position: relative;
}

.news__inner {
    max-width: var(--content-width);
    margin: 0 auto;
    padding: var(--content-padding);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 32px;
}

.news__title-area {
    width: 100%;
}

.news__title-area .section-heading {
    margin-bottom: 0;
}

.news__box {
    position: relative;
    background: #fff;
    border-radius: 20px;
    padding: 64px;
    width: 100%;
    max-width: 786px;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
    z-index: 0;
}

.news__box::after {
    position: absolute;
    content: "";
    width: clamp(224px, 32.1vw, 463px);
    height: clamp(201px, 28.8vw, 415px);
    bottom: -4.6vw;
    right: -18.2vw;
    background: url(../images/svg/news-bg2.svg) no-repeat center center/contain;
    z-index: -1;
}

.news__list {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.news__item {
    border-bottom: 1px solid #dae6eb;
    padding-bottom: 12px;

    &::before {
        display: none;
    }
}

.news__item:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.news__link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    transition: opacity 0.2s;
}

.news__link:hover {
    opacity: 0.75;
}

.news__item-info {
    display: flex;
    flex-direction: column;
    gap: 5px;
    flex: 1;
    min-width: 0;
}

.news__item-meta {
    display: flex;
    align-items: center;
}

.news__date {
    font-family: var(--font-main);
    font-weight: var(--font-nomal);
    font-size: 16px;
    color: var(--color-dark);
    letter-spacing: 0.48px;
    flex-shrink: 0;
    width: 110px;
}

.news__category {
    font-family: var(--font-main);
    font-weight: var(--font-nomal);
    font-size: 14px;
    padding: 4px 16px;
    border-radius: 4px;
    white-space: nowrap;
    flex-shrink: 0;
}

.news__category--info {
    background: var(--color-cream);
    color: var(--color-blue);
}

.news__category--letter {
    background: var(--color-cream);
    color: var(--color-blue);
}

.news__title {
    font-family: var(--font-main);
    font-weight: var(--font-bold);
    font-size: 16px;
    color: var(--color-dark);
    letter-spacing: 0.96px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.news__arrow {
    width: 24px;
    height: 24px;
    flex-shrink: 0;
}

.news__more-wrap {
    display: flex;
    justify-content: center;
    width: 100%;
}

/* ================================================
   RECRUIT
   ================================================ */
.recruit {
    background: #fff;
    padding: 40px 0;
}

.recruit__inner {
    max-width: var(--content-width);
    margin: 0 auto;
    padding: var(--content-padding);
    display: flex;
    justify-content: center;
}

.recruit__banner {
    width: 580px;
    height: 160px;
    display: flex;
    justify-content: center;
    align-items: center;
    background: var(--color-cream);
    transform: rotate(-3.51deg);
}

.recruit__banner-photo {
    width: 311px;
    align-self: flex-end;
}

.recruit__banner-content {
    width: 220px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 16px;
    transform: rotate(3.51deg);
}

.recruit__banner-title {
    font-family: var(--font-dot);
    font-size: 56px;
    color: var(--color-blue);
    letter-spacing: -2.8px;
    line-height: 1;
}

/* ================================================
   RESPONSIVE — TABLET (max 900px)
   ================================================ */
@media (max-width: 1280px) {
    :root {
        --content-padding: 0 40px;
    }

    /* FV */
    .fv__photo--3,
    .fv__photo--4 {
        display: none;
    }
    .fv__photo--1 {
        width: 160px;
        height: 180px;
    }
    .fv__photo--5 {
        width: 140px;
        height: 160px;
    }
    .fv__photo--6 {
        width: 140px;
        height: 160px;
    }

    /* Section headings */
    .section-heading__en {
        font-size: 52px;
    }
    .section-heading__ja {
        font-size: 28px;
    }
    /* Mission */
    .mission__cards {
        gap: 24px;
    }

    .mission__card {
        height: fit-content;
    }

    /* Mission msg */
    .mission-msg__inner {
        flex-direction: column;
        gap: 40px;
    }

    .mission-msg__title {
        font-size: 2.25rem;
    }

    .mission-msg__text-col {
        max-width: 100%;
    }

    /* Features */
    .features__track {
        padding: 16px 40px;
    }

    /* About header */
    .about__header {
        flex-direction: column;
        gap: 24px;
    }

    /* About cards */

    /* Movie */

    /* Like a Home */
    .likehome__inner {
        flex-direction: column;
        gap: 40px;
    }
    .likehome__right {
        margin: 0 auto;
    }

    /* Information */

    /* News */
    .news__box {
        padding: 40px 32px;
        max-width: 100%;
    }

    /* Recruit */
    .recruit__inner {
        justify-content: center;
    }
    .recruit__banner {
        width: 100%;
        max-width: 580px;
    }
}

@media (max-width: 1143px) {
    /* movie */
    .movie__inner {
        flex-direction: column;
        align-items: center;
        gap: 100px;
    }

    .movie__wrapper {
        width: 100%;
        max-width: 622px;
    }

    .movie__wrapper::before {
        top: -103px;
        width: 100%;
        height: 100%;
        max-width: 119px;
        max-height: 104px;
    }
}

/* ================================================
   RESPONSIVE — MOBILE (max 700px)
   ================================================ */
@media (max-width: 700px) {
    /* Information */
    .information__inner {
        flex-direction: column;
        gap: 32px;
    }

    .information__photo {
        width: 100%;
    }

    /* about */

    .about::before {
        bottom: 0;
        left: 50%;
        transform: translateX(-50%);
        height: 8.2vw;
    }

    .about::after {
        bottom: 0;
        left: 50%;
        transform: translateX(-50%);
        height: 8.2vw;
    }

    .about__cards {
        grid-template-columns: repeat(2, 1fr);
    }
    .about-card:nth-of-type(1),
    .about-card:nth-of-type(4) {
        margin-top: 0;
    }

    .about__building-image {
        width: 100%;
        margin: 0 auto 0;
    }

    /* movie */
    .mobie__inner {
        margin: 0 auto;
    }

    .movie__player {
        border-radius: 16px;
        padding: 16px 20px;
    }

    .movie__tabs {
        flex-direction: column;
    }

    .movie__tab {
        width: 100%;
    }

    .tab-label {
        font-size: 0.875rem;
    }

    .information .section-heading__en {
        margin-left: auto;
        margin-right: auto;
    }
}

/* ================================================
   RESPONSIVE — MOBILE (max 600px)
   ================================================ */
@media (max-width: 600px) {
    :root {
        --content-padding: 0 20px;
    }

    /* Section headings */
    .section-heading__en {
        font-size: 48px;
        letter-spacing: -2px;
    }

    .section-heading__en::after {
        width: 181px;
        height: 37px;
        transform: rotate(-3deg) translate(-50%, -40%);
    }

    .section-heading__ja {
        font-size: 22px;
        letter-spacing: 1px;
    }
    .section-heading__bg-rect {
        height: 42px;
    }

    /* FV */
    .fv {
        height: auto;
        min-height: 520px;
        max-height: none;
        margin-top: 0;
    }

    .fv__photo--5,
    .fv__photo--6 {
        display: none;
    }
    .fv__photo--1 {
        width: 130px;
        height: 150px;
        left: 4%;
        top: 6%;
    }

    .fv__bottom {
        flex-direction: column;
        align-items: flex-start;
        bottom: 20px;
        gap: 12px;
    }

    .fv__pickup {
        max-width: 100%;
        width: 100%;
    }

    .fv__movie-cta {
        flex-direction: row;
        align-self: flex-end;
    }

    /* SEPARATOR */
    .wave-separator.grass-left::after {
        top: -17vw;
        left: 0;
        width: 50vw;
        height: 36vw;
    }
    .wave-separator.grass-right::after {
        top: -9px;
        width: 50vw;
        height: 20vw;
    }
    .wave-separator.kids::before {
        top: -9.7px;
        left: 8.2px;
    }

    .wave-separator.kids::after {
        top: 41px;
        left: 10px;
    }

    /* Mission */
    .mission {
        padding: 40px 0 0;
    }
    .mission__cards {
        flex-direction: column;
        align-items: center;
        gap: 44px;
    }
    .mission__card {
        width: 260px;
    }

    /* Features track */
    .features__track {
        padding: 16px 20px;
    }

    /* About */
    .about {
        padding: 20px 0 30px;
    }
    .about__header {
        flex-direction: column;
    }
    .about__cards {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
    }

    .about__kids1-image {
        position: absolute;
        bottom: -10.4vw;
        left: 4.2vw;
        width: 12.5vw;
        height: 25.9vw;
    }

    .about__kids2-image {
        position: absolute;
        bottom: -6.3vw;
        right: 3.1vw;
        width: 17.6vw;
        height: 21.7vw;
        transform: rotate(2.059deg);
    }

    /* Movie */
    .movie {
        padding: 60px 0 110px;
    }
    .movie__inner {
        flex-direction: column;
    }
    .movie__tabs {
        display: flex;
        gap: 16px;
        padding: 0 40px;
        margin-top: 24px;
    }
    .movie__tabs::before {
        position: absolute;
        content: "";
        width: 22px;
        height: 22px;
        background-color: var(--color-orange);
        border-radius: 50%;
    }

    .movie__tabs::after {
        position: absolute;
        content: "";
        width: 22px;
        height: 22px;
        background-color: var(--color-orange);
        border-radius: 50%;
    }

    /* Like a Home */
    .likehome__left {
        order: 2;
    }

    .likehome__right {
        order: 1;
    }

    .likehome-title-image {
        order: 2;
    }

    .likehome__family-photo {
        order: 1;
    }

    .likehome__logo-icon {
        margin: 0 auto;
    }

    .likehome__title {
        font-size: 24px;
        text-align: center;
    }

    .likehome__feature-cards {
        grid-template-columns: 1fr 1fr;
    }

    /* Information */

    /* News */
    .news {
        padding: 40px 0;
    }

    .news__box {
        padding: 28px 20px;
    }
    .news__title {
        white-space: normal;
        font-size: 14px;
    }

    /* Recruit */
    .recruit {
        padding: 40px 0 60px;
    }

    .recruit__banner {
        flex-direction: column;
        width: 100%;
        height: auto;
        min-width: 0;
        background-color: transparent;
    }
    .recruit__banner-photo {
        width: 84%;
        height: auto;
        top: -20px;
        align-self: center;
    }
    .recruit__banner-content {
        right: 8px;
        width: 100%;
        background: var(--color-cream);
        transform: rotate(0);
        padding: 24px;
    }
    .recruit__banner-title {
        font-size: 40px;
        transform: rotate(3.51deg);
    }

    .recruit__banner-content .btn-text-link.btn-text-link--red {
        transform: rotate(3.51deg);
    }
}

/* ================================================
   375px — Minimum Mobile Support
   ================================================ */
@media (max-width: 374px) {
    :root {
        --content-padding: 0 16px;
    }

    .fv__pickup-title {
        white-space: normal;
        font-size: 13px;
    }

    .section-heading__en {
        font-size: 40px;
    }

    .feature-card {
        width: 343px;
        height: 455px;
    }

    .about__cards {
        grid-template-columns: 1fr;
    }

    .likehome__feature-cards {
        grid-template-columns: 1fr;
    }
}
