/* chanalyse — minimal dark-on-light UI */
:root {
  --fg: #1c1c1c;
  --muted: #6a6a6a;
  --bg: #fafaf7;
  --card-bg: #ffffff;
  --border: #e0e0d8;
  --accent: #c84a1f;
  --accent-soft: #f5d8cd;
  --pos: #1b873b;
  --neg: #b91c1c;
  --neu: #6a6a6a;
}
* { box-sizing: border-box; }
body { font: 14px/1.5 -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif; color: var(--fg); background: var(--bg); margin: 0; }

.topbar { background: #1c1c1c; color: #fff; padding: 12px 24px; display: flex; align-items: center; gap: 24px; }
.topbar .brand { color: #fff; font-weight: 700; text-decoration: none; font-size: 18px; }
.topbar nav { flex: 1; }
.topbar nav a { color: #ccc; margin-right: 16px; text-decoration: none; }
.topbar nav a:hover { color: #fff; }
.search-form { display: flex; gap: 4px; }
.search-form input { background: #2c2c2c; color: #fff; border: 1px solid #444; padding: 6px 10px; border-radius: 4px; font-size: 13px; min-width: 220px; }
.search-form input::placeholder { color: #888; }
.search-form button { background: var(--accent); color: #fff; border: none; padding: 6px 14px; border-radius: 4px; cursor: pointer; }

main { max-width: 1200px; margin: 24px auto; padding: 0 24px; }
h1 { margin: 4px 0 16px; font-size: 28px; }
h2 { margin-top: 36px; font-size: 18px; border-bottom: 1px solid var(--border); padding-bottom: 6px; }

.breadcrumb { color: var(--muted); font-size: 12px; margin-bottom: 4px; }
.breadcrumb a { color: var(--muted); }

table { width: 100%; border-collapse: collapse; margin-top: 12px; }
th, td { text-align: left; padding: 8px 12px; border-bottom: 1px solid var(--border); }
th { background: #f0f0eb; font-weight: 600; font-size: 12px; text-transform: uppercase; letter-spacing: 0.5px; color: var(--muted); }
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }
code { background: #f0f0eb; padding: 2px 4px; border-radius: 3px; font-size: 12px; }
.muted { color: var(--muted); font-size: 12px; }
.hint { padding: 10px 14px; background: var(--accent-soft); border-left: 3px solid var(--accent); border-radius: 3px; margin: 16px 0; font-size: 13px; }

/* Window selector */
.window-bar { display: flex; gap: 4px; align-items: center; margin-bottom: 20px; }
.window-label { color: var(--muted); font-size: 12px; margin-right: 8px; text-transform: uppercase; letter-spacing: 0.5px; }
.window-btn { padding: 4px 10px; border: 1px solid var(--border); border-radius: 3px; font-size: 12px; color: var(--fg); background: var(--card-bg); transition: background .12s, box-shadow .12s; }
.window-btn:hover { background: var(--accent-soft); text-decoration: none; }
.window-btn.active { background: var(--accent); color: #fff; border-color: var(--accent); font-weight: 700; box-shadow: 0 0 0 2px var(--accent-soft); }

/* Custom date-range + comparison controls (analysis page) */
.range-bar { display: flex; flex-wrap: wrap; gap: 10px 14px; align-items: flex-end; margin: 6px 0 18px; padding: 12px 14px; border: 1px solid var(--border); border-radius: 6px; background: var(--card-bg); }
.range-bar.active { border-color: var(--accent); box-shadow: 0 0 0 2px var(--accent-soft); }
.range-field { display: flex; flex-direction: column; gap: 3px; }
.range-field label { color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: 0.5px; }
.range-field input[type="date"] { padding: 5px 8px; border: 1px solid var(--border); border-radius: 3px; background: var(--card-bg); color: var(--fg); font-size: 13px; font-family: inherit; }
.range-field input[type="date"]:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 2px var(--accent-soft); }
.range-sep { color: var(--muted); padding-bottom: 6px; font-size: 13px; }
.range-bar .btn-sm, .range-apply { padding: 6px 14px; border: 1px solid var(--accent); border-radius: 3px; background: var(--accent); color: #fff; font-size: 13px; font-weight: 600; cursor: pointer; }
.range-bar .btn-sm:hover, .range-apply:hover { filter: brightness(1.08); }
.range-clear { padding: 6px 12px; border: 1px solid var(--border); border-radius: 3px; background: var(--card-bg); color: var(--fg); font-size: 13px; cursor: pointer; }
.range-clear:hover { border-color: var(--accent); background: var(--accent-soft); }
.range-grp-label { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; color: var(--accent); width: 100%; margin-bottom: -4px; }
.range-status { width: 100%; font-size: 12px; color: var(--muted); margin-top: 2px; }
.range-status.warn { color: #b45309; }

/* Comparison panel: Period A vs Period B */
.compare-panel { margin: 8px 0 30px; padding: 16px; border: 1px solid var(--accent); border-radius: 8px; background: var(--accent-soft); }
.compare-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px; margin-bottom: 14px; }
.compare-col { background: var(--card-bg); border: 1px solid var(--border); border-radius: 6px; padding: 12px; }
.compare-col h4 { margin: 0 0 8px; font-size: 13px; }
.compare-col .pill { display: inline-block; font-size: 11px; padding: 1px 7px; border-radius: 10px; font-family: ui-monospace, monospace; }
.pill-a { background: #1f4fa6; color: #fff; }
.pill-b { background: #c84a1f; color: #fff; }
.compare-metric { display: flex; justify-content: space-between; padding: 4px 0; border-bottom: 1px dashed var(--border); font-size: 13px; }
.compare-metric:last-child { border-bottom: none; }
.compare-metric .k { color: var(--muted); }
.delta-up { color: #1b873b; font-weight: 700; }
.delta-down { color: #b91c1c; font-weight: 700; }
.delta-flat { color: var(--muted); }
.compare-themes { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.compare-themes h5 { margin: 0 0 6px; font-size: 12px; text-transform: uppercase; letter-spacing: 0.4px; color: var(--muted); }
.compare-themes .tlist { list-style: none; margin: 0; padding: 0; }
.compare-themes .tlist li { display: flex; justify-content: space-between; padding: 3px 0; font-size: 13px; border-bottom: 1px dashed var(--border); }
@media (max-width: 640px) { .compare-grid { grid-template-columns: 1fr; } .compare-themes { grid-template-columns: 1fr; } }

/* Cards (board grid) */
.cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 12px; }
.card { display: block; background: var(--card-bg); border: 1px solid var(--border); padding: 14px; border-radius: 6px; color: inherit; text-decoration: none; transition: border-color 0.15s; }
.card:hover { border-color: var(--accent); text-decoration: none; }
.card-title { font-size: 14px; color: var(--muted); font-family: ui-monospace, SFMono-Regular, Menlo, monospace; }
.card-stat { font-size: 22px; font-weight: 600; margin: 4px 0; }
.card-stat small { font-size: 12px; color: var(--muted); font-weight: 400; }
.card-sub { font-size: 12px; color: var(--muted); }
.card-time { font-size: 11px; color: var(--muted); margin-top: 6px; }

/* Bars */
.bars { list-style: none; padding: 0; margin: 8px 0; }
.bars li { display: flex; align-items: center; margin-bottom: 4px; gap: 8px; }
.bar-label { width: 140px; font-size: 12px; }
.bar { display: inline-block; height: 14px; background: var(--accent); border-radius: 2px; min-width: 2px; }
.bar-count { font-size: 12px; color: var(--muted); }
.stance-bar-bullish { background: #1b873b; }
.stance-bar-bearish { background: #b91c1c; }
.stance-bar-neutral { background: #888; }
.stance-bar-mixed { background: #d4a13e; }
.stance-bar-irony { background: #6f3aac; }
.stance-bar-unclear { background: #cccccc; }

.two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
/* grid/flex children must be allowed to shrink below their content's
   intrinsic min-width, otherwise wide tables push the column (and page) wide */
.two-col > * { min-width: 0; }
@media (max-width: 800px) { .two-col { grid-template-columns: 1fr; } }

/* Alerts */
.alerts { list-style: none; padding: 0; }
.alerts li { padding: 10px 12px; background: var(--card-bg); border: 1px solid var(--border); margin-bottom: 6px; border-radius: 4px; }
.alerts .note { color: var(--muted); margin-top: 4px; font-size: 12px; }

.empty { color: var(--muted); font-style: italic; padding: 12px; }

/* Sparkline */
.sparkline { display: flex; align-items: flex-end; height: 100px; border-bottom: 1px solid var(--border); padding-bottom: 4px; gap: 1px; }
.tick { display: inline-block; flex: 1 1 4px; min-width: 2px; max-width: 8px; background: var(--accent); min-height: 1px; }

/* Thread list */
.threads { list-style: none; padding: 0; margin-top: 12px; }
.threads li { padding: 8px 12px; background: var(--card-bg); border-bottom: 1px solid var(--border); display: grid; grid-template-columns: 120px 130px 80px 1fr; gap: 12px; align-items: center; }
.threads li:hover { background: #fff; }
.threads .meta { color: var(--muted); font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 12px; }
.threads .topic { color: var(--accent); font-weight: 500; font-size: 12px; }
.threads .text { font-size: 13px; overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; max-height: 3em; }

/* Stance pills */
.stance { font-size: 11px; padding: 2px 6px; border-radius: 3px; background: #eee; text-align: center; display: inline-block; }
.stance-bullish { background: #d6f5e0; color: #1b873b; }
.stance-bearish { background: #f8d7d4; color: #b91c1c; }
.stance-neutral { background: #eee; color: var(--neu); }
.stance-mixed { background: #fff3cd; color: #856404; }
.stance-irony { background: #e0d4f5; color: #6f3aac; }
.stance-unclear { background: #eee; color: var(--muted); }
.stance-legend { margin: 10px 0; font-size: 12px; }
.stance-legend summary { cursor: pointer; color: var(--muted); }
.stance-legend ul { list-style: none; padding: 8px 0 0 0; }
.stance-legend li { margin-bottom: 4px; }

/* Category pills */
.cat-pill { font-size: 11px; padding: 2px 8px; border-radius: 10px; background: #eee; color: var(--muted); }
.cat-finance { background: #d6f5e0; color: #1b873b; }
.cat-politics { background: #fde2e2; color: #b91c1c; }
.cat-technology { background: #d6e2f5; color: #1f4fa6; }
.cat-science { background: #e6d6f5; color: #5f2eaa; }
.cat-culture { background: #f5e6d6; color: #c85a1f; }
.cat-society { background: #f5d6ec; color: #a6238b; }
.cat-geopolitics { background: #f8d7d4; color: #b91c1c; }
.cat-health { background: #d6f5ee; color: #1b8773; }
.cat-religion { background: #f5edd6; color: #8b6d23; }
.cat-philosophy { background: #ddd6f5; color: #4b3aac; }
.cat-drama { background: #ffe0c0; color: #a05000; }
.cat-misc { background: #eee; color: var(--muted); }

/* Sentiment */
.sent.pos { color: var(--pos); font-weight: 500; }
.sent.neg { color: var(--neg); font-weight: 500; }
.sent.neu { color: var(--neu); }

/* Status page */
.badge { display: inline-block; padding: 2px 8px; border-radius: 3px; font-size: 12px; }
.badge.ok { background: #d6f5e0; color: #1b873b; }
.badge.fail { background: #f8d7d4; color: #b91c1c; }
.classifier-chain { padding-left: 20px; }
.classifier-chain li { margin: 4px 0; }
.aliases { color: var(--muted); font-size: 12px; }

/* Search page */
.search-page { display: flex; gap: 8px; margin: 16px 0; flex-wrap: wrap; }
.search-page input, .search-page select { padding: 8px 12px; border: 1px solid var(--border); border-radius: 4px; font-size: 14px; background: var(--card-bg); }
.search-page input { flex: 1 1 240px; }
.search-page button { padding: 8px 20px; background: var(--accent); color: #fff; border: none; border-radius: 4px; cursor: pointer; }

/* Alert severity */
.z.high { color: #d4a13e; font-weight: 600; }
.z.critical { color: var(--neg); font-weight: 700; }
.sample a { font-family: ui-monospace, monospace; font-size: 12px; }

footer { text-align: center; color: var(--muted); padding: 24px; font-size: 12px; }

/* ── /ops dashboard ──────────────────────────────────────────── */
body.ops .topbar { background: #0f0f0f; }
.badge.warn { background: #fde2c0; color: #a05000; }
.hint.ok { background: #d6f5e0; border-left-color: #1b873b; }
.hint.warn { background: #fde2c0; border-left-color: #d4a13e; }
.hint.fail { background: #f8d7d4; border-left-color: var(--neg); }

.ops-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 16px; margin-top: 16px; }
.ops-card { background: var(--card-bg); border: 1px solid var(--border); border-radius: 6px; padding: 14px; }
.ops-card h3 { margin: 0 0 10px 0; font-size: 13px; text-transform: uppercase; letter-spacing: 0.5px; color: var(--muted); }
.pulse-list, .kv-list { list-style: none; padding: 0; margin: 0; }
.pulse-list li, .kv-list li { display: flex; justify-content: space-between; padding: 4px 0; border-bottom: 1px solid #f0f0eb; font-size: 13px; }
.pulse-list li:last-child, .kv-list li:last-child { border-bottom: none; }
.pulse-label, .kv-list li > span:first-child { color: var(--muted); }
.pulse-val, .v { font-family: ui-monospace, monospace; }

.ops-backends th, .ops-backends td { padding: 6px 10px; }
.ops-backends td code { font-size: 12px; }
.ops-errors td { font-size: 12px; padding: 4px 10px; }
.ops-errors .err-msg { font-family: ui-monospace, monospace; color: var(--neg); }

.ops-chart { display: flex; align-items: flex-end; height: 80px; gap: 2px; padding: 8px 0; border-bottom: 1px solid var(--border); }
.ops-tick { flex: 1 1 0; background: var(--accent); border-radius: 1px 1px 0 0; min-height: 2px; }

.ops-actions { display: flex; flex-wrap: wrap; gap: 8px; margin: 12px 0; }
.ops-actions button { padding: 8px 14px; background: var(--card-bg); border: 1px solid var(--border); border-radius: 4px; font-size: 13px; cursor: pointer; }
.ops-actions button:hover { border-color: var(--accent); background: var(--accent-soft); }
.ops-actions button.warn { border-color: #d4a13e; }
.ops-actions button.warn:hover { background: #fde2c0; }

/* ── v3: triggers, entities, stories ─────────────────────────── */
.triggers { list-style: none; padding: 0; }
.trigger { background: var(--card-bg); border: 1px solid var(--border); border-left: 4px solid var(--accent); border-radius: 4px; padding: 12px 14px; margin-bottom: 10px; }
.trigger-head { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.trigger-title { font-weight: 600; font-size: 15px; }
.score-badge { background: var(--accent); color: #fff; font-weight: 700; font-size: 12px; padding: 2px 7px; border-radius: 4px; font-family: ui-monospace, monospace; }
.cross-badge { background: #6f3aac; color: #fff; font-size: 10px; padding: 2px 6px; border-radius: 3px; text-transform: uppercase; }
.trigger-meta { font-size: 12px; color: var(--muted); margin: 5px 0; }
.brief { background: var(--card-bg, #f5f0e8); border: 1px solid var(--border); border-radius: 4px; padding: 8px 10px; margin-top: 6px; font-size: 13px; color: var(--fg); }
.claims { margin: 6px 0 0 0; padding-left: 18px; font-size: 13.5px; line-height: 1.55; color: var(--fg); }
.claims li { margin-bottom: 5px; }

/* Related articles — eye-catching panels with thumbnail + header */
.related-article-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 14px; margin-top: 10px; }
.ra-card { display: flex; flex-direction: column; background: var(--card-bg); border: 1px solid var(--border); border-radius: 10px; overflow: hidden; text-decoration: none; color: inherit; transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.ra-card:hover { transform: translateY(-3px); border-color: var(--accent, #ff6a3d); box-shadow: 0 8px 22px rgba(0,0,0,.12); }
.ra-thumb { height: 130px; background-size: cover; background-position: center; background-color: #1c2c3c; display: flex; align-items: center; justify-content: center; }
.ra-thumb-fallback { font-size: 34px; opacity: .5; }
.ra-body { padding: 12px 14px; display: flex; flex-direction: column; gap: 6px; }
.ra-cat { font: 700 9px ui-monospace, monospace; letter-spacing: .12em; text-transform: uppercase; color: var(--accent, #ff6a3d); }
.ra-title { font-size: 15px; font-weight: 600; line-height: 1.3; color: var(--fg); }
.ra-summary { font-size: 12.5px; line-height: 1.5; color: var(--muted); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.ra-cta { font: 600 12px ui-monospace, monospace; color: var(--accent, #ff6a3d); margin-top: 2px; }
.samples { font-size: 11px; color: var(--muted); margin-top: 6px; font-family: ui-monospace, monospace; }

.ents { display: flex; flex-wrap: wrap; gap: 5px; margin: 6px 0; }
.ent { background: #eef0f5; color: #2c3e6a; font-size: 12px; padding: 2px 8px; border-radius: 10px; }
.ent.big { font-size: 14px; padding: 4px 12px; }
.ent small { color: var(--muted); }

.nov-breaking { color: #b91c1c; font-weight: 600; }
.nov-developing { color: #c87a1f; font-weight: 500; }
.nov-evergreen { color: var(--muted); }

.filter-bar { display: flex; gap: 12px; align-items: center; margin: 12px 0; }
.filter-bar select, .filter-bar input { padding: 6px 10px; border: 1px solid var(--border); border-radius: 4px; }
.small { font-size: 11px; }

/* ── dark mode ────────────────────────────────────────────────── */
:root[data-theme="dark"] {
  --fg: #e6e6e6;
  --muted: #9a9a9a;
  --bg: #15171a;
  --card-bg: #1e2125;
  --border: #2c3036;
  --accent: #e8633a;
  --accent-soft: #3a2418;
  --pos: #3fcf6b;
  --neg: #f0584a;
  --neu: #9a9a9a;
}
:root[data-theme="dark"] body { background: var(--bg); color: var(--fg); }
:root[data-theme="dark"] th { background: #24282e; color: var(--muted); }
:root[data-theme="dark"] code { background: #24282e; }
:root[data-theme="dark"] .topbar { background: #0d0e10; }
:root[data-theme="dark"] .window-btn { background: var(--card-bg); color: var(--fg); }
:root[data-theme="dark"] .brief { background: #24282e; }
:root[data-theme="dark"] .ent { background: #24303f; color: #9bc0ff; }
:root[data-theme="dark"] .search-form input { background: #24282e; color: #fff; border-color: #333; }
.theme-toggle { background: transparent; border: none; cursor: pointer; font-size: 18px; padding: 4px 8px; }

/* ── analysis page v2 ─────────────────────────────────────────── */
.explainer { background: var(--card-bg); border: 1px solid var(--border); border-radius: 8px; padding: 4px 14px; margin: 12px 0 18px; }
.explainer summary { cursor: pointer; font-weight: 600; padding: 8px 0; }
.explainer-body { font-size: 13px; line-height: 1.6; padding-bottom: 8px; }
.explainer-body ul { margin: 8px 0; padding-left: 18px; }
.board-tabs { display: flex; flex-wrap: wrap; gap: 6px; margin: 12px 0; }
.board-tab { padding: 6px 14px; border: 1px solid var(--border); border-radius: 18px; background: var(--card-bg); color: var(--fg); cursor: pointer; font-size: 13px; font-family: ui-monospace, monospace; transition: background .12s, border-color .12s, box-shadow .12s; }
.board-tab:hover { border-color: var(--accent); background: var(--accent-soft); }
.board-tab.active { background: var(--accent); color: #fff; border-color: var(--accent); font-weight: 700; box-shadow: 0 0 0 3px var(--accent-soft); }
.board-tab.active::before { content: "✓ "; font-weight: 700; }
.stories-table td { font-size: 13px; }
tr.clickable { cursor: pointer; }
tr.clickable:hover { background: var(--accent-soft); }

/* ── extra analysis: explorer / trend / movers ─────────────────── */
.section-rule { border: none; border-top: 2px dashed var(--border); margin: 34px 0 18px; }
.explore-block { margin: 18px 0; }
.explore-summary { cursor: pointer; font-size: 18px; font-weight: 700; padding: 8px 0; list-style: none; }
.explore-summary::-webkit-details-marker { display: none; }
.explore-summary::before { content: '▸ '; color: var(--accent); }
details[open] > .explore-summary::before { content: '▾ '; }
.small { font-size: 12px; }
.mini-h { font-size: 14px; margin: 10px 0 6px; }
.explore-controls { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; margin: 10px 0 14px; }
.explore-controls label { font-size: 12px; color: var(--muted); display: flex; flex-direction: column; gap: 2px; }
.explore-controls select, .explore-controls input[type=text] {
  padding: 5px 8px; border: 1px solid var(--border); border-radius: 6px;
  background: var(--card-bg); color: var(--fg); font-family: ui-monospace, monospace; font-size: 13px; }
.explore-controls input[type=text] { min-width: 220px; }
.btn-sm { padding: 4px 9px; border: 1px solid var(--border); border-radius: 6px; background: var(--card-bg);
  color: var(--fg); cursor: pointer; font-size: 11px; font-family: ui-monospace, monospace; }
.btn-sm:hover { border-color: var(--accent); color: var(--accent); }
.mv-table { width: 100%; font-size: 13px; }
.mv-table td, .mv-table th { padding: 5px 8px; }
.mv-table .empty { color: var(--muted); text-align: center; padding: 14px; }

.cat-badge { font-size: 10px; padding: 1px 7px; border-radius: 10px; text-transform: uppercase; letter-spacing: .03em; font-weight: 600; }
.cat-crypto    { background: #f3b03922; color: #b8860b; }
.cat-ticker    { background: #1f4fa622; color: #1f4fa6; }
.cat-company   { background: #1b873b22; color: #1b873b; }
.cat-commodity { background: #c8851f22; color: #a8650f; }
.cat-political { background: #b91c1c22; color: #b91c1c; }
.cat-tech      { background: #5f2eaa22; color: #5f2eaa; }
.cat-person    { background: #2a8f8f22; color: #1b7373; }
.cat-other     { background: var(--border); color: var(--muted); }

.chips, .cat-chips { display: inline-flex; flex-wrap: wrap; gap: 6px; }
.cat-chips { margin: 8px 0 12px; }
.chip { background: var(--accent); color: #fff; padding: 3px 10px; border-radius: 14px; font-size: 12px; display: inline-flex; gap: 6px; align-items: center; }
.chip a { color: #fff; text-decoration: none; font-weight: 700; }
.cat-chip { cursor: pointer; padding: 4px 11px; border-radius: 14px; font-size: 12px; border: 1px solid var(--border); }
.cat-chip:hover { border-color: var(--accent); }

.mom { font-size: 11px; padding: 2px 8px; border-radius: 10px; font-weight: 600; }
.mom-breakout { background: #b91c1c; color: #fff; }
.mom-rising   { background: #1b873b22; color: #1b873b; }
.mom-steady   { background: var(--border); color: var(--muted); }
.mom-cooling  { background: #1f4fa622; color: #1f4fa6; }
.mom-flat     { background: var(--border); color: var(--muted); }

/* ── dashboard: articles strip + research areas ────────────────── */
.article-strip { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 12px; }
.article-card { display: block; padding: 12px 14px; border: 1px solid var(--border); border-radius: 8px; background: var(--card-bg); color: var(--fg); text-decoration: none; }
.article-card:hover { border-color: var(--accent); }
.ac-top { display: flex; gap: 8px; align-items: center; margin-bottom: 6px; font-size: 12px; }
.ac-title { font-weight: 600; font-size: 14px; line-height: 1.3; margin-bottom: 5px; }
.ac-sum { font-size: 12px; color: var(--muted); line-height: 1.4; margin-bottom: 6px; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.ac-meta { font-size: 11px; }
.status-badge { font-size: 10px; padding: 1px 8px; border-radius: 10px; text-transform: uppercase; font-weight: 600; }
.status-draft { background: #c87a1f22; color: #a8650f; }
.status-published { background: #1b873b22; color: #1b873b; }
.status-rejected { background: var(--border); color: var(--muted); }

.research-table { width: 100%; font-size: 13px; }
.research-table td, .research-table th { padding: 7px 8px; vertical-align: top; }
.ra-label { font-weight: 600; margin-bottom: 3px; }

/* ── signals page ──────────────────────────────────────────────── */
.warn { color: #b91c1c; font-size: 12px; background: #b91c1c11; padding: 8px 12px; border-radius: 6px; border-left: 3px solid #b91c1c; }
.api-table code { font-size: 11px; }
.api-example { background: var(--card-bg); border: 1px solid var(--border); border-radius: 8px; padding: 12px 14px; overflow:auto; font-size: 12px; line-height: 1.6; }
.api-example code { background: none; color: var(--fg); padding: 0; }
#signals-api .mini-h { margin: 18px 0 6px; }
.sig { font-size: 10px; padding: 1px 7px; border-radius: 10px; font-weight: 600; white-space: nowrap; }
.sig-bullish_spike { background: #1b873b; color: #fff; }
.sig-bearish_spike { background: #b91c1c; color: #fff; }
.sig-buzz_spike    { background: #c87a1f; color: #fff; }
.sig-warming_bullish { background: #1b873b22; color: #1b873b; }
.sig-warming       { background: #c87a1f22; color: #a8650f; }
.sig-cooling       { background: #1f4fa622; color: #1f4fa6; }
.sig-quiet         { background: var(--border); color: var(--muted); }
.export-bar { display: inline-flex; gap: 6px; align-items: center; margin-left: 14px; }

/* ── blog / article layout ─────────────────────────────────────── */
.blog-post { max-width: 720px; margin: 0 auto; }
.blog-kicker { display: flex; gap: 10px; align-items: center; font-size: 12px; text-transform: uppercase; letter-spacing: .04em; margin-bottom: 14px; }
.kicker-board { color: var(--accent); font-weight: 700; }
.kicker-theme { color: var(--muted); }
.blog-title { font-size: 34px; line-height: 1.2; margin: 0 0 14px; letter-spacing: -0.01em; }
.blog-dek { font-size: 19px; line-height: 1.5; color: var(--muted); margin: 0 0 22px; font-weight: 400; }
.blog-byline { display: flex; gap: 12px; align-items: center; padding: 12px 0; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.byline-avatar { font-size: 26px; }
.byline-name { font-weight: 600; }
.blog-tags { display: flex; flex-wrap: wrap; gap: 6px; margin: 16px 0; }
.blog-tags .ent { text-decoration: none; }
.blog-rule { border: none; border-top: 1px solid var(--border); margin: 22px 0; }

.blog-body { font-size: 18px; line-height: 1.75; }
.blog-body h2 { font-size: 24px; margin: 32px 0 12px; line-height: 1.3; }
.blog-body h3 { font-size: 19px; margin: 24px 0 10px; }
.blog-body p { margin: 0 0 18px; }
.blog-body ul, .blog-body ol { margin: 0 0 18px; padding-left: 24px; line-height: 1.7; }
.blog-body li { margin-bottom: 6px; }
.blog-body blockquote { border-left: 3px solid var(--accent); margin: 18px 0; padding: 4px 16px; color: var(--muted); font-style: italic; }
.blog-body a { color: var(--accent); }
.blog-body code { background: var(--card-bg); padding: 1px 5px; border-radius: 4px; font-size: 15px; }

.blog-footer { margin-top: 40px; padding-top: 20px; border-top: 2px solid var(--border); }
.src-block { margin-bottom: 18px; }
.src-links { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 6px; }
.src-links a { font-size: 12px; font-family: ui-monospace, monospace; }
.provenance { background: var(--card-bg); border: 1px solid var(--border); border-radius: 8px; padding: 6px 16px; margin: 16px 0; }
.provenance summary { cursor: pointer; padding: 8px 0; }
.note-list { list-style: none; padding: 0; margin: 8px 0; }
.note-list li { padding: 8px 0; border-bottom: 1px dashed var(--border); font-size: 14px; line-height: 1.5; }
.note-kind { font-size: 10px; padding: 1px 7px; border-radius: 8px; text-transform: uppercase; font-weight: 600; margin-right: 8px; background: var(--border); color: var(--muted); }
.note-claim { background: #1f4fa622; color: #1f4fa6; }
.note-thread_evidence { background: #1b873b22; color: #1b873b; }
.note-summary { background: #c87a1f22; color: #a8650f; }
.disclaimer-note { font-size: 12px; color: var(--muted); background: #b91c1c0d; border-left: 3px solid #b91c1c55; padding: 10px 14px; border-radius: 6px; margin-top: 20px; }

/* blog-style article index cards */
.blog-index { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 16px; }
.blog-index-card { display: block; padding: 18px 20px; border: 1px solid var(--border); border-radius: 10px; background: var(--card-bg); color: var(--fg); text-decoration: none; transition: border-color .15s; }
.blog-index-card:hover { border-color: var(--accent); }
.bic-kicker { display: flex; gap: 8px; align-items: center; font-size: 11px; text-transform: uppercase; letter-spacing: .03em; margin-bottom: 8px; }
.bic-title { font-size: 18px; font-weight: 700; line-height: 1.3; margin-bottom: 8px; }
.bic-dek { font-size: 14px; color: var(--muted); line-height: 1.5; margin-bottom: 10px; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.bic-meta { font-size: 11px; color: var(--muted); }

.window-btn.active { background: var(--accent); color: #fff; border-color: var(--accent); }

/* ── Slide-in thread panel ──────────────────────────────────────── */
.panel-overlay {
  display: none; position: fixed; inset: 0;
  background: rgba(0,0,0,0.35); z-index: 200;
}
.panel-overlay.open { display: block; }
.thread-panel {
  position: fixed; top: 0; right: -480px; width: 460px; max-width: 95vw;
  height: 100vh; background: var(--card-bg); border-left: 1px solid var(--border);
  box-shadow: -4px 0 20px rgba(0,0,0,0.15); z-index: 201;
  display: flex; flex-direction: column;
  transition: right 0.25s ease;
  overflow: hidden;
}
.thread-panel.open { right: 0; }
.panel-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px; border-bottom: 1px solid var(--border);
  font-weight: 600; font-size: 15px;
}
.panel-close {
  background: none; border: none; font-size: 18px; cursor: pointer;
  color: var(--muted); padding: 2px 6px; border-radius: 4px;
}
.panel-close:hover { color: var(--fg); background: var(--border); }
.panel-body { overflow-y: auto; flex: 1; padding: 12px 16px; }
.panel-thread { padding: 10px 0; border-bottom: 1px solid var(--border); }
.panel-thread:last-child { border-bottom: none; }
.pt-head { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; margin-bottom: 4px; }
.pt-id { font-family: ui-monospace, monospace; font-size: 12px; color: var(--muted); }
.pt-text { font-size: 13px; line-height: 1.5; margin-bottom: 4px; }
.pt-links { font-size: 12px; }
.nov { font-size: 11px; padding: 1px 6px; border-radius: 8px; background: var(--border); color: var(--muted); }
.dead { font-size: 11px; padding: 1px 6px; border-radius: 8px; background: #f8d7d4; color: #b91c1c; }

/* ── Activity heat calendar ─────────────────────────────────────── */
.activity-cal-section { margin-top: 32px; }
.activity-cal {
  display: grid;
  grid-template-columns: repeat(10, 14px);
  grid-auto-flow: column;
  grid-template-rows: repeat(7, 12px);
  gap: 2px;
  width: max-content;
  max-width: 100%;
  overflow-x: auto;
  margin: 10px 0 6px;
}
.cal-day {
  width: 12px; height: 12px;
  border-radius: 2px;
  background: var(--border);
  cursor: default;
}
.cal-lv0 { background: var(--border); }
.cal-lv1 { background: #c6e48b; }
.cal-lv2 { background: #7bc96f; }
.cal-lv3 { background: #239a3b; }
.cal-lv4 { background: #196127; }
:root[data-theme="dark"] .cal-lv0 { background: #2c3036; }
:root[data-theme="dark"] .cal-lv1 { background: #0e4429; }
:root[data-theme="dark"] .cal-lv2 { background: #006d32; }
:root[data-theme="dark"] .cal-lv3 { background: #26a641; }
:root[data-theme="dark"] .cal-lv4 { background: #39d353; }
.cal-legend { display: flex; align-items: center; gap: 3px; font-size: 11px; color: var(--muted); margin-top: 4px; }
.cal-legend .cal-day { cursor: default; }

/* ── #10 topic hierarchy (general → granular) ─────────────────────── */
.topic-tree { display: flex; flex-direction: column; gap: 4px; }
.topic-theme { border: 1px solid var(--border); border-radius: 6px; background: var(--card-bg); }
.topic-theme > summary { list-style: none; cursor: pointer; display: flex; align-items: center; gap: 10px; padding: 8px 12px; flex-wrap: wrap; }
.topic-theme > summary::-webkit-details-marker { display: none; }
.topic-theme > summary::before { content: "▸"; color: var(--muted); transition: transform .15s; }
.topic-theme[open] > summary::before { transform: rotate(90deg); }
.topic-theme[open] > summary { border-bottom: 1px solid var(--border); }
.tt-label { font-weight: 600; min-width: 160px; flex: 0 0 auto; }
.tt-share-bar { flex: 1 1 120px; height: 12px; background: var(--accent-soft); border-radius: 6px; overflow: hidden; min-width: 80px; }
.tt-share-fill { display: block; height: 100%; background: var(--accent); }
.tt-share-num { font-variant-numeric: tabular-nums; font-weight: 600; min-width: 44px; text-align: right; }
.tt-count { font-size: 12px; }
.topic-stories { width: 100%; border-collapse: collapse; margin: 0; }
.topic-stories th, .topic-stories td { padding: 6px 12px; text-align: left; border-top: 1px solid var(--border); font-size: 13px; }
.topic-stories th { color: var(--muted); font-weight: 500; }

/* delta indicators (used in topics + significant changes) */
.delta-up { color: var(--pos); font-weight: 600; font-variant-numeric: tabular-nums; }
.delta-down { color: var(--neg); font-weight: 600; font-variant-numeric: tabular-nums; }
.notable-dot { color: var(--accent); }
.sigchange-table .notable-row { background: var(--accent-soft); }
.sigchange-table .notable-row td { font-weight: 500; }

/* clickable entity chips become links */
a.ent { cursor: pointer; }
a.ent:hover { background: var(--accent); color: #fff; text-decoration: none; }
.ra-label a { font-weight: 500; }
.ra-threads { font-size: 11px; margin-left: 8px; color: var(--muted); font-weight: 400; }

/* chart captions + no-data note */
.chart-cap { margin: 6px 2px 0; line-height: 1.4; }
.no-data-note { text-align: center; }

/* story page hub additions */
.story-hub-section { margin-top: 22px; }
.related-articles { list-style: none; padding: 0; display: flex; flex-direction: column; gap: 6px; }
.related-articles a { display: block; padding: 8px 12px; border: 1px solid var(--border); border-radius: 6px; background: var(--card-bg); }
.related-articles a:hover { border-color: var(--accent); }
.thread-links { font-size: 12px; }
.sig-sources { font-size: 11px; color: var(--muted); }
.sig-sources:hover { color: var(--accent); }

/* ════════════ System Health strip (dashboard) ════════════ */
.sys-health { margin: 18px 0 26px; border: 1px solid var(--border); border-radius: 10px; padding: 14px 16px; background: var(--card-bg); position: relative; overflow: hidden; }
.sys-health::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 5px; }
.sys-health--green::before { background: #2ecc71; }
.sys-health--amber::before { background: #f5a623; }
.sys-health--red::before   { background: #f0584a; }
.sh-overall { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; }
.sh-dot { width: 14px; height: 14px; border-radius: 50%; flex: 0 0 auto; box-shadow: 0 0 0 4px rgba(0,0,0,0.04); }
.sh-dot--green { background: #2ecc71; box-shadow: 0 0 0 4px rgba(46,204,113,0.18); }
.sh-dot--amber { background: #f5a623; box-shadow: 0 0 0 4px rgba(245,166,35,0.18); }
.sh-dot--red   { background: #f0584a; box-shadow: 0 0 0 4px rgba(240,88,74,0.18); animation: shpulse 1.6s ease-in-out infinite; }
@keyframes shpulse { 0%,100% { box-shadow: 0 0 0 4px rgba(240,88,74,0.18);} 50% { box-shadow: 0 0 0 9px rgba(240,88,74,0.05);} }
.sh-overall-txt { display: flex; flex-direction: column; line-height: 1.3; }
.sh-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 12px; }
.sh-card { border: 1px solid var(--border); border-radius: 8px; padding: 12px; background: var(--bg); }
.sh-card-head { font-size: 13px; font-weight: 600; display: flex; align-items: center; gap: 6px; }
.sh-mini-dot { width: 9px; height: 9px; border-radius: 50%; display: inline-block; }
.sh-mini-dot--online { background: #2ecc71; } .sh-card--online { border-color: rgba(46,204,113,0.5); }
.sh-mini-dot--idle   { background: #f5a623; } .sh-card--idle   { border-color: rgba(245,166,35,0.5); }
.sh-mini-dot--stale  { background: #f0584a; } .sh-card--stale  { border-color: rgba(240,88,74,0.5); }
.sh-mini-dot--offline{ background: #888; }    .sh-card--offline{ border-color: #888; }
.sh-status { font-size: 22px; font-weight: 700; margin: 4px 0 2px; letter-spacing: 0.5px; }
.sh-card--online .sh-status { color: #2ecc71; } .sh-card--idle .sh-status { color: #f5a623; }
.sh-card--stale .sh-status, .sh-card--offline .sh-status { color: #f0584a; }
.sh-uptime-good { color: #2ecc71; } .sh-uptime-warn { color: #f5a623; } .sh-uptime-bad { color: #f0584a; }
.sh-detail { font-size: 12px; color: var(--muted); line-height: 1.5; }
.sh-detail b { color: var(--fg); }
.sh-boards { margin-top: 8px; display: flex; flex-wrap: wrap; gap: 4px; }
.sh-board { font-size: 11px; font-family: ui-monospace, monospace; padding: 1px 6px; border-radius: 10px; border: 1px solid var(--border); }
.sh-board--ok { background: rgba(46,204,113,0.12); border-color: rgba(46,204,113,0.4); }
.sh-board--unchanged { background: rgba(245,166,35,0.10); }
.sh-board--error { background: rgba(240,88,74,0.14); border-color: rgba(240,88,74,0.4); }
.sh-gaps { margin-top: 8px; display: flex; flex-wrap: wrap; gap: 4px; }
.sh-gap { font-size: 11px; padding: 1px 7px; border-radius: 10px; background: rgba(240,88,74,0.10); border: 1px solid rgba(240,88,74,0.3); color: var(--fg); }
.sh-gap--ongoing { background: rgba(240,88,74,0.22); border-color: #f0584a; font-weight: 600; }
.sh-gate { margin-top: 8px; display: flex; flex-wrap: wrap; align-items: center; gap: 6px; }
.sh-gate-pill { font-size: 11px; padding: 1px 8px; border-radius: 10px; border: 1px solid var(--border); font-weight: 600; }
.sh-gate-pill--on { background: rgba(46,204,113,0.12); border-color: rgba(46,204,113,0.4); }
.sh-gate-pill--defer { background: rgba(245,166,35,0.14); border-color: rgba(245,166,35,0.45); }
.sh-gate-pill--off { background: rgba(240,88,74,0.14); border-color: rgba(240,88,74,0.4); }
.sh-cap { margin-top: 12px; }

/* ════════════ Analysis tabs + Analysis Lab ════════════ */
.analysis-tabs { display: flex; gap: 4px; margin: 8px 0 18px; border-bottom: 2px solid var(--border); }
.atab { padding: 8px 18px; font-size: 14px; font-weight: 600; color: var(--muted); border: 2px solid transparent; border-bottom: none; border-radius: 8px 8px 0 0; position: relative; top: 2px; }
.atab:hover { color: var(--fg); background: var(--card-bg); text-decoration: none; }
.atab.active { color: var(--accent); background: var(--card-bg); border-color: var(--border); border-bottom: 2px solid var(--card-bg); }
.lab-badge { font-size: 9px; text-transform: uppercase; letter-spacing: 0.5px; background: var(--accent); color: #fff; padding: 1px 6px; border-radius: 8px; vertical-align: middle; margin-left: 4px; font-weight: 700; }
h1 .lab-badge { font-size: 11px; }

.lab-subtabs { display: flex; gap: 8px; margin: 16px 0; flex-wrap: wrap; }
.lab-subtab { padding: 8px 16px; font-size: 13px; font-weight: 600; border: 1px solid var(--border); border-radius: 20px; background: var(--card-bg); color: var(--fg); cursor: pointer; transition: all 0.15s; }
.lab-subtab:hover { border-color: var(--accent); }
.lab-subtab.active { background: var(--accent); color: #fff; border-color: var(--accent); }

.lab-controls { display: flex; align-items: center; gap: 18px; flex-wrap: wrap; margin: 10px 0; font-size: 13px; }
.lab-controls label { display: flex; align-items: center; gap: 6px; color: var(--muted); }
.lab-controls input[type=range] { accent-color: var(--accent); }
.lab-stat { margin-left: auto; color: var(--muted); font-family: ui-monospace, monospace; font-size: 12px; }

.lab-canvas-wrap { position: relative; border: 1px solid var(--border); border-radius: 10px; background:
  radial-gradient(circle at 30% 20%, rgba(127,127,127,0.05), transparent 60%), var(--card-bg);
  overflow: hidden; margin: 8px 0; }
.lab-canvas-wrap svg { width: 100%; display: block; }
:root[data-theme="dark"] .lab-canvas-wrap { background:
  radial-gradient(circle at 30% 20%, rgba(120,140,200,0.08), transparent 60%), #11131a; }

.lab-tooltip { position: absolute; pointer-events: none; background: rgba(20,22,28,0.95); color: #f0f0f0;
  border: 1px solid #3a3f48; border-radius: 7px; padding: 8px 11px; font-size: 12px; line-height: 1.45;
  max-width: 280px; z-index: 20; box-shadow: 0 6px 22px rgba(0,0,0,0.4); }
.lab-tooltip b { color: #fff; } .lab-tooltip .muted { color: #9aa3b2; } .lab-tooltip .pos { color: #3fcf6b; }

.lab-legend { position: absolute; top: 10px; right: 12px; background: var(--card-bg); border: 1px solid var(--border);
  border-radius: 7px; padding: 6px 10px; font-size: 12px; display: flex; flex-direction: column; gap: 3px; opacity: 0.95; }
.lg-item { display: flex; align-items: center; gap: 6px; }
.lg-dot { width: 10px; height: 10px; border-radius: 50%; display: inline-block; }

/* lab canvas wraps need an explicit height so the SVG fills them and the
   force-layout / treemap stay clipped inside (overflow:hidden already set). */
.lab-canvas-wrap { height: 560px; max-width: 100%; }
.lab-canvas-wrap svg { width: 100%; height: 100%; display: block; }

/* ════════════════════════════════════════════════════════════════════
   RESPONSIVE / MOBILE
   ════════════════════════════════════════════════════════════════════ */

/* Horizontal-scroll wrapper for wide data tables (added around every
   <table> in <main> at build time + as a safety net below). */
.table-wrap { width: 100%; max-width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; }

/* Chart wrapper: keeps Chart.js canvases responsive & bounded. */
.chart-box { position: relative; width: 100%; max-width: 100%; }
canvas { max-width: 100%; }

/* charts/svgs/imgs never exceed their column */
main img, main svg, main canvas { max-width: 100%; }

/* ── Tablet & below (≤768px) ─────────────────────────────────────── */
@media (max-width: 768px) {
  main { padding: 0 14px; margin: 18px auto; }
  h1 { font-size: 23px; }
  h2 { margin-top: 26px; font-size: 16px; }

  /* nav wraps onto multiple lines, brand + toggle stay on the first row */
  .topbar { flex-wrap: wrap; gap: 10px 16px; padding: 10px 14px; }
  .topbar nav { flex: 1 1 100%; order: 3; display: flex; flex-wrap: wrap; gap: 4px 14px; }
  .topbar nav a { margin-right: 0; padding: 2px 0; }
  #theme-toggle { order: 2; margin-left: auto; }

  /* two-column layouts stack */
  .two-col { grid-template-columns: 1fr; gap: 16px; }

  /* every standalone table inside main scrolls horizontally instead of
     pushing the page wide (covers tables not wrapped in .table-wrap) */
  main > table,
  main section > table,
  main details > table,
  .explore-block table { display: block; width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; white-space: nowrap; }
}

/* ── Phones (≤640px) ─────────────────────────────────────────────── */
@media (max-width: 640px) {
  body { font-size: 14px; }
  main { padding: 0 12px; }

  /* board cards / KPI cards / health cards: keep min sane but allow
     a single, full-width column on very narrow screens */
  .cards { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 10px; }
  .sh-cards { grid-template-columns: 1fr; }
  .ops-grid { grid-template-columns: 1fr; }
  .article-strip { grid-template-columns: 1fr; }
  .blog-index { grid-template-columns: 1fr; }

  /* health strip padding tighter */
  .sys-health { padding: 12px; }
  .sh-status { font-size: 19px; }

  /* window/board tabs: comfortable tap targets, wrap freely */
  .window-bar { flex-wrap: wrap; gap: 6px; }
  .window-btn,
  .board-tab,
  .lab-subtab { min-height: 38px; display: inline-flex; align-items: center; }
  .board-tabs { gap: 6px; }
  .analysis-tabs { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .atab { padding: 8px 12px; white-space: nowrap; }

  /* signals export bar wraps under controls instead of forcing width */
  .export-bar { margin-left: 0; margin-top: 4px; flex-wrap: wrap; }

  /* explore controls stack to full width */
  .explore-controls { gap: 8px; }
  .explore-controls input[type=text] { min-width: 0; width: 100%; flex: 1 1 100%; }
  .lab-controls { gap: 10px; }
  .lab-stat { margin-left: 0; flex: 1 1 100%; }

  /* lab graphs are shorter on a phone */
  .lab-canvas-wrap { height: 420px; }
  .lab-legend { position: static; margin: 8px; opacity: 1; }

  /* the thread-list grid (.threads li) reflows to a single column */
  .threads li { grid-template-columns: 1fr; gap: 4px; }
  .threads .text { -webkit-line-clamp: 3; max-height: none; }

  /* topic-tree summary items wrap nicely */
  .tt-label { min-width: 0; flex: 1 1 100%; }
  .tt-share-bar { flex: 1 1 60%; }

  /* slide-in panel takes (almost) full width on phones */
  .thread-panel { width: 100vw; max-width: 100vw; right: -100vw; }

  /* bar-label narrower so bars fit */
  .bar-label { width: 90px; }
}

/* Safety net: never allow the page itself to scroll sideways.
   All real overflow sources above are fixed; this only guards stray
   inline content (long unbroken tokens, etc.). */
html, body { max-width: 100%; overflow-x: hidden; }

/* ── article-threshold visualisation (analysis page) ───────────── */
.mom-eligible { background: #c87a1f22; color: #a8650f; }
.at-key { font-weight: 600; padding: 0 2px; }
.at-key.art   { color: #1b873b; }
.at-key.elig  { color: #c87a1f; }
.at-key.below { color: #7a7f87; }
.at-detail { margin: 14px 0 4px; padding: 14px 16px; border: 1px solid var(--border);
  border-left: 3px solid var(--accent); border-radius: 6px; background: var(--card-bg); }
.at-detail-head { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; margin-bottom: 10px; font-size: 15px; }
.at-detail-head .at-score { margin-left: auto; font-weight: 700; font-size: 13px; }
.at-bd { margin: 6px 0; }
.at-bd td, .at-bd th { padding: 5px 10px; font-size: 12px; }
.at-bd .at-total td { border-top: 2px solid var(--border); background: var(--accent-soft); }
.at-bd td.pos { color: #1b873b; font-weight: 600; }
.at-art-line { margin: 10px 0 0; }
#at-table td b { font-variant-numeric: tabular-nums; }
/* threshold detail: story/theme links + entity tags */
.at-links { margin: 4px 0 6px; display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.at-theme-link { text-decoration: none; cursor: pointer; }
.at-theme-link:hover { background: var(--accent); color: #fff; }
.at-ents-line { margin: 2px 0 8px; display: flex; gap: 6px; align-items: center; flex-wrap: wrap; }
.at-ent { text-decoration: none; }
/* make the threshold scatter read as interactive */
#atChart { cursor: pointer; }
