@charset "utf-8";

/* ===================================================================
  CSS information
  project name  :  わくわく まなビルド
  file name  :  style.css
=================================================================== */


/* --------------------------------
カスタムプロパティ
-------------------------------- */

:root {
    /* ベースカラー */
    --color-lightest: #fff;
    --color-darkest: #231815;
    /* テキスト */
    --color-text: #804200;
    /* アクセントカラー */
    --color-orange: #FF6600;
    /* FV空エリア背景 */
    --color-sky: #A8E0F8;
    /* 比率の基準値（SPデザインカンプ幅750px。流体計算の分母として固定） */
    --width-base: 750;
    /* コンテンツ最大幅（PC時はこの幅にデザイン全体を比例縮小して表示） */
    --width-content: 440px;
    /* 流体計算の基準幅（コンテンツ幅で頭打ち。440px以上では全要素が固定される） */
    --vw: min(100vw, var(--width-content));
    /* コンテンツ幅 */
    --width-main: min(var(--width-content), 100%);
    /* transition */
    --trans-hover: all 300ms;
    /* font */
    --font-family-primary: "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Sans", "ヒラギノ角ゴシック", "Yu Gothic Medium", "游ゴシック Medium", YuGothic, sans-serif;
    /* ヘッダー高さ */
    --header-h: min(calc(120 / var(--width-base) * var(--vw)), 120px);
}


/* --------------------------------
common
-------------------------------- */

* {
    box-sizing: border-box;
}

/* PC表示：背景画像を全幅、コンテンツは440px中央寄せ */
html {
    background-color: #68bdcd; /* 背景レイヤー外も海色で */
    min-height: 100%;
}

/* 背景画像：ビューポート固定レイヤー。
   モバイル/タブレット（iOS Safari・Android Chrome）は background-attachment:fixed を
   無視し、背景がドキュメント全高基準で巨大化するため、position:fixed の実レイヤーで固定する。
   サイズは幅基準（100% auto）にして縦長画面でも拡大しすぎないようにする。 */
body::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: -1;
    background: #68bdcd url(../img/bg_pc.png) center / 100% auto no-repeat;
    pointer-events: none;
}

body {
    max-width: var(--width-content);
    margin: 0 auto;
    font-family: var(--font-family-primary);
    color: var(--color-text);
    position: relative;

    &.is-nav-open {
        overflow: hidden;
    }
}

a {
    transition: var(--trans-hover);
    color: var(--color-text);
    text-decoration: none;
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

/* PC/SP出し分け */

.pc-only {
    display: block !important;
}

.sp-only {
    display: none !important;
}

/* フェードイン(初期値) */

.js-fadeUp {
    opacity: 0;
    transform: translateY(50px);
    transition: opacity .8s, transform 0.8s;
}

/* フェードイン(スクロールした後) */

.js-fadeUp.is-inview {
    opacity: 1;
    transform: translateY(0);
    transition-delay: .2s;
}


/* --------------------------------
c-header
-------------------------------- */

.c-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    margin: 0 auto;
    width: 100%;
    max-width: var(--width-content);
    height: var(--header-h);
    background-color: var(--color-lightest);
    border-bottom: min(calc(1/ var(--width-base) * var(--vw)), 1px) solid #000000;
    z-index: 400;

    .c-header__inner {
        width: 100%;
        max-width: var(--width-main);
        height: 100%;
        margin: 0 auto;
        display: flex;
        align-items: center;
        justify-content: space-between;
    }

    .c-header__logo {
        height: 100%;
        padding: min(calc(15/ var(--width-base) * var(--vw)), 15px) min(calc(27 / var(--width-base) * var(--vw)), 27px);
        display: flex;
        align-items: center;

        a {
            display: block;
            height: 100%;

            img {
                height: 100%;
                width: auto;
            }
        }
    }

    .c-header__target {
        font-size: min(calc(24 / var(--width-base) * var(--vw)), 1.4rem);
        font-weight: 700;
        color: var(--color-text);
        flex: 1;
        text-align: center;
    }

    /* ハンバーガーボタン */
    .c-header__hamburger {
        flex-shrink: 0;
        width: var(--header-h);
        height: var(--header-h);
        background-color: var(--color-darkest);
        border: none;
        cursor: pointer;
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        gap: min(calc(14 / var(--width-base) * var(--vw)), 14px);
        padding: 0;

        span {
            display: block;
            width: min(calc(56 / var(--width-base) * var(--vw)), 56px);
            height: min(calc(6 / var(--width-base) * var(--vw)), 6px);
            background-color: var(--color-lightest);
            border-radius: 2px;
            transition: transform 0.4s ease, opacity 0.3s ease;
        }

        /* X アニメーション（クラスで制御） */
        &.is-active span:nth-child(1) {
            transform: translateY(min(calc(20 / var(--width-base) * var(--vw)), 20px)) rotate(45deg);
        }
        &.is-active span:nth-child(2) {
            opacity: 0;
            transform: scaleX(0);
        }
        &.is-active span:nth-child(3) {
            transform: translateY(max(calc(-20 / var(--width-base) * var(--vw)), -20px)) rotate(-45deg);
        }

        @media only screen and (min-width: 750px) {
            &:hover {
                opacity: .7;
            }
        }
    }
}


/* --------------------------------
c-nav
-------------------------------- */

.c-nav {
    position: fixed;
    top: var(--header-h);
    left: 0;
    right: 0;
    margin: 0 auto;
    width: 100%;
    max-width: var(--width-content);
    height: calc(100dvh - var(--header-h));
    background-color: var(--color-lightest);
    z-index: 300;
    overflow-y: auto;
    visibility: hidden;
    opacity: 0;
    transform: translateY(-16px);
    transition: opacity 0.5s ease, transform 0.5s ease, visibility 0s linear 0.5s;

    &.is-open {
        visibility: visible;
        opacity: 1;
        transform: translateY(0);
        transition: opacity 0.5s ease, transform 0.5s ease, visibility 0s linear 0s;
    }

    /* メニューリスト */
    .c-nav__list {
        list-style: none;
        padding: min(calc(30 / var(--width-base) * var(--vw)), 30px) min(calc(30 / var(--width-base) * var(--vw)), 30px) 0;
        margin: 0;
        display: flex;
        flex-direction: column;
        gap: min(calc(20 / var(--width-base) * var(--vw)), 20px);

        .c-nav__item {
            width: 100%;

            a {
                display: block;
                width: 100%;

                img {
                    /* 横幅基準の自然高さ（コンテナ幅 var(--vw) の左右余白8%ぶんを引いて × 300/1394）と
                       画面高さ基準の上限の小さい方に制限し、1画面に収める */
                    height: min(calc((var(--vw) - calc(var(--vw) * 8 / 100)) * 300 / 1394), 10dvh);
                    width: auto;
                    max-width: 100%;
                    margin-inline: auto;
                }

                @media only screen and (min-width: 750px) {
                    &:hover {
                        opacity: .8;
                    }
                }
            }
        }
    }

    /* CTAエリア */
    .c-nav__cta {
        padding: min(calc(40 / var(--width-base) * var(--vw)), 40px) min(calc(30 / var(--width-base) * var(--vw)), 30px) min(calc(50 / var(--width-base) * var(--vw)), 50px);
        text-align: center;

        .c-nav__cta-text {
            margin: 0 auto min(calc(20 / var(--width-base) * var(--vw)), 20px);
            max-width: min(calc(500 / var(--width-base) * var(--vw)), 500px);
            /* 横幅基準の自然高さと画面高さ基準の上限の小さい方に制限 */
            height: min(calc(min(500 / var(--width-base) * var(--vw), 500px) * 80 / 983), 5dvh);
            width: auto;
        }

        .c-nav__cta-btns {
            display: flex;
            gap: min(calc(20 / var(--width-base) * var(--vw)), 20px);
            justify-content: center;

            a {
                flex: 1;
                max-width: min(calc(310 / var(--width-base) * var(--vw)), 310px);

                img {
                    /* 横幅基準の自然高さと画面高さ基準の上限の小さい方に制限 */
                    height: min(calc(min(310 / var(--width-base) * var(--vw), 310px) * 196 / 656), 10dvh);
                    width: auto;
                    max-width: 100%;
                    margin-inline: auto;
                }

                @media only screen and (min-width: 750px) {
                    &:hover {
                        opacity: .8;
                    }
                }
            }
        }

        .c-nav__cta-note {
            margin: min(calc(16 / var(--width-base) * var(--vw)), 16px) 0 0;
            /* 左端をApp Storeボタンの左端に揃える（ボタン行は中央寄せのため左に25/750*vwの余白が生じる） */
            padding-left: min(calc(25 / var(--width-base) * var(--vw)), 25px);
            font-size: min(calc(22 / var(--width-base) * var(--vw)), 22px);
            line-height: 1.5;
            color: #000;
            text-align: left;
        }
    }
}


/* --------------------------------
c-fv
-------------------------------- */

.c-fv {
    padding-top: var(--header-h);
    background-color: var(--color-sky);

    .c-fv__img {
        width: 100%;
        position: relative;

        img {
            width: 100%;
            height: auto;
            display: block;
        }

        /* fv_img上に重ねるボタン */
        .c-fv__btns {
            position: absolute;
            bottom: min(calc(88 / var(--width-base) * var(--vw)), 88px);
            left: 50%;
            transform: translateX(-50%);
            width: calc(100% - min(calc(70 / var(--width-base) * var(--vw)), 70px));
            display: flex;
            gap: min(calc(20 / var(--width-base) * var(--vw)), 20px);
            justify-content: center;

            a {
                flex: 1;

                img {
                    width: 100%;
                }

                @media only screen and (min-width: 750px) {
                    &:hover {
                        opacity: .8;
                    }
                }
            }
        }
    }
.c-fv__note {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: min(calc(40 / var(--width-base) * var(--vw)), 40px);
width: calc(100% - 20px);
	margin: 0;
    text-align: center;
	font-size: 13px;
}
    .c-fv__content {
        padding: min(calc(40 / var(--width-base) * var(--vw)), 40px) min(calc(30 / var(--width-base) * var(--vw)), 30px) min(calc(50 / var(--width-base) * var(--vw)), 50px);
        text-align: center;
    }

    .c-fv__logo {
        margin: 0 auto;
        max-width: min(calc(560 / var(--width-base) * var(--vw)), 560px);

        img {
            width: 100%;
        }
    }
}


/* -------- テキスト共通 -------- */
.c-about__text,
.c-reason__text,
.c-faq__answer p,
.c-cta__notes li,
.c-cta__accordion-btn span,
.c-company__accordion-btn span,
.c-review__text,
.c-review__sub,
.c-footer__nav-row a {
    font-size: min(calc(30 / var(--width-base) * var(--vw)), 30px);
    font-weight: 300;
    line-height: 1.67;
    letter-spacing: -0.04em;
    color: #804200;
}

/* --------------------------------
c-about
-------------------------------- */

.c-about {
    width: 100%;
    background-color: #fff9e8;

    .c-about__ttl {
        width: 100%;

        img {
            width: 100%;
            display: block;
        }
    }

    .c-about__inner {
        padding: min(calc(54 / var(--width-base) * var(--vw)), 54px) 0 min(calc(140 / var(--width-base) * var(--vw)), 140px);
    }

    .c-about__pic {
        width: 100%;
        img {
            width: 100%;
        }
    }

    .c-about__text {
        margin: min(calc(57 / var(--width-base) * var(--vw)), 57px) 0 min(calc(91 / var(--width-base) * var(--vw)), 91px);
        padding: 0 min(calc(35 / var(--width-base) * var(--vw)), 35px);
    }
    .c-about__notebook + .c-about__text {
        margin: min(calc(66 / var(--width-base) * var(--vw)), 66px) 0 0;
    }

    /* ノート画像＋スライダーの重ね合わせ */
    .c-about__notebook {
        position: relative;

        .c-about__notebook-img {
            width: 100%;
            display: block;
        }

        .c-about__slider-wrap {
            margin-top: max(calc(-254 / var(--width-base) * var(--vw)), -254px);
            position: relative;
            z-index: 1;
        }
    }

    /* スライダーラッパー */
    .c-about__slider-wrap {
        position: relative;
        margin-bottom: min(calc(20 / var(--width-base) * var(--vw)), 20px);
    }

    /* 矢印ボタン（スライダーに重ねる） */
    .c-about__prev,
    .c-about__next {
        position: absolute;
        top: 0;
        bottom: min(calc(76 / var(--width-base) * var(--vw)), 76px);
        z-index: 10;
        width: min(calc(85 / var(--width-base) * var(--vw)), 85px);
        display: flex;
        align-items: center;
        justify-content: center;
        background: none;
        border: none;
        cursor: pointer;
        padding: 0;

        img {
            width: 100%;
            height: auto;
            display: block;
        }

        @media only screen and (min-width: 750px) {
            &:hover {
                opacity: .7;
            }
        }
    }

    .c-about__prev {
        left: min(calc(32 / var(--width-base) * var(--vw)), 32px);
    }

    .c-about__next {
        right: min(calc(32 / var(--width-base) * var(--vw)), 32px);
    }

    .c-about__slider {
        width: 100%;
        visibility: hidden;

        &.slick-initialized {
            visibility: visible;
        }

        .c-about__slide {
            padding: 0 min(calc(17 / var(--width-base) * var(--vw)), 17px);

            img {
                width: 100%;
                height: auto;
            }
        }

        /* ドット */
        .slick-dots {
            position: relative;
            bottom: auto;
            margin-top: min(calc(48 / var(--width-base) * var(--vw)), 48px);

            li {
                width: min(calc(30 / var(--width-base) * var(--vw)), 30px);
                height: min(calc(30 / var(--width-base) * var(--vw)), 30px);
                margin: 0 min(calc(25 / var(--width-base) * var(--vw)), 25px);

                button {
                    width: min(calc(30 / var(--width-base) * var(--vw)), 30px);
                    height: min(calc(30 / var(--width-base) * var(--vw)), 30px);

                    &::before {
                        content: '';
                        width: min(calc(30 / var(--width-base) * var(--vw)), 30px);
                        height: min(calc(30 / var(--width-base) * var(--vw)), 30px);
                        background-color: #cccccc;
                        border-radius: 50%;
                        font-size: 0;
                        opacity: 1;
                    }
                }

                &.slick-active button::before {
                    background-color: #ffb400;
                    opacity: 1;
                }
            }
        }
    }

    /* ボタン */
    .c-about__btn {
        width: min(calc(665 / var(--width-base) * var(--vw)), 665px);
        margin: 0 auto min(calc(60 / var(--width-base) * var(--vw)), 60px);
        cursor: pointer;

        img {
            width: 100%;
        }
    }
}


/* --------------------------------
c-nayami
-------------------------------- */

.c-nayami {
    width: 100%;
    background-color: #fff9e8;

    .c-nayami__ttl {
        width: 100%;

        img {
            width: 100%;
            display: block;
        }
    }

    .c-nayami__body {
        display: flex;
        flex-direction: column;
        align-items: center;
    }

    .c-nayami__pic {
        width: 100%;

        img {
            width: 100%;
        }
    }

    .c-nayami__icon {
        width: min(calc(50 / var(--width-base) * var(--vw)), 50px);
        margin: min(calc(10 / var(--width-base) * var(--vw)), 10px) auto min(calc(15 / var(--width-base) * var(--vw)), 15px);
        img {
            width: min(calc(60 / var(--width-base) * var(--vw)), 60px);
            height: auto;
            margin: 0 auto;
        }
    }
}


/* --------------------------------
c-reason
-------------------------------- */

.c-reason {
    width: 100%;
    background-color: #fff9e8;

    .c-reason__ttl {
        width: 100%;

        img {
            width: 100%;
            display: block;
        }
    }

    .c-reason__inner {
        padding: min(calc(12 / var(--width-base) * var(--vw)), 12px) 0 min(calc(54 / var(--width-base) * var(--vw)), 54px);
    }

    .c-reason__block {
        margin-bottom: min(calc(70 / var(--width-base) * var(--vw)), 70px);

        &:last-child {
            margin-bottom: 0;
        }
    }

    /* 黒板画像 */
    .c-reason__blackboard {
        img {
            width: 100%;
        }
    }

    /* スライダーラッパー */
    .c-reason__slider-wrap {
        position: relative;
        margin:min(calc(52 / var(--width-base) * var(--vw)), 52px) 0 min(calc(20 / var(--width-base) * var(--vw)), 20px);
        &.c-reason__slider-wrap--02 {
            margin:min(calc(24 / var(--width-base) * var(--vw)), 24px) 0 min(calc(20 / var(--width-base) * var(--vw)), 20px);
            .c-reason__prev, .c-reason__next{
                bottom: auto;
                top: min(calc(205 / var(--width-base) * var(--vw)), 205px);
            }
        }

    }

    /* 矢印ボタン */
    .c-reason__prev,
    .c-reason__next {
        position: absolute;
        top: 0;
        bottom: min(calc(76 / var(--width-base) * var(--vw)), 76px);
        z-index: 10;
        width: min(calc(85 / var(--width-base) * var(--vw)), 85px);
        display: flex;
        align-items: center;
        justify-content: center;
        background: none;
        border: none;
        cursor: pointer;
        padding: 0;

        img {
            width: 100%;
            height: auto;
            display: block;
        }

        @media only screen and (min-width: 750px) {
            &:hover {
                opacity: .7;
            }
        }
    }

    .c-reason__prev {
        left: min(calc(32 / var(--width-base) * var(--vw)), 32px);
    }

    .c-reason__next {
        right: min(calc(32 / var(--width-base) * var(--vw)), 32px);
    }

    .c-reason__slider {
        width: 100%;
        visibility: hidden;

        &.slick-initialized {
            visibility: visible;
        }

        .c-reason__slide {
            padding: 0 min(calc(17 / var(--width-base) * var(--vw)), 17px);

            img {
                width: 100%;
                height: auto;
            }
        }

        /* ドット */
        .slick-dots {
            position: relative;
            bottom: auto;
            margin-top: min(calc(48 / var(--width-base) * var(--vw)), 48px);

            li {
                width: min(calc(30 / var(--width-base) * var(--vw)), 30px);
                height: min(calc(30 / var(--width-base) * var(--vw)), 30px);
                margin: 0 min(calc(25 / var(--width-base) * var(--vw)), 25px);

                button {
                    width: min(calc(30 / var(--width-base) * var(--vw)), 30px);
                    height: min(calc(30 / var(--width-base) * var(--vw)), 30px);

                    &::before {
                        content: '';
                        width: min(calc(30 / var(--width-base) * var(--vw)), 30px);
                        height: min(calc(30 / var(--width-base) * var(--vw)), 30px);
                        background-color: #cccccc;
                        border-radius: 50%;
                        font-size: 0;
                        opacity: 1;
                    }
                }

                &.slick-active button::before {
                    background-color: #ffb400;
                    opacity: 1;
                }
            }
        }
    }

    /* テキスト */
    .c-reason__text {
        margin: min(calc(65 / var(--width-base) * var(--vw)), 65px) 0 min(calc(104 / var(--width-base) * var(--vw)), 104px);
        padding: 0 min(calc(35 / var(--width-base) * var(--vw)), 35px);
        &.c-reason__text--02{
            margin: min(calc(65 / var(--width-base) * var(--vw)), 65px) 0 min(calc(150 / var(--width-base) * var(--vw)), 150px);
        }
        &.c-reason__text--03{
            margin: min(calc(41 / var(--width-base) * var(--vw)), 41px) 0 0;
        }
    }

    /* reason3 結果画像 */
    .c-reason__result {
        margin-top:  min(calc(3 / var(--width-base) * var(--vw)), 3px);
        img {
            width: 100%;
        }
    }
}


/* --------------------------------
c-cta
-------------------------------- */

.c-cta {
    width: 100%;
    background-color: #fff9e8;
    padding: 0 0 min(calc(120 / var(--width-base) * var(--vw)),120px);
    .c-cta__inner {
        padding: min(calc(55 / var(--width-base) * var(--vw)), 55px) min(calc(32 / var(--width-base) * var(--vw)), 32px) 0;
    }

    /* カード */
    .c-cta__card {
        margin-bottom: min(calc(40 / var(--width-base) * var(--vw)), 40px);
    }

    /* pic_cta上にボタンを重ねる */
    .c-cta__pic {
        position: relative;
        width: 100%;

        img {
            width: 100%;
        }

        /* 「7月16日リリース開始！」をボタンの少し上に重ねる（pic_cta2.png基準） */
        .c-cta__text {
            position: absolute;
            left: 50%;
            bottom: 18.5%;
            transform: translateX(-50%);
            width: 70%;
            height: auto;
        }

        /* 注釈：pic内・ボタンの下に重ねる。左端をApp Storeボタンの左端に揃える */
        .c-cta__note {
            position: absolute;
            left: min(calc(45 / var(--width-base) * var(--vw)), 45px);
            bottom: min(calc(30 / var(--width-base) * var(--vw)), 30px);
            margin: 0;
            font-size: min(calc(22 / var(--width-base) * var(--vw)), 22px);
            line-height: 1.5;
            color: #000;
        }
    }

    .c-cta__btns {
        position: absolute;
        bottom: min(calc(80 / var(--width-base) * var(--vw)), 80px);
        left: 50%;
        transform: translateX(-50%);
        width: calc(100% - min(calc(90 / var(--width-base) * var(--vw)), 90px));
        display: flex;
        gap: min(calc(15 / var(--width-base) * var(--vw)), 15px);
        justify-content: center;

        a {
            flex: 1;

            img {
                width: 100%;
            }

            @media only screen and (min-width: 750px) {
                &:hover {
                    opacity: .8;
                }
            }
        }
    }

    .c-cta__accordion{
        margin: min(calc(67/ var(--width-base) * var(--vw)), 67px) 0 0;
    }
    /* アコーディオン（フルwidth） */
    .c-cta__accordion-btn {
        width: 100%;
        display: flex;
        align-items: center;
        justify-content: space-between;
        background: none;
        border: none;
        border-top: min(calc(2/ var(--width-base) * var(--vw)), 2px) solid #804200;
        border-bottom: min(calc(2/ var(--width-base) * var(--vw)), 2px) solid #804200;
        padding: min(calc(39 / var(--width-base) * var(--vw)), 39px) min(calc(73 / var(--width-base) * var(--vw)), 73px) min(calc(35 / var(--width-base) * var(--vw)), 35px) min(calc(70 / var(--width-base) * var(--vw)), 70px);
        cursor: pointer;
        font-family: var(--font-family-primary);
        text-align: left;
        span{
            font-weight: bold;
        }
    }

    /* 矢印アイコン（icon_arrow.svg：素の向きが∧のため回転で∨∧切り替え） */
    .c-cta__accordion-icon {
        display: block;
        flex-shrink: 0;
        width: min(calc(50 / var(--width-base) * var(--vw)), 50px);
        height: auto;
        transform: rotate(180deg); /* 閉じた状態：∨（下向き） */
        transition: transform .3s;
    }

    .c-cta__accordion-btn.is-open .c-cta__accordion-icon {
        transform: rotate(0deg); /* 開いた状態：∧（上向き） */
    }

    /* アコーディオン本文 */
    .c-cta__accordion-body {
        background-color: #fff;
        padding: min(calc(71 / var(--width-base) * var(--vw)), 71px) min(calc(36 / var(--width-base) * var(--vw)), 36px) min(calc(84 / var(--width-base) * var(--vw)), 84px);
    }

    .c-cta__notes {
        list-style: none;
        padding: 0;
        margin: 0;
        display: flex;
        flex-direction: column;
        gap: min(calc(50 / var(--width-base) * var(--vw)), 50px);
        list-style: none;
        li{
            letter-spacing: 0;
        }
    }
}


/* --------------------------------
c-company
-------------------------------- */

.c-company {
    width: 100%;
    background-color: #fff9e8;
    padding: 0 0  min(calc(137 / var(--width-base) * var(--vw)), 137px);
    .c-company__ttl {
        width: 100%;

        img {
            width: 100%;
            display: block;
        }
    }

    .c-company__inner {
        padding: min(calc(27 / var(--width-base) * var(--vw)), 27px) min(calc(30 / var(--width-base) * var(--vw)), 30px) min(calc(66 / var(--width-base) * var(--vw)), 66px);
    }

    .c-company__pic {
        width: 100%;

        img {
            width: 100%;
        }
    }

    /* アコーディオン（フルwidth） */
    .c-company__accordion {
        &.c-company__accordion--02{
            .c-company__accordion-body {
                background-color: var(--color-lightest);
                padding: min(calc(60 / var(--width-base) * var(--vw)), 60px) min(calc(33 / var(--width-base) * var(--vw)), 33px) min(calc(35 / var(--width-base) * var(--vw)), 35px);
            }
            .c-company__logo{
                margin: min(calc(40 / var(--width-base) * var(--vw)), 40px) auto 0;
            }
        }
    }

    /* --02のborder-topは両方閉じている時に線が重ならないよう非表示 */
    /* --01が開いている時だけ--02のborder-topを表示 */
    .c-company__accordion--02 .c-company__accordion-btn {
        border-top: none;
    }
    .c-company__accordion--01:has(.is-open) + .c-company__accordion--02 .c-company__accordion-btn {
        border-top: 2px solid #804200;
    }
    .c-company__accordion--02:has(.is-open) .c-company__accordion-body {
        border-bottom: 2px solid #804200;
    }
    .c-company__accordion-btn {
        width: 100%;
        display: flex;
        align-items: center;
        justify-content: space-between;
        background: none;
        border: none;
        border-top: min(calc(2/ var(--width-base) * var(--vw)), 2px) solid #804200;
        border-bottom: min(calc(2/ var(--width-base) * var(--vw)), 2px) solid #804200;
        padding: min(calc(39 / var(--width-base) * var(--vw)), 39px) min(calc(73 / var(--width-base) * var(--vw)), 73px) min(calc(35 / var(--width-base) * var(--vw)), 35px) min(calc(70 / var(--width-base) * var(--vw)), 70px);
        cursor: pointer;
        font-family: var(--font-family-primary);
        text-align: left;
        span{
            font-weight: bold;
        }
    }

    /* ∧∨アイコン */
    .c-company__accordion-icon {
        display: block;
        flex-shrink: 0;
        width: min(calc(50 / var(--width-base) * var(--vw)), 50px);
        height: auto;
        transform: rotate(0deg); /* 閉じた状態：∨（下向き） */
        transition: transform .3s;
        margin-top: max(calc(-7 / var(--width-base) * var(--vw)), -7px)
    }

    .c-company__accordion-btn:not(.is-open) .c-company__accordion-icon {
        transform: rotate(180deg); /* 閉じた状態：∨ */
    }

    /* アコーディオン本文（白背景） */
    .c-company__accordion-body {
        background-color: var(--color-lightest);
        padding: min(calc(48 / var(--width-base) * var(--vw)), 48px) min(calc(40 / var(--width-base) * var(--vw)), 40px) min(calc(27 / var(--width-base) * var(--vw)), 27px);
    }

    .c-company__notes {
        list-style: none;
        padding: 0;
        margin: 0;
        display: flex;
        flex-direction: column;
        list-style: none;
        li{
            font-size: min(calc(30 / var(--width-base) * var(--vw)), 30px);
            font-weight: bold;
            line-height: 1.67;
            letter-spacing: -0.04em;
            color: #000;
        }
    }

    /* アコーディオン内画像 */
    .c-company__media {
        width: 100%;
        padding-top: 5px;
        img {
            width: 100%;
        }
    }

    /* サクセスロゴ */
    .c-company__logo {
        img {
            width: 100%;
        }
    }

    /* 著作権表記（note） */
    .c-company__copyright {
        margin: min(calc(10 / var(--width-base) * var(--vw)), 10px) 0 0;
        font-size: min(calc(20 / var(--width-base) * var(--vw)), 20px);
        text-align: right; 
        line-height: 1.5;
        letter-spacing: -0.04em;
        color: #804200;
    }
}


/* --------------------------------
c-voice
-------------------------------- */

.c-voice {
    width: 100%;
    background-color: #fff9e8;
    overflow: hidden;
    padding-bottom: min(calc(160 / var(--width-base) * var(--vw)), 160px);;
    .c-voice__ttl {
        width: 100%;

        img {
            width: 100%;
            display: block;
        }
    }

    .c-voice__inner {
        padding-bottom: min(calc(70 / var(--width-base) * var(--vw)), 70px);
    }

    /* 体験談の注釈 */
    .c-voice__note {
        padding: 0 min(calc(43 / var(--width-base) * var(--vw)), 43px);
        font-size: min(calc(26 / var(--width-base) * var(--vw)), 26px);
        line-height: 1.5;
        color: #000;
    }

    /* 2つ目タイトル */
    .c-voice__heading2 {
        padding-top: min(calc(7 / var(--width-base) * var(--vw)), 7px);
    }

    /* カードリスト */
    .c-voice__list {
        display: flex;
        flex-direction: column;
        padding: 0 min(calc(43 / var(--width-base) * var(--vw)), 43px) min(calc(50 / var(--width-base) * var(--vw)), 50px);
        gap: min(calc(10 / var(--width-base) * var(--vw)), 10px);
    }

    /* カード外枠（アイコン基準） */
    .c-voice__item {
        position: relative;
        padding-top: min(calc(40 / var(--width-base) * var(--vw)), 35px); /* アイコン高さの半分 */
    }

    /* 顔アイコン（固定位置：吹き出し上から） */
    .c-voice__icon {
        position: absolute;
        z-index: 1;
    }

    .c-voice__item--01 .c-voice__icon {     
        top: min(calc(82 / var(--width-base) * var(--vw)), 82px);
        left: max(calc(-14 / var(--width-base) * var(--vw)), -14px);
        width: min(calc(122 / var(--width-base) * var(--vw)), 122px);
    }
    .c-voice__item--02 {
        .c-voice__icon {
            top: min(calc(83 / var(--width-base) * var(--vw)), 83px);
            right: max(calc(-14 / var(--width-base) * var(--vw)), -14px);
            width: min(calc(107 / var(--width-base) * var(--vw)), 107px);
        }
        .c-voice__lead{
            padding-left: min(calc(20 / var(--width-base) * var(--vw)), 20px);
            padding-right: min(calc(100 / var(--width-base) * var(--vw)), 100px);
        }
    }
     .c-voice__item--03 .c-voice__icon {
        top:  min(calc(77 / var(--width-base) * var(--vw)), 77px);
        left: max(calc(-6 / var(--width-base) * var(--vw)), -6px);
        width: min(calc(110 / var(--width-base) * var(--vw)), 110px);
    }

    /* 吹き出しカード */
    .c-voice__bubble {
        background-color: var(--color-lightest);
        border: min(calc(4/ var(--width-base) * var(--vw)), 4px) solid #f7db92;
        border-radius: min(calc(20 / var(--width-base) * var(--vw)), 20px);
        padding: min(calc(42 / var(--width-base) * var(--vw)), 42px) min(calc(20 / var(--width-base) * var(--vw)), 20px) min(calc(25 / var(--width-base) * var(--vw)), 25px);
    }

    /* 見出し（アイコンを避ける） */
    .c-voice__lead {
        font-size: min(calc(34 / var(--width-base) * var(--vw)), 34px);
        font-family: "Noto Sans JP", var(--font-family-primary);
        font-weight: 700;
        line-height: 1.667;
        color: #804200;
        padding-left: min(calc(106 / var(--width-base) * var(--vw)), 106px); /* アイコン幅80 + 余白8 */
    }

    .c-voice__item--right .c-voice__lead {
        padding-left: 0;
        padding-right: min(calc(88 / var(--width-base) * var(--vw)), 88px);
    }

    /* 本文（フル幅） */
    .c-voice__text {
        font-size: min(calc(30 / var(--width-base) * var(--vw)), 30px);
        line-height: min(calc(50 / var(--width-base) * var(--vw)), 50px);
        color: #804200;
        margin: 0;
        padding:  min(calc(23 / var(--width-base) * var(--vw)), 23px) min(calc(22 / var(--width-base) * var(--vw)), 22px) min(calc(15 / var(--width-base) * var(--vw)), 15px);
    }
}


/* --------------------------------
c-review（c-voice内）
-------------------------------- */

.c-review {
    width: calc(100%  + min(calc(180 / var(--width-base) * var(--vw)), 180px));
    background-color: #fee5eb;
    position: relative;
    padding-top: min(calc(60 / var(--width-base) * var(--vw)), 60px);
    border-radius: 50%;
    margin: 0  max(calc(-90 / var(--width-base) * var(--vw)), -90px);
    .c-review__ttl {
        width: min(calc(700 / var(--width-base) * var(--vw)), 700px);
        margin: 0 auto;
        position: relative;
        z-index: 2;
        padding: min(calc(60 / var(--width-base) * var(--vw)), 60px) 0 0;
        img {
            width: 100%;
        }
    }

    .c-review__inner {
        padding: 0 min(calc(120 / var(--width-base) * var(--vw)), 120px);
    }

    /* 説明テキスト */
    .c-review__text {
        padding: min(calc(10 / var(--width-base) * var(--vw)), 17px) min(calc(53 / var(--width-base) * var(--vw)), 53px);
    }

    /* メインコピー */
    .c-review__lead {
        width: min(calc(670 / var(--width-base) * var(--vw)), 670px);
        margin: 0 auto;
    }

    /* サブテキスト */
    .c-review__sub {
        text-align: center;
        padding: min(calc(16 / var(--width-base) * var(--vw)), 16px) 0 min(calc(200 / var(--width-base) * var(--vw)), 200px);
    }

    /* ボタン */
    .c-review__btn {
        width: min(calc(620 / var(--width-base) * var(--vw)), 620px);
        margin: 0 auto;
        position: absolute;
        left: 50%;
        transform: translate(-50%);
        bottom: max(calc(-30 / var(--width-base) * var(--vw)), -30px);
        a {
            display: block;

            img {
                width: 100%;
            }

            @media only screen and (min-width: 750px) {
                &:hover {
                    opacity: .8;
                }
            }
        }
    }
}


/* --------------------------------
c-learn
-------------------------------- */

.c-learn {
    margin: min(calc(50 / var(--width-base) * var(--vw)), 50px) 0;

    .c-learn__ttl {
        width: 100%;
        img { width: 100%; display: block; }
    }

    .c-learn__btn {
        width: 100%;
        background: none;
        border: none;
        padding: 0;
        cursor: pointer;
        display: block;
        position: relative;

        @media only screen and (min-width: 750px) {
            &:hover { opacity: .7; }
        }

        img { width: 100%; display: block; }

        /* 開閉矢印（疑似要素）。既定＝下向き「∨」、is-open＝上向き「へ」 */
        &::after {
            content: "";
            position: absolute;
            top: 50%;
            right: 13%;
            width: min(calc(34 / 750 * 100vw), 17px);
            height: min(calc(34 / 750 * 100vw), 17px);
            border-right: min(calc(6 / 750 * 100vw), 3px) solid #fff;
            border-bottom: min(calc(6 / 750 * 100vw), 3px) solid #fff;
            transform: translateY(-50%) rotate(45deg);
            transition: transform .3s;
            pointer-events: none;
        }

        &.is-open::after {
            transform: translateY(-50%) rotate(225deg);
        }
    }

    .c-learn__answer {
        background-color: #fff9e8;
        padding: 0 min(calc(25 / var(--width-base) * var(--vw)), 25px) min(calc(5 / var(--width-base) * var(--vw)), 5px);
        &.c-learn__answer--02 {
            padding: min(calc(3 / var(--width-base) * var(--vw)), 3px) min(calc(25 / var(--width-base) * var(--vw)), 25px) min(calc(34 / var(--width-base) * var(--vw)), 34px);
        }
        &.c-learn__answer--03 {
            padding: min(calc(3 / var(--width-base) * var(--vw)), 3px) min(calc(25 / var(--width-base) * var(--vw)), 25px) min(calc(34 / var(--width-base) * var(--vw)), 34px);
        }
    }
    
    .c-learn__wrap{
        background: #fff;
        padding: min(calc(47 / var(--width-base) * var(--vw)), 47px) min(calc(28 / var(--width-base) * var(--vw)), 28px) min(calc(16 / var(--width-base) * var(--vw)), 16px) min(calc(42 / var(--width-base) * var(--vw)), 42px);
    }

    .c-learn__subject {
        margin-top: min(calc(56 / var(--width-base) * var(--vw)), 56px);
        padding-bottom: min(calc(60 / var(--width-base) * var(--vw)), 60px);
        border-bottom: 2px dotted #c5a98b;
        &:first-of-type { margin-top: 0; }
        &:last-of-type {
            border-bottom: none;
            padding-bottom: min(calc(40 / var(--width-base) * var(--vw)), 40px);
        }
    }
    
    .c-learn__subject-list {
        list-style: none;
        margin: 0;
        padding: 0;
        li {
            font-size: min(calc(30 / var(--width-base) * var(--vw)), 30px);
            color: var(--color-text);
            padding-left: min(calc(28 / var(--width-base) * var(--vw)), 28px);
            position: relative;
            font-weight: bold;
            line-height: 1.66;
            &::before {
                content: "・";
                position: absolute;
                left: 0;
            }
            ul{
                padding-bottom: min(calc(16 / var(--width-base) * var(--vw)), 16px);
                li{
                    font-weight: normal;
                    font-size: min(calc(28 / var(--width-base) * var(--vw)), 28px);
                    line-height: 1.6071;
                    &::before{
                        content: none;
                        position: absolute;
                        left: 0;
                    }
                }
            }
            &:last-of-type{
                ul{
                    padding-bottom: 0px;
                }
            }
        }
    }
    .c-learn__subject-jp {
        color: #ff6931;
        font-weight: bold;
        font-size: min(calc(40 / var(--width-base) * var(--vw)), 40px);
        margin: 0 0 min(calc(24 / var(--width-base) * var(--vw)), 24px);
        line-height: 1.6667;
    }
    .c-learn__subject-en {
        color: #13b94f;
        font-weight: bold;
        font-size: min(calc(40 / var(--width-base) * var(--vw)), 40px);
        margin: 0 0 min(calc(18 / var(--width-base) * var(--vw)), 18px);
        line-height: 1.6667;
        + .c-learn__subject-list{
            li {
                ul{
                    padding-bottom: 0;
                }
            }
        }
    }
    .c-learn__subject-math {
        color: #20bce4;
        font-weight: bold;
        font-size: min(calc(40 / var(--width-base) * var(--vw)), 40px);
        margin: 0 0 min(calc(24 / var(--width-base) * var(--vw)), 24px);
        line-height: 1.6667;
    }

    .c-learn__subject-sci {
        color: #e85298;
        font-weight: bold;
        font-size: min(calc(40 / var(--width-base) * var(--vw)), 40px);
        margin: 0 0 min(calc(24 / var(--width-base) * var(--vw)), 24px);
        line-height: 1.6667;
    }

    .c-learn__note {
        list-style: none;
        margin: min(calc(16 / var(--width-base) * var(--vw)), 16px) min(calc(14 / var(--width-base) * var(--vw)), 14px);
        padding: min(calc(16 / var(--width-base) * var(--vw)), 16px) min(calc(25 / var(--width-base) * var(--vw)), 25px);

        li {
            font-size: min(calc(20 / var(--width-base) * var(--vw)), 20px);
            color: var(--color-text);
            line-height: 1.7;
        }
    }
}


/* --------------------------------
c-faq
-------------------------------- */

.c-faq {
    background-color: #fff9e8;
    .c-faq__ttl {
        width: 100%;

        img {
            width: 100%;
            display: block;
        }
    }

    .c-faq__list {
        padding: min(calc(20 / var(--width-base) * var(--vw)), 20px) min(calc(34 / var(--width-base) * var(--vw)), 34px) min(calc(54 / var(--width-base) * var(--vw)), 54px);
        display: flex;
        flex-direction: column;
        gap: min(calc(18 / var(--width-base) * var(--vw)), 18px);
    }

    .c-faq__item {
        /* アイテムラッパー */
    }

    /* ボタン本体 = テキスト＋CSS（角丸の黄背景・Q.・茶丸・矢印） */
    .c-faq__btn {
        width: 100%;
        display: flex;
        align-items: center;
        gap: min(calc(20 / var(--width-base) * var(--vw)), 20px);
        background-color: #f5dd96;
        border: none;
        border-radius: min(calc(40 / var(--width-base) * var(--vw)), 40px);
        padding: min(calc(28 / var(--width-base) * var(--vw)), 28px) min(calc(30 / var(--width-base) * var(--vw)), 30px);
        cursor: pointer;
        text-align: left;
        font-family: var(--font-family-primary);
        color: var(--color-text);
        transition: var(--trans-hover);

        @media only screen and (min-width: 750px) {
            &:hover { opacity: .7; }
        }
    }

    .c-faq__q {
        flex-shrink: 0;
        width: min(calc(48 / var(--width-base) * var(--vw)), 48px);
        height: auto;
    }

    .c-faq__text {
        flex: 1;
        font-weight: bold;
        font-size: min(calc(32 / var(--width-base) * var(--vw)), 32px);
        line-height: 1.4;
        letter-spacing: 0;
    }

    /* 茶色い丸（開閉で不変） */
    .c-faq__icon {
        flex-shrink: 0;
        margin-left: auto;
        position: relative;
        width: min(calc(76 / var(--width-base) * var(--vw)), 76px);
        height: min(calc(76 / var(--width-base) * var(--vw)), 76px);
        background-color: var(--color-text);
        border-radius: 50%;
    }

    /* 矢印＝疑似要素。既定（閉）＝下向き ∨ */
    .c-faq__icon::after {
        content: "";
        position: absolute;
        top: 50%;
        left: 50%;
        width: min(calc(24 / var(--width-base) * var(--vw)), 24px);
        height: min(calc(24 / var(--width-base) * var(--vw)), 24px);
        border-right: min(calc(5 / var(--width-base) * var(--vw)), 5px) solid #fff;
        border-bottom: min(calc(5 / var(--width-base) * var(--vw)), 5px) solid #fff;
        transform: translate(-50%, -65%) rotate(45deg);
        transition: transform .3s;
    }

    /* 開いたら上向き ^ */
    .c-faq__btn.is-open .c-faq__icon::after {
        transform: translate(-50%, -35%) rotate(225deg);
    }

    /* 回答エリア */
    .c-faq__answer {
        padding: min(calc(34 / var(--width-base) * var(--vw)), 34px) min(calc(24 / var(--width-base) * var(--vw)), 24px) min(calc(37 / var(--width-base) * var(--vw)), 37px) min(calc(27 / var(--width-base) * var(--vw)), 27px);
        p{
            letter-spacing: 0;
        }
    }
    .c-cta{
        padding: 0 0 min(calc(76 / var(--width-base) * var(--vw)), 76px);
    }
    .c-faq__answer--02{
        padding: min(calc(34 / var(--width-base) * var(--vw)), 34px) min(calc(24 / var(--width-base) * var(--vw)), 24px) min(calc(55 / var(--width-base) * var(--vw)), 55px) min(calc(27 / var(--width-base) * var(--vw)), 27px);
    }
    .c-faq__answer--03{
        padding: min(calc(34 / var(--width-base) * var(--vw)), 34px) min(calc(24 / var(--width-base) * var(--vw)), 24px) min(calc(60 / var(--width-base) * var(--vw)), 60px) min(calc(27 / var(--width-base) * var(--vw)), 27px);
    }
    .c-faq__answer--04{
        padding: min(calc(34 / var(--width-base) * var(--vw)), 34px) min(calc(24 / var(--width-base) * var(--vw)), 24px) min(calc(60 / var(--width-base) * var(--vw)), 60px) min(calc(27 / var(--width-base) * var(--vw)), 27px);
    }
    .c-faq__answer--05{
        padding: min(calc(34 / var(--width-base) * var(--vw)), 34px) min(calc(24 / var(--width-base) * var(--vw)), 24px) min(calc(62 / var(--width-base) * var(--vw)), 62px) min(calc(27 / var(--width-base) * var(--vw)), 27px);
    }
    .c-faq__answer--06{
        padding: min(calc(34 / var(--width-base) * var(--vw)), 34px) min(calc(24 / var(--width-base) * var(--vw)), 24px) min(calc(58 / var(--width-base) * var(--vw)), 58px) min(calc(27 / var(--width-base) * var(--vw)), 27px);
    }
    .c-faq__answer--07{
 padding: min(calc(34 / var(--width-base) * var(--vw)), 34px) min(calc(24 / var(--width-base) * var(--vw)), 24px) min(calc(52 / var(--width-base) * var(--vw)), 52px) min(calc(27 / var(--width-base) * var(--vw)), 27px);
    }
    .c-faq__answer--08{

    }
}


/* --------------------------------
c-footer
-------------------------------- */

/* --------------------------------
c-instagram
-------------------------------- */

.c-instagram {
    background-color: #FFF;
    padding: min(calc(50 / var(--width-base) * var(--vw)), 50px) 0 min(calc(60 / var(--width-base) * var(--vw)), 60px);

    .c-instagram__ttl {
        margin: min(calc(28 / var(--width-base) * var(--vw)), 28px) auto min(calc(52 / var(--width-base) * var(--vw)), 52px);
        text-align: center;

        img {
            display: inline-block;
            width: min(calc(360 / var(--width-base) * var(--vw)), 360px);
        }
    }

    .c-instagram__link {
        display: block;

        img {
/*            width: 100%;
            display: block;*/
			display: inline;
        }
    }
}


/* --------------------------------
c-footer
-------------------------------- */

.c-footer {
    width: 100%;
    background-color: #FFF;
    padding: min(calc(8 / var(--width-base) * var(--vw)), 50px) 0 min(calc(260 / var(--width-base) * var(--vw)), 260px);

    .c-footer__inner {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: min(calc(30 / var(--width-base) * var(--vw)), 30px);
    }

    .c-footer__logo {
        img {
            width: min(calc(470 / var(--width-base) * var(--vw)), 470px);
            display: block;
            margin: 0 auto;
        }
    }

    .c-footer__nav {
        display: flex;
        flex-direction: column;
        gap: min(calc(36 / var(--width-base) * var(--vw)), 36px);
        padding: min(calc(20 / var(--width-base) * var(--vw)), 20px) 0 min(calc(12 / var(--width-base) * var(--vw)), 12px);
    }

    .c-footer__nav-row {
        list-style: none;
        display: flex;
        align-items: center;
        justify-content: center;
        flex-wrap: wrap;
        gap: 0;

        li {
            display: flex;
            align-items: center;

            &:not(:first-child)::before {
                content: '';
                display: inline-block;
                width: 2px;
                height: min(calc(22 / var(--width-base) * var(--vw)), 22px);
                background-color: var(--color-text);
                margin: 0 min(calc(37 / var(--width-base) * var(--vw)), 37px);
            }

            a {
                font-size: min(calc(24 / var(--width-base) * var(--vw)), 24px);;
                line-height: 1.67;
                color: #804200;
            }
        }
    }

    .c-footer__copyright {
        font-size: min(calc(20 / var(--width-base) * var(--vw)), 20px);
        color: var(--color-text);
        text-align: center;
        line-height: 1.67;
        letter-spacing: 0.04em;
    }
}


/* --------------------------------
c-sticky
-------------------------------- */

.c-sticky {
    position: fixed;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%) translateY(100%);
    width: 100%;
    max-width: var(--width-content);
    background-color: var(--color-lightest);
    box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.18);
    padding: min(calc(30 / var(--width-base) * var(--vw)), 30px) min(calc(20 / var(--width-base) * var(--vw)), 20px)
    ;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: min(calc(10 / var(--width-base) * var(--vw)), 10px);
    z-index: 200;
    transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);

    &.is-visible {
        transform: translateX(-50%) translateY(0);
    }

    /* 境目のシャドウ */
    &::before {
        content: '';
        position: absolute;
        top: -30px;
        left: 0;
        right: 0;
        height: 30px;
        background: linear-gradient(to bottom, transparent, rgba(0, 0, 0, 0.12));
        pointer-events: none;
    }

    .c-sticky__txt {
        width: min(calc(760 / var(--width-base) * var(--vw)), 760px);
        display: block;
        position: absolute;
        top: max(calc(-42 / var(--width-base) * var(--vw)), -42px);
        opacity: 0;
        transition: opacity 0.3s;

        .is-visible & {
            opacity: 1;
        }
    }

    .c-sticky__btns {
        display: flex;
        gap: min(calc(16 / var(--width-base) * var(--vw)), 16px);
        justify-content: center;

        a {
            display: block;
            width: min(calc(290 / var(--width-base) * var(--vw)), 290px);

            img {
                width: 100%;
                display: block;
            }
        }
    }
}
