/* ============================================================
   AFTERWAVE PLATFORM — SURFACE
   Calm, high-caliber SaaS. Warm near-white, fixed workspace
   sidebar, grayscale-dominant data viz. Color appears ONLY for
   sentiment (positive / neutral / negative). Geist + Geist Mono.
   ============================================================ */

@import url("https://fonts.googleapis.com/css2?family=Geist:wght@300;400;500;600;700&family=Geist+Mono:wght@400;500&family=Newsreader:opsz,wght@6..72,400;6..72,500&display=swap");

:root {
  --bg:        #f6f5f1;   /* app canvas — warm near-white */
  --side:      #fbfaf7;   /* sidebar */
  --surface:   #faf9f4;   /* cards — flat, near-bg (no white fills) */
  --surface-2: #f3f1ec;   /* sunken / hover fills */
  --sunken:    #efece5;   /* track / chart base */
  --ink:       #1b1a16;
  --ink-2:     #6c685e;
  --ink-3:     #9c978a;
  --ink-4:     #bcb7a9;
  --line:      #eae7df;
  --line-2:    #e0dccf;
  --line-3:    #cfcabb;

  /* warm grayscale data ramp (low → high) */
  --d0:#edeae1; --d1:#dcd8cc; --d2:#c0bbab; --d3:#9b9684; --d4:#726e5f; --d5:#48453b; --d6:#1b1a16;

  /* sentiment — the ONLY chromatic family, muted */
  --pos:#5d8a6b; --pos-bg:#e7efe7; --pos-ink:#3f6650;
  --neu:#9a9081; --neu-bg:#efebe2; --neu-ink:#6c685e;
  --neg:#bd6149; --neg-bg:#f3e3dc; --neg-ink:#9a4a36;
  --warn:#b08636; --warn-bg:#f1e8d2;

  --sans:"Geist", ui-sans-serif, system-ui, sans-serif;
  --mono:"Geist Mono", ui-monospace, "SF Mono", monospace;
  --ease:cubic-bezier(.22,.7,.2,1);

  --r:8px; --r-sm:8px; --r-xs:6px;
  --side-w:236px;
  --shadow:none;
  --shadow-lg:0 1px 2px rgba(27,26,22,.05), 0 12px 32px -14px rgba(27,26,22,.16);
}

* { box-sizing:border-box; }
html, body { margin:0; height:100%; }
body {
  background:var(--bg); color:var(--ink);
  font-family:var(--sans); font-size:14px; line-height:1.55; letter-spacing:-.006em;
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
}
#root { min-height:100%; }
a { color:inherit; text-decoration:none; }
button { font-family:inherit; cursor:pointer; }
:focus-visible { outline:2px solid var(--ink); outline-offset:2px; border-radius:4px; }
::selection { background:var(--ink); color:var(--bg); }
::-webkit-scrollbar { width:11px; height:11px; }
::-webkit-scrollbar-thumb { background:var(--line-2); border-radius:99px; border:3px solid transparent; background-clip:content-box; }
::-webkit-scrollbar-thumb:hover { background:var(--line-3); background-clip:content-box; }

.mono { font-family:var(--mono); }
.num { font-family:var(--mono); font-variant-numeric:tabular-nums; letter-spacing:0; }
.eyebrow { font-family:var(--mono); font-size:10.5px; letter-spacing:.15em; text-transform:uppercase; color:var(--ink-3); }
.dim { color:var(--ink-2); } .dim-2 { color:var(--ink-3); }

/* ============================================================
   APP FRAME — fixed sidebar + scrolling main
   ============================================================ */
.app { display:grid; grid-template-columns:var(--side-w) 1fr; height:100vh; }

.side { background:var(--side); border-right:1px solid var(--line); display:flex; flex-direction:column; min-height:0; }
.side-top { padding:20px 18px 14px; }
.side-brand { display:flex; align-items:center; gap:10px; }
.side-brand .mk { width:22px; height:22px; image-rendering:pixelated; }
.side-brand b { font-size:17px; font-weight:600; letter-spacing:-.02em; }
.side-sect { font-family:var(--mono); font-size:9.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-4); padding:18px 22px 8px; }
.side-nav { padding:6px 12px; display:flex; flex-direction:column; gap:2px; }
.nav-item { display:flex; align-items:center; gap:11px; padding:9px 12px; border-radius:var(--r-sm); color:var(--ink-2);
  font-size:13.5px; font-weight:500; transition:background .14s var(--ease), color .14s var(--ease); border:none; background:none; width:100%; text-align:left; }
.nav-item:hover { background:var(--surface-2); color:var(--ink); }
.nav-item[data-active="true"] { background:var(--ink); color:var(--bg); }
.nav-item .ic { width:17px; height:17px; flex:none; }
.nav-item .live-dot { margin-left:auto; width:6px; height:6px; border-radius:50%; background:var(--pos); animation:pulse 1.7s var(--ease) infinite; }
.side-foot { margin-top:auto; padding:16px 18px; border-top:1px solid var(--line); display:flex; flex-direction:column; gap:14px; }
.usage .ul { display:flex; justify-content:space-between; align-items:baseline; margin-bottom:7px; }
.usage .ul span:first-child { font-size:12px; color:var(--ink-2); }
.usage .ul .num { font-size:12px; color:var(--ink); }
.usage .bar { height:5px; border-radius:99px; background:var(--sunken); overflow:hidden; }
.usage .bar i { display:block; height:100%; background:var(--ink); border-radius:99px; }
.side-foot .so { display:flex; align-items:center; gap:10px; color:var(--ink-2); font-size:13px; font-weight:500; background:none; border:none; padding:2px; }
.side-foot .so:hover { color:var(--ink); }

.main { min-width:0; min-height:0; overflow:auto; }
.wrap { max-width:1240px; margin:0 auto; padding:34px 40px 80px; }
.wrap-wide { max-width:1500px; }

@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.3} }
@keyframes spin { to { transform:rotate(360deg); } }

/* ============================================================
   PAGE HEAD
   ============================================================ */
.phead { display:flex; align-items:flex-start; justify-content:space-between; gap:24px; flex-wrap:wrap; margin-bottom:26px; }
.phead h1 { margin:0; font-size:27px; font-weight:600; letter-spacing:-.028em; }
.phead .sub { color:var(--ink-2); font-size:14px; margin-top:6px; max-width:70ch; }
.phead-actions { display:flex; gap:10px; align-items:center; flex-wrap:wrap; }

/* ============================================================
   PRIMITIVES
   ============================================================ */
.btn { font-size:13.5px; font-weight:500; padding:9px 15px; border-radius:var(--r-sm); border:1px solid var(--ink);
  background:var(--ink); color:var(--bg); display:inline-flex; align-items:center; gap:8px; transition:opacity .14s, transform .1s; white-space:nowrap; }
.btn:hover { opacity:.9; } .btn:active { transform:translateY(.5px); }
.btn.ghost { background:var(--surface); color:var(--ink); border-color:var(--line-2); }
.btn.ghost:hover { border-color:var(--line-3); opacity:1; }
.btn.sm { padding:7px 12px; font-size:12.5px; }
.btn.pill { border-radius:99px; }
.btn:disabled { opacity:.45; cursor:not-allowed; }

.card { background:var(--surface); border:1px solid var(--line); border-radius:var(--r); box-shadow:var(--shadow); }
.card-h { display:flex; align-items:flex-start; gap:12px; padding:16px 18px 0; }
.card-h .t { font-size:14.5px; font-weight:600; letter-spacing:-.012em; }
.card-h .t small { display:block; font-weight:400; font-size:12px; color:var(--ink-2); margin-top:2px; letter-spacing:0; }
.card-h .hint { margin-left:auto; }
.card-b { padding:16px 18px 18px; }
.card-pad { padding:18px; }

.grid { display:grid; gap:16px; }
.g2 { grid-template-columns:1fr 1fr; } .g3 { grid-template-columns:repeat(3,1fr); } .g4 { grid-template-columns:repeat(4,1fr); }
.span2 { grid-column:span 2; } .spanall { grid-column:1/-1; }

.chip { font-family:var(--mono); font-size:10.5px; letter-spacing:.05em; text-transform:uppercase; color:var(--ink-2);
  border:1px solid var(--line-2); padding:4px 9px; border-radius:99px; display:inline-flex; align-items:center; gap:6px; background:var(--surface); }
.chip[data-on="true"] { color:var(--bg); border-color:var(--ink); background:var(--ink); }
.chip.plain { border:none; background:var(--surface-2); color:var(--ink-2); }

.badge { font-family:var(--mono); font-size:10.5px; letter-spacing:.04em; text-transform:uppercase; font-weight:500;
  display:inline-flex; align-items:center; gap:6px; padding:4px 9px; border-radius:99px; }
.badge .g { width:7px; height:7px; border-radius:50%; flex:none; }
.badge[data-tone="pos"] { color:var(--pos-ink); background:var(--pos-bg); } .badge[data-tone="pos"] .g { background:var(--pos); }
.badge[data-tone="neu"] { color:var(--neu-ink); background:var(--neu-bg); } .badge[data-tone="neu"] .g { background:var(--neu); }
.badge[data-tone="neg"] { color:var(--neg-ink); background:var(--neg-bg); } .badge[data-tone="neg"] .g { background:var(--neg); }
.badge[data-tone="warn"] { color:#7d5c1c; background:var(--warn-bg); } .badge[data-tone="warn"] .g { background:var(--warn); clip-path:polygon(50% 0,100% 100%,0 100%); border-radius:0; }
.badge[data-tone="ok"] { color:var(--ink-2); background:var(--surface-2); } .badge[data-tone="ok"] .g { background:var(--ink-3); }
.badge[data-tone="solid"] { color:var(--bg); background:var(--ink); } .badge[data-tone="solid"] .g { background:var(--bg); }

/* severity dot */
.sev { width:8px; height:8px; border-radius:50%; display:inline-block; flex:none; }
.sev[data-s="high"] { background:var(--neg); } .sev[data-s="medium"] { background:var(--warn); } .sev[data-s="low"] { background:var(--ink-3); }

/* stat card */
.stat { padding:17px 18px; }
.stat .sl { display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; }
.stat .sl .eyebrow { color:var(--ink-3); }
.stat .sv { font-family:var(--sans); font-size:34px; font-weight:400; letter-spacing:-.025em; line-height:1; font-variant-numeric:tabular-nums; }
.stat .sd { font-size:11.5px; margin-top:8px; display:flex; align-items:center; gap:5px; }
.stat .sd .up { color:var(--pos-ink); } .stat .sd .down { color:var(--neg-ink); } .stat .sd .flat { color:var(--ink-2); }

/* metric tile w/ CI */
.metric .ml { display:flex; align-items:center; justify-content:space-between; margin-bottom:10px; }
.metric .mv { font-family:var(--sans); font-size:32px; font-weight:400; letter-spacing:-.025em; line-height:1; font-variant-numeric:tabular-nums; }
.metric .mv small { font-size:14px; color:var(--ink-2); margin-left:1px; }
.metric .ci { font-family:var(--mono); font-size:10.5px; color:var(--ink-2); margin-top:9px; }
.metric .cibar { height:5px; background:var(--sunken); border-radius:99px; position:relative; margin-top:11px; }
.metric .cibar i { position:absolute; top:0; bottom:0; background:var(--d2); border-radius:99px; }
.metric .cibar b { position:absolute; top:-2px; bottom:-2px; width:2px; background:var(--ink); border-radius:2px; }

/* sentiment split bars */
.sbars { display:grid; gap:11px; }
.sbar .sl { display:flex; justify-content:space-between; font-size:12.5px; margin-bottom:5px; }
.sbar .track { height:8px; border-radius:99px; background:var(--sunken); overflow:hidden; }
.sbar .track i { display:block; height:100%; border-radius:99px; }
.sbar[data-t="pos"] .track i { background:var(--pos); } .sbar[data-t="neu"] .track i { background:var(--neu); } .sbar[data-t="neg"] .track i { background:var(--neg); }

/* horizontal bar list */
.hbars { display:grid; gap:9px; }
.hbar { display:grid; grid-template-columns:var(--lblw,128px) 1fr 42px; gap:11px; align-items:center; }
.hbar .l { font-size:12.5px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.hbar .t { height:11px; background:var(--sunken); border-radius:99px; overflow:hidden; }
.hbar .t i { display:block; height:100%; background:var(--d4); border-radius:99px; }
.hbar .v { font-family:var(--mono); font-size:11px; color:var(--ink-2); text-align:right; }

/* tabs */
.tabs { display:inline-flex; background:var(--surface-2); border-radius:99px; padding:3px; gap:2px; }
.tabs button { border:none; background:none; padding:7px 14px; border-radius:99px; font-size:12.5px; font-weight:500; color:var(--ink-2); }
.tabs button[data-on="true"] { background:var(--surface); color:var(--ink); box-shadow:var(--shadow); }

/* underline tabs */
.utabs { display:flex; gap:26px; border-bottom:1px solid var(--line); margin-bottom:22px; }
.utabs button { border:none; background:none; padding:11px 0; font-size:13.5px; font-weight:500; color:var(--ink-2); border-bottom:2px solid transparent; margin-bottom:-1px; display:inline-flex; align-items:center; gap:7px; }
.utabs button[data-on="true"] { color:var(--ink); border-color:var(--ink); }
.utabs button .ic { width:15px; height:15px; }

/* provenance dot */
.prov { display:inline-flex; align-items:center; color:var(--ink-4); cursor:help; }
.prov:hover { color:var(--ink-2); }

/* list rows */
.rows { display:flex; flex-direction:column; }
.lrow { display:flex; align-items:center; gap:14px; padding:13px 18px; border-top:1px solid var(--line); cursor:pointer; transition:background .12s; }
.lrow:first-child { border-top:none; }
.lrow:hover { background:var(--surface-2); }
.lrow .th { width:34px; height:34px; border-radius:8px; background:var(--surface-2); display:grid; place-items:center; color:var(--ink-3); flex:none; }
.lrow .rt { font-weight:500; font-size:13.5px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.lrow .rc { font-size:12px; color:var(--ink-2); }

/* data table */
.tbl { width:100%; border-collapse:collapse; }
.tbl th { text-align:left; font-family:var(--mono); font-size:9.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); font-weight:400; padding:0 14px 12px; border-bottom:1px solid var(--line); }
.tbl td { padding:14px; border-bottom:1px solid var(--line); font-size:13.5px; }
.tbl tr:last-child td { border-bottom:none; }
.tbl tbody tr { cursor:pointer; transition:background .12s; }
.tbl tbody tr:hover { background:var(--surface-2); }
.tbl .rt { font-weight:500; }

/* fields */
.field { display:grid; gap:7px; margin-bottom:16px; }
.field label { font-family:var(--mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-2); }
.input { font-family:var(--sans); font-size:14px; padding:11px 13px; border:1px solid var(--line-2); border-radius:var(--r-sm); background:var(--surface); width:100%; color:var(--ink); }
.input:focus { outline:none; border-color:var(--ink); }
textarea.input { resize:vertical; line-height:1.55; }
select.input { cursor:pointer; }

/* notice */
.notice { border:1px solid var(--line-2); border-radius:var(--r-sm); padding:12px 14px; font-size:13px; display:flex; gap:10px; align-items:flex-start; background:var(--surface); }
.notice .g { margin-top:3px; flex:none; }
.notice[data-kind="error"] { border-color:#dcb6a8; background:var(--neg-bg); }
.notice[data-kind="info"] { background:var(--surface-2); border-color:var(--line); }

/* coming soon */
.soon { border:1px dashed var(--line-3); border-radius:var(--r); background:repeating-linear-gradient(135deg, transparent 0 10px, rgba(156,151,138,.045) 10px 20px);
  display:grid; place-items:center; text-align:center; padding:30px; gap:8px; color:var(--ink-3); }
.soon .tag { font-family:var(--mono); font-size:9.5px; letter-spacing:.14em; text-transform:uppercase; border:1px solid var(--line-2); padding:3px 9px; border-radius:99px; }

/* empty */
.empty { display:grid; place-items:center; text-align:center; padding:56px 24px; gap:12px; }
.empty .ei { width:44px; height:44px; border-radius:12px; background:var(--surface-2); display:grid; place-items:center; color:var(--ink-3); }
.empty h3 { margin:0; font-size:16px; font-weight:600; }
.empty p { margin:0; color:var(--ink-2); max-width:42ch; }

/* skeleton */
.skel { background:linear-gradient(90deg,var(--sunken) 0%, #f2efe8 50%, var(--sunken) 100%); background-size:200% 100%; animation:sh 1.3s linear infinite; border-radius:var(--r-sm); }
@keyframes sh { to { background-position:-200% 0; } }

/* tooltip */
.tip { position:fixed; z-index:90; background:var(--ink); color:var(--bg); font-family:var(--mono); font-size:11px; padding:8px 11px; border-radius:7px; pointer-events:none; max-width:250px; line-height:1.5; box-shadow:var(--shadow-lg); }
.tip .k { color:var(--ink-4); }

/* phase rows (running) */
.phase { display:flex; align-items:center; gap:14px; padding:16px 18px; border-top:1px solid var(--line); }
.phase:first-child { border-top:none; }
.phase .pn { width:26px; height:26px; border-radius:50%; border:2px solid var(--line-2); flex:none; display:grid; place-items:center; font-family:var(--mono); font-size:11px; color:var(--ink-3); }
.phase[data-st="done"] .pn { border-color:var(--ink); background:var(--ink); color:var(--bg); }
.phase[data-st="active"] .pn { border-color:var(--ink); border-top-color:transparent; color:transparent; animation:spin .8s linear infinite; }
.phase .pt { font-weight:500; font-size:14px; }
.phase .pd { font-size:12.5px; color:var(--ink-2); margin-top:1px; }
.phase[data-st="wait"] { opacity:.5; }

@media (max-width:1180px){ .g4{grid-template-columns:1fr 1fr} }
@media (max-width:900px){
  .app{grid-template-columns:1fr}
  .side{display:none}
  .g2,.g3,.g4{grid-template-columns:1fr} .span2,.spanall{grid-column:auto}
  .wrap{padding:24px 20px 70px}
}
@media (prefers-reduced-motion:reduce){ *{animation-duration:.01ms!important;transition-duration:.01ms!important} }
[dir="rtl"] .nav-item, [dir="rtl"] .lrow { text-align:right; }

/* ============================================================
   REPORT HEADER (editorial)
   ============================================================ */
.rpt-eyebrow { display:flex; align-items:center; gap:10px; font-family:var(--mono); font-size:11px; letter-spacing:.13em; text-transform:uppercase; color:var(--ink-3); flex-wrap:wrap; }
.rpt-eyebrow .dot { color:var(--ink-4); }
.rpt-eyebrow .pill { font-family:var(--mono); font-size:10px; letter-spacing:.06em; text-transform:none; padding:3px 9px; border-radius:99px; background:var(--surface-2); color:var(--ink-2); }
.rpt-eyebrow .pill[data-st="complete"]{ color:var(--pos-ink); background:var(--pos-bg); }
.rpt-eyebrow .pill[data-st="failed"]{ color:var(--neg-ink); background:var(--neg-bg); }
.rpt-eyebrow .pill[data-st="running"]{ color:var(--ink-2); }
.rpt-title { font-family:var(--sans); font-weight:400; font-size:clamp(34px, 5.2vw, 60px); line-height:1.04; letter-spacing:-.028em; margin:14px 0 0; text-wrap:balance; }
.rpt-meta { font-family:var(--mono); font-size:12.5px; color:var(--ink-2); margin-top:14px; letter-spacing:.01em; }
.rpt-rule { height:1px; background:var(--line); margin:22px 0 26px; }

/* verdict band */
.verdict { display:grid; grid-template-columns:repeat(4,1fr); border:1px solid var(--line); border-radius:var(--r); overflow:hidden; background:var(--surface); }
.vcell { padding:18px 20px 20px; border-left:1px solid var(--line); }
.vcell:first-child { border-left:none; }
.vcell.flag[data-lv="moderate"]{ background:transparent; }
.vcell.flag[data-lv="high"]{ background:transparent; }
.vcell .vl { display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; }
.vcell .vv { font-family:var(--sans); font-size:32px; font-weight:400; letter-spacing:-.025em; line-height:1; font-variant-numeric:tabular-nums; }
.vcell .vv small { font-size:15px; color:var(--ink-2); }
.vcell .vsub { font-size:12px; color:var(--ink-2); margin-top:9px; }
.vcell .vsub a, .vcell .vsub button { color:inherit; border:none; background:none; padding:0; font:inherit; cursor:pointer; text-decoration:underline; text-underline-offset:2px; }
@media (max-width:980px){ .verdict{grid-template-columns:1fr 1fr} .vcell:nth-child(3){border-left:none} .vcell:nth-child(n+3){border-top:1px solid var(--line)} }
@media (max-width:560px){ .verdict{grid-template-columns:1fr} .vcell{border-left:none;border-top:1px solid var(--line)} .vcell:first-child{border-top:none} }

/* confidence-interval bar */
.cibar2 { position:relative; height:6px; margin-top:12px; background:var(--sunken); border-radius:99px; }
.cibar2 i { position:absolute; top:0; bottom:0; background:var(--d2); border-radius:99px; }
.cibar2 b { position:absolute; top:-2px; bottom:-2px; width:2px; background:var(--ink); border-radius:2px; }
.ci-txt { font-family:var(--mono); font-size:10.5px; color:var(--ink-3); margin-top:8px; display:flex; align-items:center; gap:6px; }

/* sentiment split (derived from reaction_lean) */
.split .row { margin-bottom:13px; }
.split .row:last-child { margin-bottom:0; }
.split .rl { display:flex; justify-content:space-between; font-size:13px; margin-bottom:6px; }
.split .track { height:7px; border-radius:99px; background:var(--sunken); overflow:hidden; }
.split .track i { display:block; height:100%; border-radius:99px; }
.split .pos i{background:var(--ink)} .split .neu i{background:var(--ink-3)} .split .neg i{background:var(--line-3)}

/* persona grid + drawer */
.pgrid { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; }
@media (max-width:1100px){ .pgrid{grid-template-columns:repeat(3,1fr)} }
@media (max-width:760px){ .pgrid{grid-template-columns:1fr 1fr} }
.ptile { text-align:left; background:var(--surface); border:1px solid var(--line); border-radius:var(--r); padding:14px; cursor:pointer; transition:border-color .14s,transform .12s,box-shadow .14s; display:flex; flex-direction:column; gap:11px; position:relative; }
.ptile:hover { border-color:var(--line-3); transform:translateY(-2px); box-shadow:var(--shadow-lg); }
.ptile .ava { width:30px; height:30px; border-radius:8px; background:var(--surface-2); display:grid; place-items:center; font-family:var(--mono); font-size:12px; }
.ptile .nm { font-weight:600; font-size:14px; }
.ptile .loc { color:var(--ink-2); font-size:12px; }
.ptile .driver { position:absolute; top:12px; right:12px; }
[dir="rtl"] .ptile .driver { right:auto; left:12px; }
.ptile .ib { height:4px; border-radius:99px; background:var(--sunken); overflow:hidden; }
.ptile .ib i { display:block; height:100%; }

.scrim { position:fixed; inset:0; background:rgba(27,26,22,.24); z-index:60; }
.drawer { position:fixed; top:0; right:0; bottom:0; width:min(460px,94vw); background:var(--bg); border-left:1px solid var(--line-2); z-index:61; overflow:auto; box-shadow:-26px 0 60px -24px rgba(27,26,22,.2); }
[dir="rtl"] .drawer { right:auto; left:0; border-left:none; border-right:1px solid var(--line-2); }
.drawer-h { position:sticky; top:0; background:var(--bg); border-bottom:1px solid var(--line); padding:18px 22px; display:flex; align-items:center; gap:12px; z-index:2; }

/* video timeline */
.player { aspect-ratio:16/9; background:#15140f; border-radius:var(--r); position:relative; overflow:hidden; display:grid; place-items:center; color:#6c685e; }
.player .scrubline { position:absolute; top:0; bottom:0; width:2px; background:#fff; opacity:.8; pointer-events:none; }
.tl-tracks { display:grid; gap:2px; }
.tl-track { position:relative; }
.tl-track .tlabel { font-family:var(--mono); font-size:9.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); margin-bottom:4px; display:flex; justify-content:space-between; }
.tl-playhead { position:absolute; top:0; bottom:0; width:2px; background:var(--ink); z-index:5; pointer-events:none; }
.tl-marker { position:absolute; top:0; transform:translateX(-50%); cursor:pointer; }
.tl-marker .mdot { width:11px; height:11px; border-radius:50%; border:2px solid var(--surface); background:var(--ink); }
.tl-marker[data-type="dropoff"] .mdot{ background:var(--neg) } .tl-marker[data-type="risk"] .mdot{ background:var(--neg) }
.tl-marker[data-type="hook"] .mdot{ background:var(--pos) } .tl-marker[data-type="share_trigger"] .mdot{ background:var(--ink) }
.seg-flag { font-family:var(--mono); font-size:9px; letter-spacing:.06em; text-transform:uppercase; padding:2px 6px; border-radius:99px; }
.seg-flag[data-f="hook"]{ color:var(--pos-ink); background:var(--pos-bg) }
.seg-flag[data-f="dropoff"],.seg-flag[data-f="risk"]{ color:var(--neg-ink); background:var(--neg-bg) }
.seg-flag[data-f="peak"],.seg-flag[data-f="highlight"]{ color:var(--ink-2); background:var(--surface-2) }

/* states */
.silence-card { border:1px solid var(--line-2); background:var(--surface); border-radius:var(--r); padding:16px 20px; display:flex; gap:14px; align-items:center; }
.retry-box { text-align:center; max-width:440px; margin:0 auto; }
.skelblock { border:1px solid var(--line); border-radius:var(--r); padding:18px; background:var(--surface); }

/* range inputs themed */
input[type=range]{ -webkit-appearance:none; appearance:none; height:4px; background:var(--sunken); border-radius:99px; outline:none; }
input[type=range]::-webkit-slider-thumb{ -webkit-appearance:none; width:15px; height:15px; border-radius:50%; background:var(--ink); cursor:pointer; border:2px solid var(--surface); }
input[type=range]::-moz-range-thumb{ width:15px; height:15px; border-radius:50%; background:var(--ink); cursor:pointer; border:2px solid var(--surface); }

