/* ════════════════════════════════════════════════════════════
   PIPTHEORY — "Soft Studio Desk"
   Warm light surfaces, rounded cards on a tinted backdrop, pill
   controls with an ink active state, big friendly display type,
   separation by whitespace + shadow instead of hairline grids.
   Dark theme inherits the same geometry via tokens.
   ════════════════════════════════════════════════════════════ */

body.cs-page{--brand:var(--display);--ease-out:cubic-bezier(.16,1,.3,1);background:var(--bg-0)}
/* Whisper of warmth at the top of the page (light theme only) */
body.cs-page::before{content:'';position:absolute;left:0;right:0;top:0;height:520px;pointer-events:none;z-index:0;
  background:radial-gradient(640px 340px at 12% -10%, rgba(255,150,80,.10), transparent 70%),
             radial-gradient(640px 340px at 88% -10%, rgba(90,140,255,.08), transparent 70%)}
[data-theme="dark"] body.cs-page::before,[data-theme="dark"].cs-page::before{display:none}
.cs-main{position:relative;z-index:1;max-width:1440px;margin:0 auto;padding:30px 28px 90px}

.pos{color:var(--bull-bright,var(--bull))}
.neg{color:var(--bear-bright,var(--bear))}
body.cs-page ::selection{background:var(--ink);color:var(--on-ink)}
body.cs-page a:focus-visible,body.cs-page button:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:6px}

/* ── TOPBAR ─────────────────────────────────────────────── */
body.cs-page .tv-topbar{height:62px;padding:0 max(28px, calc((100% - 1440px) / 2 + 28px));
  background:color-mix(in srgb, var(--bg-1) 88%, transparent);backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}
.dk-nav{display:flex;gap:2px;margin-left:14px}
.dk-nav-a{padding:8px 15px;border-radius:var(--radius-pill);font-size:13.5px;font-weight:600;color:var(--text-dim);transition:background .15s,color .15s}
.dk-nav-a:hover{background:var(--bg-2);color:var(--text);text-decoration:none}
.dk-nav-a.active{background:var(--ink);color:var(--on-ink)}
.tv-sync-dot,.cs-sync-m .cs-sync-dot{animation:csPulse 2.6s infinite}
.cs-nav{font-size:13px;color:var(--text-dim);font-weight:600}
.cs-nav:hover{color:var(--text);text-decoration:none}

/* ── HERO — a clean stack: kicker, question, one line, the read ── */
.dk-hero{margin:30px 0 0;display:flex;flex-direction:column;align-items:flex-start;gap:18px}
.cs-takeaway{width:100%;margin-top:4px}
.cs-kicker{display:inline-flex;align-items:center;gap:9px;padding:8px 16px;border-radius:var(--radius-pill);
  background:var(--bg-1);box-shadow:var(--shadow-card);font-family:var(--mono);font-size:10px;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;color:var(--text-dim)}
.cs-kicker::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--bull);animation:csPulse 2.6s infinite}
.dk-h1{font-family:var(--display);font-size:clamp(32px,4.4vw,54px);font-weight:700;letter-spacing:-.035em;line-height:1.04;color:var(--text)}
.dk-sub{font-size:16px;line-height:1.7;color:var(--text-dim);max-width:none;width:100%}
.dk-sub strong{color:var(--text);font-weight:700}
.cs-takeaway{font-size:13.5px;line-height:1.65;color:var(--text);background:var(--bg-1);box-shadow:var(--shadow-card);
  border-radius:var(--radius-s);padding:14px 18px}
.cs-takeaway strong{font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  color:var(--text-faint);margin-right:10px}

/* ── THE METER (full-width hero card) ───────────────────── */
.cs-meter{margin:0}
.cs-meter.hero{background:var(--bg-1);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:20px 22px 14px;margin:26px 0 0}
.cs-meter.hero .cs-row{grid-template-columns:26px 56px 230px 1fr 72px 24px 28px}
.cs-meter.hero .cs-block-head{border:none;padding:0 6px 14px;margin:0}
.cs-meter.hero .cs-block-head h2{font-size:17px}
.cs-bars{display:flex;flex-direction:column;gap:4px}
.cs-item{border:none;background:none}
.cs-row{display:grid;grid-template-columns:22px 48px minmax(70px,1fr) minmax(130px,2.2fr) 60px 22px 26px;
  align-items:center;gap:10px;width:100%;text-align:left;padding:10px 12px;cursor:pointer;border-radius:14px;
  background:transparent;transition:background .15s}
.cs-row:hover{background:var(--bg-2)}
.cs-rank{font-family:var(--mono);font-size:11px;color:var(--text-faint);text-align:center}
.cs-code{font-family:var(--display);font-size:14px;font-weight:800;letter-spacing:.02em;text-align:left}
.cs-name{font-size:13px;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cs-coverage{font-size:10px;color:var(--text-faint);font-family:var(--mono);white-space:nowrap}
.cs-coverage-partial{color:var(--amber);font-weight:600}
.cs-bar-track{position:relative;height:16px;background:var(--bg-3);border-radius:var(--radius-pill);display:block;width:100%}
.cs-bar-zero{position:absolute;left:50%;top:-3px;bottom:-3px;width:2px;border-radius:2px;background:var(--text);opacity:.4;z-index:2;transform:translateX(-1px)}
.cs-bar-fill{position:absolute;top:0;bottom:0;border-radius:0}
.cs-bar-fill.pos{background:var(--bull)}
.cs-bar-fill.neg{background:var(--bear)}
.cs-score{font-family:var(--display);font-size:15.5px;font-weight:800;text-align:right;font-variant-numeric:tabular-nums}
.cs-pill{font-size:11px;text-align:center}
.cs-pill.cs-strengthening{color:var(--bull-bright,var(--bull))}
.cs-pill.cs-weakening{color:var(--bear-bright,var(--bear))}
.cs-pill.cs-stable,.cs-pill.cs-new{color:var(--text-faint)}
.cs-chev{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;
  color:var(--text-faint);background:var(--bg-2);transition:all .2s;flex-shrink:0}
.cs-row:hover .cs-chev{background:var(--ink);color:var(--on-ink)}
.cs-meter-foot{padding:12px 6px 4px;font-size:12px;color:var(--text-faint);text-align:center}

/* ── SECTIONS — clear chapters, working spacing ─────────── */
.cs-block{margin:56px 0}
.cs-block-head{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:22px}
.cs-block-head h2{font-family:var(--display);font-size:25px;font-weight:800;letter-spacing:-.025em}
.cs-sub{font-size:13px;color:var(--text-faint);line-height:1.5}
.cs-viewall{font-weight:700;color:var(--text);white-space:nowrap;font-size:13px}
.cs-viewall:hover{color:var(--accent);text-decoration:none}
.cs-lead{font-size:15px;line-height:1.65;color:var(--text-dim)}
.cs-lead strong{color:var(--text)}
.cs-lead-after{margin:36px auto 0;max-width:860px;text-align:left}

/* info "?" tooltips */
.cs-info{display:inline-flex;align-items:center;justify-content:center;width:17px;height:17px;margin-left:7px;
  border:none;border-radius:50%;background:var(--bg-3);color:var(--text-dim);
  font-family:var(--mono);font-size:10px;font-weight:600;line-height:1;cursor:help;vertical-align:middle;
  position:relative;transition:background .15s,color .15s;flex-shrink:0;padding:0}
.cs-info:hover,.cs-info.open{background:var(--ink);color:var(--on-ink)}
.dk-h1 .cs-info,.cs-h1 .cs-info{width:20px;height:20px;font-size:11px;margin-left:10px;top:-3px}
.cs-info::after{content:attr(data-tip);position:absolute;top:calc(100% + 10px);left:0;
  width:min(300px,calc(100vw - 24px));background:var(--bg-1);border-radius:var(--radius-s);
  padding:11px 13px;font-family:var(--font);font-size:11.5px;font-weight:500;line-height:1.55;
  color:var(--text);text-align:left;letter-spacing:0;white-space:normal;z-index:60;
  box-shadow:var(--shadow-hover);display:none}
.cs-info:hover::after,.cs-info:focus-visible::after,.cs-info.open::after{display:block}
.cs-h1{font-family:var(--display);font-size:30px;font-weight:800;letter-spacing:-.03em;margin-bottom:12px;line-height:1.1}
.cs-h1-nb{white-space:nowrap}
.cs-sync-m{display:none}
.cs-sync-m .cs-sync-dot{width:7px;height:7px;border-radius:50%;background:var(--bull);flex-shrink:0;display:inline-block}

/* ── PILL CONTROL GROUPS ────────────────────────────────── */
.cs-range{display:inline-flex;gap:2px;padding:4px;border-radius:var(--radius-pill);background:var(--bg-1);box-shadow:var(--shadow-card)}
.cs-block .cs-chart-wrap .cs-range,.cs-duo-col .cs-range{box-shadow:none;background:var(--bg-2)}
.cs-range button{font-family:var(--font);font-size:11.5px;font-weight:700;color:var(--text-dim);
  padding:6px 12px;border-radius:var(--radius-pill);background:transparent;transition:all .15s}
.cs-range button:hover{color:var(--text)}
.cs-range button.active{background:var(--ink);color:var(--on-ink)}
.cs-range button.cs-dis,.cs-range button:disabled{opacity:.32;cursor:not-allowed;pointer-events:none}
.cs-ctrls{display:flex;align-items:center;gap:8px;flex-wrap:wrap;flex-shrink:0}
.cs-ctrl-div{width:1px;align-self:stretch;background:var(--border-2);margin:4px 0}
.cs-panel-ctrl{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:14px;min-height:32px}
.cs-panel-ctrl .cs-sub{line-height:1.5}
.cs-duo{display:grid;grid-template-columns:1fr;gap:20px;align-items:start}
.cs-duo.solo{grid-template-columns:1fr}
.cs-duo-cap{display:block;font-family:var(--font);font-size:11.5px;font-weight:500;letter-spacing:0;text-transform:none;color:var(--text-faint);margin-top:3px;font-style:normal}
.cs-duo-col{background:var(--bg-1);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:18px 18px 12px}
.cs-duo-t{font-family:var(--mono);font-size:10.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--text-dim)}
.cs-duo-note{font-size:12px;color:var(--text-faint);margin-top:14px;line-height:1.55}
.cs-divnote{margin-top:14px;font-size:13px;line-height:1.6;color:var(--text);background:var(--amber-bg);
  border-radius:var(--radius-s);padding:12px 16px}
.cs-divnote strong{font-weight:700}

/* ── CHARTS ─────────────────────────────────────────────── */
.cs-chart-wrap{display:flex;gap:0;align-items:stretch;background:transparent;border:none;border-radius:0;padding:6px 0 0;box-shadow:none}
.cs-block > .cs-chart-wrap{background:var(--bg-1);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:18px}
.cs-chart-yscale{display:flex;flex-direction:column;justify-content:space-between;padding:0 8px 16px 0;
  font-size:9px;font-family:var(--mono);color:var(--text-faint);min-width:32px;text-align:right}
.cs-chart-main{position:relative;flex:1;min-width:0}
.cs-chart{display:block;width:100%}
.cs-chart-tip{position:absolute;top:6px;pointer-events:none;display:none;background:var(--ink);color:var(--on-ink);
  border:none;border-radius:var(--radius-s);padding:9px 11px;font-size:11px;z-index:10;min-width:124px;box-shadow:var(--shadow-hover)}
.cs-tip-d{font-family:var(--mono);font-size:9px;opacity:.7;margin-bottom:5px}
.cs-tip-r{display:flex;align-items:center;gap:6px;line-height:1.6;white-space:nowrap}
.cs-tip-r b{margin-left:auto;font-family:var(--mono);font-weight:600}
.cs-legend{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}
.cs-leg{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;font-family:var(--font);
  padding:7px 13px;border:none;border-radius:var(--radius-pill);background:var(--bg-1);box-shadow:var(--shadow-card);
  color:var(--text);transition:opacity .15s,transform .15s}
.cs-leg:hover{transform:translateY(-1px)}
.cs-leg.off{opacity:.38;box-shadow:none;background:var(--bg-2)}
.cs-leg-dot{width:9px;height:9px;border-radius:50%;display:inline-block;flex-shrink:0}

/* ── HEATMAP ────────────────────────────────────────────── */
.cs-heatmap-wrap{overflow-x:auto;background:var(--bg-1);border:none;border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-card)}
.cs-hm{border-collapse:separate;border-spacing:3px;font-family:var(--mono);font-size:11px;width:100%;min-width:520px}
.cs-hm th{color:var(--text-dim);font-weight:700;padding:5px 6px;text-align:center}
.cs-hm td{text-align:center;padding:9px 4px;color:var(--text);font-weight:600;border:none;border-radius:8px}
.cs-hm-diag{background:var(--bg-2)!important}
.cs-hm td[data-href]{cursor:pointer;transition:transform .12s}
.cs-hm td[data-href]:hover{outline:2px solid var(--ink);outline-offset:-1px}

/* ── WIDEST GAPS ────────────────────────────────────────── */
.cs-gap-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;background:none;border:none}
.cs-gap{display:flex;flex-direction:column;gap:7px;background:var(--bg-1);border-radius:var(--radius);box-shadow:var(--shadow-card);
  padding:20px 22px;text-decoration:none;color:var(--text);transition:transform .18s var(--ease-out),box-shadow .18s}
.cs-gap:hover{transform:translateY(-3px);box-shadow:var(--shadow-hover);text-decoration:none}
.cs-gap-pair{font-family:var(--mono);font-size:13px;font-weight:700;letter-spacing:.05em;color:var(--text-dim)}
.cs-gap-diff{font-family:var(--display);font-size:30px;font-weight:800;line-height:1;letter-spacing:-.01em;font-variant-numeric:tabular-nums}
.cs-gap-note{font-size:12px;color:var(--text-dim)}
.cs-gap-cta{font-size:12.5px;font-weight:700;color:var(--text);margin-top:4px}
.cs-gap:hover .cs-gap-cta{color:var(--accent)}

/* ── DEEP DIVE (currency switcher) ──────────────────────── */
.dk-chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.dk-chip{font-family:var(--display);font-size:13px;font-weight:800;letter-spacing:.03em;padding:9px 18px;
  border-radius:var(--radius-pill);background:var(--bg-1);box-shadow:var(--shadow-card);color:var(--text-dim);
  transition:all .15s}
.dk-chip:hover{color:var(--text);transform:translateY(-1px)}
.dk-chip.active{background:var(--ink);color:var(--on-ink)}
.dk-panel{background:var(--bg-1);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:24px}
.dk-panel-head{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;margin-bottom:18px}
.dk-panel-name{font-family:var(--display);font-size:21px;font-weight:800;letter-spacing:-.02em}
.dk-panel-score{font-family:var(--display);font-size:21px;font-weight:800;font-variant-numeric:tabular-nums}
.dk-panel-meta{font-size:12px;color:var(--text-faint);font-weight:600}
.dk-panel-link{margin-left:auto;font-size:13px;font-weight:700;color:var(--text)}
.dk-panel-link:hover{color:var(--accent);text-decoration:none}
.cs-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-bottom:16px}
.cs-detail-h{font-size:10.5px;text-transform:uppercase;letter-spacing:.14em;color:var(--text-faint);margin-bottom:12px;font-weight:700;font-family:var(--mono)}
.cs-pl-row{display:grid;grid-template-columns:92px 1fr 38px;align-items:center;gap:10px;margin-bottom:9px}
.cs-pl-name{font-size:12.5px;color:var(--text-dim);font-weight:600}
.cs-pl-bar{position:relative;height:10px;background:var(--bg-3);border-radius:var(--radius-pill);overflow:hidden}
.cs-pl-zero{position:absolute;left:50%;top:-2px;bottom:-2px;width:2px;border-radius:2px;background:var(--text);opacity:.35;z-index:2;transform:translateX(-1px)}
.cs-pl-fill{position:absolute;top:0;bottom:0;border-radius:0}
.cs-pl-fill.pos{background:var(--bull)}
.cs-pl-fill.neg{background:var(--bear)}
.cs-pl-val{font-family:var(--font);font-size:12.5px;font-weight:800;text-align:right;font-variant-numeric:tabular-nums}
.cs-ind-row{display:flex;align-items:baseline;gap:8px;font-size:12.5px;padding:6px 0;border-bottom:1px solid var(--border)}
.cs-ind-row:last-child{border-bottom:none}
.cs-ind-l{color:var(--text-dim);font-weight:500}
.cs-ind-v{margin-left:auto;font-family:var(--mono);font-weight:600;color:var(--text)}
.cs-ind-a{font-size:9px;color:var(--text-faint);font-family:var(--mono)}
.cs-analysis{margin-top:6px}
.cs-analysis .cs-detail-h{margin-bottom:10px}
.cs-analysis-body{font-size:13.5px;line-height:1.75;color:var(--text);background:var(--bg-2);
  border-radius:var(--radius-s);padding:16px 20px}
.cs-explain-text{font-size:13.5px;line-height:1.7;color:var(--text);margin-top:14px}
.cs-blurb{font-size:14px;line-height:1.6;color:var(--text);background:var(--bg-2);border-radius:var(--radius-s);padding:12px 16px}
.cs-inline-pairs{margin-top:20px}
.cs-inline-pairs .cs-detail-h{margin-bottom:10px}
.cs-ipairs-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;background:none;border:none}
.cs-ipair{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 16px;background:var(--bg-2);
  border-radius:var(--radius-s);font-size:13px;text-decoration:none;color:var(--text);transition:background .12s}
.cs-ipair:hover{background:var(--bg-3);text-decoration:none}
.cs-ipair-lbl{font-family:var(--mono);font-weight:700;font-size:12.5px;letter-spacing:.04em}
.cs-ipair-diff{font-weight:800;font-size:14px;font-variant-numeric:tabular-nums}
@media(max-width:900px){.cs-ipairs-grid{grid-template-columns:repeat(2,1fr)}}
.cs-fulllink{display:inline-block;margin-top:16px;font-size:13px;font-weight:700;color:var(--text)}
.cs-fulllink:hover{color:var(--accent);text-decoration:none}

/* ── HOW IT WORKS ───────────────────────────────────────── */
.cs-pillars-intro{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;background:none;border:none;margin-bottom:20px}
.cs-pintro{background:var(--bg-1);border-radius:var(--radius-s);box-shadow:var(--shadow-card);padding:16px;display:flex;
  flex-direction:column;gap:6px;transition:transform .18s var(--ease-out),box-shadow .18s;position:relative;overflow:hidden}
.cs-pintro:hover{transform:translateY(-3px);box-shadow:var(--shadow-hover)}
.cs-pintro-num{font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.1em;color:var(--accent)}
.cs-pintro-h{font-family:var(--display);font-size:13.5px;font-weight:800;letter-spacing:-.01em;color:var(--text)}
.cs-pintro-d{font-size:11.5px;color:var(--text-faint);line-height:1.45}
.cs-howto{font-size:13.5px;color:var(--text-dim);line-height:1.65;max-width:760px}
.cs-howto strong{font-weight:700}
.cs-howto em{font-style:normal;font-weight:600;color:var(--text)}

/* ── EMBED ──────────────────────────────────────────────── */
.cs-embed{background:var(--bg-1);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:22px 22px 20px}
.cs-embed .cs-block-head{margin-bottom:12px}
.cs-embed .cs-block-head h2{font-size:17px}
.cs-embed-row{display:flex;gap:8px;align-items:stretch}
.cs-embed-code{flex:1;min-width:0;font-family:var(--mono);font-size:11px;padding:11px 13px;border:1px solid var(--border-2);
  border-radius:var(--radius-s);background:var(--bg-2);color:var(--text-dim)}
.cs-embed-btn{flex-shrink:0;padding:0 20px;border:none;border-radius:var(--radius-s);background:var(--ink);color:var(--on-ink);
  font-weight:700;font-size:12.5px;cursor:pointer;transition:opacity .15s}
.cs-embed-btn:hover{opacity:.85}

/* ── RESEARCH CARDS ─────────────────────────────────────── */
.cs-recent-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.ri-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:26px}
.ri-chip{display:inline-flex;align-items:center;gap:5px;padding:8px 16px;border-radius:var(--radius-pill);border:none;
  background:var(--bg-1);box-shadow:var(--shadow-card);font-family:var(--font);font-size:13px;font-weight:700;
  color:var(--text-dim);cursor:pointer;transition:all .15s;white-space:nowrap}
.ri-chip:hover{color:var(--text);transform:translateY(-1px)}
.ri-chip.active{background:var(--ink);color:var(--on-ink)}
.ri-chip-n{font-family:var(--mono);font-size:11px;font-weight:400;opacity:.7}
.ri-chip.active .ri-chip-n{opacity:1}
.ri-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;max-width:960px}
.ri-card{display:flex;flex-direction:column;background:var(--bg-1);border:none;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-card);transition:transform .18s var(--ease-out),box-shadow .18s}
.ri-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-hover);text-decoration:none}
.ri-card-accent{height:5px;flex-shrink:0}
.ri-cat-fundamentals{--cat-color:#2563EB}
.ri-cat-currencies{--cat-color:#0D9488}
.ri-cat-history{--cat-color:#B45309}
.ri-cat-strategy{--cat-color:#475569}
[data-theme="dark"] .ri-cat-fundamentals{--cat-color:#7AA5FF}
[data-theme="dark"] .ri-cat-currencies{--cat-color:#3FC1B0}
[data-theme="dark"] .ri-cat-history{--cat-color:#E8A04C}
[data-theme="dark"] .ri-cat-strategy{--cat-color:#9FB0C7}
.ri-card-accent{background:var(--cat-color)}
.ri-card-body{padding:18px 20px 20px;display:flex;flex-direction:column;flex:1}
.ri-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.ri-badge{font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  padding:4px 10px;border-radius:var(--radius-pill);color:var(--cat-color)}
.ri-badge{background:color-mix(in srgb,var(--cat-color) 10%,transparent)}
.ri-date{font-family:var(--mono);font-size:11px;color:var(--text-faint);letter-spacing:.04em}
.ri-title{font-family:var(--display);font-size:16.5px;font-weight:800;color:var(--text);line-height:1.35;letter-spacing:-.015em;margin-bottom:8px}
.ri-sum{font-size:13px;color:var(--text-dim);line-height:1.55;flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.ri-read{font-size:12.5px;font-weight:700;color:var(--text);margin-top:14px}
.ri-card:hover .ri-read{color:var(--accent)}

/* ── FOLLOW CTA ─────────────────────────────────────────── */
.cs-follow{border:none!important;margin:64px 0}
.cs-follow-inner{display:flex;justify-content:center;padding:6px 0}
.cs-follow-link{display:inline-flex;align-items:center;gap:10px;padding:14px 30px;border:none;border-radius:var(--radius-pill);
  background:var(--bg-1);box-shadow:var(--shadow-card);font-size:14px;color:var(--text-dim);transition:all .2s}
.cs-follow-link:hover{color:#E1306C;text-decoration:none;transform:translateY(-2px);box-shadow:var(--shadow-hover)}
.cs-follow-link strong{color:var(--text);font-weight:800}
.cs-follow-link:hover strong{color:#E1306C}
.cs-follow-link svg{flex-shrink:0}

/* ── PROSE / LEGAL / POSTS ──────────────────────────────── */
.cs-prose{max-width:740px;font-size:15px;line-height:1.8;color:var(--text-dim)}
.cs-prose h1{font-family:var(--display);font-size:clamp(28px,3.6vw,38px);font-weight:800;letter-spacing:-.03em;line-height:1.12;color:var(--text);margin-bottom:18px}
.cs-prose h2{font-family:var(--display);font-size:20px;font-weight:800;letter-spacing:-.015em;color:var(--text);margin:32px 0 10px}
.cs-prose h3{font-size:15px;font-weight:700;color:var(--text);margin:22px 0 8px}
.cs-prose p{margin-bottom:14px}
.cs-prose strong{color:var(--text);font-weight:700}
.cs-prose ul,.cs-prose ol{margin:0 0 14px 20px}
.cs-prose li{margin-bottom:6px}
.cs-prose a{color:var(--accent)}
.cs-prose em{color:var(--text-faint)}
.cs-prose code{font-family:var(--mono);font-size:13px;background:var(--bg-2);padding:2px 6px;border-radius:6px}
.cs-post-list{display:flex;flex-direction:column;gap:10px;background:none;border:none;max-width:820px}
.cs-post{display:block;background:var(--bg-1);border-radius:var(--radius-s);box-shadow:var(--shadow-card);padding:18px 22px;
  transition:transform .15s var(--ease-out),box-shadow .15s}
.cs-post:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover);text-decoration:none}
.cs-post-date{font-family:var(--mono);font-size:11px;color:var(--text-faint);letter-spacing:.04em}
.cs-post-title{font-family:var(--display);font-size:16.5px;font-weight:800;color:var(--text);margin:4px 0 6px;letter-spacing:-.015em}
.cs-post-sum{font-size:13px;color:var(--text-dim);line-height:1.5}
.cs-post-back{display:inline-block;margin-bottom:16px;font-size:12.5px;font-weight:700;color:var(--text-dim)}
.cs-post-back:hover{color:var(--text);text-decoration:none}
.cs-post-meta{font-family:var(--mono);font-size:11px;color:var(--text-faint);margin-bottom:20px;letter-spacing:.04em}

/* ── CURRENCY + PAIR PAGES ──────────────────────────────── */
.cs-breadcrumb{display:inline-block;font-size:12.5px;color:var(--text-dim);margin-bottom:16px;font-weight:600}
.cs-breadcrumb:hover{color:var(--text);text-decoration:none}
.cs-hero{display:flex;align-items:center;gap:18px;margin-bottom:18px}
.cs-hero-code{font-family:var(--display);font-size:19px;font-weight:800;letter-spacing:.02em;background:var(--ink);
  color:var(--on-ink);border-radius:var(--radius-s);padding:14px 18px;flex-shrink:0}
.cs-hero-body{min-width:0}
.cs-hero .cs-h1{margin-bottom:6px}
.cs-hero-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.cs-hero-score{font-family:var(--display);font-size:27px;font-weight:800;line-height:1;font-variant-numeric:tabular-nums}
.cs-hero-label{font-size:14px;font-weight:600;color:var(--text-dim)}
.cs-hero-rank{font-size:12px;color:var(--text-faint);font-family:var(--mono)}
.cs-hero-meta .cs-pill{font-size:12px;display:inline-flex;align-items:center;gap:4px}
.cs-lead-explain{font-size:15px;margin-bottom:8px}
.cs-pairs-list{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.cs-pair-link{display:grid;grid-template-columns:auto 52px 1fr;align-items:center;gap:10px;padding:14px 16px;
  border:none;border-radius:var(--radius-s);background:var(--bg-1);box-shadow:var(--shadow-card);
  transition:transform .18s var(--ease-out),box-shadow .18s}
.cs-pair-link:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover);text-decoration:none}
.cs-pair-lbl{font-family:var(--mono);font-size:13px;font-weight:700;color:var(--text)}
.cs-pair-diff{font-size:14px;font-weight:800;text-align:right;font-variant-numeric:tabular-nums}
.cs-pair-note{font-size:11px;color:var(--text-faint)}
.cs-pair-headline{font-size:16px;line-height:1.55;color:var(--text);margin-bottom:20px}
.cs-pair-cards{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:16px;margin-bottom:20px}
.cs-pair-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:24px 16px;border:none;
  border-radius:var(--radius);background:var(--bg-1);box-shadow:var(--shadow-card);
  transition:transform .18s var(--ease-out),box-shadow .18s;text-align:center}
.cs-pair-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover);text-decoration:none}
.cs-pair-card-name{font-size:13px;color:var(--text-dim);font-weight:600}
.cs-pair-card-score{font-family:var(--display);font-size:30px;font-weight:800;line-height:1;font-variant-numeric:tabular-nums}
.cs-pair-card-lbl{font-size:11px;color:var(--text-faint);font-family:var(--mono)}
.cs-pair-vs{font-size:13px;color:var(--text-faint);font-weight:700}
.cs-cmp{width:100%;border-collapse:collapse;font-size:13px}
.cs-cmp th{text-align:right;padding:9px 10px;font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint);border-bottom:1px solid var(--border-2)}
.cs-cmp th:first-child,.cs-cmp-name{text-align:left}
.cs-cmp td{text-align:right;padding:10px;border-bottom:1px solid var(--border);font-family:var(--mono);font-weight:600}
.cs-cmp tr:last-child td{border-bottom:none}
.cs-cmp-name{color:var(--text-dim);font-family:var(--font)!important;font-weight:600}
.cs-cmp-edge{color:var(--text);font-weight:800}

/* ── FOOTER ─────────────────────────────────────────────── */
.dk-footer{margin-top:96px;padding-top:36px;border-top:1px solid var(--border-2)}
.dk-foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px;margin-bottom:30px}
.dk-foot-brand img{height:17px;margin-bottom:12px}
.dk-foot-brand .tv-logo-dark{display:none}
[data-theme="dark"] .dk-foot-brand .tv-logo-light{display:none}
[data-theme="dark"] .dk-foot-brand .tv-logo-dark{display:inline}
.dk-foot-brand p{font-size:12.5px;color:var(--text-dim);line-height:1.65;max-width:34ch}
.dk-foot-col h4{font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--text-faint);margin-bottom:12px}
.dk-foot-col a{display:block;font-size:13px;font-weight:600;color:var(--text-dim);padding:4px 0}
.dk-foot-col a:hover{color:var(--text);text-decoration:none}
.cs-disclaimer{font-size:11px;color:var(--text-faint);max-width:720px;line-height:1.6;padding-bottom:8px}
/* legacy footer (any straggler templates) */
.cs-footer{margin-top:64px;padding-top:20px;border-top:1px solid var(--border-2);text-align:center}
.cs-footer p{font-size:12px;color:var(--text-dim);margin-bottom:6px}
.cs-footer .cs-disclaimer{margin:0 auto}
.cs-footer-links{display:flex;flex-wrap:wrap;justify-content:center;gap:18px;margin-bottom:12px}
.cs-footer-links a{font-size:12px;font-weight:600;color:var(--text-dim)}
.cs-footer-links a:hover{color:var(--text);text-decoration:none}

/* ── COOKIE ─────────────────────────────────────────────── */
.cs-cookie{position:fixed;left:16px;bottom:16px;z-index:300;max-width:340px;background:var(--bg-1);color:var(--text);
  border:none;border-radius:var(--radius);box-shadow:var(--shadow-hover);padding:16px 18px;font-size:12.5px;line-height:1.6}
.cs-cookie[hidden]{display:none}
.cs-cookie a{color:var(--accent)}
.cs-cookie-btn{display:block;width:100%;margin-top:12px;background:var(--ink);color:var(--on-ink);font-weight:700;font-size:12.5px;
  letter-spacing:.02em;padding:10px 0;border-radius:var(--radius-pill);transition:opacity .15s}
.cs-cookie-btn:hover{opacity:.85}
@media(max-width:560px){.cs-cookie{left:10px;right:10px;bottom:10px;max-width:none}}

/* ── MOTION (transform/opacity only; skipped for reduced-motion;
     gated on html.js so crawlers/no-JS see the final state) ── */
@keyframes csPulse{0%{box-shadow:0 0 0 0 rgba(34,197,94,.45)}70%{box-shadow:0 0 0 6px rgba(34,197,94,0)}100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}}
@keyframes csGrowX{to{transform:scaleX(1)}}
@keyframes csRise{from{opacity:0;transform:translateY(12px)}}
@media (prefers-reduced-motion: no-preference){
  html.js .cs-meter.hero .cs-bar-fill{transform:scaleX(0)}
  html.js .cs-meter.hero.in .cs-bar-fill{animation:csGrowX .9s var(--ease-out) .15s forwards}
  html.js .rv{opacity:0;transform:translateY(18px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
  html.js .rv.in{opacity:1;transform:translateY(0)}
  html.js .rv .cs-pl-fill{transform:scaleX(0)}
  html.js .rv.in .cs-pl-fill{animation:csGrowX .7s var(--ease-out) .25s forwards}
  html.js .dk-panel .cs-pl-fill{transform:scaleX(0);animation:csGrowX .7s var(--ease-out) .2s forwards}
  .cs-bar-fill.pos,.cs-pl-fill.pos{transform-origin:left center}
  .cs-bar-fill.neg,.cs-pl-fill.neg{transform-origin:right center}
  html.js .cs-cookie:not([hidden]){animation:csRise .55s var(--ease-out)}
}

/* ── RESPONSIVE ─────────────────────────────────────────── */
@media(max-width:1000px){
  .dk-hero-grid{grid-template-columns:1fr;gap:24px}
  .dk-hero-head{margin-bottom:22px}
  .dk-hero-intro{padding:4px 0 0}
}
@media(max-width:900px){.cs-duo{grid-template-columns:1fr;gap:20px}}
@media(max-width:760px){
  .cs-main{padding:18px 14px 60px}
  /* Two-row mobile header: logo + chips on top, nav pills below.
     Kills the min-content overflow that dragged a horizontal scroll. */
  body.cs-page .tv-topbar{flex-wrap:wrap;height:auto;min-height:54px;padding-top:9px;padding-bottom:9px;row-gap:8px;gap:10px}
  .dk-nav{order:3;width:100%;margin-left:0;gap:4px}
  .dk-nav-a{padding:7px 12px;font-size:12.5px}
  .tv-topbar-right .dk-sync-pill{display:none}
  .cs-kicker{letter-spacing:.12em;white-space:normal;line-height:1.6;padding:8px 14px}
  .cs-block{margin:54px 0}
  .cs-block-head h2{font-size:21px}
  .dk-h1{font-size:clamp(30px,8vw,38px)}
  .dk-stats{gap:24px}
  .dk-stat-v{font-size:28px}
  .cs-pillars-intro{grid-template-columns:1fr 1fr}
  .cs-gap-grid{grid-template-columns:1fr}
  .cs-recent-grid{grid-template-columns:1fr}
  .ri-grid{grid-template-columns:1fr}
  .cs-pairs-list{grid-template-columns:1fr}
  .cs-pair-cards{grid-template-columns:1fr;gap:10px}
  .cs-pair-vs{display:none}
  .cs-hero-score{font-size:22px}
  .cs-row{grid-template-columns:18px 42px minmax(70px,2.2fr) 50px 18px 26px;gap:8px;padding:9px 8px}
  .cs-meter.hero .cs-row{grid-template-columns:18px 46px minmax(70px,1fr) 52px 20px 26px}
  .cs-name{display:none}
  .cs-detail-grid{grid-template-columns:1fr;gap:20px}
  .cs-block-head{flex-direction:column;align-items:stretch;gap:10px}
  .cs-ctrls{width:100%;gap:10px}
  .cs-ctrl-div{display:none}
  .cs-range button{padding:8px 13px;min-height:36px}
  .cs-leg{padding:8px 13px;min-height:36px}
  .cs-info{width:20px;height:20px;font-size:11px}
  .cs-info::after{position:fixed;left:12px;right:12px;bottom:16px;top:auto;width:auto;max-width:none}
  .cs-fulllink,.cs-post-back,.cs-breadcrumb{display:inline-block;padding:8px 0;min-height:40px}
  .ri-filters{gap:6px}
  .ri-chip{padding:6px 12px;font-size:12px}
  .ri-title{font-size:15px}
  .cs-hm{font-size:10px;min-width:540px}
  .cs-hm th,.cs-hm td{padding:7px 3px}
  .cs-hm th:first-child{position:sticky;left:0;background:var(--bg-1);z-index:2}
  .cs-cmp th,.cs-cmp td{padding:8px 6px}
  .tv-topbar .tv-sync-dot,.tv-topbar .tv-sync{display:none}
  .cs-sync-m{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--text-dim);margin:0 0 14px;font-family:var(--mono)}
  .dk-foot-grid{grid-template-columns:1fr 1fr;gap:22px}
  .dk-foot-brand{grid-column:1/-1}
  .cs-embed-row{flex-direction:column}
  .cs-embed-btn{padding:11px}
  .dk-nav{margin-left:4px}
  .dk-nav-a{padding:7px 11px;font-size:12.5px}
}
@media(max-width:420px){
  .cs-pillars-intro{grid-template-columns:1fr}
  .cs-pl-row{grid-template-columns:80px 1fr 34px}
  .dk-chips{gap:6px}
  .dk-chip{padding:8px 13px;font-size:12px}
}

/* ════════════════════ CRAFT PASS ═══════════════════════════ */
body.cs-page{--serif:'Instrument Serif',Georgia,'Times New Roman',serif}
/* paper grain on the backdrop (cards are opaque, so it reads as texture) */
body.cs-page::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3CfeColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.04 0'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)'/%3E%3C/svg%3E")}
[data-theme="dark"] body.cs-page::after,[data-theme="dark"].cs-page::after{opacity:.25}

/* topbar right-side craft */
.dk-sync-pill{display:inline-flex;align-items:center;gap:8px;padding:7px 14px;border-radius:var(--radius-pill);background:var(--bg-2);font-size:12px;color:var(--text-dim)}
.dk-chip-btn{width:34px;height:34px;border-radius:50%;background:var(--bg-2);display:flex;align-items:center;justify-content:center;color:var(--text-dim);transition:background .15s,color .15s}
.dk-chip-btn:hover{background:var(--ink);color:var(--on-ink)}
.tv-ig.dk-chip-btn:hover{background:#E1306C;color:#fff}


/* pillar spec chips — neutral, engineered (no pastels) */
.t1,.t2,.t3,.t4,.t5{background:var(--bg-1);border:1px solid var(--border-2)}
.t1 .cs-pintro-num,.t2 .cs-pintro-num,.t3 .cs-pintro-num,.t4 .cs-pintro-num,.t5 .cs-pintro-num{color:var(--accent)}
.t6{background:var(--ink);border:1px solid var(--ink)}.t6 .cs-pintro-h,.t6 .cs-pintro-num{color:var(--on-ink)}
.t6 .cs-pintro-d{color:var(--on-ink);opacity:.65}

/* HOW strip (compact, after hero) */
.dk-how{margin:30px 0 0}
.dk-how-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:10px}
.dk-how-grid .cs-pintro{box-shadow:none}
.dk-how-grid a.cs-pintro{text-decoration:none}
.dk-how-grid a.cs-pintro:hover{text-decoration:none}
@media(max-width:900px){.dk-how-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.dk-how-grid{grid-template-columns:1fr 1fr}}

/* CENTRAL BANK WATCH */
.dk-ev-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.dk-ev{display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto auto;column-gap:12px;row-gap:4px;
  background:var(--bg-1);border-radius:var(--radius-s);box-shadow:var(--shadow-card);padding:15px 17px;align-items:center}
.dk-ev-ccy{grid-row:1/3;font-family:var(--display);font-size:10.5px;font-weight:800;letter-spacing:.04em;
  width:46px;height:46px;border-radius:14px;background:var(--bg-2);overflow:hidden;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;line-height:1}
.dk-ev-flag{width:24px;height:24px;border-radius:50%;display:block;flex:none;box-shadow:0 0 0 1px var(--border-3,#e5e3dc)}
.dk-ev.hot .dk-ev-ccy{background:var(--ink);color:var(--on-ink)}
.dk-ev-bank{font-size:12.5px;font-weight:700;color:var(--text);padding-right:70px}
.dk-ev-bank i{font-style:normal;font-weight:500;color:var(--text-faint);font-size:11px;display:block}
.dk-ev-date{font-family:var(--mono);font-size:11px;color:var(--text-dim)}
.dk-ev-days{position:absolute}
.dk-ev{position:relative}
.dk-ev-days{top:13px;right:13px;font-size:10.5px;font-weight:700;padding:4px 10px;border-radius:var(--radius-pill);background:var(--bg-2);color:var(--text-dim)}
.dk-ev.hot .dk-ev-days{background:var(--bear-bg);color:var(--bear-bright)}
@media(max-width:1000px){.dk-ev-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){
  .dk-ev-grid{grid-template-columns:1fr}
  /* days pill becomes a third column instead of floating over the text */
  .dk-ev{grid-template-columns:auto 1fr auto}
  .dk-ev-days{position:static;grid-row:1/3;align-self:center;margin-left:4px}
  .dk-ev-bank{padding-right:0}
}

/* research card covers — the article's own headline figure */
.ri-thumb{height:108px;position:relative;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;
  gap:4px;padding:0 22px;background:var(--bg-2);border-bottom:1px solid var(--border)}
.ri-thumb::before{content:'';position:absolute;inset:0;opacity:.4;pointer-events:none;
  background:repeating-linear-gradient(90deg,var(--hairline) 0 1px,transparent 1px 26px)}
.ri-thumb-stat{font-family:var(--mono);font-size:29px;font-weight:600;letter-spacing:-.02em;color:var(--cat-color);position:relative;line-height:1}
.ri-thumb-cat{font-family:var(--mono);font-size:9px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--text-faint);position:relative}

/* about-page visuals */
.ab-scale{margin:26px 0 30px}
.ab-scale-bar{position:relative;height:14px;border-radius:var(--radius-pill);
  background:linear-gradient(90deg,var(--bear) 0%,#E8B27D 38%,var(--bg-3) 50%,#9DB8F2 62%,var(--bull) 100%)}
.ab-scale-zero{position:absolute;left:50%;top:-4px;bottom:-4px;width:2px;background:var(--text);border-radius:2px}
.ab-scale-l{display:flex;justify-content:space-between;font-family:var(--mono);font-size:10px;color:var(--text-faint);margin-top:8px}
.ab-scale figcaption{font-size:12px;color:var(--text-faint);margin-top:10px}
.ab-flow{display:flex;align-items:stretch;gap:10px;flex-wrap:wrap;margin:26px 0 30px}
.ab-flow-stage{flex:1;min-width:170px;background:var(--bg-1);border-radius:var(--radius-s);box-shadow:var(--shadow-card);padding:14px 16px;display:flex;flex-direction:column;gap:8px;justify-content:center}
.ab-flow-h{font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--text-faint)}
.ab-flow-d{font-size:12px;color:var(--text-dim);line-height:1.5}
.ab-flow-pills{display:flex;flex-wrap:wrap;gap:5px}
.ab-flow-pills i{font-style:normal;font-size:11px;font-weight:700;padding:4px 10px;border-radius:var(--radius-pill);color:var(--text);background:var(--bg-2);border:none}
.ab-flow-arrow{align-self:center;color:var(--text-faint);font-size:16px}
.ab-flow-score .ab-flow-num{font-family:var(--display);font-size:21px;font-weight:800;letter-spacing:-.01em}
@media(max-width:700px){.ab-flow{flex-direction:column}.ab-flow-arrow{transform:rotate(90deg);align-self:flex-start;margin-left:18px}}

/* footer rhythm */
.dk-footer{margin-top:72px}
