/* ═══════════════════════════════════════════════════════════════════
   Clinical Performance Lab — Redesign System
   Direction C (decoded / dark) × Direction A (editorial warmth)
   ═══════════════════════════════════════════════════════════════════ */

:root {
  --teal-900:#064E45; --teal-800:#0A6358; --teal-700:#0F7A6B;
  --teal-600:#0D9E85; --teal-500:#14B896; --teal-300:#6FD3BC;
  --lime-500:#B7E04E; --lime-400:#C7E96B;
  --cream:#FAF7F0; --cream-2:#F4EFE2; --cream-3:#ECE7DA;
  --ink:#0B1F1B; --ink-2:#1F3530; --ink-card:#0E2620;
  --muted:#5C6E69; --border:#E4DCC8; --border-strong:#D2C7A8;
  --warm-bg:#FFFCF5; --warm-border:#E8B566; --trap-amber:#946115;
  --on-dark:rgba(250,247,240,.78); --on-dark-2:rgba(250,247,240,.55); --on-dark-line:rgba(250,247,240,.13);

  --font-display:'Fraunces',Georgia,'Times New Roman',serif;
  --font-body:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;

  --max-w:1180px;
  --pad:24px;
  --r-sm:8px; --r:12px; --r-lg:18px; --r-xl:26px;
  --sh-sm:0 1px 2px rgba(11,31,27,.06);
  --sh:0 6px 22px rgba(11,31,27,.09);
  --sh-lg:0 22px 56px rgba(11,31,27,.16);
}

* { box-sizing:border-box; }
html { -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body {
  margin:0; font-family:var(--font-body); font-size:16px; line-height:1.6;
  color:var(--ink-2); background:var(--cream);
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
}
img { max-width:100%; height:auto; display:block; }

h1,h2,h3,h4 { font-family:var(--font-display); font-weight:600; color:var(--ink); line-height:1.12; margin:0 0 .4em; letter-spacing:-.015em; }
h1 { font-size:clamp(2.4rem,5.5vw,4rem); }
h2 { font-size:clamp(1.8rem,3.6vw,2.6rem); }
h3 { font-size:clamp(1.2rem,2.4vw,1.5rem); }
h4 { font-size:1.05rem; }
.italic-accent { font-style:italic; font-weight:400; }
p { margin:0 0 1em; }
a { color:var(--teal-700); text-decoration:none; font-weight:500; transition:color .15s; }
a:hover { color:var(--teal-900); }

/* ── layout ── */
.container { max-width:var(--max-w); margin:0 auto; padding:0 var(--pad); }
.container-narrow { max-width:780px; margin:0 auto; padding:0 var(--pad); }
.section { padding:88px 0; }
.section-tight { padding:56px 0; }
.bg-cream2 { background:var(--cream-2); }

/* ── eyebrow ── */
.eyebrow {
  display:inline-flex; align-items:center; gap:8px; padding:6px 14px;
  border-radius:999px; font-size:.74rem; font-weight:600; letter-spacing:.08em;
  text-transform:uppercase; color:var(--teal-700);
  background:var(--cream-2); border:1px solid var(--border);
}
.eyebrow .dot { width:6px; height:6px; border-radius:50%; background:var(--lime-500); }
.eyebrow.on-dark { background:rgba(250,247,240,.08); border-color:var(--on-dark-line); color:var(--lime-400); }

.section-head { max-width:62ch; margin:0 0 40px; }
.section-head.center { margin-left:auto; margin-right:auto; text-align:center; }
.section-head h2 { margin:14px 0 12px; }
.section-head p { color:var(--muted); font-size:1.08rem; line-height:1.55; }

/* ── buttons ── */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:13px 24px; border-radius:999px; font-family:var(--font-body);
  font-weight:600; font-size:.95rem; cursor:pointer; border:none;
  text-decoration:none; transition:transform .15s ease, background .15s ease, color .15s ease; white-space:nowrap;
}
.btn:hover { transform:translateY(-1px); }
.btn:active { transform:translateY(0); }
.btn-primary { background:var(--ink); color:var(--lime-500); }
.btn-primary:hover { background:var(--teal-900); color:var(--lime-400); }
.btn-lime { background:var(--lime-500); color:var(--ink); }
.btn-lime:hover { background:var(--lime-400); color:var(--ink); }
.btn-ghost { background:transparent; color:var(--teal-700); border:1.5px solid var(--border-strong); }
.btn-ghost:hover { background:var(--cream-2); color:var(--teal-900); }
.btn-ghost-dark { background:transparent; color:var(--cream); border:1.5px solid var(--on-dark-line); }
.btn-ghost-dark:hover { background:rgba(250,247,240,.08); color:#fff; }
.btn-lg { padding:16px 30px; font-size:1.02rem; }
.btn-sm { padding:9px 18px; font-size:.86rem; }
.link-arrow { font-weight:600; font-size:.92rem; color:var(--teal-700); display:inline-flex; align-items:center; gap:6px; }
.link-arrow:hover { gap:9px; color:var(--teal-900); }

/* ═══ NAV ═══ */
.nav { position:sticky; top:0; z-index:200; background:rgba(250,247,240,.9); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); border-bottom:1px solid var(--border); }
.nav-inner { max-width:var(--max-w); margin:0 auto; padding:13px var(--pad); display:flex; align-items:center; justify-content:space-between; gap:24px; }
.nav-brand { display:flex; align-items:center; gap:11px; font-weight:600; color:var(--ink); font-size:.95rem; }
.nav-brand:hover { color:var(--ink); }
.nav-logo { width:34px; height:34px; border-radius:50%; background:var(--lime-500); display:flex; align-items:center; justify-content:center; font-weight:700; font-size:.82rem; color:var(--ink); letter-spacing:-.02em; flex-shrink:0; }
.nav-brand small { display:block; font-size:.68rem; color:var(--muted); font-weight:400; letter-spacing:.05em; text-transform:uppercase; margin-top:-1px; }
.nav-links { display:flex; align-items:center; gap:26px; list-style:none; margin:0; padding:0; }
.nav-links a { color:var(--ink-2); font-weight:500; font-size:.9rem; }
.nav-links a:hover { color:var(--teal-700); }
.nav-actions { display:flex; align-items:center; gap:12px; }
.nav-burger { display:none; flex-direction:column; gap:4px; background:none; border:none; cursor:pointer; padding:8px; }
.nav-burger span { width:22px; height:2px; background:var(--ink); display:block; transition:.2s; }
.mobile-menu { display:none; }

@media (max-width:860px) {
  .nav-links { display:none; }
  .nav-burger { display:flex; }
  .nav-cta-desktop { display:none; }
  .mobile-menu { display:block; position:fixed; inset:0 0 0 auto; width:min(82vw,340px); background:var(--cream); z-index:300; transform:translateX(100%); transition:transform .28s cubic-bezier(.16,.84,.44,1); box-shadow:var(--sh-lg); padding:80px 28px 28px; }
  .mobile-menu.open { transform:translateX(0); }
  .mobile-menu a { display:block; padding:14px 0; font-size:1.1rem; font-weight:600; color:var(--ink); border-bottom:1px solid var(--border); font-family:var(--font-display); }
  .mobile-menu .btn { width:100%; margin-top:22px; }
  .mobile-menu-close { position:absolute; top:22px; right:24px; background:none; border:none; font-size:1.8rem; color:var(--ink); cursor:pointer; line-height:1; }
  .menu-backdrop { display:none; position:fixed; inset:0; background:rgba(11,31,27,.5); z-index:250; }
  .menu-backdrop.open { display:block; }
}

/* ═══ HERO (dark decoded panel) ═══ */
.hero { padding:40px 0 24px; }
.hero-panel {
  background:var(--ink); color:var(--on-dark); border-radius:var(--r-xl);
  padding:60px 56px; position:relative; overflow:hidden;
  display:grid; grid-template-columns:1.04fr .96fr; gap:52px; align-items:center;
  box-shadow:var(--sh-lg);
}
.hero-panel::before { content:""; position:absolute; top:-180px; right:-120px; width:520px; height:520px; border-radius:50%; background:radial-gradient(circle,var(--teal-600) 0%,transparent 68%); opacity:.32; pointer-events:none; }
.hero-panel::after { content:""; position:absolute; bottom:-220px; left:-140px; width:460px; height:460px; border-radius:50%; background:radial-gradient(circle,var(--lime-500) 0%,transparent 70%); opacity:.1; pointer-events:none; }
.hero-content { position:relative; z-index:2; }
.hero h1 { color:var(--cream); font-size:clamp(2.5rem,4.8vw,3.9rem); margin:20px 0 20px; }
.hero h1 .italic-accent { color:var(--lime-400); }
.hero-sub { font-size:1.14rem; line-height:1.55; color:var(--on-dark); max-width:46ch; margin:0 0 30px; }
.hero-ctas { display:flex; gap:12px; align-items:center; flex-wrap:wrap; }
.hero-tertiary { margin:20px 0 0; font-size:.92rem; color:var(--on-dark-2); }
.hero-tertiary a { color:var(--lime-400); }
.hero-tertiary a:hover { color:var(--lime-500); }
.hero-trust { display:flex; gap:34px; margin-top:38px; padding-top:28px; border-top:1px solid var(--on-dark-line); flex-wrap:wrap; }
.hero-trust .t { font-size:.84rem; color:var(--on-dark-2); max-width:14ch; }
.hero-trust b { display:block; font-family:var(--font-display); font-size:1.7rem; color:var(--cream); font-weight:600; line-height:1; margin-bottom:5px; white-space:nowrap; }

/* decoded rubric device */
.rubric { position:relative; z-index:2; background:rgba(250,247,240,.045); border:1px solid var(--on-dark-line); border-radius:var(--r-lg); padding:24px; backdrop-filter:blur(2px); }
.rubric-title { font-size:.72rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--on-dark-2); margin-bottom:8px; display:flex; justify-content:space-between; align-items:center; }
.rubric-title .badge { color:var(--lime-400); font-size:.68rem; padding:3px 9px; border:1px solid var(--on-dark-line); border-radius:999px; letter-spacing:.06em; }
.rubric-case { font-family:var(--font-display); font-size:1.05rem; color:var(--cream); font-weight:600; margin-bottom:14px; }
.rubric-row { display:flex; align-items:center; gap:13px; padding:12px 0; border-bottom:1px solid rgba(250,247,240,.08); }
.rubric-row:last-child { border-bottom:none; }
.rubric-check { width:24px; height:24px; border-radius:7px; background:var(--lime-500); color:var(--ink); display:flex; align-items:center; justify-content:center; font-weight:700; font-size:13px; flex-shrink:0; transition:background .5s; }
.rubric-text { flex:1; font-size:.9rem; color:var(--cream); line-height:1.3; }
.rubric-text small { display:block; font-size:.74rem; color:var(--on-dark-2); margin-top:3px; font-weight:400; }
.rubric-pts { font-family:var(--font-display); font-weight:600; color:var(--lime-400); font-size:1.05rem; transition:filter .5s; }
/* locked state (pre-reveal) */
.rubric-row.locked .rubric-text, .rubric-row.locked .rubric-pts { filter:blur(5px); transition:filter .6s ease; }
.rubric-row.locked .rubric-check { background:rgba(250,247,240,.15); color:transparent; }
.rubric.revealed .rubric-row.locked .rubric-text,
.rubric.revealed .rubric-row.locked .rubric-pts { filter:blur(0); }
.rubric.revealed .rubric-row.locked .rubric-check { background:var(--lime-500); color:var(--ink); }

/* ═══ HOW IT WORKS ═══ */
.steps { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.step { background:var(--warm-bg); border:1px solid var(--border); border-radius:var(--r-lg); padding:30px 28px; display:flex; flex-direction:column; gap:12px; }
.step-num { font-family:var(--font-display); font-size:1rem; font-weight:600; color:var(--teal-700); width:42px; height:42px; border-radius:50%; border:1.5px solid var(--border-strong); display:flex; align-items:center; justify-content:center; }
.step h3 { margin:6px 0 0; font-size:1.28rem; }
.step p { color:var(--muted); font-size:.96rem; margin:0; line-height:1.55; }
.step .link-arrow { margin-top:auto; padding-top:6px; }
.step-free { align-self:flex-start; font-size:.68rem; font-weight:700; letter-spacing:.07em; text-transform:uppercase; color:var(--ink); background:var(--lime-500); padding:3px 10px; border-radius:999px; }
.step-paid { align-self:flex-start; font-size:.68rem; font-weight:700; letter-spacing:.07em; text-transform:uppercase; color:var(--teal-700); background:var(--cream-2); border:1px solid var(--border); padding:3px 10px; border-radius:999px; }

/* ═══ RESOURCE / CHEAT-SHEET CARDS ═══ */
.resource-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:16px; }
.resource-card { position:relative; background:#fff; border:1px solid var(--border); border-radius:var(--r-lg); padding:22px; display:flex; flex-direction:column; gap:10px; cursor:pointer; transition:transform .18s, border-color .18s, box-shadow .18s; }
.resource-card:hover { border-color:var(--teal-500); transform:translateY(-2px); box-shadow:var(--sh); }
.resource-card.selected { border-color:var(--teal-700); border-width:2px; padding:21px; background:var(--warm-bg); }
.resource-card.selected::after { content:"✓"; position:absolute; top:14px; right:14px; width:24px; height:24px; background:var(--lime-500); border-radius:50%; display:flex; align-items:center; justify-content:center; font-weight:700; color:var(--ink); font-size:13px; }
.resource-stage { font-size:.68rem; font-weight:700; color:var(--teal-700); letter-spacing:.08em; text-transform:uppercase; }
.resource-card h3 { font-size:1.15rem; margin:0; }
.resource-card p { font-size:.88rem; color:var(--muted); margin:0; line-height:1.5; }
.resource-meta { margin-top:auto; padding-top:10px; border-top:1px solid var(--border); font-size:.76rem; color:var(--muted); display:flex; gap:10px; }

/* email capture */
.capture { background:var(--ink); color:var(--cream); border-radius:var(--r-lg); padding:32px; margin-top:24px; position:relative; overflow:hidden; }
.capture::before { content:""; position:absolute; top:-120px; right:-80px; width:300px; height:300px; border-radius:50%; background:radial-gradient(circle,var(--teal-600) 0%,transparent 70%); opacity:.25; }
.capture-inner { position:relative; z-index:2; }
.capture-eyebrow { font-size:.72rem; font-weight:700; color:var(--lime-400); letter-spacing:.08em; text-transform:uppercase; margin-bottom:8px; }
.capture h3 { color:var(--cream); font-size:1.4rem; margin:0 0 8px; }
.capture p { color:var(--on-dark); font-size:.94rem; margin:0 0 18px; }
.capture-row { display:flex; gap:8px; flex-wrap:wrap; }
.capture input[type=email] { flex:1; min-width:240px; padding:14px 18px; border-radius:999px; border:1.5px solid rgba(250,247,240,.22); background:rgba(250,247,240,.06); color:var(--cream); font-family:var(--font-body); font-size:.95rem; transition:.15s; }
.capture input[type=email]::placeholder { color:rgba(250,247,240,.45); }
.capture input[type=email]:focus { outline:none; border-color:var(--lime-500); background:rgba(250,247,240,.1); }
.capture-fine { margin-top:12px; font-size:.76rem; color:var(--on-dark-2); }

/* ═══ CASE CARDS ═══ */
.case-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(290px,1fr)); gap:20px; }
.case-card { background:#fff; border:1px solid var(--border); border-radius:var(--r-lg); padding:26px; display:flex; flex-direction:column; gap:11px; text-decoration:none; color:inherit; transition:transform .18s, border-color .18s, box-shadow .18s; }
.case-card:hover { border-color:var(--teal-500); transform:translateY(-3px); box-shadow:var(--sh); color:inherit; }
.case-card h3 { font-size:1.2rem; margin:0; color:var(--ink); }
.case-cc { font-style:italic; color:var(--muted); font-size:.9rem; margin:0; }
.case-meta { display:flex; flex-wrap:wrap; gap:7px; margin-top:2px; }
.case-tag { display:inline-block; padding:4px 10px; border-radius:6px; font-size:.7rem; font-weight:600; background:var(--cream-2); color:var(--teal-800); }
.case-tag.lead-fast { background:var(--lime-500); color:var(--ink); font-weight:700; }
.case-sub { font-size:.82rem; color:var(--muted); margin:6px 0 0; }
.case-cta { margin-top:auto; padding-top:14px; border-top:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; font-weight:600; font-size:.88rem; color:var(--teal-700); }

/* ═══ PRICING ═══ */
.pricing-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.tier { background:#fff; border:1.5px solid var(--border); border-radius:var(--r-lg); padding:30px 26px; text-align:center; position:relative; }
.tier.featured { border-color:var(--teal-700); background:var(--warm-bg); }
.tier.featured::before { content:"BEST VALUE"; position:absolute; top:-12px; left:50%; transform:translateX(-50%); background:var(--lime-500); color:var(--ink); font-size:.68rem; font-weight:700; letter-spacing:.06em; padding:4px 13px; border-radius:999px; }
.tier-label { font-size:.82rem; font-weight:600; color:var(--muted); text-transform:uppercase; letter-spacing:.04em; }
.tier-price { font-family:var(--font-display); font-size:3rem; font-weight:600; color:var(--ink); line-height:1; margin:10px 0 4px; }
.tier-price .cur { font-size:1.2rem; vertical-align:top; color:var(--muted); margin-right:2px; }
.tier-saves { font-size:.82rem; color:var(--teal-700); font-weight:600; min-height:1.4em; }
.tier-blurb { font-size:.9rem; color:var(--muted); margin:14px 0 18px; }

/* ═══ FOOTER ═══ */
.footer { background:var(--ink); color:var(--on-dark); padding:60px 0 30px; margin-top:0; }
.footer-inner { max-width:var(--max-w); margin:0 auto; padding:0 var(--pad); display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:36px; }
.footer h4 { color:var(--lime-400); font-family:var(--font-body); font-size:.74rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; margin:0 0 14px; }
.footer a { color:rgba(250,247,240,.82); font-weight:400; font-size:.9rem; }
.footer a:hover { color:var(--lime-400); }
.footer ul { list-style:none; padding:0; margin:0; }
.footer ul li { margin-bottom:9px; }
.footer-brand { font-family:var(--font-display); font-size:1.35rem; color:var(--cream); font-weight:600; margin-bottom:8px; }
.footer-tagline { font-size:.86rem; color:var(--on-dark-2); margin-bottom:14px; max-width:36ch; line-height:1.55; }
.footer-bottom { max-width:var(--max-w); margin:40px auto 0; padding:24px var(--pad) 0; border-top:1px solid var(--on-dark-line); font-size:.76rem; color:var(--on-dark-2); display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px; }

/* ═══════════════════════════════════════════════════════════════════
   SIMULATOR
   ═══════════════════════════════════════════════════════════════════ */
.sim-wrap { padding:40px 0 80px; }
.sim-shell { background:var(--ink); border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--sh-lg); position:relative; }
.sim-topbar { padding:22px 30px; display:flex; align-items:center; justify-content:space-between; gap:20px; border-bottom:1px solid var(--on-dark-line); flex-wrap:wrap; }
.sim-patient { display:flex; align-items:center; gap:14px; }
.sim-avatar { width:46px; height:46px; border-radius:50%; background:var(--teal-700); color:var(--cream); display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-weight:600; font-size:1.1rem; }
.sim-patient .pn { font-family:var(--font-display); font-size:1.1rem; color:var(--cream); font-weight:600; }
.sim-patient .pc { font-size:.8rem; color:var(--on-dark-2); }
.sim-scorebox { text-align:right; }
.sim-scorebox .sl { font-size:.68rem; text-transform:uppercase; letter-spacing:.07em; color:var(--on-dark-2); }
.sim-scorebox .sv { font-family:var(--font-display); font-size:1.5rem; color:var(--lime-400); font-weight:600; line-height:1; }
.sim-stepper { display:flex; gap:0; padding:0 30px; background:rgba(250,247,240,.03); }
.sim-step { flex:1; padding:14px 8px; text-align:center; font-size:.8rem; font-weight:600; color:var(--on-dark-2); border-bottom:2px solid transparent; position:relative; }
.sim-step.active { color:var(--lime-400); border-bottom-color:var(--lime-500); }
.sim-step.done { color:var(--cream); }
.sim-step .si { display:block; font-size:.66rem; text-transform:uppercase; letter-spacing:.06em; opacity:.7; }
.sim-stage { padding:30px; background:var(--cream); }
.sim-prompt { margin-bottom:6px; }
.sim-prompt .pe { font-size:.72rem; font-weight:700; letter-spacing:.07em; text-transform:uppercase; color:var(--teal-700); }
.sim-prompt h3 { font-size:1.35rem; margin:6px 0 4px; }
.sim-prompt p { color:var(--muted); font-size:.94rem; margin:0 0 18px; }
.sim-opts { display:flex; flex-direction:column; gap:10px; }
.sim-opt { display:flex; align-items:center; gap:14px; padding:15px 17px; border:1.5px solid var(--border); border-radius:var(--r); background:#fff; cursor:pointer; transition:.13s; text-align:left; font-family:var(--font-body); }
.sim-opt:hover { border-color:var(--teal-500); }
.sim-opt.sel { border-color:var(--teal-700); background:var(--warm-bg); }
.sim-check { width:24px; height:24px; border-radius:7px; border:2px solid var(--border-strong); flex-shrink:0; display:flex; align-items:center; justify-content:center; font-weight:700; color:transparent; transition:.13s; }
.sim-opt.sel .sim-check { background:var(--teal-700); border-color:var(--teal-700); color:#fff; }
.sim-opt .so-text { flex:1; font-size:.95rem; color:var(--ink-2); }
.sim-opt.revealed { cursor:default; }
.sim-opt.r-key { border-color:var(--teal-500); background:rgba(20,184,150,.07); }
.sim-opt.r-minor { border-color:var(--border); }
.sim-opt.r-trap { border-color:var(--warm-border); background:var(--warm-bg); }
.sim-opt.r-missed { border-style:dashed; opacity:.85; }
.so-note { font-size:.82rem; color:var(--muted); margin-top:5px; line-height:1.4; }
.so-note b { color:var(--ink); }
.so-pts { font-family:var(--font-body); font-weight:700; font-size:.82rem; padding:4px 11px; border-radius:999px; flex-shrink:0; white-space:nowrap; }
.so-pts.plus { background:var(--lime-500); color:var(--ink); }
.so-pts.zero { background:var(--cream-2); color:var(--muted); }
.so-pts.minus { background:#F3D8B0; color:var(--trap-amber); }
.sim-actions { display:flex; align-items:center; justify-content:space-between; gap:14px; margin-top:22px; flex-wrap:wrap; }
.sim-hint { font-size:.82rem; color:var(--muted); }
.sim-feedback { margin-top:18px; padding:16px 18px; background:var(--ink); border-radius:var(--r); color:var(--on-dark); font-size:.9rem; line-height:1.55; }
.sim-feedback b { color:var(--lime-400); }
.sim-feedback .sf-delta { font-family:var(--font-display); color:var(--lime-400); font-weight:600; }

/* results */
.sim-results { padding:40px 34px; background:var(--cream); text-align:center; }
.sim-score-ring { width:150px; height:150px; margin:0 auto 18px; position:relative; }
.sim-score-ring svg { transform:rotate(-90deg); }
.sim-score-ring .rv { position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; }
.sim-score-ring .rv b { font-family:var(--font-display); font-size:2.4rem; color:var(--ink); font-weight:600; line-height:1; }
.sim-score-ring .rv span { font-size:.72rem; color:var(--muted); text-transform:uppercase; letter-spacing:.06em; }
.sim-grade { display:inline-block; font-size:.8rem; font-weight:700; letter-spacing:.05em; text-transform:uppercase; padding:5px 14px; border-radius:999px; background:var(--lime-500); color:var(--ink); margin-bottom:12px; }
.sim-results h3 { font-size:1.6rem; margin:0 0 8px; }
.sim-results > p { color:var(--muted); max-width:46ch; margin:0 auto 22px; }
.sim-breakdown { display:grid; grid-template-columns:repeat(4,1fr); gap:10px; max-width:520px; margin:0 auto 26px; }
.sbd { background:#fff; border:1px solid var(--border); border-radius:var(--r); padding:14px 8px; }
.sbd b { display:block; font-family:var(--font-display); font-size:1.4rem; color:var(--ink); }
.sbd span { font-size:.7rem; color:var(--muted); text-transform:uppercase; letter-spacing:.04em; }
.sim-results-ctas { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
.sim-casebar { display:flex; gap:10px; flex-wrap:wrap; padding:16px 30px; background:rgba(250,247,240,.03); border-bottom:1px solid var(--on-dark-line); align-items:center; }
.sim-casebar .cl { font-size:.72rem; text-transform:uppercase; letter-spacing:.06em; color:var(--on-dark-2); margin-right:4px; }
.sim-casetab { background:rgba(250,247,240,.06); border:1px solid var(--on-dark-line); color:var(--cream); font-family:var(--font-body); font-size:.82rem; font-weight:500; padding:7px 14px; border-radius:999px; cursor:pointer; }
.sim-casetab.active { background:var(--lime-500); color:var(--ink); border-color:var(--lime-500); }
.sim-casetab.locked { opacity:.5; cursor:default; }
@media (max-width:600px) {
  .sim-stage, .sim-results { padding:22px 18px; }
  .sim-topbar { padding:18px 20px; }
  .sim-stepper { padding:0 12px; }
  .sim-step { font-size:0; padding:12px 4px; }
  .sim-step .si { font-size:.62rem; }
  .sim-breakdown { grid-template-columns:repeat(2,1fr); }
  .sim-opt { padding:13px 14px; }
}

/* ═══════════════════════════════════════════════════════════════════
   CATALOG PAGE
   ═══════════════════════════════════════════════════════════════════ */
.cat-hero { padding:40px 0 0; }
.cat-hero-panel { background:var(--ink); color:var(--on-dark); border-radius:var(--r-xl); padding:48px 52px; position:relative; overflow:hidden; }
.cat-hero-panel::before { content:""; position:absolute; top:-160px; right:-110px; width:460px; height:460px; border-radius:50%; background:radial-gradient(circle,var(--teal-600) 0%,transparent 68%); opacity:.3; }
.cat-hero-inner { position:relative; z-index:2; }
.cat-hero h1 { color:var(--cream); font-size:clamp(2rem,4vw,3.2rem); margin:14px 0 14px; }
.cat-hero h1 .italic-accent { color:var(--lime-400); }
.cat-hero p { color:var(--on-dark); font-size:1.05rem; max-width:54ch; margin:0 0 26px; }
.cat-search-big { display:flex; align-items:center; gap:12px; background:rgba(250,247,240,.07); border:1.5px solid var(--on-dark-line); border-radius:999px; padding:4px 6px 4px 20px; max-width:560px; transition:.15s; }
.cat-search-big:focus-within { border-color:var(--lime-500); background:rgba(250,247,240,.11); }
.cat-search-big svg { color:var(--on-dark-2); flex-shrink:0; }
.cat-search-big input { flex:1; background:transparent; border:none; outline:none; color:var(--cream); font-family:var(--font-body); font-size:1rem; padding:12px 0; }
.cat-search-big input::placeholder { color:var(--on-dark-2); }
.cat-search-clear { background:rgba(250,247,240,.12); border:none; color:var(--cream); width:32px; height:32px; border-radius:50%; font-size:1.2rem; cursor:pointer; line-height:1; }

.cat-body { padding:36px 0 60px; }
.cat-filters { display:flex; flex-direction:column; gap:14px; margin-bottom:24px; }
.filter-group { display:flex; align-items:baseline; gap:12px; flex-wrap:wrap; }
.filter-label { font-size:.72rem; font-weight:700; letter-spacing:.07em; text-transform:uppercase; color:var(--muted); min-width:78px; }
.filter-chips { display:flex; flex-wrap:wrap; gap:7px; }
.filter-chip { background:#fff; border:1.5px solid var(--border); color:var(--ink-2); font-family:var(--font-body); font-size:.82rem; font-weight:500; padding:6px 13px; border-radius:999px; cursor:pointer; transition:.13s; }
.filter-chip:hover { border-color:var(--teal-500); }
.filter-chip.active { background:var(--ink); color:var(--lime-500); border-color:var(--ink); }
.filter-clear { display:none; align-items:center; gap:5px; background:var(--cream-2); border:1px solid var(--border-strong); color:var(--trap-amber); font-family:var(--font-body); font-weight:600; font-size:.8rem; padding:6px 14px; border-radius:999px; cursor:pointer; align-self:flex-start; }
.cat-count { font-size:.9rem; color:var(--muted); font-weight:500; margin-bottom:18px; }
.cat-card-actions { margin-top:auto; padding-top:14px; border-top:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; gap:10px; }
.bundle-add { background:var(--cream-2); border:1.5px solid var(--border-strong); color:var(--teal-700); font-family:var(--font-body); font-weight:600; font-size:.8rem; padding:7px 14px; border-radius:999px; cursor:pointer; transition:.13s; white-space:nowrap; }
.bundle-add:hover { border-color:var(--teal-500); background:#fff; }
.bundle-add.added { background:var(--lime-500); border-color:var(--lime-500); color:var(--ink); }
.cat-empty { display:none; text-align:center; padding:60px 20px; color:var(--muted); }
.cat-empty h3 { color:var(--ink); margin-bottom:8px; }

/* bundle cart bar */
.bundle-bar { position:fixed; left:0; right:0; bottom:0; z-index:1150; background:var(--ink); color:var(--cream); transform:translateY(110%); transition:transform .28s cubic-bezier(.16,.84,.44,1); box-shadow:0 -10px 40px rgba(11,31,27,.25); }
.bundle-bar.open { transform:none; }
.bundle-bar-inner { max-width:var(--max-w); margin:0 auto; padding:16px var(--pad); display:flex; align-items:center; gap:20px; flex-wrap:wrap; }
.bundle-info { display:flex; align-items:baseline; gap:14px; }
.bundle-info .bc { font-family:var(--font-display); font-size:1.3rem; font-weight:600; }
.bundle-info .bt { font-family:var(--font-display); font-size:1.6rem; font-weight:600; color:var(--lime-400); }
.bundle-info .bs { font-size:.82rem; font-weight:600; }
.bundle-list { display:flex; gap:7px; flex-wrap:wrap; flex:1; min-width:140px; }
.bundle-chip { background:rgba(250,247,240,.1); border:1px solid var(--on-dark-line); border-radius:999px; padding:5px 6px 5px 12px; font-size:.8rem; color:var(--cream); display:inline-flex; align-items:center; gap:6px; }
.bundle-chip button { background:rgba(250,247,240,.18); border:none; color:var(--cream); width:18px; height:18px; border-radius:50%; cursor:pointer; font-size:.9rem; line-height:1; }
.bundle-bar .btn { flex-shrink:0; }
@media (max-width:720px) {
  .bundle-list { display:none; }
  .bundle-bar-inner { gap:14px; }
  .bundle-bar .btn { flex:1; }
}
@media (max-width:560px) {
  .cat-hero-panel { padding:32px 22px; border-radius:var(--r-lg); }
  .filter-group { align-items:flex-start; flex-direction:column; gap:8px; }
}

/* ═══════════════════════════════════════════════════════════════════
   CHECKOUT MODAL
   ═══════════════════════════════════════════════════════════════════ */
.modal-overlay { position:fixed; inset:0; z-index:1400; background:rgba(11,31,27,.6); backdrop-filter:blur(5px); display:none; align-items:center; justify-content:center; padding:24px; opacity:0; transition:opacity .2s; }
.modal-overlay.open { display:flex; opacity:1; }
.modal { background:var(--cream); border-radius:var(--r-lg); width:100%; max-width:480px; max-height:92vh; overflow-y:auto; padding:34px 32px 30px; position:relative; box-shadow:var(--sh-lg); animation:modal-in .28s cubic-bezier(.16,.84,.44,1); }
@keyframes modal-in { from{transform:translateY(16px);opacity:0;} to{transform:none;opacity:1;} }
.modal-close { position:absolute; top:14px; right:18px; background:none; border:none; font-size:1.7rem; color:var(--muted); cursor:pointer; line-height:1; }
.modal-close:hover { color:var(--ink); }
.modal-eyebrow { font-size:.72rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--teal-700); margin-bottom:6px; }
.modal-title { font-size:1.5rem; margin:0 0 14px; }
.modal-sub { color:var(--muted); font-size:.95rem; line-height:1.55; margin:0 0 20px; }
.modal-sub b { color:var(--ink); }
.modal-badge { width:54px; height:54px; border-radius:50%; background:var(--cream-2); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; font-size:1.5rem; margin-bottom:16px; }
.modal-badge.success { background:var(--lime-500); border-color:var(--lime-500); color:var(--ink); }
.order-summary { display:flex; align-items:center; justify-content:space-between; gap:16px; background:#fff; border:1px solid var(--border); border-radius:var(--r); padding:16px 18px; margin-bottom:16px; }
.order-summary small { display:block; color:var(--muted); font-size:.78rem; margin-top:3px; }
.os-price { font-family:var(--font-display); font-size:1.9rem; font-weight:600; color:var(--ink); white-space:nowrap; }
.os-price .cur { font-size:.9rem; vertical-align:top; color:var(--muted); }
.invoice-note { background:var(--warm-bg); border:1px solid var(--warm-border); border-radius:var(--r); padding:13px 16px; font-size:.86rem; color:var(--ink-2); line-height:1.5; margin-bottom:18px; }
.invoice-note b { color:var(--trap-amber); }
.fld { display:block; margin-bottom:12px; }
.fld > span { display:block; font-size:.8rem; font-weight:600; color:var(--ink-2); margin-bottom:5px; }
.fld > span small { font-weight:400; color:var(--muted); }
.fld input { width:100%; padding:12px 15px; border-radius:10px; border:1.5px solid var(--border-strong); background:#fff; font-family:var(--font-body); font-size:.92rem; color:var(--ink); }
.fld input:focus { outline:none; border-color:var(--teal-500); box-shadow:0 0 0 3px rgba(20,184,150,.12); }
.fld-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.modal-link { display:block; width:100%; background:none; border:none; color:var(--teal-700); font-family:var(--font-body); font-weight:600; font-size:.88rem; cursor:pointer; margin-top:16px; text-align:center; }
.modal-link:hover { color:var(--teal-900); }
.code-entry { background:#fff; border:1px solid var(--border); border-radius:var(--r); padding:18px; margin-top:6px; }
[data-code-form], [data-code-form2] { display:flex; gap:8px; }
[data-code-form] { margin-top:4px; }
.code-entry input, .code-input-lg { flex:1; padding:12px 15px; border-radius:10px; border:1.5px solid var(--border-strong); font-family:var(--font-body); font-size:.95rem; letter-spacing:.06em; text-transform:uppercase; background:var(--cream); }
.code-entry input:focus, .code-input-lg:focus { outline:none; border-color:var(--teal-500); }
.code-error { color:#b4452c; font-size:.82rem; margin:10px 0 0; }
.code-hint { font-size:.78rem; color:var(--muted); margin:12px 0 0; }
.code-hint b { color:var(--teal-700); letter-spacing:.04em; }
@media (max-width:480px) { .fld-row { grid-template-columns:1fr; } .modal { padding:28px 22px 24px; } }

/* ═══════════════════════════════════════════════════════════════════
   SUPPORT CHAT WIDGET
   ═══════════════════════════════════════════════════════════════════ */
.cpl-fab { position:fixed; bottom:22px; right:22px; z-index:1200; display:inline-flex; align-items:center; gap:9px; padding:13px 20px 13px 16px; border:none; border-radius:999px; background:var(--ink); color:var(--lime-500); font-family:var(--font-body); font-weight:600; font-size:.92rem; cursor:pointer; box-shadow:var(--sh-lg); transition:transform .18s, opacity .18s; }
.cpl-fab:hover { transform:translateY(-2px); }
.cpl-fab.hidden { opacity:0; pointer-events:none; transform:scale(.9); }
.cpl-fab-ico { font-size:1.15rem; }
.cpl-chat { position:fixed; bottom:22px; right:22px; z-index:1300; width:min(380px,calc(100vw - 32px)); height:min(580px,calc(100vh - 44px)); background:var(--cream); border:1px solid var(--border); border-radius:var(--r-lg); box-shadow:var(--sh-lg); display:flex; flex-direction:column; overflow:hidden; opacity:0; transform:translateY(16px) scale(.98); pointer-events:none; transition:opacity .22s, transform .22s; }
.cpl-chat.open { opacity:1; transform:none; pointer-events:auto; }
.cpl-chat-head { background:var(--ink); color:var(--cream); padding:16px 18px; display:flex; align-items:center; justify-content:space-between; }
.cpl-chat-id { display:flex; align-items:center; gap:11px; }
.cpl-chat-avatar { width:38px; height:38px; border-radius:50%; background:var(--lime-500); color:var(--ink); display:flex; align-items:center; justify-content:center; font-weight:700; font-size:.78rem; }
.cpl-chat-id b { font-family:var(--font-display); font-size:1.02rem; display:block; }
.cpl-chat-id small { font-size:.74rem; color:var(--on-dark-2); display:flex; align-items:center; gap:6px; margin-top:1px; }
.cpl-dot { width:7px; height:7px; border-radius:50%; background:var(--lime-500); box-shadow:0 0 0 0 rgba(183,224,78,.6); animation:cpl-pulse 2s infinite; }
@keyframes cpl-pulse { 0%{box-shadow:0 0 0 0 rgba(183,224,78,.5);} 70%{box-shadow:0 0 0 6px rgba(183,224,78,0);} 100%{box-shadow:0 0 0 0 rgba(183,224,78,0);} }
.cpl-chat-close { background:none; border:none; color:var(--on-dark); font-size:1.6rem; cursor:pointer; line-height:1; }
.cpl-chat-close:hover { color:#fff; }
.cpl-chat-body { flex:1; overflow-y:auto; padding:18px; display:flex; flex-direction:column; gap:10px; background:var(--cream-2); }
.cpl-msg { max-width:84%; padding:11px 14px; border-radius:14px; font-size:.9rem; line-height:1.5; }
.cpl-msg.bot { background:#fff; border:1px solid var(--border); color:var(--ink-2); align-self:flex-start; border-bottom-left-radius:5px; }
.cpl-msg.user { background:var(--ink); color:var(--cream); align-self:flex-end; border-bottom-right-radius:5px; }
.cpl-typing { display:flex; gap:4px; align-items:center; }
.cpl-typing span { width:7px; height:7px; border-radius:50%; background:var(--muted); animation:cpl-bounce 1.2s infinite; }
.cpl-typing span:nth-child(2){animation-delay:.15s;} .cpl-typing span:nth-child(3){animation-delay:.3s;}
@keyframes cpl-bounce { 0%,60%,100%{transform:translateY(0);opacity:.4;} 30%{transform:translateY(-5px);opacity:1;} }
.cpl-chat-chips { display:flex; flex-wrap:wrap; gap:7px; padding:0 14px 4px; background:var(--cream-2); }
.cpl-chat-chips:empty { display:none; }
.cpl-chip { background:#fff; border:1px solid var(--border-strong); color:var(--teal-700); font-family:var(--font-body); font-size:.8rem; font-weight:500; padding:7px 12px; border-radius:999px; cursor:pointer; transition:.15s; }
.cpl-chip:hover { background:var(--ink); color:var(--lime-500); border-color:var(--ink); }
.cpl-chat-input { display:flex; gap:8px; padding:12px 14px; border-top:1px solid var(--border); background:var(--cream); }
.cpl-chat-input input { flex:1; padding:11px 15px; border-radius:999px; border:1.5px solid var(--border-strong); background:#fff; font-family:var(--font-body); font-size:.9rem; color:var(--ink); }
.cpl-chat-input input:focus { outline:none; border-color:var(--teal-500); }
.cpl-chat-input button { width:42px; height:42px; flex-shrink:0; border-radius:50%; border:none; background:var(--lime-500); color:var(--ink); font-size:1.1rem; font-weight:700; cursor:pointer; transition:.15s; }
.cpl-chat-input button:hover { background:var(--lime-400); }
.cpl-chat-foot { font-size:.72rem; color:var(--muted); text-align:center; padding:8px 14px 11px; background:var(--cream); }
@media (max-width:560px) {
  .cpl-fab { bottom:16px; right:16px; }
  .cpl-chat { bottom:0; right:0; width:100vw; height:100vh; border-radius:0; }
}

/* ═══════════════════════════════════════════════════════════════════
   CASE PREVIEW PAGE
   ═══════════════════════════════════════════════════════════════════ */
.cp-hero { padding:40px 0 0; }
.cp-hero-panel { background:var(--ink); color:var(--on-dark); border-radius:var(--r-xl) var(--r-xl) 0 0; padding:48px 56px 56px; position:relative; overflow:hidden; }
.cp-hero-panel::before { content:""; position:absolute; top:-160px; right:-100px; width:440px; height:440px; border-radius:50%; background:radial-gradient(circle,var(--teal-600) 0%,transparent 68%); opacity:.3; }
.cp-breadcrumb { position:relative; z-index:2; font-size:.82rem; color:var(--on-dark-2); margin-bottom:22px; }
.cp-breadcrumb a { color:var(--on-dark); }
.cp-breadcrumb a:hover { color:var(--lime-400); }
.cp-eyebrow { position:relative; z-index:2; display:flex; align-items:center; gap:12px; flex-wrap:wrap; margin-bottom:14px; }
.cp-eyebrow .course { font-size:.74rem; font-weight:700; letter-spacing:.07em; text-transform:uppercase; color:var(--lime-400); }
.cp-badge { display:inline-flex; align-items:center; gap:6px; padding:4px 12px; border-radius:999px; font-size:.72rem; font-weight:700; letter-spacing:.02em; background:var(--lime-500); color:var(--ink); }
.cp-hero h1 { position:relative; z-index:2; color:var(--cream); font-size:clamp(2rem,4vw,3rem); margin:0 0 12px; max-width:18ch; }
.cp-cc { position:relative; z-index:2; font-family:var(--font-display); font-style:italic; font-size:1.25rem; color:var(--on-dark); margin:0 0 26px; }
.cp-meta { position:relative; z-index:2; display:flex; gap:30px; flex-wrap:wrap; padding-top:24px; border-top:1px solid var(--on-dark-line); }
.cp-meta .m { font-size:.82rem; color:var(--on-dark-2); }
.cp-meta .m b { display:block; color:var(--cream); font-size:.98rem; font-weight:600; margin-top:3px; }

.cp-body { padding:48px 0 88px; }
.cp-grid { display:grid; grid-template-columns:1fr 340px; gap:40px; align-items:start; }

.panel { background:#fff; border:1px solid var(--border); border-radius:var(--r-lg); padding:28px; margin-bottom:20px; }
.panel h3 { font-size:1.2rem; margin:0 0 14px; }
.panel-eyebrow { font-size:.72rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--teal-700); margin-bottom:6px; }

.dx-final { font-family:var(--font-display); font-size:1.5rem; color:var(--teal-800); margin:0; font-weight:600; }
.dx-row { display:flex; gap:20px; flex-wrap:wrap; }
.dx-row > div { flex:1; min-width:200px; }

.guide-contents { display:grid; grid-template-columns:1fr 1fr; gap:10px 24px; margin:0; padding:0; list-style:none; }
.guide-contents li { display:flex; gap:10px; align-items:flex-start; font-size:.92rem; color:var(--ink-2); line-height:1.4; }
.guide-contents li::before { content:"✓"; color:var(--teal-600); font-weight:700; flex-shrink:0; }
.guide-contents b { color:var(--ink); }
.guide-stats { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:20px; }
.gstat { flex:1; min-width:90px; background:var(--cream-2); border:1px solid var(--border); border-radius:var(--r); padding:14px 16px; text-align:center; }
.gstat b { display:block; font-family:var(--font-display); font-size:1.7rem; color:var(--ink); font-weight:600; line-height:1; }
.gstat span { font-size:.74rem; color:var(--muted); text-transform:uppercase; letter-spacing:.04em; }

/* scoring traps — the decoded device */
.trap { background:var(--warm-bg); border:1px solid var(--warm-border); border-left:4px solid var(--trap-amber); border-radius:var(--r); padding:15px 18px; margin-bottom:12px; display:flex; gap:13px; align-items:flex-start; }
.trap-ico { color:var(--trap-amber); font-weight:700; font-size:1rem; flex-shrink:0; line-height:1.4; }
.trap-body { font-size:.92rem; color:var(--ink-2); line-height:1.45; }
.trap-body b { color:var(--trap-amber); }

/* guide preview — 15% visible */
.guide-doc-wrap { position:relative; border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--border); background:var(--cream-2); }
.guide-doc { background:#fff; padding:38px 40px; font-size:.84rem; color:var(--ink-2); }
.gd-head { display:flex; justify-content:space-between; align-items:baseline; border-bottom:2px solid var(--ink); padding-bottom:12px; margin-bottom:18px; }
.gd-title { font-family:var(--font-display); font-size:1.15rem; color:var(--ink); font-weight:600; }
.gd-page { font-size:.72rem; color:var(--muted); letter-spacing:.04em; }
.gd-h { font-family:var(--font-display); font-size:1rem; color:var(--teal-800); font-weight:600; margin:0 0 10px; }
.gd-qa { margin-bottom:14px; }
.gd-q { font-weight:600; color:var(--ink); }
.gd-a { color:var(--muted); font-style:italic; }
.gd-line { height:9px; border-radius:3px; background:var(--cream-3); margin-bottom:8px; }
.guide-doc-fade { position:absolute; left:0; right:0; bottom:0; height:62%; background:linear-gradient(to bottom, rgba(255,255,255,0) 0%, rgba(255,255,255,.7) 28%, var(--cream-2) 70%); backdrop-filter:blur(2px); display:flex; flex-direction:column; align-items:center; justify-content:flex-end; text-align:center; padding:0 26px 28px; }
.guide-doc-fade .lock-ico { width:46px; height:46px; border-radius:50%; background:var(--ink); color:var(--lime-500); display:flex; align-items:center; justify-content:center; font-size:1.2rem; margin-bottom:14px; }
.guide-doc-fade h4 { font-size:1.25rem; margin:0 0 8px; }
.guide-doc-fade p { font-size:.9rem; color:var(--muted); max-width:42ch; margin:0 0 18px; }
.preview-tag { position:absolute; top:14px; left:14px; z-index:3; background:var(--ink); color:var(--lime-400); font-size:.68rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; padding:5px 12px; border-radius:999px; }

.alias-chips { display:flex; flex-wrap:wrap; gap:8px; margin:6px 0 12px; }

/* real-image guide preview gallery */
.gallery { display:flex; gap:14px; overflow-x:auto; padding:4px 4px 12px; scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch; }
.gpage { flex:0 0 auto; width:172px; scroll-snap-align:start; }
.gpage-frame { position:relative; aspect-ratio:8.5/11; border:1px solid var(--border); border-radius:10px; overflow:hidden; background:#fff; box-shadow:var(--sh-sm); transition:transform .18s, box-shadow .18s; }
.gpage-frame img { width:100%; height:100%; object-fit:cover; object-position:top center; }
.gpage.clear .gpage-frame { cursor:zoom-in; }
.gpage.clear:hover .gpage-frame { transform:translateY(-3px); box-shadow:var(--sh); }
.gpage-tag { position:absolute; top:8px; left:8px; z-index:2; font-size:.62rem; font-weight:700; letter-spacing:.05em; text-transform:uppercase; padding:3px 8px; border-radius:999px; }
.gpage-tag.sample { background:var(--lime-500); color:var(--ink); }
.gpage-tag.locked { background:rgba(11,31,27,.82); color:var(--cream); }
.gpage.locked .gpage-frame::after { content:"🔒"; position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-size:1.5rem; background:rgba(244,239,226,.35); }
.gpage-label { font-size:.74rem; color:var(--muted); margin-top:8px; line-height:1.35; text-align:center; }
.gpage-label b { display:block; color:var(--ink); font-weight:600; }
.unlock-bar { display:flex; align-items:center; justify-content:space-between; gap:18px; flex-wrap:wrap; background:var(--ink); border-radius:var(--r); padding:18px 22px; margin-top:18px; }
.unlock-bar .ub-text { color:var(--cream); font-size:.95rem; }
.unlock-bar .ub-text b { font-family:var(--font-display); font-weight:600; }
.unlock-bar .ub-text small { display:block; color:var(--on-dark-2); font-size:.8rem; margin-top:2px; }

/* lightbox */
.lightbox { position:fixed; inset:0; z-index:1500; background:rgba(11,31,27,.86); backdrop-filter:blur(6px); display:none; align-items:center; justify-content:center; padding:32px; }
.lightbox.open { display:flex; }
.lightbox img { max-width:min(680px,92vw); max-height:90vh; border-radius:8px; box-shadow:var(--sh-lg); }
.lightbox-close { position:absolute; top:20px; right:24px; background:none; border:none; color:var(--cream); font-size:2rem; cursor:pointer; line-height:1; }

.alias-chips-spacer { display:none; }

/* about / mission */
.mission-quote { font-family:var(--font-display); font-size:clamp(1.6rem,3.4vw,2.5rem); line-height:1.3; color:var(--ink); font-weight:500; max-width:20ch; letter-spacing:-.01em; }
.mission-quote .hl { color:var(--teal-700); font-style:italic; font-weight:400; }
.statband { background:var(--ink); border-radius:var(--r-xl); padding:48px 44px; display:grid; grid-template-columns:repeat(4,1fr); gap:32px; position:relative; overflow:hidden; }
.statband::before { content:""; position:absolute; bottom:-160px; right:-100px; width:420px; height:420px; border-radius:50%; background:radial-gradient(circle,var(--teal-600) 0%,transparent 70%); opacity:.28; }
.statband .sb { position:relative; z-index:2; }
.statband .sb b { display:block; font-family:var(--font-display); font-size:clamp(2.2rem,4vw,3rem); color:var(--lime-400); font-weight:600; line-height:1; }
.statband .sb span { display:block; font-size:.86rem; color:var(--on-dark); margin-top:8px; line-height:1.4; }
.principle { display:flex; gap:16px; align-items:flex-start; }
.principle .pi { width:40px; height:40px; border-radius:10px; background:var(--cream-2); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; font-size:1.1rem; flex-shrink:0; }
.principle h4 { font-size:1.1rem; margin:4px 0 6px; }
.principle p { color:var(--muted); font-size:.94rem; margin:0; line-height:1.55; }
@media (max-width:760px) { .statband { grid-template-columns:1fr 1fr; gap:24px; padding:34px 26px; } }
@media (max-width:720px) { .about-split { grid-template-columns:1fr !important; gap:24px !important; } .about-principles { grid-template-columns:1fr !important; } }

/* FAQ accordion */
.faq-list { border-top:1px solid var(--border); }
.faq-item { border-bottom:1px solid var(--border); }
.faq-item summary { padding:22px 0; font-family:var(--font-display); font-weight:600; font-size:1.12rem; color:var(--ink); cursor:pointer; list-style:none; display:flex; align-items:center; justify-content:space-between; gap:18px; }
.faq-item summary::-webkit-details-marker { display:none; }
.faq-item summary::after { content:"+"; font-size:1.5rem; color:var(--teal-700); transition:transform .2s; flex-shrink:0; line-height:1; }
.faq-item[open] summary::after { transform:rotate(45deg); }
.faq-item-body { padding:0 0 22px; color:var(--ink-2); font-size:.98rem; line-height:1.7; max-width:68ch; }

/* prose (legal) */
.prose { max-width:720px; }
.prose h2 { font-size:1.4rem; margin:32px 0 12px; }
.prose h2:first-child { margin-top:0; }
.prose p, .prose li { color:var(--ink-2); font-size:.98rem; line-height:1.7; }
.prose ul { padding-left:20px; }
.prose li { margin-bottom:8px; }
.prose .updated { color:var(--muted); font-size:.86rem; margin-bottom:28px; }

/* status pages (confirm / thank-you) */
.status-page { min-height:62vh; display:flex; align-items:center; justify-content:center; padding:60px 0; }
.status-card { max-width:560px; text-align:center; background:#fff; border:1px solid var(--border); border-radius:var(--r-xl); padding:48px 40px; box-shadow:var(--sh); }
.status-badge { width:64px; height:64px; border-radius:50%; background:var(--lime-500); color:var(--ink); display:flex; align-items:center; justify-content:center; font-size:1.7rem; margin:0 auto 20px; }
.status-card h1 { font-size:clamp(1.8rem,3.5vw,2.4rem); margin:0 0 12px; }
.status-card p { color:var(--muted); font-size:1.02rem; max-width:46ch; margin:0 auto 14px; }
.status-card .status-ctas { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin-top:24px; }
@media (max-width:540px) { .status-card { padding:36px 24px; } }

/* sample-guide anatomy */
.anatomy-row { display:grid; grid-template-columns:300px 1fr; gap:40px; align-items:center; padding:40px 0; border-top:1px solid var(--border); }
.anatomy-row:nth-child(even) .anatomy-img { order:2; }
.anatomy-img { position:relative; }
.anatomy-img .a-frame { aspect-ratio:8.5/11; border:1px solid var(--border); border-radius:var(--r); overflow:hidden; background:#fff; box-shadow:var(--sh); cursor:zoom-in; transition:transform .18s; }
.anatomy-img .a-frame:hover { transform:translateY(-3px); }
.anatomy-img .a-frame img { width:100%; height:100%; object-fit:cover; object-position:top center; }
.anatomy-img .a-page { position:absolute; top:10px; left:10px; background:var(--ink); color:var(--lime-400); font-size:.66rem; font-weight:700; letter-spacing:.05em; text-transform:uppercase; padding:4px 10px; border-radius:999px; }
.anatomy-num { font-family:var(--font-display); font-size:.95rem; color:var(--teal-700); font-weight:600; }
.anatomy-text h3 { font-size:1.45rem; margin:6px 0 10px; }
.anatomy-text p { color:var(--ink-2); font-size:.98rem; line-height:1.6; margin:0 0 14px; }
.anatomy-scores { display:flex; gap:8px; flex-wrap:wrap; }
.anatomy-scores .as { background:var(--cream-2); border:1px solid var(--border); border-radius:999px; padding:5px 13px; font-size:.8rem; color:var(--teal-800); font-weight:600; }
@media (max-width:760px) {
  .anatomy-row { grid-template-columns:1fr; gap:22px; padding:30px 0; }
  .anatomy-row:nth-child(even) .anatomy-img { order:0; }
  .anatomy-img { max-width:240px; }
}
.alias-chip { background:var(--cream-2); border:1px solid var(--border); color:var(--teal-800); font-size:.8rem; font-weight:600; padding:5px 12px; border-radius:999px; }

/* sticky order card */
.order-card { position:sticky; top:88px; background:var(--ink); color:var(--on-dark); border-radius:var(--r-lg); padding:26px; overflow:hidden; }
.order-card::before { content:""; position:absolute; top:-90px; right:-60px; width:240px; height:240px; border-radius:50%; background:radial-gradient(circle,var(--teal-600) 0%,transparent 70%); opacity:.28; }
.order-card-inner { position:relative; z-index:2; }
.order-eyebrow { font-size:.7rem; font-weight:700; letter-spacing:.07em; text-transform:uppercase; color:var(--lime-400); }
.order-card h4 { color:var(--cream); font-size:1.15rem; margin:6px 0 4px; }
.order-price { font-family:var(--font-display); font-size:2.6rem; color:var(--cream); font-weight:600; line-height:1; margin:8px 0 2px; }
.order-price .cur { font-size:1.1rem; vertical-align:top; color:var(--on-dark-2); }
.order-card .sub { font-size:.84rem; color:var(--on-dark); margin:8px 0 18px; }
.order-card .btn { width:100%; }
.order-card .btn + .btn { margin-top:9px; }
.order-incl { list-style:none; padding:0; margin:18px 0 0; border-top:1px solid var(--on-dark-line); padding-top:16px; }
.order-incl li { font-size:.84rem; color:var(--on-dark); display:flex; gap:9px; margin-bottom:8px; }
.order-incl li::before { content:"✓"; color:var(--lime-400); font-weight:700; }
.order-code { margin-top:16px; font-size:.78rem; color:var(--on-dark-2); text-align:center; }
.order-code strong { color:var(--lime-400); }

.side-free { background:var(--warm-bg); border:1px solid var(--border); border-radius:var(--r-lg); padding:22px; margin-top:18px; }
.side-free .panel-eyebrow { margin-bottom:4px; }
.side-free h4 { font-size:1.05rem; margin:0 0 6px; }
.side-free p { font-size:.86rem; color:var(--muted); margin:0 0 12px; }

@media (max-width:920px) {
  .cp-grid { grid-template-columns:1fr; }
  .order-card { position:static; }
  .cp-hero-panel { padding:36px 30px 40px; }
  .guide-contents { grid-template-columns:1fr; }
}
@media (max-width:560px) {
  .cp-hero { padding:20px 0 0; }
  .cp-hero-panel { padding:28px 22px 32px; border-radius:var(--r-lg) var(--r-lg) 0 0; }
  .cp-meta { gap:18px; }
  .guide-doc { padding:24px 22px; }
  .dx-row { gap:14px; }
}

/* ═══ reveal (fail-safe: hidden state only applies when html.js is set) ═══ */
.js [data-reveal] { opacity:0; transform:translateY(16px); transition:opacity .7s cubic-bezier(.16,.84,.44,1), transform .7s cubic-bezier(.16,.84,.44,1); }
.js [data-reveal].is-revealed { opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce) { .js [data-reveal]{opacity:1;transform:none;transition:none;} .rubric-row.locked .rubric-text,.rubric-row.locked .rubric-pts{filter:none;} }

/* ═══ RESPONSIVE ═══ */
@media (max-width:920px) {
  .hero-panel { grid-template-columns:1fr; gap:36px; padding:44px 36px; }
  .steps { grid-template-columns:1fr; }
  .pricing-grid { grid-template-columns:1fr; }
}
@media (max-width:560px) {
  .section { padding:60px 0; }
  .hero { padding:20px 0 8px; }
  .hero-panel { padding:34px 22px; border-radius:var(--r-lg); }
  .hero-trust { gap:22px; }
  .footer-inner { grid-template-columns:1fr 1fr; }
  .footer-inner > div:first-child { grid-column:span 2; }
  .capture-row .btn { width:100%; }
  .section-head { margin-bottom:28px; }
}
