
  :root {
    --cream: #f4efe6;
    --cream-deep: #ebe4d6;
    --paper: #faf6ec;
    --ink: #1a1814;
    --ink-soft: #3a342c;
    --ink-mute: #6b6358;
    --rule: #c9bfae;
    --rule-soft: #ddd3c0;
    --oxblood: #6b1f1f;
    --oxblood-deep: #4a1414;
    --gold: #a07020;
    --green: #2d5a3d;
    --red: #8a2020;
    --shadow: 0 1px 0 rgba(26,24,20,.04), 0 12px 32px -16px rgba(26,24,20,.18);
  }
  * { box-sizing: border-box; margin: 0; padding: 0; }
  html, body { background: var(--cream); color: var(--ink); }
  body {
    font-family: 'Inter Tight', sans-serif;
    font-size: 14px;
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
    min-height: 100vh;
    background-image:
      radial-gradient(at 0% 0%, rgba(107,31,31,.04) 0px, transparent 50%),
      radial-gradient(at 100% 100%, rgba(160,112,32,.04) 0px, transparent 50%);
  }
  .serif { font-family: 'Cormorant Garamond', serif; }
  .mono { font-family: 'JetBrains Mono', monospace; font-feature-settings: "tnum" 1; }

  /* ---------- LOAD SCREEN ---------- */
  .gate {
    min-height: 100vh;
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    padding: 40px 20px;
    text-align: center;
  }
  .gate-logo { width: clamp(280px, 36vw, 480px); height: auto; margin-bottom: 28px; opacity: .92; }
  .gate-entity { font-size: 10.5px; letter-spacing: .22em; text-transform: uppercase; color: var(--ink-mute); margin-bottom: 6px; font-family: 'JetBrains Mono', monospace; }
  .gate-rule { width: 48px; height: 1px; background: var(--rule); margin: 18px auto 22px; }
  .gate-sources { display: flex; justify-content: center; gap: 32px; margin-bottom: 36px; max-width: 720px; flex-wrap: wrap; }
  .gate-source { display: flex; align-items: flex-start; gap: 10px; text-align: left; max-width: 320px; }
  .gate-source-dot { width: 8px; height: 8px; border-radius: 50%; margin-top: 7px; flex-shrink: 0; }
  .gate-source-dot.opus { background: var(--green); }
  .gate-source-dot.marex { background: var(--gold); }
  .gate-source-k { font-size: 10.5px; letter-spacing: .18em; text-transform: uppercase; font-weight: 600; color: var(--ink-soft); margin-bottom: 3px; }
  .gate-source-v { font-size: 12.5px; color: var(--ink-mute); line-height: 1.5; }
  .gate-drop {
    border: 1.5px dashed var(--rule);
    background: var(--paper);
    padding: 32px 64px;
    cursor: pointer;
    transition: all .2s ease;
    max-width: 560px;
    width: 100%;
  }
  .gate-drop:hover, .gate-drop.drag { border-color: var(--oxblood); background: #fcf9f0; }
  .gate-drop-label { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 20px; color: var(--ink); }
  .gate-drop-hint { color: var(--ink-mute); font-size: 11px; letter-spacing: .15em; text-transform: uppercase; margin-top: 6px; }
  .gate-footer { margin-top: 56px; color: var(--ink-mute); font-size: 10.5px; letter-spacing: .14em; text-transform: uppercase; max-width: 720px; line-height: 1.9; }
  .gate-err { color: var(--red); margin-top: 16px; font-size: 13px; }

  /* ---------- DASHBOARD ---------- */
  .wrap { max-width: 1240px; margin: 0 auto; padding: 32px 32px 80px; }

  /* Masthead */
  .mast { border-bottom: 2px solid var(--ink); padding-bottom: 18px; margin-bottom: 28px; }
  .mast-top { display: flex; justify-content: space-between; align-items: baseline; font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: var(--ink-mute); margin-bottom: 18px; }
  .mast-top .right { display: flex; gap: 24px; align-items: center; }
  .mast-top button { background: none; border: 1px solid var(--rule); padding: 6px 12px; font: inherit; font-size: 10px; letter-spacing: .18em; text-transform: uppercase; cursor: pointer; color: var(--ink-soft); }
  .mast-top button:hover { border-color: var(--oxblood); color: var(--oxblood); }
  .mast-logo { height: clamp(38px, 5vw, 54px); width: auto; display: block; opacity: .92; }
  .mast-sub { display: flex; justify-content: space-between; align-items: flex-end; margin-top: 16px; gap: 24px; }
  .mast-sub .tag { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 18px; color: var(--ink-soft); }
  .mast-sub .meta { font-size: 11px; letter-spacing: .15em; text-transform: uppercase; color: var(--ink-mute); text-align: right; }

  /* Strap */
  .strap { display: grid; grid-template-columns: repeat(6, 1fr); border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); padding: 18px 0; margin-bottom: 36px; }
  .strap-item { padding: 0 18px; border-right: 1px solid var(--rule-soft); }
  .strap-item:last-child { border-right: none; }
  .strap-item:first-child { padding-left: 0; }
  .strap-label { font-size: 10px; letter-spacing: .15em; text-transform: uppercase; color: var(--ink-mute); margin-bottom: 6px; display: flex; align-items: center; gap: 4px; }
  .strap-label .src { font-size: 8.5px; letter-spacing: .12em; padding: 1px 5px; border-radius: 2px; font-weight: 600; }
  .strap-label .src.opus { background: rgba(45,90,61,.14); color: var(--green); }
  .strap-label .src.marex { background: rgba(160,112,32,.14); color: var(--gold); }
  .strap-val { font-family: 'Cormorant Garamond', serif; font-size: 28px; font-weight: 500; line-height: 1; letter-spacing: -.01em; }
  .strap-val.pos { color: var(--green); }
  .strap-val.neg { color: var(--oxblood); }
  .strap-val.pending { color: var(--ink-mute); font-style: italic; font-size: 22px; }
  .strap-sub { font-size: 11px; color: var(--ink-mute); margin-top: 4px; font-family: 'JetBrains Mono', monospace; }

  /* Source legend */
  .source-legend {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
    background: var(--paper);
    border: 1px solid var(--rule-soft);
    margin-bottom: 22px;
    box-shadow: var(--shadow);
  }
  .source-item {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 14px 18px;
    border-right: 1px solid var(--rule-soft);
  }
  .source-item:last-child { border-right: none; }
  .source-dot {
    flex-shrink: 0;
    width: 10px; height: 10px;
    border-radius: 50%;
    margin-top: 5px;
  }
  .source-dot.opus { background: var(--green); box-shadow: 0 0 0 3px rgba(45,90,61,.12); }
  .source-dot.marex { background: var(--gold); box-shadow: 0 0 0 3px rgba(160,112,32,.12); }
  .source-k { font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--ink); font-weight: 600; margin-bottom: 3px; }
  .source-v { font-size: 11px; color: var(--ink-mute); line-height: 1.5; }
  @media (max-width: 900px) {
    .source-legend { grid-template-columns: 1fr; }
    .source-item { border-right: none; border-bottom: 1px solid var(--rule-soft); }
    .source-item:last-child { border-bottom: none; }
  }

  /* Pills in section heads */
  .pill {
    font-size: 9px;
    letter-spacing: .14em;
    padding: 2px 7px;
    border-radius: 2px;
    font-weight: 600;
    text-transform: uppercase;
    vertical-align: middle;
    margin-left: 8px;
  }
  .pill.opus { background: rgba(45,90,61,.14); color: var(--green); }
  .pill.marex { background: rgba(160,112,32,.14); color: var(--gold); }
  .today-source { font-size: 9px; letter-spacing: .14em; background: rgba(244,239,230,.16); color: rgba(244,239,230,.85); padding: 2px 7px; border-radius: 2px; margin-left: 6px; }

  /* Italicised in-section explanatory note */
  .section-note {
    font-family: 'Cormorant Garamond', serif;
    font-style: italic;
    font-size: 14.5px;
    color: var(--ink-soft);
    line-height: 1.7;
    background: var(--paper);
    padding: 14px 18px;
    border-left: 3px solid var(--rule);
    margin-bottom: 22px;
  }
  .section-note strong {
    font-style: normal;
    font-family: 'Inter Tight', sans-serif;
    font-weight: 600;
    font-size: 13px;
    letter-spacing: -.005em;
    color: var(--ink);
  }

  /* Section heads */
  .section { margin-top: 40px; }
  .sect-head { display: flex; align-items: baseline; justify-content: space-between; border-bottom: 1px solid var(--ink); padding-bottom: 8px; margin-bottom: 22px; }
  .sect-head h2 { font-family: 'Cormorant Garamond', serif; font-size: 32px; font-weight: 500; letter-spacing: -.01em; }
  .sect-head h2 em { font-style: italic; color: var(--oxblood); }
  .sect-head .kicker { font-size: 10px; letter-spacing: .25em; text-transform: uppercase; color: var(--ink-mute); }

  .subhead {
    font-family: 'Cormorant Garamond', serif;
    font-style: italic;
    font-size: 20px;
    color: var(--ink-soft);
    margin: 28px 0 14px;
    padding-bottom: 6px;
    border-bottom: 1px solid var(--rule-soft);
    display: flex;
    align-items: baseline;
    justify-content: space-between;
  }
  .subhead-meta { font-style: normal; font-family: 'Inter Tight', sans-serif; font-size: 10px; letter-spacing: .2em; text-transform: uppercase; color: var(--ink-mute); }

  /* Today's session strip */
  .today-strip {
    background: var(--ink);
    color: var(--cream);
    padding: 18px 24px;
    margin-bottom: 36px;
    margin-top: -16px;
    display: flex;
    align-items: center;
    gap: 28px;
    box-shadow: var(--shadow);
  }
  .today-label {
    font-family: 'Cormorant Garamond', serif;
    font-style: italic;
    font-size: 18px;
    color: var(--cream);
    padding-right: 24px;
    border-right: 1px solid rgba(244,239,230,.18);
    flex-shrink: 0;
  }
  .today-grid { display: flex; gap: 32px; flex: 1; flex-wrap: wrap; }
  .today-cell { display: flex; flex-direction: column; gap: 3px; }
  .today-k { font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: rgba(244,239,230,.55); }
  .today-v { font-family: 'JetBrains Mono', monospace; font-size: 15px; font-weight: 500; color: var(--cream); }
  .today-v.pos { color: #7fb88a; }
  .today-v.neg { color: #d97b7b; }
  @media (max-width: 900px) {
    .today-strip { flex-direction: column; align-items: flex-start; gap: 14px; }
    .today-label { border-right: none; border-bottom: 1px solid rgba(244,239,230,.18); padding: 0 0 12px; }
    .today-grid { gap: 18px 24px; }
  }

  /* Tables of metrics */
  .grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; }
  .grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
  .metric-tbl { width: 100%; border-collapse: collapse; }
  .metric-tbl tr { border-bottom: 1px solid var(--rule-soft); }
  .metric-tbl tr:last-child { border-bottom: none; }
  .metric-tbl td { padding: 11px 0; vertical-align: baseline; }
  .metric-tbl td.label { color: var(--ink-soft); font-size: 13px; }
  .metric-tbl td.value { text-align: right; font-family: 'JetBrains Mono', monospace; font-size: 14px; font-weight: 500; }
  .metric-tbl td.value.pos { color: var(--green); }
  .metric-tbl td.value.neg { color: var(--oxblood); }
  .metric-tbl td.value.muted { color: var(--ink-mute); font-weight: 400; }

  /* Charts */
  .chart-card { background: var(--paper); border: 1px solid var(--rule-soft); padding: 24px; margin-bottom: 24px; box-shadow: var(--shadow); }

  /* Feeder cards - richer layout with NAV/share, monthly, cumulative */
  .feeder-cards { gap: 20px; margin-bottom: 18px; }
  .feeder-card {
    background: var(--paper);
    border: 1px solid var(--rule-soft);
    padding: 24px 26px;
    box-shadow: var(--shadow);
    display: flex;
    flex-direction: column;
    gap: 18px;
  }
  .feeder-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--rule-soft);
  }
  .feeder-kicker {
    font-size: 10px;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: var(--ink-mute);
    margin-bottom: 4px;
  }
  .feeder-name {
    font-family: 'Cormorant Garamond', serif;
    font-style: italic;
    font-size: 22px;
    line-height: 1.15;
    color: var(--ink);
    letter-spacing: -.005em;
  }
  .feeder-sub {
    font-size: 11px;
    color: var(--ink-mute);
    margin-top: 4px;
  }
  .feeder-asof {
    font-family: 'Cormorant Garamond', serif;
    font-style: italic;
    font-size: 14px;
    color: var(--ink-soft);
    white-space: nowrap;
    padding-top: 2px;
  }
  .feeder-body {
    display: grid;
    grid-template-columns: minmax(0,1.05fr) minmax(0,1.4fr);
    gap: 24px;
    align-items: center;
  }
  .feeder-share {
    border-right: 1px solid var(--rule-soft);
    padding-right: 24px;
  }
  .feeder-share-label {
    font-size: 10px;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--ink-mute);
    margin-bottom: 6px;
  }
  .feeder-share-val {
    font-family: 'Cormorant Garamond', serif;
    font-size: 38px;
    font-weight: 500;
    line-height: 1;
    letter-spacing: -.015em;
    color: var(--ink);
  }
  .feeder-stats {
    display: flex;
    flex-direction: column;
    gap: 12px;
  }
  .feeder-stat {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 12px;
  }
  .feeder-stat-k {
    font-size: 11px;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--ink-mute);
  }
  .feeder-stat-v {
    font-family: 'JetBrains Mono', monospace;
    font-feature-settings: "tnum" 1;
    font-size: 15px;
    font-weight: 500;
    color: var(--ink);
  }
  .feeder-stat-v.pos { color: var(--green); }
  .feeder-stat-v.neg { color: var(--oxblood); }

  /* Combined master strip - dark, prominent, sits between feeder cards and chart */
  .master-strip {
    background: var(--ink);
    color: var(--cream);
    padding: 22px 26px;
    margin-bottom: 24px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 32px;
    flex-wrap: wrap;
    box-shadow: var(--shadow);
  }
  .master-strip-kicker {
    font-size: 10px;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: rgba(244,239,230,.6);
    margin-bottom: 4px;
  }
  .master-strip-asof {
    font-family: 'Cormorant Garamond', serif;
    font-style: italic;
    font-size: 13px;
    letter-spacing: 0;
    text-transform: none;
    color: var(--cream);
    margin-left: 6px;
  }
  .master-strip-name {
    font-family: 'Cormorant Garamond', serif;
    font-style: italic;
    font-size: 24px;
    line-height: 1.1;
    color: var(--cream);
    letter-spacing: -.005em;
  }
  .master-strip-stats {
    display: flex;
    gap: 40px;
    flex-wrap: wrap;
  }
  .master-strip-stat { display: flex; flex-direction: column; gap: 4px; }
  .master-strip-k {
    font-size: 10px;
    letter-spacing: .15em;
    text-transform: uppercase;
    color: rgba(244,239,230,.6);
  }
  .master-strip-v {
    font-family: 'JetBrains Mono', monospace;
    font-feature-settings: "tnum" 1;
    font-size: 18px;
    font-weight: 500;
    color: var(--cream);
  }
  .master-strip-v.pos { color: #7fb88a; }
  .master-strip-v.neg { color: #d97b7b; }

  @media (max-width: 900px) {
    .feeder-body { grid-template-columns: 1fr; }
    .feeder-share { border-right: none; border-bottom: 1px solid var(--rule-soft); padding-right: 0; padding-bottom: 14px; }
    .master-strip { flex-direction: column; align-items: flex-start; }
    .master-strip-stats { gap: 18px; }
  }

  .footnote {
    margin-top: 18px;
    font-family: 'Cormorant Garamond', serif;
    font-style: italic;
    font-size: 14px;
    line-height: 1.7;
    color: var(--ink-soft);
    padding: 0 4px;
  }
  .footnote strong {
    font-style: normal;
    font-family: 'Inter Tight', sans-serif;
    font-weight: 600;
    font-size: 11px;
    letter-spacing: .15em;
    text-transform: uppercase;
    color: var(--ink);
    margin-right: 6px;
  }
  .chart-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 16px; padding-bottom: 12px; border-bottom: 1px solid var(--rule-soft); }
  .chart-title { font-family: 'Cormorant Garamond', serif; font-size: 22px; font-weight: 500; }
  .chart-title em { font-style: italic; color: var(--oxblood); }
  .chart-legend { display: flex; gap: 16px; font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-mute); }
  .chart-legend span { display: inline-flex; align-items: center; gap: 6px; }
  .chart-legend .sw { width: 14px; height: 2px; background: var(--ink); }
  .chart-legend .sw.net { background: var(--oxblood); }
  .chart-legend .sw.bench { background: var(--gold); border-top: 2px dashed var(--gold); height: 0; }
  .chart-legend .sw.dd { background: var(--oxblood); height: 8px; opacity: .25; }

  /* Multi-benchmark toggle chips */
  .bench-toggles {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    margin: 10px 0 14px;
    padding: 10px 14px;
    background: var(--cream-deep);
    border-radius: 2px;
    border: 1px solid var(--rule-soft);
  }
  .bench-toggles-label {
    font-size: 10px;
    letter-spacing: .15em;
    text-transform: uppercase;
    color: var(--ink-mute);
    margin-right: 8px;
    font-family: 'Inter Tight', sans-serif;
  }
  .bench-chip {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 5px 11px;
    background: var(--paper);
    border: 1px solid var(--rule);
    border-radius: 2px;
    font-family: 'Inter Tight', sans-serif;
    font-size: 11px;
    font-weight: 500;
    letter-spacing: .04em;
    color: var(--ink-mute);
    cursor: pointer;
    transition: background 0.15s, color 0.15s, border-color 0.15s, opacity 0.15s;
  }
  .bench-chip:hover { background: var(--cream); color: var(--ink); }
  .bench-chip.active { background: var(--ink); color: var(--cream); border-color: var(--ink); }
  .bench-chip.disabled { opacity: 0.45; cursor: not-allowed; }
  .bench-chip.disabled:hover { background: var(--paper); color: var(--ink-mute); }
  .bench-chip-sw {
    display: inline-block;
    width: 12px;
    height: 2px;
  }
  .bench-chip-pending {
    margin-left: 4px;
    font-size: 9px;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--gold);
    background: rgba(160,112,32,.12);
    padding: 1px 5px;
    border-radius: 2px;
  }
  .bench-chip.active .bench-chip-pending {
    color: var(--cream);
    background: rgba(244,239,230,.18);
  }

  /* Benchmark matrix table */
  .bench-table-wrap {
    padding: 8px 14px 14px;
  }
  .bench-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
  }
  .bench-table thead th {
    font-family: 'Inter Tight', sans-serif;
    font-size: 10px;
    letter-spacing: .15em;
    text-transform: uppercase;
    color: var(--ink-mute);
    font-weight: 600;
    text-align: right;
    padding: 12px 14px 10px;
    border-bottom: 1px solid var(--rule);
  }
  .bench-table thead th.bench-table-metric {
    text-align: left;
    color: var(--ink);
    font-family: 'Cormorant Garamond', serif;
    font-style: italic;
    font-size: 16px;
    text-transform: none;
    letter-spacing: 0;
    font-weight: 500;
    padding-left: 4px;
  }
  .bench-table tbody td {
    padding: 9px 14px;
    border-bottom: 1px solid var(--rule-soft);
    font-family: 'JetBrains Mono', monospace;
    font-size: 12px;
    text-align: right;
    color: var(--ink);
  }
  .bench-table tbody td:first-child {
    text-align: left;
    font-family: 'Inter Tight', sans-serif;
    font-size: 12px;
    color: var(--ink-soft);
    font-weight: 500;
    padding-left: 4px;
  }
  .bench-table tbody tr:last-child td { border-bottom: none; }
  .bench-table .bv-pos { color: var(--green); }
  .bench-table .bv-neg { color: var(--oxblood); }
  .bench-table .bv-pending {
    color: var(--ink-mute);
    font-style: italic;
    font-family: 'Cormorant Garamond', serif;
    font-size: 13px;
  }
  .bench-table .bv-info {
    display: inline-block;
    width: 13px; height: 13px;
    border: 1px solid var(--rule);
    border-radius: 50%;
    text-align: center;
    line-height: 11px;
    font-size: 9px;
    color: var(--ink-mute);
    font-style: italic;
    cursor: help;
    margin-left: 5px;
    font-family: 'Cormorant Garamond', serif;
    vertical-align: middle;
  }
  .bench-table .bv-info:hover { background: var(--cream-deep); color: var(--ink); }

  /* Market regime context strip */
  .regime-strip {
    display: flex;
    align-items: center;
    gap: 24px;
    margin-top: 12px;
    padding: 10px 14px;
    border-top: 1px solid var(--rule-soft);
  }
  .regime-strip-label {
    font-size: 10px;
    letter-spacing: .15em;
    text-transform: uppercase;
    color: var(--ink-mute);
    font-family: 'Inter Tight', sans-serif;
  }
  .regime-strip-stats {
    display: flex;
    gap: 28px;
    align-items: center;
  }
  .regime-stat {
    display: inline-flex;
    align-items: baseline;
    gap: 8px;
  }
  .regime-k {
    font-size: 10px;
    letter-spacing: .15em;
    text-transform: uppercase;
    color: var(--ink-mute);
    font-family: 'Inter Tight', sans-serif;
  }
  .regime-v {
    font-family: 'JetBrains Mono', monospace;
    font-size: 14px;
    font-weight: 600;
    color: var(--ink);
  }
  .regime-tag {
    font-size: 10px;
    font-style: italic;
    color: var(--ink-mute);
    font-family: 'Cormorant Garamond', serif;
  }
  .chart-wrap { position: relative; height: 320px; }
  .chart-wrap.tall { height: 380px; }
  .chart-wrap.short { height: 220px; }

  /* Heatmap */
  .heatmap { width: 100%; border-collapse: separate; border-spacing: 3px; }
  .heatmap th { font-size: 10px; letter-spacing: .15em; text-transform: uppercase; color: var(--ink-mute); padding: 4px; font-weight: 500; text-align: center; }
  .heatmap th:first-child, .heatmap td:first-child { text-align: left; }
  .heatmap td { padding: 12px 6px; text-align: center; font-family: 'JetBrains Mono', monospace; font-size: 12px; font-weight: 500; }
  .heatmap td.year { background: none; color: var(--ink-mute); font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 18px; padding-right: 12px; }
  .heatmap td.empty { background: var(--cream-deep); color: transparent; }
  .heatmap td.tot { background: var(--ink); color: var(--cream); font-weight: 600; }
  .hm-mtd { font-size: 9px; padding-left: 2px; opacity: .85; }
  .hm-key { display: flex; gap: 28px; flex-wrap: wrap; padding: 14px 4px 0; font-size: 11px; color: var(--ink-mute); border-top: 1px solid var(--rule-soft); margin-top: 12px; }
  .hm-key-item { display: flex; align-items: center; gap: 8px; font-family: 'Inter Tight', sans-serif; }
  .hm-key-item sup { font-size: 9px; color: var(--gold); }
  .hm-key-dot { width: 10px; height: 10px; border-radius: 2px; flex-shrink: 0; }
  .hm-key-dot.opus { background: rgba(45,90,61,.45); }
  .hm-key-dot.marex { background: rgba(160,112,32,.45); }

  /* Tooltip */
  .info { display: inline-block; width: 13px; height: 13px; border-radius: 50%; border: 1px solid var(--rule); color: var(--ink-mute); font-size: 9px; line-height: 11px; text-align: center; cursor: help; font-family: 'Cormorant Garamond', serif; font-style: italic; position: relative; }
  .info:hover { border-color: var(--oxblood); color: var(--oxblood); }
  .info:hover::after {
    content: attr(data-tip);
    position: absolute;
    bottom: calc(100% + 8px);
    left: 50%;
    transform: translateX(-50%);
    background: var(--ink);
    color: var(--paper);
    padding: 10px 14px;
    font-family: 'Inter Tight', sans-serif;
    font-size: 12px;
    font-style: normal;
    line-height: 1.5;
    width: 280px;
    z-index: 100;
    box-shadow: var(--shadow);
    text-align: left;
    letter-spacing: 0;
    text-transform: none;
  }
  .info:hover::before {
    content: '';
    position: absolute;
    bottom: calc(100% + 2px);
    left: 50%;
    transform: translateX(-50%);
    border: 5px solid transparent;
    border-top-color: var(--ink);
    z-index: 100;
  }

  /* Footer */
  .colophon { margin-top: 64px; padding-top: 24px; border-top: 2px solid var(--ink); display: grid; grid-template-columns: 2fr 1fr; gap: 32px; }
  .colophon .lead { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 14px; color: var(--ink-soft); line-height: 1.7; }
  .colophon .meta { font-size: 10px; letter-spacing: .15em; text-transform: uppercase; color: var(--ink-mute); line-height: 2; text-align: right; }

  .hidden { display: none !important; }

  @media (max-width: 900px) {
    .strap { grid-template-columns: repeat(3, 1fr); }
    .strap-item:nth-child(3) { border-right: none; }
    .strap-item:nth-child(4), .strap-item:nth-child(5), .strap-item:nth-child(6) { padding-top: 14px; border-top: 1px solid var(--rule-soft); }
    .grid-2 { grid-template-columns: 1fr; }
    .grid-3 { grid-template-columns: 1fr; }
    .colophon { grid-template-columns: 1fr; }
    .colophon .meta { text-align: left; }
  }


/* ============== SHARED ADDITIONS (post-extraction) ============== */

/* Page-level layouts for non-dashboard pages */
.page-narrow { max-width: 720px; margin: 0 auto; padding: 32px 32px 80px; }
.page-medium { max-width: 960px; margin: 0 auto; padding: 32px 32px 80px; }

/* Card style for content blocks */
.card {
  background: var(--paper);
  border: 1px solid var(--rule-soft);
  padding: 32px 36px;
  margin-bottom: 24px;
  box-shadow: var(--shadow);
}
.card-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 24px;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 12px;
  letter-spacing: -.01em;
}
.card-eyebrow {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-bottom: 8px;
}
.card-body { color: var(--ink-soft); line-height: 1.7; font-size: 14px; }
.card-body p { margin-bottom: 12px; }
.card-body p:last-child { margin-bottom: 0; }
.card-body strong { color: var(--ink); font-weight: 600; }
.card-body ul { padding-left: 22px; margin: 12px 0; }
.card-body li { margin-bottom: 6px; }

/* Form elements (login, attestation) */
.form-group { margin-bottom: 20px; }
.form-label {
  display: block;
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-bottom: 8px;
  font-weight: 600;
}
.form-input, .form-textarea {
  width: 100%;
  padding: 10px 14px;
  background: var(--paper);
  border: 1px solid var(--rule);
  font-family: 'Inter Tight', sans-serif;
  font-size: 14px;
  color: var(--ink);
}
.form-input:focus, .form-textarea:focus { outline: none; border-color: var(--oxblood); }
.form-textarea { min-height: 80px; resize: vertical; }

.checkbox-group {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 14px;
  background: var(--paper);
  border: 1px solid var(--rule-soft);
  margin-bottom: 12px;
  cursor: pointer;
  transition: all .15s ease;
}
.checkbox-group:hover { border-color: var(--rule); }
.checkbox-group input[type="checkbox"] { margin-top: 3px; flex-shrink: 0; cursor: pointer; }
.checkbox-group label { font-size: 13px; line-height: 1.6; color: var(--ink-soft); cursor: pointer; }

.btn-primary {
  display: inline-block;
  background: var(--oxblood);
  color: var(--paper);
  padding: 12px 28px;
  font-family: 'Inter Tight', sans-serif;
  font-size: 12px;
  letter-spacing: .15em;
  text-transform: uppercase;
  font-weight: 600;
  border: none;
  cursor: pointer;
  transition: background .15s ease;
}
.btn-primary:hover { background: var(--oxblood-deep); }
.btn-primary:disabled { background: var(--ink-mute); cursor: not-allowed; }
.btn-secondary {
  display: inline-block;
  background: transparent;
  color: var(--ink);
  padding: 12px 28px;
  font-family: 'Inter Tight', sans-serif;
  font-size: 12px;
  letter-spacing: .15em;
  text-transform: uppercase;
  font-weight: 600;
  border: 1px solid var(--ink);
  cursor: pointer;
}
.btn-secondary:hover { background: var(--ink); color: var(--paper); }

/* Status messages */
.alert {
  padding: 12px 16px;
  margin-bottom: 16px;
  border-left: 3px solid var(--rule);
  background: var(--paper);
  font-size: 13px;
  line-height: 1.6;
}
.alert-error { border-left-color: var(--red); color: var(--red); }
.alert-success { border-left-color: var(--green); color: var(--green); }
.alert-warn { border-left-color: var(--gold); color: var(--gold); }

/* Top navigation bar (shown on authenticated pages) */
.topnav {
  border-bottom: 1px solid var(--rule);
  padding: 16px 32px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: var(--paper);
  margin-bottom: 0;
}
.topnav-brand {
  font-family: 'Cormorant Garamond', serif;
  font-size: 18px;
  font-weight: 600;
  color: var(--ink);
  letter-spacing: -.01em;
}
.topnav-links { display: flex; gap: 24px; align-items: center; }
.topnav-link {
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  text-decoration: none;
  font-weight: 600;
  transition: color .15s ease;
}
.topnav-link:hover, .topnav-link.active { color: var(--oxblood); }
.topnav-user { font-size: 11px; color: var(--ink-mute); letter-spacing: .1em; text-transform: uppercase; }

/* Methodology page specific */
.method-section { margin-bottom: 40px; }
.method-list { list-style: none; padding: 0; }
.method-list li {
  padding: 14px 0;
  border-bottom: 1px solid var(--rule-soft);
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: 24px;
  align-items: baseline;
}
.method-list li:last-child { border-bottom: none; }
.method-list .method-k {
  font-size: 11px;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--ink-mute);
  font-weight: 600;
}
.method-list .method-v { font-size: 14px; color: var(--ink-soft); line-height: 1.6; }

/* TOC / How-to-read sidebar */
.toc { position: sticky; top: 20px; padding: 20px 0; }
.toc-item {
  display: block;
  padding: 6px 0;
  color: var(--ink-mute);
  text-decoration: none;
  font-size: 12px;
  letter-spacing: .1em;
  text-transform: uppercase;
  border-left: 2px solid transparent;
  padding-left: 12px;
  transition: all .15s ease;
}
.toc-item:hover, .toc-item.active { color: var(--oxblood); border-left-color: var(--oxblood); }

.with-toc { display: grid; grid-template-columns: 200px 1fr; gap: 48px; }
@media (max-width: 900px) {
  .with-toc { grid-template-columns: 1fr; }
  .toc { position: static; }
}

/* Audit log table */
.audit-table { width: 100%; border-collapse: collapse; font-size: 12px; }
.audit-table th {
  text-align: left;
  padding: 10px 12px;
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  border-bottom: 2px solid var(--ink);
  font-weight: 600;
}
.audit-table td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--rule-soft);
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  color: var(--ink-soft);
}
.audit-table tr:hover td { background: rgba(107, 31, 31, .03); }
.audit-table .ts { color: var(--ink-mute); }
.audit-table .action { color: var(--ink); font-weight: 600; }

/* Upload area for admin */
.upload-area {
  display: block;
  border: 2px dashed var(--rule);
  border-radius: 2px;
  background: var(--paper);
  padding: 56px 40px;
  text-align: center;
  cursor: pointer;
  transition: all .2s ease;
  margin-bottom: 20px;
}
.upload-area:hover, .upload-area.drag { border-color: var(--oxblood); background: #fcf9f0; }
.upload-label { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 22px; color: var(--ink); display: block; }
.upload-hint { color: var(--ink-mute); font-size: 11px; letter-spacing: .15em; text-transform: uppercase; margin-top: 10px; display: block; }
.upload-status { margin-top: 0; font-size: 13px; color: var(--ink-soft); }
.upload-status:empty { display: none; }

/* Reference range chips inside tooltips/cards */
.range-chip {
  display: inline-block;
  padding: 2px 8px;
  background: var(--cream-deep);
  font-size: 10px;
  letter-spacing: .1em;
  text-transform: uppercase;
  margin-right: 6px;
  color: var(--ink-soft);
  font-family: 'JetBrains Mono', monospace;
}


/* ================================================================
   MOBILE RESPONSIVENESS — appended for iPhone / Android optimization
   Breakpoints:
     - 1024px : tablet / small laptop adjustments
     - 768px  : phone landscape / small tablet (primary mobile rules)
     - 480px  : phone portrait (tightest layouts)
   ================================================================ */

/* ---------- Prevent iOS-Safari from zooming on form input focus ---- */
/* iOS auto-zooms when input font-size < 16px. The shared.css form
   defaults set 14px; raise to 16px on touch-capable narrow viewports
   while preserving the desktop typographic scale. */
@media (max-width: 768px) {
  .form-input,
  .form-textarea,
  select.form-input,
  input[type="text"].form-input,
  input[type="email"].form-input,
  input[type="password"].form-input {
    font-size: 16px;
  }
}

/* ---------- Hamburger toggle (injected by auth.js) ----------------- */
/* The button is invisible at >=769px; visible on mobile.            */
.topnav-toggle {
  display: none;
  background: none;
  border: 1px solid var(--rule);
  padding: 8px 10px;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  flex-shrink: 0;
}
.topnav-toggle:hover { border-color: var(--oxblood); }
.topnav-toggle-icon,
.topnav-toggle-icon::before,
.topnav-toggle-icon::after {
  display: block;
  width: 18px;
  height: 1.5px;
  background: var(--ink);
  position: relative;
  transition: transform .2s ease, opacity .2s ease, top .2s ease;
}
.topnav-toggle-icon::before,
.topnav-toggle-icon::after {
  content: '';
  position: absolute;
  left: 0;
}
.topnav-toggle-icon::before { top: -6px; }
.topnav-toggle-icon::after  { top:  6px; }
.topnav.is-open .topnav-toggle-icon { background: transparent; }
.topnav.is-open .topnav-toggle-icon::before { top: 0; transform: rotate(45deg); }
.topnav.is-open .topnav-toggle-icon::after  { top: 0; transform: rotate(-45deg); }

/* =============== 1024px : tablet & small laptop =================== */
@media (max-width: 1024px) {
  .wrap { padding: 24px 24px 64px; }
  .page-narrow,
  .page-medium { padding: 24px 24px 64px; }

  /* Section heads scale down */
  .sect-head h2 { font-size: 28px; }

  /* Chart legend & toggles wrap cleanly */
  .chart-head { flex-wrap: wrap; gap: 10px; }
  .chart-legend { flex-wrap: wrap; gap: 12px; }
}

/* ============= 768px : phone landscape / small tablet ============= */
@media (max-width: 768px) {

  /* ----- Containers ----- */
  body { font-size: 14px; }
  .wrap { padding: 16px 16px 56px; }
  .page-narrow,
  .page-medium { padding: 20px 16px 56px; max-width: 100%; }

  /* ----- Top navigation : hamburger drawer pattern ----- */
  .topnav {
    padding: 12px 16px;
    flex-wrap: wrap;
    gap: 12px;
  }
  .topnav-brand {
    font-size: 16px;
    flex: 1 1 auto;
    min-width: 0;
    /* Allow truncation rather than overflow */
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .topnav-toggle { display: inline-flex; }
  .topnav-links {
    display: none;
    flex-basis: 100%;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    padding-top: 8px;
    border-top: 1px solid var(--rule-soft);
    margin-top: 4px;
  }
  .topnav.is-open .topnav-links { display: flex; }
  .topnav-link {
    padding: 14px 4px;
    border-bottom: 1px solid var(--rule-soft);
    font-size: 12px;
    min-height: 44px;
    display: flex;
    align-items: center;
  }
  .topnav-link:last-of-type { border-bottom: none; }
  .topnav-user {
    padding: 12px 4px 6px;
    font-size: 10.5px;
    border-bottom: 1px solid var(--rule-soft);
  }

  /* ----- Masthead (dashboard) ----- */
  .mast { padding-bottom: 14px; margin-bottom: 22px; }
  .mast-top {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    font-size: 10px;
    letter-spacing: .16em;
    margin-bottom: 14px;
    line-height: 1.5;
  }
  .mast-top .right { gap: 14px; flex-wrap: wrap; }
  .mast-sub {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    margin-top: 12px;
  }
  .mast-sub .tag { font-size: 16px; line-height: 1.4; }
  .mast-sub .meta { text-align: left; font-size: 10px; }

  /* ----- Confidentiality & sample banners ----- */
  .confid-banner,
  .sample-banner {
    padding: 12px 14px;
    margin-bottom: 18px;
  }
  .confid-banner-v,
  .sample-banner-v { font-size: 13px; line-height: 1.6; }

  /* ----- Section heads ----- */
  .section { margin-top: 28px; }
  .sect-head {
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
    padding-bottom: 10px;
    margin-bottom: 18px;
  }
  .sect-head h2 { font-size: 24px; line-height: 1.2; }
  .sect-head .kicker { font-size: 9.5px; letter-spacing: .2em; }
  .subhead { font-size: 17px; margin: 22px 0 12px; }
  .subhead-meta { font-size: 9.5px; }
  .section-note { font-size: 13.5px; padding: 12px 14px; }

  /* ----- Strap of headline metrics (6-col grid) ----- */
  .strap {
    grid-template-columns: repeat(2, 1fr);
    padding: 14px 0;
    margin-bottom: 26px;
    row-gap: 16px;
  }
  /* Reset every-third-border logic from the 900px rule */
  .strap-item {
    padding: 0 12px;
    border-right: 1px solid var(--rule-soft);
    border-top: none !important;
    padding-top: 0 !important;
  }
  .strap-item:nth-child(odd) { padding-left: 0; }
  .strap-item:nth-child(even) { border-right: none; padding-right: 0; }
  .strap-item:nth-child(3),
  .strap-item:nth-child(4),
  .strap-item:nth-child(5),
  .strap-item:nth-child(6) {
    padding-top: 14px !important;
    border-top: 1px solid var(--rule-soft) !important;
  }
  .strap-val { font-size: 22px; }
  .strap-val.pending { font-size: 17px; }
  .strap-sub { font-size: 10px; }

  /* ----- Feeder cards ----- */
  .feeder-card { padding: 18px 18px; gap: 14px; }
  .feeder-head {
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
    padding-bottom: 12px;
  }
  .feeder-asof { padding-top: 0; font-size: 13px; }
  .feeder-name { font-size: 19px; }
  .feeder-share-val { font-size: 30px; }
  .feeder-stat-v { font-size: 14px; }
  .feeder-stat-k { font-size: 10.5px; }

  /* ----- Master strip ----- */
  .master-strip {
    padding: 16px 18px;
    gap: 14px;
  }
  .master-strip-name { font-size: 20px; }
  .master-strip-stats { gap: 14px 24px; width: 100%; }
  .master-strip-v { font-size: 16px; }

  /* ----- Source legend ----- */
  .source-item { padding: 12px 14px; }

  /* ----- Charts ----- */
  .chart-card { padding: 14px 12px; }
  .chart-head {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    padding-bottom: 10px;
    margin-bottom: 12px;
  }
  .chart-title { font-size: 18px; line-height: 1.3; }
  .chart-legend { font-size: 10px; gap: 10px; }
  .chart-wrap { height: 260px; }
  .chart-wrap.tall { height: 300px; }
  .chart-wrap.short { height: 200px; }

  /* ----- Benchmark toggles & regime strip ----- */
  .bench-toggles {
    padding: 10px 10px;
    gap: 6px;
  }
  .bench-toggles-label {
    flex-basis: 100%;
    margin: 0 0 4px;
  }
  .bench-chip {
    padding: 7px 10px;
    font-size: 11px;
    min-height: 34px;
  }
  .regime-strip {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    padding: 10px 12px;
  }
  .regime-strip-stats {
    gap: 14px 20px;
    flex-wrap: wrap;
  }

  /* ----- Grids ----- */
  .grid-2 { grid-template-columns: 1fr; gap: 20px; }
  .grid-3 { grid-template-columns: 1fr; gap: 20px; }

  /* ----- Metric tables ----- */
  .metric-tbl td.label { font-size: 12.5px; }
  .metric-tbl td.value { font-size: 13px; }
  .metric-tbl td { padding: 10px 0; }

  /* ----- Wide data tables : enable horizontal scroll ----- */
  .bench-table-wrap {
    padding: 8px 4px 14px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .bench-table { min-width: 480px; }
  .bench-table thead th { font-size: 9.5px; padding: 10px 8px 8px; }
  .bench-table thead th.bench-table-metric { font-size: 14px; }
  .bench-table tbody td { font-size: 11px; padding: 8px 8px; }
  .bench-table tbody td:first-child { font-size: 11px; }

  /* ----- Heatmap : horizontal scroll on phone ----- */
  #heatmap-wrap,
  .heatmap-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .heatmap { min-width: 640px; border-spacing: 2px; }
  .heatmap th { font-size: 9px; padding: 3px; }
  .heatmap td { padding: 9px 4px; font-size: 11px; }
  .heatmap td.year { font-size: 14px; padding-right: 8px; }
  .hm-mtd { font-size: 8px; }
  .hm-key { gap: 14px; font-size: 10px; padding-top: 10px; }

  /* ----- Forms & cards ----- */
  .card { padding: 22px 18px; margin-bottom: 18px; }
  .card-title { font-size: 20px; }
  .card-body { font-size: 13.5px; }

  .form-group { margin-bottom: 16px; }
  .form-label { font-size: 10.5px; }
  .form-input,
  .form-textarea { padding: 12px 12px; }

  .checkbox-group { padding: 12px; gap: 10px; }
  .checkbox-group label { font-size: 12.5px; line-height: 1.5; }
  /* Touch-target friendly checkboxes */
  .checkbox-group input[type="checkbox"] {
    width: 18px;
    height: 18px;
    margin-top: 1px;
  }

  .btn-primary,
  .btn-secondary {
    padding: 14px 22px;
    font-size: 11.5px;
    min-height: 44px;
  }

  /* ----- Upload area ----- */
  .upload-area { padding: 36px 20px; }
  .upload-label { font-size: 18px; }
  .upload-hint { font-size: 10px; }

  /* ----- Tooltip : keep within viewport on mobile ----- */
  .info:hover::after {
    width: min(280px, calc(100vw - 32px));
    max-width: calc(100vw - 32px);
    font-size: 11.5px;
    padding: 9px 12px;
  }

  /* ----- Method list (methodology page) : stack key/value ----- */
  .method-list li {
    grid-template-columns: 1fr;
    gap: 4px;
    padding: 12px 0;
  }
  .method-list .method-k { font-size: 10.5px; }
  .method-list .method-v { font-size: 13px; line-height: 1.6; }

  /* ----- TOC ----- */
  .with-toc { gap: 24px; }
  .toc { padding: 12px 0; }
  .toc-item { padding: 10px 0 10px 10px; font-size: 11px; }

  /* ----- Colophon footer ----- */
  .colophon {
    grid-template-columns: 1fr;
    gap: 20px;
    margin-top: 40px;
  }
  .colophon .lead { font-size: 13px; }
  .colophon .meta { text-align: left; font-size: 10px; line-height: 1.9; }
  .colophon .disc-k { font-size: 9.5px; }

  /* ----- Audit table (already scrolls; tighten cells) ----- */
  .audit-table th { font-size: 9px; padding: 8px 8px; }
  .audit-table td { font-size: 10px; padding: 8px 8px; }

  /* ----- Audit-log filter grid (inline-styled 3-col on desktop) ----- */
  .card-body > div[style*="grid-template-columns: 1fr 1fr 1fr"] {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }

  /* ----- Misc: gate (load screen) ----- */
  .gate { padding: 32px 16px; }
  .gate-sources { gap: 18px; }
  .gate-drop { padding: 24px 20px; }
  .gate-footer { font-size: 9.5px; margin-top: 36px; line-height: 1.8; }
}

/* ================ 480px : phone portrait (tight) ================== */
@media (max-width: 480px) {

  .wrap { padding: 14px 12px 48px; }
  .page-narrow,
  .page-medium { padding: 16px 12px 48px; }

  /* Top nav */
  .topnav { padding: 10px 12px; }
  .topnav-brand { font-size: 14.5px; }

  /* Masthead */
  .mast-logo { height: 40px; }

  /* Section heads */
  .sect-head h2 { font-size: 21px; }
  .subhead { font-size: 16px; }

  /* Strap : 6 cells in 2 columns is still the right shape, but
     the values must read clearly */
  .strap { padding: 12px 0; row-gap: 14px; }
  .strap-item { padding: 0 8px; }
  .strap-val { font-size: 19px; }
  .strap-val.pending { font-size: 15px; }
  .strap-label { font-size: 9px; }

  /* Feeder & master */
  .feeder-card { padding: 16px 14px; }
  .feeder-share-val { font-size: 26px; }
  .feeder-name { font-size: 17px; }
  .master-strip { padding: 14px 14px; }
  .master-strip-name { font-size: 18px; }
  .master-strip-v { font-size: 15px; }

  /* Charts */
  .chart-card { padding: 12px 10px; }
  .chart-title { font-size: 16.5px; }
  .chart-wrap { height: 240px; }
  .chart-wrap.tall { height: 280px; }
  .chart-wrap.short { height: 180px; }

  /* Cards */
  .card { padding: 18px 14px; }
  .card-title { font-size: 18px; }
  .card-eyebrow { font-size: 9.5px; }

  /* Tables — shrink one more notch */
  .bench-table tbody td { font-size: 10.5px; padding: 7px 6px; }
  .heatmap td { font-size: 10.5px; padding: 8px 3px; }
  .heatmap td.year { font-size: 13px; }
  .metric-tbl td.label { font-size: 12px; }
  .metric-tbl td.value { font-size: 12.5px; }

  /* Forms — keep 16px on inputs (set above), trim elsewhere */
  .checkbox-group label { font-size: 12px; }
  .btn-primary,
  .btn-secondary { padding: 13px 18px; font-size: 11px; width: 100%; }

  /* Index/login: inline align-items on submit row */
  .card-body > div[style*="justify-content: space-between"] {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 14px;
  }

  /* Logo on gate / index */
  .gate-logo { width: min(240px, 70vw); }
}

/* ============= Touch-device fine print (any size) ================= */
/* On true touch devices, hide hover-only tooltip pre-arrow because
   :hover persists awkwardly after tap. Tooltip text still appears
   via tap-and-hold on most browsers via the underlying element. */
@media (hover: none) {
  .info:hover::after,
  .info:hover::before { display: none; }
  /* Tap-to-show via :focus instead */
  .info { -webkit-tap-highlight-color: transparent; }
  .info:focus { outline: 1px dashed var(--oxblood); }
}

/* Allow horizontal-scroll containers to actually scroll on iOS */
.chart-card,
.bench-table-wrap {
  -webkit-overflow-scrolling: touch;
}
