/* ============================================================
   江戸前鮨学校オンライン｜共有スタイルシート
   LP（index.html）と記事ページ（articles/<slug>/）で共有する。
   出典：reference/index.html の <style> を切り出し。
   カラー/フォント定義は docs/02_DESIGN_SYSTEM.md と一致。
   palette: 墨(sumi) / 和紙(washi) / 檜(hinoki) / 藍(ai) / 朱(shu-urushi) / 金(kin)
============================================================ */
:root{
  --sumi:#0b1a2e;          /* 濃紺（ベース・最暗） */
  --sumi-2:#0f2338;
  --sumi-soft:#17324c;
  --washi:#f5f8fc;         /* 白（清廉） */
  --washi-2:#e6edf5;       /* 銀がかった白 */
  --hinoki:#d2b766;        /* 金（明）※旧・檜を金へ */
  --hinoki-deep:#a8822f;   /* 金（濃・白地のアクセント） */
  --ai:#1a3a5c;            /* 藍（紺の中間調） */
  --shu:#cf3a2b;           /* 朱（差し色・一点） */
  --shu-deep:#9c2a20;
  --kin:#cda451;           /* 金（罫・落款） */
  --silver:#c3ccd8;        /* 銀（メタリック・線/淡色） */
  --silver-deep:#8a97a8;
  --ink-on-dark:#eef3f9;   /* 白に近い文字 on 濃紺 */
  --ink-on-dark-dim:#9fb1c6;/* 銀がかった淡色 */
  --ink-on-light:#11233a;  /* 紺インク on 白 */
  --ink-on-light-dim:#566576;
  --line-dark:rgba(205,164,81,.24);  /* 金の罫 on 濃紺 */
  --line-light:rgba(17,35,58,.14);   /* 紺の罫 on 白 */

  --font-disp:'Shippori Mincho B1', serif;
  --font-body:'Zen Kaku Gothic New', system-ui, sans-serif;

  --maxw:1120px;
  --pad:clamp(20px,5vw,64px);
  --r:14px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  background:var(--sumi);
  color:var(--ink-on-dark);
  line-height:1.85;
  letter-spacing:.02em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* 和紙テクスチャ（CSSのみ） */
.washi-grain{position:relative}
.washi-grain::after{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.05;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* レイアウト */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}
section{position:relative}
.sec{padding-block:clamp(72px,11vw,140px)}
.eyebrow{
  font-family:var(--font-body);font-weight:700;font-size:.74rem;letter-spacing:.42em;
  color:var(--kin);text-transform:uppercase;display:inline-flex;align-items:center;gap:.7em;margin-bottom:1.4em;
}
.eyebrow::before{content:"";width:34px;height:1px;background:var(--kin);display:inline-block;opacity:.7}
h2.head{font-family:var(--font-disp);font-weight:800;line-height:1.32;
  font-size:clamp(1.7rem,4.6vw,3rem);letter-spacing:.02em}
h2.head .shu{color:var(--shu)}
.lead{font-size:clamp(1rem,1.6vw,1.12rem);max-width:62ch;margin-top:1.4em;color:var(--ink-on-dark-dim)}

/* セクションの明暗 */
.on-dark{background:var(--sumi);color:var(--ink-on-dark)}
.on-dark .lead{color:var(--ink-on-dark-dim)}
.on-light{background:var(--washi);color:var(--ink-on-light)}
.on-light .eyebrow{color:var(--hinoki-deep)}
.on-light .eyebrow::before{background:var(--hinoki-deep)}
.on-light .lead{color:var(--ink-on-light-dim)}
.on-light h2.head .shu{color:var(--shu)}

/* CTA ボタン */
.cta{
  --bg:var(--shu);--bg2:var(--shu-deep);
  display:inline-flex;align-items:center;gap:.85em;justify-content:center;
  font-family:var(--font-body);font-weight:900;font-size:1.02rem;letter-spacing:.04em;
  color:#fff;background:linear-gradient(150deg,var(--bg),var(--bg2));
  padding:1.05em 2.1em;border-radius:999px;border:0;cursor:pointer;
  box-shadow:0 14px 34px -12px rgba(207,58,43,.7), inset 0 1px 0 rgba(255,255,255,.18);
  transition:transform .25s cubic-bezier(.2,.7,.2,1), box-shadow .25s;
  position:relative;overflow:hidden;
}
.cta .line-ico{width:1.25em;height:1.25em;flex:0 0 auto}
.cta small{display:block;font-weight:500;font-size:.7rem;letter-spacing:.16em;opacity:.85;margin-top:.15em}
.cta .stk{display:flex;flex-direction:column;line-height:1.25}
.cta:hover{transform:translateY(-3px);box-shadow:0 22px 46px -14px rgba(207,58,43,.78)}
.cta:focus-visible{outline:3px solid var(--kin);outline-offset:3px}
.cta::after{content:"";position:absolute;top:0;left:-130%;width:55%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.35),transparent);
  transform:skewX(-18deg);animation:sheen 5.5s ease-in-out infinite}
@keyframes sheen{0%,55%{left:-130%}80%,100%{left:130%}}
.cta-ghost{background:transparent;border:1px solid var(--kin);color:var(--ink-on-dark);box-shadow:none}
.cta-ghost::after{display:none}
.cta-ghost:hover{background:rgba(205,164,81,.1);transform:translateY(-2px)}

/* ヘッダー */
header.bar{position:fixed;top:0;left:0;right:0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:.7rem clamp(16px,4vw,40px);
  background:rgba(8,18,30,0);transition:background .35s, border-color .35s;
  border-bottom:1px solid transparent}
header.bar.scrolled{background:rgba(8,18,30,.86);backdrop-filter:blur(10px);border-color:var(--line-dark)}
.brand{display:flex;align-items:center;gap:.7em;font-family:var(--font-disp);font-weight:700;letter-spacing:.14em;font-size:1.02rem}
.brand .seal{width:30px;height:30px;flex:0 0 auto}
.brand small{display:block;font-family:var(--font-body);font-weight:500;font-size:.6rem;letter-spacing:.34em;color:var(--silver)}
header .cta{padding:.7em 1.3em;font-size:.82rem}
header .cta small{display:none}
@media(max-width:720px){header .brand small{display:none}.brand{font-size:.95rem}header.bar>.cta{display:none}}

/* ============ HERO ============ */
.hero{min-height:100svh;display:flex;align-items:center;position:relative;overflow:hidden;
  background:
    radial-gradient(120% 80% at 75% 0%, rgba(40,74,112,.35), transparent 60%),
    radial-gradient(90% 70% at 10% 100%, rgba(207,58,43,.16), transparent 55%),
    linear-gradient(180deg,#081427,#0d1f34 60%,#0a1a2c);
}
/* ヒーロー背景動画（蒼の鮨PV）＋可読性スクリム */
.hero .hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;pointer-events:none}
.hero .hero-scrim{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(90deg, rgba(8,18,30,.88) 0%, rgba(8,18,30,.58) 42%, rgba(8,18,30,.20) 100%),
    linear-gradient(180deg, rgba(8,18,30,.45) 0%, rgba(8,18,30,.22) 38%, rgba(8,18,30,.90) 100%),
    radial-gradient(70% 60% at 82% 12%, rgba(40,74,112,.30), transparent 60%)}
.hero.has-video::before{z-index:1}
.hero.has-video .orbs{z-index:1;opacity:.45}
/* ヒーロー・イントロ：掛け軸を2秒センター表示→フェードアウト */
.hero-intro{position:fixed;inset:0;z-index:50;display:grid;place-items:center;pointer-events:none;
  background:radial-gradient(78% 88% at 50% 47%, rgba(8,18,30,.55), rgba(6,13,22,.96));
  animation:introOut .8s 3s forwards}
@keyframes introOut{to{opacity:0;visibility:hidden}}
.hero-intro .intro-inner{display:flex;flex-direction:column;align-items:center;gap:clamp(.8rem,2vh,1.4rem);
  opacity:0;animation:introIn 1s .15s forwards}
@keyframes introIn{from{opacity:0;transform:translateY(18px) scale(.97)}to{opacity:1;transform:none}}
.hero-intro .intro-inner::before,.hero-intro .intro-inner::after{content:"";width:clamp(90px,16vw,140px);height:1px;
  background:linear-gradient(90deg,transparent,var(--line-dark),transparent)}
.hero-intro .intro-kake{writing-mode:vertical-rl;text-orientation:upright;white-space:nowrap;font-family:var(--font-disp);font-weight:700;
  font-size:clamp(1.3rem,min(4.6vw,4.4vh),2.4rem);letter-spacing:.28em;color:var(--ink-on-dark);
  padding:.6em .35em;border-inline:1px solid var(--line-dark)}
.hero-intro .intro-kake .shu{color:var(--shu)}
.hero-intro .intro-seal{width:clamp(46px,7vw,64px);height:auto;
  filter:drop-shadow(0 2px 10px rgba(207,58,43,.45));opacity:0;animation:stamp .55s 1s forwards}
/* モバイルは通信量/負荷配慮で動画を出さずポスター静止画 */
@media(max-width:720px){
  .hero.has-video .hero-bg{display:none}
  .hero.has-video{background:#081427 url(hero-poster.jpg) center/cover no-repeat}
}
@media(prefers-reduced-motion:reduce){
  .hero.has-video .hero-bg{display:none}
  .hero.has-video{background:#081427 url(hero-poster.jpg) center/cover no-repeat}
}
/* つけ場の檜カウンター（CSSのみの“床面”） */
.hero::before{content:"";position:absolute;inset:auto 0 0 0;height:34%;pointer-events:none;
  background:linear-gradient(0deg, rgba(205,164,81,.20), transparent);
  -webkit-mask:linear-gradient(0deg,#000,transparent);mask:linear-gradient(0deg,#000,transparent)}
/* 浮遊する光の粒（提灯のにじみ） */
.hero .orbs{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.hero .orbs i{position:absolute;border-radius:50%;filter:blur(40px);opacity:.5;
  background:radial-gradient(circle,var(--kin),transparent 70%);animation:drift 16s ease-in-out infinite}
.hero .orbs i:nth-child(1){width:260px;height:260px;left:62%;top:8%;animation-delay:0s}
.hero .orbs i:nth-child(2){width:180px;height:180px;left:8%;top:54%;background:radial-gradient(circle,var(--shu),transparent 70%);opacity:.32;animation-delay:-6s}
.hero .orbs i:nth-child(3){width:140px;height:140px;left:80%;top:64%;animation-delay:-3s}
@keyframes drift{0%,100%{transform:translate(0,0)}50%{transform:translate(-22px,-26px)}}

.hero-grid{display:grid;grid-template-columns:1fr auto;gap:clamp(20px,4vw,56px);align-items:center;width:100%;position:relative;z-index:2}
.hero-copy{max-width:42rem}
.hero .kicker{font-family:var(--font-body);font-weight:700;letter-spacing:.4em;font-size:.76rem;color:var(--kin);
  display:inline-block;margin-bottom:1.5rem;opacity:0;animation:rise .9s 3.2s forwards}
.hero h1{font-family:var(--font-disp);font-weight:800;line-height:1.34;letter-spacing:.015em;
  font-size:clamp(2.05rem,6vw,3.7rem)}
.hero h1 .em{color:var(--shu);position:relative;white-space:nowrap}
.hero h1 .small{display:block;font-size:.5em;color:var(--ink-on-dark);margin-top:.55em;line-height:1.6;font-weight:600}
.hero h1 .ln{display:block;opacity:0;transform:translateY(24px);animation:rise .95s forwards}
.hero h1 .ln:nth-child(1){animation-delay:3.35s}
.hero h1 .ln:nth-child(2){animation-delay:3.5s}
.hero h1 .ln:nth-child(3){animation-delay:3.7s}
.hero p.sub{margin-top:1.8rem;font-size:clamp(.98rem,1.6vw,1.12rem);color:var(--ink-on-dark-dim);max-width:40ch;
  opacity:0;animation:rise .9s 3.95s forwards}
.hero .actions{margin-top:2.4rem;display:flex;flex-wrap:wrap;gap:1rem;opacity:0;animation:rise .9s 4.1s forwards}
.hero .trust{margin-top:2.6rem;display:flex;flex-wrap:wrap;gap:1.6rem 2.4rem;opacity:0;animation:rise .9s 4.25s forwards}
.hero .trust div{display:flex;flex-direction:column;gap:.1em}
.hero .trust b{font-family:var(--font-body);font-weight:900;font-size:clamp(1.95rem,4.2vw,2.7rem);color:var(--washi);line-height:1;letter-spacing:-.01em}
.hero .trust>div>span{font-size:.74rem;letter-spacing:.12em;color:var(--ink-on-dark-dim)}
.hero .trust b em{font-family:var(--font-body);font-style:normal;font-weight:700;color:var(--kin);font-size:.42em;margin-left:.14em}

/* 縦書きの掛け軸（シグネチャー / 装飾） */
.kakejiku{writing-mode:vertical-rl;text-orientation:upright;
  font-family:var(--font-disp);font-weight:700;font-size:clamp(1.2rem,2.4vw,1.9rem);
  letter-spacing:.34em;color:var(--ink-on-dark);
  padding:1.4em .55em;border-inline:1px solid var(--line-dark);
  position:relative;opacity:0;animation:rise 1s 4.35s forwards}
.kakejiku .shu{color:var(--shu)}
.kakejiku .seal{position:absolute;bottom:.4em;left:50%;transform:translateX(-50%);width:56px;height:auto;
  filter:drop-shadow(0 2px 8px rgba(207,58,43,.35));opacity:0;animation:stamp .6s 5.05s forwards}
@keyframes stamp{0%{opacity:0;transform:translateX(-50%) scale(1.6) rotate(-8deg)}60%{opacity:1}100%{opacity:1;transform:translateX(-50%) scale(1) rotate(0)}}
@media(max-width:820px){.hero{align-items:flex-start}.hero-grid{grid-template-columns:1fr;padding-top:84px}.kakejiku{display:none}}

.scrollcue{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);z-index:3;
  font-size:.62rem;letter-spacing:.3em;color:var(--ink-on-dark-dim);display:flex;flex-direction:column;align-items:center;gap:.6em;opacity:0;animation:rise 1s 4.65s forwards}
.scrollcue i{width:1px;height:34px;background:linear-gradient(var(--kin),transparent);animation:cue 1.8s 4.65s ease-in-out infinite}
@keyframes cue{0%,100%{transform:scaleY(.4);opacity:.4}50%{transform:scaleY(1);opacity:1}}

@keyframes rise{to{opacity:1;transform:translateY(0)}}

/* ===== 悩み（共感） ===== */
.pain-list{display:grid;gap:1px;background:var(--line-light);border:1px solid var(--line-light);border-radius:var(--r);overflow:hidden;margin-top:2.6rem}
.pain-list .row{background:var(--washi);padding:1.5rem clamp(1.2rem,3vw,2rem);display:flex;gap:1.1rem;align-items:flex-start}
.pain-list .q{font-family:var(--font-disp);font-weight:800;color:var(--shu);font-size:1.5rem;line-height:1;flex:0 0 auto}
.pain-list .row p{font-weight:500}
.pain-list .row p b{font-weight:700}

/* ===== 構造的欠陥 ===== */
.flaw-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,2vw,22px);margin-top:3rem}
.flaw{background:var(--sumi-soft);border:1px solid var(--line-dark);border-radius:var(--r);padding:1.8rem 1.5rem;position:relative}
.flaw .n{font-family:var(--font-disp);font-weight:800;color:var(--kin);font-size:.9rem;letter-spacing:.2em;opacity:.8}
.flaw h3{font-family:var(--font-disp);font-weight:700;font-size:1.18rem;margin:.5em 0 .5em;line-height:1.5}
.flaw p{font-size:.92rem;color:var(--ink-on-dark-dim)}
.flaw .big{font-family:var(--font-disp);font-weight:800;color:var(--shu);font-size:2.2rem;line-height:1;margin-top:.4rem}
@media(max-width:760px){.flaw-grid{grid-template-columns:1fr}}

/* ===== 経歴 timeline ===== */
.profile{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(28px,5vw,64px);align-items:center}
.profile .portrait{aspect-ratio:4/5;border-radius:var(--r);position:relative;overflow:hidden;
  /* IMAGE SLOT: 青島ポートレート（4:5）→ background-imageに差し替え */
  background:linear-gradient(160deg,#14283f,#0a1626),radial-gradient(80% 60% at 70% 20%,rgba(205,164,81,.25),transparent);
  border:1px solid var(--line-dark)}
.profile .portrait img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top}
.profile .portrait .tag{position:absolute;left:0;bottom:0;right:0;padding:1.4rem;background:linear-gradient(0deg,rgba(8,18,30,.92),transparent)}
.profile .portrait .tag b{font-family:var(--font-disp);font-size:1.3rem;font-weight:700}
.profile .portrait .tag span{display:block;font-size:.78rem;color:var(--kin);letter-spacing:.16em}
.statline{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line-dark);border:1px solid var(--line-dark);border-radius:var(--r);overflow:hidden;margin:2rem 0}
.statline div{background:var(--sumi-2);padding:1.2rem 1.3rem}
.statline b{font-family:var(--font-body);font-weight:900;font-size:clamp(1.9rem,3.6vw,2.5rem);color:var(--washi);display:block;line-height:1;letter-spacing:-.01em}
.statline b em{font-family:var(--font-body);font-style:normal;font-weight:700;font-size:.4em;color:var(--kin);margin-left:.14em}
.statline>div>span{font-size:.74rem;letter-spacing:.1em;color:var(--ink-on-dark-dim)}
.tl{list-style:none;border-left:1px solid var(--line-dark);margin-top:1rem;padding-left:1.6rem;display:grid;gap:1.5rem}
.tl li{position:relative}
.tl li::before{content:"";position:absolute;left:calc(-1.6rem - 5px);top:.5em;width:9px;height:9px;border-radius:50%;background:var(--shu);box-shadow:0 0 0 4px rgba(207,58,43,.15)}
.tl b{font-family:var(--font-disp);font-weight:700;color:var(--washi)}
.tl p{font-size:.92rem;color:var(--ink-on-dark-dim)}
@media(max-width:820px){.profile{grid-template-columns:1fr}}

/* ===== 3つの理由 ＋ 5技法 ===== */
.reasons{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,2vw,22px);margin-top:3rem}
.reason{background:var(--washi);border:1px solid var(--line-light);border-radius:var(--r);padding:2rem 1.6rem}
.reason .n{font-family:var(--font-disp);font-weight:800;font-size:2.4rem;color:var(--hinoki-deep);line-height:1}
.reason h3{font-family:var(--font-disp);font-weight:700;font-size:1.22rem;margin:.4em 0 .5em}
.reason p{font-size:.93rem;color:var(--ink-on-light-dim)}
@media(max-width:760px){.reasons{grid-template-columns:1fr}}

.goho{margin-top:3.4rem;border-top:1px solid var(--line-light);padding-top:2.4rem}
.goho h3{font-family:var(--font-disp);font-weight:800;font-size:clamp(1.2rem,2.6vw,1.6rem);text-align:center;margin-bottom:.4em}
.goho .sub{text-align:center;color:var(--ink-on-light-dim);font-size:.92rem;margin-bottom:1.8rem}
.gohos{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.gohos .g{background:linear-gradient(160deg,#fff,var(--washi-2));border:1px solid var(--line-light);border-radius:12px;padding:1.3rem 1rem;text-align:center;transition:transform .3s,box-shadow .3s}
.gohos .g:hover{transform:translateY(-5px);box-shadow:0 18px 30px -18px rgba(17,35,58,.4)}
.gohos .g b{font-family:var(--font-disp);font-weight:800;font-size:1.3rem;display:block;color:var(--ink-on-light)}
.gohos .g em{font-style:normal;font-size:.7rem;color:var(--hinoki-deep);letter-spacing:.12em;display:block;margin:.2em 0 .6em}
.gohos .g span{font-size:.8rem;color:var(--ink-on-light-dim)}
@media(max-width:760px){.gohos{grid-template-columns:repeat(2,1fr)}}

/* ===== 3つの力の掛け算 ===== */
.kakezan{display:grid;grid-template-columns:1fr 1fr;gap:clamp(16px,3vw,28px);margin-top:3rem}
.kbox{border-radius:var(--r);padding:2rem 1.7rem;border:1px solid var(--line-dark)}
.kbox.bad{background:var(--sumi-2)}
.kbox.good{background:linear-gradient(160deg,rgba(207,58,43,.16),rgba(40,74,112,.18));border-color:rgba(205,164,81,.4)}
.kbox .lbl{font-size:.74rem;letter-spacing:.2em;color:var(--ink-on-dark-dim)}
.kbox .formula{font-family:var(--font-disp);font-weight:700;font-size:1.05rem;margin:.7em 0;color:var(--ink-on-dark)}
.kbox .formula em{font-style:normal;color:var(--kin)}
.kbox .score{font-family:var(--font-body);font-weight:900;font-size:clamp(2.1rem,5vw,3.3rem);line-height:1;letter-spacing:-.01em}
.kbox.bad .score{color:var(--ink-on-dark-dim)}
.kbox.good .score{color:var(--shu)}
.kbox .score em{font-style:normal;font-size:.32em;color:var(--ink-on-dark-dim);letter-spacing:.1em;display:block;margin-top:.5em}
.kbox ul{list-style:none;margin-top:1.2rem;display:grid;gap:.5rem;font-size:.9rem;color:var(--ink-on-dark-dim)}
.kbox ul li{padding-left:1.4em;position:relative}
.kbox.bad ul li::before{content:"×";position:absolute;left:0;color:#7c8a9c;font-weight:700}
.kbox.good ul li::before{content:"○";position:absolute;left:0;color:var(--kin);font-weight:700}
.three{display:flex;justify-content:center;gap:clamp(10px,3vw,30px);margin-top:2.6rem;flex-wrap:wrap}
.three .pill{font-family:var(--font-disp);font-weight:700;border:1px solid var(--kin);border-radius:999px;padding:.7em 1.4em;color:var(--washi);display:flex;align-items:center;gap:.6em}
.three .pill span{color:var(--kin);font-size:.8em}
.three .op{display:flex;align-items:center;font-family:var(--font-disp);color:var(--shu);font-size:1.5rem;font-weight:800}
@media(max-width:760px){.kakezan{grid-template-columns:1fr}}

/* ===== カリキュラム 全10章 ===== */
.curri{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line-light);border:1px solid var(--line-light);border-radius:var(--r);overflow:hidden;margin-top:2.8rem}
.curri .ch{background:var(--washi);padding:1.4rem 1.5rem;display:flex;gap:1.1rem;align-items:flex-start;transition:background .3s}
.curri .ch:hover{background:#fff}
.curri .ch .no{font-family:var(--font-disp);font-weight:800;color:var(--hinoki-deep);font-size:1.2rem;line-height:1;flex:0 0 auto;width:2.2em}
.curri .ch b{font-family:var(--font-disp);font-weight:700;display:block;font-size:1.02rem;color:var(--ink-on-light)}
.curri .ch p{font-size:.85rem;color:var(--ink-on-light-dim);margin-top:.2em}
.steps{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin-top:2.4rem}
.steps .s{background:var(--sumi-soft);border:1px solid var(--line-dark);border-radius:999px;padding:.6em 1.2em;font-size:.85rem;color:var(--ink-on-dark)}
.steps .s b{color:var(--kin);font-family:var(--font-disp);margin-right:.4em}
.steps .arr{align-self:center;color:var(--shu)}
@media(max-width:760px){.curri{grid-template-columns:1fr}}

/* ===== サポート 8 ===== */
.support{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:3rem}
.support .sp{background:var(--washi);border:1px solid var(--line-light);border-radius:var(--r);padding:1.5rem 1.3rem}
.support .sp .no{font-family:var(--font-disp);font-weight:800;color:var(--shu);font-size:.9rem;letter-spacing:.1em}
.support .sp b{font-family:var(--font-disp);font-weight:700;display:block;font-size:1.05rem;margin:.4em 0 .3em;color:var(--ink-on-light)}
.support .sp p{font-size:.84rem;color:var(--ink-on-light-dim)}
@media(max-width:900px){.support{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.support{grid-template-columns:1fr}}

/* ===== 実績マーキー ===== */
.marquee{overflow:hidden;border-block:1px solid var(--line-dark);margin-top:3rem;padding-block:1.2rem;-webkit-mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee .track{display:flex;gap:2.4rem;width:max-content;animation:scrollx 32s linear infinite}
.marquee:hover .track{animation-play-state:paused}
.marquee .it{display:flex;align-items:baseline;gap:.7em;white-space:nowrap;font-size:.95rem;color:var(--ink-on-dark-dim)}
.marquee .it b{font-family:var(--font-disp);font-weight:800;color:var(--kin);font-size:1.25rem}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ===== 受講生対談 ===== */
.voices{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2.5vw,24px);margin-top:3rem}
.voice{background:var(--sumi-soft);border:1px solid var(--line-dark);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column}
.voice .vid{aspect-ratio:16/9;position:relative;background:#000;cursor:pointer}
.voice .vid img{width:100%;height:100%;object-fit:cover;opacity:.78}
.voice .vid .play{position:absolute;inset:0;display:grid;place-items:center}
.voice .vid .play span{width:56px;height:56px;border-radius:50%;background:rgba(207,58,43,.92);display:grid;place-items:center;box-shadow:0 8px 24px rgba(0,0,0,.5);transition:transform .3s}
.voice .vid:hover .play span{transform:scale(1.1)}
.voice .vid .play span::after{content:"";border-left:16px solid #fff;border-block:10px solid transparent;margin-left:4px}
.voice .body{padding:1.5rem 1.4rem;flex:1;display:flex;flex-direction:column}
.voice .badge{font-size:.72rem;letter-spacing:.12em;color:var(--kin);font-weight:700}
.voice h3{font-family:var(--font-disp);font-weight:700;font-size:1.12rem;margin:.4em 0;line-height:1.5}
.voice .who{font-size:.8rem;color:var(--ink-on-dark-dim);margin-bottom:.8rem}
.voice p{font-size:.9rem;color:var(--ink-on-dark-dim)}
.voice .res{margin-top:auto;padding-top:1rem;border-top:1px solid var(--line-dark);display:flex;gap:.5em;align-items:baseline}
.voice .res b{font-family:var(--font-disp);font-weight:800;color:var(--shu);font-size:1.4rem}
.voice .res span{font-size:.78rem;color:var(--ink-on-dark-dim)}
@media(max-width:880px){.voices{grid-template-columns:1fr}}

/* ===== 動画 ===== */
.videos{display:grid;grid-template-columns:1.4fr 1fr;gap:clamp(16px,2.5vw,24px);margin-top:3rem}
.vcard{border:1px solid var(--line-dark);border-radius:var(--r);overflow:hidden;background:var(--sumi-2)}
.vcard .vid{aspect-ratio:16/9;background:#000;position:relative;cursor:pointer}
.vcard .vid img{width:100%;height:100%;object-fit:cover}
.vcard .vid .play{position:absolute;inset:0;display:grid;place-items:center}
.vcard .vid .play span{width:64px;height:64px;border-radius:50%;background:rgba(207,58,43,.92);display:grid;place-items:center;box-shadow:0 10px 30px rgba(0,0,0,.55);transition:transform .3s}
.vcard .vid:hover .play span{transform:scale(1.1)}
.vcard .vid .play span::after{content:"";border-left:18px solid #fff;border-block:11px solid transparent;margin-left:5px}
.vcard .cap{padding:1.2rem 1.4rem}
.vcard .cap .badge{font-size:.7rem;letter-spacing:.16em;color:var(--kin);font-weight:700}
.vcard .cap b{font-family:var(--font-disp);font-weight:700;display:block;font-size:1.1rem;margin-top:.3em}
.vcard .cap p{font-size:.86rem;color:var(--ink-on-dark-dim);margin-top:.4em}
@media(max-width:820px){.videos{grid-template-columns:1fr}}

/* ===== 未来 ===== */
.future{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:3rem}
.future .f{background:linear-gradient(160deg,#fff,var(--washi-2));border:1px solid var(--line-light);border-radius:var(--r);padding:1.7rem 1.4rem}
.future .f .n{font-family:var(--font-disp);font-weight:800;color:var(--hinoki-deep);font-size:1rem;letter-spacing:.14em}
.future .f b{font-family:var(--font-disp);font-weight:700;display:block;font-size:1.1rem;margin:.5em 0 .3em;color:var(--ink-on-light)}
.future .f p{font-size:.85rem;color:var(--ink-on-light-dim)}
@media(max-width:880px){.future{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.future{grid-template-columns:1fr}}

/* ===== 対象者 2カラム ===== */
.fit{display:grid;grid-template-columns:1fr 1fr;gap:clamp(16px,2.5vw,24px);margin-top:3rem}
.fit .col{border-radius:var(--r);padding:2rem 1.8rem;border:1px solid var(--line-dark)}
.fit .col.yes{background:linear-gradient(160deg,rgba(205,164,81,.12),transparent)}
.fit .col.no{background:var(--sumi-2)}
.fit .col h3{font-family:var(--font-disp);font-weight:800;font-size:1.2rem;margin-bottom:1rem;display:flex;align-items:center;gap:.5em}
.fit .col.yes h3{color:var(--kin)}
.fit .col.no h3{color:var(--ink-on-dark-dim)}
.fit ul{list-style:none;display:grid;gap:.7rem}
.fit li{padding-left:1.6em;position:relative;font-size:.93rem;color:var(--ink-on-dark)}
.fit .yes li::before{content:"○";position:absolute;left:0;color:var(--kin);font-weight:700}
.fit .no li::before{content:"×";position:absolute;left:0;color:#7c8a9c;font-weight:700}
.fit .no li{color:var(--ink-on-dark-dim)}
@media(max-width:760px){.fit{grid-template-columns:1fr}}

/* ===== FAQ ===== */
.faq{margin-top:2.8rem;border-top:1px solid var(--line-light)}
.faq details{border-bottom:1px solid var(--line-light)}
.faq summary{list-style:none;cursor:pointer;padding:1.4rem .3rem;display:flex;gap:1rem;align-items:flex-start;font-family:var(--font-disp);font-weight:700;font-size:1.05rem;color:var(--ink-on-light)}
.faq summary::-webkit-details-marker{display:none}
.faq summary .qm{color:var(--shu);font-weight:800;flex:0 0 auto}
.faq summary .ico{margin-left:auto;flex:0 0 auto;transition:transform .3s;color:var(--hinoki-deep);font-weight:800}
.faq details[open] summary .ico{transform:rotate(45deg)}
.faq .a{padding:0 .3rem 1.5rem 2.5rem;color:var(--ink-on-light-dim);font-size:.95rem}

/* ===== 最終CTA ===== */
.final{position:relative;overflow:hidden;text-align:center;
  background:radial-gradient(110% 90% at 50% 0%,rgba(40,74,112,.45),transparent 60%),linear-gradient(180deg,#0a1626,#0f2338)}
.final .orbs i{position:absolute;border-radius:50%;filter:blur(50px);opacity:.4;background:radial-gradient(circle,var(--shu),transparent 70%)}
.final .orbs i:nth-child(1){width:300px;height:300px;left:-60px;top:-40px}
.final .orbs i:nth-child(2){width:260px;height:260px;right:-50px;bottom:-60px;background:radial-gradient(circle,var(--kin),transparent 70%)}
.final .inner{position:relative;z-index:2;max-width:760px;margin-inline:auto}
.final h2{font-family:var(--font-disp);font-weight:800;font-size:clamp(1.7rem,4.6vw,2.8rem);line-height:1.4}
.final h2 .shu{color:var(--shu)}
.final p{color:var(--ink-on-dark-dim);margin-top:1.4rem;font-size:1.02rem}
.benefits{display:flex;flex-wrap:wrap;gap:.7rem;justify-content:center;margin:2.2rem 0}
.benefits .b{background:rgba(205,164,81,.1);border:1px solid var(--line-dark);border-radius:999px;padding:.6em 1.2em;font-size:.85rem;color:var(--ink-on-dark)}
.benefits .b b{color:var(--kin);font-family:var(--font-disp);margin-right:.4em}
.final .actions{display:flex;justify-content:center;margin-top:1rem}
.final .note{font-size:.78rem;color:var(--ink-on-dark-dim);margin-top:1.6rem}

/* footer */
footer{background:#07111f;color:var(--ink-on-dark-dim);padding:3rem var(--pad);border-top:1px solid var(--line-dark)}
footer .fwrap{max-width:var(--maxw);margin-inline:auto;display:flex;justify-content:space-between;gap:2rem;flex-wrap:wrap;align-items:center}
footer .brand{color:var(--ink-on-dark)}
footer a{color:var(--kin)}
footer .fnote{font-size:.74rem;max-width:48ch;line-height:1.7}

/* ===== チャンネル導線 ===== */
.chband{margin-top:2.6rem;display:flex;flex-wrap:wrap;align-items:center;gap:1.2rem 1.8rem;justify-content:space-between;
  background:linear-gradient(150deg,rgba(207,58,43,.14),rgba(40,74,112,.18));border:1px solid var(--line-dark);border-radius:var(--r);padding:1.6rem 1.8rem;transition:transform .3s,box-shadow .3s}
.chband:hover{transform:translateY(-3px);box-shadow:0 24px 44px -26px rgba(0,0,0,.7)}
.chband .yt{display:flex;align-items:center;gap:1rem}
.chband .yt .ic{width:46px;height:34px;flex:0 0 auto}
.chband .yt b{font-family:var(--font-disp);font-weight:700;font-size:1.12rem;display:block;color:var(--ink-on-dark)}
.chband .yt span{font-size:.84rem;color:var(--ink-on-dark-dim)}
.chsub{display:inline-flex;align-items:center;gap:.55em;background:#fff;color:#0a1626;font-weight:900;border-radius:999px;padding:.85em 1.6em;font-size:.92rem;white-space:nowrap}
.chsub .ic{width:1.3em;height:1.3em}
@media(max-width:560px){.chband{justify-content:center;text-align:center}.chband .yt{flex-direction:column;text-align:center}}

/* mobile sticky CTA */
.sticky{position:fixed;left:0;right:0;bottom:0;z-index:55;padding:.6rem .8rem;
  background:rgba(8,18,30,.92);backdrop-filter:blur(8px);border-top:1px solid var(--line-dark);
  transform:translateY(120%);transition:transform .35s;display:none}
.sticky.show{transform:translateY(0)}
.sticky .cta{width:100%}
@media(max-width:820px){.sticky{display:block}body{padding-bottom:76px}}

/* ===== FilmPresso型 動画スライダー（Swiper Coverflow） ===== */
.vslider{margin-top:3rem;position:relative}
.vslider .swiper{overflow:visible;padding-bottom:8px}
.vslider .swiper-slide{width:min(560px,86vw);height:auto;transition:opacity .5s ease, filter .5s ease}
.vslider .swiper-slide .voice{height:100%}
.vslider .swiper-slide:not(.swiper-slide-active){opacity:.5;filter:saturate(.7)}
.vslider .swiper-slide-active .voice{border-color:rgba(205,164,81,.5);box-shadow:0 36px 70px -34px rgba(0,0,0,.8)}
/* コントロール（矢印＋プログレス＋ドット＝複合UX） */
.vctrl{display:flex;align-items:center;gap:1.2rem;margin-top:2rem}
.vnav{flex:0 0 auto;width:52px;height:52px;border-radius:50%;border:1px solid var(--kin);background:transparent;color:var(--ink-on-dark);
  font-size:1.5rem;cursor:pointer;display:grid;place-items:center;transition:transform .25s,background .25s,opacity .25s}
.vnav:hover{background:rgba(205,164,81,.12);transform:translateY(-2px)}
.vnav:focus-visible{outline:3px solid var(--kin);outline-offset:3px}
.vnav.swiper-button-disabled{opacity:.3;cursor:default}
.vprogress{flex:1;height:3px;background:var(--line-dark);border-radius:999px;overflow:hidden}
.vprogress span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--shu),var(--kin));transition:width .2s linear}
.vpag{display:flex;justify-content:center;gap:.5rem;margin-top:1.4rem}
.vpag .swiper-pagination-bullet{width:9px;height:9px;background:var(--ink-on-dark-dim);opacity:.5;border-radius:999px;cursor:pointer;transition:width .3s,opacity .3s,background .3s;margin:0!important}
.vpag .swiper-pagination-bullet-active{opacity:1;width:26px;background:var(--shu)}
.vhint{text-align:center;font-size:.72rem;letter-spacing:.16em;color:var(--ink-on-dark-dim);margin-top:1rem}
/* Swiper未読込時のフォールバック（横スクロール） */
.vslider.no-swiper .swiper{overflow-x:auto;overflow-y:hidden}
.vslider.no-swiper .swiper-wrapper{display:flex;gap:24px}
.vslider.no-swiper .swiper-slide:not(.swiper-slide-active){opacity:1;filter:none}
@media(max-width:520px){.vnav{width:44px;height:44px;font-size:1.2rem}}

/* reveal */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
  /* イントロは出さず、ヒーロー本文を即可視に（animation:none で opacity:0 のまま消えるのを防ぐ） */
  .hero-intro{display:none!important}
  .hero .kicker,.hero h1 .ln,.hero p.sub,.hero .actions,.hero .trust,.hero .kakejiku,.hero .kakejiku .seal,.hero .scrollcue{opacity:1!important;transform:none!important}
}

/* ============================================================
   記事ページ（articles/<slug>/）追加スタイル
   LPと同じトークンを使った可読性の高い本文＋パンくず＋関連記事
============================================================ */
.article-main{padding-top:clamp(96px,12vw,140px)}
.breadcrumb{font-size:.78rem;color:var(--ink-on-dark-dim);letter-spacing:.06em;display:flex;flex-wrap:wrap;gap:.5em;align-items:center}
.breadcrumb a{color:var(--kin)}
.breadcrumb .sep{opacity:.5}
.article-head{margin:1.4rem 0 2.4rem}
.article-head .cat{font-size:.74rem;font-weight:700;letter-spacing:.2em;color:var(--kin);text-transform:uppercase}
.article-head h1{font-family:var(--font-disp);font-weight:800;line-height:1.4;font-size:clamp(1.7rem,4.4vw,2.7rem);margin:.5em 0 .4em}
.article-head .meta{font-size:.8rem;color:var(--ink-on-dark-dim);display:flex;gap:1.2em;flex-wrap:wrap}
.article-cover{aspect-ratio:16/9;border-radius:var(--r);overflow:hidden;border:1px solid var(--line-dark);margin-bottom:2.6rem;background:var(--sumi-2)}
.article-cover img{width:100%;height:100%;object-fit:cover}
.prose{max-width:72ch;margin-inline:auto;font-size:1.04rem;line-height:1.95}
.prose>*+*{margin-top:1.2em}
.prose h2{font-family:var(--font-disp);font-weight:800;font-size:clamp(1.4rem,3.2vw,1.9rem);line-height:1.5;margin-top:2.4em;padding-top:.4em;border-top:1px solid var(--line-dark);color:var(--washi)}
.prose h3{font-family:var(--font-disp);font-weight:700;font-size:1.24rem;margin-top:1.8em;color:var(--washi)}
.prose p{color:var(--ink-on-dark)}
.prose strong{color:var(--kin);font-weight:700}
.prose a{color:var(--kin);text-decoration:underline;text-underline-offset:3px}
.prose ul,.prose ol{padding-left:1.4em;display:grid;gap:.5em}
.prose li{color:var(--ink-on-dark)}
.prose blockquote{border-left:3px solid var(--shu);padding:.4em 0 .4em 1.2em;color:var(--ink-on-dark-dim);font-style:italic;background:linear-gradient(90deg,rgba(207,58,43,.06),transparent)}
.prose figure{margin:1.6em 0}
.prose figure img{border-radius:var(--r);border:1px solid var(--line-dark)}
.prose figcaption{font-size:.8rem;color:var(--ink-on-dark-dim);text-align:center;margin-top:.6em}
.prose code{font-family:ui-monospace,monospace;font-size:.92em;background:var(--sumi-soft);padding:.1em .4em;border-radius:6px}
.prose hr{border:0;border-top:1px solid var(--line-dark);margin:2em 0}
.prose .embed{aspect-ratio:16/9;border-radius:var(--r);overflow:hidden;border:1px solid var(--line-dark);background:#000;position:relative;cursor:pointer}
.prose .embed img{width:100%;height:100%;object-fit:cover}
.prose .embed .play{position:absolute;inset:0;display:grid;place-items:center}
.prose .embed .play span{width:64px;height:64px;border-radius:50%;background:rgba(207,58,43,.92);display:grid;place-items:center;box-shadow:0 10px 30px rgba(0,0,0,.55)}
.prose .embed .play span::after{content:"";border-left:18px solid #fff;border-block:11px solid transparent;margin-left:5px}

/* 記事下CTA */
.article-cta{max-width:72ch;margin:3.4rem auto 0;border-radius:var(--r);overflow:hidden;border:1px solid var(--line-dark);
  background:linear-gradient(160deg,rgba(207,58,43,.16),rgba(40,74,112,.18));padding:2.2rem clamp(1.4rem,4vw,2.4rem);text-align:center}
.article-cta b{font-family:var(--font-disp);font-weight:800;font-size:clamp(1.2rem,3vw,1.6rem);display:block;line-height:1.5;color:var(--washi)}
.article-cta p{font-size:.92rem;color:var(--ink-on-dark-dim);margin:.8em 0 1.4em}

/* 関連記事 */
.related{max-width:var(--maxw);margin:3.4rem auto 0}
.related h2{font-family:var(--font-disp);font-weight:800;font-size:1.3rem;margin-bottom:1.4rem;color:var(--washi)}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.related-card{background:var(--sumi-soft);border:1px solid var(--line-dark);border-radius:var(--r);padding:1.4rem 1.3rem;transition:transform .3s,border-color .3s}
.related-card:hover{transform:translateY(-4px);border-color:rgba(205,164,81,.4)}
.related-card .cat{font-size:.7rem;font-weight:700;letter-spacing:.16em;color:var(--kin)}
.related-card b{font-family:var(--font-disp);font-weight:700;display:block;font-size:1.02rem;margin:.4em 0 .3em;color:var(--ink-on-dark);line-height:1.5}
.related-card p{font-size:.84rem;color:var(--ink-on-dark-dim)}
@media(max-width:760px){.related-grid{grid-template-columns:1fr}}

/* 記事一覧 */
.alist{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:2.8rem}
.alist .card{background:var(--sumi-soft);border:1px solid var(--line-dark);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;transition:transform .3s,border-color .3s}
.alist .card:hover{transform:translateY(-5px);border-color:rgba(205,164,81,.45)}
.alist .card .thumb{aspect-ratio:16/9;background:var(--sumi-2);overflow:hidden}
.alist .card .thumb img{width:100%;height:100%;object-fit:cover}
.alist .card .thumb-ph{display:grid;place-items:center;gap:.4rem;position:relative;
  background:linear-gradient(150deg,#14283f,#0a1626),radial-gradient(80% 70% at 70% 20%,rgba(205,164,81,.18),transparent)}
.alist .card .thumb-ph .seal{font-family:var(--font-disp);font-weight:800;font-size:1.8rem;color:var(--shu);
  border:2px solid var(--shu);border-radius:8px;width:2.2em;height:2.2em;display:grid;place-items:center;opacity:.85}
.alist .card .thumb-ph .cat{font-family:var(--font-disp);font-size:.82rem;letter-spacing:.18em;color:var(--kin)}
.alist .card .c{padding:1.4rem 1.3rem;flex:1;display:flex;flex-direction:column}
.alist .card .cat{font-size:.7rem;font-weight:700;letter-spacing:.16em;color:var(--kin)}
.alist .card b{font-family:var(--font-disp);font-weight:700;font-size:1.06rem;margin:.4em 0 .4em;color:var(--ink-on-dark);line-height:1.5}
.alist .card p{font-size:.85rem;color:var(--ink-on-dark-dim);flex:1}
.alist .card .date{font-size:.74rem;color:var(--ink-on-dark-dim);margin-top:1rem}
.filterbar{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:2.4rem}
.filterbar button{font-family:var(--font-body);font-size:.84rem;color:var(--ink-on-dark);background:var(--sumi-soft);border:1px solid var(--line-dark);border-radius:999px;padding:.55em 1.2em;cursor:pointer;transition:background .25s,color .25s,border-color .25s}
.filterbar button.active{background:var(--shu);border-color:var(--shu);color:#fff}
.filterbar button:focus-visible{outline:3px solid var(--kin);outline-offset:3px}
@media(max-width:880px){.alist{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.alist{grid-template-columns:1fr}}

/* ============================================================
   数字インフォグラフィック ＆ リッチモーション
============================================================ */
/* 等幅数字（カウントアップのガタつき防止） */
.hero .trust b,.statline b,.kbox .score,.leap .v,.gauge .gv b{font-variant-numeric:tabular-nums}

/* スクロール進捗バー（上部） */
.scrollprog{position:fixed;top:0;left:0;right:0;height:3px;z-index:70;pointer-events:none;background:rgba(205,164,81,.08)}
.scrollprog>i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--shu),var(--kin) 55%,var(--silver));box-shadow:0 0 12px rgba(205,164,81,.55)}

/* 掛け算スコアのゴールド・シマー */
.kbox.good .score{
  background:linear-gradient(90deg,var(--shu),var(--kin) 45%,var(--silver) 65%,var(--kin) 85%,var(--shu));
  background-size:220% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:var(--shu);
  animation:scoreShine 5s ease-in-out infinite}
@keyframes scoreShine{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}

/* ドーナツゲージ（例：10年でも成功は約3割） */
.gauge{position:relative;width:148px;height:148px;margin:1rem auto .4rem}
.gauge svg{width:100%;height:100%;transform:rotate(-90deg)}
.gauge circle{fill:none;stroke-width:8;stroke-linecap:round}
.gauge .track{stroke:rgba(205,164,81,.16)}
.gauge .fill{stroke:var(--shu);filter:drop-shadow(0 0 6px rgba(207,58,43,.45))}
.gauge .gv{position:absolute;inset:0;display:grid;place-content:center;text-align:center;gap:.1em}
.gauge .gv b{font-family:var(--font-body);font-weight:900;font-size:3.1rem;color:var(--shu);line-height:1;letter-spacing:-.02em;display:flex;align-items:baseline;justify-content:center}
.gauge .gv b .u{font-family:var(--font-disp);font-weight:700;font-size:.36em;letter-spacing:.02em}
.gauge .gv .cap{font-size:.66rem;color:var(--ink-on-dark-dim);letter-spacing:.14em}

/* 比較バー（掛け算スコアの戦闘力） */
.kbar{height:10px;border-radius:999px;background:rgba(255,255,255,.06);border:1px solid var(--line-dark);overflow:hidden;margin-top:1.1rem}
.kbar>span{display:block;height:100%;width:0;border-radius:999px}
.kbox.bad .kbar>span{background:linear-gradient(90deg,var(--silver-deep),var(--silver))}
.kbox.good .kbar>span{background:linear-gradient(90deg,var(--shu),var(--kin));box-shadow:0 0 10px rgba(205,164,81,.5)}
.kbar-cap{font-size:.72rem;color:var(--ink-on-dark-dim);margin-top:.5rem;letter-spacing:.06em}

/* 進捗バー（例：コースの約7割が5技法の仕込み）— 白地 */
.statbar{margin:1.8rem auto 0;max-width:560px}
.statbar .track{height:13px;border-radius:999px;background:var(--washi-2);border:1px solid var(--line-light);overflow:hidden}
.statbar .track>span{display:block;height:100%;width:0;border-radius:999px;background:linear-gradient(90deg,var(--hinoki-deep),var(--kin));box-shadow:0 0 10px rgba(205,164,81,.4)}
.statbar .lbl{display:flex;justify-content:space-between;align-items:baseline;font-size:.82rem;color:var(--ink-on-light-dim);margin-top:.6rem}
.statbar .lbl b{font-family:var(--font-disp);color:var(--shu);font-weight:800;margin:0 .15em}

/* 収入リープ（消防士→独立後の比較バー）— 紺地 */
.leap{margin:1.6rem 0;background:var(--sumi-2);border:1px solid var(--line-dark);border-radius:var(--r);padding:1.3rem 1.4rem}
.leap .lh{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;flex-wrap:wrap}
.leap .lh>span:first-child{font-family:var(--font-disp);font-weight:700;color:var(--washi);font-size:1rem;letter-spacing:.04em}
.leap .lh .cap{font-size:.72rem;color:var(--ink-on-dark-dim);letter-spacing:.06em}
.leap .rows{display:grid;gap:.7rem;margin-top:1rem}
.leap .row{display:grid;grid-template-columns:5.2em 1fr auto;gap:.9rem;align-items:center}
.leap .row .k{font-size:.74rem;color:var(--ink-on-dark-dim)}
.leap .row .bar{height:13px;border-radius:999px;background:rgba(255,255,255,.05);border:1px solid var(--line-dark);overflow:hidden}
.leap .row .bar>span{display:block;height:100%;width:0;border-radius:999px}
.leap .row.before .bar>span{background:linear-gradient(90deg,var(--silver-deep),var(--silver))}
.leap .row.after .bar>span{background:linear-gradient(90deg,var(--shu),var(--kin) 80%,var(--silver));box-shadow:0 0 12px rgba(205,164,81,.45)}
.leap .row .v{font-family:var(--font-body);font-weight:900;font-size:1.05rem;white-space:nowrap;letter-spacing:-.01em}
.leap .row.before .v{color:var(--silver)}
.leap .row.after .v{color:var(--kin)}
@media(max-width:520px){.leap .row{grid-template-columns:4.4em 1fr;grid-template-areas:"k bar" "v v"}.leap .row .k{grid-area:k}.leap .row .bar{grid-area:bar}.leap .row .v{grid-area:v;text-align:right}}

/* 反応の効いたカード（数字系のホバー浮き＋光） */
.statline div,.flaw,.reason,.gohos .g,.future .f{will-change:transform}
.statline{transition:none}
.statline div{transition:background .3s}
.statline div:hover{background:var(--sumi-soft)}
