/* v3 module overrides — applied to existing module DOM to turn it editorial.
   Ribbon (.ribbon/.rb-*) and Tweaks (.tweaks/.tw-pick/.reorder*) styles now
   live in src/shared/chrome.css so legacy pages share the same chrome. */
const CSS_V3_MOD = `

/* ==== MACRO row — turn into editorial stat cards ==== */
/* Two-column layout: 3 compact stat cards stacked on the left, sector
   leaderboard on the right. Natural heights — no dead space from grid
   row-equalization between short stat cards and the tall leaderboard. */
.macro-row {
  display: grid;
  grid-template-columns: 1fr 3fr;
  gap: 14px;
  align-items: stretch;
}
.macro-stack {
  display: flex; flex-direction: column; gap: 14px;
  min-width: 0;
}
.macro {
  padding: 16px 18px 14px;
  background: var(--card);
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  display: flex; flex-direction: column; gap: 8px;
  min-height: 150px;
  box-shadow: var(--shadow-card);
}
.macro-stack > .macro { flex: 1; min-height: 0; }
.macro:hover { border-color: var(--rule-strong); }
.macro .hd { display: flex; align-items: center; gap: 8px; }
.macro .hd .t {
  font-family: var(--sans);
  font-size: 10.5px; font-weight: 600;
  color: var(--ink-2); letter-spacing: 0.1em; text-transform: uppercase;
}
.macro .hd .st {
  margin-left: auto; font-family: var(--sans);
  font-size: 9.5px; font-weight: 600;
  padding: 2px 6px; border-radius: 3px;
  background: var(--paper-2); color: var(--ink-3);
  letter-spacing: 0.06em;
}
.macro .hd .st.up   { color: var(--up);   background: var(--up-bg); }
.macro .hd .st.down { color: var(--down); background: var(--down-bg); }
.macro .hd .st.warn { color: var(--warm); background: var(--warm-bg); }
.macro .explain {
  font-family: var(--sans); font-size: 11px; color: var(--ink-3);
  line-height: 1.4; text-wrap: pretty;
}
.macro .big {
  font-family: var(--serif);
  font-size: 28px; font-weight: 500;
  color: var(--ink); letter-spacing: -0.015em;
  font-variant-numeric: tabular-nums;
  line-height: 1.1;
}
.macro .chg {
  font-family: var(--mono); font-size: 11.5px; font-variant-numeric: tabular-nums;
}
.macro .viz { flex: 1; min-height: 42px; }

/* ==== NEWS row ==== */
/* 6 tracks. Breadth is sized on par with the news cards so its explain line
   fits on ONE row (no ugly mid-sentence wrap) and the six stat rows have
   room to breathe. Calendar stays span-2 on narrow tracks; Bulletin stays
   compact. */
.news-row {
  display: grid;
  grid-template-columns: 1.8fr 1.8fr 0.7fr 0.7fr 1.3fr 1.3fr;
  gap: 14px;
}
.news-card { min-height: 340px; }
.news-card .card-bd { padding: 0; overflow: auto; max-height: 340px; }
.news-item {
  padding: 12px 16px;
  border-bottom: 1px solid var(--rule-soft);
  cursor: pointer;
  transition: background 120ms;
}
.news-item:hover { background: var(--paper-1); }
.news-item .meta {
  display: flex; align-items: center; gap: 6px;
  font-family: var(--sans);
  font-size: 10.5px; color: var(--ink-3);
  margin-bottom: 4px;
}
.news-item .src {
  color: var(--warm); font-weight: 700; font-size: 9.5px;
  letter-spacing: 0.14em; text-transform: uppercase;
}
.news-item h5 {
  font-family: var(--serif);
  font-size: 14px; font-weight: 500;
  color: var(--ink); line-height: 1.32;
  letter-spacing: -0.005em;
  text-wrap: pretty;
}
.news-item .syms { display: flex; gap: 4px; margin-top: 7px; flex-wrap: wrap; }
.news-item .syms .s {
  font-family: var(--mono);
  font-size: 9.5px; padding: 1px 6px; border-radius: 3px;
  background: var(--paper-2); color: var(--ink-2);
  font-weight: 600; letter-spacing: 0.04em;
}
.news-item .syms .s.up { background: var(--up-bg); color: var(--up); }
.news-item .syms .s.down { background: var(--down-bg); color: var(--down); }
.news-item.new { animation: newItem 1200ms ease-out; }
@keyframes newItem {
  0% { background: var(--warm-bg); transform: translateY(-4px); opacity: 0; }
  20% { opacity: 1; transform: translateY(0); }
  100% { background: transparent; }
}

.cal-item {
  padding: 10px 16px;
  display: grid; grid-template-columns: 46px minmax(0, 1fr) auto; gap: 10px;
  border-bottom: 1px solid var(--rule-soft);
  font-size: 12px;
  align-items: center;
  min-width: 0;
}
.cal-item .time { color: var(--ink-1); font-family: var(--mono); font-variant-numeric: tabular-nums; font-weight: 500; }
.cal-item .t { color: var(--ink); font-family: var(--sans); line-height: 1.35; font-size: 12.5px; min-width: 0; overflow-wrap: anywhere; }
.cal-item .t .d { display: block; color: var(--ink-3); font-size: 11px; font-family: var(--sans); }
.cal-item .imp { width: 12px; display: flex; flex-direction: column; gap: 1px; }
.cal-item .imp span { height: 3px; background: var(--ink-4); border-radius: 1px; }
.cal-item .imp.high span { background: var(--down); }
.cal-item .imp.med span:nth-child(1), .cal-item .imp.med span:nth-child(2) { background: var(--warm); }
.cal-item .imp.low span:nth-child(1) { background: var(--ink-2); }

.er-item {
  padding: 11px 16px;
  border-bottom: 1px solid var(--rule-soft);
  display: grid; grid-template-columns: minmax(0,1fr) auto auto; gap: 10px;
  align-items: center;
}
.er-item .lhs { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.er-item .sym { font-family: var(--mono); font-weight: 700; color: var(--ink); font-size: 12.5px; }
.er-item .name { color: var(--ink-3); font-size: 11px; font-family: var(--sans); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.er-item .when {
  padding: 2px 6px; border-radius: 3px;
  background: var(--paper-2); color: var(--ink-2);
  font-family: var(--sans); font-size: 9.5px; font-weight: 600;
  letter-spacing: 0.08em;
}
.er-item .when.amc { background: var(--cool-bg); color: var(--cool); }
.er-item .when.bmo { background: var(--warm-bg); color: var(--warm); }
.er-item .eps {
  font-family: var(--mono);
  font-variant-numeric: tabular-nums;
  color: var(--ink-1); text-align: right; font-size: 12px;
}
.er-item .eps .k {
  display: block; color: var(--ink-4); font-size: 9px;
  font-family: var(--sans);
  letter-spacing: 0.1em; text-transform: uppercase; font-weight: 600;
}

/* Raised specificity to .card-bd.breadth so this padding actually wins over
   .news-card .card-bd { padding: 0 } — otherwise the bar/legend/stats render
   edge-to-edge against the card border. min-width: 0 on the container and
   its grid children prevents intrinsic content from forcing width past the
   card and being clipped by .card { overflow: hidden }. */
.card-bd.breadth { padding: 16px; display: flex; flex-direction: column; gap: 12px; flex: 1; min-width: 0; }
.breadth .bar {
  height: 10px; border-radius: 3px; background: var(--paper-2);
  display: flex; overflow: hidden;
}
.breadth .bar .g { background: var(--up); height: 100%; }
.breadth .bar .r { background: var(--down); height: 100%; }
.breadth .legend {
  display: flex; justify-content: space-between;
  gap: 8px; flex-wrap: wrap;
  font-family: var(--mono);
  font-size: 11px; font-variant-numeric: tabular-nums;
  min-width: 0;
}
.breadth .legend > span { white-space: nowrap; }
.breadth .stat {
  display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 8px;
  font-size: 12px; padding: 5px 0;
  border-bottom: 1px solid var(--rule-soft);
  font-family: var(--sans);
  align-items: baseline;
  min-width: 0;
}
.breadth .stat:last-child { border-bottom: 0; }
.breadth .stat .k {
  color: var(--ink-3);
  min-width: 0;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.breadth .stat .v {
  color: var(--ink); font-family: var(--mono); font-variant-numeric: tabular-nums; font-weight: 600;
  white-space: nowrap;
}

.sb-tf {
  display: flex; gap: 4px; flex-wrap: wrap;
  margin-top: 8px;
  padding-top: 10px;
  border-top: 1px dashed var(--rule-soft);
}
.sb-tf-btn {
  font-family: var(--sans);
  font-size: 10.5px; font-weight: 600;
  color: var(--ink-2);
  padding: 3px 9px; border-radius: 12px;
  border: 1px solid var(--rule);
  background: var(--card);
  cursor: pointer;
  transition: background 120ms, color 120ms, border-color 120ms;
  letter-spacing: 0.02em;
}
.sb-tf-btn:hover { border-color: var(--rule-strong); color: var(--ink-1); }
.sb-tf-btn.on {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}

/* Sector leaderboard expands to fill the macro-sector card. Rows distribute
   evenly so the leaderboard reads as a single tall, deliberate panel rather
   than a tight stack with dead space underneath. */
.macro-sector { display: flex; flex-direction: column; }
.macro-sector .sector-breadth { flex: 1; min-height: 0; }
.sector-breadth {
  margin-top: 14px;
  display: flex; flex-direction: column;
  gap: 0;
}
.sb-h {
  font-family: var(--sans);
  font-size: 11px; font-weight: 700;
  color: var(--ink-3); letter-spacing: 0.14em; text-transform: uppercase;
  margin-bottom: 10px;
}
.sb-row {
  display: grid;
  grid-template-columns: minmax(120px, 150px) minmax(0, 1fr) 56px;
  align-items: center; gap: 14px;
  font-family: var(--mono);
  flex: 1;
  min-height: 32px;
  padding: 4px 0;
  min-width: 0;
}
.sb-n { font-family: var(--sans); font-size: 13.5px; font-weight: 500; color: var(--ink-1); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; min-width: 0; }
.sb-bar { display: flex; height: 12px; border-radius: 3px; overflow: hidden; background: var(--paper-2); }
.sb-bar .g { background: var(--up); height: 100%; }
.sb-bar .r { background: var(--down); height: 100%; }
.sb-nums { font-size: 13px; color: var(--ink-3); font-variant-numeric: tabular-nums; text-align: right; }
.sb-nums .up { color: var(--up); font-weight: 700; }
.sb-nums .down { color: var(--down); font-weight: 700; }

.bul { padding: 0; }
.bul-item {
  padding: 12px 16px;
  border-bottom: 1px solid var(--rule-soft);
  display: flex; flex-direction: column; gap: 5px;
}
.bul-item .row1 {
  display: flex; align-items: center; gap: 6px;
  font-family: var(--sans);
  font-size: 10.5px; color: var(--ink-3);
}
.bul-item .tag {
  font-size: 9.5px; padding: 1px 6px; border-radius: 3px;
  letter-spacing: 0.12em; text-transform: uppercase; font-weight: 700;
  font-family: var(--sans);
}
.bul-item .tag.signal { background: var(--cool-bg); color: var(--cool); }
.bul-item .tag.flow   { background: var(--up-bg); color: var(--up); }
.bul-item .tag.risk   { background: var(--down-bg); color: var(--down); }
.bul-item .tag.watch  { background: var(--warm-bg); color: var(--warm); }
.bul-item h5 {
  font-family: var(--serif);
  font-size: 13.5px; color: var(--ink); font-weight: 500; line-height: 1.35;
  letter-spacing: -0.005em;
}
.bul-item p {
  font-family: var(--sans);
  font-size: 12px; color: var(--ink-2); line-height: 1.5;
  text-wrap: pretty;
}

/* ==== MOVERS row ==== */
.movers-row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.movers-card { min-height: 400px; padding-bottom: 8px; }
.movers-card .rows { padding: 4px 6px; }
.mv-row {
  display: grid;
  grid-template-columns: 28px minmax(0,1fr) 78px 68px 80px 54px !important;
  gap: 10px !important;
  padding: 12px 12px; align-items: center;
  border-radius: 6px;
  cursor: pointer;
  transition: background 120ms;
}
.mv-row:hover { background: var(--paper-1); }
.mv-row .rank {
  font-family: var(--mono);
  font-size: 11px; color: var(--ink-3);
  font-variant-numeric: tabular-nums; letter-spacing: 0.04em;
}
.mv-row .left { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.mv-row .left .sym { font-family: var(--mono); font-weight: 700; color: var(--ink); font-size: 13px; letter-spacing: 0.02em; }
.mv-row .left .name { font-family: var(--sans); color: var(--ink-3); font-size: 11.5px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mv-row .px { font-family: var(--mono); text-align: right; font-variant-numeric: tabular-nums; color: var(--ink-1); font-size: 12.5px; }
.mv-row .pct {
  font-family: var(--mono);
  text-align: right; font-variant-numeric: tabular-nums; font-weight: 700;
  padding: 3px 7px; border-radius: 4px; font-size: 11.5px;
  justify-self: end;
}
.mv-row .pct.up { color: var(--up); background: var(--up-bg); }
.mv-row .pct.down { color: var(--down); background: var(--down-bg); }
.mv-row .vol { font-family: var(--mono); font-size: 11px; text-align: right; color: var(--ink-3); font-variant-numeric: tabular-nums; min-width: 0; }
.mv-row .vol .k { font-family: var(--sans); font-size: 9.5px; color: var(--ink-3); letter-spacing: 0.1em; display: block; text-transform: uppercase; font-weight: 600; }
.mv-row .spark { justify-self: end; }
@media (max-width: 1280px) {
  .mv-row { grid-template-columns: 28px minmax(0,1fr) 72px 62px 54px !important; }
  .mv-row .vol { display: none; }
}

/* ==== SCANNERS ==== */
.scanners-row { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 14px; }
.scan-card { min-height: 360px; }
.scan-thead {
  display: grid; grid-template-columns: minmax(0,1.4fr) minmax(0,1.1fr) 70px 60px; gap: 8px;
  padding: 7px 16px;
  font-family: var(--sans);
  font-size: 9.5px; color: var(--ink-3);
  text-transform: uppercase; letter-spacing: 0.12em; font-weight: 600;
  background: var(--paper-1); border-bottom: 1px solid var(--rule-soft);
}
.scan-thead.f13 { grid-template-columns: minmax(0,1fr) minmax(0,1fr) minmax(0,1.3fr); }
.scan-thead.ipo { grid-template-columns: minmax(0,1.4fr) minmax(0,1fr) 80px 60px; }
.scan-thead .r { text-align: right; }

.ins-row {
  display: grid; grid-template-columns: minmax(0,1.4fr) minmax(0,1.1fr) 70px 60px !important; gap: 8px;
  padding: 10px 16px; border-bottom: 1px solid var(--rule-soft);
  font-size: 12px; align-items: center;
}
.ins-row .who { min-width: 0; }
.ins-row .who .sym { font-family: var(--mono); font-weight: 700; color: var(--ink); font-size: 12.5px; display: block; }
.ins-row .who .name { font-family: var(--sans); color: var(--ink-3); font-size: 11px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ins-row .act { display: flex; align-items: center; gap: 7px; min-width: 0; }
.ins-row .act .arrow { font-size: 10px; }
.ins-row .act.up .arrow { color: var(--up); }
.ins-row .act.down .arrow { color: var(--down); }
.ins-row .act b { font-family: var(--sans); color: var(--ink); font-size: 12px; }
.ins-row .act .sub { font-family: var(--mono); color: var(--ink-3); font-size: 10.5px; }
.ins-row .val { font-family: var(--mono); text-align: right; font-variant-numeric: tabular-nums; color: var(--ink); font-weight: 600; font-size: 12px; }
.ins-row .when { font-family: var(--sans); text-align: right; color: var(--ink-3); font-size: 10.5px; }

.f13-row {
  display: grid; grid-template-columns: minmax(0,1fr) minmax(0,1fr) minmax(0,1.3fr) !important; gap: 10px;
  padding: 11px 16px; border-bottom: 1px solid var(--rule-soft);
  font-size: 12px; align-items: center;
}
.f13-row .fund { min-width: 0; }
.f13-row .fund .name { font-family: var(--serif); font-weight: 600; color: var(--ink); font-size: 13px; display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; letter-spacing: -0.005em; }
.f13-row .fund .q { font-family: var(--sans); color: var(--ink-4); font-size: 10px; letter-spacing: 0.1em; font-weight: 600; }
.f13-row .top { display: flex; align-items: baseline; gap: 8px; }
.f13-row .top .sym { font-family: var(--mono); font-weight: 700; color: var(--ink); font-size: 12.5px; }
.f13-row .top .pct { font-family: var(--mono); color: var(--ink-2); font-size: 11.5px; }
.f13-row .move { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.f13-row .move .chg { font-family: var(--sans); color: var(--ink-1); font-size: 11px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.f13-row .move .drs { display: flex; gap: 5px; }
.f13-row .move .new { font-family: var(--mono); padding: 1px 6px; border-radius: 3px; background: var(--up-bg); color: var(--up); font-size: 10px; font-weight: 700; }
.f13-row .move .exit { font-family: var(--mono); padding: 1px 6px; border-radius: 3px; background: var(--down-bg); color: var(--down); font-size: 10px; font-weight: 700; }

.ai-row {
  display: grid; grid-template-columns: 26px minmax(0,1fr) 58px !important; gap: 10px;
  padding: 12px 16px; border-bottom: 1px solid var(--rule-soft);
  font-size: 12px; align-items: center;
}
.ai-row .rank { font-family: var(--mono); color: var(--ink-3); font-size: 11px; font-variant-numeric: tabular-nums; }
.ai-row .body { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.ai-row .venue { font-family: var(--sans); font-size: 9.5px; color: var(--warm); text-transform: uppercase; letter-spacing: 0.12em; font-weight: 700; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ai-row .title { font-family: var(--serif); color: var(--ink); font-size: 13px; line-height: 1.32; letter-spacing: -0.005em; text-wrap: pretty; }
.ai-row .auth { font-family: var(--sans); color: var(--ink-3); font-size: 11px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ai-row .impact { display: flex; flex-direction: column; align-items: flex-end; gap: 3px; }
.ai-row .impact .score { font-family: var(--serif); font-size: 18px; color: var(--cool); font-weight: 600; letter-spacing: -0.01em; }
.ai-row .impact .bar { width: 50px; height: 3px; background: var(--paper-2); border-radius: 2px; overflow: hidden; }
.ai-row .impact .bar span { display: block; height: 100%; background: var(--cool); }

.ipo-row {
  display: grid; grid-template-columns: minmax(0,1.4fr) minmax(0,0.9fr) 92px 64px !important; gap: 10px;
  padding: 10px 16px; border-bottom: 1px solid var(--rule-soft);
  font-size: 12px; align-items: center;
}
.ipo-row .co { min-width: 0; }
.ipo-row .co .tk { font-family: var(--mono); font-weight: 700; color: var(--ink); font-size: 12.5px; display: block; }
.ipo-row .co .nm { font-family: var(--sans); color: var(--ink-3); font-size: 11px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ipo-row .when .d { font-family: var(--sans); color: var(--ink); font-size: 11.5px; display: block; }
.ipo-row .when .st { font-family: var(--sans); font-size: 9px; padding: 1px 5px; border-radius: 3px; background: var(--paper-2); color: var(--ink-2); letter-spacing: 0.1em; text-transform: uppercase; font-weight: 700; white-space: nowrap; display: inline-block; }
.ipo-row .when .st.priced { background: var(--up-bg); color: var(--up); }
.ipo-row .when .st.roadshow { background: var(--cool-bg); color: var(--cool); }
.ipo-row .when .st.expected { background: var(--warm-bg); color: var(--warm); }
.ipo-row .when .st.delayed { background: var(--down-bg); color: var(--down); }
.ipo-row .range { font-family: var(--mono); text-align: right; color: var(--ink-1); font-size: 11.5px; }
.ipo-row .sz { font-family: var(--mono); text-align: right; color: var(--ink); font-weight: 600; font-size: 11.5px; }

/* ==== TOOLS row ==== */
.tools-row { display: grid; grid-template-columns: 1.7fr 1.3fr; gap: 18px; }
.tool-card { min-height: 480px; display: flex; flex-direction: column; }
.tool-card .card-bd { flex: 1; display: flex; flex-direction: column; }

.heat-card .heat-bd { padding: 12px; }
.heat-card .heat-grid { flex: 1; }
.heat-legend { display: inline-flex; align-items: center; gap: 3px; font-family: var(--sans); font-size: 10px; color: var(--ink-3); }
.heat-legend span:nth-child(odd) { width: 16px; height: 10px; display: inline-block; border-radius: 2px; }
.heat-grid { display: flex; flex-wrap: wrap; gap: 4px; align-content: stretch; }
.heat-sec { display: flex; flex-direction: column; gap: 3px; min-width: 170px; }
.heat-sec .sec-lbl {
  font-family: var(--sans);
  font-size: 10px; color: var(--ink-2); font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.1em;
  padding: 4px 5px;
}
.heat-sec .sec-lbl .w { color: var(--ink-4); font-weight: 500; margin-left: 6px; }
.heat-sec .sec-cells { flex: 1; display: flex; flex-wrap: wrap; gap: 2px; min-height: 64px; }
.heat-sec .cell {
  flex: 1 1 0; min-width: 58px; min-height: 56px;
  display: flex; flex-direction: column; justify-content: center; align-items: center;
  padding: 6px 4px; border-radius: 4px;
  cursor: pointer;
  transition: transform 120ms;
}
.heat-sec .cell:hover { transform: scale(1.04); z-index: 2; outline: 1px solid var(--rule-strong); }
.heat-sec .cell .sym { font-family: var(--mono); font-size: 11.5px; font-weight: 700; color: var(--ink); letter-spacing: 0.02em; }
.heat-sec .cell .pct { font-family: var(--mono); font-size: 10.5px; color: var(--ink-1); font-variant-numeric: tabular-nums; }

.screen-card { min-height: 480px; }
.screen-card .presets { display: flex; gap: 6px; padding: 10px 16px 12px; flex-wrap: wrap; border-bottom: 1px solid var(--rule-soft); }
.screen-card .presets button {
  padding: 6px 12px; font-family: var(--sans); font-size: 11.5px; color: var(--ink-2);
  border: 1px solid var(--rule); border-radius: 20px;
  background: var(--card);
  font-weight: 500;
}
.screen-card .presets button.on { color: var(--paper); border-color: var(--ink); background: var(--ink); font-weight: 600; }
.screen-card .presets button.edit { margin-left: auto; border-style: dashed; color: var(--ink-3); }
.scr-thead {
  display: grid; grid-template-columns: minmax(0,1.5fr) 64px 66px 60px 52px 44px 52px 50px !important; gap: 6px;
  padding: 8px 16px; font-family: var(--sans);
  font-size: 9.5px; color: var(--ink-3);
  text-transform: uppercase; letter-spacing: 0.12em; font-weight: 600;
  background: var(--paper-1); border-bottom: 1px solid var(--rule-soft);
}
.scr-thead .r { text-align: right; }
.scr-row {
  display: grid; grid-template-columns: minmax(0,1.5fr) 64px 66px 60px 52px 44px 52px 50px !important; gap: 6px;
  padding: 10px 16px; border-bottom: 1px solid var(--rule-soft);
  font-size: 12px; align-items: center;
  cursor: pointer; transition: background 120ms;
}
.scr-row:hover { background: var(--paper-1); }
.scr-row .sym-c { min-width: 0; }
.scr-row .sym-c .lbl { font-family: var(--mono); font-weight: 700; color: var(--ink); font-size: 12.5px; display: block; }
.scr-row .sym-c .nm { font-family: var(--sans); color: var(--ink-3); font-size: 11px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.scr-row .r { font-family: var(--mono); text-align: right; font-variant-numeric: tabular-nums; color: var(--ink-1); }
.scr-row .pct { justify-self: end; padding: 2px 6px; border-radius: 3px; font-weight: 700; font-size: 11.5px; font-family: var(--mono); }
.scr-row .pct.up { color: var(--up); background: var(--up-bg); }
.scr-row .pct.down { color: var(--down); background: var(--down-bg); }
.rsi-pill { padding: 2px 6px; border-radius: 3px; font-size: 11px; font-weight: 600; font-family: var(--mono); }

.earncal-card .earncal-bd { padding: 14px 16px 18px; overflow: auto; }
.earncal-card .days { display: flex; gap: 10px; min-height: 360px; }
.earncal-card .day { flex: 1; min-width: 140px; display: flex; flex-direction: column; background: var(--paper-1); border: 1px solid var(--rule-soft); border-radius: 6px; overflow: hidden; }
.earncal-card .day-hd {
  padding: 10px 12px;
  font-family: var(--sans);
  font-size: 10.5px; color: var(--ink-1); font-weight: 700;
  letter-spacing: 0.08em; background: var(--paper-2);
  display: flex; justify-content: space-between; align-items: center;
  border-bottom: 1px solid var(--rule-soft);
}
.earncal-card .day-hd span { color: var(--ink-3); font-size: 10px; font-weight: 500; }
.earncal-card .day-body { flex: 1; padding: 8px; display: flex; flex-direction: column; gap: 6px; }
.ec-item {
  display: grid; grid-template-columns: 1fr auto; grid-template-rows: auto auto;
  padding: 8px 10px; border: 1px solid var(--rule-soft); border-radius: 5px;
  background: var(--card);
  column-gap: 8px; row-gap: 2px;
}
.ec-item .sym { font-family: var(--mono); font-weight: 700; color: var(--ink); font-size: 12px; }
.ec-item .mc { font-family: var(--sans); color: var(--ink-3); font-size: 10px; }
.ec-item .when { font-family: var(--sans); font-size: 9px; padding: 1px 5px; border-radius: 2px; letter-spacing: 0.08em; background: var(--paper-2); color: var(--ink-2); justify-self: end; font-weight: 700; }
.ec-item .when.amc { background: var(--cool-bg); color: var(--cool); }
.ec-item .when.bmo { background: var(--warm-bg); color: var(--warm); }
.ec-item .est { grid-column: 2; text-align: right; font-family: var(--mono); color: var(--ink-1); font-size: 11px; font-variant-numeric: tabular-nums; }

/* ==== DRAWER / PALETTE / TWEAKS — reskin ==== */
.scrim { position: fixed; inset: 0; background: oklch(0 0 0 / 0.30); z-index: 90; backdrop-filter: blur(2px); animation: fadeIn 180ms ease; }

/* Push-layout drawer: hide scrim, shift main content so both visible */
html.drawer-open .scrim { display: none; }
html.drawer-open .topbar { padding-right: 440px; }
html.drawer-open .ribbon-rail,
html.drawer-open .hero,
html.drawer-open .dash { padding-right: 440px; }
html.drawer-open .hero-inner { max-width: none; }
@media (max-width: 1100px) {
  /* Narrow viewport: drawer overlays rather than pushes (not enough room) */
  html.drawer-open .topbar,
  html.drawer-open .ribbon-rail,
  html.drawer-open .hero,
  html.drawer-open .dash { padding-right: 24px; }
  html.drawer-open .scrim { display: block; }
}

/* Drawer-open: reflow rows that normally demand more columns */
@media (min-width: 1101px) {
  html.drawer-open .news-row { grid-template-columns: repeat(3, 1fr); }
  html.drawer-open .scanners-row { grid-template-columns: repeat(2, 1fr); }
  html.drawer-open .macro-row { grid-template-columns: 1fr 2fr; }
  html.drawer-open .movers-row { grid-template-columns: repeat(2, 1fr); }
  html.drawer-open .tools-row { grid-template-columns: 1fr; }
  html.drawer-open .trailhead-section .trail-grid { grid-template-columns: repeat(2, 1fr); }
}
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
.drawer {
  position: fixed; top: 0; right: 0; bottom: 0;
  width: 440px; max-width: 100vw; z-index: 91;
  background: var(--card);
  border-left: 1px solid var(--rule);
  box-shadow: var(--shadow-lift);
  display: flex; flex-direction: column;
  animation: slideIn 260ms cubic-bezier(0.22, 1, 0.36, 1);
  /* Respect notch / home-indicator safe areas on iOS */
  padding-top: env(safe-area-inset-top, 0);
  padding-bottom: env(safe-area-inset-bottom, 0);
}
@media (max-width: 520px) {
  /* On a phone the 440px drawer overflows; take the full viewport instead. */
  .drawer { width: 100vw; }
  .drawer-hd { padding: 14px 16px; }
  .drawer-hd .x { width: 40px; height: 40px; font-size: 18px; }
  .wl-thead, .wl-row { padding-left: 14px; padding-right: 14px; }
}
@keyframes slideIn { from { transform: translateX(24px); opacity: 0; } to { transform: translateX(0); opacity: 1; } }
.drawer-hd { display: flex; align-items: center; gap: 12px; padding: 18px 20px; border-bottom: 1px solid var(--rule); }
.drawer-hd h3 { font-family: var(--serif); font-size: 20px; font-weight: 600; color: var(--ink); letter-spacing: -0.015em; }
.drawer-hd .sub { font-family: var(--sans); font-size: 11px; color: var(--ink-3); }
.drawer-hd .x { margin-left: auto; width: 28px; height: 28px; display: grid; place-items: center; border-radius: 6px; color: var(--ink-2); }
.drawer-hd .x:hover { background: var(--paper-2); color: var(--ink); }
.drawer-tabs { display: flex; gap: 2px; padding: 0 16px; border-bottom: 1px solid var(--rule); }
.drawer-tabs button { padding: 11px 10px; font-family: var(--sans); color: var(--ink-2); font-size: 12px; border-bottom: 2px solid transparent; white-space: nowrap; font-weight: 500; }
.drawer-tabs button.on { color: var(--ink); border-bottom-color: var(--warm); font-weight: 600; }
.drawer-tabs button:hover { color: var(--ink); }
.drawer-search { display: flex; align-items: center; gap: 8px; padding: 12px 16px; border-bottom: 1px solid var(--rule-soft); }
.drawer-search input { flex: 1; height: 30px; border: 1px solid var(--rule); border-radius: 6px; padding: 0 10px; font-size: 12.5px; background: var(--paper-1); font-family: var(--sans); }
.drawer-search input:focus { border-color: var(--warm); background: var(--card); }
.wl-thead { display: grid; grid-template-columns: 1fr 80px 62px 60px; gap: 8px; padding: 8px 20px; font-family: var(--sans); font-size: 9.5px; color: var(--ink-3); text-transform: uppercase; letter-spacing: 0.12em; font-weight: 600; background: var(--paper-1); border-bottom: 1px solid var(--rule-soft); }
.wl-thead .num { text-align: right; }
.wl-body { flex: 1; overflow: auto; }
.wl-row { display: grid; grid-template-columns: 1fr 80px 62px 60px; gap: 8px; padding: 10px 20px; font-size: 12px; align-items: center; border-bottom: 1px solid var(--rule-soft); cursor: pointer; transition: background 120ms; position: relative; }
.wl-row:hover { background: var(--paper-1); }
.wl-row.active { background: var(--paper-2); }
.wl-row.active::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 2px; background: var(--warm); }
.wl-row .sym-cell .lbl { font-family: var(--mono); font-weight: 700; color: var(--ink); font-size: 12.5px; }
.wl-row .sym-cell .co { font-family: var(--sans); color: var(--ink-3); font-size: 11px; display: block; }
.wl-row .num { font-family: var(--mono); text-align: right; font-variant-numeric: tabular-nums; }
.wl-row .pct { text-align: right; font-variant-numeric: tabular-nums; font-weight: 700; padding: 2px 5px; border-radius: 3px; font-family: var(--mono); font-size: 11px; }
.wl-row .pct.up { color: var(--up); background: var(--up-bg); }
.wl-row .pct.down { color: var(--down); background: var(--down-bg); }
.wl-cat-hd { display: flex; align-items: center; justify-content: space-between; padding: 8px 20px; font-family: var(--sans); font-size: 10px; text-transform: uppercase; letter-spacing: 0.14em; font-weight: 700; color: var(--ink-2); background: var(--paper-1); border-top: 1px solid var(--rule-soft); border-bottom: 1px solid var(--rule-soft); }
.wl-cat-hd .wl-cat-count { font-family: var(--mono); color: var(--ink-3); font-size: 10.5px; font-weight: 600; letter-spacing: 0; }
.flash-up   { animation: flashUp 700ms ease-out; }
.flash-down { animation: flashDn 700ms ease-out; }
@keyframes flashUp { 0% { background: var(--up-bg); } 100% { background: transparent; } }
@keyframes flashDn { 0% { background: var(--down-bg); } 100% { background: transparent; } }

.cmd-scrim {
  position: fixed; inset: 0; background: oklch(0 0 0 / 0.30);
  z-index: 100; backdrop-filter: blur(4px);
  display: grid; place-items: start center; padding-top: 14vh;
  animation: fadeIn 160ms ease;
}
.cmd-modal {
  width: min(640px, 92vw);
  background: var(--card);
  border: 1px solid var(--rule-strong);
  border-radius: 10px; box-shadow: var(--shadow-lift);
  overflow: hidden; display: flex; flex-direction: column;
  max-height: 60vh;
}
.cmd-input-row { display: flex; align-items: center; gap: 10px; padding: 16px 18px; border-bottom: 1px solid var(--rule); }
.cmd-input-row .p { color: var(--warm); font-family: var(--serif); font-weight: 700; font-size: 18px; font-style: italic; }
.cmd-input-row input { flex: 1; font-size: 14.5px; font-family: var(--sans); color: var(--ink); }
.cmd-input-row input::placeholder { color: var(--ink-3); }
.cmd-list { overflow: auto; }
.cmd-group-hd { padding: 9px 18px; font-family: var(--sans); font-size: 10px; text-transform: uppercase; letter-spacing: 0.14em; color: var(--ink-3); background: var(--paper-1); border-bottom: 1px solid var(--rule-soft); font-weight: 700; }
.cmd-item { display: flex; align-items: center; gap: 12px; padding: 10px 18px; font-size: 12.5px; cursor: pointer; font-family: var(--sans); }
.cmd-item.active { background: var(--paper-2); box-shadow: inset 2px 0 0 var(--warm); }
.cmd-item .i { width: 20px; color: var(--ink-3); text-align: center; }
.cmd-item .t { flex: 1; color: var(--ink); }
.cmd-item .t b { font-family: var(--mono); }
.cmd-item .s { font-family: var(--mono); color: var(--ink-3); font-size: 11px; }
.cmd-hint { padding: 10px 18px; border-top: 1px solid var(--rule); color: var(--ink-3); font-size: 11px; display: flex; gap: 14px; font-family: var(--sans); }
.cmd-hint kbd { padding: 1px 5px; border: 1px solid var(--rule); border-radius: 3px; background: var(--paper-1); color: var(--ink-2); font-size: 10px; font-family: var(--mono); }

/* .tweaks/.tweak-group/.tw-pick/.reorder* + slideUp keyframe live in src/shared/chrome.css */

.counter-chip { display: inline-flex; align-items: center; gap: 5px; padding: 2px 7px; border-radius: 12px; border: 1px solid var(--rule); color: var(--ink-2); font-family: var(--sans); font-size: 10.5px; }
.counter-chip .d { width: 5px; height: 5px; border-radius: 50%; background: var(--up); animation: pulse 1.8s ease-in-out infinite; }

/* ==== V3 DENSITY OVERRIDES — higher specificity than v2 ==== */
html[data-density="compact"] .card-hd { padding: 8px 14px 6px !important; }
html[data-density="compact"] .news-item { padding: 7px 14px !important; }
html[data-density="compact"] .news-item h5 { font-size: 13px; }
html[data-density="compact"] .mv-row { padding: 6px 10px !important; }
html[data-density="compact"] .ins-row,
html[data-density="compact"] .f13-row,
html[data-density="compact"] .ipo-row,
html[data-density="compact"] .ai-row { padding: 7px 14px !important; }
html[data-density="compact"] .scr-row { padding: 6px 14px !important; }
html[data-density="compact"] .macro { min-height: 120px; padding: 12px 14px 10px !important; }
html[data-density="compact"] .macro .big { font-size: 24px; }
html[data-density="compact"] .cal-item { padding: 7px 14px !important; }
html[data-density="compact"] .er-item { padding: 7px 14px !important; }
html[data-density="compact"] .bul-item { padding: 8px 14px !important; }
html[data-density="compact"] .news-card { min-height: 280px; }
html[data-density="compact"] .movers-card { min-height: 340px; }
html[data-density="compact"] .scan-card { min-height: 300px; }
html[data-density="compact"] .tool-card { min-height: 420px; }
html[data-density="compact"] .hero { padding: 10px 24px 8px; }
html[data-density="compact"] .hero-line { font-size: 15.5px; }
html[data-density="compact"] .hero-stat { padding: 5px 11px 6px; }
html[data-density="compact"] .bcgrid-wrap { padding: 10px 24px 8px; }
html[data-density="compact"] .bigchart { padding: 8px 12px 6px; }
html[data-density="compact"] .bc-svg { height: 30px; }
html[data-density="compact"] .section { margin-top: 24px; }
html[data-density="compact"] .section-hd { margin-bottom: 14px; }
html[data-density="compact"] .rb-item { padding: 7px 14px; }
html[data-density="compact"] .dash { padding: 18px 24px 24px; }
html[data-density="comfy"] .macro { min-height: 150px; }

@media (max-width: 1400px) {
  .news-row { grid-template-columns: repeat(3, 1fr); }
  .scanners-row { grid-template-columns: repeat(2, 1fr); }
  .macro-row { grid-template-columns: 1fr 2fr; }
  .tools-row { grid-template-columns: 1fr; }
}
@media (max-width: 900px) {
  .news-row { grid-template-columns: repeat(2, 1fr); }
  .macro-row { grid-template-columns: 1fr; }
  .scanners-row, .movers-row { grid-template-columns: 1fr; }
  /* Stack section header rows so "See full view →" doesn't crowd the title */
  .section-hd { grid-template-columns: minmax(0, 1fr); }
  .section-hd .hd-actions {
    grid-column: 1; grid-row: 2;
    padding-top: 2px;
  }
  .section-hd .expl { grid-row: 3; }
}
@media (max-width: 640px) {
  .news-row { grid-template-columns: 1fr; }
  .section-hd h2 { font-size: 22px; }
  .section-hd .expl { max-width: 100%; }
}
`;
const ex3 = document.getElementById("v3-styles");
ex3.textContent = (ex3.textContent || "") + CSS_V3_MOD;
