/* ===========================================================
   ZEKU FITNESS — Renewal stylesheet
   Mobile-first / black-yellow / gothic-condensed

   ============================================================
   TYPOGRAPHY RULES v2 (日本語可読性ファースト)
   ============================================================
   【絶対ルール】
   - 日本語が含まれる要素は最低 12px (絶対NG: 11px以下)
   - 本文 (説明・カードテキスト) は最低 15px (PCは16px)
   - 英字装飾ラベルも 12px 以上 (letter-spacing 広めなら 12px で読める)
   - line-height は日本語向け 1.7〜2.0
   - letter-spacing は本文 0.02em (body 既定)
   - font-feature-settings: "palt" 有効化済 (body)

   【スケールトークン】(CSS変数で利用)
   --fs-2xs   12px  注記・税表記・フッタ著作権
   --fs-xs    13px  メタ情報・タグ・キャプション
   --fs-sm    14px  サブテキスト・小さめ説明
   --fs-base  15px  本文 (スマホ標準)
   --fs-md    16px  本文 (PC) / リード文
   --fs-lg    17px  強いリード文
   --fs-xl    19px  小見出し (カードタイトル)
   --fs-2xl   22px  サブセクションタイトル
   --fs-3xl   26px  セクションタイトル

   --fs-en-sm 12px  英字ラベル小 (SUPPORT / KICK BACK 等)
   --fs-en-md 14px  英字ラベル中

   --lh-tight  1.4  見出し
   --lh-snug   1.55 小見出し
   --lh-normal 1.7  デフォルト
   --lh-relax  1.85 本文 (推奨)
   --lh-loose  2.0  長文段落
=========================================================== */
:root{
  --yellow:#FFE500;
  --yellow-deep:#F4C500;
  --yellow-glow:rgba(255,229,0,.5);

  /* === サブアクセント: ピーチオレンジ (黄色のアナログ配色・初心者向けPOPアクセント) ===
     旧コーラルピンク #FF5C8A は黄色との色温度衝突＋彩度過多で違和感あり
     ピーチに変更で「黄色×ピーチ」の暖色グラデーション、上品でストイック寄り */
  --coral:#FFA670;          /* メイン: 黒背景 7.5:1 AAA */
  --coral-soft:#FFD4A6;     /* 薄: マーカー帯・装飾用 */
  --coral-deep:#C26A3D;     /* 深: 白背景の文字用 5.2:1 AA */
  --coral-glow:rgba(255,166,112,.45);

  --black:#0A0A0A;
  --black-2:#101010;
  --gray:#171717;
  --gray-2:#1F1F1F;
  --gray-3:#2A2A2A;
  --white:#FFFFFF;
  --off-white:#F2F2F2;
  --text-soft:#B5B5B5;
  --text-mute:#7A7A7A;
  --line:rgba(255,255,255,.08);
  --line-y:rgba(255,229,0,.18);

  --ease:cubic-bezier(.22,1,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);

  --radius:2px;
  --radius-lg:4px;

  --pad-mobile:20px;
  --pad-section:80px 0;

  --font-jp:"Zen Kaku Gothic New","Hiragino Kaku Gothic ProN","Noto Sans JP",sans-serif;
  --font-en:"Barlow Condensed","Oswald",sans-serif;

  /* === Typography scale (日本語可読性優先) === */
  --fs-2xs:12px;
  --fs-xs:13px;
  --fs-sm:14px;
  --fs-base:15px;
  --fs-md:16px;
  --fs-lg:17px;
  --fs-xl:19px;
  --fs-2xl:22px;
  --fs-3xl:26px;
  --fs-en-sm:12px;
  --fs-en-md:14px;
  --lh-tight:1.4;
  --lh-snug:1.55;
  --lh-normal:1.7;
  --lh-relax:1.85;
  --lh-loose:2.0;
}

*{margin:0;padding:0;box-sizing:border-box;}
*::selection{background:var(--yellow);color:#000;}
html{scroll-behavior:smooth;-webkit-tap-highlight-color:transparent;}
body{
  font-family:var(--font-jp);
  background:var(--black);
  color:var(--white);
  overflow-x:hidden;
  line-height:1.7;
  letter-spacing:.02em;
  -webkit-font-smoothing:antialiased;
  font-feature-settings:"palt";
}
img,svg{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}

[data-icon]{
  display:inline-flex;align-items:center;justify-content:center;
  width:1em;height:1em;
  vertical-align:middle;
}
[data-icon] svg{width:100%;height:100%;display:block;}

.container{
  max-width:1280px;margin:0 auto;
  padding:0 var(--pad-mobile);
}
@media (min-width:900px){
  .container{padding:0 32px;}
}

.en{font-family:var(--font-en);font-weight:800;letter-spacing:.02em;}
.en-light{font-family:var(--font-en);font-weight:600;letter-spacing:.12em;font-size:12px;color:var(--text-mute);}
.yellow{color:var(--yellow);}

/* === ピーチアクセント (黄色のアナログ配色・初心者向けPOP強調) ===
   ※ クラス名 .coral / .coral-mark / .coral-badge は記法互換性のため維持 */
.coral{color:var(--coral);}
.coral-bg{background:var(--coral);color:#1A1A1A;padding:2px 10px;border-radius:6px;font-weight:800;}
.coral-mark{
  /* マーカー風ハイライト: テキスト後ろにピーチ薄色の下線 */
  background:linear-gradient(transparent 60%, var(--coral-soft) 60%, var(--coral-soft) 92%, transparent 92%);
  padding:0 .15em;font-weight:800;
}

/* === ピーチ NEWバッジ === */
.coral-badge{
  display:inline-block;
  background:var(--coral);color:#1A1A1A;
  font-family:var(--font-en);font-weight:800;font-size:12px;letter-spacing:.12em;
  padding:4px 10px;border-radius:999px;
  box-shadow:0 4px 14px var(--coral-glow);
  animation:coralPulse 2s ease-in-out infinite;
}
@keyframes coralPulse{
  0%,100%{box-shadow:0 4px 14px var(--coral-glow);}
  50%   {box-shadow:0 4px 22px rgba(255,166,112,.7);}
}

/* ============ HEADER ============ */
.header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:14px 0;
  background:rgba(8,8,8,.78);
  backdrop-filter:blur(14px) saturate(150%);
  -webkit-backdrop-filter:blur(14px) saturate(150%);
  border-bottom:1px solid rgba(255,229,0,.06);
  transition:padding .35s var(--ease), background .35s ease;
}
.header.scrolled{padding:10px 0;background:rgba(8,8,8,.92);}
.header__inner{display:flex;align-items:center;justify-content:space-between;gap:16px;}
.logo{display:flex;align-items:center;gap:10px;flex-shrink:0;white-space:nowrap;}
.logo__img{
  height:36px;width:auto;display:block;
  transition:opacity .3s ease, transform .3s ease;
}
@media (min-width:480px){.logo__img{height:40px;}}
.logo:hover .logo__img{opacity:.85;transform:scale(1.03);}
.gnav{display:none;}
@media (min-width:1100px){
  .gnav{display:flex;gap:24px;align-items:center;}
  .gnav a{
    font-size:15px;font-weight:500;position:relative;padding:8px 0;
    transition:color .3s;
  }
  .gnav a:hover{color:var(--yellow);}
  .gnav a::after{
    content:"";position:absolute;bottom:0;left:0;right:0;height:1px;
    background:var(--yellow);transform:scaleX(0);transform-origin:right;
    transition:transform .4s var(--ease);
  }
  .gnav a:hover::after{transform:scaleX(1);transform-origin:left;}
  .logo__img{height:44px;}
}
.header-cta{
  display:none;
  background:var(--yellow);color:#000;
  padding:10px 18px;font-weight:700;font-size:14px;
  border-radius:var(--radius);
  align-items:center;gap:8px;
  transition:transform .3s,background .3s;
}
@media (min-width:760px){.header-cta{display:inline-flex;}}
.header-cta:hover{background:#fff;transform:translateY(-2px);}
.header-cta i{font-size:12px;}

.menu-btn{
  width:40px;height:40px;
  display:flex;align-items:center;justify-content:center;
  font-size:22px;color:#fff;
}
@media (min-width:1100px){.menu-btn{display:none;}}

/* ============ DRAWER ============ */
.drawer{
  position:fixed;inset:0;z-index:200;
  background:rgba(0,0,0,.97);
  backdrop-filter:blur(20px);
  display:flex;flex-direction:column;
  padding:80px 32px 40px;
  transform:translateY(-100%);
  transition:transform .55s var(--ease);
  overflow-y:auto;
}
.drawer.open{transform:translateY(0);}
.drawer::before{
  content:"ZEKU";
  position:absolute;bottom:-40px;right:-20px;
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:38vw;color:rgba(255,229,0,.04);
  line-height:.85;letter-spacing:-.04em;pointer-events:none;
}
.drawer__close{
  position:absolute;top:18px;right:18px;
  width:44px;height:44px;font-size:22px;color:#fff;
  display:flex;align-items:center;justify-content:center;
}
.drawer a{
  display:flex;justify-content:space-between;align-items:baseline;
  padding:18px 0;
  font-size:22px;font-weight:900;
  border-bottom:1px solid rgba(255,255,255,.08);
  transition:padding .3s ease;
}
.drawer a:hover{padding-left:8px;color:var(--yellow);}
.drawer__cta{
  margin-top:32px;padding:18px !important;
  background:var(--yellow);color:#000 !important;
  text-align:center;justify-content:center !important;
  border-bottom:none !important;
  font-size:15px !important;
}

/* ============ TYPO HEAD ============ */
.section{padding:var(--pad-section);position:relative;}
@media (min-width:900px){.section{padding:120px 0;}}

.section-label{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-en);font-weight:700;
  font-size:12px;letter-spacing:.3em;color:var(--yellow);
  margin-bottom:16px;
}
.section-label::before{
  content:"";width:24px;height:2px;background:var(--yellow);
}
.section-title{
  font-size:clamp(28px,6vw,52px);
  font-weight:900;line-height:1.2;margin-bottom:18px;
  letter-spacing:-.01em;
  text-wrap:balance;
}
.section-subtitle{
  color:var(--text-soft);
  font-size:15px;line-height:1.95;
  max-width:680px;margin-bottom:40px;
}
@media (min-width:760px){.section-subtitle{font-size:16px;}}

.reveal{opacity:0;transform:translateY(40px);transition:opacity 1s var(--ease),transform 1s var(--ease);}
.reveal.in{opacity:1;transform:translateY(0);}
.reveal-stagger > *{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease),transform .8s var(--ease);}
.reveal-stagger.in > *{opacity:1;transform:translateY(0);}
.reveal-stagger.in > *:nth-child(1){transition-delay:.05s;}
.reveal-stagger.in > *:nth-child(2){transition-delay:.15s;}
.reveal-stagger.in > *:nth-child(3){transition-delay:.25s;}
.reveal-stagger.in > *:nth-child(4){transition-delay:.35s;}
.reveal-stagger.in > *:nth-child(5){transition-delay:.45s;}
.reveal-stagger.in > *:nth-child(6){transition-delay:.55s;}

/* ============ HERO A ============ */
.hero{
  position:relative;min-height:100svh;
  display:flex;align-items:center;
  padding:110px 0 80px;
  overflow:hidden;
  background:
    radial-gradient(ellipse 80% 60% at 80% 30%, rgba(255,229,0,.10) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 10% 90%, rgba(255,229,0,.05) 0%, transparent 60%),
    var(--black);
}
.hero::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse at center, #000 30%, transparent 80%);
  pointer-events:none;
}
.hero--a .hero__inner{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1fr;gap:48px;
}
@media (min-width:900px){
  .hero--a .hero__inner{grid-template-columns:1.15fr .85fr;gap:60px;align-items:center;}
}

.hero__label{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--font-en);font-size:12px;letter-spacing:.18em;font-weight:700;
  color:var(--yellow);margin-bottom:24px;
  opacity:0;animation:fadeUp .8s var(--ease) .2s forwards;
}
.hero__label::before{
  content:"";width:32px;height:1px;background:var(--yellow);
  animation:lineGrow 1s var(--ease) .2s forwards;transform-origin:left;transform:scaleX(0);
}
@keyframes lineGrow{to{transform:scaleX(1);}}

.hero__title{
  font-size:clamp(34px,9vw,76px);
  font-weight:900;line-height:1.18;letter-spacing:-.015em;
  margin-bottom:24px;
  /* 日本語タイポ: 句読点を半角詰め + 単語の真ん中で改行禁止 + 末尾句読点ぶら下げ */
  font-feature-settings:"palt" 1, "halt" 1;
  word-break:keep-all;
  overflow-wrap:break-word;
  hanging-punctuation:allow-end;
  /* text-wrap:balance は日本語の禁則を破ることがあるため pretty に */
  text-wrap:pretty;
}
.hero__title .line{
  display:block;overflow:hidden;line-height:1.25;
  /* 行単位でも句読点処理を継承 */
  font-feature-settings:"palt" 1, "halt" 1;
}
.hero__title .line span{display:inline-block;transform:translateY(110%);animation:revealUp .9s var(--ease) forwards;}
.hero__title .line:nth-child(1) span{animation-delay:.3s;}
.hero__title .line:nth-child(2) span{animation-delay:.45s;}
.hero__title .line:nth-child(3) span{animation-delay:.6s;}
@keyframes revealUp{to{transform:translateY(0);}}

.hero__title .mark{position:relative;display:inline-block;}
.hero__title .mark::after{
  content:"";position:absolute;bottom:4px;left:-4px;right:-4px;height:14px;
  background:var(--yellow);z-index:-1;opacity:.25;
  transform:scaleX(0);transform-origin:left;
  animation:markGrow .6s var(--ease) 1s forwards;
}
@keyframes markGrow{to{transform:scaleX(1);}}

.hero__desc{
  font-size:15px;line-height:1.95;color:#CFCFCF;
  max-width:520px;margin-bottom:32px;
  opacity:0;animation:fadeUp 1s var(--ease) .8s forwards;
}
.hero__desc strong{color:var(--yellow);font-weight:700;}
@media (min-width:760px){.hero__desc{font-size:16px;}}

.hero__cta{
  display:flex;gap:12px;flex-wrap:wrap;
  opacity:0;animation:fadeUp 1s var(--ease) 1s forwards;
}
.btn-primary{
  position:relative;
  display:inline-flex;align-items:center;gap:14px;
  background:var(--yellow);color:#000;
  padding:18px 28px;font-weight:800;font-size:15px;
  letter-spacing:.05em;border-radius:var(--radius);
  overflow:hidden;transition:transform .3s;
  flex:1;justify-content:center;
}
@media (min-width:500px){.btn-primary{flex:initial;justify-content:flex-start;padding:20px 34px;font-size:16px;}}
.btn-primary::before{
  content:"";position:absolute;inset:0;
  background:#fff;transform:translateX(-100%);
  transition:transform .5s var(--ease);
}
.btn-primary:hover::before{transform:translateX(0);}
.btn-primary > *{position:relative;z-index:2;}
.btn-primary:hover{transform:translateY(-3px);}
.btn-primary .arrow{
  width:26px;height:26px;background:#000;color:var(--yellow);
  border-radius:50%;display:inline-flex;align-items:center;justify-content:center;
  font-size:12px;transition:transform .3s;
}
.btn-primary:hover .arrow{transform:translateX(3px);}
.btn-ghost{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:18px 24px;font-weight:700;font-size:15px;
  border:1px solid rgba(255,255,255,.4);border-radius:var(--radius);
  transition:all .3s;
  flex:1;
}
@media (min-width:500px){.btn-ghost{flex:initial;padding:20px 28px;}}
/* メインCTA=黄色 / サブCTA=ピーチホバー で役割を明確に分離 */
.btn-ghost:hover{border-color:var(--coral);color:var(--coral);}

/* HERO bg text drift */
.hero__bg-text{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  font-family:var(--font-en);
  font-weight:800;font-style:italic;
  font-size:clamp(140px,28vw,420px);
  color:rgba(255,229,0,.04);
  letter-spacing:-.04em;line-height:1;
  white-space:nowrap;pointer-events:none;
  animation:drift 24s ease-in-out infinite;
}
@keyframes drift{
  0%,100%{transform:translate(-50%,-50%) translateX(0);}
  50%{transform:translate(-50%,-50%) translateX(-30px);}
}

/* hero visual frame */
.hero__visual{
  position:relative;aspect-ratio:4/5;width:100%;
  opacity:0;animation:fadeUp 1.2s var(--ease) .5s forwards;
  max-width:480px;margin:0 auto;
}
.hero__visual-frame{
  position:relative;width:100%;height:100%;
  background:linear-gradient(135deg, #232323 0%, #0a0a0a 100%);
  border:1px solid rgba(255,229,0,.18);
  overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}
.hero__visual-frame::before{
  content:"";position:absolute;inset:-2px;
  background:conic-gradient(from 0deg, transparent 60%, var(--yellow) 75%, transparent 90%);
  animation:rotate 6s linear infinite;
  opacity:.5;
}
.hero__visual-frame::after{
  content:"";position:absolute;inset:2px;background:#0e0e0e;
  background-image:
    linear-gradient(rgba(255,229,0,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,229,0,.04) 1px,transparent 1px);
  background-size:32px 32px;
}
@keyframes rotate{to{transform:rotate(360deg);}}
.hero__visual-inner{
  position:relative;z-index:2;
  text-align:center;padding:24px 18px;
}
.hero__visual-tag{
  color:#444;font-size:12px;font-weight:600;
  font-family:var(--font-en);letter-spacing:.25em;
}
.hero__visual-big{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:clamp(36px,6vw,56px);color:var(--yellow);
  line-height:.92;margin:14px 0;letter-spacing:-.01em;
  word-break:keep-all;
}
.hero__visual-sub{color:#666;font-size:12px;line-height:1.7;margin-top:8px;}

/* corner ticks */
.hero__photo-corners{position:absolute;inset:0;z-index:3;pointer-events:none;}
.hero__photo-corners::before,.hero__photo-corners::after{
  content:"";position:absolute;width:16px;height:16px;
  border:2px solid var(--yellow);
}
.hero__photo-corners::before{top:8px;left:8px;border-right:none;border-bottom:none;}
.hero__photo-corners::after{bottom:8px;right:8px;border-left:none;border-top:none;}

.hero__badge{
  position:absolute;right:0;bottom:102px;
  width:108px;height:108px;border-radius:50%;
  background:var(--yellow);color:#000;
  display:flex;align-items:center;justify-content:center;
  text-align:center;font-weight:900;
  animation:spin 12s linear infinite;
  z-index:3;
  /* グロー過剰問題を修正: glow を box-shadow から控えめな影に */
  box-shadow:0 0 0 6px var(--black), 0 8px 22px rgba(255,229,0,.22);
  transition:box-shadow .3s ease;
}
.hero__badge:hover{
  box-shadow:0 0 0 6px var(--black), 0 12px 32px rgba(255,229,0,.45);
}
@media (min-width:900px){.hero__badge{right:-14px;bottom:108px;width:124px;height:124px;}}
.hero__badge-inner{font-size:11px;line-height:1.35;}
.hero__badge-inner small{font-size:10px;letter-spacing:.05em;display:block;}
.hero__badge-inner strong{
  font-family:var(--font-en);font-style:italic;font-size:22px;display:block;letter-spacing:0;
  margin:2px 0;
}
@media (min-width:900px){
  .hero__badge-inner small{font-size:11px;}
  .hero__badge-inner strong{font-size:24px;}
}
@media (max-width:640px){
  .hero__badge{right:6px;bottom:118px;width:92px;height:92px;}
  .hero__badge-inner{font-size:9px;line-height:1.25;}
  .hero__badge-inner small{font-size:9px;}
  .hero__badge-inner strong{font-size:19px;margin:1px 0;}
}
@keyframes spin{to{transform:rotate(360deg);}}

.scroll-cue{
  position:absolute;bottom:24px;left:50%;transform:translateX(-50%);
  z-index:5;display:none;flex-direction:column;align-items:center;gap:8px;
  font-size:12px;letter-spacing:.3em;color:var(--coral);
  font-family:var(--font-en);font-weight:600;
}
@media (min-width:900px){.scroll-cue{display:flex;}}
.scroll-cue::after{
  content:"";width:1px;height:36px;background:var(--coral);
  animation:scrollLine 2s ease-in-out infinite;
}
@keyframes scrollLine{
  0%,100%{transform:scaleY(1);transform-origin:top;}
  50%{transform:scaleY(0);transform-origin:bottom;}
}

@keyframes fadeUp{
  from{opacity:0;transform:translateY(24px);}
  to{opacity:1;transform:translateY(0);}
}

/* ============ HERO B (BIG TYPO) ============ */
.hero--b{
  background:var(--black);
  padding:110px 0 80px;
  overflow:hidden;
}
.hero--b .hero__inner{position:relative;display:flex;flex-direction:column;gap:24px;z-index:2;}
.hero-bgnum{
  position:absolute;top:60px;right:-10px;
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:clamp(80px,14vw,160px);color:rgba(255,229,0,.07);
  line-height:1;letter-spacing:-.02em;pointer-events:none;
}
.hero-typo{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:clamp(48px,15vw,150px);
  line-height:.9;letter-spacing:-.02em;color:#fff;
}
.hero-typo .row{display:flex;gap:.2em;flex-wrap:wrap;align-items:baseline;line-height:.95;}
.hero-typo .yellow{color:var(--yellow);display:block;}
.hero-typo .outline{
  -webkit-text-stroke:2px var(--yellow);
  color:transparent;
}
.hero__copy-block{margin-top:8px;}
.hero__jp{
  font-size:clamp(18px,4vw,28px);font-weight:900;line-height:1.5;
  margin-bottom:12px;
}
.hero__sub{font-size:15px;color:var(--text-soft);line-height:1.9;max-width:520px;}
@media (min-width:760px){.hero__sub{font-size:16px;}}

.hero-stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:12px;
  margin-top:8px;padding-top:24px;
  border-top:1px solid var(--line);
}
.hero-stat__num{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:clamp(36px,9vw,64px);color:var(--yellow);line-height:1;
}
.hero-stat__label{font-size:12px;color:var(--text-mute);letter-spacing:.15em;margin-top:4px;font-weight:700;}

/* ============ HERO D (NEON) ============ */
.hero--d{
  background:#000;
  padding:120px 0 80px;
}
.hero-neon-bg{
  position:absolute;inset:0;z-index:0;overflow:hidden;
  background:
    radial-gradient(ellipse 60% 50% at 30% 30%, rgba(180,0,255,.25) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 70% 80%, rgba(0,240,255,.18) 0%, transparent 60%),
    radial-gradient(ellipse 70% 50% at 50% 50%, rgba(255,0,212,.12) 0%, transparent 70%);
}
.hero-neon-bg::before{
  content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(0deg,transparent 0 3px,rgba(255,255,255,.02) 3px 4px);
  mix-blend-mode:overlay;
}
.hero--d .hero__inner{position:relative;z-index:2;}
.hero--d .hero__title{
  text-shadow:
    0 0 20px rgba(255,255,255,.3),
    0 0 40px rgba(255,0,212,.4);
}

/* ============ TICKER ============ */
.ticker{
  background:var(--yellow);color:#000;
  overflow:hidden;padding:14px 0;
  border-top:2px solid #000;border-bottom:2px solid #000;
  position:relative;
}
.ticker__track{
  display:flex;gap:36px;white-space:nowrap;
  animation:ticker 32s linear infinite;
  font-family:var(--font-en);
  font-weight:800;font-style:italic;font-size:18px;
  letter-spacing:.05em;
  width:max-content;
}
@media (min-width:760px){.ticker__track{font-size:22px;gap:40px;}}
.ticker__track span{display:flex;align-items:center;gap:36px;}
.ticker__track span::before{content:"★";color:#000;}
@keyframes ticker{to{transform:translateX(-50%);}}

/* ============ EMPATHY ============ */
.empathy{
  background:var(--black-2);
  position:relative;overflow:hidden;
}
.empathy::before{
  content:"VOICE";
  position:absolute;top:50px;right:-20px;
  font-family:var(--font-en);
  font-weight:800;font-style:italic;font-size:clamp(80px,16vw,260px);
  color:rgba(255,229,0,.04);line-height:.9;
  writing-mode:vertical-rl;
  pointer-events:none;
}
.empathy-grid{
  display:grid;grid-template-columns:1fr;
  gap:14px;margin-top:32px;
}
@media (min-width:600px){.empathy-grid{grid-template-columns:repeat(2,1fr);gap:16px;}}
@media (min-width:1000px){.empathy-grid{grid-template-columns:repeat(4,1fr);gap:18px;}}

.empathy-card{
  background:var(--gray);
  padding:24px 22px;
  border-left:3px solid var(--yellow);
  position:relative;
  transition:transform .4s var(--ease),background .3s ease;
  overflow:hidden;
}
.empathy-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:0;
  background:linear-gradient(180deg, rgba(255,229,0,.10), transparent);
  transition:height .4s var(--ease);
  z-index:0;
}
.empathy-card:hover{transform:translateY(-6px);}
.empathy-card:hover::before{height:100%;}
.empathy-card > *{position:relative;z-index:1;}
.empathy-card__num{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:48px;color:var(--yellow);line-height:.85;
  margin-bottom:10px;
  display:flex;align-items:baseline;gap:10px;
}
.empathy-card__num small{
  font-size:12px;letter-spacing:.3em;color:var(--text-mute);
  font-style:normal;font-weight:700;
}
.empathy-card__text{font-size:16px;font-weight:700;line-height:1.65;}
.empathy-card__tag{
  display:inline-flex;align-items:center;gap:6px;margin-top:14px;
  font-size:12px;font-weight:700;letter-spacing:.05em;
  color:var(--yellow);
  padding:6px 10px;background:rgba(255,229,0,.08);
}
.empathy-card__tag i{font-size:12px;}

.empathy__answer{
  margin-top:48px;padding:32px 24px;
  background:linear-gradient(135deg, rgba(255,229,0,.10) 0%, transparent 100%);
  border:1px solid rgba(255,229,0,.18);
  text-align:center;position:relative;
}
@media (min-width:760px){.empathy__answer{padding:48px;}}
.empathy__answer-lead{font-size:12px;color:var(--yellow);font-weight:700;letter-spacing:.3em;margin-bottom:14px;}
.empathy__answer-main{
  font-size:clamp(20px,4.5vw,32px);font-weight:900;line-height:1.5;
  text-wrap:balance;
}

/* ============ SUPPORT ============ */
.support{background:var(--black);position:relative;}
.support-intro{display:grid;grid-template-columns:1fr;gap:20px;margin-bottom:40px;}
@media (min-width:900px){.support-intro{grid-template-columns:1.2fr .8fr;gap:60px;align-items:end;margin-bottom:60px;}}
.support-intro p{color:var(--text-soft);line-height:1.95;font-size:15px;}
@media (min-width:900px){.support-intro p{font-size:16px;}}

.support-steps{display:grid;grid-template-columns:1fr;gap:16px;position:relative;}
@media (min-width:900px){
  .support-steps{grid-template-columns:repeat(3,1fr);gap:20px;}
  .support-steps::before{
    content:"";position:absolute;
    top:60px;left:8%;right:8%;height:2px;
    background:repeating-linear-gradient(90deg, var(--yellow) 0 8px, transparent 8px 16px);
    opacity:.25;z-index:0;
  }
}
.support-step{
  position:relative;z-index:1;
  background:var(--gray);
  padding:32px 24px 28px;
  border:1px solid var(--line);
  transition:all .4s var(--ease);
  overflow:hidden;
}
.support-step::after{
  content:"";position:absolute;top:0;right:0;width:0;height:2px;
  background:var(--yellow);transition:width .5s var(--ease);
}
.support-step:hover{
  border-color:rgba(255,229,0,.4);
  background:var(--gray-2);
  transform:translateY(-6px);
}
.support-step:hover::after{width:100%;left:0;}
.support-step__icon-wrap{
  width:60px;height:60px;
  background:var(--yellow);color:#000;
  display:flex;align-items:center;justify-content:center;
  font-size:26px;
  margin-bottom:20px;
  position:relative;
  transform:rotate(-3deg);
  transition:transform .4s var(--ease);
}
.support-step:hover .support-step__icon-wrap{transform:rotate(3deg) scale(1.05);}
.support-step__icon-wrap::after{
  content:"";position:absolute;inset:-4px;border:1px solid var(--yellow);opacity:.3;
}
.support-step__num{
  font-family:var(--font-en);
  font-size:12px;font-weight:700;letter-spacing:.25em;
  color:var(--yellow);margin-bottom:8px;
}
.support-step__title{font-size:20px;font-weight:900;margin-bottom:12px;line-height:1.4;}
.support-step__desc{font-size:15px;color:var(--text-soft);line-height:1.85;}
@media (min-width:900px){.support-step__desc{font-size:16px;}}

/* ============ BLACKOUT ============ */
.blackout{
  position:relative;overflow:hidden;
  background:#000;
  padding:120px 0;
  color:#fff;
  isolation:isolate;
}
@media (min-width:900px){.blackout{padding:160px 0;}}
.blackout__bg{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(ellipse 900px 600px at 50% 50%, rgba(20,5,35,1) 0%, transparent 70%),
    linear-gradient(180deg, #000 0%, #0a0015 50%, #000 100%);
}
.blackout::after{
  content:"";position:absolute;inset:0;z-index:5;
  background:repeating-linear-gradient(0deg,transparent 0,transparent 3px,rgba(255,255,255,.012) 3px,rgba(255,255,255,.012) 4px);
  pointer-events:none;mix-blend-mode:overlay;
}
.laser{position:absolute;left:-20%;width:140%;height:2px;pointer-events:none;z-index:2;filter:blur(.5px);}
.laser::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg, transparent, var(--c) 20%, #fff 50%, var(--c) 80%, transparent);
  box-shadow:0 0 8px var(--c),0 0 16px var(--c),0 0 40px var(--c),0 0 80px var(--c);
}
.laser-1{top:18%;--c:#FF00D4;animation:laserSweep 7s ease-in-out infinite;transform:rotate(-8deg);}
.laser-2{top:48%;--c:#00F0FF;animation:laserSweep 9s ease-in-out infinite -2s;transform:rotate(6deg);}
.laser-3{top:78%;--c:#FFE500;animation:laserSweep 6s ease-in-out infinite -4s;transform:rotate(-4deg);}
@keyframes laserSweep{
  0%,100%{opacity:0;transform:translateX(-30%) rotate(var(--r,-8deg)) scaleX(0);}
  10%{opacity:1;transform:translateX(-10%) rotate(var(--r,-8deg)) scaleX(1);}
  60%{opacity:1;transform:translateX(10%) rotate(var(--r,-8deg)) scaleX(1);}
  75%{opacity:0;transform:translateX(30%) rotate(var(--r,-8deg)) scaleX(1);}
}
.orb{position:absolute;border-radius:50%;pointer-events:none;z-index:1;mix-blend-mode:screen;filter:blur(60px);}
.orb-1{
  width:400px;height:400px;top:-100px;left:-150px;
  background:radial-gradient(circle, #FF00D4 0%, transparent 60%);
  animation:orbPulse 6s ease-in-out infinite, orbFloat1 14s ease-in-out infinite;
}
.orb-2{
  width:500px;height:500px;bottom:-200px;right:-200px;
  background:radial-gradient(circle, #00F0FF 0%, transparent 60%);
  animation:orbPulse 8s ease-in-out infinite -2s, orbFloat2 18s ease-in-out infinite;
}
.orb-3{
  width:350px;height:350px;top:30%;right:10%;
  background:radial-gradient(circle, #B400FF 0%, transparent 60%);
  animation:orbPulse 7s ease-in-out infinite -3s, orbFloat3 16s ease-in-out infinite;
}
.orb-4{
  width:280px;height:280px;bottom:25%;left:20%;
  background:radial-gradient(circle, #FFE500 0%, transparent 60%);
  animation:orbPulse 5s ease-in-out infinite -1s, orbFloat1 12s ease-in-out infinite reverse;
}
@keyframes orbPulse{
  0%,100%{opacity:.4;filter:blur(60px);}
  50%{opacity:.75;filter:blur(80px);}
}
@keyframes orbFloat1{
  0%,100%{transform:translate(0,0);}
  33%{transform:translate(60px,30px);}
  66%{transform:translate(-30px,60px);}
}
@keyframes orbFloat2{
  0%,100%{transform:translate(0,0);}
  33%{transform:translate(-60px,-30px);}
  66%{transform:translate(30px,-60px);}
}
@keyframes orbFloat3{
  0%,100%{transform:translate(0,0) scale(1);}
  50%{transform:translate(-40px,40px) scale(1.15);}
}

.blackout__inner{position:relative;z-index:10;}
.blackout__head{display:grid;grid-template-columns:1fr;gap:24px;margin-bottom:48px;}
@media (min-width:900px){.blackout__head{grid-template-columns:1.1fr .9fr;gap:60px;align-items:end;margin-bottom:60px;}}

.blackout__label{
  color:#FF00D4;font-weight:800;
  text-shadow:0 0 10px #FF00D4, 0 0 20px #FF00D4;
}
.blackout__label::before{background:#FF00D4;box-shadow:0 0 8px #FF00D4;}

/* BLACKOUT brand lockup (Z logo + label, horizontal) */
.blackout__brand{
  display:flex;
  align-items:center;
  gap:16px;
  margin-bottom:18px;
}
.blackout__brand .blackout__label{margin-bottom:0;}
.blackout__emblem{
  display:block;
  width:auto;height:64px;
  margin:0;
  filter:
    drop-shadow(0 0 12px rgba(255,0,212,.65))
    drop-shadow(0 0 28px rgba(180,0,255,.45));
  animation:emblemBreathe 3.4s ease-in-out infinite;
  pointer-events:none;
  user-select:none;
  flex-shrink:0;
}
@media (min-width:760px){.blackout__emblem{height:84px;}}
@keyframes emblemBreathe{
  0%,100%{
    filter:drop-shadow(0 0 10px rgba(255,0,212,.6)) drop-shadow(0 0 22px rgba(180,0,255,.4));
  }
  50%{
    filter:drop-shadow(0 0 16px rgba(255,0,212,.9)) drop-shadow(0 0 38px rgba(180,0,255,.6));
  }
}

.blackout__title{
  font-family:var(--font-en);
  font-weight:800;font-style:italic;
  font-size:clamp(72px,16vw,200px);
  line-height:.9;letter-spacing:-.02em;
  color:#fff;position:relative;
  text-shadow:
    0 0 20px rgba(255,255,255,.5),
    0 0 40px rgba(255,0,212,.5),
    0 0 80px rgba(0,240,255,.3);
}
.blackout__title .shake{display:inline-block;position:relative;animation:neonFlicker 4s linear infinite;}
.blackout__title .shake::before,
.blackout__title .shake::after{
  content:attr(data-text);
  position:absolute;top:0;left:0;width:100%;
  mix-blend-mode:screen;
}
.blackout__title .shake::before{color:#FF00D4;animation:glitch1 3s steps(1) infinite;text-shadow:0 0 20px #FF00D4;}
.blackout__title .shake::after{color:#00F0FF;animation:glitch2 3s steps(1) infinite;text-shadow:0 0 20px #00F0FF;}
@keyframes neonFlicker{
  0%,19.9%,21%,63%,63.9%,65%,100%{opacity:1;}
  20%,64%{opacity:.7;}
  64.5%{opacity:.4;}
}
@keyframes glitch1{
  0%,100%{transform:translate(0);clip-path:inset(0);}
  10%{transform:translate(-3px,2px);clip-path:inset(20% 0 60% 0);}
  20%{transform:translate(3px,-2px);clip-path:inset(60% 0 10% 0);}
  30%{transform:translate(-2px,1px);clip-path:inset(40% 0 40% 0);}
  40%,90%{transform:translate(0);clip-path:inset(0);}
}
@keyframes glitch2{
  0%,100%{transform:translate(0);clip-path:inset(0);}
  15%{transform:translate(3px,-1px);clip-path:inset(10% 0 70% 0);}
  25%{transform:translate(-3px,2px);clip-path:inset(70% 0 10% 0);}
  35%{transform:translate(2px,-2px);clip-path:inset(30% 0 50% 0);}
  45%,95%{transform:translate(0);clip-path:inset(0);}
}
.blackout__subtitle{
  font-size:clamp(18px,3vw,26px);font-weight:700;
  line-height:1.65;margin-bottom:20px;
  text-shadow:0 0 20px rgba(255,255,255,.3);
}
.blackout__desc{
  font-size:15px;line-height:1.95;color:#C0C0C0;
  margin-bottom:24px;
}
@media (min-width:900px){.blackout__desc{font-size:16px;}}
.blackout__keywords{display:flex;flex-wrap:wrap;gap:8px;}
.blackout__keyword{
  padding:8px 14px;
  border:1px solid var(--yellow);
  font-family:var(--font-en);
  font-weight:700;font-size:12px;letter-spacing:.15em;
  color:var(--yellow);
  background:rgba(0,0,0,.3);
  backdrop-filter:blur(4px);
  text-shadow:0 0 8px var(--yellow);
  box-shadow:0 0 10px rgba(255,229,0,.25),inset 0 0 10px rgba(255,229,0,.06);
  animation:keywordGlow 3s ease-in-out infinite;
}
.blackout__keyword:nth-child(2){animation-delay:-.5s;color:#FF00D4;border-color:#FF00D4;text-shadow:0 0 8px #FF00D4;box-shadow:0 0 10px rgba(255,0,212,.25),inset 0 0 10px rgba(255,0,212,.06);}
.blackout__keyword:nth-child(3){animation-delay:-1s;color:#00F0FF;border-color:#00F0FF;text-shadow:0 0 8px #00F0FF;box-shadow:0 0 10px rgba(0,240,255,.25),inset 0 0 10px rgba(0,240,255,.06);}
.blackout__keyword:nth-child(4){animation-delay:-1.5s;color:#B400FF;border-color:#B400FF;text-shadow:0 0 8px #B400FF;box-shadow:0 0 10px rgba(180,0,255,.25),inset 0 0 10px rgba(180,0,255,.06);}
.blackout__keyword:nth-child(5){animation-delay:-2s;}
@keyframes keywordGlow{0%,100%{filter:brightness(1);}50%{filter:brightness(1.25);}}

/* PROGRAMS slider */
.programs-wrap{margin:0 -20px;}
@media (min-width:900px){.programs-wrap{margin:0;}}
.programs{
  display:grid;grid-auto-flow:column;
  grid-auto-columns:80%;
  gap:14px;overflow-x:auto;padding:16px 20px 24px;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:thin;
  scrollbar-color:var(--yellow) rgba(255,255,255,.05);
}
@media (min-width:600px){.programs{grid-auto-columns:45%;}}
@media (min-width:900px){.programs{grid-auto-columns:minmax(240px,1fr);padding:16px 0 24px;}}
.programs::-webkit-scrollbar{height:5px;}
.programs::-webkit-scrollbar-track{background:rgba(255,255,255,.04);}
.programs::-webkit-scrollbar-thumb{background:var(--yellow);}

.program-card{
  scroll-snap-align:start;
  aspect-ratio:3/4;
  background:linear-gradient(180deg, rgba(40,20,40,.8) 0%, rgba(0,0,0,.95) 100%);
  border:1px solid rgba(255,255,255,.10);
  padding:20px;
  display:flex;flex-direction:column;justify-content:space-between;
  position:relative;overflow:hidden;
  transition:transform .5s var(--ease),border-color .3s ease;
  cursor:pointer;
}
.program-card::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg, rgba(255,0,180,.25), rgba(0,180,255,.25));
  opacity:0;transition:opacity .5s var(--ease);
}
.program-card:hover{transform:translateY(-8px);border-color:var(--yellow);}
.program-card:hover::before{opacity:.18;}
.program-card > *{position:relative;z-index:2;}
.program-card__photo{
  position:absolute;inset:0;z-index:0 !important;
  background-size:cover;background-position:center;
  filter:saturate(1.05) contrast(.95);
  transition:transform .8s var(--ease);
}
.program-card__photo::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.25) 0%, rgba(10,10,15,.55) 45%, rgba(0,0,0,.92) 100%);
}
.program-card:hover .program-card__photo{transform:scale(1.06);}
.program-card__num{
  font-family:var(--font-en);font-weight:800;font-size:13px;letter-spacing:.2em;color:var(--yellow);
}
.program-card__title{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:clamp(22px,5vw,28px);
  letter-spacing:.02em;line-height:1;
  margin-bottom:10px;
}
.program-card__jp{font-size:12px;color:#CFCFCF;line-height:1.7;margin-bottom:14px;}
.program-card__tags{display:flex;flex-wrap:wrap;gap:5px;}
.program-card__tag{
  font-family:var(--font-en);
  font-size:12px;padding:3px 8px;
  background:rgba(255,229,0,.12);color:var(--yellow);
  letter-spacing:.1em;font-weight:700;
}
.program-card__arrow{
  position:absolute;right:18px;bottom:18px;
  width:36px;height:36px;border:1px solid var(--yellow);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--yellow);font-size:13px;z-index:3;
  transition:all .3s;
}
.program-card:hover .program-card__arrow{background:var(--yellow);color:#000;transform:rotate(-45deg);}

/* ============ PROGRAM GALAXY (interactive bubble cluster) ============ */
.program-galaxy{
  position:relative;
  margin:30px auto 0;
  width:100%;
  max-width:none;
  height:820px;
  isolation:isolate;
}
@media (min-width:760px){.program-galaxy{height:680px;}}

/* CTA on top of galaxy — guides users to tap */
.galaxy-cta{
  position:absolute;top:6px;left:50%;transform:translateX(-50%);
  z-index:14;
  display:flex;flex-direction:column;align-items:center;gap:4px;
  pointer-events:none;text-align:center;
  transition:opacity .5s ease;
}
.galaxy-cta.dim{opacity:.35;}
.galaxy-cta__bounce{
  width:36px;height:36px;border-radius:50%;
  background:var(--yellow);color:#000;
  display:flex;align-items:center;justify-content:center;
  font-size:14px;font-weight:900;
  box-shadow:0 0 18px var(--yellow), 0 0 40px var(--yellow);
  animation:bounceCta 1.6s ease-in-out infinite;
}
@keyframes bounceCta{
  0%,100%{transform:translateY(0);}
  50%{transform:translateY(8px);}
}
.galaxy-cta__text{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:18px;letter-spacing:.08em;color:var(--yellow);
  text-shadow:0 0 12px var(--yellow);
}
.galaxy-cta__sub{
  font-family:var(--font-en);font-weight:700;
  font-size:12px;letter-spacing:.22em;color:rgba(255,255,255,.7);
}

.galaxy-stage{
  position:absolute;inset:80px 0 36px;
  z-index:11;
}
.galaxy-stage::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse 80% 60% at 50% 50%, rgba(255,229,0,.05) 0%, transparent 70%),
    radial-gradient(circle at 18% 25%, rgba(255,0,212,.07) 0%, transparent 50%),
    radial-gradient(circle at 82% 75%, rgba(0,240,255,.06) 0%, transparent 50%),
    radial-gradient(circle at 50% 80%, rgba(180,0,255,.05) 0%, transparent 55%);
  pointer-events:none;
}

.galaxy-bubble-wrap{
  position:absolute;
  width:118px;height:118px;
  transform:translate(-50%,-50%);
  pointer-events:none;
}
@media (min-width:760px){.galaxy-bubble-wrap{width:138px;height:138px;}}

.galaxy-bubble{
  position:relative;display:block;
  width:100%;height:100%;
  border:none;background:transparent;padding:0;cursor:pointer;
  pointer-events:auto;
  -webkit-tap-highlight-color:transparent;
  animation-name:bubFloatA;
  animation-timing-function:ease-in-out;
  animation-iteration-count:infinite;
  animation-duration:9s;
}
.galaxy-bubble[data-anim="b"]{animation-name:bubFloatB;}
.galaxy-bubble[data-anim="c"]{animation-name:bubFloatC;}
.galaxy-bubble[data-anim="d"]{animation-name:bubFloatD;}

.galaxy-bubble__inner{
  display:block;
  position:relative;
  width:100%;height:100%;
  border-radius:50%;
  background-color:#0a0a0a;
  background-size:cover;background-position:center;background-repeat:no-repeat;
  border:2px solid var(--bub-c, #fff);
  box-shadow:
    0 0 22px var(--bub-c, #fff),
    0 0 50px rgba(0,0,0,.55),
    inset 0 0 14px rgba(0,0,0,.35);
  transition:transform .4s var(--ease), box-shadow .4s ease, filter .4s ease;
  overflow:hidden;
  filter:saturate(1.1) contrast(1.04);
}
/* color tint at top — keeps neon mood */
.galaxy-bubble__inner::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 50% 0%, var(--bub-c, #fff), transparent 60%);
  opacity:.22;mix-blend-mode:screen;pointer-events:none;
}
/* pulsing outer ring — tap affordance */
.galaxy-bubble__inner::after{
  content:"";position:absolute;inset:-4px;
  border-radius:50%;
  border:1.5px solid var(--bub-c, #fff);
  opacity:.45;
  animation:bubPulse 2.6s ease-in-out infinite;
  pointer-events:none;
}
@keyframes bubPulse{
  0%,100%{transform:scale(1);opacity:.45;}
  50%{transform:scale(1.13);opacity:0;}
}

.galaxy-bubble:hover .galaxy-bubble__inner,
.galaxy-bubble:focus-visible .galaxy-bubble__inner,
.galaxy-bubble.active .galaxy-bubble__inner{
  transform:scale(1.18);
  filter:saturate(1.18) brightness(1.05) contrast(1.05);
  box-shadow:
    0 0 38px var(--bub-c, #fff),
    0 0 86px var(--bub-c, #fff),
    inset 0 0 24px rgba(0,0,0,.25);
}
.galaxy-bubble:hover .galaxy-bubble__inner::after,
.galaxy-bubble.active .galaxy-bubble__inner::after{
  animation-duration:1.2s;
  opacity:.7;
}

/* Hover label — popup tooltip showing program name */
.galaxy-bubble__label{
  position:absolute;
  left:50%;
  top:calc(100% + 14px);
  transform:translateX(-50%) translateY(-6px);
  padding:6px 12px 5px;
  font-family:var(--font-en);
  font-weight:800;font-style:italic;
  font-size:12px;letter-spacing:.04em;line-height:1.15;
  color:#fff;text-align:center;
  background:rgba(0,0,0,.92);
  border:1px solid var(--bub-c, #fff);
  white-space:nowrap;
  opacity:0;
  pointer-events:none;
  transition:opacity .25s ease, transform .25s var(--ease);
  box-shadow:0 0 16px rgba(0,0,0,.7), 0 0 22px var(--bub-c, #fff);
  text-shadow:0 0 6px var(--bub-c, #fff);
  z-index:6;
}
@media (min-width:760px){
  .galaxy-bubble__label{font-size:12px;padding:7px 14px 6px;}
}
.galaxy-bubble__label::before{
  content:"";position:absolute;
  left:50%;top:-6px;transform:translateX(-50%) rotate(45deg);
  width:8px;height:8px;
  background:rgba(0,0,0,.92);
  border-left:1px solid var(--bub-c, #fff);
  border-top:1px solid var(--bub-c, #fff);
}
.galaxy-bubble[data-label-pos="top"] .galaxy-bubble__label{
  top:auto;
  bottom:calc(100% + 14px);
  transform:translateX(-50%) translateY(6px);
}
.galaxy-bubble[data-label-pos="top"] .galaxy-bubble__label::before{
  top:auto;bottom:-6px;
  transform:translateX(-50%) rotate(225deg);
}
.galaxy-bubble:hover .galaxy-bubble__label,
.galaxy-bubble:focus-visible .galaxy-bubble__label,
.galaxy-bubble.active .galaxy-bubble__label{
  opacity:1;
  transform:translateX(-50%) translateY(0);
}

@keyframes bubFloatA{
  0%,100%{transform:translate(0,0);}
  50%{transform:translate(10px,-14px);}
}
@keyframes bubFloatB{
  0%,100%{transform:translate(0,0);}
  33%{transform:translate(-12px,9px);}
  66%{transform:translate(13px,-7px);}
}
@keyframes bubFloatC{
  0%,100%{transform:translate(0,0);}
  50%{transform:translate(-13px,-11px);}
}
@keyframes bubFloatD{
  0%,100%{transform:translate(0,0);}
  25%{transform:translate(11px,5px);}
  75%{transform:translate(-8px,-13px);}
}

.galaxy-hint{
  position:absolute;bottom:6px;left:50%;transform:translateX(-50%);
  z-index:10;
  font-family:var(--font-en);font-size:12px;letter-spacing:.22em;font-weight:700;
  color:rgba(255,255,255,.5);
  pointer-events:none;white-space:nowrap;
  animation:hintPulse 2.4s ease-in-out infinite;
}
@keyframes hintPulse{0%,100%{opacity:.5;}50%{opacity:.95;}}

/* DETAIL PANEL */
.galaxy-detail{
  position:absolute;inset:0;z-index:30;
  display:flex;align-items:center;justify-content:center;
  padding:24px 50px;
  opacity:0;visibility:hidden;
  transition:opacity .4s var(--ease), visibility .4s;
  background:radial-gradient(ellipse at center, rgba(0,0,0,.7) 0%, rgba(0,0,0,.95) 100%);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  overflow:hidden;
}
.galaxy-detail.open{opacity:1;visibility:visible;}

.galaxy-detail__photo{
  position:absolute;inset:0;z-index:0;
  background-size:cover;background-position:center;
  filter:saturate(.95) brightness(.45);
  opacity:0;transform:scale(1.05);
  transition:opacity .5s ease, transform .8s var(--ease);
}
.galaxy-detail__photo.show{opacity:.55;transform:scale(1);}
.galaxy-detail::after{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(ellipse at center, transparent 25%, rgba(0,0,0,.65) 100%);
}

.galaxy-detail__body{
  position:relative;z-index:2;
  width:100%;max-width:460px;
  max-height:calc(100% - 40px);
  overflow-y:auto;
  text-align:center;color:#fff;
  scrollbar-width:thin;scrollbar-color:var(--bub-c, #fff) rgba(255,255,255,.05);
}
.galaxy-detail__body::-webkit-scrollbar{width:4px;}
.galaxy-detail__body::-webkit-scrollbar-thumb{background:var(--bub-c, #fff);}

.galaxy-detail__num{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:36px;color:var(--bub-c, #fff);line-height:1;
  text-shadow:0 0 22px var(--bub-c, #fff);
  margin-bottom:6px;
}
.galaxy-detail__title{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:clamp(24px,5.5vw,40px);line-height:1.04;
  letter-spacing:-.01em;
  margin-bottom:8px;
  text-shadow:0 0 28px var(--bub-c, #fff);
}
.galaxy-detail__catch{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:14px;letter-spacing:.04em;
  color:var(--bub-c, #fff);
  margin-bottom:12px;
  text-shadow:0 0 12px var(--bub-c, #fff);
}
.galaxy-detail__desc{
  font-size:15px;line-height:1.85;color:#dedede;
  margin-bottom:14px;
  padding:0 6px;
}
@media (min-width:760px){.galaxy-detail__desc{font-size:16px;}}
.galaxy-detail__tags{
  display:flex;flex-wrap:wrap;gap:6px;justify-content:center;
  margin-bottom:18px;
}
.galaxy-detail__tag{
  font-family:var(--font-en);font-size:12px;font-weight:700;letter-spacing:.15em;
  padding:4px 10px;
  border:1px solid var(--bub-c, #fff);color:var(--bub-c, #fff);
  background:rgba(0,0,0,.4);
  text-shadow:0 0 4px var(--bub-c, #fff);
}

.galaxy-detail__meta{
  display:grid;grid-template-columns:auto 1fr;gap:7px 14px;
  margin:0 auto;
  padding:14px 18px;
  background:rgba(0,0,0,.55);
  border:1px solid var(--bub-c, #fff);
  border-radius:2px;
  text-align:left;max-width:380px;
  box-shadow:inset 0 0 14px rgba(0,0,0,.4);
}
.galaxy-detail__meta .meta-row{display:contents;}
.galaxy-detail__meta .meta-label{
  font-family:var(--font-en);font-size:12px;letter-spacing:.18em;font-weight:700;
  color:var(--bub-c, #fff);
  white-space:nowrap;align-self:center;
  text-shadow:0 0 6px var(--bub-c, #fff);
}
.galaxy-detail__meta .meta-value{
  font-size:14px;color:#fff;line-height:1.5;font-weight:500;
}
@media (min-width:760px){.galaxy-detail__meta .meta-value{font-size:15px;}}
.galaxy-detail__meta .meta-value.stars{
  font-family:var(--font-en);font-weight:800;letter-spacing:.1em;
  color:var(--bub-c, #fff);font-size:14px;
}

.galaxy-detail__close{
  position:absolute;top:14px;right:14px;z-index:5;
  width:42px;height:42px;border-radius:50%;
  background:rgba(0,0,0,.6);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:14px;
  border:1px solid rgba(255,255,255,.3);
  transition:all .3s;
}
.galaxy-detail__close:hover{background:var(--bub-c, #fff);color:#000;border-color:var(--bub-c, #fff);}

.galaxy-detail__nav{
  position:absolute;top:50%;transform:translateY(-50%);z-index:5;
  width:44px;height:44px;border-radius:50%;
  background:rgba(0,0,0,.6);color:#fff;
  font-family:var(--font-en);font-weight:800;font-size:28px;line-height:1;
  display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(255,255,255,.25);
  transition:all .3s;
  padding-bottom:3px;
}
.galaxy-detail__nav:hover{background:var(--bub-c, #fff);color:#000;border-color:var(--bub-c, #fff);}
.galaxy-detail__nav.prev{left:8px;}
.galaxy-detail__nav.next{right:8px;}
@media (min-width:760px){
  .galaxy-detail__nav{width:50px;height:50px;font-size:32px;}
  .galaxy-detail__nav.prev{left:14px;}
  .galaxy-detail__nav.next{right:14px;}
}

.galaxy-detail__pager{
  position:absolute;bottom:14px;left:50%;transform:translateX(-50%);z-index:5;
  font-family:var(--font-en);font-size:12px;letter-spacing:.25em;font-weight:700;
  color:rgba(255,255,255,.55);
}
.galaxy-detail__pager-hint{
  display:block;font-size:12px;letter-spacing:.2em;color:rgba(255,255,255,.35);margin-top:2px;
}

/* color tokens */
.galaxy-bubble-wrap[data-color="magenta"]{--bub-c:#FF00D4;}
.galaxy-bubble-wrap[data-color="cyan"]{--bub-c:#00F0FF;}
.galaxy-bubble-wrap[data-color="yellow"]{--bub-c:#FFE500;}
.galaxy-bubble-wrap[data-color="purple"]{--bub-c:#B400FF;}
.galaxy-detail.color-magenta{--bub-c:#FF00D4;}
.galaxy-detail.color-cyan{--bub-c:#00F0FF;}
.galaxy-detail.color-yellow{--bub-c:#FFE500;}
.galaxy-detail.color-purple{--bub-c:#B400FF;}

/* ============ PERSONAL ============ */
.personal{background:var(--black);position:relative;overflow:hidden;}
.personal__lead{color:var(--text-soft);font-size:15px;line-height:1.95;margin-bottom:20px;}
@media (min-width:760px){.personal__lead{font-size:16px;}}
.personal__grid{display:grid;grid-template-columns:1fr;gap:32px;align-items:center;}
@media (min-width:900px){.personal__grid{grid-template-columns:1fr 1.1fr;gap:60px;}}
.personal__visual{
  position:relative;aspect-ratio:4/5;max-width:480px;width:100%;margin:0 auto;
  background:linear-gradient(135deg, rgba(255,229,0,.08), transparent 70%), var(--gray);
  overflow:hidden;
  border:1px solid var(--line);
}
.personal__visual::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,229,0,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,229,0,.04) 1px,transparent 1px);
  background-size:40px 40px;
}
.personal__visual-inner{
  position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  color:var(--text-mute);font-family:var(--font-en);letter-spacing:.2em;font-size:12px;
  gap:14px;
}
.personal__visual-inner i{font-size:60px;color:var(--yellow);opacity:.4;}
.personal__sticker{
  position:absolute;top:16px;right:16px;z-index:3;
  background:var(--yellow);color:#000;
  padding:10px 14px;font-weight:900;font-size:12px;
  transform:rotate(3deg);
  white-space:nowrap;
  box-shadow:0 6px 20px rgba(255,229,0,.3);
}
.personal-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:32px 0;}
.personal-stat{
  padding:18px 12px;background:var(--gray);
  border-top:2px solid var(--yellow);
  text-align:left;
}
.personal-stat__num{
  font-family:var(--font-en);
  font-weight:800;font-size:clamp(32px,6vw,44px);font-style:italic;color:var(--yellow);
  line-height:1;
}
.personal-stat__num .unit{font-size:.45em;margin-left:2px;font-style:normal;}
.personal-stat__label{font-size:12px;color:var(--text-soft);margin-top:6px;font-weight:700;letter-spacing:.1em;}

.personal-trial{
  margin-top:24px;padding:24px 20px;
  background:linear-gradient(135deg, rgba(255,229,0,.10) 0%, rgba(255,229,0,.02) 100%);
  border:1px dashed var(--yellow);
  position:relative;
}
.personal-trial__badge{
  position:absolute;top:-12px;left:20px;
  background:var(--yellow);color:#000;padding:4px 12px;
  font-size:12px;font-weight:900;letter-spacing:.15em;font-family:var(--font-en);
}
.personal-trial__row{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.personal-trial__text{font-size:15px;font-weight:700;line-height:1.6;}
@media (min-width:760px){.personal-trial__text{font-size:16px;}}
.personal-trial__price{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;}
.personal-trial__old{text-decoration:line-through;color:var(--text-mute);font-size:14px;}
.personal-trial__new{
  font-family:var(--font-en);font-style:italic;font-weight:800;
  font-size:40px;color:var(--yellow);line-height:1;
}
.personal-trial__free{font-size:12px;color:var(--yellow);font-weight:700;width:100%;letter-spacing:.05em;}

/* ============ BEFORE / AFTER ============ */
.ba{background:var(--black-2);}
.ba-grid{display:grid;grid-template-columns:1fr;gap:24px;margin-top:32px;}
@media (min-width:900px){.ba-grid{grid-template-columns:1fr 1fr;gap:28px;}}
.ba-card{
  background:var(--gray);padding:24px;
  border:1px solid var(--line);
  transition:border-color .4s ease;
}
.ba-card:hover{border-color:rgba(255,229,0,.3);}
.ba-card__head{display:flex;gap:14px;align-items:center;margin-bottom:20px;}
.ba-card__avatar{
  width:54px;height:54px;border-radius:50%;
  background:linear-gradient(135deg,var(--yellow),var(--yellow-deep));
  color:#000;display:flex;align-items:center;justify-content:center;
  font-weight:900;font-size:16px;font-family:var(--font-en);
  flex-shrink:0;
}
.ba-card__meta{font-size:12px;color:var(--text-mute);letter-spacing:.08em;margin-bottom:2px;}
.ba-card__name{font-size:18px;font-weight:900;}
.ba-card__trainer{font-size:12px;color:var(--yellow);font-weight:700;margin-top:2px;letter-spacing:.05em;}

/* BA SLIDER (drag to reveal) */
.ba-slider{
  position:relative;aspect-ratio:3/2;
  background:#222;
  overflow:hidden;
  cursor:ew-resize;
  user-select:none;
  margin-bottom:18px;
  border:1px solid var(--line);
}
.ba-slider__before,.ba-slider__after{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-en);font-weight:800;font-style:italic;font-size:48px;
  letter-spacing:.1em;
}
.ba-slider__before{
  background:
    linear-gradient(135deg,#3a3a3a 0%,#1a1a1a 100%);
  color:#444;
}
.ba-slider__after{
  background:
    radial-gradient(ellipse at center,rgba(255,229,0,.12),transparent 70%),
    linear-gradient(135deg,#1f1f0e 0%,#0d0d0a 100%);
  color:rgba(255,229,0,.45);
  clip-path:inset(0 0 0 50%);
}
.ba-slider__handle{
  position:absolute;top:0;bottom:0;left:50%;width:2px;
  background:var(--yellow);
  z-index:3;
  box-shadow:0 0 12px var(--yellow);
}
.ba-slider__handle::before{
  content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:36px;height:36px;border-radius:50%;
  background:var(--yellow);
  box-shadow:0 0 20px var(--yellow);
}
.ba-slider__handle::after{
  content:"⇄";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  font-size:14px;color:#000;font-weight:900;
  z-index:1;
}
.ba-slider__label{
  position:absolute;top:12px;
  font-family:var(--font-en);font-weight:800;font-size:12px;letter-spacing:.2em;
  padding:4px 10px;background:rgba(0,0,0,.7);color:#fff;
  z-index:2;
}
.ba-slider__label.before{left:12px;}
.ba-slider__label.after{right:12px;background:var(--yellow);color:#000;}

.ba-results{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:18px;}
.ba-result{background:var(--black);padding:14px;text-align:center;}
.ba-result__label{font-size:12px;color:var(--text-mute);letter-spacing:.15em;margin-bottom:4px;}
.ba-result__value{
  font-family:var(--font-en);font-weight:800;font-size:30px;font-style:italic;
  color:var(--yellow);line-height:1;
}
.ba-result__value .unit{font-size:.5em;margin-left:1px;}
.ba-card__comment{font-size:15px;color:var(--text-soft);line-height:1.85;}
@media (min-width:760px){.ba-card__comment{font-size:16px;}}

/* ============ PRICE ============ */
.price{background:var(--black);}
.price__switcher{
  display:flex;gap:6px;margin-bottom:28px;flex-wrap:wrap;
}
.price__tab{
  padding:10px 16px;background:var(--gray);color:var(--text-soft);
  font-size:12px;font-weight:700;letter-spacing:.05em;
  cursor:pointer;transition:all .3s;border:1px solid transparent;
}
.price__tab.active{
  background:var(--yellow);color:#000;
  box-shadow:0 4px 14px rgba(255,229,0,.3);  /* 選択中の立体感UP */
}
.price__tab:hover:not(.active){border-color:var(--yellow);color:var(--yellow);}

.plan-grid{display:grid;grid-template-columns:1fr;gap:14px;}
@media (min-width:600px){.plan-grid{grid-template-columns:repeat(2,1fr);gap:16px;}}
@media (min-width:1000px){.plan-grid{grid-template-columns:repeat(3,1fr);gap:18px;}}

.plan{
  background:var(--gray);
  padding:32px 24px;
  position:relative;
  border:1px solid var(--line);
  transition:transform .4s var(--ease),border-color .3s ease;
  display:flex;flex-direction:column;
}
.plan.hidden{display:none;}
.plan:hover{transform:translateY(-6px);border-color:rgba(255,229,0,.3);}
.plan.featured{
  background:linear-gradient(180deg, #1c1c1c 0%, var(--gray) 100%);
  border-color:var(--yellow);
}
.plan.featured::before{
  content:"POPULAR";
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  /* 黄→ピーチのグラデで「特別感」を強化（アナログ配色の見せ場） */
  background:linear-gradient(90deg, var(--yellow) 0%, var(--coral) 100%);
  color:#1A1A1A;
  padding:5px 18px;font-size:12px;font-weight:900;letter-spacing:.2em;
  font-family:var(--font-en);
  box-shadow:0 4px 14px rgba(255,166,112,.35);
}
.plan__name{
  font-family:var(--font-en);font-weight:800;
  font-size:24px;letter-spacing:.05em;margin-bottom:6px;
}
.plan__sub{font-size:12px;color:var(--text-mute);margin-bottom:20px;letter-spacing:.08em;font-weight:700;}
.plan__price{display:flex;align-items:baseline;gap:4px;margin-bottom:4px;}
.plan__price .currency{font-size:18px;font-weight:800;color:var(--yellow);margin-right:2px;}
.plan__price .num{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:56px;color:#fff;line-height:1;letter-spacing:.01em;
  /* 通常プラン: 白で視認性最大化、￥マークと月期間を yellow / soft に配分 */
}
/* featured プランの価格だけピーチで視線誘導 → 「これがおすすめ」を色で伝える */
.plan.featured .plan__price .num{color:var(--coral);}
.plan.featured .plan__price .currency{color:var(--coral);}
.plan__price .period{font-size:13px;color:var(--text-soft);font-weight:600;}
.plan__tax{font-size:12px;color:var(--text-mute);margin-bottom:20px;}
.plan__list{list-style:none;margin-bottom:24px;border-top:1px solid var(--line);padding-top:16px;flex:1;}
.plan__list li{padding:7px 0;font-size:15px;color:#CFCFCF;padding-left:20px;position:relative;line-height:1.8;}
@media (min-width:760px){.plan__list li{font-size:16px;}}
.plan__list li::before{content:"";position:absolute;left:0;top:13px;width:12px;height:2px;background:var(--yellow);}
.plan__cta{
  display:block;width:100%;text-align:center;
  padding:14px;background:transparent;border:1px solid var(--yellow);color:var(--yellow);
  font-weight:700;font-size:12px;letter-spacing:.1em;
  transition:all .3s;
}
.plan__cta:hover{background:var(--yellow);color:#000;}
.plan.featured .plan__cta{background:var(--yellow);color:#000;}
.plan.featured .plan__cta:hover{background:#fff;border-color:#fff;}

.plan-finder{
  margin-top:48px;padding:32px 24px;text-align:center;
  background:linear-gradient(135deg, rgba(255,229,0,.08), transparent);
  border:1px solid rgba(255,229,0,.15);
}
.plan-finder__title{font-size:clamp(18px,4vw,24px);font-weight:900;margin-bottom:10px;text-wrap:balance;}
.plan-finder__desc{font-size:15px;color:var(--text-soft);margin-bottom:20px;line-height:1.85;}
@media (min-width:760px){.plan-finder__desc{font-size:16px;}}

/* ============ QUIZ MODAL ============ */
.quiz-modal{
  position:fixed;inset:0;z-index:300;
  background:rgba(0,0,0,.85);
  backdrop-filter:blur(8px);
  display:none;align-items:center;justify-content:center;
  padding:20px;
}
.quiz-modal.open{display:flex;animation:fadeIn .35s ease;}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
.quiz-modal__inner{
  position:relative;
  background:var(--gray);
  border:1px solid var(--line-y);
  width:100%;max-width:520px;
  max-height:90vh;overflow-y:auto;
  padding:48px 28px 32px;
  animation:popIn .4s var(--ease);
}
@keyframes popIn{from{transform:translateY(20px) scale(.97);opacity:0;}to{transform:none;opacity:1;}}
.quiz-close{
  position:absolute;top:14px;right:14px;
  width:36px;height:36px;font-size:18px;color:#fff;
  display:flex;align-items:center;justify-content:center;
  border-radius:50%;background:rgba(255,255,255,.06);
}
.quiz-close:hover{background:rgba(255,229,0,.15);color:var(--yellow);}
.quiz-progress{
  position:absolute;top:0;left:0;right:0;height:3px;
  background:rgba(255,255,255,.05);
}
.quiz-progress__fill{
  height:100%;background:var(--yellow);
  transition:width .5s var(--ease);
  box-shadow:0 0 10px var(--yellow);
}
.quiz-step{display:none;}
.quiz-step.active{display:block;}
.quiz-step__num{
  font-family:var(--font-en);font-size:12px;letter-spacing:.3em;color:var(--yellow);
  margin-bottom:8px;font-weight:700;
}
.quiz-step__title{font-size:22px;font-weight:900;line-height:1.4;margin-bottom:24px;text-wrap:balance;}
.quiz-options{display:flex;flex-direction:column;gap:10px;}
.quiz-option{
  display:flex;align-items:center;gap:14px;
  padding:16px 18px;
  background:var(--black);border:1px solid var(--line);
  text-align:left;
  transition:all .3s;
  font-size:15px;font-weight:700;line-height:1.5;
}
.quiz-option:hover,.quiz-option.selected{
  border-color:var(--yellow);background:rgba(255,229,0,.08);
  transform:translateX(4px);
}
.quiz-option__num{
  width:32px;height:32px;border-radius:50%;background:rgba(255,229,0,.12);
  display:flex;align-items:center;justify-content:center;
  color:var(--yellow);font-family:var(--font-en);font-weight:800;font-size:14px;
  flex-shrink:0;
}
.quiz-option:hover .quiz-option__num,.quiz-option.selected .quiz-option__num{background:var(--yellow);color:#000;}
.quiz-option__sub{font-size:12px;color:var(--text-mute);font-weight:500;display:block;margin-top:3px;}

.quiz-result{text-align:center;}
.quiz-result__lead{font-family:var(--font-en);font-size:12px;letter-spacing:.3em;color:var(--yellow);margin-bottom:8px;font-weight:700;}
.quiz-result__title{font-size:20px;font-weight:900;margin-bottom:20px;line-height:1.5;text-wrap:balance;}
.quiz-result__plan{
  background:linear-gradient(180deg,#1c1c1c,var(--gray));
  border:2px solid var(--yellow);padding:24px;margin-bottom:20px;
}
.quiz-result__plan-name{font-family:var(--font-en);font-weight:800;font-size:28px;color:var(--yellow);letter-spacing:.05em;margin-bottom:6px;}
.quiz-result__plan-price{
  font-family:var(--font-en);font-weight:800;font-style:italic;font-size:42px;color:#fff;line-height:1;margin:8px 0;
}
.quiz-result__plan-price small{font-size:.4em;color:var(--text-soft);font-style:normal;}
.quiz-result__plan-desc{font-size:15px;color:var(--text-soft);line-height:1.85;}
@media (min-width:760px){.quiz-result__plan-desc{font-size:16px;}}
.quiz-result__cta{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 28px;background:var(--yellow);color:#000;
  font-weight:800;font-size:14px;letter-spacing:.05em;
  transition:transform .3s;
}
.quiz-result__cta:hover{transform:translateY(-2px);}
.quiz-result__retry{
  display:block;margin:14px auto 0;font-size:12px;color:var(--text-mute);
  text-decoration:underline;
}

/* ============ FAQ ============ */
.faq{background:var(--black-2);}
.faq-list{display:flex;flex-direction:column;gap:8px;margin-top:32px;}
.faq-item{
  background:var(--gray);
  border:1px solid var(--line);
  transition:border-color .3s ease;
  overflow:hidden;
}
.faq-item.open{border-color:rgba(255,229,0,.3);}
.faq-item__q{
  display:flex;justify-content:space-between;align-items:center;gap:14px;
  padding:18px 20px;width:100%;text-align:left;
  font-size:15px;font-weight:700;line-height:1.6;
}
@media (min-width:760px){.faq-item__q{font-size:16px;}}
.faq-item__q-mark{
  font-family:var(--font-en);font-weight:800;font-style:italic;color:var(--yellow);
  margin-right:8px;font-size:16px;
}
.faq-item__icon{
  width:24px;height:24px;flex-shrink:0;position:relative;
}
.faq-item__icon::before,
.faq-item__icon::after{
  content:"";position:absolute;top:50%;left:50%;background:var(--yellow);
  transition:transform .3s ease;
}
.faq-item__icon::before{width:14px;height:2px;transform:translate(-50%,-50%);}
.faq-item__icon::after{width:2px;height:14px;transform:translate(-50%,-50%);}
.faq-item.open .faq-item__icon::after{transform:translate(-50%,-50%) scaleY(0);}

.faq-item__a{
  max-height:0;overflow:hidden;
  transition:max-height .4s var(--ease);
}
.faq-item.open .faq-item__a{max-height:800px;}
.faq-item__a-inner{
  padding:0 20px 20px;
  color:var(--text-soft);font-size:15px;line-height:1.95;
}
@media (min-width:760px){.faq-item__a-inner{font-size:16px;}}

/* ============ FLOW ============ */
.flow{background:var(--black);}
.flow-list{
  display:grid;grid-template-columns:1fr;gap:14px;margin-top:32px;
}
@media (min-width:600px){.flow-list{grid-template-columns:repeat(2,1fr);gap:16px;}}
@media (min-width:1100px){.flow-list{grid-template-columns:repeat(5,1fr);}}
.flow-item{
  background:var(--gray);padding:28px 22px 24px;
  position:relative;
  transition:all .3s;
  border:1px solid var(--line);
  overflow:hidden;
}
.flow-item:hover{background:var(--gray-2);transform:translateY(-4px);border-color:rgba(255,229,0,.25);}
.flow-item__num{
  position:absolute;top:14px;right:18px;
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:48px;color:rgba(255,229,0,.13);line-height:1;
}
.flow-item__icon{
  width:48px;height:48px;background:var(--yellow);color:#000;
  display:flex;align-items:center;justify-content:center;
  font-size:22px;margin-bottom:14px;
}
.flow-item__label{
  font-family:var(--font-en);
  font-size:12px;color:var(--yellow);font-weight:700;letter-spacing:.25em;margin-bottom:6px;
}
.flow-item__title{font-size:18px;font-weight:900;margin-bottom:8px;line-height:1.4;}
.flow-item__desc{font-size:15px;color:var(--text-soft);line-height:1.85;}
@media (min-width:760px){.flow-item__desc{font-size:16px;}}

/* ============ FINAL CTA ============ */
.final-cta{
  padding:90px 0 110px;position:relative;overflow:hidden;
  background:var(--yellow);color:#000;
}
@media (min-width:900px){.final-cta{padding:120px 0;}}
.final-cta::before{
  content:"START";position:absolute;left:-30px;top:50%;transform:translateY(-50%);
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:clamp(180px,32vw,420px);
  color:#000;opacity:.07;line-height:.9;letter-spacing:-.03em;pointer-events:none;
}
.final-cta__inner{position:relative;z-index:2;text-align:center;}
.final-cta__lead{font-family:var(--font-en);font-size:12px;font-weight:700;letter-spacing:.3em;margin-bottom:16px;}
.final-cta__title{
  font-size:clamp(36px,8vw,80px);
  font-weight:900;line-height:1.1;margin-bottom:24px;
  letter-spacing:-.02em;
  text-wrap:balance;
}
.final-cta__desc{font-size:15px;line-height:1.95;max-width:560px;margin:0 auto 32px;font-weight:500;}
@media (min-width:760px){.final-cta__desc{font-size:17px;}}
.final-cta__btn{
  display:inline-flex;align-items:center;gap:14px;
  background:#000;color:var(--yellow);
  padding:22px 36px;font-size:16px;font-weight:900;letter-spacing:.05em;
  transition:all .3s;
}
.final-cta__btn:hover{background:#fff;color:#000;transform:translateY(-3px);}
.final-cta__btn i{font-size:18px;}
.final-cta__phone{margin-top:24px;font-size:15px;font-weight:700;}
@media (min-width:760px){.final-cta__phone{font-size:16px;}}
.final-cta__phone a{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:26px;border-bottom:2px solid #000;padding-bottom:2px;margin-left:8px;
  display:inline-flex;align-items:center;gap:6px;
}
.final-cta__phone a i{font-size:18px;}

/* ============ FOOTER ============ */
.footer{background:#000;padding:60px 0 100px;color:#888;font-size:14px;line-height:1.85;}
@media (min-width:760px){.footer{font-size:15px;}}
@media (min-width:900px){.footer{padding:80px 0 30px;}}
.footer__grid{display:grid;grid-template-columns:1fr;gap:32px;margin-bottom:40px;}
@media (min-width:600px){.footer__grid{grid-template-columns:1fr 1fr;gap:32px;}}
@media (min-width:1000px){.footer__grid{grid-template-columns:1.5fr 1fr 1fr 1fr;gap:36px;margin-bottom:50px;}}
.footer__logo{margin-bottom:14px;}
.footer__logo img{height:40px;width:auto;display:block;}
.footer__info p{margin-bottom:6px;line-height:1.8;}
.footer__title{color:#fff;font-size:12px;font-weight:700;letter-spacing:.25em;margin-bottom:14px;font-family:var(--font-en);}
.footer__list{list-style:none;}
.footer__list li{margin-bottom:8px;}
.footer__list a{color:#888;transition:color .3s;}
.footer__list a:hover{color:var(--yellow);}
.footer__bottom{
  border-top:1px solid #222;padding-top:20px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:12px;
}
.footer__social{display:flex;gap:10px;margin-top:6px;}
.footer__social a{
  width:34px;height:34px;border:1px solid #333;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:14px;
  transition:all .3s;
}
.footer__social a:hover{background:var(--yellow);border-color:var(--yellow);color:#000;}

/* ============ MOBILE STICKY CTA ============ */
.mobile-cta{
  position:fixed;left:0;right:0;bottom:0;z-index:90;
  display:flex;gap:0;
  background:rgba(8,8,8,.96);
  backdrop-filter:blur(16px);
  border-top:1px solid var(--line-y);
  padding:8px;padding-bottom:max(8px,env(safe-area-inset-bottom));
  transform:translateY(100%);
  transition:transform .4s var(--ease);
}
.mobile-cta.show{transform:translateY(0);}
@media (min-width:900px){.mobile-cta{display:none !important;}}
.mobile-cta a{
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 8px;font-size:15px;font-weight:800;
  flex:1;border-radius:var(--radius);
}
.mobile-cta a.primary{background:var(--yellow);color:#000;flex:1.5;}
.mobile-cta a.ghost{color:#fff;border:1px solid rgba(255,255,255,.18);margin-right:8px;}
.mobile-cta a i{font-size:16px;}

/* ============ PHOTO INJECTION (TOP page) ============ */
/* Hero A — replace placeholder block with real photo */
.hero__visual-frame.has-photo{
  background:#0a0a0a;
}
.hero__visual-frame.has-photo .hero__visual-photo{
  position:absolute;inset:2px;z-index:1;
  background-size:cover;background-position:center;
  filter:saturate(1.05) contrast(1.02);
}
.hero__visual-frame.has-photo .hero__visual-photo::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 50%, rgba(0,0,0,.55) 100%),
             linear-gradient(135deg, rgba(255,229,0,.08) 0%, transparent 40%);
}
.hero__visual-frame.has-photo .hero__visual-inner{display:none;}
.hero__visual-overlay{
  position:absolute;left:14px;right:14px;bottom:14px;z-index:3;
  display:flex;align-items:flex-end;justify-content:space-between;gap:10px;
  pointer-events:none;
}
.hero__visual-overlay .tag{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:14px;color:var(--yellow);letter-spacing:.05em;
  background:rgba(0,0,0,.55);padding:6px 10px;
  border-left:2px solid var(--yellow);
  backdrop-filter:blur(4px);
}
.hero__visual-overlay .meta{
  font-family:var(--font-en);font-weight:700;
  font-size:12px;color:#fff;letter-spacing:.2em;
  background:rgba(0,0,0,.55);padding:6px 10px;
  backdrop-filter:blur(4px);
}

/* Hero D — neon bg with studio photo */
.hero-neon-bg.has-photo{
  background-image:
    linear-gradient(180deg, rgba(0,0,0,.5) 0%, rgba(10,0,20,.78) 60%, #000 100%),
    var(--neon-photo);
  background-size:cover;background-position:center;
  filter:saturate(1.1);
}

/* Empathy answer — add a thin photo strip as visual accent */
.empathy__photos{
  display:grid;grid-template-columns:repeat(3,1fr);gap:6px;
  margin:36px 0 0;
}
.empathy__photo{
  aspect-ratio:4/3;background-size:cover;background-position:center;
  border:1px solid var(--line);
  filter:grayscale(.15) contrast(1.05);
  transition:filter .4s var(--ease), transform .5s var(--ease);
}
.empathy__photo:hover{filter:grayscale(0) contrast(1.05);transform:translateY(-2px);}
@media (max-width:640px){
  .empathy__photos{grid-template-columns:repeat(3,1fr);gap:4px;}
}

/* Support steps — top photo header */
.support-step{padding:0;overflow:hidden;}
.support-step__photo{
  width:100%;aspect-ratio:5/3;
  background-size:cover;background-position:center;
  position:relative;
}
.support-step__photo::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,0) 40%, rgba(20,20,20,.92) 100%);
}
.support-step__body{padding:24px 22px 28px;position:relative;z-index:2;margin-top:-44px;}
.support-step .support-step__icon-wrap{position:relative;z-index:2;}
.support-steps::before{display:none;}

/* Blackout — replace placeholder bg with studio photo */
.blackout__bg.has-photo{
  background:
    radial-gradient(ellipse at 30% 30%, rgba(255,16,255,.18) 0%, transparent 50%),
    radial-gradient(ellipse at 70% 70%, rgba(0,229,255,.14) 0%, transparent 55%),
    linear-gradient(180deg, rgba(0,0,0,.55) 0%, rgba(10,0,20,.85) 100%),
    var(--blackout-photo) center/cover no-repeat;
}

/* Personal — replace placeholder with real photo */
.personal__visual.has-photo{
  background:#0a0a0a;
  overflow:hidden;
}
.personal__visual.has-photo::before{display:none;}
.personal__visual.has-photo .personal__visual-inner{display:none;}
.personal__visual-photo{
  position:absolute;inset:0;z-index:1;
  background-size:cover;background-position:center;
}
.personal__visual-photo::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 55%, rgba(0,0,0,.5) 100%);
}
.personal__visual.has-photo .personal__sticker{z-index:3;}
.personal__visual-frame{
  content:"";position:absolute;inset:10px;z-index:2;pointer-events:none;
  border:1px solid rgba(255,229,0,.25);
}
.personal__visual-frame::before,
.personal__visual-frame::after{
  content:"";position:absolute;width:18px;height:18px;border:2px solid var(--yellow);
}
.personal__visual-frame::before{top:-1px;left:-1px;border-right:none;border-bottom:none;}
.personal__visual-frame::after{bottom:-1px;right:-1px;border-left:none;border-top:none;}

/* BA slider — real photos */
.ba-slider.has-photos .ba-slider__before{
  background:var(--ba-before) center/cover no-repeat;
  color:transparent;
}
.ba-slider.has-photos .ba-slider__after{
  background:var(--ba-after) center/cover no-repeat;
  color:transparent;
}

/* BA photo — static composite (no slider) */
.ba-photo{
  position:relative;
  background:#000;
  border:1px solid var(--line);
  margin-bottom:18px;
  overflow:hidden;
  transition:border-color .4s ease, transform .5s var(--ease);
  line-height:0;
}
.ba-photo img{
  display:block;
  width:100%;
  height:auto;
}
.ba-card:hover .ba-photo{border-color:rgba(255,229,0,.35);}
.ba-photo::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg, transparent 75%, rgba(0,0,0,.45) 100%),
    linear-gradient(90deg, rgba(0,0,0,.18) 0%, transparent 22%, transparent 78%, rgba(255,229,0,.06) 100%);
  pointer-events:none;
}
.ba-photo__label{
  position:absolute;top:12px;
  font-family:var(--font-en);font-weight:800;font-size:12px;letter-spacing:.22em;
  padding:5px 11px;
  z-index:3;
  font-style:italic;
}
.ba-photo__label.before{
  left:12px;
  background:rgba(0,0,0,.78);color:#fff;
  border-left:2px solid #888;
}
.ba-photo__label.after{
  right:12px;
  background:var(--yellow);color:#000;
  box-shadow:0 0 18px rgba(255,229,0,.4);
}
.ba-photo__arrow{
  position:absolute;bottom:14px;left:50%;transform:translateX(-50%);
  z-index:3;
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:14px;letter-spacing:.15em;
  color:var(--yellow);
  text-shadow:0 0 10px rgba(255,229,0,.7);
  background:rgba(0,0,0,.6);
  padding:5px 14px;
  border:1px solid rgba(255,229,0,.5);
}

/* Final CTA — yellow with photo strip on side */
.final-cta__photos{
  position:absolute;inset:0;z-index:0;pointer-events:none;
  display:grid;grid-template-columns:1fr 1fr 1fr;
  opacity:.18;mix-blend-mode:multiply;
}
.final-cta__photo{
  background-size:cover;background-position:center;
}
.final-cta__photo:nth-child(2){display:none;}
@media (min-width:900px){
  .final-cta__photos{opacity:.14;}
  .final-cta__photo:nth-child(2){display:block;}
}

/* Section divider strip — full bleed gym photo (between sections) */
.photo-strip{
  position:relative;height:280px;
  background-size:cover;background-position:center;
  overflow:hidden;
}
.photo-strip::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg, rgba(0,0,0,.85) 0%, rgba(0,0,0,.35) 50%, rgba(0,0,0,.85) 100%);
}
.photo-strip::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, var(--black) 0%, transparent 8%, transparent 92%, var(--black) 100%);
}
.photo-strip__inner{
  position:relative;z-index:2;height:100%;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:0 var(--pad-mobile);
}
.photo-strip__lead{
  font-family:var(--font-en);font-size:12px;letter-spacing:.4em;
  color:var(--yellow);margin-bottom:12px;font-weight:700;
}
.photo-strip__title{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:clamp(40px,7vw,72px);line-height:.95;
  letter-spacing:-.01em;
}
.photo-strip__title .yellow{color:var(--yellow);}
.photo-strip__sub{
  font-size:15px;color:var(--text-soft);margin-top:14px;letter-spacing:.05em;line-height:1.85;
}
@media (min-width:760px){.photo-strip__sub{font-size:16px;}}
@media (min-width:900px){
  .photo-strip{height:360px;}
}

/* ============ TWEAKS yellow accent ============ */
body[data-accent="lime"]{
  --yellow:#D8FF00;
  --yellow-deep:#B8E000;
}
body[data-accent="amber"]{
  --yellow:#FFB800;
  --yellow-deep:#E69E00;
}

/* reduce motion */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;}
}

/* ============ GOOGLE REVIEWS ============ */
.reviews-section{padding:80px 0;background:#0a0a0a;position:relative;overflow:hidden;}
.reviews-section::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 0%, rgba(255,229,0,.08), transparent 60%);
  pointer-events:none;
}
.reviews-header{text-align:center;margin-bottom:40px;position:relative;}
.reviews-header .section-label{justify-content:center;}
.reviews-header .section-label::before{display:none;}
.reviews-header .section-title{margin-bottom:12px;}
.reviews-rating{
  display:inline-flex;align-items:center;gap:14px;
  margin-top:20px;padding:14px 24px;
  background:rgba(255,229,0,.08);
  border:1px solid rgba(255,229,0,.3);
  border-radius:999px;
}
.reviews-rating__stars{color:var(--yellow);font-size:18px;letter-spacing:.1em;}
.reviews-rating__num{
  font-family:var(--font-en);font-weight:800;font-size:30px;color:#fff;
  line-height:1;display:inline-flex;align-items:baseline;gap:2px;
}
.reviews-rating__num small{font-size:14px;color:var(--text-mute);}
.reviews-rating__count{font-size:12px;color:var(--text-soft);letter-spacing:.05em;}

.reviews-carousel{
  position:relative;margin:0 -20px;
  -webkit-mask-image:linear-gradient(90deg, transparent 0, #000 6%, #000 94%, transparent 100%);
  mask-image:linear-gradient(90deg, transparent 0, #000 6%, #000 94%, transparent 100%);
}
.reviews-track{
  display:flex;gap:18px;padding:8px 20px;
  width:max-content;
  animation:reviews-scroll 60s linear infinite;
}
.reviews-carousel:hover .reviews-track{animation-play-state:paused;}
@keyframes reviews-scroll{
  from{transform:translateX(0);}
  to{transform:translateX(-50%);}
}

.review-card{
  flex:0 0 auto;width:320px;
  background:#171717;border:1px solid rgba(255,255,255,.08);
  border-radius:12px;padding:20px;
  display:flex;flex-direction:column;gap:12px;
  transition:border-color .2s, transform .2s;
}
.review-card:hover{border-color:rgba(255,229,0,.4);transform:translateY(-2px);}

.review-card__head{display:flex;align-items:center;gap:12px;}
.review-card__avatar{
  width:42px;height:42px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-en);font-weight:800;font-size:14px;
  color:#fff;flex-shrink:0;letter-spacing:.04em;
  background:var(--yellow);color:#111;
}
.review-card__avatar[data-color="yellow"]{background:linear-gradient(135deg,#FFE500,#F4C500);color:#111;}
.review-card__avatar[data-color="cyan"]{background:linear-gradient(135deg,#22D3EE,#0EA5E9);color:#fff;}
.review-card__avatar[data-color="magenta"]{background:linear-gradient(135deg,#EC4899,#C026D3);color:#fff;}
.review-card__avatar[data-color="purple"]{background:linear-gradient(135deg,#A78BFA,#7C3AED);color:#fff;}
.review-card__avatar[data-color="pink"]{background:linear-gradient(135deg,#FB7185,#E11D48);color:#fff;}
.review-card__avatar[data-color="green"]{background:linear-gradient(135deg,#34D399,#059669);color:#fff;}

.review-card__meta{flex:1;min-width:0;}
.review-card__name{font-size:14px;font-weight:700;color:#fff;}
.review-card__date{font-size:12px;color:var(--text-mute);margin-top:2px;letter-spacing:.05em;}

.review-card__google{flex-shrink:0;opacity:.8;}

.review-card__stars{color:var(--yellow);font-size:14px;letter-spacing:.05em;}
.review-card__comment{
  font-size:15px;line-height:1.8;color:var(--text-soft);
  display:-webkit-box;-webkit-line-clamp:6;-webkit-box-orient:vertical;
  overflow:hidden;
}

.reviews-cta{text-align:center;margin-top:36px;}
.reviews-cta__btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 28px;
  background:#fff;color:#111;border-radius:999px;
  font-size:14px;font-weight:700;
  transition:transform .2s, box-shadow .2s;
  box-shadow:0 4px 14px rgba(0,0,0,.3);
}
.reviews-cta__btn:hover{transform:translateY(-2px);box-shadow:0 8px 22px rgba(0,0,0,.4);}
.reviews-cta__btn i{font-size:12px;}

@media (max-width:768px){
  .reviews-section{padding:60px 0;}
  .review-card{width:280px;padding:16px;}
  .reviews-rating{padding:10px 18px;gap:10px;}
  .reviews-rating__num{font-size:24px;}
}

/* ============ trainer-detail__placeholder + role + instagram ============ */
.trainer-detail__media{position:relative;}
.trainer-detail__placeholder{
  display:none;
  position:absolute;inset:0;
  align-items:center;justify-content:center;flex-direction:column;
  background:linear-gradient(135deg, #1a1a1a, #2a2a2a);
  border:1px dashed rgba(255,229,0,.4);
  color:rgba(255,255,255,.5);
  font-size:14px;letter-spacing:.1em;font-weight:600;
  min-height:300px;border-radius:8px;
}
.trainer-detail__placeholder::before{
  content:"📷";font-size:42px;margin-bottom:10px;opacity:.4;
}
.trainer-detail__placeholder.is-shown{display:flex;}
.trainer-detail__role{
  font-size:14px;color:var(--text-soft);
  letter-spacing:.05em;margin:-6px 0 8px;font-weight:500;
}
.trainer-detail__instagram{
  display:inline-flex;align-items:center;gap:4px;
  margin-top:14px;padding:8px 16px;
  background:linear-gradient(45deg,#F58529,#DD2A7B,#8134AF,#515BD4);
  color:#fff;border-radius:999px;
  font-size:12px;font-weight:600;letter-spacing:.04em;
  transition:transform .2s,filter .2s;
}
.trainer-detail__instagram:hover{transform:translateY(-2px);filter:brightness(1.1);}

/* ============ NEW PROGRAM: KICK BACK ============ */
.neon-kickback{
  padding:60px 0;background:#0a0a0a;position:relative;overflow:hidden;
}
.neon-kickback::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at 30% 50%, rgba(255,0,212,.18), transparent 60%),
             radial-gradient(ellipse at 70% 50%, rgba(0,240,255,.10), transparent 60%);
  pointer-events:none;
}
.kickback-card{
  position:relative;display:grid;
  grid-template-columns:1fr 1.2fr;gap:32px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,0,212,.4);
  border-radius:14px;padding:0;overflow:hidden;
  box-shadow:0 20px 60px rgba(255,0,212,.15);
}
.kickback-card__media{position:relative;min-height:340px;}
.kickback-card__media img{width:100%;height:100%;object-fit:cover;display:block;}
.kickback-card__body{padding:36px 32px;display:flex;flex-direction:column;justify-content:center;}
.kickback-card__badge{
  display:inline-block;align-self:flex-start;
  background:var(--coral);color:#1A1A1A;
  font-family:var(--font-en);font-weight:800;font-size:12px;letter-spacing:.15em;
  padding:5px 12px;border-radius:999px;margin-bottom:12px;
  box-shadow:0 4px 16px var(--coral-glow);
  animation:kickback-pulse 2s ease-in-out infinite;
}
@keyframes kickback-pulse{
  0%,100%{box-shadow:0 4px 16px var(--coral-glow);}
  50%   {box-shadow:0 4px 28px rgba(255,166,112,.85);}
}
.kickback-card__title{
  font-size:clamp(24px,3.4vw,36px);
  font-weight:900;color:#fff;line-height:1.3;
  margin:8px 0 16px;letter-spacing:.02em;
}
.kickback-card__lead{
  font-size:15px;line-height:1.85;color:var(--text-soft);
  margin-bottom:18px;
}
@media (min-width:760px){.kickback-card__lead{font-size:16px;}}
.kickback-card__keywords{display:flex;flex-wrap:wrap;gap:8px;}
.kickback-card__keyword{
  font-family:var(--font-en);font-weight:700;font-size:12px;
  letter-spacing:.08em;color:var(--coral);
  padding:4px 12px;border:1px solid rgba(255,166,112,.5);
  border-radius:999px;background:rgba(255,166,112,.08);
}
@media (max-width:768px){
  .kickback-card{grid-template-columns:1fr;}
  .kickback-card__media{min-height:240px;}
  .kickback-card__body{padding:24px 20px;}
}

/* ============ PRICING EXTRAS（追加チケット） ============ */
.pricing-extras{
  margin:40px auto 0;max-width:760px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,229,0,.2);
  border-radius:12px;padding:24px;
}
.pricing-extras__title{
  font-size:15px;font-weight:700;color:var(--yellow);
  text-align:center;letter-spacing:.08em;margin-bottom:8px;
}
.pricing-extras__note{
  font-size:12px;color:var(--text-soft);text-align:center;
  margin-bottom:16px;line-height:1.6;
}
.pricing-extras__table{display:flex;flex-direction:column;gap:8px;}
.pricing-extras__row{
  display:grid;grid-template-columns:1.5fr 1fr 1.5fr;gap:14px;align-items:center;
  background:rgba(0,0,0,.4);
  border:1px solid rgba(255,255,255,.05);
  padding:12px 16px;border-radius:8px;
}
.pricing-extras__plan{font-size:14px;color:#fff;font-weight:600;}
.pricing-extras__price{font-size:16px;color:var(--yellow);font-weight:800;font-family:var(--font-en);text-align:center;}
.pricing-extras__note-cell{font-size:12px;color:var(--text-mute);text-align:right;}
@media (max-width:640px){
  .pricing-extras__row{grid-template-columns:1fr;gap:4px;text-align:center;}
  .pricing-extras__note-cell{text-align:center;}
}

/* ============ 15分ミットパーソナル ============ */
.mitt-personal{padding:80px 0;background:#0a0a0a;position:relative;}
.mitt-personal::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at 70% 30%, rgba(255,0,212,.10), transparent 60%);
  pointer-events:none;
}
.mitt-personal__head{text-align:center;max-width:760px;margin:0 auto 36px;position:relative;}
.mitt-personal__head .section-label{justify-content:center;}
.mitt-personal__head .section-label::before{display:none;}
.mitt-personal__badge{
  display:inline-block;background:var(--coral);color:#1A1A1A;
  font-family:var(--font-en);font-weight:800;font-size:12px;letter-spacing:.15em;
  padding:4px 12px;border-radius:999px;margin-bottom:14px;
}

.mitt-personal__hero{
  display:grid;grid-template-columns:1.4fr 1fr;gap:24px;
  margin:0 auto 40px;max-width:920px;
}
.mitt-personal__visual{
  border-radius:12px;overflow:hidden;
  background:#111;min-height:280px;
}
.mitt-personal__visual img{width:100%;height:100%;object-fit:cover;display:block;}
.mitt-personal__price{
  background:linear-gradient(135deg,#1a1a1a,#0a0a0a);
  border:1px solid rgba(255,229,0,.3);border-radius:12px;
  padding:28px 22px;display:flex;flex-direction:column;
  text-align:center;justify-content:center;
}
.mitt-personal__price-amount{
  font-family:var(--font-en);font-weight:900;font-size:64px;
  color:var(--yellow);line-height:1;letter-spacing:.02em;
}
.mitt-personal__price-amount::before{content:"¥";font-size:28px;color:#fff;margin-right:4px;vertical-align:top;}
.mitt-personal__price-unit{font-size:14px;color:var(--text-soft);margin-top:6px;letter-spacing:.05em;}
.mitt-personal__instructor{
  display:flex;align-items:center;gap:12px;
  margin-top:18px;padding-top:18px;
  border-top:1px solid rgba(255,255,255,.08);
}
.mitt-personal__instructor-photo{
  width:46px;height:46px;border-radius:50%;object-fit:cover;flex-shrink:0;
  border:2px solid var(--yellow);
}
.mitt-personal__instructor-meta{text-align:left;flex:1;min-width:0;}
.mitt-personal__instructor-label{font-size:12px;color:var(--text-mute);letter-spacing:.1em;display:block;}
.mitt-personal__instructor-name{font-size:14px;color:#fff;font-weight:700;display:block;margin-top:2px;}
.mitt-personal__price-note{font-size:12px;color:var(--text-mute);margin-top:12px;line-height:1.6;}

.mitt-personal__benefits{
  display:grid;grid-template-columns:repeat(auto-fit, minmax(240px,1fr));gap:14px;
  max-width:920px;margin:0 auto 36px;
}
.mitt-personal__benefit{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
  border-radius:10px;padding:20px;
  text-align:center;transition:border-color .2s;
}
.mitt-personal__benefit:hover{border-color:var(--yellow);}
.mitt-personal__benefit-icon{font-size:36px;display:block;margin-bottom:8px;}
.mitt-personal__benefit-title{font-size:15px;color:#fff;margin-bottom:6px;font-weight:700;}
.mitt-personal__benefit-desc{font-size:13px;color:var(--text-soft);line-height:1.8;}

.mitt-personal__target{
  max-width:760px;margin:0 auto 36px;padding:22px 28px;
  background:rgba(255,229,0,.06);border-left:3px solid var(--yellow);
  border-radius:8px;
}
.mitt-personal__target-title{font-size:15px;color:var(--yellow);font-weight:700;margin-bottom:10px;}
.mitt-personal__target-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px;}
.mitt-personal__target-list li{font-size:15px;color:#e5e5e5;padding-left:22px;position:relative;line-height:1.8;}
.mitt-personal__target-list li::before{content:"✓";position:absolute;left:0;color:var(--yellow);font-weight:800;}

.mitt-personal__details{
  max-width:760px;margin:0 auto 32px;
}
.mitt-personal__details-title{font-size:15px;color:var(--text-soft);font-weight:600;letter-spacing:.05em;margin-bottom:12px;text-align:center;}
.mitt-personal__details-table{display:flex;flex-direction:column;gap:4px;}
.mitt-personal__details-row{
  display:grid;grid-template-columns:160px 1fr;gap:12px;
  padding:10px 16px;background:rgba(0,0,0,.4);border-radius:6px;
  border:1px solid rgba(255,255,255,.05);
}
.mitt-personal__details-row[data-status="pending"]{
  border-color:rgba(255,170,0,.3);background:rgba(255,170,0,.04);
}
.mitt-personal__details-label{font-size:12px;color:var(--text-mute);}
.mitt-personal__details-value{font-size:14px;color:#fff;}
.mitt-personal__details-row[data-status="pending"] .mitt-personal__details-value{color:#FFC857;}

.mitt-personal__cta{text-align:center;margin-top:32px;}

@media (max-width:768px){
  .mitt-personal{padding:60px 0;}
  .mitt-personal__hero{grid-template-columns:1fr;}
  .mitt-personal__price-amount{font-size:48px;}
  .mitt-personal__details-row{grid-template-columns:1fr;gap:2px;}
}

/* ============ PRICE GROUP（2段構成：ジム + NEWスタジオ） ============ */
.price-group{margin-bottom:48px;}
.price-group:last-child{margin-bottom:0;}
.price-group__head{
  text-align:center;margin-bottom:24px;
  padding-bottom:18px;border-bottom:1px solid rgba(255,229,0,.15);
}
.price-group__chip{
  display:inline-block;background:rgba(255,229,0,.15);color:var(--yellow);
  font-family:var(--font-en);font-weight:800;font-size:12px;letter-spacing:.15em;
  padding:5px 14px;border-radius:999px;margin-bottom:10px;
  border:1px solid rgba(255,229,0,.3);
}
.price-group__chip--new{
  background:var(--coral);color:#1A1A1A;border-color:var(--coral);
  box-shadow:0 4px 14px var(--coral-glow);
  animation:price-group-pulse 2s ease-in-out infinite;
}
@keyframes price-group-pulse{
  0%,100%{box-shadow:0 4px 14px var(--coral-glow);}
  50%   {box-shadow:0 4px 24px rgba(255,166,112,.75);}
}
.price-group__title{
  font-size:clamp(20px,2.4vw,26px);font-weight:800;color:#fff;
  margin:0 0 8px;letter-spacing:.02em;
}
.price-group__title small{
  font-size:.7em;color:var(--text-soft);font-weight:600;margin-left:6px;
}
.price-group__lead{
  font-size:15px;color:var(--text-soft);line-height:1.85;
  max-width:600px;margin:0 auto;
}
@media (min-width:760px){.price-group__lead{font-size:16px;}}
.price-group--new .price-group__title{color:var(--coral);}

/* ============ TRAINER ASSIGNMENT (担当制) ============ */
.assignment{
  padding:80px 0;
  background:linear-gradient(180deg, #0e0e0e 0%, #151515 100%);
  position:relative;overflow:hidden;
}
.assignment::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 0%, rgba(255,229,0,.10), transparent 60%);
  pointer-events:none;
}
.assignment__head{text-align:center;max-width:760px;margin:0 auto 36px;position:relative;}
.assignment__head .section-label{justify-content:center;}
.assignment__head .section-label::before{display:none;}
.assignment__badge{
  display:inline-block;background:var(--yellow);color:#111;
  font-family:var(--font-en);font-weight:800;font-size:12px;letter-spacing:.15em;
  padding:4px 12px;border-radius:999px;margin-bottom:14px;
  box-shadow:0 4px 14px rgba(255,229,0,.4);
}
.assignment__head .section-title{margin-bottom:14px;}

.assignment__body{
  max-width:920px;margin:0 auto;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,229,0,.2);
  border-radius:14px;
  padding:34px 28px;
  text-align:center;
}
.assignment__supports-title{
  font-size:14px;font-weight:700;color:var(--yellow);
  letter-spacing:.08em;margin-bottom:20px;
}
.assignment__supports{
  list-style:none;display:grid;
  grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));
  gap:12px;margin:0 0 24px;padding:0;
}
.assignment__support-item{
  display:flex;align-items:center;gap:12px;
  background:rgba(0,0,0,.4);
  border:1px solid rgba(255,255,255,.06);
  border-radius:8px;padding:12px 14px;
  text-align:left;
  transition:border-color .2s, background .2s;
}
.assignment__support-item:hover{
  border-color:var(--yellow);
  background:rgba(255,229,0,.06);
}
.assignment__support-icon{
  flex-shrink:0;
  width:42px;height:42px;display:flex;align-items:center;justify-content:center;
  background:rgba(255,229,0,.12);border-radius:50%;
  color:var(--yellow);
  /* SVG ライン系アイコン用サイズ調整 */
  transition:background .2s, color .2s, transform .2s;
}
.assignment__support-icon svg,
.assignment__support-icon > i{
  width:22px;height:22px;display:block;
}
.assignment__support-icon > i{display:inline-flex;align-items:center;justify-content:center;}
.assignment__support-item:hover .assignment__support-icon{
  background:var(--yellow);color:#111;
  transform:rotate(-6deg) scale(1.08);
}
.assignment__support-text{
  font-size:15px;line-height:1.8;color:#e5e5e5;
}
.assignment__price-tag{
  display:inline-block;
  background:var(--yellow);color:#111;
  font-weight:800;font-size:14px;letter-spacing:.04em;
  padding:10px 22px;border-radius:999px;
  margin:8px 0 18px;
}
.assignment__footer{
  font-size:15px;line-height:1.85;color:var(--text-soft);
  margin-bottom:24px;
}
.assignment__cta{margin:0 auto;}

@media (max-width:640px){
  .assignment{padding:60px 0;}
  .assignment__body{padding:24px 18px;}
  .assignment__support-item{padding:10px 12px;}
}

/* ============ INSTAGRAM ============ */
.instagram-section{padding:80px 0;background:#0a0a0a;position:relative;overflow:hidden;}
.instagram-section::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 0%, rgba(236,72,153,.10), transparent 60%);
  pointer-events:none;
}
.instagram-header{text-align:center;margin-bottom:32px;position:relative;}
.instagram-header .section-label{justify-content:center;}
.instagram-header .section-label::before{display:none;}
.instagram-header .section-title{margin-bottom:12px;}

.instagram-widget{
  position:relative;margin:0 auto;
  max-width:1200px;border-radius:12px;overflow:hidden;
  background:transparent;
}
.instagram-widget iframe{display:block;}

/* === Instagram 公式 oEmbed グリッド ===
   blockquote.instagram-media を Instagram embed.js が iframe に変換。
   本物の投稿（画像・動画・いいね数・キャプション・コメント）が表示される。
   カード縦幅は投稿アスペクト比により可変（揃わない）が、リアル表示優先。 */
.instagram-grid{
  display:grid;grid-template-columns:1fr;
  gap:18px;
  max-width:1200px;margin:0 auto;
  justify-items:center;
}
@media (min-width:640px){
  .instagram-grid{grid-template-columns:repeat(2, 1fr);gap:18px;}
}
@media (min-width:1000px){
  .instagram-grid{grid-template-columns:repeat(3, 1fr);gap:20px;}
}
.instagram-grid__cell{
  width:100%;max-width:540px;
  display:flex;justify-content:center;align-items:flex-start;
}
.instagram-grid__cell .instagram-media,
.instagram-grid__cell iframe.instagram-media{
  margin:0 auto !important;
  width:100% !important;
  max-width:540px !important;
  min-width:auto !important;
  border-radius:8px !important;
}

/* === LightWidget URL 未設定時のフォールバック（フォロー誘導グリッド） === */
.instagram-fallback{
  position:relative;
  min-height:440px;
  background:linear-gradient(135deg, #1a1a1a 0%, #0a0a0a 100%);
}
.instagram-fallback__grid{
  display:grid;grid-template-columns:repeat(3, 1fr);gap:2px;
  width:100%;
}
@media (min-width:760px){.instagram-fallback__grid{grid-template-columns:repeat(6, 1fr);}}
.instagram-fallback__cell{
  position:relative;aspect-ratio:1/1;
  background:linear-gradient(135deg,
    rgba(245,133,41,.18),
    rgba(221,42,123,.18),
    rgba(129,52,175,.18),
    rgba(81,91,212,.18));
  display:flex;align-items:center;justify-content:center;
  transition:transform .3s var(--ease), background .3s ease;
  overflow:hidden;
}
.instagram-fallback__cell:nth-child(2n){
  background:linear-gradient(135deg,
    rgba(245,133,41,.10),
    rgba(221,42,123,.22),
    rgba(129,52,175,.22),
    rgba(81,91,212,.10));
}
.instagram-fallback__cell:nth-child(3n){
  background:linear-gradient(135deg,
    rgba(245,133,41,.22),
    rgba(221,42,123,.10),
    rgba(129,52,175,.10),
    rgba(81,91,212,.22));
}
.instagram-fallback__cell:hover{transform:scale(1.04);z-index:2;}
.instagram-fallback__cell-icon{
  color:rgba(255,255,255,.35);
  width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;
}
.instagram-fallback__cell-icon i,
.instagram-fallback__cell-icon svg{width:100%;height:100%;}

/* 中央のフォロー誘導オーバーレイ */
.instagram-fallback__overlay{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  display:flex;flex-direction:column;align-items:center;gap:8px;
  padding:24px 36px;
  background:rgba(0,0,0,.78);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.12);
  border-radius:14px;
  transition:transform .3s var(--ease), box-shadow .3s ease;
  text-align:center;color:#fff;
  box-shadow:0 14px 40px rgba(0,0,0,.5);
}
.instagram-fallback__overlay:hover{
  transform:translate(-50%,-50%) scale(1.04);
  box-shadow:0 20px 50px rgba(221,42,123,.35);
}
.instagram-fallback__overlay-icon{
  width:48px;height:48px;display:inline-flex;align-items:center;justify-content:center;
  border-radius:14px;
  background:linear-gradient(45deg,#F58529,#DD2A7B,#8134AF,#515BD4);
  color:#fff;
}
.instagram-fallback__overlay-icon i,
.instagram-fallback__overlay-icon svg{width:26px;height:26px;}
.instagram-fallback__overlay-handle{
  font-family:var(--font-en);font-weight:800;font-size:18px;
  letter-spacing:.02em;color:#fff;
}
.instagram-fallback__overlay-text{
  font-size:13px;color:var(--text-soft);letter-spacing:.04em;
}
.instagram-fallback__overlay-note{
  font-size:11px;color:var(--text-mute);letter-spacing:.03em;
  margin-top:6px;display:block;max-width:280px;line-height:1.5;
}

.instagram-cta{text-align:center;margin-top:32px;}
.instagram-cta__btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 28px;
  background:linear-gradient(45deg,#F58529,#DD2A7B,#8134AF,#515BD4);
  color:#fff;border-radius:999px;
  font-size:15px;font-weight:700;
  transition:transform .2s, box-shadow .2s, filter .2s;
  box-shadow:0 4px 14px rgba(221,42,123,.30);
}
.instagram-cta__btn:hover{transform:translateY(-2px);filter:brightness(1.1);box-shadow:0 8px 22px rgba(221,42,123,.45);}
.instagram-cta__btn i{font-size:12px;}

@media (max-width:768px){
  .instagram-section{padding:60px 0;}
}

/* ============ NOTICES (お知らせ) ============ */
.notices{padding:60px 0 20px;}
.notices .section-title{font-size:clamp(28px,5vw,42px);margin-bottom:24px;}
.notices-list{display:flex;flex-direction:column;gap:10px;max-width:880px;margin:0 auto;}
.notice-card{background:#111;border:1px solid #222;border-radius:8px;overflow:hidden;transition:border-color .2s;}
.notice-card[open]{border-color:var(--yellow);}
.notice-card__head{display:grid;grid-template-columns:auto auto 1fr auto;gap:14px;align-items:center;padding:14px 18px;cursor:pointer;list-style:none;}
.notice-card__head::-webkit-details-marker{display:none;}
.notice-card__date{font-family:'Barlow Condensed',sans-serif;font-weight:600;color:var(--yellow);letter-spacing:.04em;font-size:14px;}
.notice-card__tag{font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;background:rgba(255,221,0,.12);color:var(--yellow);padding:3px 8px;border-radius:4px;}
.notice-card__title{font-size:15px;font-weight:500;color:#fff;line-height:1.6;}
.notice-card__chev{color:#888;font-size:18px;line-height:1;transition:transform .2s;}
.notice-card[open] .notice-card__chev{transform:rotate(90deg);}
.notice-card__body{padding:0 18px 18px 18px;font-size:15px;line-height:1.95;color:#bbb;white-space:pre-line;}
@media (max-width:640px){
  .notice-card__head{grid-template-columns:auto auto auto;grid-template-rows:auto auto;row-gap:6px;}
  .notice-card__title{grid-column:1/-1;}
  .notice-card__chev{grid-column:3;grid-row:1;}
}
