/* ============================================================
   Outside-In E-Commerce Diagnostic — Kyle Hawke
   Visual identity: precise, slightly technical. UX-audit tearsheet.
   ============================================================ */

:root {
  --bg:        #f6f3ec;   /* off-white linen */
  --bg-card:   #ffffff;
  --bg-code:   #1f1d1a;
  --ink:       #1a1714;   /* near-black charcoal */
  --ink-2:     #4a443c;
  --ink-3:     #7c7468;
  --rule:      #d6cebb;
  --accent:    #c4452d;   /* signal red */
  --accent-2:  #b8881c;   /* amber */
  --good:      #2c6f43;
  --bad:       #b8331a;
  --partial:   #8a7a2a;

  --serif:     'Tiempos Text','Source Serif Pro',Charter,Georgia,serif;
  --sans:      'IBM Plex Sans','Inter',-apple-system,system-ui,sans-serif;
  --mono:      'JetBrains Mono','IBM Plex Mono','SF Mono',Menlo,monospace;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--sans);
  background: var(--bg);
  color: var(--ink);
  line-height: 1.5;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
}

a { color: var(--accent); text-decoration: none; border-bottom: 1px solid currentColor; }
a:hover { color: var(--ink); }

.container {
  max-width: 1120px;
  margin: 0 auto;
  padding: 0 32px;
}

/* ─── Header ─────────────────────────────────────────────── */
.site-header {
  border-bottom: 1px solid var(--rule);
  padding: 22px 0 18px;
  background: var(--bg);
  position: sticky; top: 0; z-index: 50;
  backdrop-filter: blur(8px);
  background: rgba(246, 243, 236, 0.92);
}
.site-header .container { display: flex; align-items: baseline; justify-content: space-between; gap: 24px; }
.brand {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-2);
}
.brand strong { color: var(--ink); }
.site-nav { display: flex; gap: 22px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; }
.site-nav a { border: 0; color: var(--ink-2); }
.site-nav a:hover { color: var(--accent); }

/* ─── Hero ───────────────────────────────────────────────── */
.hero { padding: 96px 0 72px; border-bottom: 1px solid var(--rule); }
.eyebrow {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--accent); margin-bottom: 28px;
}
.hero h1 {
  font-family: var(--serif);
  font-size: 64px; line-height: 1.04;
  font-weight: 400; letter-spacing: -0.02em;
  margin: 0 0 28px; max-width: 920px;
  text-wrap: balance;
}
.hero .lede {
  font-family: var(--serif); font-size: 22px; line-height: 1.5;
  color: var(--ink-2); max-width: 760px; margin: 0 0 40px;
}
.hero-meta {
  display: flex; gap: 48px; flex-wrap: wrap;
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.08em;
  color: var(--ink-3); text-transform: uppercase;
}
.hero-meta b { color: var(--ink); font-weight: 600; }

/* ─── Section ────────────────────────────────────────────── */
section.section { padding: 80px 0; border-bottom: 1px solid var(--rule); }
section.section.dim { background: linear-gradient(180deg, var(--bg) 0%, #efeadd 100%); }

.section-label {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--accent-2);
  display: flex; align-items: center; gap: 16px; margin-bottom: 22px;
}
.section-label::before {
  content: ''; width: 28px; height: 1px; background: var(--accent-2);
}

h2.section-h {
  font-family: var(--serif); font-size: 40px; line-height: 1.12;
  letter-spacing: -0.015em; font-weight: 400; margin: 0 0 22px;
  max-width: 820px; text-wrap: balance;
}
.section-dek {
  font-family: var(--serif); font-size: 19px; line-height: 1.55;
  color: var(--ink-2); max-width: 740px; margin: 0 0 44px;
}

/* ─── The 5-layer stack table ───────────────────────────── */
.stack-table {
  width: 100%; border-collapse: collapse;
  font-family: var(--sans); font-size: 14px;
  background: var(--bg-card); border: 1px solid var(--rule);
}
.stack-table th, .stack-table td {
  padding: 14px 18px; text-align: left;
  border-bottom: 1px solid var(--rule);
  vertical-align: top;
}
.stack-table th {
  font-family: var(--mono); font-size: 10.5px;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--ink-3); font-weight: 500;
  border-bottom: 1px solid var(--ink);
}
.stack-table tbody tr:last-child td { border-bottom: 0; }
.stack-table td.layer-n {
  font-family: var(--mono); color: var(--accent);
  font-weight: 600; width: 56px;
}
.stack-table td.layer-tool { font-family: var(--mono); font-size: 12.5px; color: var(--ink); }
.stack-table td.layer-time { font-family: var(--mono); font-size: 12px; color: var(--ink-3); white-space: nowrap; }
.stack-foot {
  margin-top: 22px;
  font-family: var(--mono); font-size: 12px;
  letter-spacing: 0.06em; color: var(--ink-2);
}
.stack-foot b { color: var(--ink); }
.stack-foot .sep { margin: 0 14px; color: var(--rule); }

/* ─── Code blocks ───────────────────────────────────────── */
.code {
  background: var(--bg-code);
  color: #e9e4d7;
  font-family: var(--mono); font-size: 12.5px; line-height: 1.6;
  padding: 22px 26px;
  border-radius: 4px;
  overflow-x: auto;
  margin: 24px 0;
}
.code .cmt { color: #8b8478; }
.code .kw  { color: #d6a85a; }
.code .str { color: #9bbf76; }
.code .fn  { color: #82b0d2; }

/* ─── Funnel viz ────────────────────────────────────────── */
.funnel-grid {
  display: grid; grid-template-columns: 1fr;
  gap: 18px; margin: 32px 0 24px;
}
.funnel-row {
  background: var(--bg-card); border: 1px solid var(--rule);
  padding: 18px 22px;
}
.funnel-row__hdr {
  display: flex; justify-content: space-between; align-items: baseline;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--ink-3); margin-bottom: 14px;
}
.funnel-row__hdr .clicks { color: var(--ink); font-size: 13px; font-weight: 600; }
.funnel-row__hdr .clicks.high { color: var(--accent); }
.funnel-steps {
  display: flex; gap: 8px; flex-wrap: wrap; align-items: center;
}
.step {
  font-family: var(--mono); font-size: 11.5px;
  padding: 6px 10px; border: 1px solid var(--rule);
  background: var(--bg); color: var(--ink);
  white-space: nowrap;
}
.step.friction { background: #fceee9; border-color: var(--accent); color: var(--accent); }
.step-arrow { color: var(--ink-3); font-family: var(--mono); }
.funnel-row__frictions {
  margin-top: 12px; padding-top: 12px; border-top: 1px dashed var(--rule);
  display: flex; flex-wrap: wrap; gap: 18px;
  font-family: var(--mono); font-size: 11px; color: var(--accent);
}
.funnel-row__provenance {
  margin-top: 10px; font-family: var(--mono); font-size: 10.5px;
  color: var(--ink-3); font-style: italic;
}

/* ─── Peer-set toggle ───────────────────────────────────── */
.peerset {
  background: var(--bg-card); border: 1px solid var(--rule);
  padding: 22px 26px; margin: 28px 0 36px;
}
.peerset__hdr {
  display: flex; justify-content: space-between; align-items: baseline;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--ink-3); margin-bottom: 16px;
}
.peerset__presets { display: flex; gap: 10px; flex-wrap: wrap; }
.preset-btn {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.04em;
  padding: 5px 11px; border: 1px solid var(--rule); background: var(--bg);
  color: var(--ink-2); cursor: pointer;
}
.preset-btn:hover { color: var(--ink); border-color: var(--ink-2); }
.preset-btn.is-active { background: var(--ink); color: #fff; border-color: var(--ink); }

.peerset__brands {
  display: flex; gap: 8px; flex-wrap: wrap; margin-top: 14px;
}
.peer-chip {
  font-family: var(--mono); font-size: 11.5px;
  padding: 5px 11px; border: 1px solid var(--rule); background: var(--bg);
  color: var(--ink-3); cursor: pointer; user-select: none;
}
.peer-chip.is-on { background: var(--ink); color: #fff; border-color: var(--ink); }
.peer-chip:hover { border-color: var(--ink-2); }

/* ─── Stat row (BSET vs peer median) ────────────────────── */
.stat-row {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 1px; background: var(--rule);
  border: 1px solid var(--rule); margin: 28px 0;
}
.stat-cell { background: var(--bg-card); padding: 22px 22px; }
.stat-cell__label {
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--ink-3); margin-bottom: 10px;
}
.stat-cell__bset {
  font-family: var(--serif); font-size: 30px; line-height: 1; font-weight: 400;
  color: var(--ink); margin-bottom: 8px;
}
.stat-cell__bset.lag { color: var(--accent); }
.stat-cell__compare {
  font-family: var(--mono); font-size: 11.5px; color: var(--ink-2);
}
.stat-cell__compare b { color: var(--ink); }

/* ─── Feature matrix ────────────────────────────────────── */
.matrix-wrap { overflow-x: auto; margin: 28px 0; border: 1px solid var(--rule); }
.matrix {
  border-collapse: collapse; width: 100%; min-width: 920px;
  background: var(--bg-card);
}
.matrix th, .matrix td {
  padding: 10px 12px; text-align: center; border-bottom: 1px solid var(--rule);
  font-family: var(--mono); font-size: 12px;
}
.matrix th { background: var(--bg); border-bottom: 1px solid var(--ink); }
.matrix th.feature-col, .matrix td.feature-col {
  text-align: left; min-width: 230px; padding-left: 18px;
  font-family: var(--sans); font-size: 13.5px; color: var(--ink);
}
.matrix td.cell-y { color: var(--good); font-weight: 700; }
.matrix td.cell-p { color: var(--partial); font-weight: 600; }
.matrix td.cell-n { color: var(--bad); opacity: 0.45; }
.matrix .totals td { font-weight: 700; background: var(--bg); color: var(--ink); border-top: 1px solid var(--ink); }
.matrix th.bset, .matrix td.bset { background: #fdf6e9; }

/* ─── Keyword table ────────────────────────────────────── */
.kw-wrap { overflow-x: auto; margin: 24px 0; border: 1px solid var(--rule); }
.kw { border-collapse: collapse; width: 100%; min-width: 900px; background: var(--bg-card); }
.kw th, .kw td {
  padding: 8px 11px; border-bottom: 1px solid var(--rule);
  font-family: var(--mono); font-size: 11.5px; text-align: center;
}
.kw th { background: var(--bg); font-size: 10.5px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-3); border-bottom: 1px solid var(--ink); }
.kw td.kw-col { text-align: left; min-width: 200px; font-family: var(--sans); font-size: 13px; color: var(--ink); }
.kw td.rank-strong { color: var(--good); font-weight: 700; }
.kw td.rank-mod { color: var(--ink); }
.kw td.rank-weak { color: var(--bad); opacity: 0.6; }
.kw td.rank-absent { color: var(--ink-3); opacity: 0.4; }
.kw th.bset, .kw td.bset { background: #fdf6e9; }

/* ─── Provenance pill ──────────────────────────────────── */
.prov {
  display: inline-block;
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 3px 8px; border: 1px solid var(--rule);
  color: var(--ink-3); margin-left: 10px;
}
.prov.deterministic { color: var(--good); border-color: #b8d3a5; background: #f0f6ea; }
.prov.estimate      { color: var(--partial); border-color: #d4c498; background: #f7f1de; }
.prov.illustrative  { color: var(--accent); border-color: #e5b6a8; background: #fbeee9; }

/* ─── Callout ───────────────────────────────────────────── */
.callout {
  background: var(--ink); color: #f5efe0;
  padding: 36px 40px; margin: 40px 0 0;
  border-left: 4px solid var(--accent);
}
.callout h3 {
  font-family: var(--serif); font-size: 28px; line-height: 1.18;
  font-weight: 400; letter-spacing: -0.01em;
  margin: 0 0 16px; color: #fff;
}
.callout p {
  font-family: var(--serif); font-size: 17px; line-height: 1.6;
  color: #d8d2c2; max-width: 760px; margin: 0;
}
.callout p + p { margin-top: 12px; }
.callout b { color: #fff; }

/* ─── Download bar ──────────────────────────────────────── */
.download {
  background: var(--bg-card); border: 1px solid var(--ink);
  padding: 32px 36px; display: flex; justify-content: space-between;
  align-items: center; gap: 28px; flex-wrap: wrap;
}
.download__copy h3 {
  font-family: var(--serif); font-size: 26px; line-height: 1.15;
  font-weight: 400; margin: 0 0 8px; max-width: 580px;
}
.download__copy p {
  font-family: var(--sans); font-size: 14px; color: var(--ink-2);
  margin: 0; max-width: 580px;
}
.download__cta {
  background: var(--ink); color: #fff;
  font-family: var(--mono); font-size: 12.5px; letter-spacing: 0.08em;
  text-transform: uppercase; padding: 16px 24px;
  border: 0; cursor: pointer; text-decoration: none;
  display: inline-block; white-space: nowrap;
}
.download__cta:hover { background: var(--accent); color: #fff; border-bottom: 0; }
.download__sub {
  margin-top: 22px; font-family: var(--mono); font-size: 11px;
  color: var(--ink-3); letter-spacing: 0.04em;
}

/* ─── DIY playbook ──────────────────────────────────────── */
.tools-grid {
  display: grid; grid-template-columns: repeat(2, 1fr);
  gap: 1px; background: var(--rule); border: 1px solid var(--rule);
  margin: 28px 0;
}
.tool-card { background: var(--bg-card); padding: 22px 26px; }
.tool-card h4 {
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--accent);
  margin: 0 0 6px;
}
.tool-card p {
  font-family: var(--sans); font-size: 13.5px; line-height: 1.5;
  color: var(--ink-2); margin: 0 0 10px;
}
.tool-card a {
  font-family: var(--mono); font-size: 11.5px; color: var(--ink);
}

/* ─── Footer ────────────────────────────────────────────── */
.footer {
  padding: 56px 0 64px;
  font-family: var(--mono); font-size: 11.5px;
  color: var(--ink-3); letter-spacing: 0.06em;
}
.footer .container { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 24px; }
.footer a { color: var(--ink-2); border: 0; }
.footer a:hover { color: var(--accent); }

/* ─── Responsive ────────────────────────────────────────── */
@media (max-width: 760px) {
  .hero h1 { font-size: 42px; }
  .hero .lede { font-size: 18px; }
  h2.section-h { font-size: 30px; }
  section.section { padding: 56px 0; }
  .stat-row { grid-template-columns: repeat(2, 1fr); }
  .tools-grid { grid-template-columns: 1fr; }
  .download { flex-direction: column; align-items: flex-start; }
  .container { padding: 0 20px; }
}

/* ===== Traffic × Ticket diagnostic — chart layer (appended) ===== */
section { padding: 44px 0 10px; }
.hm-svg { width: 100%; height: auto; display: block; margin: 14px 0 6px; }
.hm-title { font: 600 13px var(--mono); fill: var(--ink-2); }
.hm-lab { font: 500 12.5px var(--sans); fill: var(--ink-2); }
.hm-val { font: 600 9.5px var(--mono); fill: #fff; }
.hm-tick, .ax { font: 500 12.5px var(--mono); fill: var(--ink-3); }
.ax-t { font: 500 12.5px var(--mono); fill: var(--ink-3); }
.tt-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(380px, 1fr)); gap: 22px 28px; margin-top: 18px; }
.tt-panel { margin: 0; background: var(--bg-card); border: 1px solid var(--rule); border-radius: 6px; padding: 12px 14px 8px; }
.tt-panel figcaption { display: flex; justify-content: space-between; align-items: baseline; gap: 10px; margin-bottom: 4px; flex-wrap: wrap; }
.tt-name { font: 600 14px var(--sans); }
.tt-sub { font: 500 12px var(--mono); color: var(--ink-3); }
.tt-panel-svg, .quad-svg, .ty-svg, .wf-svg { width: 100%; height: auto; display: block; }
.clip { font: 600 12px var(--mono); fill: var(--ink-3); }
.quad-svg { max-width: 680px; margin: 12px auto; background: var(--bg-card); border: 1px solid var(--rule); border-radius: 6px; }
.quad-lab { font: 500 12px var(--mono); fill: var(--ink-3); }
.quad-name { font: 600 12.5px var(--sans); }
.wf-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 18px; margin-top: 16px; }
.wf-fig { margin: 0; background: var(--bg-card); border: 1px solid var(--rule); border-radius: 6px; padding: 10px 12px 6px; }
.wf-fig figcaption { font: 600 13.5px var(--sans); color: var(--ink); margin-bottom: 2px; }
.wf-val { font: 600 10px var(--mono); fill: var(--ink-2); }
.wf-lab { font: 500 9.5px var(--sans); fill: var(--ink-3); }
.ty-svg { background: var(--bg-card); border: 1px solid var(--rule); border-radius: 6px; margin-top: 12px; }
.dl-h { font-family: var(--serif); margin: 34px 0 10px; }
.matrix td, .matrix th { vertical-align: top; }

/* ===== v3: interactive layer ===== */
.chip-row { display: flex; gap: 8px; flex-wrap: wrap; margin: 16px 0 4px; }
.chip { font: 600 13.5px var(--sans); padding: 7px 16px; border: 1.5px solid var(--rule); border-radius: 999px; background: var(--bg-card); color: var(--ink-2); cursor: pointer; transition: all .12s; }
.chip:hover { border-color: var(--ink-3); }
.chip.on { color: #fff; }
.chip-HD.on { background: #e36f1e; border-color: #e36f1e; }
.chip-LOW.on { background: #0b5394; border-color: #0b5394; }
.chip-FND.on { background: #0f766e; border-color: #0f766e; }
.chip-TSCO.on { background: #b3282d; border-color: #b3282d; }
.stat-line { font: 500 12px var(--mono); color: var(--ink-3); margin: 4px 0 10px; }
.chart-mount { background: var(--bg-card); border: 1px solid var(--rule); border-radius: 6px; padding: 10px 12px; }
.chart-mount svg, .trend-svg { width: 100%; height: auto; display: block; }
.tt-tip { position: absolute; display: none; z-index: 50; background: var(--bg-code); color: #f6f3ec; font: 500 12px var(--mono); line-height: 1.5; padding: 8px 11px; border-radius: 6px; pointer-events: none; max-width: 300px; box-shadow: 0 3px 12px rgba(0,0,0,.25); }
.tt-tip b { color: #fff; }
.quad-dot { cursor: pointer; }
.hm-svg rect[data-tip] { cursor: pointer; }
.wf-val2 { font: 600 13px var(--mono); fill: var(--ink-2); }
.wf-lab2 { font: 500 12px var(--sans); fill: var(--ink-3); }
.quad-svg { max-width: none; }

/* ===== v4: mobile ===== */
.scroll-x { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.scroll-x > svg { min-width: 780px; }
.matrix-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
@media (max-width: 760px) {
  .site-header .container { flex-wrap: wrap; gap: 4px 12px; }
  .site-nav { display: flex; flex-wrap: wrap; gap: 2px 12px; }
  .hero h1 { font-size: 32px; line-height: 1.18; }
  .hero-meta { flex-wrap: wrap; gap: 6px 14px; }
  h2 { font-size: 24px; line-height: 1.25; }
  section { padding: 28px 0 6px; }
  .section-dek { font-size: 15px; }
  .chip { padding: 6px 12px; font-size: 12.5px; }
  .chart-mount { padding: 8px 6px; }
  .prov { font-size: 10px; }
  /* method table -> stacked cards on mobile (no horizontal scroll) */
  .matrix-wrap { overflow-x: visible; border: none; margin: 18px 0; }
  .matrix, .matrix tbody, .matrix tr, .matrix td { display: block; width: 100%; }
  .matrix thead { display: none; }
  .matrix tr { border: 1px solid var(--rule); border-radius: 6px; margin-bottom: 12px; padding: 4px 0; background: var(--bg-card); }
  .matrix td { min-width: 0; border: none; padding: 5px 13px; font-size: 13px; }
  .matrix td::before { content: attr(data-label); display: block; font: 600 9px var(--mono); letter-spacing: .08em; text-transform: uppercase; color: var(--ink-3); margin-bottom: 2px; }
}
.wf-controls { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 4px 16px; }
.qsel-wrap { font: 500 12px var(--mono); color: var(--ink-3); display: flex; align-items: center; gap: 8px; }
.qsel { font: 600 13px var(--mono); padding: 6px 10px; border: 1.5px solid var(--rule); border-radius: 8px; background: var(--bg-card); color: var(--ink-2); cursor: pointer; }
.wf-right { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.seg { display: inline-flex; border: 1.5px solid var(--rule); border-radius: 8px; overflow: hidden; }
.segbtn { font: 600 12px var(--sans); padding: 6px 12px; background: var(--bg-card); color: var(--ink-2); border: none; border-right: 1.5px solid var(--rule); cursor: pointer; }
.segbtn:last-child { border-right: none; }
.segbtn.on { background: var(--ink); color: #fff; }
@media (max-width: 760px) { .wf-right { width: 100%; } .segbtn { padding: 6px 9px; font-size: 11px; } }
.wf-controls { display: flex; flex-direction: column; gap: 10px; }
.wf-line { display: flex; align-items: center; flex-wrap: wrap; gap: 8px 12px; }
.wf-line .chip-row { margin: 0; }
.wf-line .qsel-wrap { margin: 0; }
.wf-line:first-child > .qsel-wrap:last-child { margin-left: auto; }
.wf-controls { margin-bottom: 20px; }
.chip-ACE.on { background: #6d4c91; border-color: #6d4c91; }
.gs-svg, .quad-svg, .ty-svg { width: 100%; height: auto; display: block; }
.gs-tot { font: 600 13px var(--mono); fill: var(--ink); }
.gs-name { font: 600 14.5px var(--sans); fill: var(--ink); }
.gs-sub { font: 500 12.5px var(--mono); fill: var(--ink-3); }
.gs-val { font: 600 13px var(--mono); fill: var(--ink-2); }

/* ===== v12: time scatter + productivity bars ===== */
.us-controls { display: flex; align-items: center; gap: 14px; margin: 14px 0 8px; flex-wrap: wrap; }
.us-play { font: 600 12px var(--sans); padding: 6px 14px; border: 1.5px solid var(--rule); border-radius: 999px; background: var(--bg-card); color: var(--ink-2); cursor: pointer; }
.us-play:hover { border-color: var(--ink-3); }
.us-controls input[type=range] { flex: 1; min-width: 160px; max-width: 420px; accent-color: var(--accent); cursor: pointer; }
.us-yr { font: 600 14px var(--mono); color: var(--ink); min-width: 64px; }
.pb-svg { width: 100%; height: auto; display: block; }
.pb-note { font: 500 11.5px var(--mono); fill: var(--ink-3); }

/* ===== v14: Claude Design rec — mobile-first chart polish ===== */
.exhibit-hd { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.exhibit-hd::after { content: ''; flex: 1; height: 1px; background: rgba(26,23,20,.18); }
.exhibit-num { font-family: var(--mono); font-size: 11px; font-weight: 700; letter-spacing: .13em; text-transform: uppercase; color: var(--accent); white-space: nowrap; }

/* transposed heat map + log-AUV: render at design width, centered */
.chart-narrow { max-width: 460px; margin: 0 auto; }
.hm-metric { font-family: var(--mono); font-size: 9.5px; font-weight: 600; letter-spacing: .11em; text-transform: uppercase; color: #6a6560; margin-bottom: 6px; }
.hm-svg, .hm-legend, .pb-svg { width: 100%; height: auto; display: block; }
.hm-col { font: 700 11px var(--mono); fill: #1a1714; }
.hm-yr  { font: 600 10px var(--mono); fill: #2a2520; }
.hm-q   { font: 400 9px var(--mono); fill: #9a9590; }
.hm-cell { font: 600 10px var(--mono); }
.hm-leg-t { font: 600 10px var(--mono); }
.hm-svg rect[data-tip], .pb-svg rect[data-tip] { cursor: pointer; }
.pb-scale { font: italic 12px var(--mono); fill: #9a9590; }
.pb-grid  { font: 400 12px var(--mono); fill: #9a9590; }
.pb-tk    { font: 700 13px var(--mono); }
.pb-auv   { font: 700 14px var(--mono); fill: #1a1714; }
.pb-det   { font: 400 12px var(--sans); fill: #6a6560; }

/* 44px touch targets, unified across exhibits 2/4/6 */
.chip { height: 44px; padding: 0 14px; font-family: var(--mono); font-size: 12px; font-weight: 700; letter-spacing: .04em; border-radius: 4px; display: inline-flex; align-items: center; }
.segbtn { height: 44px; padding: 0 16px; }
.qsel { height: 44px; }

/* scatter: 56px play, fat 28px scrubber thumb */
.us-play { min-height: 56px; min-width: 56px; padding: 0 18px; font-size: 13px; border-radius: 28px; }
.us-controls input[type=range] { -webkit-appearance: none; appearance: none; height: 6px; border-radius: 3px; background: rgba(26,23,20,.18); }
.us-controls input[type=range]::-webkit-slider-thumb { -webkit-appearance: none; appearance: none; width: 28px; height: 28px; border-radius: 50%; background: var(--accent); cursor: pointer; border: 3px solid #f6f3ec; box-shadow: 0 1px 3px rgba(0,0,0,.22); }
.us-controls input[type=range]::-moz-range-thumb { width: 28px; height: 28px; border: 3px solid #f6f3ec; border-radius: 50%; background: var(--accent); cursor: pointer; }
.us-controls input[type=range]::-moz-range-track { height: 6px; border-radius: 3px; background: rgba(26,23,20,.18); }
.us-controls { flex-direction: column; align-items: stretch; gap: 10px; }
.us-focus { display: flex; gap: 6px; flex-wrap: wrap; }
.us-row { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.chip-all.on { background: var(--ink); border-color: var(--ink); }
.gs-period { font: 500 11px var(--mono); fill: var(--ink-3); }

.chart-note { font-family: var(--sans); font-size: 12px; line-height: 1.5; color: var(--ink-3); margin-top: 10px; }

/* ===== v20: readable chart titles (frontend-design) + interactive Ex1 ===== */
/* Canonical chart-title / chart-eyebrow — sits directly above a chart.
   12px mono, 600, ink-2 (not light grey), uppercase, signal-red left tick. */
.chart-title {
  font-family: var(--mono);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--ink-2);
  border-left: 2px solid var(--accent);
  padding-left: 9px;
  line-height: 1.3;
  margin-bottom: 9px;
}
#gs-modes { margin-bottom: 10px; }
@media (max-width: 760px) {
  .chart-title { font-size: 13.5px; }
  #gs-modes { display: flex; width: 100%; }
  #gs-modes .segbtn { flex: 1; padding: 0 6px; font-size: 10.5px; }
}

/* ===== v24: Exhibit 5 — ticket vs margin ===== */
.tm-scorecard { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-bottom: 30px; }
.tm-card { display: flex; flex-direction: column; gap: 5px; align-items: flex-start; text-align: left; border: 1px solid var(--rule); border-radius: 6px; padding: 11px 13px; background: var(--bg-card); cursor: pointer; transition: border-color .12s, box-shadow .12s; }
.tm-card:hover { border-color: var(--ink-3); }
.tm-card.on { border-color: var(--ink); box-shadow: inset 0 0 0 1px var(--ink); }
.tm-card-t { font-family: var(--mono); font-size: 12px; font-weight: 700; }
.tm-card-v { font-family: var(--mono); font-size: 12.5px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--ink); }
.tm-quote { border-left: 3px solid var(--accent); margin: 26px 0 0; padding: 6px 0 6px 18px; max-width: 860px; }
.tm-quote p { font-family: var(--serif); font-style: italic; font-size: 19px; line-height: 1.5; color: var(--ink); margin: 0 0 8px; }
.tm-quote cite { font-family: var(--mono); font-size: 12px; color: var(--ink-3); font-style: normal; }
@media (max-width: 760px) { .tm-scorecard { grid-template-columns: repeat(2, 1fr); } .tm-quote p { font-size: 17px; } }
