/*
Theme Name: Linoe Pilates
Theme URI: https://example.com/
Author: Your Name
Description: Custom WordPress theme inspired by TCD demo site
Version: 1.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: linoe-pilates
*/

/* =======================================
   0) Tokens / Variables
======================================= */
:root{
  /* Colors */
  --text:#333; --text-invert:#fff; --line:#eee;
  --overlay:rgba(0,0,0,.36); --backdrop:rgba(0,0,0,.32);
  --brand:#90B8E0;          /* ブランド色（無料体験など） */
  --line-green:#06C755;     /* LINE予約ボタン */
  --accent:#111;            /* セカンダリアクセント */

  /* Header */
  --header-h:64px; --header-h-small:44px;
  --header-gap:24px; --header-gap-small:14px;
  --logo-w:180px; --logo-w-small:80px;
  --logo-w-sp:100px; --logo-w-sp-small:90px;
  --nav-pad-y:10px; --nav-pad-y-small:6px;

  /* Layout */
  --max-w:1100px; --max-w-narrow:860px;
  --radius-lg:20px; --shadow-sm:0 6px 24px rgba(0,0,0,.06);
}

/* ユーザーの省モーション設定に追従 */
@media (prefers-reduced-motion: reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important;}
}

/* ===== Overlay unify: brand-blue ===== */

/* ページヒーローの黒グラデを青系に */
.page-hero.tcd-ish .page-hero__overlay{
  background: linear-gradient(
    to bottom,
    rgba(144,184,224, .28) 0%,
    rgba(144,184,224, .28) 35%,
    rgba(144,184,224, .42) 70%,
    rgba(144,184,224, .58) 100%
  );
}

/* パンくず帯の黒半透明も青系に */
.page-hero.tcd-ish .page-hero__crumbs-inner{
  background: rgba(144,184,224, .30);
}

/* Gate Split（MENU/PRICEカード）の下部黒グラデも青系に */
.gate-split__card::after{
  background: linear-gradient(
    to top,
    rgba(144,184,224, .52),
    rgba(144,184,224, .22) 45%,
    transparent 70%
  );
}

/* もしヒーローのオーバーレイもトーン合わせたいなら（すでに青だけど揃えるなら有効化）
.hero-swiper::after{
  background: rgba(144,184,224, .35);
}
*/

/* =======================================
   1) Base
======================================= */
*{box-sizing:border-box;}
html,body{margin:0;padding:0;overflow-x:hidden;}
html,body{
  font-family:"Noto Sans JP",system-ui,-apple-system,"Segoe UI","Hiragino Kaku Gothic ProN","Hiragino Sans","Noto Sans CJK JP",Meiryo,sans-serif;
  font-weight:400;line-height:1.8;color:var(--text);
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;height:auto;display:block;}
.container{max-width:var(--max-w);width:100%;margin-inline:auto;padding-inline:clamp(16px,4vw,24px);}
.container--narrow{max-width:var(--max-w-narrow);width:100%;margin-inline:auto;padding-inline:clamp(16px,4vw,24px);}
.container--wide{width:min(1100px,94vw);margin-inline:auto;padding-inline:clamp(8px,2vw,16px);}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}

/* 改行ユーティリティ */
.pc-br{display:none;}
.sp-br{display:inline;}
@media (min-width:961px){.pc-br{display:inline;}.sp-br{display:none;}}

/* 表示切替ユーティリティ */
.pc-only{display:none;}
.sp-only{display:block;}
@media (min-width:961px){.pc-only{display:block;}.sp-only{display:none;}}

/* =======================================
   2) Header（PC=横並び / SP=オーバーレイ）
======================================= */
.site-header{
  position:fixed; inset:0 0 auto 0; width:100%;
  background:transparent; border-bottom:1px solid transparent;
  transition:background .3s, border-color .3s, box-shadow .3s, opacity .35s;
  z-index:1000; opacity:1; pointer-events:auto;
}
.header-inner{
  position:relative; display:flex; align-items:center; gap:var(--header-gap);
  min-height:var(--header-h); padding-block:12px;
  transition:min-height .28s, gap .28s, padding .28s;
}
.site-header.scrolled{
  background:#fff; border-bottom-color:var(--line); box-shadow:0 1px 8px rgba(0,0,0,.04);
}
.site-header.scrolled .header-inner{ padding-block:8px; }
body.no-scroll .site-header{ opacity:0; pointer-events:none; } /* スプラッシュ中は非表示 */

.site-header .logo{ display:flex; align-items:center; line-height:0; }
.site-header .logo a{
  display:flex; align-items:center; padding:4px 0; color:var(--text-invert); transition:color .25s;
}
.site-header.scrolled .logo a{ color:var(--text); }
.site-header .logo svg{
  width:var(--logo-w); height:auto; display:block; color:#fff;
  transition:width .28s ease, color .28s ease;
}
.site-header.scrolled .logo svg{ width:var(--logo-w-small); color:var(--brand); }

/* PCナビ */
#global-nav{ margin-left:auto; }
#global-nav .menu{ list-style:none; display:flex; gap:24px; margin:0; padding:0; }
#global-nav .menu>li>a{
  display:block; padding-block:var(--nav-pad-y); color:var(--text-invert);
  transition:padding .28s, color .25s, opacity .25s;
}
.site-header.scrolled #global-nav .menu>li>a{ color:var(--text); }
#global-nav .menu>li>a:hover{ opacity:.7; }

@media (min-width:961px){
  #global-nav{ display:flex !important; align-items:center !important; gap:16px !important; margin-left:auto; }
  #global-nav .menu{ display:flex !important; flex-direction:row !important; align-items:center !important; gap:24px !important; margin:0 !important; padding:0 !important; }
}

/* CTAボタン（共通ベース） */
.btn-cta{
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 16px; border-radius:6px; border:1px solid transparent;
  font-weight:700; line-height:1; text-decoration:none;
  transition:transform .18s, opacity .18s, filter .18s, background .18s, color .18s, border-color .18s;
}
.btn-cta:hover{ transform:translateY(-1px); opacity:.96; }
.btn-cta:focus-visible{ outline:2px solid #000; outline-offset:2px; }

/* ── PC専用 nav-cta（右端の目立つボタン） ── */
.nav-cta{ display:none; }
@media (min-width:961px){
  .nav-cta{ display:flex; align-items:center; gap:12px; margin-left:10px; flex:0 0 auto; }
  /* 配色（PC） */
  #global-nav .nav-cta .btn-cta--trial{
    background:#CC7F91 !important; border-color:#CC7F91 !important; color:#fff !important;
  }
  #global-nav .nav-cta .btn-cta--line{
    background:#90B8E0 !important; border-color:#90B8E0 !important; color:#fff !important;
  }
  .nav-cta .btn-cta--trial:hover,
  .nav-cta .btn-cta--line:hover{ filter:brightness(.95); }
}

/* ── SP用：ドロワー内CTA ── */
.menu-cta-wrap{ display:none; }
@media (max-width:960px){
  .menu-cta-wrap{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin-top:16px; }
  /* 配色（SPドロワー） */
  #global-nav .menu-cta-wrap .btn-cta--brand{
    background:#CC7F91 !important; border-color:#CC7F91 !important; color:#fff !important;
  }
  #global-nav .menu-cta-wrap .btn-cta--line{
    background:#90B8E0 !important; border-color:#90B8E0 !important; color:#fff !important;
  }
}

/* SPメニューボタン（右上テキスト） */
.menu-btn.menu-btn--text{
  display:none; position:absolute; right:16px; top:10px; padding:8px 14px; background:transparent; border:0; cursor:pointer; z-index:1100;
  font-family:"Noto Serif JP",serif; font-style:italic; font-size:20px; font-weight:700; color:var(--text-invert); transition:color .25s;
}
.site-header.scrolled .menu-btn.menu-btn--text{ color:var(--text); }
.menu-btn__label{ position:relative; display:inline-block; padding-bottom:2px; }
.menu-btn__label::after{
  content:""; position:absolute; left:0; bottom:0; width:100%; height:1px;
  background:currentColor; transform:scaleX(1); transform-origin:left; transition:transform .25s;
}
.menu-btn.is-open .menu-btn__label::after{ transform:scaleX(0); }
.menu-btn__label::before{ content:attr(data-open); }
.menu-btn.is-open .menu-btn__label::before{ content:attr(data-close); }

/* ── SPドロワー本体 ── */
@media (max-width:960px){
  .menu-btn.menu-btn--text{ display:inline-block; }
  .site-header .logo svg{ width:var(--logo-w-sp); }
  .site-header.scrolled .logo svg{ width:var(--logo-w-sp-small); }

  #global-nav{
    position:fixed; inset:0; display:flex; flex-direction:column; justify-content:center; align-items:center;
    background:#fff; opacity:0; pointer-events:none; transform:scale(1.02);
    transition:opacity .32s, transform .32s; z-index:1090;
  }
  #global-nav.open{ opacity:1; pointer-events:auto; transform:none; }
  #global-nav .nav-backdrop{ position:fixed; inset:0; background:var(--backdrop); opacity:0; pointer-events:none; transition:opacity .28s; z-index:-1; }
  #global-nav.open .nav-backdrop{ opacity:1; pointer-events:auto; }

  #global-nav .menu{ flex-direction:column; gap:18px; width:min(92%,720px); }
  #global-nav .menu>li>a{
    color:var(--text) !important; border-bottom:1px solid transparent; padding:16px 20px; line-height:1.4;
  }
}

/* ── PC固定（ドロワー無効化） ── */
@media (min-width:961px){
  .menu-btn.menu-btn--text{ display:none !important; }
  #global-nav, #global-nav.open{
    position:static !important; inset:auto !important; transform:none !important; opacity:1 !important;
    pointer-events:auto !important; background:transparent !important; width:auto !important; border-left:0 !important; box-shadow:none !important;
  }
  #global-nav .nav-backdrop{ display:none !important; }
  #global-nav .menu{ flex-direction:row !important; gap:24px !important; margin:0 !important; padding:0 !important; }
  .site-header.scrolled #global-nav .menu>li>a{ padding-block:var(--nav-pad-y-small); }
}

/* ドロワーOPEN時の背景スクロール抑止 */
body.no-scroll, body.drawer-open{ overflow:hidden; touch-action:none; }
.site-header:not(.scrolled){
  background:transparent !important; border-bottom-color:transparent !important; box-shadow:none !important;
}

/* =======================================
   3) SP固定バー（LINE予約／無料体験）
======================================= */
.fixed-reserve{
  position:fixed; left:0; right:0; bottom:0; display:flex; align-items:stretch; height:clamp(52px,7.2vh,64px);
  z-index:1200; background:#fff; box-shadow:0 -6px 22px rgba(0,0,0,.08);
  padding-bottom:env(safe-area-inset-bottom,0); transition:transform .28s ease, opacity .28s ease, visibility .28s ease;
}
.drawer-open .fixed-reserve{ transform:translateY(100%); opacity:0; visibility:hidden; pointer-events:none; }
.fixed-btn{
  flex:0 0 50% !important; display:flex; align-items:center; justify-content:center; gap:10px;
  padding:0 clamp(12px,3vw,18px); font-weight:700; letter-spacing:.02em; font-size:15px; line-height:1;
  -webkit-tap-highlight-color:transparent; min-height:48px;
  border-radius:0; /* ← スマ下部はフラット */
}
.fixed-btn--primary{ background:#90B8E0; color:#fff; border:0; }
.fixed-btn--ghost  { background:#CC7F91; color:#fff; border:0; }
.fixed-btn::before{
  -webkit-mask:none !important; mask:none !important; content:""; width:1.15em; height:1.15em; display:inline-block; background-repeat:no-repeat; background-position:center; background-size:100% 100%;
}
.fixed-btn--primary::before{
  background-image:url(data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23fff' d='M2 3h20v14H7l-5 5V3z'/%3E%3C/svg%3E);
}
.fixed-btn--ghost::before{
  background-image:url(data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23fff' d='M12 17.27 18.18 21l-1.64-7.03L22 9.24l-7.19-.61L12 2 9.19 8.63 2 9.24l5.46 4.73L5.82 21z'/%3E%3C/svg%3E);
}
@media (min-width:961px){ .fixed-reserve{ display:none; } }



/* =======================================
   4) Hero / Swiper
======================================= */
.hero-swiper,.hero-swiper .swiper-wrapper,.hero-swiper .swiper-slide{width:100%;height:100dvh;}
.hero-swiper{position:relative;background:#000;overflow:hidden;}
.hero-swiper::after{content:"";position:absolute;inset:0;background:rgba(60,110,180,0.35);mix-blend-mode:multiply;pointer-events:none;z-index:1;}
.hero-swiper .swiper-slide img{width:100%;height:100%;object-fit:cover;will-change:transform,opacity;transform:translateZ(0);}
.hero-swiper.swiper-fade .swiper-slide{pointer-events:none;transition:opacity 1.4s ease !important;z-index:0;}
.hero-swiper.swiper-fade .swiper-slide-active{pointer-events:auto;}

/* ヒーロー縦書きコピー */
.hero-copy{position:absolute;inset:0;z-index:5;display:flex;justify-content:center;align-items:center;color:#fff;pointer-events:none;padding:0;}
.hero-title,.hero-subtitle{
  font-family:"Klee One","Noto Serif JP",serif;font-weight:600;writing-mode:vertical-rl;text-orientation:upright;letter-spacing:.15em;line-height:1.8;text-shadow:0 2px 14px rgba(0,0,0,.25);
}
.hero-title{font-size:clamp(20px,2.5vw,36px);}
.hero-subtitle{font-size:clamp(20px,3.4vw,56px);line-height:1.9;}
@media (max-width:960px){
  .hero-title{font-size:clamp(22px,6vw,28px);}
  .hero-subtitle{font-size:clamp(26px,8vw,34px);}
  .hero-swiper::after{background:rgba(60,110,180,0.44);}
}

/* ズームアニメーション */
@keyframes heroZoom{from{transform:scale(1);}to{transform:scale(1.06);}}
.hero-swiper .swiper-slide.swiper-slide-active img{animation:heroZoom 6.8s linear forwards;}

/* =======================================
   5) Splash
======================================= */
:root{
  --catch-delay:0s; --catch-dur:.7s; --hold-catch:2.2s;  /* テキスト短く */
  --wipe-delay:2.4s; --wipe-dur:.9s; --hold-wipe:.7s;    /* ピンク早め */
  --logo-delay:3.0s; --logo-dur:.8s; --hold-logo:1.2s;   /* ロゴも早め */
  --leave-extra:.5s;
}

#splash{position:fixed;inset:0;background:#fff;z-index:2000;display:grid;place-items:center;overflow:hidden;opacity:1;}
.splash-inner{position:relative;width:100vw;height:100dvh;display:grid;place-items:center;text-align:center;isolation:isolate;}
.splash-catch,.splash-logo{grid-area:1/1;position:relative;}

.splash-catch{
  z-index:1;margin:0;font-family:"Klee One","Noto Serif JP",serif;font-weight:600;
  font-size:clamp(20px,2.1vw,34px);letter-spacing:.06em;color:#8696a4;opacity:0;transform:translateY(14px);
}
.splash-wipe{position:absolute;inset:-20px 0 -20px 0;background:#FDECEE;transform:translateY(-120%);z-index:5;pointer-events:none;}
.splash-logo{z-index:10;color:#90B8E0;opacity:0;transform:translateY(12px);}
.splash-logo svg{width:clamp(180px,30vw,380px);height:auto;fill:currentColor;}
@media (min-width:961px){.splash-logo svg{width:clamp(160px,20vw,300px);}}

/* 動き */
@keyframes splashCatchIn{from{opacity:0;transform:translateY(14px);}to{opacity:1;transform:translateY(0);}}
@keyframes wipeDownStraight{from{transform:translateY(-120%);}to{transform:translateY(0);}}
@keyframes logoIn{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:translateY(0);}}
@keyframes splashOut{to{opacity:0;}}
#splash.is-run .splash-catch{animation:splashCatchIn var(--catch-dur) ease var(--catch-delay) forwards;}
#splash.is-run .splash-wipe{animation:wipeDownStraight var(--wipe-dur) cubic-bezier(.25,.9,.3,1) var(--wipe-delay) forwards;}
#splash.is-run .splash-logo{animation:logoIn var(--logo-dur) cubic-bezier(.22,1,.36,1) var(--logo-delay) forwards;}
#splash.is-leave{animation:splashOut .7s ease forwards;}

/* =======================================
   6) Local nav
======================================= */
.page-localnav{border-bottom:1px solid #eee;}
.page-localnav .container{overflow-x:auto;}
.page-localnav__list{display:flex;gap:16px;padding:14px 0;margin:0;list-style:none;}
.page-localnav__link{
  display:inline-block;padding:8px 14px;border-radius:999px;background:#f7f7f8;color:#222;transition:background .2s,color .2s;white-space:nowrap;
}
.page-localnav__link:hover{background:#ececee;}
.page-localnav__link.is-current{background:#111;color:#fff;}

/* =======================================
   7) Content / Typography
======================================= */
.page-hero{
  position:relative;background:#f6f6f6;background-image:var(--hero, none);
  background-size:cover;background-position:center;color:#111;padding:clamp(64px,10vw,128px) 0;
}
.page-hero__overlay{position:absolute;inset:0;background:rgba(255,255,255,.5);pointer-events:none;}
.page-hero .container{position:relative;z-index:1;}
.page-hero__title{font-size:clamp(28px,4vw,44px);font-weight:700;letter-spacing:.02em;margin:0 0 .35em;}
.page-hero__subtitle{font-size:clamp(15px,1.5vw,18px);opacity:.85;}
.page-hero[style*="--hero:none"] .page-hero__overlay{display:none;}

.page-content{padding:clamp(36px,6vw,72px) 0;}
.prose :where(p,ul,ol){line-height:1.9;}
.prose h2{font-size:clamp(22px,3vw,28px);margin:1.8em 0 .6em;}
.prose h3{font-size:clamp(18px,2.3vw,22px);margin:1.6em 0 .5em;}
.prose img{max-width:100%;height:auto;border-radius:14px;}

.section{padding:clamp(48px,8vw,96px) 0;}
.section-title{font-size:clamp(22px,3vw,32px);font-weight:700;text-align:center;margin-bottom:1em;}
.section-lead{text-align:center;font-size:1.1rem;opacity:.85;}

.feature-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;list-style:none;padding:0;margin:0;text-align:center;}
.feature-list img{border-radius:12px;margin-bottom:12px;}
.visual-grid{display:grid;gap:40px;align-items:center;}
@media (min-width:960px){.visual-grid{grid-template-columns:1fr 1fr;}}
.visual-text p{line-height:1.9;}
.cta{background:#fafafa;text-align:center;}
.cta-buttons{margin-top:20px;display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}
.blog-list{display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));}
.blog-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 12px rgba(0,0,0,.06);}
.blog-card img{width:100%;height:auto;display:block;}
.blog-card h3{margin:12px;font-size:1rem;}
.access .map{margin-top:20px;border-radius:12px;overflow:hidden;}

/* 共通ボタン（再掲・他所でも利用） */
.btn,.btn-cta{
  display:inline-flex;align-items:center;gap:8px;padding:12px 22px;border-radius:9999px;border:1px solid currentColor;
  text-decoration:none;font-weight:700;letter-spacing:.02em;line-height:1;transition:transform .18s,opacity .18s,background .18s,color .18s,border-color .18s;
}
.btn:hover,.btn-cta:hover{transform:translateY(-1px);opacity:.95;}
.btn-cta .i-line{display:inline-block;vertical-align:-1px;}
.btn--primary{background:#111;color:#fff;border-color:#111;}
.btn-cta--brand{background:var(--brand);border-color:var(--brand);color:#fff;}
.btn-cta--line{background:var(--line-green);border-color:var(--line-green);color:#fff;}

/* Hero右側CTA（PCのみ） */
.hero-cta{position:absolute;right:clamp(16px,4vw,56px);top:50%;transform:translateY(-50%);display:grid;gap:12px;z-index:3;pointer-events:auto;}
@media (max-width:960px){.hero-cta{display:none;}}

/* =======================================
   Footer（Light / Clean）
======================================= */
.site-footer{
  background:#f8f9fb; /* 清潔感のある薄グレー */
  color:#333;
  padding:60px 0 40px;
  overflow:hidden;
  border-top:1px solid #e6e8eb;
}
.footer-inner{width:min(92%,1200px);margin:0 auto;}
.footer-heading{
  font-size:1.4rem;font-weight:700;letter-spacing:.06em;margin-bottom:24px;
  text-align:center;color:#2b3137;
}

/* layout */
.footer-access-body{display:grid;gap:24px;}
@media (min-width:961px){
  .footer-access-body{grid-template-columns:1.1fr .9fr;gap:40px;align-items:start;}
}

/* map card */
.card{
  background:#fff;border-radius:var(--radius,12px);
  box-shadow:var(--shadow-sm,0 8px 24px rgba(0,0,0,.06));
  overflow:hidden;
}
.footer-map{position:relative;width:100%;aspect-ratio:16/9;min-height:280px;}
@supports not (aspect-ratio:1/1){
  .footer-map{padding-top:56.25%;}
  .footer-map iframe{position:absolute;inset:0;}
}
.footer-map iframe{width:100%;height:100%;border:0;display:block;}

/* text & info */
.footer-access-text{font-size:.95rem;line-height:1.9;word-break:keep-all;}
.footer-address{margin:0 0 10px;}
.footer-hours{margin:0 0 10px;color:#4b5563;}
.footer-contacts{list-style:none;padding:0;margin:10px 0 18px;display:flex;flex-wrap:wrap;gap:14px;}
.footer-contacts a{color:#1f2937;text-decoration:underline;text-decoration-color:#cbd5e1;text-underline-offset:3px;}
.footer-contacts a:hover{opacity:.85}

/* CTAs */
.footer-ctas{display:flex;flex-wrap:wrap;gap:10px;margin:18px 0 10px;}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.45em;
  padding:.75em 1.05em;border-radius:999px;font-weight:700;font-size:.95rem;
  border:1px solid transparent;text-decoration:none;transition:.2s ease;
}
.btn.line{background:#06C755;color:#fff;}
.btn.line:hover{filter:brightness(.95);}
.btn.trial{background:#90B8E0;color:#fff;}
.btn.trial:hover{filter:brightness(.96);}
.btn.ghost{background:#fff;border-color:#d1d5db;color:#374151;}
.btn.ghost:hover{border-color:#c5cad3;background:#f9fafb}
		
		.footer-directions {
  margin-top: 1em;
  font-size: 0.9rem;
  line-height: 1.6;
}
.footer-directions h3 {
  font-weight: 600;
  margin-bottom: 0.3em;
}
.footer-directions ul {
  list-style: none;

}
		
		
/* =========================
   Campaign（Footer直前/独立カード）
========================= */
.site-campaign-wrap{
  /* ページ末尾に独立して“浮いてる”感じを出す */
  padding: clamp(18px, 3vw, 28px) 0 0;   /* 上に少し息継ぎ */
  background: transparent;               /* ← フッターとは別の層 */
}
.site-campaign__inner{
  width: min(92%, 1200px);
  margin-inline: auto;
}

/* 白カード + 影（既存 .card を活かしつつ念のため指定） */
.campaign.card{
  background:#fff;
  border:1px solid #e6e8eb;
  border-radius: var(--radius, 12px);
  box-shadow: var(--shadow-sm, 0 8px 24px rgba(0,0,0,.06));
  padding: clamp(18px, 3.6vw, 28px);
}

/* ヘッダー */
.campaign__head{ text-align:center; margin-bottom: 14px; }
.campaign__label{
  display:inline-block;
  font-size:.85rem; letter-spacing:.15em;
  color: color-mix(in oklab, var(--brand) 85%, #2b3137);
  background:#f4f6fb;
  border-radius:999px; padding:6px 10px; font-weight:700;
}
.campaign__title{
  font-family:"Klee One","Noto Serif JP",serif; font-weight:600;
  color: var(--brand, #90B8E0);
  font-size: clamp(20px, 3.2vw, 28px);
  margin: 8px 0 6px;
}
.campaign__lead{
  margin: 0 auto; max-width: 48rem;
  font-size: .98rem; line-height: 1.9; color: #444;
}

/* グリッド */
.campaign-grid{
  list-style:none; padding:0; margin: 16px 0 8px;
  display:grid; gap:12px;
}
@media (min-width:801px){
  .campaign-grid{ grid-template-columns: repeat(3, 1fr); gap: 14px; }
}

/* 小カード */
.campaign-card{
  border: 1px solid #eee; border-radius: 12px;
  padding: 14px 14px 16px; background:#fff;
}
.campaign-card__title{ margin: 0 0 .4em; font-weight:700; color:#1f2937; }
.campaign-card__desc{ margin: 0 0 .35em; color:#4b5563; font-size:.95rem; }
.campaign-card__price{ margin:0; font-size:1rem; }
.campaign-card__price del{ color:#9ca3af; margin-right:.4em; }
.campaign-card__price .now{ display:inline-flex; gap:.35em; font-weight:800; }
.campaign-card__price .now strong{ font-size:1.2rem; color:#111; }

/* CTA */
.campaign-ctas{
  display:flex; flex-wrap:wrap; gap:10px; justify-content:center; margin-top:14px;
}
/* 既存の .btn / .btn.line / .btn.trial を利用 */

					
					/* =========================
   Campaign（Footer上部・全ページ表示）
========================= */
.site-campaign{
  margin: 0 0 28px;
}
@media (min-width:961px){
  .site-campaign{ margin: 0 0 36px; }
}

.campaign{
  padding: clamp(18px, 3.6vw, 28px);
  border: 1px solid #e6e8eb;
  background: #fff;
}

.campaign__head{
  text-align:center;
  margin-bottom: 14px;
}
.campaign__label{
  display:inline-block;
  font-size:.85rem;
  letter-spacing:.15em;
  color: color-mix(in oklab, var(--brand) 85%, #2b3137);
  background: #f4f6fb;
  border-radius: 999px;
  padding: 6px 10px;
  font-weight: 700;
}
.campaign__title{
  font-family:"Klee One","Noto Serif JP",serif;
  font-weight:600;
  color: var(--brand, #90B8E0);
  font-size: clamp(20px, 3.2vw, 28px);
  margin: 8px 0 6px;
}
.campaign__lead{
  margin: 0 auto;
  max-width: 48rem;
  font-size: .98rem;
  line-height: 1.9;
  color: #444;
}

/* grid */
.campaign-grid{
  list-style:none;
  padding:0; margin: 16px 0 8px;
  display:grid; gap:12px;
}
@media (min-width:801px){
  .campaign-grid{ grid-template-columns: repeat(3, 1fr); gap: 14px; }
}

/* cards */
.campaign-card{
  border: 1px solid #eee;
  border-radius: 12px;
  padding: 14px 14px 16px;
  background:#fff;
}
.campaign-card__title{
  margin: 0 0 .4em;
  font-weight: 700;
  color: #1f2937;
}
.campaign-card__desc{
  margin: 0 0 .35em;
  color: #4b5563;
  font-size: .95rem;
}
.campaign-card__price{
  margin: 0;
  font-size: 1rem;
}
.campaign-card__price del{
  color: #9ca3af;
  margin-right: .4em;
}
.campaign-card__price .now{
  display: inline-flex;
  align-items: center;
  gap: .35em;
  font-weight: 800;
}
.campaign-card__price .now strong{
  font-size: 1.2rem;
  color: #111;
}

/* CTAs */
.campaign-ctas{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  justify-content:center;
  margin-top: 14px;
}

/* 既存の .btn, .btn.line, .btn.trial を流用（定義済） */
/* PCで少し見栄えを強めたい場合は以下を任意で追加
.campaign-ctas .btn{ min-width: 200px; }
*/
					
					
/* =======================================
   9) Page Hero (TCD-ish) 共通
======================================= */
.page-hero.tcd-ish{
  position:relative;color:#111;background:#f5f5f5;
  padding:clamp(84px,14vw,220px) 0 clamp(34px,5vw,56px);
}
.page-hero.tcd-ish .page-hero__inner{
  position:relative;z-index:1;display:grid;grid-template-rows:1fr auto; /* 本文 + パンくず帯 */
  min-height:clamp(60vh,70vh,72vh);
}
.page-hero.tcd-ish .page-hero__container{
  align-self:center;justify-self:center;width:min(92vw,1000px);text-align:center;padding-inline:16px;
}
.page-hero.tcd-ish .page-hero__title{
  margin:0 0 .4em;font-size:clamp(28px,5.2vw,56px);font-weight:700;letter-spacing:.02em;text-shadow:0 2px 14px rgba(0,0,0,.3);color:currentColor;
}
.page-hero.tcd-ish .page-hero__subtitle{margin:0;font-size:clamp(14px,1.8vw,18px);opacity:.95;text-shadow:0 2px 10px rgba(0,0,0,.28);color:currentColor;}
.page-hero.tcd-ish .page-hero__crumbs{align-self:end;}
.page-hero.tcd-ish .page-hero__crumbs-inner{
  display:flex;align-items:center;min-height:46px;padding:10px clamp(16px,4vw,28px);
  background:rgba(0,0,0,.3);backdrop-filter:saturate(1.1) blur(2px);
}
.page-hero.tcd-ish:not(.has-image) .page-hero__crumbs-inner{background:rgba(0,0,0,.06);}
.page-hero.tcd-ish .breadcrumbs{width:100%;color:#fff;font-size:13px;white-space:nowrap;overflow:auto;}
.page-hero.tcd-ish:not(.has-image) .breadcrumbs{color:#333;}
.page-hero.tcd-ish .breadcrumbs a{color:inherit;opacity:.9;text-decoration:none;}
.page-hero.tcd-ish .breadcrumbs a:hover{opacity:1;text-decoration:underline;}
.page-hero.tcd-ish .breadcrumbs span{opacity:.75;}
.page-hero.tcd-ish.is-compact{padding:clamp(56px,9vw,120px) 0 clamp(26px,4vw,40px);}
.page-hero.tcd-ish.is-compact .page-hero__inner{min-height:42vh;}
@media (max-width:960px){.page-hero.tcd-ish .page-hero__inner{min-height:56vh;}}

/* 画像あり時のオーバーレイ */
.page-hero.tcd-ish.has-image{color:#fff;background-image:var(--hero);background-size:cover;background-position:center;}
.page-hero.tcd-ish .page-hero__overlay{
  position:absolute;inset:0;background:linear-gradient(to bottom, rgba(0,0,0,.20) 0%, rgba(0,0,0,.20) 35%, rgba(0,0,0,.35) 70%, rgba(0,0,0,.55) 100%);
  opacity:0;pointer-events:none;transition:opacity .35s ease;
}
.page-hero.tcd-ish.has-image .page-hero__overlay{opacity:1;}

/* =======================================
   Concept page
======================================= */

/* 共通タイトル */
.concept .section-title,
.concept h3,
.concept-features__head .section-title {
  font-family: "Klee One","Noto Serif JP",serif;
  font-weight: 600;
  color: var(--brand);
  letter-spacing: .05em;
  line-height: 1.4;
  text-align: center;
  margin-bottom: 1em;
}
.concept .section-title { font-size: clamp(22px,3vw,32px); }
.concept h3,
.concept h3.section-title,
.concept-features__head .section-title { font-size: clamp(22px,3.2vw,30px); }
.concept .section-lead { font-size: 1.05rem; opacity: .9; }
.concept .visual-text p { margin: .5em 0; }
.concept .visual-image img {
  display: block; width: 100%; height: auto;
  border-radius: 12px; object-fit: cover;
}
@media (min-width:960px) {
  .visual-grid { display:grid; grid-template-columns: 1fr 1fr; align-items: center; gap: 40px; }
}

/* ======================
   Features セクション（3カード）
====================== */
.concept-features__head {
  text-align: center;
  max-width: 56rem;
  margin: 0 auto 18px;
}
.concept-features__head p {
  max-width: 48rem;
  margin: .6em auto 0;
  line-height: 1.9;
  font-size: 1rem;
  opacity: .95;
}

.feature-grid {
  display: grid;
  gap: 16px;
  margin-top: 22px;
  list-style: none;
  padding: 0;
}
@media (min-width:961px) {
  .feature-grid { grid-template-columns: repeat(3,1fr); }
}
@media (max-width:960px) and (min-width:561px) {
  .feature-grid { grid-template-columns: repeat(2,1fr); }
}
@media (max-width:560px) {
  .feature-grid { grid-template-columns: 1fr; }
}

.feature-card {
  display: flex;
  align-items: flex-start;
  gap: 18px;
  padding: 16px;
  border: 1px solid #eee;
  border-radius: 12px;
  background: #fff;
  box-shadow: var(--shadow-sm);
  text-align: left;
}
.feature-card__media {
  flex: 0 0 200px;
  max-width: 200px;
}
.feature-card__media img {
  display: block;
  width: 100%; height: auto;
  aspect-ratio: 4/3;
  object-fit: cover;
  border-radius: 10px;
}
.feature-card__body {
  flex: 1;
  min-width: 0;   /* ← これがないと一文字折り返しになる */
}
.feature-card__title {
  margin: 0 0 .4em;
  font-size: 1.1rem;
  font-weight: 700;
  line-height: 1.5;
  color: #111;
}
.feature-card__text {
  margin: 0;
  line-height: 1.8;
  font-size: 1rem;
  opacity: .95;
}
.feature-card__text + .feature-card__text { margin-top: .6em; }

@media (max-width:680px) {
  .feature-card { flex-direction: column; }
  .feature-card__media { flex: none; width: 100%; max-width: 100%; }
}

/* ======================
   Method セクション（タイムライン）
====================== */
.concept-method .method-steps {
  position: relative;
  display: grid;
  gap: 28px;
  margin: 32px 0;
  padding-left: 48px; /* 番号分の余白 */
  list-style: none;
}
.concept-method .method-steps::before {
  content: "";
  position: absolute;
  top: 0; bottom: 0;
  left: 22px;
  width: 2px;
  background: #e5e7eb;
}
.concept-method .method-step {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.concept-method .method-num {
  position: absolute;
  left: -48px;
  top: 0;
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--brand,#90B8E0);
  color: #fff;
  font-weight: 800;
  font-size: 1rem;
  line-height: 44px;
  text-align: center;
  box-shadow: 0 2px 6px rgba(0,0,0,.08);
}
.concept-method .method-body h4 {
  margin: 0 0 .25em;
  font-size: 1.1rem;
  font-weight: 700;
  color: #111;
}
.concept-method .method-body p {
  margin: 0;
  font-size: 1rem;
  line-height: 1.8;
  opacity: .95;
}
.concept-method .method-visual { margin-top: 32px; }
.concept-method .method-visual img {
  width: 100%; height: auto;
  border-radius: 14px; object-fit: cover;
}

/* ======================
   横長ビジュアル帯
====================== */
.concept-visual-band { padding: clamp(16px,3vw,24px) 0; }
.concept-visual-band .band-figure {
  position: relative; width: 100%; aspect-ratio: 21/9;
  border-radius: 14px; overflow: hidden;
  background: #eaeaea; box-shadow: 0 6px 24px rgba(0,0,0,.06);
}
.concept-visual-band .band-figure img {
  display: block; width: 100%; height: 100%;
  object-fit: cover; transform: translateZ(0);
}
@media (max-height:680px) {
  .concept-visual-band .band-figure { max-height: 46vh; }
}

/* ===== HOTFIX: Concept Features を強制レイアウト（最下部に貼る） ===== */
.concept-features .feature-grid{
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 16px !important;
  margin-top: 22px;
  list-style: none; padding: 0;
}
@media (min-width: 961px){
  .concept-features .feature-grid{
    grid-template-columns: repeat(3, 1fr) !important;
  }
}

.concept-features .feature-card{
  display: flex !important;
  align-items: flex-start !important;
  gap: 18px !important;
  padding: 16px !important;
  border: 1px solid #eee;
  border-radius: 12px;
  background: #fff;
  box-shadow: var(--shadow-sm, 0 4px 12px rgba(0,0,0,.06));
  text-align: left !important;
}

/* 左：画像 */
.concept-features .feature-card__media{
  flex: 0 0 200px !important;
  max-width: 200px !important;
  margin: 0 !important;
}
.concept-features .feature-card__media img{
  display: block; width: 100%; height: auto;
  aspect-ratio: 4 / 3; object-fit: cover;
  border-radius: 10px;
}

/* 右：本文（潰れ防止が本命） */
.concept-features .feature-card__body{
  flex: 1 1 auto !important;
  min-width: 0 !important;   /* ← これが無いと1文字折りになる */
  width: auto !important;
  overflow: visible;
  writing-mode: horizontal-tb !important; /* 念のため横書きを強制 */
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: anywhere;
}
.concept-features .feature-card__title{
  margin: 0 0 .4em !important;
  font-size: 1.1rem; font-weight: 700; line-height: 1.5; color: #111;
}
.concept-features .feature-card__text{ margin: 0; line-height: 1.8; font-size: 1rem; opacity: .95; }
.concept-features .feature-card__text + .feature-card__text{ margin-top: .6em; }

/* SPでは縦積み */
@media (max-width: 680px){
  .concept-features .feature-card{ flex-direction: column !important; }
  .concept-features .feature-card__media{
    flex: none !important; width: 100% !important; max-width: 100% !important;
  }
}

/* 他セクションの .feature-card 既存指定を無効化（影響範囲をConcept内に限定） */
.concept-features .feature-card img{ margin-bottom: 0 !important; }
		
		
/* ===== Concept (scoped & conflict-free) ===== */

/* 共通 */
.cpt-concept .cpt-section-title,
.cpt-concept h3.cpt-h3 {
  font-family: "Klee One","Noto Serif JP",serif;
  font-weight: 600;
  color: var(--brand, #90B8E0);
  letter-spacing: .05em;
  line-height: 1.4;
  text-align: center;
  margin: 0 0 1em;
}
.cpt-concept .cpt-section-title { font-size: clamp(22px,3vw,32px); }
.cpt-concept h3.cpt-h3 { font-size: clamp(22px,3.2vw,30px); }
.cpt-concept .cpt-lead { font-size: 1.05rem; opacity: .9; text-align: center; }
.cpt-concept .cpt-container { max-width: var(--max-w, 1100px); width: 100%; margin: 0 auto; padding-inline: clamp(16px,4vw,24px); }

/* 1) イントロ */
.cpt-intro { padding: clamp(48px,8vw,96px) 0; }
.cpt-visual-band { padding: clamp(16px,3vw,24px) 0; }
.cpt-visual-band .cpt-band-figure {
  position: relative; width: 100%; aspect-ratio: 21/9;
  border-radius: 14px; overflow: hidden; background: #eaeaea;
  box-shadow: 0 6px 24px rgba(0,0,0,.06);
}
.cpt-visual-band .cpt-band-figure img {
  display:block; width:100%; height:100%; object-fit:cover; transform: translateZ(0);
}

/* 2) Features（画像 左 / テキスト 右、上揃え、スマホ縦積み） */
.cpt-features { padding: clamp(48px,8vw,96px) 0; }
.cpt-features-head { text-align:center; max-width:56rem; margin:0 auto 18px; }
.cpt-features-head p {
  max-width:48rem; margin:.6em auto 0; line-height:1.9; font-size:1rem; opacity:.95;
}

/* リスト（縦積み） */
.cpt-feature-list {
  list-style: none; padding: 0; margin: 22px 0 0;
  display: grid; gap: 16px;
}

/* カード本体（横並びレイアウト） */
.cpt-card {
  display: flex; align-items: flex-start;
  gap: 18px; padding: 16px;
  border: 1px solid #eee; border-radius: 12px;
  background: #fff; box-shadow: var(--shadow-sm, 0 4px 12px rgba(0,0,0,.06));
  text-align: left;
}

/* 左：画像 */
.cpt-card-media {
  --thumb: clamp(120px, 32vw, 200px);
  flex: 0 0 var(--thumb); max-width: var(--thumb); margin: 0;
}
@media (min-width: 801px){ .cpt-card-media{ --thumb: 200px; } }
.cpt-card-media img {
  display:block; width:100%; height:auto; aspect-ratio:4/3;
  object-fit:cover; border-radius:10px;
}

/* 右：本文（潰れ防止がカギ） */
.cpt-card-body {
  flex: 1 1 auto; min-width: 0; width: auto;
  writing-mode: horizontal-tb; white-space: normal;
  word-break: break-word; overflow-wrap: anywhere;
}
.cpt-card-title {
  margin: 0 0 .4em; font-size: 1.1rem; font-weight: 700; line-height: 1.5; color: #111;
}
.cpt-card-text { margin: 0; line-height: 1.8; font-size: 1rem; opacity: .95; }
.cpt-card-text + .cpt-card-text { margin-top: .6em; }

/* スマホでは縦積み */
@media (max-width: 680px){
  .cpt-card { flex-direction: column; }
  .cpt-card-media { flex: none; width: 100%; max-width: 100%; }
}

/* 3) Two-col（テキスト＆画像） */
.cpt-two-col { padding: clamp(48px,8vw,96px) 0; }
.cpt-two-col-grid {
  display: grid; gap: 40px; align-items: center;
  grid-template-columns: 1fr;
}
@media (min-width:960px){
  .cpt-two-col-grid { grid-template-columns: 1fr 1fr; }
}
.cpt-two-col .cpt-visual-text p { margin:.5em 0; line-height:1.9; }
.cpt-two-col .cpt-visual-image img {
  display:block; width:100%; height:auto; border-radius:12px; object-fit:cover;
}

/* 4) Method（年表風：左丸数字＋縦線） */
.cpt-method { padding: clamp(48px,8vw,96px) 0; }
.cpt-steps {
  position: relative; display: block;
  max-width: 56rem; margin: 24px auto 10px;
}
.cpt-steps::before {
  content:""; position:absolute; left:30px; top:0; bottom:0; width:2px; background:#eee;
}
.cpt-step {
  position: relative;
  display: grid; grid-template-columns: 60px 1fr; gap: 16px;
  padding: 18px 12px 18px 0; margin: 0;
  background: transparent; border: 0; box-shadow: none;
}
.cpt-step + .cpt-step { margin-top: 8px; }
.cpt-num {
  position: relative; z-index: 1;
  width: 40px; height: 40px; margin-left: 10px; border-radius: 50%;
  display: grid; place-items: center;
  font-weight: 800; letter-spacing: .06em;
  background: var(--brand, #90B8E0); color: #fff; font-size: .95rem;
  box-shadow: 0 4px 12px rgba(0,0,0,.06);
}
.cpt-step h4 { margin: .1em 0 .4em; font-size: 1.1rem; line-height: 1.5; }
.cpt-step p  { margin: 0; line-height: 1.9; font-size: 1rem; opacity: .96; }

/* 年表下の横長画像 */
.cpt-method-visual {
  margin: 20px auto 0; max-width: 1100px;
  padding-inline: clamp(16px,4vw,24px);
}
.cpt-method-visual img {
  display:block; width:100%; height:auto;
  aspect-ratio: 21/9; object-fit:cover;
  border-radius:14px; box-shadow:0 6px 24px rgba(0,0,0,.06);
}
		
		/* ======================
   Concept: Approach（1カラム + 下に画像）
====================== */
.cpt-two-col {
  padding: clamp(48px,8vw,96px) 0;
}

.cpt-two-col-grid {
  display: block; /* ← グリッド解除 */
  max-width: 56rem;
  margin: 0 auto;
  padding-inline: clamp(16px,4vw,24px);
}

.cpt-two-col .cpt-visual-text {
  margin-bottom: 18px;
  text-align: left;
}

.cpt-two-col .cpt-visual-text p {
  margin: .5em 0;
  line-height: 1.9;
}

.cpt-two-col .cpt-visual-image {
  margin: 0;
}

.cpt-two-col .cpt-visual-image img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 21/9; /* 横長に安定 */
  object-fit: cover;
  border-radius: 14px;
  box-shadow: 0 6px 24px rgba(0,0,0,.06);
}
		
		
		
		
/* =======================================
   11) MENU
======================================= */
.menu-strengths__grid{display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));list-style:none;padding:0;margin:0;}
.menu-card{
  position:relative;background:#fff;border:1px solid #eee;border-radius:12px;padding:16px;text-align:center;box-shadow:var(--shadow-sm);
}
.menu-card__num{
  position:absolute;left:12px;top:12px;width:38px;height:38px;border-radius:10px;display:grid;place-items:center;background:#111;color:#fff;font-weight:800;font-size:.95rem;letter-spacing:.06em;
}
.menu-card__thumb{margin:0 0 12px 0;}
.menu-card__thumb img{border-radius:10px;display:block;width:100%;height:auto;object-fit:cover;}
.menu-card__title{margin:.4em 0 .2em;font-size:1.05rem;font-weight:700;}
.menu-card__text{margin:0;font-size:.95rem;opacity:.92;}
.menu-details .visual-grid{gap:28px;}
.menu-detail__text h3{margin-top:0;}
.menu-detail__image img{width:100%;height:auto;border-radius:12px;object-fit:cover;}
@media (min-width:960px){
  .menu-details .visual-grid{grid-template-columns:1fr 1fr;align-items:center;}
  .menu-details .menu-detail__text:nth-of-type(2){order:2;}
}
.u-center{text-align:center;}
.u-strong{font-weight:700;}
		
		/* ===== MENU add-ons ===== */

/* ヒーローは共通 .page-hero.tcd-ish を流用（追記なし） */

/* サムネ比率を安定化（3カード） */
.menu-card__thumb { position: relative; aspect-ratio: 4 / 3; overflow: hidden; }
.menu-card__thumb img {
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  transform:scale(1.02); transition:transform .5s ease;
}
.menu-card:hover .menu-card__thumb img { transform:scale(1.06); }

/* レッスン詳細セクション */
.menu-details .visual-grid { gap: 28px; align-items: center; }
.menu-detail__text p { margin:.5em 0; line-height:1.9; }
.menu-ctas { margin-top:12px; display:flex; flex-wrap:wrap; gap:10px; }

/* 設備帯 */
.menu-equip .equip-band {
  border:1px solid #eee; border-radius:14px; background:#fff;
  box-shadow:var(--shadow-sm); padding:clamp(16px,3vw,22px);
}
.menu-equip .equip-title { text-align:center; margin:0 0 12px; }
.equip-grid {
  list-style:none; padding:0; margin:0; display:flex; flex-wrap:wrap;
  gap:10px; justify-content:center;
}
.equip-item {
  border:1px solid #e6e8eb; border-radius:999px; padding:8px 12px;
  background:#f9fafb; font-weight:700; font-size:.92rem; color:#374151;
}
		
		
		/* ===== MENU (scoped & conflict-free) ===== */
.menu-page .mnu-container{max-width:var(--max-w,1100px);width:100%;margin:0 auto;padding-inline:clamp(16px,4vw,24px);}
.menu-page .mnu-section-title,
.menu-page h3.mnu-h3{
  font-family:"Klee One","Noto Serif JP",serif;font-weight:600;color:var(--brand,#90B8E0);
  letter-spacing:.05em;line-height:1.4;text-align:center;margin:0 0 1em;
}
.menu-page .mnu-section-title{font-size:clamp(22px,3vw,32px);}
.menu-page h3.mnu-h3{font-size:clamp(22px,3.2vw,30px);}
.menu-page .mnu-lead{font-size:1.05rem;opacity:.9;text-align:center;margin:0 auto;max-width:48rem;}

/* spacing */
.menu-page .mnu-intro,
.menu-page .mnu-offers,
.menu-page .mnu-equip{padding:clamp(48px,8vw,96px) 0;}
.menu-page .mnu-cta{padding:clamp(36px,6vw,72px) 0;}

/* visual band */
.menu-page .mnu-visual-band{padding:clamp(16px,3vw,24px) 0;}
.menu-page .mnu-band-figure{position:relative;width:100%;aspect-ratio:21/9;border-radius:14px;overflow:hidden;background:#eaeaea;box-shadow:0 6px 24px rgba(0,0,0,.06);}
.menu-page .mnu-band-figure img{display:block;width:100%;height:100%;object-fit:cover;transform:translateZ(0);}

/* offers（Conceptのカード設計を踏襲） */
.menu-page .mnu-offers-head{text-align:center;max-width:56rem;margin:0 auto 18px;}
.menu-page .mnu-offers-head p{max-width:48rem;margin:.6em auto 0;line-height:1.9;font-size:1rem;opacity:.95;}
.menu-page .mnu-offer-list{list-style:none;padding:0;margin:22px 0 0;display:grid;gap:16px;}
.menu-page .mnu-card{
  display:flex;align-items:flex-start;gap:18px;padding:16px;border:1px solid #eee;border-radius:12px;background:#fff;
  box-shadow:var(--shadow-sm,0 4px 12px rgba(0,0,0,.06));text-align:left;
}
.menu-page .mnu-card-media{--thumb:clamp(120px,32vw,200px);flex:0 0 var(--thumb);max-width:var(--thumb);margin:0;}
@media (min-width:801px){.menu-page .mnu-card-media{--thumb:200px;}}
.menu-page .mnu-card-media img{display:block;width:100%;height:auto;aspect-ratio:4/3;object-fit:cover;border-radius:10px;}
.menu-page .mnu-card-body{flex:1 1 auto;min-width:0;width:auto;writing-mode:horizontal-tb;white-space:normal;word-break:break-word;overflow-wrap:anywhere;}
.menu-page .mnu-card-title{margin:0 0 .4em;font-size:1.1rem;font-weight:700;line-height:1.5;color:#111;}
.menu-page .mnu-card-text{margin:0;line-height:1.9;font-size:1rem;opacity:.95;}
.menu-page .mnu-bullets{list-style:disc;margin:.6em 0 0 1.2em;padding:0;opacity:.92;}
.menu-page .mnu-ctas{margin-top:10px;display:flex;flex-wrap:wrap;gap:10px;}
@media (max-width:680px){
  .menu-page .mnu-card{flex-direction:column;}
  .menu-page .mnu-card-media{flex:none;width:100%;max-width:100%;}
}

/* equipment（タグ表示） */
.menu-page .mnu-equip-list{
  list-style:none;padding:0;margin:10px 0 0;display:flex;flex-wrap:wrap;gap:10px;justify-content:center;
}
.menu-page .mnu-equip-list li{
  border:1px solid #e6e8eb;border-radius:999px;padding:8px 12px;background:#f9fafb;font-weight:700;font-size:.92rem;color:#374151;
}

/* CTA（共通ボタン流用） */
.menu-page .mnu-cta-inner{
  border:1px solid #eee;border-radius:14px;background:#fff;box-shadow:var(--shadow-sm,0 6px 24px rgba(0,0,0,.06));
  display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 18px;
}
.menu-page .mnu-cta-title{margin:0 0 4px;font-size:clamp(20px,3vw,26px);font-weight:800;}
.menu-page .mnu-cta-note{margin:0;opacity:.85;}
.menu-page .mnu-cta-action{flex:0 0 auto;}
@media (max-width:720px){
  .menu-page .mnu-cta-inner{flex-direction:column;align-items:flex-start;}
}
		
		
/* =======================================
   12) PRICE
======================================= */
.price-kv{list-style:none;padding:0;margin:0;display:grid;gap:10px;}
.price-kv li{
  display:flex;justify-content:space-between;align-items:center;background:#fff;border:1px solid #eee;border-radius:12px;
  padding:12px 16px;box-shadow:var(--shadow-sm);
}
.price-kv li span{opacity:.9;}
.price-kv li strong{font-size:1.1rem;}

.price-grid{list-style:none;padding:0;margin:0;display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));}
.price-card{background:#fff;border:1px solid #eee;border-radius:14px;box-shadow:var(--shadow-sm);padding:16px;text-align:center;position:relative;}
.price-card.is-popular{border-color:var(--brand);box-shadow:0 6px 24px rgba(0,0,0,.08);}
.price-card__head{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:8px;}
.price-card__head .tag{display:inline-block;font-weight:700;font-size:.85rem;letter-spacing:.02em;padding:4px 8px;border-radius:999px;background:#f4f6fb;color:#3a4c6b;}
.price-card__head .badge{display:inline-block;font-size:.78rem;padding:2px 6px;border-radius:6px;background:var(--brand);color:#fff;font-weight:700;}
.price-card__price span{display:inline-block;font-size:1.6rem;font-weight:800;letter-spacing:.02em;}
.price-card__note{margin:.3em 0 0;font-size:.9rem;opacity:.8;}

.combo-list{list-style:none;padding:0;margin:0;display:grid;gap:12px;}
.combo-item{display:flex;align-items:center;justify-content:space-between;gap:16px;background:#fff;border:1px solid #eee;border-radius:12px;padding:12px 16px;box-shadow:var(--shadow-sm);}
.combo-item__head{font-weight:600;}
.combo-item__price{font-weight:800;}

.notes{list-style:disc inside;padding:0;margin:0;display:grid;gap:.4em;font-size:.95rem;}
.notes li{opacity:.92;}

.price-group.section,.price-personal.section,.price-combo.section{
  padding-top:clamp(28px,4vw,44px);padding-bottom:clamp(28px,4vw,44px);
}
		
		
		/* ===== Price page: heading tweak ===== */
.price-intro .section-title.u-klee.u-brand,
.price-menu .section-title.u-klee.u-brand,
.price-group .section-title.u-klee.u-brand,
.price-personal .section-title.u-klee.u-brand,
.price-combo .section-title.u-klee.u-brand {
  color: var(--brand, #90B8E0);
  position: relative;
  text-align: center;
}

/* 日本語サブ見出し（英字の下に小さく） */
.section-title .jp-sub{
  display:block;
  margin-top:.2em;
  font-size:.9rem;
  font-weight:700;
  letter-spacing:.12em;
  color:#374151;
  opacity:.85;
}

/* アクセントの下線バー（見出しの下に細いライン） */
.price-intro .section-title.u-klee.u-brand::after,
.price-menu .section-title.u-klee.u-brand::after,
.price-group .section-title.u-klee.u-brand::after,
.price-personal .section-title.u-klee.u-brand::after,
.price-combo .section-title.u-klee.u-brand::after{
  content:"";
  display:block;
  width:64px;
  height:3px;
  margin:.55em auto 0;
  background: var(--brand, #90B8E0);
  border-radius:999px;
  opacity:.9;
}

/* アンカー位置のズレ対策（固定ヘッダー分ずらす） */
#group, #personal { scroll-margin-top: calc(var(--header-h, 64px) + 12px); }

/* （任意）“まずは無料体験”ボタンを軽く：既存のブランドCTA色を使用 */
		
		
		
		
/* =======================================
   13) FAQ / Accordion
======================================= */
#faq.section{padding:clamp(36px,6vw,72px) 0;}
.faq .ttl{
  margin:0 0 .4em;text-align:center;font-family:"Klee One","Noto Serif JP",serif;font-weight:600;color:var(--brand);
  font-size:clamp(22px,3vw,32px);letter-spacing:.05em;
}
.faq .ttl2{margin:0 0 1.2em;text-align:center;opacity:.9;font-size:clamp(15px,1.6vw,18px);}
.faq .box{margin:10px 0;}
.faq .box + .box{margin-top:12px;}
.faq .box dl{margin:0;}
.faq .box dt,.faq .box dd{margin:0;}

.faq .faq-toggle{
  display:flex;align-items:flex-start;gap:12px;width:100%;
  background:#fff;border:1px solid #eee;border-radius:12px;padding:14px 18px;text-align:left;cursor:pointer;
  font:inherit;color:inherit;box-shadow:var(--shadow-sm);
  transition:background .2s,border-color .2s,box-shadow .2s;
}
.faq .faq-toggle:hover{border-color:#ddd;box-shadow:0 8px 28px rgba(0,0,0,.08);}
.faq .faq-toggle:focus-visible{outline:2px solid transparent;box-shadow:0 0 0 3px color-mix(in oklab, var(--brand) 60%, #fff);border-color:var(--brand);}
.faq .faq-item.is-open .faq-toggle{border-color:var(--brand);}
.faq .faq-toggle>span:last-child{flex:1 1 auto;font-weight:700;line-height:1.7;}
.faq .faq-toggle::after{
  content:"";flex:0 0 auto;width:12px;height:12px;margin-left:10px;margin-top:4px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg);transition:transform .2s ease;opacity:.8;
}
.faq .faq-item.is-open .faq-toggle::after{transform:rotate(-135deg);}
.faq .faq-panel{
  overflow:hidden;max-height:0;opacity:0;transition:max-height .28s ease,opacity .18s ease;
  background:#fff;border:1px solid #eee;border-top:0;border-radius:0 0 12px 12px;padding:0 18px;
}
.faq .faq-item.is-open .faq-panel{opacity:1;}
.faq .faq-panel-inner{display:flex;gap:12px;padding:14px 0 16px;}
.faq .faq-panel-inner span:last-child{line-height:1.9;}
.faq-ico{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;flex:0 0 auto;background:#111;color:#fff;font-weight:700;font-size:.8rem;margin-top:2px;}
.faq-ico--q::before{content:"Q";}
.faq-ico--a::before{content:"A";}
@media (prefers-reduced-motion: reduce){.faq .faq-toggle,.faq .faq-panel{transition-duration:.001ms !important;}}

/* =======================================
   14) Instructors
======================================= */
.instructors-about p + p{margin-top:.8em;}
.instructors-note{margin:.2em 0 1.6em;opacity:.9;}

.inst-name{
  margin:.1em 0 .4em;font-family:"Klee One","Noto Serif JP",serif;font-weight:600;
  font-size:clamp(20px,2.2vw,26px);color:var(--brand);
}
.inst-photo img{display:block;width:100%;height:auto;object-fit:cover;border-radius:12px;}

.inst-meta{list-style:none;padding:0;margin:0 0 .6em;display:flex;flex-wrap:wrap;gap:10px 16px;font-size:.95rem;}
.inst-meta li strong{font-weight:700;}

.inst-quals{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:.8em;}
.inst-qual{display:inline-block;padding:6px 10px;border-radius:999px;background:#f4f6fb;color:#3a4c6b;font-size:.85rem;font-weight:700;letter-spacing:.02em;}

.instructor-profile.visual-grid{gap:22px;align-items:start;}
@media (min-width:960px){
  .instructor-profile.visual-grid{grid-template-columns:1fr 1.2fr;}
  .instructor-profile.inst--reverse.visual-grid{grid-template-columns:1.2fr 1fr;}
  .instructor-profile.inst--reverse .visual-image{order:2;}
  .instructor-profile.inst--reverse .visual-text{order:1;}
}
.inst-bio p{margin:.5em 0;line-height:1.9;}


/* ===== Contact Form ===== */
.contact-form .wpcf7 form { margin: 0; }
.form-grid{
  display: grid; gap: 16px;
  grid-template-columns: 1fr 1fr;
}
.form-row{ display:flex; flex-direction:column; gap:8px; }
.form-row--full{ grid-column: 1 / -1; }

/* ラベル */
.form-row > label{
  font-weight:700; letter-spacing:.02em;
  display:flex; align-items:center; gap:8px;
}
.req{
  display:inline-block; font-size:.75rem; line-height:1;
  padding:2px 6px; border-radius:999px;
  background:#f4f6fb; color:#3a4c6b; font-weight:700;
}

/* 入力 */
.input-text,
.input-select,
.input-textarea,
input[type="text"], input[type="email"], input[type="tel"],
select, textarea{
  appearance:none; width:100%;
  border:1px solid #e5e7eb; border-radius:12px;
  padding:12px 14px; background:#fff; color:var(--text);
  transition:border-color .18s, box-shadow .18s, background .18s;
  font: inherit; line-height:1.6;
}
.input-textarea, textarea{ min-height: 160px; resize: vertical; }
.input-file{ display:block; }

/* フォーカス */
.input-text:focus, .input-select:focus, .input-textarea:focus,
input:focus, select:focus, textarea:focus{
  outline: 2px solid transparent;
  border-color: color-mix(in oklab, var(--brand) 55%, #ddd);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--brand) 35%, #fff);
}

/* エラー・メッセージ */
.wpcf7 form .wpcf7-not-valid{
  border-color:#e96363 !important;
  box-shadow: 0 0 0 3px rgba(233,99,99,.12);
}
.wpcf7 form .wpcf7-not-valid-tip{
  font-size:.85rem; color:#b42318; margin-top:6px;
}
.wpcf7 form .wpcf7-response-output{
  margin-top:12px; border-radius:12px; padding:12px 14px; border:1px solid #eee; background:#fff;
}

/* 送信ボタン（既存ボタンを流用） */
.form-actions .btn{ padding:14px 26px; }

/* SPレイアウト */
@media (max-width: 960px){
  .form-grid{ grid-template-columns: 1fr; }
}
/* Trial Flow */
.trial-flow .flow-step {
  margin-bottom:64px;
}
.trial-flow .flow-step h4 {
  font-family:"Klee One", serif;
  font-size:1.25rem;
  color:var(--brand);
  margin-bottom:.5em;
  display:flex;
  align-items:center;
  gap:.4em;
}
.trial-flow .step-num {
  display:inline-block;
  width:2em; height:2em;
  border-radius:50%;
  background:var(--brand);
  color:#fff; font-weight:700;
  line-height:2em; text-align:center;
  font-size:.9rem;
}
.trial-flow figure {
  margin-top:16px;
}
.trial-flow figure img {
  width:100%; height:auto;
  border-radius:12px; object-fit:cover;
}
					
					
/* =========================
   Home CONCEPT（寄せバランス）
========================= */
.home-concept{
  background:#fff;
  padding-block:80px;
}
@media (min-width:961px){ .home-concept{ padding-block:100px; } }

.home-concept__head{
  text-align:center;
  margin-bottom:28px;
}
.home-concept__label{
  display:block;
  font-size:.95rem;
  letter-spacing:.15em;
  color: var(--brand, #90B8E0);
  font-weight:600;
  margin-bottom:6px;
}
.home-concept__title{
  font-size:2rem;
  font-weight:700;
  letter-spacing:.12em;
  color: var(--brand, #90B8E0);
}
@media (min-width:961px){
  .home-concept__title{ font-size:2.4rem; }
}

/* リード文（スプラッシュフォントで太く） */
.home-concept__lead{
  text-align:center;
  font-family: var(--splash-font, "Klee One", "Noto Serif JP", serif);
  font-size:1.6rem;
  font-weight:600;   /* ← 太めに */
  line-height:1.55;  /* 詰めて力強く */
  color:#222;
  margin:22px auto 28px;
  max-width:42rem;
}
@media (min-width:961px){
  .home-concept__lead{
    font-size:1.9rem;
    line-height:1.55;
  }
}

/* 本文（ゆったり行間） */
.home-concept__body{
  max-width:46rem;
  margin:0 auto;
  color:#444;
  line-height:2;     /* ←広めにして読みやすさ重視 */
  font-size:1rem;
  text-align:center;
}

.home-concept__cta{
  text-align:center;
  margin-top:40px;
}
.btn.btn--brand-lg{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:1.2em 3.2em;
  border-radius:999px;
  font-weight:700;
  font-size:1.2rem;
  background: var(--brand, #90B8E0);
  color:#fff;
  border:1px solid transparent;
  text-decoration:none;
  transition:filter .2s ease, transform .08s ease;
}
.btn.btn--brand-lg:hover{ filter:brightness(.95); }
.btn.btn--brand-lg:active{ transform:translateY(1px); }


					
					
/* =========================
   Gate Split (MENU / PRICE)
========================= */
.home-visual-split{ margin:0; padding:0; }
.gate-split{
  display:grid; grid-template-columns:1fr 1fr; width:100%;
}
@media (max-width:960px){
  .gate-split{ grid-template-columns:1fr; }
}

.gate-split__card{
  position:relative; display:block; overflow:hidden;
  isolation:isolate; text-decoration:none; color:#fff;
  /* 高さバランス：画像が未ロードでも見栄えを維持 */
  aspect-ratio:16/9; /* 好みで16/10や3/2でもOK */
}
@supports not (aspect-ratio:1/1){
  .gate-split__card::before{ content:""; display:block; padding-top:56.25%; }
}

.gate-split__card img{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; transform:scale(1.02);
  transition:transform .5s ease, filter .5s ease;
  filter:saturate(1) contrast(1.02);
}

/* 下部グラデーションで白文字をくっきり */
.gate-split__card::after{
  content:""; position:absolute; inset:auto 0 0 0; height:62%;
  background: linear-gradient(to top, rgba(0,0,0,.52), rgba(0,0,0,.22) 45%, transparent 70%);
  z-index:1; pointer-events:none;
}

/* オーバーレイ内側 */
.gate-split__overlay{
  position:absolute; inset:0; display:flex; align-items:flex-end;
  justify-content:space-between; padding:18px 16px; z-index:2;
}
@media (min-width:961px){
  .gate-split__overlay{ padding:22px 22px; }
}

.gate-split__text{ max-width:70%; }
.gate-split__label{
  display:inline-block; font-size:.85rem; letter-spacing:.14em;
  color:#e5e7eb; opacity:.95; margin-bottom:6px;
}
.gate-split__title{
  margin:0 0 6px; font-family: var(--heading-font, "Klee One", "Noto Sans JP", system-ui, -apple-system, sans-serif);
  font-weight:800; letter-spacing:.08em; font-size:2rem; line-height:1;
  text-shadow:0 2px 10px rgba(0,0,0,.25); color:#fff;
}
@media (min-width:961px){
  .gate-split__title{ font-size:2.2rem; }
}
.gate-split__desc{
  margin:0; font-size:.95rem; line-height:1.6; opacity:.95;
}

/* 矢印ボタン風 */
.gate-split__arrow{
  display:inline-flex; align-items:center; justify-content:center;
  width:44px; height:44px; border-radius:999px;
  background:rgba(255,255,255,.92); color: var(--brand, #90B8E0);
  box-shadow:0 6px 16px rgba(0,0,0,.18);
  transform:translate3d(0,0,0);
  transition:transform .18s ease, background .18s ease, color .18s ease, box-shadow .18s ease;
}

/* ホバー演出：自然なズーム＋矢印ちょいスライド */
.gate-split__card:hover img{ transform:scale(1.06); filter:saturate(1.05); }
.gate-split__card:hover .gate-split__arrow{ transform:translateX(2px); background:#fff; color:#1f293b; }

/* 省エネ＆タッチ端末配慮 */
@media (hover:none){
  .gate-split__card:hover img{ transform:scale(1.02); }
  .gate-split__card:hover .gate-split__arrow{ transform:none; }
}
@media (prefers-reduced-motion: reduce){
  .gate-split__card img{ transition:none; }
  .gate-split__card:hover img{ transform:none; }
  .gate-split__arrow{ transition:none; }
}
					
					/* =========================
   NEWS（お知らせ）
========================= */
.home-news{ padding-block:70px; background:#fff; }
@media (min-width:961px){ .home-news{ padding-block:90px; } }

.home-news__head{
  text-align:center; margin-bottom:26px;
}
.home-news__label,
.home-news__title{
  display:block; letter-spacing:.15em; color: var(--brand, #90B8E0); font-weight:600;
}
.home-news__label{ font-size:.95rem; margin-bottom:6px; }
.home-news__title{ font-size:2rem; }
@media (min-width:961px){ .home-news__title{ font-size:2.4rem; } }

/* grid */
.news-grid{
  display:grid; gap:16px;
}
@media (min-width:801px){
  .news-grid{ grid-template-columns:repeat(3, 1fr); gap:20px; }
}

/* card */
.news-card{
  background:#fff; border:1px solid #e6e8eb; border-radius:12px; overflow:hidden;
  transition: box-shadow .18s ease, transform .18s ease, border-color .18s ease;
}
.news-card:hover{
  box-shadow:0 10px 28px rgba(0,0,0,.08);
  transform: translateY(-2px);
  border-color:#d9dce1;
}
.news-card__link{ display:block; color:inherit; text-decoration:none; }

/* thumb with fixed ratio */
.news-card__thumb{ position:relative; aspect-ratio:16/9; background:#f3f4f6; overflow:hidden; }
@supports not (aspect-ratio:1/1){
  .news-card__thumb::before{ content:""; display:block; padding-top:56.25%; }
}
.news-card__thumb img{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  transform: scale(1.02); transition: transform .5s ease;
}
.news-card:hover .news-card__thumb img{ transform: scale(1.06); }

/* body */
.news-card__body{ padding:12px 14px 14px; }
.news-card__title{
  font-size:1.02rem; line-height:1.5; color:#1f2937; margin:4px 0 8px; font-weight:700;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}
.news-card__meta{
  font-size:.85rem; color:#6b7280;
}
					
		
/* ===== Campaign 強化 & 余白 ===== */
.site-campaign-wrap.site-campaign--separate{
  margin-bottom: clamp(22px, 4vw, 40px);   /* ← フッターと“くっつく”のを回避 */
}
.campaign.card.campaign--push{
  position: relative;
  overflow: hidden;
  border: 1px solid #e6e8eb;
  background:
    radial-gradient(1200px 400px at 90% -10%, color-mix(in oklab, var(--brand) 28%, #fff), transparent 60%),
    #fff;
}
.campaign--push .campaign__head{ margin-bottom: 12px; }
.campaign--push .campaign__title{ letter-spacing: .03em; }
.campaign--push .campaign-grid{ margin-top: 10px; }
.campaign--push .campaign-ctas{ margin-top: 14px; }

/* 画像バナー */
.campaign-banner{
  position: relative;
  display: block;
  overflow: hidden;
  border-radius: var(--radius, 12px);
  box-shadow: var(--shadow-sm, 0 8px 24px rgba(0,0,0,.08));
}
.campaign-banner img{
  display:block; width:100%; height:auto; object-fit:cover; transform:scale(1.01);
  transition: transform .45s ease, filter .45s ease;
}
.campaign-banner:hover img{ transform:scale(1.04); filter:saturate(1.05) contrast(1.02); }
.campaign-banner .banner-badge{
  position:absolute; left:12px; top:12px;
  display:inline-block; padding:6px 10px; border-radius:999px;
  background: var(--brand, #90B8E0); color:#fff; font-weight:800; font-size:.82rem; letter-spacing:.06em;
  box-shadow: 0 6px 16px rgba(0,0,0,.18);
}

/* 押したくなる“鼓動” */
.btn-cta--pulse{
  position:relative;
  box-shadow: 0 8px 22px rgba(144,184,224,.35);
  animation: pulseGlow 1.8s ease-in-out infinite;
}
@keyframes pulseGlow{
  0%,100%{ box-shadow: 0 8px 22px rgba(144,184,224,.36); transform: translateY(0); }
  50%{    box-shadow: 0 10px 26px rgba(144,184,224,.5);  transform: translateY(-1px); }
}

/* ===== Footer Contacts: アイコン & 並び ===== */
.footer-contacts{
  display:flex; flex-wrap:wrap; gap: 10px 16px;
}
.footer-contacts .ico{
  margin-right: 6px; vertical-align: -3px; opacity: .9;
}
.footer-contacts li a{
  display:inline-flex; align-items:center; gap:6px;
  text-decoration: underline; text-decoration-color:#cbd5e1; text-underline-offset: 3px;
}
.footer-contacts li.insta a{
  text-decoration: none;          /* インスタだけはボタン的に */
  background:#fff;
  border:1px solid #e5e7eb;
  padding:6px 10px; border-radius:999px;
  box-shadow: 0 4px 12px rgba(0,0,0,.04);
}
.footer-contacts li.insta a:hover{ box-shadow: 0 8px 18px rgba(0,0,0,.08); }

/* ちょいアクセント */
.footer-heading{ margin-bottom: 18px; }
		
		
		
		
		
/* reCAPTCHA バッジ非表示 */
.grecaptcha-badge {
  visibility: hidden !important;
		}
		
		
/* ===== Overlay tune: darker blue for readability ===== */

/* 1) ページヒーローのグラデを“濃いめ青”に */
.page-hero.tcd-ish .page-hero__overlay{
  /* 以前より暗く・深く */
  background: linear-gradient(
    to bottom,
    rgba(60,110,180, .32) 0%,    /* ← 濃く */
    rgba(60,110,180, .42) 35%,
    rgba(60,110,180, .48) 70%,
    rgba(60,110,180, .52) 100%   /* ← 最下部ほど強く */
  );
}

/* 2) パンくず帯（下部の半透明帯）も少し暗めに */
.page-hero.tcd-ish .page-hero__crumbs-inner{
  background: rgba(60,110,180, .36);
  backdrop-filter: saturate(1.05) blur(2px);
}

/* 3) Gate Split（HOMEの2枚カード）の下部グラデも濃いめに */
.gate-split__card::after{
  background: linear-gradient(
    to top,
    rgba(60,110,180, .60),
    rgba(60,110,180, .28) 45%,
    transparent 70%
  );
}

/* 4) ヒーローの見出しを読みやすく（白文字のエッジ強化） */
.hero-title, .hero-subtitle,
.page-hero.tcd-ish .page-hero__title,
.page-hero.tcd-ish .page-hero__subtitle{
  text-shadow:
    0 2px 12px rgba(0,0,0,.35),
    0 1px 0 rgba(0,0,0,.08);
}


/* ===== Trial Flow Layout ===== */
.trial-flow .flow-step {
  margin-bottom: 48px;
}
.trial-flow .flow-grid {
  display: grid;
  gap: 24px;
  align-items: center;
}
@media (min-width: 960px) {
  .trial-flow .flow-grid {
    grid-template-columns: 1fr 1fr; /* 左テキスト / 右画像 */
  }
}
.trial-flow .flow-text p {
  line-height: 1.9;
}
.trial-flow .flow-image img {
  width: 100%;
  height: auto;
  border-radius: 12px;
  object-fit: cover;
  box-shadow: 0 4px 12px rgba(0,0,0,.08);
}
		
		
		
		
		
		
/* ==== もやっと浮遊する円背景（全ページ・少し濃い） ==== */
.bg-animation{
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

.site{
  position: relative;
  z-index: 1;
}

/* 共通：ブロブ */
.bg-animation .blob{
  position: absolute;
  width: 34vmin;
  height: 34vmin;
  border-radius: 9999px;
  filter: blur(44px);   /* ぼかし少し弱め */
  opacity: 0.26;        /* 前より濃いめ（0.18 → 0.26） */
  will-change: transform;
  mix-blend-mode: soft-light;
}

/* 色味 */
.bg-animation .blob--pink{ background:#f8d7e1; }
.bg-animation .blob--blue{ background:#cfe3f6; }
.bg-animation .blob--mix { background:#f1e8ff; }

/* ゆったり動き */
@keyframes blobA{
  0%   { transform: translate(10vw, 20vh) scale(1.0); }
  50%  { transform: translate(18vw, 14vh) scale(1.1); }
  100% { transform: translate(10vw, 20vh) scale(1.0); }
}
@keyframes blobB{
  0%   { transform: translate(65vw, 65vh) scale(0.9); }
  50%  { transform: translate(58vw, 58vh) scale(1.05); }
  100% { transform: translate(65vw, 65vh) scale(0.9); }
}
@keyframes blobC{
  0%   { transform: translate(45vw, 10vh) scale(0.95); }
  50%  { transform: translate(52vw, 18vh) scale(1.05); }
  100% { transform: translate(45vw, 10vh) scale(0.95); }
}

.bg-animation .blob--pink{ animation: blobA 36s ease-in-out infinite; }
.bg-animation .blob--blue{ animation: blobB 44s ease-in-out infinite; }
.bg-animation .blob--mix { animation: blobC 52s ease-in-out infinite; }

/* スマホ調整 */
@media (max-width: 768px){
  .bg-animation .blob{
    width: 40vmin; height: 40vmin;
    opacity: 0.22;
    filter: blur(48px);
  }
}

@media (prefers-reduced-motion: reduce){
  .bg-animation .blob{ animation: none; }
}


