/* ============================================================================
   STOCK RESEARCH — Project layer on top of the Atlas Design System.
   Requires: colors_and_type.css + components.css (load both before this file).
   Use <body class="atlas"> on every page.

   This file does two jobs:
   1. Maps the project's legacy design tokens (--s-N, --ink, --accent, ...) onto
      Atlas tokens, so existing markup adopts the new look by only swapping the
      <link>s and adding class="atlas" — no per-element rewrite required.
   2. Defines the domain components shared across the research sites
      (verdict bar, stats grid, pillars, ip/power bars, scenario cards,
       anchor ladder, agent grid, risk list, file list, portal grid, ...).
   ============================================================================ */

/* ---- 1. Legacy token bridge ------------------------------------------------ */
:root {
  /* Spacing — old --s-N → Atlas --sp-N */
  --s-1: var(--sp-1);
  --s-2: var(--sp-2);
  --s-3: var(--sp-3);
  --s-4: var(--sp-4);
  --s-5: var(--sp-5);
  --s-6: var(--sp-6);
  --s-7: var(--sp-7);
  --s-8: var(--sp-8);
  --s-9: var(--sp-9);

  /* Surfaces & ink — old names → Atlas semantic tokens */
  --bg-elevated:  var(--surface);
  --bg-subtle:    var(--surface-sunken);
  --ink:          var(--fg-1);
  --ink-muted:    var(--fg-3);
  --ink-light:    var(--fg-4);
  --line:         var(--border);
  --line-strong:  var(--border-strong);

  /* Accent — old editorial-red → Atlas denim blue */
  --accent:       var(--blue);
  --accent-soft:  var(--blue-soft);
  --accent-deep:  var(--blue-strong);

  /* Layout widths */
  --w-narrow:  720px;
  --w-content: 920px;
  --w-wide:    1200px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 104px; }
body.atlas { margin: 0; padding: 0; }

/* tabular numerals helpers (legacy class names) */
.num, td.num, th.num, .t-num { font-variant-numeric: tabular-nums; font-feature-settings: "tnum"; }
.t-center, td.center, th.center { text-align: center; }

/* ---- 2. Layout ------------------------------------------------------------- */
.container         { max-width: var(--w-wide);    margin: 0 auto; padding: 0 var(--sp-5); }
.container-content { max-width: var(--w-content); margin: 0 auto; padding: 0 var(--sp-5); }
.container-narrow  { max-width: var(--w-narrow);  margin: 0 auto; padding: 0 var(--sp-5); }

.section       { padding: var(--sp-8) 0; }
.section-tight { padding: var(--sp-6) 0; }
.section--sunken { background: var(--surface-sunken); }

.grid   { display: grid; gap: var(--sp-5); }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }
.two-col { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-6); align-items: start; }
@media (max-width: 860px) {
  .grid-2, .grid-3, .grid-4, .two-col { grid-template-columns: 1fr; }
}

.divider { border: none; border-top: 1px solid var(--border); margin: var(--sp-6) 0; }

/* ---- 3. Topbar / sticky nav ------------------------------------------------ */
.topbar {
  position: sticky; top: 0; z-index: 50;
  border-bottom: 1px solid var(--border);
  background: color-mix(in srgb, var(--ivory) 88%, transparent);
  backdrop-filter: blur(10px) saturate(1.1);
  padding: var(--sp-3) 0;
}
.topbar-inner {
  max-width: var(--w-wide); margin: 0 auto; padding: 0 var(--sp-5);
  display: flex; justify-content: space-between; align-items: center; gap: var(--sp-4);
}
.topbar a { border: none; }
.topbar-brand {
  font-family: var(--font-serif); font-weight: var(--fw-medium);
  font-size: var(--text-body); letter-spacing: -0.01em; color: var(--fg-1);
}
.topbar-brand .accent { color: var(--blue); }
.topbar-meta { color: var(--fg-3); font-size: var(--text-small); font-family: var(--font-mono); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
@media (max-width: 560px) { .topbar-meta { display: none; } }

/* Section sub-navigation (scroll-spy).
   `top` is set by site.js to the live topbar height (handles font-swap / wrap /
   narrow viewports); the 49px here is only a no-JS fallback. */
.subnav {
  position: sticky; top: 49px; z-index: 40;
  border-bottom: 1px solid var(--border);
  background: color-mix(in srgb, var(--ivory) 90%, transparent);
  backdrop-filter: blur(10px);
}
.subnav .container,
.subnav-inner {
  display: flex; gap: var(--sp-1); overflow-x: auto; scrollbar-width: none;
  max-width: var(--w-wide); margin: 0 auto; padding: 0 var(--sp-5);
}
.subnav .container::-webkit-scrollbar, .subnav-inner::-webkit-scrollbar { display: none; }
.subnav a {
  flex: none; border: none; padding: 12px 14px; white-space: nowrap;
  font-size: var(--text-small); font-weight: var(--fw-medium); color: var(--fg-3);
  border-bottom: 2px solid transparent; margin-bottom: -1px;
  transition: color var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.subnav a:hover { color: var(--fg-1); }
.subnav a.is-active { color: var(--blue-strong); border-bottom-color: var(--blue); }

/* ---- 4. Hero --------------------------------------------------------------- */
.hero { padding: var(--sp-9) 0 var(--sp-8); border-bottom: 1px solid var(--border); position: relative; }
.hero .kicker, .kicker {
  font-family: var(--font-mono); font-size: var(--text-caption);
  text-transform: uppercase; letter-spacing: var(--tracking-wide);
  color: var(--blue-strong); font-weight: var(--fw-medium); margin-bottom: var(--sp-4);
  display: block;
}
.hero h1 { font-size: clamp(2rem, 4.4vw, var(--text-display)); font-weight: var(--fw-light); line-height: var(--lh-tight); letter-spacing: -0.02em; margin-bottom: var(--sp-5); }
.hero .lede { margin-bottom: 0; max-width: 760px; }

/* Lede / pull text */
.lede {
  font-family: var(--font-serif); font-weight: var(--fw-light);
  font-size: 1.2rem; line-height: 1.5; color: var(--fg-2);
  margin: 0 0 var(--sp-6); max-width: 760px; text-wrap: pretty;
}

/* Section label / overline */
.section-label {
  font-family: var(--font-mono); font-size: var(--text-caption);
  text-transform: uppercase; letter-spacing: var(--tracking-wide);
  color: var(--fg-3); font-weight: var(--fw-regular); margin-bottom: var(--sp-3);
}
.section-header {
  display: flex; align-items: baseline; gap: var(--sp-4);
  margin-bottom: var(--sp-5); padding-bottom: var(--sp-3); border-bottom: 1px solid var(--border-strong);
}
.section-header h2 { margin: 0; }
.section-header .section-num { font-family: var(--font-mono); font-size: var(--text-small); color: var(--blue-strong); }

/* In-text highlights */
.hi { background: linear-gradient(transparent 12%, var(--highlight) 12%, var(--highlight) 86%, transparent 86%); padding: 0 0.12em; box-decoration-break: clone; -webkit-box-decoration-break: clone; color: var(--fg-1); }
.hi-good { color: color-mix(in srgb, var(--success) 80%, #000); font-weight: var(--fw-medium); }
.hi-warn { color: color-mix(in srgb, var(--warning) 78%, #000); font-weight: var(--fw-medium); }
.hi-bad  { color: color-mix(in srgb, var(--danger) 82%, #000); font-weight: var(--fw-medium); }

.key-quote {
  font-family: var(--font-serif); font-weight: var(--fw-light);
  font-size: 1.18rem; line-height: 1.55; color: var(--fg-1);
  border-left: 3px solid var(--blue); padding: var(--sp-2) 0 var(--sp-2) var(--sp-5);
  margin: var(--sp-5) 0; max-width: 820px;
}
.key-quote strong { font-weight: var(--fw-semibold); }

.note   { font-size: var(--text-caption); color: var(--fg-4); font-style: italic; }
.source { font-size: var(--text-caption); color: var(--fg-4); font-style: italic; margin-top: var(--sp-2); }

/* ---- 5. Verdict bar -------------------------------------------------------- */
.verdict-bar {
  display: flex; flex-wrap: wrap; gap: var(--sp-2);
  margin-top: var(--sp-6); padding: var(--sp-4) var(--sp-5);
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md);
  box-shadow: var(--shadow-sm);
}
.verdict { display: flex; flex-direction: column; gap: 4px; padding: 0 var(--sp-5) 0 0; margin-right: var(--sp-5); border-right: 1px solid var(--border); }
.verdict:last-child { border-right: none; margin-right: 0; padding-right: 0; }
.verdict-label { font-size: var(--text-caption); text-transform: uppercase; letter-spacing: 0.08em; color: var(--fg-4); font-family: var(--font-mono); }
.verdict-value { font-size: 1.15rem; font-weight: var(--fw-semibold); color: var(--fg-1); font-variant-numeric: tabular-nums; }
.verdict-value.positive { color: color-mix(in srgb, var(--success) 80%, #000); }
.verdict-value.warning  { color: color-mix(in srgb, var(--warning) 78%, #000); }
.verdict-value.negative { color: color-mix(in srgb, var(--danger) 82%, #000); }
.verdict-value.tier-1 { color: var(--blue-strong); }
.verdict-value.tier-2 { color: color-mix(in srgb, var(--warning) 80%, #000); }
@media (max-width: 640px) { .verdict { border-right: none; margin-right: 0; padding-right: 0; min-width: 45%; } }

/* ---- 6. Stats -------------------------------------------------------------- */
.stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: var(--sp-4); margin-top: var(--sp-6); }
.stat, .stat-card {
  display: flex; flex-direction: column; gap: 6px;
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md); padding: var(--sp-5);
}
.stat-card.highlight-card { background: var(--blue-faint); border-color: transparent; }
.stat-label { font-family: var(--font-mono); font-size: var(--text-caption); text-transform: uppercase; letter-spacing: 0.06em; color: var(--fg-3); }
.stat-value, .stat-value-large { font-family: var(--font-serif); font-size: 1.9rem; font-weight: var(--fw-regular); letter-spacing: -0.02em; line-height: 1.05; color: var(--fg-1); font-variant-numeric: tabular-nums; }
.stat-value-large { font-size: 2.4rem; }
.stat-unit { font-size: 0.5em; color: var(--fg-3); margin-left: 3px; font-family: var(--font-sans); }
.stat-sub { font-size: var(--text-small); color: var(--fg-3); }
.big-num { font-family: var(--font-serif); font-size: 3.6rem; font-weight: var(--fw-light); letter-spacing: -0.03em; line-height: 1; font-variant-numeric: tabular-nums; color: var(--fg-1); }
.big-num-accent { color: var(--blue); }

/* ---- 7. Pillars (thesis drivers) ------------------------------------------- */
.pillars { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: var(--sp-4); }
.pillar { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md); padding: var(--sp-5); position: relative; }
.pillar-num { font-family: var(--font-mono); font-size: var(--text-caption); letter-spacing: 0.1em; text-transform: uppercase; color: var(--blue-strong); margin-bottom: var(--sp-2); }
.pillar h3 { font-size: var(--text-h3); margin: 0 0 var(--sp-2); }
.pillar p { font-size: var(--text-small); color: var(--fg-2); margin: 0; line-height: 1.55; }

/* ---- 8. Tables (extend Atlas .table / legacy .data-table) ------------------ */
.data-table { width: 100%; border-collapse: collapse; font-size: var(--text-small); margin: var(--sp-5) 0; font-variant-numeric: tabular-nums; }
.data-table th { text-align: left; font-family: var(--font-mono); font-weight: var(--fw-regular); font-size: var(--text-caption); text-transform: uppercase; letter-spacing: 0.04em; color: var(--fg-3); padding: 10px 14px; border-bottom: 1px solid var(--border-strong); }
.data-table th.num, .data-table td.num { text-align: right; }
.data-table th.center, .data-table td.center { text-align: center; }
.data-table td { padding: 11px 14px; border-bottom: 1px solid var(--border); color: var(--fg-2); vertical-align: top; }
.data-table tbody tr { transition: background var(--dur) var(--ease); }
.data-table tbody tr:hover { background: var(--gray-50); }
.data-table tr.row-emphasis td { background: var(--blue-faint); font-weight: var(--fw-medium); }

/* ---- 9. Pills (legacy) — map onto Atlas badge palette ---------------------- */
.pill { display: inline-flex; align-items: center; gap: 6px; padding: 3px 10px; border-radius: var(--r-pill); font-size: var(--text-caption); font-weight: var(--fw-medium); background: var(--gray-100); color: var(--fg-3); white-space: nowrap; }
.pill-accent, .pill-active { background: var(--blue-soft); color: var(--blue-strong); }
.pill-success { background: var(--success-soft); color: color-mix(in srgb, var(--success) 80%, #000); }
.pill-warning { background: var(--warning-soft); color: color-mix(in srgb, var(--warning) 78%, #000); }
.pill-danger  { background: var(--danger-soft);  color: color-mix(in srgb, var(--danger) 82%, #000); }
.pill-info    { background: var(--info-soft);    color: color-mix(in srgb, var(--info) 80%, #000); }

/* ---- 10. Horizontal data bars (IP share, 7 Powers) ------------------------- */
.ip-bar { display: grid; grid-template-columns: 1fr auto; gap: 2px var(--sp-3); align-items: center; padding: var(--sp-2) 0; border-bottom: 1px solid var(--border); }
.ip-name { font-size: var(--text-small); font-weight: var(--fw-medium); color: var(--fg-1); }
.ip-share { font-variant-numeric: tabular-nums; font-weight: var(--fw-semibold); color: var(--fg-1); font-size: var(--text-small); }
.ip-track { grid-column: 1 / -1; height: 7px; background: var(--gray-100); border-radius: var(--r-pill); overflow: hidden; }
.ip-fill { height: 100%; background: var(--blue); border-radius: var(--r-pill); transform-origin: left; transition: transform 0.8s var(--ease); }
html.js-reveal .ip-fill { transform: scaleX(0); }
html.js-reveal .ip-fill.is-in { transform: scaleX(1); }
.ip-yoy { font-size: var(--text-caption); color: var(--fg-3); font-variant-numeric: tabular-nums; }

.power-bar { display: grid; grid-template-columns: 160px 1fr 48px; gap: var(--sp-3); align-items: center; padding: var(--sp-2) 0; }
.power-bar-label { font-size: var(--text-small); color: var(--fg-2); }
.power-bar-track { height: 8px; background: var(--gray-100); border-radius: var(--r-pill); overflow: hidden; }
.power-bar-fill { height: 100%; border-radius: var(--r-pill); transform-origin: left; transition: transform 0.8s var(--ease); }
html.js-reveal .power-bar-fill { transform: scaleX(0); }
html.js-reveal .power-bar-fill.is-in { transform: scaleX(1); }
.power-bar-fill.high { background: var(--blue); }
.power-bar-fill.mid  { background: var(--info); }
.power-bar-fill.low  { background: var(--gray-400); }
.power-bar-value { font-variant-numeric: tabular-nums; font-size: var(--text-small); font-weight: var(--fw-semibold); color: var(--fg-1); text-align: right; }
@media (max-width: 520px) { .power-bar { grid-template-columns: 110px 1fr 40px; } }

/* Strength bar (5 forces) */
.strength-bar { display: flex; align-items: center; gap: var(--sp-3); }
.strength-bar-track { flex: 1; height: 7px; background: var(--gray-100); border-radius: var(--r-pill); overflow: hidden; }
.strength-bar-fill { height: 100%; background: var(--fg-2); transform-origin: left; transition: transform 0.8s var(--ease); }
html.js-reveal .strength-bar-fill { transform: scaleX(0); }
html.js-reveal .strength-bar-fill.is-in { transform: scaleX(1); }
.strength-bar-fill.strong { background: var(--blue); }
.strength-bar-fill.medium { background: var(--warning); }
.strength-bar-fill.weak   { background: var(--gray-400); }
.strength-label { font-size: var(--text-small); font-variant-numeric: tabular-nums; min-width: 64px; }

/* ---- 11. Scenario cards ---------------------------------------------------- */
.scenario-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--sp-4); margin: var(--sp-5) 0; }
.scenario-card { background: var(--surface); border: 1px solid var(--border); border-top: 3px solid var(--gray-400); border-radius: var(--r-md); padding: var(--sp-5); }
.scenario-card.bull     { border-top-color: var(--success); }
.scenario-card.base     { border-top-color: var(--blue); }
.scenario-card.bear     { border-top-color: var(--warning); }
.scenario-card.disaster { border-top-color: var(--danger); }
.scenario-name { font-family: var(--font-serif); font-size: var(--text-h3); color: var(--fg-1); }
.scenario-prob { font-size: var(--text-caption); font-family: var(--font-mono); color: var(--fg-3); text-transform: uppercase; letter-spacing: 0.04em; margin-bottom: var(--sp-3); }
.scenario-price { font-family: var(--font-serif); font-size: 2rem; font-weight: var(--fw-regular); color: var(--fg-1); font-variant-numeric: tabular-nums; }
.scenario-change { font-size: var(--text-small); font-weight: var(--fw-semibold); font-variant-numeric: tabular-nums; }
.scenario-change.up   { color: color-mix(in srgb, var(--success) 80%, #000); }
.scenario-change.down { color: color-mix(in srgb, var(--danger) 82%, #000); }
.scenario-detail { font-size: var(--text-small); color: var(--fg-3); line-height: 1.5; margin-top: var(--sp-3); }

/* ---- 12. Anchor ladder ----------------------------------------------------- */
.anchor-ladder { display: flex; flex-direction: column; gap: var(--sp-2); margin: var(--sp-5) 0; }
.anchor-row { display: grid; grid-template-columns: 96px 150px 1fr 88px; gap: var(--sp-4); align-items: start; padding: var(--sp-4); background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md); }
.anchor-row.stop { background: var(--danger-soft); border-color: transparent; }
.anchor-tag { display: inline-flex; align-items: center; justify-content: center; padding: 4px 10px; border-radius: var(--r-sm); background: var(--blue-soft); color: var(--blue-strong); font-weight: var(--fw-semibold); font-size: var(--text-small); height: fit-content; }
.anchor-row.stop .anchor-tag { background: var(--danger); color: #fff; }
.anchor-price { font-family: var(--font-serif); font-size: 1.25rem; color: var(--fg-1); font-variant-numeric: tabular-nums; }
.anchor-cond { font-size: var(--text-small); color: var(--fg-2); line-height: 1.5; }
.anchor-pos { font-variant-numeric: tabular-nums; font-weight: var(--fw-semibold); color: var(--fg-1); text-align: right; }
@media (max-width: 760px) { .anchor-row { grid-template-columns: 1fr 1fr; } .anchor-cond { grid-column: 1 / -1; } }

.divergence { background: var(--warning-soft); border-radius: var(--r-md); padding: var(--sp-5); margin: var(--sp-5) 0; }
.divergence h4 { margin: 0 0 var(--sp-2); color: color-mix(in srgb, var(--warning) 80%, #000); font-family: var(--font-sans); font-size: var(--text-body); }

/* ---- 13. Agent grid -------------------------------------------------------- */
.agent-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: var(--sp-4); }
.agent-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md); padding: var(--sp-5); }
.agent-name { font-family: var(--font-mono); font-size: var(--text-small); font-weight: var(--fw-semibold); color: var(--blue-strong); }
.agent-verdict { font-weight: var(--fw-semibold); color: var(--fg-1); margin: var(--sp-1) 0 var(--sp-3); font-size: var(--text-small); }
.agent-key { font-size: var(--text-small); color: var(--fg-3); line-height: 1.55; }

/* ---- 14. Risk list --------------------------------------------------------- */
.risk-list { display: flex; flex-direction: column; gap: var(--sp-1); }
.risk-row { display: grid; grid-template-columns: 44px 1fr 64px 64px; gap: var(--sp-3); align-items: start; padding: var(--sp-3) var(--sp-4); background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-sm); }
.risk-num { font-family: var(--font-mono); font-size: var(--text-small); font-weight: var(--fw-semibold); color: var(--fg-3); }
.risk-desc { font-size: var(--text-small); color: var(--fg-2); line-height: 1.5; }
.risk-prob, .risk-impact { font-size: var(--text-caption); text-align: center; padding: 2px 8px; border-radius: var(--r-pill); height: fit-content; font-weight: var(--fw-medium); }
.risk-prob.high, .risk-impact.high { background: var(--danger-soft); color: color-mix(in srgb, var(--danger) 82%, #000); }
.risk-prob.mid,  .risk-impact.mid  { background: var(--warning-soft); color: color-mix(in srgb, var(--warning) 78%, #000); }
.risk-prob.low,  .risk-impact.low  { background: var(--success-soft); color: color-mix(in srgb, var(--success) 80%, #000); }
@media (max-width: 640px) { .risk-row { grid-template-columns: 36px 1fr; } .risk-prob, .risk-impact { grid-column: 2; justify-self: start; } }

/* ---- 15. File list / source cards ------------------------------------------ */
.file-list { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: var(--sp-3); }
.file-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-sm); padding: var(--sp-4); transition: border-color var(--dur) var(--ease), transform var(--dur-fast) var(--ease); }
.file-card:hover { border-color: var(--blue); transform: translateY(-2px); }
.file-card a { display: block; font-family: var(--font-mono); font-size: var(--text-small); color: var(--blue-strong); border: none; word-break: break-word; }
.file-card-desc { font-size: var(--text-caption); color: var(--fg-3); margin-top: 4px; line-height: 1.45; }

/* ---- 16. Portal grid (home / index hubs) ----------------------------------- */
.portal-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(330px, 1fr)); gap: var(--sp-5); margin-top: var(--sp-7); }
.portal-card { display: flex; flex-direction: column; gap: var(--sp-3); background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md); padding: var(--sp-6); text-decoration: none; color: var(--fg-2); box-shadow: var(--shadow-sm); transition: border-color var(--dur) var(--ease), transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease); }
.portal-card { border-bottom: none; }
.portal-card:hover { border-color: var(--blue); transform: translateY(-3px); box-shadow: var(--shadow-md); }
.portal-card.is-featured { border-color: var(--blue); border-width: 1.5px; }
.portal-kind { font-family: var(--font-mono); font-size: var(--text-caption); letter-spacing: 0.06em; text-transform: uppercase; color: var(--blue-strong); }
.portal-card h3 { font-size: var(--text-h3); margin: 0; color: var(--fg-1); }
.portal-card .lede { font-family: var(--font-sans); font-style: normal; font-size: var(--text-small); color: var(--fg-3); line-height: 1.55; margin: 0; font-weight: var(--fw-regular); }
.portal-meta { display: flex; flex-wrap: wrap; gap: var(--sp-2) var(--sp-4); font-size: var(--text-caption); color: var(--fg-4); margin-top: auto; padding-top: var(--sp-3); border-top: 1px solid var(--border); }
.portal-meta span { display: inline-flex; align-items: center; gap: 4px; }
.portal-meta strong { color: var(--fg-2); font-weight: var(--fw-semibold); }

.hero-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); gap: var(--sp-4); margin-top: var(--sp-6); }

/* Topic card (industry sub-pages) */
.topic-card { display: block; text-decoration: none; color: var(--fg-2); background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md); padding: var(--sp-5); box-shadow: var(--shadow-sm); transition: border-color var(--dur) var(--ease), transform var(--dur) var(--ease); border-bottom: 1px solid var(--border); }
.topic-card:hover { border-color: var(--blue); transform: translateY(-2px); }
.topic-card .topic-num { font-family: var(--font-serif); font-size: 1.5rem; font-style: italic; color: var(--blue); }
.topic-card h3 { margin: var(--sp-2) 0; font-size: var(--text-h3); color: var(--fg-1); }
.topic-card p { margin: 0; font-size: var(--text-small); color: var(--fg-3); line-height: 1.5; }
.topic-card .topic-meta { margin-top: var(--sp-3); font-size: var(--text-caption); color: var(--fg-4); display: flex; gap: var(--sp-3); flex-wrap: wrap; }

/* ---- 17. SVG viz container ------------------------------------------------- */
.viz { width: 100%; margin: var(--sp-5) 0; }
.viz svg { width: 100%; height: auto; display: block; }

/* ---- 18. Backlink ---------------------------------------------------------- */
.backlink { display: inline-flex; align-items: center; gap: var(--sp-2); font-size: var(--text-small); color: var(--fg-3); border: none; margin-bottom: var(--sp-5); }
.backlink:hover { color: var(--blue); }
.backlink::before { content: "←"; }

/* ---- 19. Footer ------------------------------------------------------------ */
.site-footer { margin-top: var(--sp-9); padding: var(--sp-7) 0; border-top: 1px solid var(--border); font-size: var(--text-small); color: var(--fg-3); }
.footer-note { margin-top: var(--sp-9); padding-top: var(--sp-6); border-top: 1px solid var(--border); font-size: var(--text-small); color: var(--fg-3); }
.footer-note code { font-family: var(--font-mono); background: var(--surface-sunken); padding: 1px 6px; border-radius: var(--r-xs); font-size: 0.85em; }

/* ---- 20. Scroll-reveal animation hook (progressive enhancement) ------------
   Default = fully visible (so pages that don't load site.js never break).
   site.js adds `js-reveal` to <html>, which switches on the hidden start state
   and the grow/fade-in transitions. */
.reveal { transition: opacity 0.6s var(--ease), transform 0.6s var(--ease); }
html.js-reveal .reveal { opacity: 0; transform: translateY(12px); }
html.js-reveal .reveal.is-in { opacity: 1; transform: none; }
html.js-reveal .bar-animate { transform: scaleX(0); }
html.js-reveal .bar-animate.is-in { transform: scaleX(1); }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .reveal, .bar-animate, .ip-fill, .power-bar-fill, .strength-bar-fill { transition: none !important; transform: none !important; opacity: 1 !important; }
}

/* ---- 20b. Legacy generic utilities (from the old hospitality base) --------- */
.flex { display: flex; gap: var(--sp-3); }
.flex-col { flex-direction: column; }
.flex-between { justify-content: space-between; }
.flex-center { align-items: center; }
.flex-wrap { flex-wrap: wrap; }
.container-wide { max-width: var(--w-wide); margin: 0 auto; padding: 0 var(--sp-5); }
.grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-5); }
@media (max-width: 860px) { .grid2 { grid-template-columns: 1fr; } }
.card-padded { padding: var(--sp-6); }
.divider-strong { border-top-color: var(--fg-1); }
.divider-accent { border: none; height: 3px; width: 48px; background: var(--blue); margin: var(--sp-4) 0; }
.no-hover tr:hover td, .no-hover tr:hover { background: transparent !important; }
.section-num { font-family: var(--font-mono); font-size: var(--text-small); color: var(--blue-strong); }

/* Legacy single-dash callout (border-left style) — overrides Atlas .callout for
   project pages that use the old markup `<div class="callout callout-warn">…`. */
.callout { display: block; border-left: 3px solid var(--blue); padding: var(--sp-3) var(--sp-5); background: var(--blue-faint); border-radius: 0 var(--r-sm) var(--r-sm) 0; margin: var(--sp-5) 0; font-size: var(--text-small); color: var(--fg-2); }
.callout.callout-info, .callout-info { border-left-color: var(--info); background: var(--info-soft); }
.callout.callout-warn, .callout-warn { border-left-color: var(--warning); background: var(--warning-soft); }
.callout.callout-success, .callout-success { border-left-color: var(--success); background: var(--success-soft); }
.callout strong { color: var(--fg-1); }

/* ---- 21. Print ------------------------------------------------------------- */
@media print {
  .topbar, .subnav, .site-footer { display: none; }
  body.atlas { background: #fff; }
  .reveal { opacity: 1 !important; transform: none !important; }
}
