        /* --- デザイン変数 --- */
        :root {
            --bg-color: #F7F7F5;
            --text-main: #333333;
            --text-sub: #666666;
            --accent-color: #8E7866;
            --accent-dark: #2F353B;
            --white: #FFFFFF;
            --gold-gradient: linear-gradient(135deg, #E8CFA6 0%, #C69F68 100%);
            --gold-shadow: 0 4px 15px rgba(198, 159, 104, 0.4);
            --font-serif: 'Shippori Mincho', serif;
            --font-sans: 'Zen Kaku Gothic New', sans-serif;

            /* 追加：満足度No.1 用（濃いめのグレー） */
            --badge-gray: #808080;
        }

        /* --- Base Reset --- */
        * { margin: 0; padding: 0; box-sizing: border-box; }

        body {
            background-color: var(--bg-color);
            color: var(--text-main);
            font-family: var(--font-sans);
            line-height: 2;
            letter-spacing: 0.08em;
            padding-bottom: 100px; /* 固定フッター用余白 */
            overflow-x: hidden;
        }

        a { text-decoration: none; color: inherit; transition: all 0.4s ease; }
        a:hover { opacity: 0.8; }
        img { width: 100%; height: auto; display: block; object-fit: cover; }

        /* --- Typography & Utilities --- */
        h1, h2, h3, h4 { font-family: var(--font-serif); font-weight: 500; }
        
        .vertical-text {
            writing-mode: vertical-rl;
            text-orientation: upright;
            letter-spacing: 0.25em;
            line-height: 1.8;
        }

        .container {
            max-width: 1000px;
            margin: 0 auto;
            padding: 0 2rem;
        }

        /* =========================================================
           追加：スマホのときだけ改行する <br>（サイト全体で利用可）
           使い方：<br class="sp-only">
        ========================================================= */
        br.sp-only { display: none; }

        /* --- Header --- */
        header {
            position: fixed;
            top: 0; left: 0; width: 100%;
            padding: 1.5rem 3rem;
            display: flex;
            justify-content: space-between;
            align-items: center;
            z-index: 100;
            transition: background 0.3s;
        }
        
        header.scrolled {
            background-color: rgba(247, 247, 245, 0.95);
            backdrop-filter: blur(10px);
            padding: 1rem 3rem;
            border-bottom: 1px solid rgba(0,0,0,0.05);
        }

        .logo {
            font-family: var(--font-serif);
            font-size: 1.2rem;
            letter-spacing: 0.15em;
            color: var(--text-main);
            display: flex;
            flex-direction: column;
            line-height: 1;
        }
        
        .logo span {
            font-size: 0.65rem;
            font-family: var(--font-sans);
            color: var(--accent-color);
            margin-top: 5px;
            letter-spacing: 0.2em;
        }

        nav.desktop-nav { display: none; }
        @media (min-width: 768px) {
            nav.desktop-nav { display: block; }
            nav ul { display: flex; gap: 3rem; list-style: none; align-items: center; }
            nav li { font-size: 0.85rem; font-family: var(--font-serif); letter-spacing: 0.1em; }
            nav a { position: relative; }
            nav a::after {
                content: ''; position: absolute; bottom: -5px; left: 0; width: 0; height: 1px;
                background: var(--accent-dark); transition: width 0.3s;
            }
            nav a:hover::after { width: 100%; }
        }

        /* =========================================================
           修正：PCナビ「ご予約」→ CTAボタンと同じ色（gold-gradient）
        ========================================================= */
        .nav-reserve-btn {
            display: inline-flex;
            align-items: center;
            justify-content: center;

            /* CTAボタンと同じ色 */
            background: var(--gold-gradient);
            color: #fff;

            padding: 0.55rem 1.25rem;
            border-radius: 999px;
            font-size: 0.85rem;
            letter-spacing: 0.1em;
            font-family: var(--font-serif);
            transition: all 0.3s ease;

            /* CTAに寄せた影 */
            box-shadow: 0 10px 25px rgba(198, 159, 104, 0.4);

            position: relative;
            overflow: hidden;

            border: 1px solid rgba(255,255,255,0.25);
            text-shadow: 0 1px 2px rgba(0,0,0,0.12);
            line-height: 1;
            white-space: nowrap;
        }
        .nav-reserve-btn::before {
            content: '';
            position: absolute; top: -50%; left: -50%;
            width: 200%; height: 200%;
            background: linear-gradient(45deg, transparent, rgba(255,255,255,0.32), transparent);
            transform: rotate(45deg);
            animation: navShine 3.4s infinite;
        }
        @keyframes navShine { 0% { left: -100%; opacity: 0; } 50% { opacity: 1; } 100% { left: 100%; opacity: 0; } }
        .nav-reserve-btn:hover {
            transform: translateY(-1px);
            box-shadow: 0 15px 30px rgba(198, 159, 104, 0.5);
            opacity: 1;
        }
        /* 下線演出を無効化（ボタンなので） */
        nav a.nav-reserve-btn::after { content: none !important; }

        /* =========================================================
           追加：スマホ用ハンバーガー + モバイルメニュー
        ========================================================= */
        .hamburger {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            width: 46px;
            height: 46px;
            border-radius: 999px;
            background: rgba(255,255,255,0.85);
            border: 1px solid rgba(0,0,0,0.08);
            box-shadow: 0 10px 30px rgba(0,0,0,0.08);
            cursor: pointer;
            transition: all 0.25s ease;
        }
        .hamburger:hover { opacity: 1; transform: translateY(-1px); }
        .hamburger-lines {
            width: 18px;
            height: 12px;
            display: grid;
            gap: 4px;
        }
        .hamburger-lines span {
            display: block;
            height: 2px;
            width: 100%;
            background: var(--accent-dark);
            border-radius: 999px;
            transition: transform 0.25s ease, opacity 0.25s ease;
        }

        /* メニューオープン時：×に変形 */
        body.menu-open .hamburger-lines span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
        body.menu-open .hamburger-lines span:nth-child(2) { opacity: 0; }
        body.menu-open .hamburger-lines span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

        /* PCではハンバーガー非表示 */
        @media (min-width: 768px) {
            .hamburger { display: none; }
        }

        /* モバイルメニュー本体（オーバーレイ＋パネル） */
        .mobile-nav {
            position: fixed;
            inset: 0;
            z-index: 2000;
            opacity: 0;
            pointer-events: none;
            transition: opacity 0.25s ease;
        }
        .mobile-nav__overlay {
            position: absolute;
            inset: 0;
            background: rgba(0,0,0,0.28);
            backdrop-filter: blur(2px);
        }
        .mobile-nav__panel {
            position: absolute;
            top: 0;
            right: 0;
            width: min(88vw, 380px);
            height: 100%;
            background: rgba(247, 247, 245, 0.98);
            backdrop-filter: blur(18px);
            border-left: 1px solid rgba(0,0,0,0.08);
            box-shadow: -20px 0 50px rgba(0,0,0,0.12);
            transform: translateX(16px);
            transition: transform 0.25s ease;
            padding: 1.25rem 1.25rem 2rem;
            display: flex;
            flex-direction: column;
            gap: 1.2rem;
        }

        body.menu-open .mobile-nav {
            opacity: 1;
            pointer-events: auto;
        }
        body.menu-open .mobile-nav__panel {
            transform: translateX(0);
        }

        /* PCではモバイルメニュー自体も無効化 */
        @media (min-width: 768px) {
            .mobile-nav { display: none !important; }
        }

        /* =========================================================
           修正：モバイルメニュー上部のブランドを左右中央寄せ
        ========================================================= */
        .mobile-nav__top {
            display: grid;
            grid-template-columns: 1fr auto 1fr;
            align-items: center;
            gap: 1rem;
            padding-bottom: 0.8rem;
            border-bottom: 1px solid rgba(0,0,0,0.08);
        }
        .mobile-nav__brand {
            font-family: var(--font-serif);
            letter-spacing: 0.15em;
            line-height: 1.1;
            display: flex;
            flex-direction: column;

            /* 中央寄せ */
            align-items: center;
            text-align: center;
            grid-column: 2;
            justify-self: center;
        }
        .mobile-nav__brand span {
            font-size: 0.65rem;
            font-family: var(--font-sans);
            color: var(--accent-color);
            margin-top: 4px;
            letter-spacing: 0.2em;
        }

        .mobile-nav__close {
            width: 42px;
            height: 42px;
            border-radius: 999px;
            background: rgba(255,255,255,0.9);
            border: 1px solid rgba(0,0,0,0.08);
            box-shadow: 0 10px 28px rgba(0,0,0,0.08);
            cursor: pointer;
            display: inline-flex;
            align-items: center;
            justify-content: center;

            /* グリッド右端 */
            grid-column: 3;
            justify-self: end;
        }
        .mobile-nav__close i { color: var(--accent-dark); }

        .mobile-nav__list {
            list-style: none;
            display: flex;
            flex-direction: column;
            gap: 0.9rem;
            margin-top: 0.6rem;
        }
        .mobile-nav__list a {
            display: block;
            padding: 0.75rem 0.2rem;
            font-family: var(--font-serif);
            font-size: 1rem;
            letter-spacing: 0.1em;
        }

        .mobile-nav__sub {
            margin-top: auto;
            padding-top: 1.2rem;
            border-top: 1px solid rgba(0,0,0,0.08);
            display: flex;
            flex-direction: column;
            gap: 0.6rem;
        }
        .mobile-nav__sub a {
            font-size: 0.85rem;
            color: var(--text-sub);
            letter-spacing: 0.08em;
            padding: 0.35rem 0.2rem;
        }

        /* メニューオープン中は背面スクロール禁止 */
        body.menu-open { overflow: hidden; }

        /* =========================================================
           追加：Heroで使っている「動くグラデーション装飾」を
           他セクションでも使える共通クラスにする
           適用先：CTA(一人で抱え込む前に...), お悩み, FAQ
        ========================================================= */
        .aurora-section {
            position: relative;
            overflow: hidden;
        }
        .aurora-section::before {
            content: '';
            position: absolute;
            inset: -180px; /* ブラーのはみ出し対策 */
            pointer-events: none;
            z-index: 0;

            background:
                radial-gradient(circle at 12% 18%, rgba(255, 205, 226, 0.78) 0%, transparent 58%),
                radial-gradient(circle at 86% 16%, rgba(195, 230, 255, 0.78) 0%, transparent 58%),
                radial-gradient(circle at 82% 86%, rgba(224, 206, 255, 0.78) 0%, transparent 58%),
                radial-gradient(circle at 18% 88%, rgba(198, 255, 234, 0.78) 0%, transparent 58%),
                linear-gradient(120deg,
                    rgba(255, 246, 232, 0.72) 0%,
                    rgba(236, 248, 255, 0.72) 50%,
                    rgba(248, 236, 255, 0.72) 100%
                );

            background-size: 240% 240%;
            background-position: 0% 50%;
            filter: blur(40px) saturate(140%);
            opacity: 0.55;

            will-change: transform, background-position;
            animation: auroraSectionMove 26s ease-in-out infinite;
            transform: translate3d(0,0,0);
        }
        /* 読みやすさを保つ薄い白ベール（グラデを消さない程度） */
        .aurora-section::after {
            content: '';
            position: absolute;
            inset: 0;
            pointer-events: none;
            z-index: 1;
            background: rgba(255,255,255,0.22);
        }
        /* aurora-section内の実コンテンツは前面へ */
        .aurora-section > .container {
            position: relative;
            z-index: 2;
        }

        @keyframes auroraSectionMove {
            0% {
                background-position: 0% 50%;
                transform: rotate(0deg) scale(1.06);
            }
            50% {
                background-position: 100% 50%;
                transform: rotate(180deg) scale(1.12);
            }
            100% {
                background-position: 0% 50%;
                transform: rotate(360deg) scale(1.06);
            }
        }

        /* --- Hero Section --- */
        .hero {
            position: relative;
            height: 100vh;
            display: flex;
            align-items: center;
            justify-content: center;
            overflow: hidden;
        }

        .hero-video {
            position: absolute;
            top: 0; left: 0;
            width: 100%; height: 100%;
            object-fit: cover;
            z-index: 0;
            opacity: 0.7;
            filter: grayscale(20%) sepia(10%);
        }
        
        .hero::after {
            content: '';
            position: absolute;
            inset: 0;
            background: rgba(255, 255, 255, 0.4);
            z-index: 1;
        }

        .hero-content {
            position: relative;
            z-index: 10;
            display: flex;
            flex-direction: row-reverse;
            align-items: center;
            gap: 4rem;
            padding: 2rem;

            /* ★追加：横幅を固定（可変上限付き）して、文字出現中に伸縮しないようにする */
            width: clamp(320px, 88vw, 580px);

            /* 既存の“ガラスっぽさ”は維持しつつ、グラデが見えるよう少し調整 */
            background: rgba(255, 255, 255, 0.76);
            backdrop-filter: blur(10px);

            box-shadow: 0 20px 40px rgba(0,0,0,0.05);
            border: 1px solid rgba(255,255,255,0.5);

            /* 追加：動くグラデーションを枠内に収める */
            overflow: hidden;
        }

        /* ★追加：Flex要素の幅変動がレイアウトに影響しにくいように */
        .hero-title-area,
        .hero-sub {
            flex: 0 0 auto;
        }

        /* =========================================================
           Hero枠内の動くグラデーション（既存のまま）
        ========================================================= */
        .hero-content::before {
            content: '';
            position: absolute;
            inset: -140px;
            pointer-events: none;
            z-index: 0;

            background:
                radial-gradient(circle at 12% 18%, rgba(255, 205, 226, 0.78) 0%, transparent 58%),
                radial-gradient(circle at 86% 16%, rgba(195, 230, 255, 0.78) 0%, transparent 58%),
                radial-gradient(circle at 82% 86%, rgba(224, 206, 255, 0.78) 0%, transparent 58%),
                radial-gradient(circle at 18% 88%, rgba(198, 255, 234, 0.78) 0%, transparent 58%),
                linear-gradient(120deg,
                    rgba(255, 246, 232, 0.72) 0%,
                    rgba(236, 248, 255, 0.72) 50%,
                    rgba(248, 236, 255, 0.72) 100%
                );

            background-size: 220% 220%;
            background-position: 0% 50%;
            filter: blur(26px) saturate(140%);
            opacity: 0.62;

            will-change: transform, background-position;
            animation: heroAuroraMove 18s ease-in-out infinite;
            transform: translate3d(0,0,0);
        }

        /* hero-content の中身を、グラデーションより前面へ */
        .hero-title-area,
        .hero-sub,
        .scroll-indicator {
            position: relative;
            z-index: 2;
        }

        @keyframes heroAuroraMove {
            0% {
                background-position: 0% 50%;
                transform: rotate(0deg) scale(1.06);
            }
            50% {
                background-position: 100% 50%;
                transform: rotate(180deg) scale(1.12);
            }
            100% {
                background-position: 0% 50%;
                transform: rotate(360deg) scale(1.06);
            }
        }

        .hero-title-area {
            height: 350px;
            border-left: 1px solid var(--accent-dark);
            padding-left: 2rem;
            display: flex;
            flex-direction: column;
            justify-content: space-between;
        }

        .hero h1 { font-size: 2.5rem; color: var(--text-main); height: 100%; margin: 0; }
        .hero-sub {
            writing-mode: vertical-rl;
            font-size: 0.8rem;
            color: var(--text-sub);
            letter-spacing: 0.2em;
            margin-right: 1rem;
        }

        /* =========================================================
           追加：hero-sub内の強調（「僧侶」「四柱推命」）
           - HTMLでspan.hero-sub-emを付与（非アニメ時/スマホ時）
           - PCのアニメ時は1文字=span.hero-charになるため、nth-of-typeで同じ装飾を適用
        ========================================================= */
        .hero-sub-em {
            font-size: 1.2em;
            font-weight: 700;
            color: #333333;
        }
        #heroSub .hero-char:nth-of-type(1),
        #heroSub .hero-char:nth-of-type(2),
        #heroSub .hero-char:nth-of-type(6),
        #heroSub .hero-char:nth-of-type(7),
        #heroSub .hero-char:nth-of-type(8),
        #heroSub .hero-char:nth-of-type(9) {
            font-size: 1.2em;
            font-weight: 700;
            color: #333333;
        }

        .hero-location {
            writing-mode: horizontal-tb;
            position: absolute;
            bottom: 2rem; right: 3rem;
            font-size: 0.8rem;
            font-family: var(--font-serif);
            letter-spacing: 0.2em;
            color: var(--text-main);
            display: flex; align-items: center; gap: 1rem;
            z-index: 10;
        }
        
        .hero-location::before { content: ''; width: 30px; height: 1px; background: var(--text-main); }

        /* =========================================================
           追加：Hero（hero-content下部中央）に点滅SCROLL表示
        ========================================================= */
        .scroll-indicator {
            position: absolute;
            left: 50%;
            bottom: 0.9rem;
            transform: translateX(-50%);
            font-family: var(--font-serif);
            font-size: 0.75rem;
            letter-spacing: 0.35em;
            color: var(--accent-dark);
            opacity: 0.6;
            animation: scrollBlink 1.2s infinite;
            pointer-events: none;
            user-select: none;
            text-shadow: 0 2px 10px rgba(0,0,0,0.06);
        }
        @keyframes scrollBlink {
            0%, 100% { opacity: 0.15; }
            50%      { opacity: 0.9; }
        }

        /* =========================================================
           追加：Heroの文字を順番に表示するためのスタイル
           - JS有効時は最初は非表示
           - hero-sub：スルスル（速め）
           - hero-title：1文字ずつ0.3秒
           - SCROLL：最後に表示
           ※現在のタイトルは「0.2秒/1文字」に設定（JS内で変更可）
        ========================================================= */
        html.js #heroSub,
        html.js #heroTitle {
            visibility: hidden;
        }

        /* SCROLLは最後に表示したいのでJS時は非表示＆点滅停止 */
        html.js #heroScroll {
            visibility: hidden;
            opacity: 0;
            animation: none;
            transform: translateX(-50%) translateY(6px);
            transition: opacity 0.6s ease, transform 0.6s ease;
        }
        html.js #heroScroll.is-shown {
            visibility: visible;
            opacity: 0.6;
            transform: translateX(-50%) translateY(0);
            animation: scrollBlink 1.2s infinite;
        }

        /* 文字1つずつの表示（共通） */
        .hero-char {
            display: inline-block;
            opacity: 0;
            transform: translate3d(0, 0.35em, 0);
            filter: blur(1px);
            transition: opacity 0.45s ease, transform 0.45s ease, filter 0.45s ease;
            will-change: opacity, transform, filter;
        }
        .hero-char.is-visible {
            opacity: 1;
            transform: translate3d(0, 0, 0);
            filter: blur(0);
        }

        /* =========================================================
           追加：タイトル用「ほんの少し拡大/フェード」
           - タイトルだけ span に hero-char--title を付与して演出
           - 少し小さめ(0.94)→等倍(1)へ（=拡大）
        ========================================================= */
        .hero-char--title {
            transform: translate3d(0, 0.18em, 0) scale(0.94);
            filter: blur(0.8px);
            transition: opacity 0.55s ease, transform 0.55s ease, filter 0.55s ease;
            transform-origin: center center;
        }
        .hero-char--title.is-visible {
            transform: translate3d(0, 0, 0) scale(1);
            filter: blur(0);
        }

        /* 動きを減らしたいユーザー設定への配慮（Hero + aurora-section共通で止める）
           ※既存の記述を保持しつつ、scroll-indicatorは!importantで確実に無効化 */
        @media (prefers-reduced-motion: reduce) {
            .hero-content::before,
            .aurora-section::before { animation: none; }

            .scroll-indicator { animation: none !important; opacity: 0.2 !important; }

            /* JSが有効でも、reduceの場合はHero文字を隠さず即表示 */
            html.js #heroSub,
            html.js #heroTitle {
                visibility: visible !important;
            }
            html.js #heroScroll {
                visibility: visible !important;
                opacity: 0.2 !important;
                transform: translateX(-50%) translateY(0) !important;
                animation: none !important;
            }
        }

        /* --- Section Common --- */
        .section-padding { padding: 8rem 0; }
        .section-header {
            margin-bottom: 5rem;
            position: relative;
            display: flex;
            flex-direction: column;
            align-items: center;
        }
        .section-title-en {
            font-family: var(--font-serif);
            font-size: 4rem;
            color: rgba(0,0,0,0.03);
            position: absolute;
            top: 50%; left: 50%;
            transform: translate(-50%, -50%);
            white-space: nowrap;
            z-index: -1;
            letter-spacing: 0.1em;
        }
        .section-title-jp {
            font-size: 1.5rem;
            font-family: var(--font-serif);
            background: var(--bg-color);
            padding: 0 1rem;
            z-index: 1;
        }

        /* =========================================================
           追加：スマホで特定セクションの上余白を増やす（お悩み/FAQ用）
        ========================================================= */
        .section-padding--sp-gap { /* PCは既存のまま */ }

        /* --- Worries Section --- */
        .worries-intro { text-align: center; margin-bottom: 4rem; font-size: 1.1rem; line-height: 2; }
        .worries-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
            gap: 2rem;
        }
        .worry-item {
            background: var(--white);
            padding: 2.5rem 2rem;
            text-align: center;
            box-shadow: 0 5px 20px rgba(0,0,0,0.03);
            border-radius: 8px;
            transition: transform 0.3s;

            /* =========================================================
               追加：背景画像を敷くための土台
            ========================================================= */
            position: relative;
            overflow: hidden;
        }

        /* =========================================================
           追加：worry-item 背景画像（透明度50%）
           - 画像は疑似要素に載せて、文字は前面へ
        ========================================================= */
        .worry-item::before {
            content: '';
            position: absolute;
            inset: 0;
            background-size: cover;
            background-position: center;
            background-repeat: no-repeat;
            opacity: 0.05;               /* ★画像の透明度 50% */
            z-index: 0;
            border-radius: inherit;
        }
        .worry-item > * {
            position: relative;
            z-index: 1;
        }

        /* ★3項目それぞれの背景画像 */
        .worry-item--n1::before { background-image: url('../../images/n_back1.jpg'); }
        .worry-item--n2::before { background-image: url('../../images/n_back2.jpg'); }
        .worry-item--n3::before { background-image: url('../../images/n_back3.jpg'); }

        .worry-item:hover { transform: translateY(-5px); }
        .worry-icon { font-size: 2.5rem; display: block; margin-bottom: 1rem; }
        .worry-text { font-family: var(--font-serif); font-size: 1.05rem; }

        /* --- Reasons Section --- */
        .reasons-sub { text-align: center; margin-bottom: 4rem; color: var(--text-sub); }
        .reasons-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
            gap: 2rem;
        }
        .reason-card {
            border: 1px solid rgba(0,0,0,0.08);
            padding: 2.5rem;
            background: var(--white);
            text-align: center;
        }
        .reason-title {
            font-family: var(--font-serif);
            font-size: 1.25rem;
            margin-bottom: 1.5rem;
            color: var(--accent-dark);
            border-bottom: 1px solid var(--accent-color);
            display: inline-block;
            padding-bottom: 0.5rem;
        }
        .reason-desc { font-size: 0.95rem; text-align: justify; }

        /* 理由カードのペール背景 */
        .reason-card--trust { background-color: #f5fbff; }
        .reason-card--advice { background-color: #fff7f1; }
        .reason-card--monk { background-color: #f5fbf7; }

        /* 丸枠画像 */
        .section-header--reasons { margin-bottom: 2.5rem; }
        .cp-circle {
            width: 160px;
            height: 160px;
            border-radius: 50%;
            overflow: hidden;
            background: var(--white);
            border: 2px solid rgba(142, 120, 102, 0.35);
            box-shadow: 0 12px 30px rgba(0,0,0,0.08);
            margin-top: 2.2rem;
        }
        .cp-circle img {
            width: 100%;
            height: 100%;
            object-fit: cover;
        }

        /* --- Profile Section --- */
        .concept-wrapper {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 4rem;
            align-items: start;
        }
        .profile-section--primary { padding-bottom: 0; }
        .profile-section--secondary { padding-top: 0; }
        .profile-divider {
            display: flex;
            justify-content: center;
            align-items: center;
            margin: 5.5rem auto;
        }
        .profile-divider::before {
            content: '';
            width: min(240px, 60%);
            height: 1px;
            display: block;
            background: linear-gradient(
                90deg,
                rgba(142, 120, 102, 0),
                rgba(142, 120, 102, 0.42) 20%,
                rgba(198, 159, 104, 0.95) 50%,
                rgba(142, 120, 102, 0.42) 80%,
                rgba(142, 120, 102, 0)
            );
        }
        .concept-image { position: relative; }
        .concept-image img { width: 100%; aspect-ratio: 4/4; filter: grayscale(10%); }
        .concept-image::before {
            content: '';
            position: absolute;
            top: -20px; left: -20px;
            width: 100%; height: 100%;
            border: 1px solid var(--accent-color);
            z-index: -1;
        }
        .concept-text h3 { font-size: 1.6rem; margin-bottom: 2rem; line-height: 1.6; }

        /* =========================================================
           追加：プロフィールSNSアイコン（5つ）※ありものに差し替え
        ========================================================= */
        .social-links {
            display: flex;
            flex-wrap: wrap;
            gap: 0.9rem;
            align-items: center;
            margin: -0.6rem 0 1.6rem; /* h3直下でも詰まり過ぎないよう調整 */
        }
        .social-icon {
            width: 46px;
            height: 46px;
            border-radius: 999px;
            display: grid;
            place-items: center;
            background: rgba(255,255,255,0.9);
            border: 1px solid rgba(0,0,0,0.08);
            box-shadow: 0 8px 22px rgba(0,0,0,0.06);
            position: relative;
        }
        .social-icon i {
            font-size: 20px;
            color: var(--accent-dark);
            opacity: 0.88;
            line-height: 1;
        }
        .social-icon:hover i { opacity: 1; }
        .social-icon:focus-visible {
            outline: 2px solid rgba(198, 159, 104, 0.65);
            outline-offset: 3px;
        }
        .social-icon[data-tag]::after {
            content: attr(data-tag);
            position: absolute;
            bottom: -8px;
            right: -8px;
            font-size: 0.55rem;
            letter-spacing: 0.06em;
            padding: 2px 7px;
            border-radius: 999px;
            background: rgba(255,255,255,0.95);
            border: 1px solid rgba(0,0,0,0.12);
            color: var(--accent-dark);
            box-shadow: 0 4px 12px rgba(0,0,0,0.06);
        }

        .profile-table { margin-top: 2rem; font-size: 0.9rem; border-top: 1px solid #ddd; }
        .profile-row {
            display: grid; grid-template-columns: 80px 1fr;
            padding: 1rem 0; border-bottom: 1px solid #ddd;
        }
        .profile-label { color: var(--accent-color); font-weight: 500; }

        /* --- Divination Section --- */
        .divination-list {
            display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; margin-top: 2rem;
        }
        .divination-item {
            background: var(--white); padding: 2rem;
            border: 1px solid rgba(0,0,0,0.05); transition: transform 0.3s;
        }
        .divination-item:hover { transform: translateY(-5px); border-color: var(--accent-color); }
        .divination-head {
            display: flex; align-items: center; margin-bottom: 1rem;
            border-bottom: 1px solid #eee; padding-bottom: 0.8rem;
        }
        .divination-img {
            width: 50px; height: 50px; object-fit: contain;
            margin-right: 1.2rem;
        }
        .divination-title { font-size: 1.15rem; color: var(--accent-dark); }
        .divination-desc { font-size: 0.85rem; color: var(--text-sub); text-align: justify; line-height: 1.8; }

        /* --- Emotional Section --- */
        .emotional-section {
            background-image: url('../../images/back1.jpg');
            background-attachment: fixed;
            background-position: center;
            background-size: cover;
            padding: 10rem 2rem;
            position: relative;
            color: var(--white);
            text-align: center;
        }
        .emotional-overlay {
            position: absolute; inset: 0;
            background: rgba(0,0,0,0.5);
        }
        .emotional-content { position: relative; z-index: 1; max-width: 800px; margin: 0 auto; }
        .emotional-title {
            font-family: var(--font-serif);
            font-size: 2rem;
            margin-bottom: 3rem;
            line-height: 1.6;
            text-shadow: 0 2px 10px rgba(0,0,0,0.3);
        }
        .emotional-text { font-size: 1.1rem; line-height: 2.2; }

        /* --- Menu Section --- */
        .menu-wrapper {
            background-color: var(--white); padding: 4rem 4rem 2rem;
            box-shadow: 0 10px 40px rgba(0,0,0,0.02); position: relative;
        }
        .menu-wrapper::after {
            content: ''; position: absolute; top: 0; left: 0; width: 4px; height: 100%;
            background-color: var(--accent-dark);
        }
        .menu-category { margin-bottom: 4rem; }

        .menu-category--normal {
            background-color: #fff2f6;
            padding: 2rem 2rem 1.5rem;
            border-radius: 10px;
        }
        .menu-category--late {
            background-color: #f4f4f4;
            padding: 2rem 2rem 1.5rem;
            border-radius: 10px;
        }

        .menu-category-title {
            font-family: var(--font-serif); font-size: 1.1rem; color: var(--accent-color);
            margin-bottom: 1.5rem; display: flex; align-items: center; gap: 1rem;
        }
        .menu-category-title::after { content: ''; flex: 1; height: 1px; background-color: #eee; }
        .price-row {
            display: flex; justify-content: space-between; align-items: center;
            padding: 1.2rem 0; border-bottom: 1px solid #f5f5f5; transition: transform 0.3s ease;
        }
        /* ★修正：満足度No.1 / 人気No.1 等の「枠」まで消さないように除外 */
        .price-row:last-child:not(.recommended-plan):not(.satisfaction-plan) { border-bottom: none; }

        .price-name {
            font-family: var(--font-serif); font-size: 1.0rem; font-weight: 500;
            display: flex; align-items: baseline; gap: 1rem;
        }
        .price-time { font-family: var(--font-sans); font-size: 0.9rem; color: var(--text-sub); width: 60px; }
        .price-amount { font-family: var(--font-serif); font-size: 1.3rem; color: var(--accent-dark); letter-spacing: 0.05em; }
        
        .recommended-plan {
            background: linear-gradient(to right, #faf8f5, #fffcf9);
            border: 2px solid #E8CFA6; border-radius: 8px;
            padding: 1.5rem 1.5rem !important; margin: 1.5rem 0;
            position: relative; box-shadow: 0 4px 20px rgba(142, 120, 102, 0.1); z-index: 1;
        }
        .recommended-badge {
            position: absolute; top: -12px; left: 20px;
            background: var(--gold-gradient); color: #fff; font-size: 0.75rem;
            padding: 4px 14px; border-radius: 20px; box-shadow: 0 3px 6px rgba(0,0,0,0.1);
            letter-spacing: 0.1em; font-family: var(--font-sans); font-weight: 500;
        }
        
        /* Amebloアイコンの配置（上下左右中央） */
        .social-icon--ameblo{
          display: inline-flex;      /* 既にflexでもOK。上書きしても問題になりにくい */
          align-items: center;       /* 縦中央 */
          justify-content: center;   /* 横中央 */
        }
        
        /* Amebloの黒マークを 1/2 サイズ（縦横比維持） */
        .social-img--ameblo{
          width: 40%;
          height: 40%;
          object-fit: contain; /* 念のため：縦横比維持で収める */
          display: block;
        }

        /* =========================================================
           追加：満足度No.1（濃いめグレー）枠＆バッジ
           - 「人気No.1」「おすすめ」と同じ感じ
        ========================================================= */
        .satisfaction-plan {
            background: linear-gradient(to right, #f7f7f7, #ffffff);
            border: 2px solid var(--badge-gray);
            border-radius: 8px;
            padding: 1.5rem 1.5rem !important;
            margin: 1.5rem 0;
            position: relative;
            box-shadow: 0 4px 20px rgba(47, 53, 59, 0.12);
            z-index: 1;

            /* ★保険：最下部の枠線も確実に表示 */
            border-bottom: 2px solid var(--badge-gray);
        }
        .satisfaction-badge {
            position: absolute;
            top: -12px;
            left: 20px;
            background: var(--badge-gray); /* 塗り：濃いめグレー */
            color: #fff;
            font-size: 0.75rem;
            padding: 4px 14px;
            border-radius: 20px;
            box-shadow: 0 6px 18px rgba(47, 53, 59, 0.22);
            letter-spacing: 0.1em;
            font-family: var(--font-sans);
            font-weight: 500;
        }

        .discount-badge {
            display: inline-block; background: var(--gold-gradient); color: #fff;
            font-size: 0.8rem; padding: 0.2rem 1rem; border-radius: 20px;
            margin-left: 1rem; box-shadow: var(--gold-shadow); vertical-align: middle;
        }

        /* =========================================================
           修正：学生割引（スマホ時に読みやすいレイアウトに）
           ※文言は変更なし
        ========================================================= */
        .student-discount {
            background-color: #faf8f5;
            padding: 1.5rem;
            border-radius: 8px;
            border: none;
            margin-bottom: 3rem;
        }
        .student-discount .price-name {
            color: var(--accent-color);
        }
        .student-discount .price-amount {
            font-size: 0.8rem;
            text-align: right;
            line-height: 1.4;
        }
        .student-discount__amount {
            font-size: 1.2rem;
            color: #C69F68;
        }
        .student-discount__note {
            font-size: 0.7rem;
            color: #999;
            font-weight: normal;
            font-family: var(--font-sans);
        }

        .special-menu {
            background-color: #faf8f5;
            padding: 2rem;
            border-radius: 4px;
            margin-top: 1.5rem;
            margin-bottom: 2rem;
        }
        .special-menu h4 {
            color: var(--accent-color);
            font-size: 0.9rem;
            margin-bottom: 1rem;
            display: flex;
            align-items: center;
            gap: 0.5rem;
        }

        /* =========================================================
           追加：その他・特別メニュー（Special）
           - 価格を説明文の下に折り返し、右寄せで表示
           - インラインCSSを撤廃し、読みやすい幅に調整
        ========================================================= */
        .special-badge {
            font-size: 0.8rem;
            border: 1px solid var(--accent-color);
            padding: 2px 8px;
            border-radius: 10px;
        }

        .special-menu .price-row {
            border-bottom: none;
            padding-bottom: 0;
            flex-wrap: wrap;
            align-items: flex-start;
        }

        .special-menu .price-name {
            display: block;
            width: 100%;
            flex: 0 0 100%;
        }

        .special-menu-desc {
            width: 100%;
            font-size: 0.8rem;
            color: var(--text-sub);
            font-weight: normal;
            margin-top: 0.5rem;
            line-height: 1.8;
        }

        .special-menu .price-amount {
            width: 100%;
            flex: 0 0 100%;
            text-align: right;
            margin-left: 0;
            margin-top: 0.75rem;
        }

        /* 電話鑑定：準備中の表示 */
        .price-amount--preparing {
            font-size: 1rem;
            color: var(--text-main);
        }

        /* メニュー内 注釈 */
        .menu-note {
            margin-top: 2rem;
            text-align: right;
            font-size: 0.8rem;
            color: #999;
            line-height: 1.6;
        }

        /* --- CTA Section --- */
        .cta-section { text-align: center; padding: 6rem 0; background-color: #fffaf5; }
        .cta-title { font-size: 1.6rem; margin-bottom: 2rem; line-height: 1.5; color: var(--accent-dark); }
        .cta-text { margin-bottom: 2.5rem; color: var(--text-sub);font-size: 0.9rem; }
        .cta-btn {
            display: inline-block;
            background: var(--gold-gradient);
            color: #fff;
            padding: 1.2rem 4rem;
            border-radius: 50px;
            font-size: 1.1rem;
            font-family: var(--font-serif);
            letter-spacing: 0.1em;
            box-shadow: 0 10px 25px rgba(198, 159, 104, 0.4);
            transition: all 0.3s;
        }
        .cta-btn:hover { transform: translateY(-3px); box-shadow: 0 15px 30px rgba(198, 159, 104, 0.5); opacity: 1; }

        /* 指定CTAだけ背景 back2.jpg + 透明度50% */
        .cta-section--bg {
            position: relative;
            overflow: hidden;
        }
        .cta-section--bg::before {
            content: '';
            position: absolute;
            inset: 0;
            background-image: url('../../images/back2.jpg');
            background-size: cover;
            background-position: center;
            background-repeat: no-repeat;
            opacity: 0.5;
            z-index: 0;
            pointer-events: none;
        }
        .cta-section--bg .container {
            position: relative;
            z-index: 1;
        }

        /* --- FAQ Section --- */
        .faq-list { max-width: 800px; margin: 0 auto; }
        .faq-item { background: var(--white); border-bottom: 1px solid #eee; margin-bottom: 1rem; }
        .faq-question {
            padding: 1.5rem; cursor: pointer; font-weight: 500;
            display: flex; justify-content: space-between; align-items: center;
            font-family: var(--font-serif); font-size: 1.1rem;
        }
        .faq-question::after {
            content: '+'; font-size: 1.5rem; color: var(--accent-color); transition: transform 0.3s;
        }
        .faq-question.active::after { transform: rotate(45deg); }
        .faq-answer {
            padding: 0 1.5rem 1.5rem; display: none; color: var(--text-sub);
            line-height: 1.8;
        }
        .faq-answer.show { display: block; animation: fadeIn 0.5s; }
        @keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }

        /* --- Access Section --- */
        .access-box {
            background-color: var(--accent-dark); color: var(--white);
            padding: 4rem; display: grid; grid-template-columns: 1fr; gap: 4rem;
        }
        .access-info h3 {
            font-size: 1.5rem; margin-bottom: 2rem;
            border-bottom: 1px solid rgba(255,255,255,0.2);
            padding-bottom: 1rem; display: inline-block;
        }
        .access-detail p { margin-bottom: 1rem; font-size: 0.95rem; opacity: 0.9; line-height: 1.8; }
        .map-btn {
            display: inline-block; margin-top: 1.5rem; border: 1px solid rgba(255,255,255,0.4);
            padding: 0.8rem 2rem; font-size: 0.9rem; color: var(--white); transition: all 0.3s;
        }
        .map-btn:hover {
            background: var(--gold-gradient); border-color: transparent; color: #fff;
            box-shadow: 0 0 20px rgba(198, 159, 104, 0.5);
        }
        .access-map { width: 100%; height: 100%; min-height: 350px; position: relative; }
        .access-map iframe {
            width: 100%; height: 100%; border: 1px solid rgba(255,255,255,0.2); filter: grayscale(0.2);
        }

        /* --- Sticky Footer --- */
        .sticky-bar {
            position: fixed; bottom: 20px; left: 50%; transform: translateX(-50%);
            width: 90%; max-width: 650px; background: rgba(255,255,255,0.95);
            backdrop-filter: blur(15px); padding: 0.8rem 1.5rem; border-radius: 50px;
            box-shadow: 0 10px 40px rgba(0,0,0,0.15); display: flex; justify-content: space-between;
            align-items: center; z-index: 999; border: 1px solid rgba(255, 255, 255, 0.8);
        }
        .sticky-info { display: flex; flex-direction: column; padding-left: 1rem; }
        .sticky-label { font-size: 0.65rem; color: #C69F68; letter-spacing: 0.15em; margin-bottom: 2px; }
        .sticky-main { font-family: var(--font-serif); font-size: 1.1rem; color: var(--text-main); }

        /* Stickyボタン：落ち着いた赤系（#cc0033） */
        .sticky-btn {
            background: linear-gradient(135deg, #cc0033 0%, #a8002a 100%);
            color: #fff;
            padding: 0.9rem 2.5rem;
            border-radius: 30px;
            font-size: 0.95rem;
            letter-spacing: 0.1em;
            font-family: var(--font-serif);
            transition: all 0.3s ease;
            box-shadow: 0 10px 25px rgba(204, 0, 51, 0.28);
            position: relative;
            overflow: hidden;
            border: 1px solid rgba(255,255,255,0.25);
            text-shadow: 0 1px 2px rgba(0,0,0,0.12);
        }
        .sticky-btn::before {
            content: '';
            position: absolute; top: -50%; left: -50%;
            width: 200%; height: 200%;
            background: linear-gradient(45deg, transparent, rgba(255,255,255,0.32), transparent);
            transform: rotate(45deg);
            animation: shine 3s infinite;
        }
        @keyframes shine { 0% { left: -100%; opacity: 0; } 50% { opacity: 1; } 100% { left: 100%; opacity: 0; } }
        .sticky-btn:hover { transform: translateY(-2px); box-shadow: 0 14px 28px rgba(204, 0, 51, 0.36); opacity: 1; }

        /* --- Footer --- */
        footer { text-align: center; padding: 2rem; font-size: 0.7rem; color: var(--text-sub); }

        /* =========================================================
           追加：フッターのさり気ないリンク（コピーライトの上）
        ========================================================= */
        .footer-links {
            display: flex;
            justify-content: center;
            gap: 1.6rem;
            margin-bottom: 0.55rem;
            font-size: 0.75rem;
            color: var(--text-sub);
        }
        .footer-links a {
            color: var(--text-sub);
            position: relative;
            letter-spacing: 0.06em;

            /* ★修正：スマホで文字が改行されないように */
            white-space: nowrap;
        }
        .footer-links a::after {
            content: '';
            position: absolute;
            left: 0;
            bottom: -3px;
            width: 0;
            height: 1px;
            background: rgba(47,53,59,0.35);
            transition: width 0.3s ease;
        }
        .footer-links a:hover::after { width: 100%; }

        /* --- Mobile Optimizations --- */
        @media (max-width: 768px) {
            header { padding: 1rem; }
            .container { padding: 0 1.5rem; }

            br.sp-only { display: inline; }

            /* スマホで「お悩み」「FAQ」上余白を増やす */
            .section-padding--sp-gap { padding-top: 10rem; }

            .hero { height: 100dvh; }

            /* =========================================================
               追加：スマホHeroは動画を使わず画像背景に（低スペック/弱回線配慮）
               ※動画要素は表示しない（CSS）＋ sourceはPC幅のみ（HTML側）で実質読み込まれません
            ========================================================= */
            .hero {
                background-image: url('../../movie/osaka.jpg');
                background-size: cover;
                background-position: center;
            }
            .hero-video { display: none; }

            /* =========================================================
               修正：スマホHeroが縦に長すぎる → gapとpaddingを詰めて短くする
               （文章は変更なし）
            ========================================================= */
            .hero-content {
                flex-direction: column-reverse;
                width: 90%;

                /* ここを詰めて高さを短く */
                gap: 1.25rem;
                padding: 1.2rem 1rem 2.2rem;
            }

            .hero-title-area {
                height: auto; min-height: 250px; border-left: none;
                border-bottom: 1px solid var(--accent-dark);

                /* ここも少し詰めて高さを短く */
                padding-left: 0;
                padding-bottom: 1.4rem;

                width: 100%; text-align: center;
            }
            .hero h1 { writing-mode: vertical-rl; margin: 0 auto; height: 250px; font-size: 2.2rem; }
            .hero-sub { writing-mode: horizontal-tb; margin-bottom: 0.6rem; margin-right: 0; }

            .hero-content::before {
                filter: blur(22px) saturate(135%);
                animation-duration: 22s;
            }
            .aurora-section::before {
                filter: blur(34px) saturate(135%);
                animation-duration: 30s;
            }

            /* =========================================================
               追加：スマホではHero内のアニメーションはタイトルのみ
               - hero-sub：アニメなし（即表示）
               - hero-content背景：アニメ停止
               - SCROLL点滅：停止（表示自体は維持）
            ========================================================= */
            html.js #heroSub { visibility: visible !important; }
            .hero-content::before { animation: none !important; }
            .scroll-indicator { animation: none !important; }

            .concept-wrapper { grid-template-columns: 1fr; gap: 2rem; }
            .profile-section--primary { padding-bottom: 0; }
            .profile-section--secondary { padding-top: 0; }
            .profile-divider { margin: 3.5rem auto; }
            .profile-divider::before { width: min(240px, 60%); }
            .divination-list { grid-template-columns: 1fr; gap: 1.5rem; }
            
            .profile-row { display: flex; flex-direction: column; gap: 0.2rem; padding: 1rem 0; }
            .profile-label { font-size: 0.85rem; color: var(--accent-color); opacity: 0.9; margin-bottom: 0.2rem; }

            /* SNSアイコン微調整（スマホ） */
            .social-links { gap: 0.75rem; margin: -0.5rem 0 1.4rem; }
            .social-icon { width: 44px; height: 44px; }
            .social-icon i { font-size: 19px; }

            .menu-wrapper { padding: 2rem 1.5rem; }
            .price-row { flex-direction: row; flex-wrap: wrap; align-items: baseline; padding: 1rem 0; }
            .price-name { width: auto; flex: 1; font-size: 0.7rem; margin-bottom: 0; }
            .price-time { display: inline-block; font-size: 0.85rem; margin-right: 0.5rem; width: auto; }
            .price-amount { margin-left: 1rem; font-size: 1.1rem; }

            .recommended-plan { margin-top: 2rem; padding: 1.5rem 1rem !important; }
            .satisfaction-plan { margin-top: 2rem; padding: 1.5rem 1rem !important; }

            .special-menu .price-name { width: 100%; margin-bottom: 0.5rem; }

            .menu-category--normal,
            .menu-category--late {
                padding: 1.2rem 1.0rem 1.0rem;
            }

            /* =========================================================
               修正：学生割引（スマホ時に見やすく縦並び）
            ========================================================= */
            .student-discount {
                flex-direction: column;
                align-items: stretch;
                gap: 0.75rem;
                text-align: center;
                padding: 1.4rem 1.2rem;
            }
            .student-discount .price-name {
                width: 100%;
                justify-content: center;
                align-items: center;
            }
            .student-discount .price-amount {
                width: 100%;
                text-align: center;
                margin-left: 0;
                line-height: 1.7;
                font-size: 0.95rem;
            }
            .student-discount__amount {
                display: inline-block;
                margin-top: 0.2rem;
            }
            .student-discount__note {
                display: block;
                margin-top: 0.35rem;
            }
            
            .access-box { grid-template-columns: 1fr; padding: 2rem; gap: 2rem; }
            .section-title-en { font-size: 2.5rem; }
            
            .emotional-title { font-size: 1.5rem; }
            
            .sticky-bar { width: 94%; bottom: 15px; padding: 0.8rem 1rem; }
            .sticky-btn { padding: 0.7rem 1.5rem; font-size: 0.85rem; }
            .sticky-main { font-size: 0.95rem; }

            .cp-circle {
                width: 130px;
                height: 130px;
                margin-top: 2rem;
            }

            .scroll-indicator { bottom: 0.7rem; font-size: 0.7rem; }

            /* ★修正：フッターリンクを「横2項目」配置に（文字は改行しない） */
            .footer-links {
                font-size: 0.72rem;

                display: grid;
                grid-template-columns: repeat(2, max-content);
                justify-content: center;
                align-items: center;
                gap: 0.6rem 1.2rem;
            }
            .footer-links a {
                justify-self: center;
            }
            .footer-links a:last-child {
                grid-column: 1 / -1; /* 3つ目は2列ぶん使って中央 */
            }
        }

        .fade-in { opacity: 0; transform: translateY(20px); transition: all 0.8s ease; }
        .fade-in.visible { opacity: 1; transform: translateY(0); }

/* =========================================================
           追加：プレオープン告知（バナー/価格表示の切替）
           - JSの PREOPEN_PRICE_ACTIVE を false にすると「元価格」に戻せます
        ========================================================= */
        .preopen-only { display: none; }
        html.preopen-active .preopen-only { display: block; }

        .preopen-banner { margin: 0 0 1.8rem; }
        .preopen-banner img {
            border-radius: 8px;
            box-shadow: 0 10px 30px rgba(0,0,0,0.06);
        }

        .preopen-price {
            background: #fffaf5;
            border: 1px solid rgba(198,159,104,0.35);
            border-radius: 10px;
            padding: 1.6rem 1.6rem;
            margin: 0 0 3rem;
        }
        .preopen-title {
            font-family: var(--font-serif);
            color: var(--accent-dark);
            font-size: 1.05rem;
            margin-bottom: 1rem;
            letter-spacing: 0.06em;
        }
        .preopen-heading {
            font-family: var(--font-serif);
            color: var(--accent-color);
            font-size: 1rem;
            margin: 1.2rem 0 0.8rem;
        }
        .preopen-list {
            list-style: none;
            padding-left: 0;
            margin: 0;
        }
        .preopen-list li {
            padding: 0.4rem 0;
            font-size: 0.95rem;
            color: var(--text-main);
        }
        .preopen-old { text-decoration: line-through; opacity: 0.6; }
        .preopen-new { font-weight: 700; color: var(--accent-dark); }
        .preopen-note {
            margin-top: 1.2rem;
            font-size: 0.85rem;
            color: #999;
        }

        /* =========================================================
           追加：価格表示（元価格→新価格）切替
        ========================================================= */
        .price-promo-set { display: none; }
        html.preopen-active .price-promo-set { display: inline; }

        html.preopen-active .price-original {
            text-decoration: line-through;
            opacity: 0.6;
            font-size: 1rem;
        }

        html.preopen-active .price-promo {
            text-decoration: none;
            opacity: 1;
        }

        /* =========================================================
           追加：メニュー見出し直下の占術表示（小さめ）
        ========================================================= */
        .menu-methods {
            font-size: 0.85rem;
            color: #888;
            margin-top: -1.2rem;
            margin-bottom: 1.5rem;
            letter-spacing: 0.06em;
        }

        @media (max-width: 768px) {
            .menu-methods {
                font-size: 0.7rem;
                margin-top: -1rem;
                margin-bottom: 1.2rem;
            }
        }
    

/* =========================================================
   追加：トップページ Blog（WordPress最新3件表示）
========================================================= */
.blog-tiles{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:1.2rem;
    margin-top:2.5rem;
}
.blog-tile{
    display:grid;
    grid-template-rows:auto 1fr;
    background:var(--white);
    border:1px solid rgba(0,0,0,0.06);
    border-radius:12px;
    overflow:hidden;
    box-shadow:0 10px 30px rgba(0,0,0,0.03);
}
.blog-tile:focus-visible{
    outline:2px solid rgba(198, 159, 104, 0.65);
    outline-offset:4px;
}
.blog-tile__thumb img{
/* 	opacity: 0.6; */
}
.blog-tile__thumb img,
.blog-tile__thumb--empty{
    width:100%;
    aspect-ratio:16/9;
    object-fit:cover;
    background:rgba(0,0,0,0.04);
    display:block;
}
.blog-tile__title{
    padding:1rem 1rem 1.1rem;
    font-family:var(--font-serif);
    font-size:1.05rem;
    line-height:1.7;
    letter-spacing:0.06em;
}
.blog-tile__title-text{ display:block; }
.blog-tile__date{
    display:block;
    margin-top:0.35rem;
    text-align:right;
    font-family:var(--font-sans);
    font-size:0.62rem;
    line-height:1.2;
    letter-spacing:0.08em;
    color:var(--text-sub);
    opacity:0.85;
}
.blog-more-link{
    margin-top:1.2rem;
    text-align:right;
    font-family:var(--font-serif);
    letter-spacing:0.08em;
    color:var(--accent-dark);
}
.blog-more-link a{
    display:inline-block;
    border-bottom:1px solid rgba(47,53,59,0.35);
    padding-bottom:2px;
}
@media (max-width: 768px){
    .blog-tiles{
        grid-template-columns:1fr;
        gap:0.8rem;
        margin-top:1.8rem;
    }
    .blog-tile__thumb img,
    .blog-tile__thumb--empty{
        aspect-ratio:16/10;
    }
    .blog-tile__title{
        padding:0.85rem 0.9rem;
        font-size:0.95rem;
        line-height:1.85;
    }
    .blog-tile__date{
        margin-top:0.3rem;
        font-size:0.58rem;
    }
}


/* =========================================================
   追加：オギャ子さんご一行 体験記リンク（バナー）
   - 左：正方形画像 / 右：指定テキスト
   - エリア全体がクリック可能、hoverで色が薄くなる
   - スマホでも崩れないように縮小
========================================================= */
.ogya-report-section{
    padding: 1.8rem 0 1.2rem;
}
.ogya-report{
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem;
    background: rgba(255,255,255,0.92);
    border: 1px solid rgba(0,0,0,0.06);
    box-shadow: 0 10px 30px rgba(0,0,0,0.06);
    transition: opacity 0.25s ease, transform 0.25s ease;
}
.ogya-report:hover{
    opacity: 0.88;
    transform: translateY(-1px);
}
.ogya-report__img{
    width: 120px;
    flex: 0 0 120px;
    aspect-ratio: 1 / 1;
    overflow: hidden;
}
.ogya-report__img img{
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.ogya-report__title{
    font-family: var(--font-sans);
    font-size: 1.4rem;
    line-height: 1.6;
    letter-spacing: 0.08em;
    color: var(--accent-dark);
}
@media (max-width: 768px){
    .ogya-report-section{ padding: 1.2rem 0 0.9rem; }
    .ogya-report{ padding: 0.85rem; gap: 0.75rem; border-radius: 16px; }
    .ogya-report__img{ width: 72px; flex-basis: 72px; border-radius: 12px; }
    .ogya-report__title{ font-size: 0.7rem; line-height: 1.75; font-weight: bold;}
}

/* =========================================================
   追加：Google Maps Reviews（お客様の声 5件表示）
   - タイトルはアーチ文字（SVG）
   - 星は黄色、各カード背景は白
   - 最後の下右側に「Google Maps Reviews さらに詳しく」
========================================================= */
:root{
    --gm-star-yellow: #F5C542;
}
.gm-reviews-section{
    background: #faf9f7;
}
.gm-reviews-header{
    text-align: center;
}

.gm-reviews-rating{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    margin-top: -0.1rem;
}
.gm-stars{
    color: var(--gm-star-yellow);
    font-size: 1.35rem;
    letter-spacing: 0.14em;
}
.gm-rating-value{
    font-family: var(--font-sans);
    font-size: 1.08rem;
    color: #9a9a9a;
    font-weight: 500;
    letter-spacing: 0.02em;
}
.gm-reviews-title{
    margin-top: 0.35rem;
    font-family: var(--font-serif);
    font-size: 1.35rem;
    letter-spacing: 0.12em;
}

.gm-reviews-grid{
    margin-top: 2.2rem;
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 0.9rem;
}
.gm-review-card{
    background: #fff;
    border-radius: 14px;
    padding: 0.95rem 0.8rem;
    border: 1px solid rgba(0,0,0,0.06);
    box-shadow: 0 8px 22px rgba(0,0,0,0.05);
}
.gm-review-card__stars{
    color: var(--gm-star-yellow);
    font-size: 0.98rem;
    letter-spacing: 0.14em;
}
.gm-review-card__headline{
    margin-top: 0.55rem;
    font-family: var(--font-sans);
    font-size: 0.78rem;
    line-height: 1.65;
    letter-spacing: 0.06em;
}
.gm-review-card__text{
    margin-top: 0.35rem;
    font-family: var(--font-sans);
    font-size: 0.78rem;
    color: var(--text-sub);
    line-height: 1.85;
    letter-spacing: 0.04em;
}

.gm-reviews-more{
    margin-top: 1.1rem;
    text-align: right;
}
.gm-reviews-more a{
    display: inline-block;
    font-family: var(--font-serif);
    font-size: 0.9rem;
    letter-spacing: 0.08em;
    color: var(--accent-dark);
    border-bottom: 1px solid rgba(47,53,59,0.35);
    padding-bottom: 2px;
}

@media (max-width: 1024px){
    .gm-reviews-grid{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 768px){
    .gm-reviews-arch text{ font-size: 20px; }
    .gm-stars{ font-size: 1.2rem; }
    .gm-rating-value{ font-size: 1.0rem; }
    .gm-reviews-title{ font-size: 1.25rem; }

    .gm-reviews-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 0.8rem; }
    .gm-review-card{ padding: 0.95rem; }
    .gm-review-card__headline{ font-size: 0.78rem; }
    .gm-review-card__text{ font-size: 0.82rem; }
}
@media (max-width: 520px){
    .gm-reviews-grid{ grid-template-columns: 1fr; }
}
