/* ============================================================
   GADGET — Application Design System
   Terminal vocabulary built on the marketing brand tokens.
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Hanken+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600;700&display=swap');

:root{
  --black:#000000;
  --bg:#000000;
  --panel:#0a0c0b;
  --panel-2:#0e1110;
  --panel-3:#10130f;
  --raised:#15191700;
  --raised-solid:#151917;
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.14);
  --line-3:rgba(255,255,255,.22);
  --white:#f5f7f6;
  --text:#e7eae9;
  --muted:#8a918d;
  --muted-2:#5f6663;
  --muted-3:#454b48;

  --green:#2de89e;
  --green-bright:#46f5af;
  --green-deep:#0f3d2c;
  --green-dim:#1aa873;
  --glow:rgba(45,232,158,.55);
  --glow-soft:rgba(45,232,158,.16);

  --blue:#7ad0ff;        /* tokens */
  --blue-dim:#3a8fce;
  --amber:#e8c24a;       /* caution */
  --amber-dim:#a8852a;
  --red:#ff6b6b;         /* danger */
  --red-dim:#c24a4a;
  --violet:#b69bff;      /* callers / telegram universe */
  --violet-dim:#7d63c7;

  --display:'Space Grotesk',sans-serif;
  --body:'Hanken Grotesk',sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;

  --radius:18px;
  --radius-sm:12px;
  --radius-xs:9px;
  --radius-lg:24px;
  --ease:cubic-bezier(.22,.61,.36,1);

  --sidebar:236px;
  --topbar:60px;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);
  background:var(--bg);
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  line-height:1.5;
  overflow:hidden;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input{font-family:inherit}
::selection{background:var(--green);color:#04130d}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.07);border-radius:8px;border:2px solid transparent;background-clip:padding-box}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.14);background-clip:padding-box}

#root{height:100%}

/* ---------- type helpers ---------- */
.mono{font-family:var(--mono)}
.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--green);display:inline-flex;align-items:center;gap:8px}
.eyebrow.muted{color:var(--muted-2)}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 9px var(--glow)}
h1,h2,h3,h4{font-family:var(--display);font-weight:600;letter-spacing:-.02em;color:var(--white);line-height:1.1}

/* ============================================================
   APP SHELL
   ============================================================ */
.app{display:grid;grid-template-columns:var(--sidebar) 1fr;height:100%;overflow:hidden}

/* ---- sidebar ---- */
.sidebar{
  background:linear-gradient(180deg,#070908,#050605);
  border-right:1px solid var(--line);
  display:flex;flex-direction:column;
  padding:18px 14px;gap:4px;overflow:hidden;position:relative;z-index:30;
}
.sb-brand{display:flex;align-items:center;gap:11px;padding:6px 8px 18px;margin-bottom:6px;border-bottom:1px solid var(--line)}
.sb-brand img{height:26px;filter:drop-shadow(0 0 12px rgba(45,232,158,.3))}
.sb-brand .wm{font-family:var(--display);font-weight:500;font-size:16px;letter-spacing:.32em;color:var(--white)}
.sb-brand .ver{margin-left:auto;font-family:var(--mono);font-size:9px;letter-spacing:.1em;color:var(--muted-2);border:1px solid var(--line);padding:2px 5px;border-radius:5px}
.sb-section{font-family:var(--mono);font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted-3);padding:14px 10px 7px}
.nav-item{
  display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:10px;
  color:var(--muted);font-size:13.5px;font-weight:500;cursor:pointer;position:relative;
  transition:background .18s,color .18s;white-space:nowrap;
}
.nav-item svg{width:17px;height:17px;flex:none;stroke:currentColor;fill:none;stroke-width:1.7}
.nav-item:hover{background:rgba(255,255,255,.04);color:var(--text)}
.nav-item.on{background:rgba(45,232,158,.10);color:var(--green)}
.nav-item.on::before{content:'';position:absolute;left:-14px;top:50%;transform:translateY(-50%);width:3px;height:18px;border-radius:0 3px 3px 0;background:var(--green);box-shadow:0 0 10px var(--glow)}
.nav-item .badge{margin-left:auto;font-family:var(--mono);font-size:10px;font-weight:600;padding:1px 6px;border-radius:6px;background:rgba(45,232,158,.12);color:var(--green)}
.nav-item .badge.amber{background:rgba(232,194,74,.14);color:var(--amber)}
.sb-spacer{flex:1}
.sb-foot{border-top:1px solid var(--line);padding-top:12px;margin-top:8px}
.sb-token{display:flex;align-items:center;gap:10px;padding:10px;border:1px solid var(--line);border-radius:12px;background:rgba(45,232,158,.04)}
.sb-token img{width:30px;height:30px;border-radius:8px}
.sb-token .tk{font-family:var(--mono);font-size:12px;color:var(--green);font-weight:600}
.sb-token .sub{font-size:10.5px;color:var(--muted-2);margin-top:1px}
.sb-acct{display:flex;align-items:center;gap:10px;padding:10px 8px 2px;margin-top:6px}
.sb-acct .av{width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,var(--green-deep),#1a2420);display:grid;place-items:center;font-family:var(--mono);font-size:11px;color:var(--green);font-weight:600;border:1px solid var(--line-2)}
.sb-acct .nm{font-size:12.5px;color:var(--text);font-weight:600}
.sb-acct .pl{font-family:var(--mono);font-size:10px;color:var(--green)}

/* ---- main ---- */
.main{display:flex;flex-direction:column;height:100%;overflow:hidden;min-width:0}
.topbar{
  height:var(--topbar);flex:none;display:flex;align-items:center;gap:16px;
  padding:0 24px;border-bottom:1px solid var(--line);
  background:rgba(8,10,9,.72);backdrop-filter:blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);position:relative;z-index:20;
}
.tb-title{display:flex;flex-direction:column;gap:1px;min-width:0;overflow:hidden}
.tb-title .crumb{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tb-title h2{font-size:16px;font-weight:600;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.tb-searchwrap{margin-left:auto;position:relative;min-width:0}
.tb-search{
  display:flex;align-items:center;gap:9px;width:min(380px,38vw);
  height:38px;padding:0 14px;border:1px solid var(--line);border-radius:11px;
  background:rgba(255,255,255,.03);color:var(--muted);transition:border-color .2s,background .2s;
}
.tb-search:focus-within{border-color:var(--line-3);background:rgba(255,255,255,.05)}
.tb-search svg{width:15px;height:15px;flex:none;stroke:var(--muted)}
.tb-search input{flex:1;background:none;border:none;outline:none;color:var(--text);font-size:13px}
.tb-search input::placeholder{color:var(--muted-2)}
.tb-search .kbd{font-family:var(--mono);font-size:10px;color:var(--muted-2);border:1px solid var(--line);border-radius:5px;padding:2px 6px}
.tb-live{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);flex:none}
.tb-live .pulse{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 0 var(--glow);animation:pulse 2.2s infinite}
.tb-icon{width:38px;height:38px;border-radius:11px;border:1px solid var(--line);display:grid;place-items:center;color:var(--muted);transition:.18s;flex:none;position:relative}
.tb-icon:hover{border-color:var(--line-3);color:var(--text)}
.tb-icon svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:1.7}
.tb-icon .ndot{position:absolute;top:8px;right:9px;width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--glow);border:1.5px solid #080a09}
@keyframes pulse{0%{box-shadow:0 0 0 0 var(--glow)}70%{box-shadow:0 0 0 7px rgba(45,232,158,0)}100%{box-shadow:0 0 0 0 rgba(45,232,158,0)}}

.content{flex:1;overflow-y:auto;overflow-x:hidden;position:relative}
.content-pad{padding:24px}
/* density */
.app[data-density="compact"] .content-pad{padding:16px}
.app[data-density="compact"] .card-pad{padding:14px}
.app[data-density="compact"] .kstat{padding:12px 14px}
.app[data-density="comfy"] .content-pad{padding:34px}
.app[data-density="comfy"] .card-pad{padding:26px}
.app[data-density="comfy"] .kstat{padding:20px 22px}
.page-enter{animation:pageIn .42s var(--ease) both}
@keyframes pageIn{from{transform:translateY(8px)}to{transform:none}}

/* ============================================================
   PRIMITIVES
   ============================================================ */
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);position:relative}
.card-2{background:var(--panel-2)}
.card-pad{padding:20px}
.card-h{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.card-h h3{font-size:15px;font-weight:600}
.card-h h4{font-size:13.5px;font-weight:600}
.card-h .sub{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2)}
.card-h .right{margin-left:auto;display:flex;align-items:center;gap:8px}
.divline{height:1px;background:var(--line);border:none;margin:0}

.chip{font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;color:var(--muted);background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:7px;padding:4px 8px;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}
.chip.green{color:var(--green);background:rgba(45,232,158,.09);border-color:rgba(45,232,158,.24)}
.chip.blue{color:var(--blue);background:rgba(122,208,255,.09);border-color:rgba(122,208,255,.22)}
.chip.amber{color:var(--amber);background:rgba(232,194,74,.1);border-color:rgba(232,194,74,.24)}
.chip.red{color:var(--red);background:rgba(255,107,107,.1);border-color:rgba(255,107,107,.24)}
.chip.violet{color:var(--violet);background:rgba(182,155,255,.1);border-color:rgba(182,155,255,.24)}
.chip .ic{width:11px;height:11px}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--body);font-weight:600;font-size:13px;padding:0 16px;height:38px;border-radius:10px;transition:.2s var(--ease);white-space:nowrap}
.btn svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2}
.btn-primary{background:var(--green);color:#04130d}
.btn-primary:hover{background:var(--green-bright);box-shadow:0 8px 26px -10px var(--glow)}
.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--line-2)}
.btn-ghost:hover{border-color:var(--green);color:var(--green);background:rgba(45,232,158,.05)}
.btn-sm{height:32px;font-size:12px;padding:0 12px;border-radius:9px}

/* segmented control */
.seg{display:inline-flex;background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:10px;padding:3px;gap:2px}
.seg button{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--muted);padding:6px 12px;border-radius:7px;transition:.18s;text-transform:uppercase;white-space:nowrap}
.seg button:hover{color:var(--text)}
.seg button.on{background:rgba(45,232,158,.12);color:var(--green)}

/* tabs */
.tabs{display:flex;gap:2px;border-bottom:1px solid var(--line)}
.tabs button{font-family:var(--body);font-weight:600;font-size:13.5px;color:var(--muted);padding:11px 16px;position:relative;transition:color .18s}
.tabs button:hover{color:var(--text)}
.tabs button.on{color:var(--white)}
.tabs button.on::after{content:'';position:absolute;left:12px;right:12px;bottom:-1px;height:2px;background:var(--green);box-shadow:0 0 10px var(--glow);border-radius:2px}

/* token logo placeholder */
.tlogo{border-radius:50%;display:grid;place-items:center;font-family:var(--display);font-weight:700;color:#04130d;flex:none;position:relative;overflow:hidden}
.tlogo::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.25),transparent 60%)}

/* avatar */
.avatar{border-radius:9px;background:linear-gradient(135deg,#1a2420,#0d100e);display:grid;place-items:center;font-family:var(--mono);font-weight:600;color:var(--text);flex:none;border:1px solid var(--line-2);overflow:hidden}
.avatar.round{border-radius:50%}

/* quality dots — visual weight of a source */
.qdots{display:inline-flex;gap:2px;align-items:center}
.qdots i{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.14)}
.qdots i.on{background:var(--green);box-shadow:0 0 5px var(--glow)}

/* confidence meter inline */
.cbar{height:4px;border-radius:3px;background:rgba(255,255,255,.07);overflow:hidden;flex:1;min-width:36px}
.cbar i{display:block;height:100%;border-radius:3px;background:linear-gradient(90deg,var(--green-dim),var(--green))}
.cbar.amber i{background:linear-gradient(90deg,var(--amber-dim),var(--amber))}
.cbar.red i{background:linear-gradient(90deg,var(--red-dim),var(--red))}
.cbar.blue i{background:linear-gradient(90deg,var(--blue-dim),var(--blue))}

/* delta colors */
.up{color:var(--green)}
.down{color:var(--red)}
.flat{color:var(--muted)}

/* freshness pip */
.fresh{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10.5px;color:var(--muted)}
.fresh .pip{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 6px var(--glow)}
.fresh.stale .pip{background:var(--amber);box-shadow:none}
.fresh.cold .pip{background:var(--muted-2);box-shadow:none}

/* uncertainty / learning state */
.learning{font-family:var(--mono);font-size:10.5px;color:var(--amber);display:inline-flex;align-items:center;gap:6px}

/* tooltip */
.tip{position:relative}
.tip .tipbox{
  position:absolute;bottom:calc(100% + 9px);left:50%;transform:translateX(-50%) translateY(4px);
  background:#0c0f0d;border:1px solid var(--line-2);border-radius:10px;padding:11px 13px;width:max-content;max-width:260px;
  font-family:var(--body);font-size:12px;color:var(--text);line-height:1.45;
  box-shadow:0 20px 50px -20px rgba(0,0,0,.9);opacity:0;pointer-events:none;transition:.18s;z-index:60;
}
.tip:hover .tipbox{opacity:1;transform:translateX(-50%) translateY(0)}
.tip .tipbox .lab{font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--green);display:block;margin-bottom:5px}

/* table */
.tbl{width:100%;border-collapse:collapse}
.tbl th{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2);text-align:left;padding:9px 12px;font-weight:600;border-bottom:1px solid var(--line);white-space:nowrap}
.tbl th.r,.tbl td.r{text-align:right}
.tbl td{padding:11px 12px;border-bottom:1px solid var(--line);font-size:13px;vertical-align:middle}
.tbl tr{transition:background .15s}
.tbl tbody tr:hover{background:rgba(255,255,255,.025);cursor:pointer}
.tbl tbody tr:last-child td{border-bottom:none}

/* score gauge label */
.gauge-wrap{display:flex;flex-direction:column;align-items:center;gap:8px}
.gauge-val{font-family:var(--display);font-weight:700;letter-spacing:-.02em}
.gauge-lab{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-2)}

/* contributor row */
.contrib{display:flex;align-items:center;gap:10px;padding:7px 0}
.contrib .nm{font-size:12.5px;color:var(--text);width:128px;flex:none}
.contrib .nm .q{font-family:var(--mono);font-size:10px;color:var(--muted-2);display:block;margin-top:1px}
.contrib .val{font-family:var(--mono);font-size:11.5px;color:var(--muted);width:38px;text-align:right;flex:none}

/* mini sparkline canvas */
.spark-mini{display:block}

/* empty / degraded state */
.empty{border:1px dashed var(--line-2);border-radius:var(--radius-sm);padding:22px;text-align:center;color:var(--muted-2);font-size:13px}
.empty .ttl{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}

/* pill toggle row of filters */
.filters{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.fpill{font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--muted);background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:8px;padding:6px 11px;cursor:pointer;transition:.18s;display:inline-flex;align-items:center;gap:6px}
.fpill:hover{border-color:var(--line-3);color:var(--text)}
.fpill.on{color:var(--green);background:rgba(45,232,158,.09);border-color:rgba(45,232,158,.26)}

/* event row (feed) */
.evt{display:flex;gap:13px;padding:13px;border:1px solid var(--line);border-radius:13px;background:var(--panel-2);transition:.2s;cursor:pointer}
.evt:hover{border-color:var(--line-2);background:var(--panel-3);transform:translateY(-1px)}
.evt .ico{flex:none;width:36px;height:36px;border-radius:9px;display:grid;place-items:center;background:rgba(255,255,255,.04);border:1px solid var(--line)}
.evt .ico svg{width:17px;height:17px;stroke:var(--green);fill:none;stroke-width:1.6}
.evt.t-buy .ico svg{stroke:var(--green)}
.evt.t-join .ico svg{stroke:var(--blue)}
.evt.t-call .ico svg{stroke:var(--violet)}
.evt.t-warn .ico svg{stroke:var(--amber)}
.evt .body{flex:1;min-width:0}
.evt .row1{display:flex;justify-content:space-between;gap:10px;align-items:baseline}
.evt .ttl{font-size:13.5px;color:var(--text);font-weight:500}
.evt .ttl b{color:var(--green);font-weight:600}
.evt .ago{font-family:var(--mono);font-size:10.5px;color:var(--muted-2);flex:none}
.evt .sub{font-size:12px;color:var(--muted);margin-top:3px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}

/* signature convergence panel */
.conv-graph{position:relative;border-radius:var(--radius);overflow:hidden;background:radial-gradient(120% 100% at 80% 0%,rgba(45,232,158,.05),transparent 55%),var(--panel)}
.conv-graph canvas{display:block;width:100%}
.conv-badge{position:absolute;top:14px;left:14px;font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);background:rgba(0,0,0,.5);border:1px solid var(--line);padding:6px 10px;border-radius:8px;backdrop-filter:blur(6px)}

/* alert row */
.alert-row{display:flex;align-items:center;gap:11px;padding:11px 0;border-bottom:1px solid var(--line)}
.alert-row:last-child{border-bottom:none}
.alert-row .ad{width:8px;height:8px;border-radius:50%;flex:none}
.alert-row .at{font-size:12.5px;color:var(--text);flex:1;min-width:0}
.alert-row .at b{color:var(--green);font-weight:600}

/* big number key-stat */
.kstat{padding:16px 18px}
.kstat .k{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-2)}
.kstat .v{font-family:var(--display);font-weight:600;font-size:26px;color:var(--white);margin-top:6px;letter-spacing:-.02em}
.kstat .v .s{font-size:15px;color:var(--green)}
.kstat .d{font-family:var(--mono);font-size:11px;margin-top:4px}

/* ---------- layout grids (responsive by class — inline grids can't collapse) ---------- */
.g-main{display:grid;gap:16px;align-items:start}
.g-main.c2a{grid-template-columns:minmax(0,1.5fr) minmax(0,1fr)}
.g-main.c2b{grid-template-columns:minmax(0,1.4fr) minmax(0,1fr)}
.g-main.c2c{grid-template-columns:minmax(0,1.25fr) minmax(0,1fr)}
.g-main.c2d{grid-template-columns:minmax(0,1.3fr) minmax(0,1fr)}
.g-triage{display:grid;gap:16px;align-items:start;grid-template-columns:minmax(0,1.05fr) minmax(0,1.25fr) minmax(0,0.95fr)}
.g-stream{display:grid;gap:16px;align-items:start;grid-template-columns:minmax(0,1fr) 320px}
.strip{display:grid;overflow:hidden}
.strip.c3{grid-template-columns:repeat(3,1fr)}
.strip.c4{grid-template-columns:repeat(4,1fr)}
.strip.c5{grid-template-columns:repeat(5,1fr)}
.strip.c6{grid-template-columns:repeat(6,1fr)}
.opp{display:grid}

/* ---------- responsive ---------- */
.menu-btn{display:none}
.nav-scrim{display:none}
@media(max-width:1100px){
  :root{--sidebar:0px}
  .sidebar{position:fixed;top:0;bottom:0;left:0;width:236px;transform:translateX(-100%);transition:transform .3s var(--ease);box-shadow:0 0 60px rgba(0,0,0,.7);z-index:40}
  .app.nav-open .sidebar{transform:none}
  .app{grid-template-columns:1fr}
  .menu-btn{display:grid}
  .nav-scrim{display:block;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:35;opacity:0;pointer-events:none;transition:.3s}
  .app.nav-open .nav-scrim{opacity:1;pointer-events:auto}
  .g-triage{grid-template-columns:1fr 1fr}
}
@media(max-width:900px){
  /* !important: the base .g-main.c2a/.c2b… selectors are MORE specific than a plain .g-main,
     so without it these multi-column page layouts never collapse on mobile */
  .g-main,.g-main.c2a,.g-main.c2b,.g-main.c2c,.g-main.c2d,.g-triage,.g-stream{grid-template-columns:1fr!important}
  .strip.c6,.strip.c5{grid-template-columns:repeat(3,1fr)}
  .strip>div{border-right:none!important;border-bottom:1px solid var(--line)}
  .card{overflow-x:auto}
  table.tbl{min-width:600px}
  iframe{max-height:300px}
  .conv-graph{position:static!important}
  /* stack the big opportunity card's right rail below its body */
  .opp{grid-template-columns:1fr!important}
  .opp-side{border-left:none!important;border-top:1px solid var(--line)}
}
@media(max-width:760px){
  .tb-searchwrap{flex:1 1 auto;margin-left:8px}
  .tb-search{width:100%;min-width:0}
  .tb-search .kbd{display:none}
  .tb-title{display:none}
  .tb-live{display:none}
  .content-pad{padding:16px}
  /* dense row chrome (overlapping avatar stack + 3-segment breadth meter) doesn't fit a phone
     row — drop it everywhere; the conviction number + tap-through to detail remain */
  .srcstack,.breadth{display:none!important}
}
@media(max-width:640px){
  .strip.c4,.strip.c5,.strip.c6{grid-template-columns:repeat(2,1fr)}
  .strip.c3{grid-template-columns:repeat(3,1fr)}
  .chip{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
  .content-pad{padding:12px}
  .content-pad h2{font-size:20px!important}
  .topbar{padding:0 12px;gap:8px}
  /* tighten cards + tables so dense data fits a phone */
  .card-pad{padding:14px}
  .kstat{padding:11px 13px}
  /* wide data tables scroll horizontally inside their card (overflow-x set at 900) — keep
     columns readable rather than crushing them; just tighten spacing */
  table.tbl{min-width:480px}
  .tbl th,.tbl td{padding:9px 7px;font-size:11.5px}
  .opp-side{padding:14px}
  .seg,.filters{flex-wrap:wrap}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important}
}
