/* ============================================================
   QQQ COUPLING-ONSET RADAR -- page styles
   DARK NAVY TERMINAL theme, matched to the Pre-Market Structural
   Bias band (assets/structural-bias.css). Sits on top of styles.css
   but overrides to a dark band; scoped under .radar-page.

   Class scheme: BULL / BEAR / WATCH / STABLE (polarity-aware).
   --bull = green, --bear = red, --watch = amber, --stable = blue.
   The legacy COUPLE+/FLIP- mechanic is shown inside cards/tooltips.
   ============================================================ */

.radar-page {
  /* structural-bias token set */
  --sb-cream:#F3F0E8; --sb-navy:#213744; --sb-blue:#95A9AB; --sb-mustard:#DCB482;
  --sb-fdisp:Georgia,"Iowan Old Style","Apple Garamond",serif;
  --sb-fsans:-apple-system,BlinkMacSystemFont,"SF Pro Text","Inter",system-ui,sans-serif;
  --sb-fmono:ui-monospace,"SF Mono",Menlo,Consolas,monospace;

  /* signal palette -- brightened for the dark base */
  --bull:#8FA67E; --bear:#D08E76; --watch:#DCB482; --stable:#95A9AB;

  /* surfaces */
  --line:rgba(243,240,232,0.13);
  --line-soft:rgba(243,240,232,0.08);
  --ink:#0E1A20;

  background:#15262F;
  color:var(--sb-cream);
  font-family:var(--sb-fsans);
  min-height:100vh;
}

.radar-shell {
  max-width: 1300px;
  margin: 0 auto;
  min-height: 100vh;
  background: radial-gradient(125% 80% at 82% 6%, #2A4452 0%, #213744 46%, #15262F 100%);
}

.radar-page code { font-family: var(--sb-fmono); color: var(--sb-mustard); }
.radar-page a { color: var(--sb-mustard); }

/* nav framed to the same 1300px shell as the content below */
.nav { padding-left: 0; padding-right: 0; }
.nav-inner {
  width: 100%; max-width: 1300px; margin: 0 auto;
  padding: 0 22px; box-sizing: border-box;
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; flex-wrap: wrap;
}

/* -- AS-OF banner ------------------------------------------- */
.radar-page .asof-bar {
  display: flex; align-items: center; gap: 14px; flex-wrap: wrap;
  background: var(--ink); color: var(--sb-cream);
  padding: 11px 22px; border-bottom: 1px solid var(--line);
}
.radar-page .asof-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--sb-mustard); flex-shrink: 0;
  animation: asofPulse 2.4s ease-in-out infinite;
}
@keyframes asofPulse {
  0% { box-shadow: 0 0 0 0 rgba(220,180,130,0.6); }
  70% { box-shadow: 0 0 0 7px rgba(220,180,130,0); }
  100% { box-shadow: 0 0 0 0 rgba(220,180,130,0); }
}
.radar-page .asof-txt { font-family: var(--sb-fmono); font-size: 11px; letter-spacing: 0.04em; color: var(--sb-blue); }
.radar-page .asof-txt b { color: var(--sb-mustard); font-weight: 700; }
.radar-page .asof-txt .sep { opacity: 0.4; margin: 0 8px; }
.radar-page .asof-right { margin-left: auto; display: flex; align-items: center; gap: 8px; font-family: var(--sb-fmono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--sb-blue); }

.radar-page .asof-bar.in-sec {
  border: 1px solid var(--line); border-bottom: 1px solid var(--line);
  border-radius: 8px; background: rgba(0,0,0,0.18);
  padding: 9px 14px; margin: 14px 0 18px;
}

/* -- HEADER ------------------------------------------------- */
.radar-page .radar-head { padding: 40px 22px 18px; }
.radar-page a.rh-back {
  display: inline-flex; align-items: center; gap: 7px;
  font-family: var(--sb-fsans); font-size: 12px; font-weight: 600;
  letter-spacing: 0.03em; color: rgba(243,240,232,0.82);
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--line); border-radius: 999px;
  padding: 6px 14px 6px 11px; margin: 0 0 16px;
  white-space: nowrap; transition: color 140ms ease, border-color 140ms ease, background 140ms ease;
}
.radar-page a.rh-back:hover { color: var(--sb-mustard); border-color: var(--sb-mustard); background: rgba(220,180,130,0.08); }
.radar-page .rh-back .arr { font-family: var(--sb-fdisp); font-style: italic; font-weight: 700; font-size: 14px; }
.radar-page .rh-eb {
  font-family: var(--sb-fmono); font-size: 11px; font-weight: 700;
  letter-spacing: 0.22em; text-transform: uppercase; color: var(--sb-mustard);
  margin: 0 0 12px;
}
.radar-page .rh-h {
  font-family: var(--sb-fdisp); font-weight: 700;
  font-size: clamp(30px, 4.4vw, 46px); line-height: 1.04; letter-spacing: -0.01em;
  color: var(--sb-mustard); margin: 0 0 14px; max-width: 22ch; text-wrap: balance;
}
.radar-page .rh-h em { font-style: italic; font-weight: 400; color: var(--sb-mustard); }
.radar-page .rh-lead {
  font-size: 14.5px; line-height: 1.6; color: var(--sb-blue);
  max-width: 72ch; margin: 0;
}
.rh-lead b { color: var(--sb-cream); font-weight: 600; }

/* -- DIRECTION SWITCHER ------------------------------------- */
.radar-page .dir-bar {
  position: sticky; top: 0; z-index: 25;
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  background: rgba(21,38,47,0.86);
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
  padding: 11px 22px; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
}
.radar-page .dir-lab {
  font-family: var(--sb-fmono); font-size: 9.5px; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--sb-blue);
}
.radar-page .dir-seg { display: inline-flex; background: rgba(0,0,0,0.22); border: 1px solid var(--line); border-radius: 9px; padding: 2px; }
.radar-page .dir-btn {
  background: transparent; border: none; font-family: var(--sb-fsans);
  font-size: 11px; font-weight: 600; letter-spacing: 0.02em; color: var(--sb-blue);
  padding: 7px 13px; border-radius: 7px; white-space: nowrap; transition: background 0.14s, color 0.14s;
}
.dir-btn .dn { font-family: var(--sb-fmono); font-weight: 700; margin-right: 6px; opacity: 0.55; }
.dir-btn:hover:not(.on) { color: var(--sb-cream); }
.dir-btn.on { background: var(--sb-mustard); color: var(--ink); }
.dir-btn.on .dn { opacity: 1; color: var(--ink); }
.radar-page .dir-spacer { flex: 1; }
.radar-page .dir-hint { font-family: var(--sb-fmono); font-size: 10px; color: var(--sb-blue); }

/* -- CONTROL RAIL (tweaks) ---------------------------------- */
.radar-page .ctl-rail {
  display: flex; align-items: center; gap: 18px 22px; flex-wrap: wrap;
  padding: 16px 22px; border-bottom: 1px solid var(--line);
  background: rgba(0,0,0,0.14);
}
.radar-page .ctl-grp { display: flex; align-items: center; gap: 9px; }
.radar-page .ctl-lab {
  font-family: var(--sb-fmono); font-size: 9.5px; font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--sb-blue); white-space: nowrap;
}
.radar-page .seg { display: inline-flex; background: rgba(0,0,0,0.22); border: 1px solid var(--line); border-radius: 9px; padding: 2px; }
.seg button {
  background: transparent; border: none; font-family: var(--sb-fmono);
  font-size: 11px; font-weight: 700; color: var(--sb-blue);
  padding: 6px 12px; border-radius: 7px; transition: background 0.13s, color 0.13s;
}
.seg button.on { background: var(--sb-mustard); color: var(--ink); }
.seg button:hover:not(.on) { color: var(--sb-cream); }

/* threshold slider */
.thr-wrap { display: flex; align-items: center; gap: 11px; }
.thr-slider { -webkit-appearance: none; appearance: none; width: 132px; height: 4px; border-radius: 2px; background: rgba(243,240,232,0.16); outline: none; }
.thr-slider::-webkit-slider-thumb { -webkit-appearance: none; appearance: none; width: 16px; height: 16px; border-radius: 50%; background: var(--sb-mustard); border: 2px solid var(--ink); box-shadow: 0 0 0 1px var(--sb-mustard), 0 0 14px rgba(220,180,130,0.4); cursor: grab; }
.thr-slider::-moz-range-thumb { width: 16px; height: 16px; border-radius: 50%; background: var(--sb-mustard); border: 2px solid var(--ink); box-shadow: 0 0 0 1px var(--sb-mustard); cursor: grab; }
.thr-val { font-family: var(--sb-fmono); font-size: 13px; font-weight: 700; color: var(--sb-cream); min-width: 38px; }

/* category select */
.radar-page .cat-select {
  font-family: var(--sb-fsans); font-size: 12px; font-weight: 600; color: var(--sb-cream);
  background: rgba(0,0,0,0.22); border: 1px solid var(--line); border-radius: 9px;
  padding: 7px 28px 7px 11px; cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%2395A9AB' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 10px center;
  -webkit-appearance: none; appearance: none;
}
.cat-select option { background: var(--sb-navy); color: var(--sb-cream); }

/* signal-type pills */
.radar-page .sig-pills { display: inline-flex; gap: 6px; flex-wrap: wrap; }
.radar-page .sig-pill {
  display: inline-flex; align-items: center; gap: 7px;
  background: rgba(0,0,0,0.2); border: 1px solid var(--line); border-radius: 999px;
  padding: 6px 12px; font-family: var(--sb-fsans); font-size: 11px; font-weight: 600; color: var(--sb-blue);
  transition: background 0.13s, color 0.13s, border-color 0.13s, box-shadow 0.13s;
}
.sig-pill .dot { width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; }
.sig-pill .pn { font-family: var(--sb-fmono); font-weight: 700; font-size: 10.5px; color: var(--sb-blue); background: rgba(0,0,0,0.28); border-radius: 999px; padding: 1px 6px; min-width: 16px; text-align: center; }
.sig-pill.off { opacity: 0.4; }
.sig-pill.bull.on  { background: color-mix(in srgb, var(--bull) 20%, transparent);  border-color: var(--bull);  color: #fff; box-shadow: 0 0 16px color-mix(in srgb, var(--bull) 28%, transparent); }
.sig-pill.bear.on  { background: color-mix(in srgb, var(--bear) 20%, transparent);  border-color: var(--bear);  color: #fff; box-shadow: 0 0 16px color-mix(in srgb, var(--bear) 28%, transparent); }
.sig-pill.watch.on { background: color-mix(in srgb, var(--watch) 20%, transparent); border-color: var(--watch); color: #fff; box-shadow: 0 0 16px color-mix(in srgb, var(--watch) 28%, transparent); }
.sig-pill.on .pn { background: rgba(255,255,255,0.16); color: #fff; }

/* -- SUMMARY STRIP ------------------------------------------ */
.radar-page .sum-strip { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line); border-bottom: 1px solid var(--line); }
.radar-page .sum-cell { background: #1B303B; padding: 17px 20px; }
.radar-page .sum-cell.regime { background: linear-gradient(150deg, #2A4452, #1A2E38); }
.radar-page .sum-cell.regime.fragility { background: linear-gradient(150deg, #4A2E26, #2E1A1A); }
.radar-page .sum-cell.regime.fragility .sum-l { color: var(--bear); }
.radar-page .sum-cell.regime.fragility .sum-v { color: var(--bear); }
.radar-page .sum-l { font-family: var(--sb-fmono); font-size: 9px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--sb-blue); margin-bottom: 8px; }
.radar-page .sum-cell.regime .sum-l { color: var(--sb-mustard); }
.radar-page .sum-v { font-family: var(--sb-fdisp); font-weight: 700; font-size: 30px; line-height: 1; letter-spacing: -0.01em; color: var(--sb-cream); font-variant-numeric: tabular-nums; }
.radar-page .sum-cell.regime .sum-v { color: #fff; font-size: 23px; }
.radar-page .sum-v .u { font-size: 13px; color: var(--sb-blue); font-weight: 600; margin-left: 4px; font-family: var(--sb-fsans); }
.radar-page .sum-v.bull { color: var(--bull); }
.radar-page .sum-v.bear { color: var(--bear); }
.radar-page .sum-s { font-family: var(--sb-fmono); font-size: 10px; color: var(--sb-blue); margin-top: 7px; line-height: 1.45; }
.radar-page .sum-cell.regime .sum-s b { color: var(--sb-mustard); }

/* -- SECTION HEADERS ---------------------------------------- */
.radar-page .sec { padding: 28px 22px; }
.radar-page .sec-eb { font-family: var(--sb-fmono); font-size: 10px; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sb-mustard); margin: 0 0 7px; }
.radar-page .sec-h { font-family: var(--sb-fdisp); font-weight: 700; font-size: 24px; letter-spacing: -0.01em; color: var(--sb-cream); margin: 0 0 5px; }
.radar-page .sec-h .ct { font-family: var(--sb-fmono); font-size: 13px; font-weight: 700; color: var(--sb-blue); margin-left: 8px; }
.radar-page .sec-d { font-size: 13px; color: var(--sb-blue); margin: 0; max-width: 72ch; line-height: 1.6; }
.radar-page .sec-d b { color: var(--sb-cream); font-weight: 600; }

/* -- RADAR PLOT --------------------------------------------- */
.radar-page .radar-stage { position: relative; max-width: 760px; margin: 8px auto 0; }
.radar-page .radar-svg { width: 100%; height: auto; display: block; overflow: visible; }
.rr-ring { fill: none; stroke: rgba(243,240,232,0.10); stroke-width: 1; }
.rr-ring.zero { stroke: rgba(220,180,130,0.4); stroke-width: 1.1; stroke-dasharray: 4 4; }
.rr-ring-lab { font-family: var(--sb-fmono); font-size: 9px; fill: var(--sb-blue); }
.rr-spoke { stroke: rgba(243,240,232,0.06); stroke-width: 0.7; }
.rr-tk { font-family: var(--sb-fsans); font-size: 11px; font-weight: 700; fill: var(--sb-cream); cursor: pointer; }
.rr-tk.dim { opacity: 0.22; }
.rr-arc { fill: none; stroke-width: 2.2; opacity: 0.4; }
.rr-sec { font-family: var(--sb-fdisp); font-weight: 700; font-size: 12.5px; fill: var(--sb-blue); }
.rr-core { fill: #0E1A20; stroke: var(--sb-mustard); stroke-width: 2.5; filter: drop-shadow(0 0 18px rgba(220,180,130,0.35)); }
.rr-core-t { font-family: var(--sb-fdisp); font-weight: 800; font-size: 26px; fill: var(--sb-cream); letter-spacing: 0.01em; }
.rr-core-s { font-family: var(--sb-fmono); font-size: 8px; letter-spacing: 0.2em; fill: var(--sb-mustard); }
.rr-drift { stroke-linecap: round; transition: opacity 0.6s ease; }
.rr-ago { transition: opacity 0.6s ease; }
.rr-now { cursor: pointer; transition: opacity 0.5s ease, transform 0.45s cubic-bezier(.34,1.56,.64,1); transform-box: fill-box; transform-origin: center; }
.rr-now { stroke: var(--ink) !important; }
.rr-now:hover { stroke-width: 3; }
.rr-halo { fill: none; stroke-width: 1.6; transform-box: fill-box; transform-origin: center; animation: rrHalo 2s ease-in-out infinite; }
@keyframes rrHalo { 0% { opacity: 0.6; transform: scale(0.85);} 70%{opacity:0; transform: scale(2.1);} 100%{opacity:0; transform: scale(2.1);} }

.radar-page .radar-tip {
  position: absolute; pointer-events: none; z-index: 6;
  background: #0E1A20; color: var(--sb-cream); border: 1px solid var(--line); border-radius: 12px;
  padding: 11px 13px; width: 224px; box-shadow: 0 14px 40px rgba(0,0,0,0.5);
  transform: translate(-50%, calc(-100% - 16px));
}
.rt-tk { font-family: var(--sb-fdisp); font-weight: 800; font-size: 16px; color: #fff; }
.rt-nm { font-size: 10px; color: var(--sb-blue); font-style: italic; margin: 1px 0 8px; }
.rt-row { display: flex; align-items: center; gap: 8px; font-family: var(--sb-fmono); font-size: 11px; padding: 2px 0; }
.rt-row .lab { color: var(--sb-blue); }
.rt-row .val { font-weight: 700; margin-left: auto; color: var(--sb-cream); }
.rt-tag { margin-top: 8px; padding-top: 8px; border-top: 1px solid var(--line); font-family: var(--sb-fmono); font-size: 9.5px; letter-spacing: 0.1em; text-transform: uppercase; font-weight: 700; }
.rt-tag.bull { color: var(--bull); }
.rt-tag.bear { color: var(--bear); }
.rt-tag.watch { color: var(--watch); }
.rt-tag.stable { color: var(--stable); }

.radar-page .radar-legend { display: flex; flex-wrap: wrap; gap: 14px 30px; justify-content: center; margin: 22px auto 0; max-width: 760px; padding-top: 18px; border-top: 1px dashed var(--line); }
.rleg-g { display: flex; flex-direction: column; gap: 8px; }
.rleg-t { font-family: var(--sb-fmono); font-size: 9.5px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--sb-blue); }
.rleg-row { display: flex; align-items: center; gap: 8px; font-size: 11.5px; color: var(--sb-cream); }
.rleg-row .sw { width: 12px; height: 12px; border-radius: 50%; flex-shrink: 0; box-shadow: 0 0 10px currentColor; }
.rleg-drift { display: inline-flex; align-items: center; gap: 6px; }
.rleg-bar { display: block; width: 130px; height: 12px; border-radius: 3px; background: linear-gradient(90deg, #1B303B, var(--sb-blue) 55%, var(--sb-cream)); }
.rleg-scale-labs { display: flex; justify-content: space-between; font-family: var(--sb-fmono); font-size: 9px; color: var(--sb-blue); margin-top: 3px; }
.rad-replay { font-family: var(--sb-fsans); font-size: 12px; font-weight: 600; color: var(--sb-cream); background: rgba(0,0,0,0.2); border: 1px solid var(--line); border-radius: 8px; padding: 7px 13px; cursor: pointer; transition: border-color 0.14s; }
.rad-replay:hover { border-color: var(--sb-blue); }

/* -- ALERT CARDS -- glow tiles ------------------------------ */
.radar-page .cards-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(330px, 1fr)); gap: 12px; }
.cards-grid.cols-2 { grid-template-columns: repeat(auto-fill, minmax(420px, 1fr)); }
.radar-page .acard {
  --vc: var(--stable);
  background: color-mix(in srgb, var(--vc) 9%, #1A2E38);
  border: 1px solid color-mix(in srgb, var(--vc) 32%, transparent);
  border-radius: 14px; padding: 0; overflow: hidden; display: flex; flex-direction: column;
  box-shadow: 0 0 24px color-mix(in srgb, var(--vc) 12%, transparent);
  transition: box-shadow 0.18s ease, transform 0.18s ease;
}
.acard.bull  { --vc: var(--bull); }
.acard.bear  { --vc: var(--bear); }
.acard.watch { --vc: var(--watch); }
.acard:hover { transform: translateY(-2px); box-shadow: 0 0 34px color-mix(in srgb, var(--vc) 24%, transparent); }
.acard-top { display: flex; align-items: stretch; gap: 0; border-left: 3px solid var(--vc); }
.acard-id { padding: 14px 16px; flex: 1; min-width: 0; }
.acard-sym { font-family: var(--sb-fdisp); font-weight: 800; font-size: 20px; letter-spacing: -0.01em; color: #fff; line-height: 1; }
.acard-nm { font-size: 11px; color: var(--sb-blue); margin-top: 4px; line-height: 1.3; }
.acard-cat { display: inline-block; margin-top: 8px; font-family: var(--sb-fmono); font-size: 9px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--sb-blue); background: rgba(0,0,0,0.24); border-radius: 999px; padding: 3px 9px; }
.acard-pol { display: inline-block; margin: 8px 0 0 6px; font-family: var(--sb-fmono); font-size: 9px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; border-radius: 999px; padding: 3px 9px; }
.acard-pol.pol-pro             { background: color-mix(in srgb, var(--bull) 14%, transparent); color: var(--bull); }
.acard-pol.pol-counter         { background: color-mix(in srgb, var(--bear) 14%, transparent); color: var(--bear); }
.acard-pol.pol-haven           { background: color-mix(in srgb, var(--watch) 14%, transparent); color: var(--watch); }
.acard-pol.pol-cyclical_commod { background: color-mix(in srgb, var(--bull) 10%, transparent); color: #B8CDA0; opacity: 0.9; }
.acard-pol.pol-mixed           { background: rgba(149,169,171,0.14); color: var(--sb-blue); }
.acard-badge { padding: 14px 16px; display: flex; flex-direction: column; align-items: flex-end; justify-content: center; min-width: 126px; gap: 4px; }
.sig-tag { font-family: var(--sb-fmono); font-size: 11px; font-weight: 700; letter-spacing: 0.08em; padding: 5px 10px; border-radius: 7px; white-space: nowrap; background: color-mix(in srgb, var(--vc) 22%, transparent); color: var(--vc); border: 1px solid color-mix(in srgb, var(--vc) 45%, transparent); }
.acard-onset { font-family: var(--sb-fmono); font-size: 11px; font-weight: 700; color: var(--sb-cream); }
.acard-onset .o-l { color: var(--sb-blue); font-weight: 600; }
.acard-mech { font-family: var(--sb-fmono); font-size: 9px; font-weight: 700; letter-spacing: 0.1em; color: var(--sb-blue); opacity: 0.72; }

.acard-body { padding: 14px 16px; border-top: 1px solid var(--line-soft); display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.beta-block .bb-l, .spark-block .bb-l { font-family: var(--sb-fmono); font-size: 9px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--sb-blue); margin-bottom: 7px; }
.bb-flow { display: flex; align-items: baseline; gap: 7px; }
.bb-then { font-family: var(--sb-fmono); font-size: 15px; font-weight: 700; color: var(--sb-blue); font-variant-numeric: tabular-nums; }
.bb-arrow { color: var(--sb-mustard); font-weight: 700; font-size: 13px; }
.bb-now { font-family: var(--sb-fdisp); font-size: 24px; font-weight: 700; color: #fff; letter-spacing: -0.02em; font-variant-numeric: tabular-nums; line-height: 1; }

.spark-block .bb-l { display: flex; justify-content: space-between; }
.spark-svg { width: 100%; height: 38px; display: block; overflow: visible; }
.spark-path { fill: none; stroke-width: 2; stroke-linejoin: round; stroke-linecap: round; shape-rendering: geometricPrecision; }
.spark-area { stroke: none; }
.spark-zero { stroke: rgba(243,240,232,0.16); stroke-width: 1; stroke-dasharray: 3 3; }
.spark-dot { stroke: var(--ink); stroke-width: 1.5; }

.acard-move { padding: 12px 16px; border-top: 1px solid var(--line-soft); display: flex; align-items: center; gap: 12px; }
.move-pair { display: flex; align-items: baseline; gap: 14px; flex: 1; }
.move-item .mi-l { font-family: var(--sb-fmono); font-size: 8.5px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--sb-blue); }
.move-item .mi-v { font-family: var(--sb-fmono); font-size: 14px; font-weight: 700; font-variant-numeric: tabular-nums; }
.mi-v.pos { color: var(--bull); }
.mi-v.neg { color: var(--bear); }
.agree-badge { font-family: var(--sb-fmono); font-size: 9.5px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; padding: 4px 9px; border-radius: 999px; white-space: nowrap; }
.agree-badge.agree { background: color-mix(in srgb, var(--bull) 18%, transparent); color: var(--bull); }
.agree-badge.diverge { background: color-mix(in srgb, var(--bear) 18%, transparent); color: var(--bear); }

/* enrichment / news panel */
.enrich-toggle {
  width: 100%; text-align: left; background: rgba(0,0,0,0.18); border: none; border-top: 1px solid var(--line-soft);
  padding: 11px 16px; font-family: var(--sb-fsans); font-size: 11.5px; font-weight: 600; color: var(--sb-mustard);
  display: flex; align-items: center; gap: 8px; cursor: pointer; transition: background 0.15s;
}
.enrich-toggle:hover { background: rgba(0,0,0,0.3); }
.enrich-toggle .et-ar { color: var(--sb-mustard); font-weight: 700; transition: transform 0.2s; }
.enrich-toggle.open .et-ar { transform: rotate(90deg); }
.enrich-toggle .et-n { margin-left: auto; font-family: var(--sb-fmono); font-size: 9.5px; color: var(--sb-blue); }
.enrich-body { padding: 14px 16px 16px; border-top: 1px solid var(--line-soft); background: rgba(0,0,0,0.16); animation: enrichIn 0.22s ease; }
@keyframes enrichIn { from { opacity: 0; } to { opacity: 1; } }
.enrich-hl { display: flex; flex-direction: column; gap: 8px; margin-bottom: 12px; }
.enrich-link { display: block; padding: 9px 11px; background: rgba(0,0,0,0.2); border: 1px solid var(--line); border-radius: 8px; transition: border-color 0.14s, background 0.14s; }
.enrich-link:hover { border-color: var(--sb-mustard); background: rgba(0,0,0,0.32); }
.el-title { font-size: 12px; font-weight: 600; color: var(--sb-cream); line-height: 1.4; }
.el-meta { font-family: var(--sb-fmono); font-size: 9.5px; color: var(--sb-blue); margin-top: 4px; }
.el-meta .src { color: var(--sb-mustard); font-weight: 700; }
.enrich-read { font-family: var(--sb-fmono); font-size: 9px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--sb-mustard); margin-bottom: 7px; }
.enrich-interp { font-size: 12.5px; line-height: 1.62; color: #C7D2D6; white-space: pre-line; }
.enrich-interp b { color: var(--sb-cream); font-weight: 600; }

/* -- UNIVERSE TABLE ----------------------------------------- */
.uni-wrap { border: 1px solid var(--line); border-radius: 14px; overflow: hidden; background: rgba(0,0,0,0.14); }
.uni-tools { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; padding: 12px 14px; border-bottom: 1px solid var(--line); background: rgba(0,0,0,0.2); }
.uni-search { flex: 1; min-width: 160px; font-family: var(--sb-fmono); font-size: 12px; color: var(--sb-cream); background: rgba(0,0,0,0.26); border: 1px solid var(--line); border-radius: 8px; padding: 8px 11px; }
.uni-search::placeholder { color: var(--sb-blue); }
.uni-count { font-family: var(--sb-fmono); font-size: 10px; color: var(--sb-blue); letter-spacing: 0.06em; }
.uni-scroll { overflow-x: auto; max-height: 620px; overflow-y: auto; }
table.uni { width: 100%; border-collapse: collapse; font-family: var(--sb-fmono); font-size: 12px; }
table.uni thead th {
  position: sticky; top: 0; z-index: 2; background: #0E1A20; color: var(--sb-cream);
  font-family: var(--sb-fsans); font-size: 9.5px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase;
  padding: 11px 12px; text-align: right; white-space: nowrap; cursor: pointer; user-select: none;
}
table.uni thead th:first-child, table.uni thead th.l { text-align: left; }
table.uni thead th .sort-ar { color: var(--sb-mustard); margin-left: 4px; }
table.uni tbody td { padding: 9px 12px; text-align: right; border-bottom: 1px solid var(--line-soft); white-space: nowrap; font-variant-numeric: tabular-nums; color: var(--sb-cream); }
table.uni tbody td.l { text-align: left; }
table.uni tbody tr:hover { background: rgba(255,255,255,0.04); }
table.uni tbody tr.bull { background: color-mix(in srgb, var(--bull) 9%, transparent); }
table.uni tbody tr.bear { background: color-mix(in srgb, var(--bear) 9%, transparent); }
table.uni tbody tr.bull:hover, table.uni tbody tr.bear:hover { background: rgba(255,255,255,0.05); }
.u-sym { font-family: var(--sb-fdisp); font-weight: 700; font-size: 13px; color: #fff; }
.u-nm { color: var(--sb-blue); font-family: var(--sb-fsans); font-size: 11px; }
.u-cat { color: var(--sb-blue); font-family: var(--sb-fsans); font-size: 10.5px; }
.u-pol { font-family: var(--sb-fmono); font-size: 9.5px; font-weight: 700; letter-spacing: 0.06em; padding: 2px 7px; border-radius: 6px; }
.u-pol.pol-pro             { background: color-mix(in srgb, var(--bull) 14%, transparent); color: var(--bull); }
.u-pol.pol-counter         { background: color-mix(in srgb, var(--bear) 14%, transparent); color: var(--bear); }
.u-pol.pol-haven           { background: color-mix(in srgb, var(--watch) 14%, transparent); color: var(--watch); }
.u-pol.pol-cyclical_commod { background: color-mix(in srgb, var(--bull) 10%, transparent); color: #B8CDA0; }
.u-pol.pol-mixed           { background: rgba(149,169,171,0.14); color: var(--sb-blue); }
.u-sig { font-family: var(--sb-fsans); font-weight: 700; font-size: 10px; letter-spacing: 0.06em; padding: 2px 7px; border-radius: 6px; }
.u-sig.bull   { background: color-mix(in srgb, var(--bull) 22%, transparent);   color: var(--bull); }
.u-sig.bear   { background: color-mix(in srgb, var(--bear) 22%, transparent);   color: var(--bear); }
.u-sig.watch  { background: color-mix(in srgb, var(--watch) 22%, transparent);  color: var(--watch); }
.u-sig.stable { background: transparent; color: var(--sb-blue); }
.u-pos { color: var(--bull); } .u-neg { color: var(--bear); }
.u-spark { width: 70px; height: 22px; display: inline-block; vertical-align: middle; }
.u-news { color: var(--sb-mustard); }

/* -- EMPTY STATE -------------------------------------------- */
.radar-page .empty {
  text-align: center; padding: 56px 24px; border: 1px dashed var(--sb-blue);
  border-radius: 14px; background: rgba(0,0,0,0.16); margin: 0 22px;
}
.empty-mark { width: 52px; height: 52px; margin: 0 auto 16px; border-radius: 50%; border: 2px solid var(--bull); display: flex; align-items: center; justify-content: center; color: var(--bull); box-shadow: 0 0 24px color-mix(in srgb, var(--bull) 30%, transparent); }
.empty-h { font-family: var(--sb-fdisp); font-weight: 700; font-size: 21px; color: var(--sb-cream); margin: 0 0 8px; }
.empty-d { font-size: 13px; color: var(--sb-blue); max-width: 48ch; margin: 0 auto; line-height: 1.6; }

/* -- METHOD / FOOTER NOTE ----------------------------------- */
.radar-page .method { padding: 24px 22px 48px; }
.radar-page .method-card { background: rgba(0,0,0,0.2); border: 1px solid var(--line); border-radius: 16px; padding: 24px 24px; }
.radar-page .method-eb { font-family: var(--sb-fmono); font-size: 9.5px; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sb-mustard); margin: 0 0 12px; }
.radar-page .method-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 20px; }
.radar-page .method-item h4 { font-family: var(--sb-fdisp); font-weight: 700; font-size: 14.5px; margin: 0 0 5px; color: var(--sb-cream); }
.radar-page .method-item p { font-size: 12px; line-height: 1.6; color: var(--sb-blue); margin: 0; }
.radar-page .method-item p b { color: var(--sb-mustard); font-weight: 600; }
.radar-page .method-item p i { color: var(--sb-cream); font-style: italic; }
.radar-page .method-foot { font-family: var(--sb-fmono); font-size: 10px; color: var(--sb-blue); margin: 18px 0 0; padding-top: 15px; border-top: 1px solid var(--line); line-height: 1.5; }

/* -- LAYOUT DIRECTIONS -------------------------------------- */
.dir-b-grid { display: grid; grid-template-columns: minmax(440px, 1.1fr) minmax(360px, 1fr); align-items: start; }
.dir-b-grid .dir-b-left { position: sticky; top: 56px; align-self: start; border-right: 1px solid var(--line); }
.dir-b-grid .dir-b-right { min-width: 0; }
.dir-b-grid .dir-b-right .cards-grid { grid-template-columns: 1fr; }
.dir-b-grid .sec { padding-top: 20px; }

/* -- RESPONSIVE --------------------------------------------- */
@media (max-width: 1080px) {
  .dir-b-grid { grid-template-columns: 1fr; }
  .dir-b-grid .dir-b-left {
    position: static; border-right: none; border-bottom: 1px solid var(--line);
  }
}
@media (max-width: 900px) {
  .sum-strip { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
  .radar-head { padding: 28px 16px 14px; }
  .sec, .ctl-rail, .dir-bar, .asof-bar, .method { padding-left: 16px; padding-right: 16px; }
  .sum-strip { grid-template-columns: 1fr 1fr; }
  .sum-v { font-size: 24px; }
  .cards-grid, .cards-grid.cols-2 { grid-template-columns: 1fr; }
  .ctl-rail { gap: 14px 16px; }
  .empty { margin: 0 16px; }
  .acard-body { grid-template-columns: 1fr; }
  table.uni { font-size: 11px; }
  .u-news-col, .u-cat-col, .u-pol-col { display: none; }
}
