/* ============================================================
   Analysis page v2 — uses the project design system
   (colors_and_type.css). Class namespace `.av2-*` is preserved
   so the React components don't need touching.
   Tokens used (no new ones invented):
     --font-sans, --font-mono, --color-ink, --color-gray-*,
     --fg-1/2/3/4, --bg-page/subtle/muted, --border-1/2,
     --accent / --accent-hover / --accent-light / --accent-dark,
     --color-success/warning/error/info (+ -light/-dark),
     --radius-*, --shadow-*, --font-size-*, letter-spacing/kicker
   ============================================================ */

/* ---------- frame ---------- */
.av2 {
  font-family: var(--font-sans);
  color: var(--fg-1);
  background: var(--bg-page);
  line-height: var(--line-height-normal);
  font-size: var(--font-size-base);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.av2 *, .av2 *::before, .av2 *::after { box-sizing: border-box; }
.av2 a { color: var(--accent); text-decoration: none; }
.av2 a:hover { color: var(--accent-hover); text-decoration: underline; }

/* SUR-1779: the legacy `.av2-masthead` / `.av2-bar*` block has been
   removed from av2-analysis.njk in favour of the canonical site
   header in base.njk. The selectors that styled it (`.av2-masthead`,
   `.av2-masthead__inner`, `.av2-bar`, `.av2-bar__brand`,
   `.av2-bar__nav`, `.av2-bar__date`) are intentionally not retained
   here because no template emits them anymore. */

/* ---------- hero ---------- */
.av2-hero {
  max-width: 1240px;
  margin: 0 auto;
  padding: var(--spacing-12) var(--spacing-8) var(--spacing-10);
}
.av2-hero__crumbs {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--fg-3);
  margin-bottom: var(--spacing-4);
  display: flex; align-items: center; gap: var(--spacing-2); flex-wrap: wrap;
}
.av2-hero__crumbs a { color: var(--fg-3); }
.av2-hero__crumbs a:hover { color: var(--fg-1); text-decoration: none; }
.av2-hero__crumbs .sep { opacity: 0.5; }

.av2-hero__type-chip {
  display: inline-flex; align-items: center; gap: var(--spacing-2);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--accent-dark);
  background: var(--accent-light);
  padding: 3px 10px;
  border-radius: var(--radius-sm);
}
.av2-hero__type-chip::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: currentColor;
}

.av2-hero__title {
  font-family: var(--font-sans);
  font-size: clamp(1.6rem, 4vw, 3.25rem);
  line-height: 1.05;
  letter-spacing: var(--letter-spacing-hero);
  font-weight: var(--font-weight-black);
  color: var(--color-gray-900);
  margin: var(--spacing-3) 0 var(--spacing-4);
  max-width: 22ch;
  text-wrap: balance;
}

.av2-hero__bill {
  font-size: var(--font-size-sm);
  color: var(--fg-2);
  border-left: 3px solid var(--accent);
  padding-left: var(--spacing-3);
  margin-bottom: var(--spacing-5);
  max-width: 70ch;
}
.av2-hero__bill .bill-id {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 0.75rem;
  font-weight: var(--font-weight-bold);
  background: var(--accent);
  color: #fff;
  padding: 2px 8px;
  border-radius: 3px;
  letter-spacing: 0.04em;
  margin-right: var(--spacing-2);
  text-transform: uppercase;
  vertical-align: 1px;
  line-height: 1.4;
}

.av2-meta {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: var(--spacing-5) var(--spacing-6);
  align-items: center;
  padding: var(--spacing-4) 0;
  border-top: 1px solid var(--border-1);
  border-bottom: 1px solid var(--border-1);
  margin-top: var(--spacing-6);
  flex-wrap: wrap;
}
.av2-byline { display: flex; align-items: center; gap: var(--spacing-3); }
.av2-byline__avatar {
  width: 38px; height: 38px;
  border-radius: 50%;
  background: var(--color-ink);
  color: #fff;
  display: grid; place-items: center;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.04em;
}
.av2-byline__text { line-height: 1.3; }
.av2-byline__label {
  font-size: var(--font-size-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--fg-3);
  font-weight: var(--font-weight-semibold);
}
.av2-byline__name {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--fg-1);
}
.av2-meta__dates {
  display: flex; gap: var(--spacing-6); flex-wrap: wrap;
  font-size: var(--font-size-sm); color: var(--fg-2);
}
.av2-meta__dates dt {
  font-size: var(--font-size-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--fg-3);
  font-weight: var(--font-weight-semibold);
  margin-bottom: 2px;
}
.av2-meta__dates dd { margin: 0; font-variant-numeric: tabular-nums; color: var(--fg-1); font-weight: var(--font-weight-medium); }
.av2-meta__dates > div { display: flex; flex-direction: column; }

.av2-vetting {
  display: inline-flex; align-items: center; gap: var(--spacing-2);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: var(--radius-sm);
  white-space: nowrap;
}
.av2-vetting--vetted { background: var(--color-success-light); color: var(--color-success-dark); }
.av2-vetting--unvetted { background: var(--color-warning-light); color: var(--color-warning-dark); }
.av2-vetting::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: currentColor;
}

/* ---------- type-specific hero slots ---------- */

/* Public Summary — clear lede, no drop cap */
.av2-lede {
  font-family: var(--font-sans);
  font-size: var(--font-size-xl);
  line-height: 1.5;
  color: var(--fg-1);
  margin: var(--spacing-6) 0 0;
  max-width: 50ch;
  font-weight: var(--font-weight-regular);
  letter-spacing: -0.005em;
}

/* Impact Analysis — verdict + metric tiles */
.av2-verdict {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--spacing-5);
  align-items: start;
  margin: var(--spacing-6) 0 0;
  padding: var(--spacing-5) var(--spacing-6);
  background: var(--bg-subtle);
  border: 1px solid var(--border-1);
  border-radius: var(--radius-lg);
}
.av2-verdict__label {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--fg-3);
  margin-bottom: var(--spacing-2);
}
.av2-verdict__stance {
  font-family: var(--font-sans);
  font-size: 1.5rem;
  line-height: 1.25;
  color: var(--fg-1);
  font-weight: var(--font-weight-semibold);
  letter-spacing: -0.015em;
}
.av2-verdict__stance .qualifier { color: var(--fg-3); font-weight: var(--font-weight-medium); }
.av2-verdict__bar {
  width: 4px;
  background: var(--accent);
  border-radius: 2px;
  align-self: stretch;
  min-height: 60px;
}
.av2-verdict__sub {
  margin: var(--spacing-2) 0 0;
  font-size: var(--font-size-sm);
  line-height: 1.55;
  color: var(--fg-2);
  max-width: 64ch;
}

.av2-metric-strip {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 0;
  margin: var(--spacing-6) 0 0;
  border-top: 2px solid var(--color-ink);
  border-bottom: 1px solid var(--border-1);
}
.av2-metric-strip__cell {
  padding: var(--spacing-4) var(--spacing-5) var(--spacing-4) 0;
  border-right: 1px solid var(--border-1);
}
.av2-metric-strip__cell:last-child { border-right: 0; padding-right: 0; }
.av2-metric-strip__label {
  font-size: var(--font-size-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fg-3);
  font-weight: var(--font-weight-semibold);
  margin-bottom: var(--spacing-2);
  line-height: 1.35;
  text-wrap: balance;
}
.av2-metric-strip__value {
  font-family: var(--font-sans);
  font-size: 1.75rem;
  font-weight: var(--font-weight-bold);
  color: var(--fg-1);
  letter-spacing: -0.025em;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.av2-metric-strip__unit {
  margin-left: 4px;
  font-size: var(--font-size-sm);
  color: var(--fg-3);
  font-weight: var(--font-weight-medium);
  letter-spacing: 0;
}

/* Prediction — probability gauge hero */
.av2-prob {
  margin: var(--spacing-8) 0 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: var(--spacing-10);
  align-items: center;
}
.av2-prob__label {
  font-size: var(--font-size-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: var(--font-weight-bold);
  color: var(--fg-3);
  margin-bottom: var(--spacing-2);
}
.av2-prob__qualifier {
  font-size: var(--font-size-sm);
  color: var(--fg-2);
  margin-top: var(--spacing-2);
  max-width: 38ch;
  line-height: 1.55;
}
.av2-prob__big {
  font-family: var(--font-sans);
  font-size: clamp(4rem, 8vw, 6.5rem);
  line-height: 0.95;
  letter-spacing: -0.045em;
  color: var(--accent);
  font-weight: var(--font-weight-black);
  font-variant-numeric: tabular-nums;
  display: flex; align-items: baseline; gap: var(--spacing-2);
}
.av2-prob__big .pct {
  font-size: 0.4em;
  color: var(--fg-3);
  font-weight: var(--font-weight-semibold);
}
.av2-prob__bar {
  position: relative;
  height: 8px;
  background: var(--color-gray-200);
  border-radius: var(--radius-sm);
  margin-top: var(--spacing-5);
  max-width: 420px;
}
.av2-prob__bar-fill {
  position: absolute; left: 0; top: 0; bottom: 0;
  background: var(--accent);
  border-radius: var(--radius-sm);
}
.av2-prob__bar-tick {
  position: absolute;
  top: -8px; bottom: -8px;
  width: 2px;
  background: var(--color-ink);
}
.av2-prob__bar-tick::after {
  content: attr(data-label);
  position: absolute;
  left: 50%;
  top: -22px;
  transform: translateX(-50%);
  font-size: 0.625rem;
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fg-3);
  white-space: nowrap;
}
.av2-prob__scale {
  display: flex; justify-content: space-between;
  margin-top: var(--spacing-2);
  font-size: 0.6875rem;
  color: var(--fg-3);
  font-variant-numeric: tabular-nums;
  max-width: 420px;
  font-weight: var(--font-weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.av2-prob__side {
  display: grid; gap: var(--spacing-4);
  border-left: 1px solid var(--border-1);
  padding-left: var(--spacing-8);
}
.av2-prob__side-row {
  display: grid; grid-template-columns: 1fr auto;
  gap: var(--spacing-3);
  align-items: baseline;
  padding-bottom: var(--spacing-3);
  border-bottom: 1px solid var(--border-1);
}
.av2-prob__side-row:last-child { border-bottom: 0; padding-bottom: 0; }
.av2-prob__side-label { font-size: var(--font-size-xs); color: var(--fg-3); line-height: 1.4; text-transform: uppercase; letter-spacing: 0.08em; font-weight: var(--font-weight-semibold); }
.av2-prob__side-value {
  font-family: var(--font-sans);
  font-size: 1.25rem;
  font-weight: var(--font-weight-bold);
  color: var(--fg-1);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  letter-spacing: -0.01em;
}

/* ---------- body grid ---------- */
.av2-body {
  max-width: 1240px;
  margin: 0 auto;
  padding: var(--spacing-12) var(--spacing-8) 0;
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr) 280px;
  gap: var(--spacing-12);
  align-items: start;
}
@media (max-width: 1239px) {
  /* PR #295 review #5 — when the body grid drops to 2 columns the
     `.av2-keypts` rail must hide too, otherwise CSS Grid auto-flow
     places it at row 2 column 1 directly under the TOC, an unwanted
     visual state in the 1024–1239 range. AGENTS.md cascade: at 1240+
     full 3-col, ≤1239 collapse to 2-col without the callouts rail. */
  .av2-body { grid-template-columns: 200px minmax(0, 1fr); gap: var(--spacing-10); }
  .av2-keypts { display: none; }
}
@media (max-width: 767px) {
  .av2-body { grid-template-columns: 1fr; gap: var(--spacing-8); padding: var(--spacing-8) var(--spacing-6) 0; }
  .av2-toc { display: none; }
}

.av2-toc {
  position: sticky; top: var(--spacing-6);
  font-size: var(--font-size-sm);
  line-height: 1.45;
}
.av2-toc__label {
  font-size: var(--font-size-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: var(--font-weight-bold);
  color: var(--fg-3);
  margin-bottom: var(--spacing-3);
  padding-bottom: var(--spacing-2);
  border-bottom: 1px solid var(--border-1);
}
.av2-toc__list { list-style: none; margin: 0; padding: 0; }
.av2-toc__list li { margin-bottom: var(--spacing-2); }
.av2-toc__list a {
  display: block;
  color: var(--fg-2);
  padding-left: var(--spacing-3);
  border-left: 2px solid transparent;
  transition: border-color var(--transition-fast), color var(--transition-fast);
}
.av2-toc__list a:hover { color: var(--fg-1); text-decoration: none; }
.av2-toc__list a.is-active {
  color: var(--accent);
  border-left-color: var(--accent);
  font-weight: var(--font-weight-semibold);
}

/* ---------- main column ---------- */
.av2-main { max-width: 68ch; }
.av2-section {
  padding: var(--spacing-3) 0 var(--spacing-8);
  border-bottom: 1px solid var(--border-1);
  margin-bottom: var(--spacing-6);
}
.av2-section:last-child { border-bottom: 0; }
.av2-section__num {
  font-size: var(--font-size-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: var(--font-weight-bold);
  color: var(--accent);
  margin-bottom: var(--spacing-2);
  font-variant-numeric: tabular-nums;
}
.av2-section__title {
  font-family: var(--font-sans);
  font-size: var(--font-size-3xl);
  line-height: 1.15;
  color: var(--fg-1);
  font-weight: var(--font-weight-bold);
  letter-spacing: -0.025em;
  margin: 0 0 var(--spacing-4);
  text-wrap: balance;
}
.av2-section h4 {
  font-family: var(--font-sans);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  color: var(--fg-1);
  margin: var(--spacing-6) 0 var(--spacing-2);
  letter-spacing: -0.005em;
}
.av2-section p {
  margin: 0 0 var(--spacing-4);
  font-size: var(--font-size-base);
  line-height: 1.65;
  color: var(--fg-1);
  text-wrap: pretty;
}
.av2-section p:last-child { margin-bottom: 0; }
.av2-section strong { color: var(--fg-1); font-weight: var(--font-weight-semibold); }
.av2-section em { font-style: italic; color: var(--fg-1); }

/* ---------- block: bullet/numbered list ---------- */
.av2-list {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--spacing-5);
}
.av2-list li {
  position: relative;
  padding-left: var(--spacing-6);
  margin-bottom: var(--spacing-2);
  font-size: var(--font-size-base);
  line-height: 1.6;
  color: var(--fg-1);
}
.av2-list--bullet > li::before {
  content: "";
  position: absolute;
  left: 6px; top: 11px;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--accent);
}
.av2-list--numbered { counter-reset: avlist; }
.av2-list--numbered > li {
  padding-left: 38px;
  counter-increment: avlist;
}
.av2-list--numbered > li::before {
  content: counter(avlist);
  position: absolute;
  left: 0; top: 0;
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: var(--font-weight-bold);
  color: #fff;
  background: var(--accent);
  font-variant-numeric: tabular-nums;
  width: 22px; height: 22px;
  border-radius: 50%;
  display: grid; place-items: center;
  margin-top: 4px;
}

/* ---------- block: callout ---------- */
.av2-callout {
  padding: var(--spacing-3) var(--spacing-4);
  margin: 0 0 var(--spacing-5);
  border-radius: var(--radius-md);
  border-left: 3px solid;
  font-size: var(--font-size-sm);
  line-height: 1.55;
}
.av2-callout--warning { background: var(--color-warning-light); border-color: var(--color-warning); color: var(--color-warning-dark); }
.av2-callout--info    { background: var(--accent-light); border-color: var(--accent); color: var(--accent-dark); }
.av2-callout--success { background: var(--color-success-light); border-color: var(--color-success); color: var(--color-success-dark); }
.av2-callout--error   { background: var(--color-error-light); border-color: var(--color-error); color: var(--color-error-dark); }
.av2-callout__label {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-right: var(--spacing-2);
}

/* ---------- block: metrics ---------- */
.av2-metrics {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 0;
  margin: var(--spacing-1) 0 var(--spacing-5);
  border: 1px solid var(--border-1);
  background: var(--bg-page);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.av2-metrics__cell {
  padding: var(--spacing-3) var(--spacing-4);
  border-right: 1px solid var(--border-1);
}
.av2-metrics__cell:last-child { border-right: 0; }
.av2-metrics__label {
  font-size: var(--font-size-xs);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--fg-3);
  font-weight: var(--font-weight-semibold);
  margin-bottom: var(--spacing-2);
  line-height: 1.35;
}
.av2-metrics__value {
  font-family: var(--font-sans);
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  color: var(--fg-1);
  letter-spacing: -0.02em;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.av2-metrics__unit {
  margin-left: 4px;
  font-size: var(--font-size-sm);
  color: var(--fg-3);
  font-weight: var(--font-weight-medium);
  letter-spacing: 0;
}

/* ---------- block: table ---------- */
.av2-table {
  width: 100%;
  border-collapse: collapse;
  margin: var(--spacing-1) 0 var(--spacing-5);
  font-size: var(--font-size-sm);
}
.av2-table th {
  text-align: left;
  padding: var(--spacing-3) var(--spacing-4);
  background: var(--bg-subtle);
  font-size: var(--font-size-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: var(--font-weight-bold);
  color: var(--fg-3);
  border-bottom: 1px solid var(--border-2);
}
.av2-table td {
  padding: var(--spacing-3) var(--spacing-4);
  border-bottom: 1px solid var(--border-1);
  vertical-align: top;
  line-height: 1.5;
  color: var(--fg-1);
}
.av2-table tr:last-child td { border-bottom: 0; }

/* ---------- block: key_value ---------- */
.av2-kv {
  display: grid;
  grid-template-columns: minmax(140px, 30%) 1fr;
  gap: 0;
  margin: var(--spacing-1) 0 var(--spacing-5);
  font-size: var(--font-size-sm);
  border: 1px solid var(--border-1);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.av2-kv__k, .av2-kv__v {
  padding: var(--spacing-3) var(--spacing-4);
  border-bottom: 1px solid var(--border-1);
  line-height: 1.5;
}
.av2-kv__k {
  font-weight: var(--font-weight-semibold);
  color: var(--fg-1);
  background: var(--bg-subtle);
  font-size: var(--font-size-sm);
}
.av2-kv__v { color: var(--fg-1); }
.av2-kv > :nth-last-child(-n+2) { border-bottom: 0; }

/* ---------- right rail: key points ---------- */
.av2-keypts {
  position: sticky; top: var(--spacing-6);
  font-size: var(--font-size-sm);
  line-height: 1.5;
  padding: var(--spacing-5);
  background: var(--bg-page);
  border: 1px solid var(--border-1);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}
.av2-keypts__label {
  font-size: var(--font-size-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: var(--font-weight-bold);
  color: var(--fg-3);
  margin-bottom: var(--spacing-3);
  padding-bottom: var(--spacing-3);
  border-bottom: 1px solid var(--border-1);
}
.av2-keypts__item { padding: var(--spacing-3) 0; border-bottom: 1px solid var(--border-1); }
.av2-keypts__item:last-child { border-bottom: 0; padding-bottom: 0; }
.av2-keypts__tone {
  display: inline-block;
  font-size: 0.6875rem;
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 2px 7px;
  border-radius: 3px;
  margin-bottom: var(--spacing-2);
}
.av2-keypts__tone--warning { background: var(--color-warning-light); color: var(--color-warning-dark); }
.av2-keypts__tone--info    { background: var(--accent-light); color: var(--accent-dark); }
.av2-keypts__tone--success { background: var(--color-success-light); color: var(--color-success-dark); }
.av2-keypts__src {
  margin-top: var(--spacing-2);
  font-size: var(--font-size-xs);
  color: var(--fg-3);
}
.av2-keypts__src a { color: var(--accent); }
.av2-keypts__src a:hover { color: var(--accent-hover); text-decoration: underline; }

/* ---------- inline citations ---------- */
.av2-cite {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: 0.7em;
  font-weight: var(--font-weight-bold);
  vertical-align: super;
  line-height: 1;
  color: var(--accent-dark);
  cursor: pointer;
  margin-left: 1px;
  position: relative;
  border-radius: 3px;
  padding: 1px 4px;
  background: var(--accent-light);
  transition: background var(--transition-fast), color var(--transition-fast);
}
.av2-cite:hover { background: var(--accent); color: #fff; }
.av2-cite__pop {
  position: absolute;
  bottom: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%);
  width: 260px;
  background: var(--color-ink);
  color: #fff;
  padding: var(--spacing-3);
  border-radius: var(--radius-md);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  letter-spacing: 0;
  line-height: 1.45;
  text-align: left;
  text-transform: none;
  box-shadow: var(--shadow-xl);
  pointer-events: none;
  opacity: 0;
  transition: opacity var(--transition-fast);
  z-index: 10;
}
.av2-cite__pop::after {
  content: ""; position: absolute;
  bottom: -5px; left: 50%; transform: translateX(-50%) rotate(45deg);
  width: 8px; height: 8px;
  background: var(--color-ink);
}
.av2-cite:hover .av2-cite__pop { opacity: 1; }

/* ---------- sources section ---------- */
.av2-sources {
  margin-top: var(--spacing-12);
  padding-top: var(--spacing-6);
  border-top: 2px solid var(--color-ink);
}
.av2-sources__label {
  font-size: var(--font-size-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: var(--font-weight-bold);
  color: var(--fg-3);
  margin-bottom: var(--spacing-5);
}
.av2-sources__list {
  list-style: none; margin: 0; padding: 0;
  font-size: var(--font-size-sm);
  line-height: 1.5;
}
.av2-sources__list li {
  display: grid;
  grid-template-columns: 30px 1fr;
  gap: var(--spacing-2);
  padding: var(--spacing-3) 0;
  border-bottom: 1px solid var(--border-1);
}
.av2-sources__list li:last-child { border-bottom: 0; }
.av2-sources__num {
  font-family: var(--font-mono);
  font-weight: var(--font-weight-bold);
  color: var(--accent);
  font-size: var(--font-size-sm);
  font-variant-numeric: tabular-nums;
}
.av2-sources__text { color: var(--fg-2); }
/* SUR-1783: publisher attribution rendered alongside the resolved
   source title (e.g. "Reuters"). Italicised + muted so the title
   stays the primary visual anchor. */
.av2-sources__publisher {
  font-style: italic;
  color: var(--fg-3, var(--fg-2));
  margin-left: var(--spacing-1);
}


/* =================================================================
   HERO VARIANTS — added for the 10 remaining analysis types.
   Three families, all consume the same design-system tokens.
   ================================================================= */

/* ---------- Family 1: STAT HEROES ---------- */

/* Procedural Viability — verdict lede + 4-up score grid */
.av2-rubric {
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: var(--spacing-8);
  align-items: end;
  padding: var(--spacing-8) 0 var(--spacing-6);
  border-bottom: 1px solid var(--border-2);
  margin-bottom: var(--spacing-6);
}
@media (max-width: 900px) { .av2-rubric { grid-template-columns: 1fr; } }
.av2-rubric__label {
  font-size: var(--font-size-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: var(--font-weight-bold);
  color: var(--fg-3);
  margin-bottom: var(--spacing-3);
}
.av2-rubric__verdict {
  font-family: var(--font-sans);
  font-size: 1.4rem;
  line-height: 1.3;
  letter-spacing: -0.01em;
  color: var(--fg-1);
  margin: 0;
  text-wrap: balance;
}
.av2-rubric__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--spacing-1);
  background: var(--border-1);
  border: 1px solid var(--border-1);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.av2-rubric__cell {
  background: var(--bg-page);
  padding: var(--spacing-4) var(--spacing-5);
}
.av2-rubric__cell-val {
  font-family: var(--font-sans);
  font-weight: var(--font-weight-bold);
  font-size: 1.75rem;
  line-height: 1;
  color: var(--accent);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.02em;
  margin-bottom: var(--spacing-2);
}
.av2-rubric__cell-unit {
  font-size: 0.65em;
  color: var(--fg-3);
  font-weight: var(--font-weight-semibold);
  margin-left: 4px;
  display: inline-block;
  max-width: 100%;
  overflow-wrap: anywhere;
}
.av2-rubric__cell-lbl {
  font-size: var(--font-size-xs);
  color: var(--fg-3);
  font-weight: var(--font-weight-medium);
  line-height: 1.3;
  text-wrap: balance;
}

/* Whip Count Analysis — 5-segment chamber bar */
.av2-whip {
  padding: var(--spacing-6) 0;
  border-top: 2px solid var(--color-ink);
  border-bottom: 1px solid var(--border-2);
  margin-top: var(--spacing-6);
  margin-bottom: var(--spacing-6);
}
.av2-whip__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: var(--spacing-4);
  gap: var(--spacing-6);
}
.av2-whip__label {
  font-size: var(--font-size-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: var(--font-weight-bold);
  color: var(--fg-3);
  margin-bottom: var(--spacing-1);
}
.av2-whip__chamber {
  font-size: 1.1rem;
  font-weight: var(--font-weight-semibold);
  color: var(--fg-1);
}
.av2-whip__threshold {
  text-align: right;
  border-left: 1px solid var(--border-1);
  padding-left: var(--spacing-5);
}
.av2-whip__threshold-num {
  font-family: var(--font-sans);
  font-weight: var(--font-weight-bold);
  font-size: 1.75rem;
  line-height: 1;
  color: var(--color-ink);
  font-variant-numeric: tabular-nums;
}
.av2-whip__threshold-lbl {
  font-size: var(--font-size-xs);
  color: var(--fg-3);
  margin-top: var(--spacing-1);
}
.av2-whip__bar {
  display: flex;
  height: 36px;
  border-radius: 4px;
  overflow: hidden;
  border: 1px solid var(--border-2);
  background: var(--bg-subtle);
}
.av2-whip__seg {
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-sans);
  font-weight: var(--font-weight-bold);
  font-size: 0.875rem;
  color: #fff;
  font-variant-numeric: tabular-nums;
  border-right: 1px solid rgba(255,255,255,0.3);
}
.av2-whip__seg:last-child { border-right: 0; }
.av2-whip__seg--0 { background: var(--color-success-dark); }
.av2-whip__seg--1 { background: var(--color-success); }
.av2-whip__seg--2 { background: var(--color-gray-400); color: var(--color-ink); }
.av2-whip__seg--3 { background: var(--color-warning); color: var(--color-ink); }
.av2-whip__seg--4 { background: var(--color-error); }
.av2-whip__legend {
  display: flex;
  gap: var(--spacing-5);
  flex-wrap: wrap;
  margin-top: var(--spacing-3);
  font-size: var(--font-size-sm);
  color: var(--fg-2);
}
.av2-whip__leg {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-2);
}
.av2-whip__sw {
  display: inline-block;
  width: 12px; height: 12px;
  border-radius: 2px;
}
.av2-whip__sw--0 { background: var(--color-success-dark); }
.av2-whip__sw--1 { background: var(--color-success); }
.av2-whip__sw--2 { background: var(--color-gray-400); }
.av2-whip__sw--3 { background: var(--color-warning); }
.av2-whip__sw--4 { background: var(--color-error); }
.av2-whip__note {
  margin: var(--spacing-5) 0 0;
  font-size: var(--font-size-base);
  line-height: 1.55;
  color: var(--fg-2);
  max-width: 72ch;
}

/* Whip Count Feasibility — composite gauge */
.av2-feas {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: var(--spacing-10);
  padding: var(--spacing-8) 0;
  border-top: 2px solid var(--color-ink);
  border-bottom: 1px solid var(--border-2);
  margin-top: var(--spacing-6);
  margin-bottom: var(--spacing-6);
  align-items: start;
}
@media (max-width: 900px) { .av2-feas { grid-template-columns: 1fr; } }
.av2-feas__label {
  font-size: var(--font-size-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: var(--font-weight-bold);
  color: var(--fg-3);
  margin-bottom: var(--spacing-2);
}
.av2-feas__score {
  display: flex;
  align-items: baseline;
  gap: var(--spacing-2);
  margin-bottom: var(--spacing-4);
}
.av2-feas__num {
  font-family: var(--font-sans);
  font-weight: var(--font-weight-bold);
  font-size: clamp(4rem, 8vw, 6.5rem);
  line-height: 0.95;
  color: var(--accent);
  letter-spacing: -0.04em;
  font-variant-numeric: tabular-nums;
}
.av2-feas__den {
  font-family: var(--font-sans);
  font-weight: var(--font-weight-semibold);
  font-size: 1.5rem;
  color: var(--fg-3);
}
.av2-feas__gauge {
  position: relative;
  height: 10px;
  background: var(--bg-muted);
  border-radius: var(--radius-sm);
  overflow: visible;
  max-width: 480px;
}
.av2-feas__gauge-fill {
  position: absolute; left: 0; top: 0; bottom: 0;
  background: var(--accent);
  border-radius: var(--radius-sm);
}
.av2-feas__tick {
  position: absolute;
  top: -3px; bottom: -3px;
  width: 1px;
  background: var(--bg-page);
}
.av2-feas__scale {
  display: flex;
  justify-content: space-between;
  margin-top: var(--spacing-2);
  max-width: 480px;
  font-size: var(--font-size-xs);
  color: var(--fg-3);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.av2-feas__qualifier {
  margin: var(--spacing-5) 0 0;
  font-size: var(--font-size-base);
  line-height: 1.55;
  color: var(--fg-2);
  max-width: 64ch;
}
.av2-feas__side {
  display: grid;
  gap: var(--spacing-4);
  border-left: 1px solid var(--border-1);
  padding-left: var(--spacing-6);
}
.av2-feas__side-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--spacing-3);
  align-items: baseline;
  padding-bottom: var(--spacing-3);
  border-bottom: 1px solid var(--border-1);
}
.av2-feas__side-row:last-child { border-bottom: 0; padding-bottom: 0; }
.av2-feas__side-label {
  font-size: var(--font-size-xs);
  color: var(--fg-3);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: var(--font-weight-semibold);
  line-height: 1.4;
}
.av2-feas__side-value {
  font-family: var(--font-sans);
  font-weight: var(--font-weight-bold);
  font-size: 1.25rem;
  color: var(--fg-1);
  font-variant-numeric: tabular-nums;
}

/* Impact Perspective — first-person stake card */
.av2-stake {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: var(--spacing-8);
  padding: var(--spacing-7) var(--spacing-8);
  background: var(--bg-subtle);
  border-radius: var(--radius-lg);
  margin: var(--spacing-6) 0;
  align-items: start;
}
@media (max-width: 900px) { .av2-stake { grid-template-columns: 1fr; } }
.av2-stake__verdict {
  position: relative;
  padding-left: var(--spacing-8);
}
.av2-stake__quote-mark {
  position: absolute;
  left: -8px; top: -16px;
  font-family: var(--font-sans);
  font-size: 5rem;
  line-height: 1;
  color: var(--accent);
  font-weight: var(--font-weight-bold);
}
.av2-stake__text {
  font-family: var(--font-sans);
  font-size: 1.4rem;
  line-height: 1.4;
  color: var(--fg-1);
  letter-spacing: -0.01em;
  margin: 0 0 var(--spacing-3);
  text-wrap: pretty;
}
.av2-stake__attrib {
  font-size: var(--font-size-xs);
  color: var(--fg-3);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: var(--font-weight-semibold);
}
.av2-stake__numbers {
  border-left: 1px solid var(--border-1);
  padding-left: var(--spacing-6);
}
.av2-stake__numbers-label {
  font-size: var(--font-size-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: var(--font-weight-bold);
  color: var(--fg-3);
  margin-bottom: var(--spacing-3);
}
.av2-stake__numbers-grid {
  display: grid;
  gap: var(--spacing-3);
}
.av2-stake__num-cell {
  padding: var(--spacing-3) 0;
  border-bottom: 1px solid var(--border-1);
}
.av2-stake__num-cell:last-child { border-bottom: 0; }
.av2-stake__num-val {
  font-family: var(--font-sans);
  font-weight: var(--font-weight-bold);
  font-size: 1.5rem;
  line-height: 1;
  color: var(--fg-1);
  font-variant-numeric: tabular-nums;
  margin-bottom: var(--spacing-1);
}
.av2-stake__num-unit {
  font-size: 0.65em;
  color: var(--fg-3);
  font-weight: var(--font-weight-semibold);
  margin-left: 4px;
  display: inline-block;
  max-width: 100%;
  overflow-wrap: anywhere;
}
.av2-stake__num-lbl {
  font-size: var(--font-size-xs);
  color: var(--fg-3);
  line-height: 1.3;
}

/* K Street Scorecard — provision rail */
.av2-scorecard {
  padding: var(--spacing-6) 0;
  border-top: 2px solid var(--color-ink);
  border-bottom: 1px solid var(--border-2);
  margin-top: var(--spacing-6);
  margin-bottom: var(--spacing-6);
}
.av2-scorecard__head {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: var(--spacing-8);
  margin-bottom: var(--spacing-5);
  align-items: end;
}
@media (max-width: 900px) { .av2-scorecard__head { grid-template-columns: 1fr; gap: var(--spacing-3); } }
.av2-scorecard__label {
  font-size: var(--font-size-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: var(--font-weight-bold);
  color: var(--fg-3);
  margin-bottom: var(--spacing-1);
}
.av2-scorecard__sub {
  font-family: var(--font-sans);
  font-weight: var(--font-weight-semibold);
  font-size: 1.25rem;
  color: var(--fg-1);
  font-variant-numeric: tabular-nums;
}
.av2-scorecard__sub strong { color: var(--accent); }
.av2-scorecard__summary {
  margin: 0;
  font-size: var(--font-size-base);
  line-height: 1.55;
  color: var(--fg-2);
}
.av2-scorecard__list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.av2-scorecard__row {
  display: grid;
  grid-template-columns: 32px 1fr 120px 60px;
  gap: var(--spacing-4);
  align-items: center;
  padding: var(--spacing-3) 0;
  border-bottom: 1px solid var(--border-1);
}
.av2-scorecard__row:last-child { border-bottom: 0; }
.av2-scorecard__rank {
  font-family: var(--font-mono);
  font-size: var(--font-size-xs);
  color: var(--fg-3);
  font-weight: var(--font-weight-bold);
  font-variant-numeric: tabular-nums;
}
.av2-scorecard__name {
  font-size: var(--font-size-sm);
  color: var(--fg-1);
  line-height: 1.4;
}
.av2-scorecard__dots {
  display: inline-flex;
  gap: 4px;
}
.av2-scorecard__dot {
  width: 16px;
  height: 8px;
  background: var(--bg-muted);
  border-radius: 2px;
}
.av2-scorecard__dot.is-on { background: var(--accent); }
.av2-scorecard__score {
  font-family: var(--font-sans);
  font-weight: var(--font-weight-bold);
  font-size: 1.125rem;
  color: var(--fg-1);
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.av2-scorecard__score .den {
  font-size: 0.65em;
  color: var(--fg-3);
  font-weight: var(--font-weight-semibold);
}

/* ---------- Family 2: SPECTRUM HEROES ---------- */

/* Overton — 7-band horizontal window */
.av2-overton {
  padding: var(--spacing-6) 0;
  border-top: 2px solid var(--color-ink);
  border-bottom: 1px solid var(--border-2);
  margin-top: var(--spacing-6);
  margin-bottom: var(--spacing-6);
}
.av2-overton__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: var(--spacing-5);
  gap: var(--spacing-6);
}
.av2-overton__label {
  font-size: var(--font-size-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: var(--font-weight-bold);
  color: var(--fg-3);
}
.av2-overton__verdict {
  font-family: var(--font-sans);
  font-weight: var(--font-weight-semibold);
  font-size: 1.25rem;
  color: var(--fg-1);
  text-align: right;
  line-height: 1.3;
}
.av2-overton__drift {
  color: var(--accent);
  font-weight: var(--font-weight-bold);
}
.av2-overton__track {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1.4fr 1.4fr 1fr 1fr;
  height: 56px;
  border-radius: 4px;
  overflow: hidden;
  margin-bottom: var(--spacing-3);
}
.av2-overton__band {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: var(--font-weight-semibold);
  color: var(--fg-2);
}
.av2-overton__band--0 { background: #fee2e2; }
.av2-overton__band--1 { background: #fed7aa; }
.av2-overton__band--2 { background: #fef3c7; }
.av2-overton__band--3 { background: #dcfce7; }
.av2-overton__band--4 { background: #bbf7d0; }
.av2-overton__band--5 { background: #d1fae5; }
.av2-overton__band--6 { background: #a7f3d0; color: var(--fg-1); }
.av2-overton__pos {
  position: absolute;
  top: -8px; bottom: -8px;
  z-index: 2;
}
.av2-overton__pos-tick {
  position: absolute;
  left: -2px; top: 0; bottom: 0;
  width: 4px;
  background: var(--color-ink);
  border-radius: 2px;
  box-shadow: 0 0 0 3px var(--bg-page);
}
.av2-overton__pos-lbl {
  position: absolute;
  top: -22px;
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-ink);
  background: var(--bg-page);
  padding: 0 6px;
}
.av2-overton__proj {
  position: absolute;
  top: 50%; transform: translateY(-50%);
  height: 2px;
  background: var(--color-ink);
  z-index: 1;
  opacity: 0.6;
}
.av2-overton__proj-arrow {
  position: absolute;
  right: -8px; top: -4px;
  width: 0; height: 0;
  border-left: 8px solid var(--color-ink);
  border-top: 5px solid transparent;
  border-bottom: 5px solid transparent;
  opacity: 0.6;
}
.av2-overton__note {
  margin: var(--spacing-6) 0 0;
  font-size: var(--font-size-base);
  line-height: 1.55;
  color: var(--fg-2);
  max-width: 72ch;
}

/* Narrative Reception — sentiment meter */
.av2-reception {
  padding: var(--spacing-6) 0;
  border-top: 2px solid var(--color-ink);
  border-bottom: 1px solid var(--border-2);
  margin-top: var(--spacing-6);
  margin-bottom: var(--spacing-6);
}
.av2-reception__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: var(--spacing-5);
  gap: var(--spacing-6);
}
.av2-reception__label {
  font-size: var(--font-size-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: var(--font-weight-bold);
  color: var(--fg-3);
}
.av2-reception__verdict {
  font-family: var(--font-sans);
  font-weight: var(--font-weight-semibold);
  font-size: 1.25rem;
  color: var(--accent);
}
.av2-reception__meter {
  position: relative;
  height: 12px;
  border-radius: var(--radius-sm);
  overflow: visible;
  margin-bottom: var(--spacing-2);
}
.av2-reception__gradient {
  position: absolute; inset: 0;
  border-radius: var(--radius-sm);
  background: linear-gradient(
    to right,
    var(--color-error) 0%,
    var(--color-warning) 30%,
    var(--color-gray-400) 50%,
    var(--color-success) 75%,
    var(--color-success-dark) 100%
  );
  opacity: 0.85;
}
.av2-reception__pos {
  position: absolute;
  top: -6px; bottom: -6px;
  width: 4px;
  background: var(--color-ink);
  border-radius: 2px;
  transform: translateX(-50%);
  box-shadow: 0 0 0 3px var(--bg-page);
}
.av2-reception__scale {
  display: flex;
  justify-content: space-between;
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--fg-3);
  font-weight: var(--font-weight-medium);
  margin-bottom: var(--spacing-5);
}
.av2-reception__quote {
  margin: 0;
  padding-left: var(--spacing-5);
  border-left: 3px solid var(--accent);
  font-family: var(--font-sans);
  font-size: 1.15rem;
  line-height: 1.5;
  color: var(--fg-1);
  font-style: italic;
  max-width: 72ch;
  text-wrap: pretty;
}

/* ---------- Family 3: VOICE HEROES ---------- */

/* Identity-Group — profile + stance */
.av2-identity {
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: var(--spacing-8);
  padding: var(--spacing-7) var(--spacing-8);
  background: var(--bg-subtle);
  border-radius: var(--radius-lg);
  margin: var(--spacing-6) 0;
  align-items: start;
}
@media (max-width: 900px) { .av2-identity { grid-template-columns: 1fr; } }
.av2-identity__profile {
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: var(--spacing-4);
  align-items: start;
}
.av2-identity__avatar {
  width: 64px; height: 64px;
  border-radius: 50%;
  background: var(--accent);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-sans);
  font-weight: var(--font-weight-bold);
  font-size: 1.25rem;
  letter-spacing: 0.05em;
}
.av2-identity__profile-label {
  font-size: var(--font-size-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: var(--font-weight-bold);
  color: var(--fg-3);
  margin-bottom: var(--spacing-2);
}
.av2-identity__name {
  font-family: var(--font-sans);
  font-weight: var(--font-weight-bold);
  font-size: 1.25rem;
  color: var(--fg-1);
  line-height: 1.2;
  margin-bottom: var(--spacing-3);
  letter-spacing: -0.01em;
}
.av2-identity__attrs {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-2);
}
.av2-identity__attr {
  font-size: 0.7rem;
  font-weight: var(--font-weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--fg-2);
  background: var(--bg-page);
  border: 1px solid var(--border-1);
  border-radius: 999px;
  padding: 3px 10px;
}
.av2-identity__stance {
  margin: 0;
  border-left: 3px solid var(--accent);
  padding-left: var(--spacing-5);
  font-family: var(--font-sans);
  font-size: 1.15rem;
  line-height: 1.5;
  color: var(--fg-1);
  font-style: italic;
  text-wrap: pretty;
}

/* Kitchen-Table — big editorial pull-quote */
.av2-kitchen {
  position: relative;
  padding: var(--spacing-9) 0 var(--spacing-7);
  border-top: 2px solid var(--color-ink);
  border-bottom: 1px solid var(--border-2);
  margin-top: var(--spacing-6);
  margin-bottom: var(--spacing-6);
  text-align: left;
}
.av2-kitchen__mark {
  font-family: var(--font-sans);
  font-size: 7rem;
  line-height: 0.8;
  color: var(--accent);
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--spacing-2);
}
.av2-kitchen__quote {
  font-family: var(--font-sans);
  font-size: clamp(1.5rem, 3vw, 2.25rem);
  line-height: 1.25;
  color: var(--fg-1);
  letter-spacing: -0.02em;
  margin: 0 0 var(--spacing-6);
  font-weight: var(--font-weight-medium);
  max-width: 30ch;
  text-wrap: balance;
}
.av2-kitchen__attrib {
  display: flex;
  align-items: baseline;
  gap: var(--spacing-3);
  padding-top: var(--spacing-4);
  border-top: 1px solid var(--border-1);
  max-width: 30ch;
}
.av2-kitchen__attrib-name {
  font-family: var(--font-sans);
  font-weight: var(--font-weight-bold);
  font-size: var(--font-size-base);
  color: var(--fg-1);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.av2-kitchen__attrib-bill {
  font-size: var(--font-size-sm);
  color: var(--fg-3);
  font-style: italic;
}

/* Values-Driven — single-word kicker + connection */
.av2-values {
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: var(--spacing-10);
  padding: var(--spacing-8) 0;
  border-top: 2px solid var(--color-ink);
  border-bottom: 1px solid var(--border-2);
  margin-top: var(--spacing-6);
  margin-bottom: var(--spacing-6);
  align-items: start;
}
@media (max-width: 900px) { .av2-values { grid-template-columns: 1fr; gap: var(--spacing-6); } }
.av2-values__kicker {
  container-type: inline-size;
  container-name: av2-values-kicker;
  border-right: 1px solid var(--border-1);
  padding-right: var(--spacing-6);
}
@media (max-width: 900px) { .av2-values__kicker { border-right: 0; padding-right: 0; border-bottom: 1px solid var(--border-1); padding-bottom: var(--spacing-5); } }
.av2-values__kicker-label {
  font-size: var(--font-size-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: var(--font-weight-bold);
  color: var(--fg-3);
  margin-bottom: var(--spacing-3);
}
.av2-values__kicker-word {
  font-family: var(--font-sans);
  font-weight: var(--font-weight-bold);
  /* SUR-2124: container-query-relative cap so long tokens shrink inside the
     fixed kicker column; --kicker-chars is set inline from the template. */
  font-size: clamp(
    1.35rem,
    calc(88cqi / max(var(--kicker-chars, 10), 6)),
    min(4rem, 26cqi)
  );
  line-height: 0.95;
  color: var(--accent);
  letter-spacing: -0.03em;
  text-transform: uppercase;
  text-wrap: balance;
  max-width: 100%;
  overflow-wrap: anywhere;
  hyphens: auto;
}
@media (min-width: 901px) {
  .av2-values__kicker-word {
    text-wrap: nowrap;
    hyphens: manual;
  }
}
.av2-values__connection-label {
  font-size: var(--font-size-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: var(--font-weight-bold);
  color: var(--fg-3);
  margin-bottom: var(--spacing-3);
}
.av2-values__connection-text {
  margin: 0;
  font-family: var(--font-sans);
  font-size: 1.25rem;
  line-height: 1.45;
  color: var(--fg-1);
  letter-spacing: -0.01em;
  text-wrap: pretty;
}

/* =================================================================
   SUR-1772 — mobile / responsive cascade.

   Breakpoint table (matches docs/design/analysis-page-v2/README.md):
     1240+:    full 3-col body (TOC, main, key callouts)
     1024-1239: gap reduced — 2-col body, key callouts hide
     768-1023: 2-col body still (TOC + main)
     640-767:  single-col body, TOC hides
     <=639:    single-col body, dense small-screen tweaks below

   Sources-on-mobile strategy: Option A (CSS-only). Citation chips
   keep their span.av2-cite hook; analysis-page.js intercepts the
   click and smooth-scrolls to the matching #src-N entry in the
   bottom Sources list. `scroll-behavior: smooth` here is the
   anchor-jump fallback for browsers that bypass the JS handler.

   No new av2-* class names — every selector reuses an existing
   one from the chassis above. No new CSS custom property — all
   sizing references --spacing-*, --font-size-*, etc.
   ================================================================= */

/* Smooth-scroll for anchor jumps, including JS-triggered chip taps. */
html { scroll-behavior: smooth; }

/* Hero crumbs: wrap below ~480px so the type chip never punches
   off the viewport on iPhone-class screens. */
@media (max-width: 480px) {
  .av2-hero__crumbs { flex-wrap: wrap; }
  .av2-hero__crumbs-spacer { display: none; }
}

/* Spectrum scale labels shrink and the meter scrolls horizontally
   below 500px — the scale text otherwise wraps onto two lines and
   visually breaks the gradient meter. */
@media (max-width: 500px) {
  .av2-reception__scale,
  .av2-feas__scale {
    font-size: 0.65rem;
    letter-spacing: 0.04em;
  }
  .av2-reception,
  .av2-feas,
  .av2-overton {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}

/* Single-column metrics + collapsed hero meta strip + breathing room
   on chip-style tap targets at <=640px. */
@media (max-width: 640px) {
  .av2-metrics,
  .av2-metric-strip {
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  }
  .av2-meta {
    grid-template-columns: 1fr;
    gap: var(--spacing-3);
    align-items: start;
  }
  .av2-meta__dates { gap: var(--spacing-4); }
  .av2-hero {
    padding: var(--spacing-8) var(--spacing-6) var(--spacing-6);
  }
  /* Cite chips become tap-target-sized at mobile (>= 44 x 44 px to
     satisfy WCAG 2.5.5 / Apple HIG); font-size stays superscript-sized
     so the chip still reads as a marker, not a button. */
  .av2-cite {
    min-width: 44px;
    min-height: 44px;
    padding: 6px 10px;
    font-size: 0.85em;
  }
}
