/* ───────────────── Hesper Atlas · design system ─────────────────
   A map for the AI age. Cool night-sky ink (dark) and neutral bone
   (light), unified by one luminous gold accent (Hesperus, the evening
   star) with a restrained teal counterpoint (the atlas / star chart).
   Rule: gold is a LIGHT colour. Gold FILLS carry dark ink (--ink-on-gold),
   never white. --brand = legible gold for text/links/icons; --brand-fill
   = bright gold for solid button/pill fills. */
:root{
  --bg:#0e1116;
  --bg-2:#11151b;
  --panel:#161a21;
  --panel-2:#1d222b;
  --line:rgba(176,194,224,.085);
  --line-2:rgba(176,194,224,.16);
  --text:#e8eaef;
  --muted:#9aa3b2;
  --dim:#646e7e;
  --buy:#3fcb8e;
  --buy-dim:rgba(63,203,142,.13);
  --sell:#f2655f;
  --sell-dim:rgba(242,101,95,.13);
  --hold:#e08a3b;
  --hold-dim:rgba(224,138,59,.13);
  --brand:#eba63a;
  --brand-fill:#eba63a;
  --brand-2:#5ab6ad;
  --ink-on-gold:#0e1116;
  /* shaded gold button: top-lit gradient, white inset highlight, soft light rim.
     Defined once so every gold button reads dimensional, never flat. */
  --gold-grad:linear-gradient(180deg, color-mix(in srgb,var(--brand-fill) 78%,#fff), var(--brand-fill) 52%, color-mix(in srgb,var(--brand-fill) 90%,#000));
  --gold-edge:rgba(255,255,255,.34);
  --gold-hi:inset 0 1px 0 rgba(255,255,255,.55), inset 0 -1px 1px rgba(0,0,0,.14);
  --ring:color-mix(in srgb,var(--brand) 40%,transparent);
  /* text inks for tinted info panels — themed so light mode stays readable */
  --ink-soft:#c8cdd6;   /* body text on brand-tinted panels & docs */
  --warn-ink:#e7d2ad;   /* body text on amber warning panels */
  --font-display:'Newsreader',Georgia,'Times New Roman',serif;
  --radius:11px;
  --shadow:0 24px 64px -30px rgba(0,0,0,.66);
  --elev:none;
  --elev-hover:none;
  font-synthesis:none;
}

body.light{
  --bg:#f7f6f3;
  --bg-2:#f1efe9;
  --panel:#ffffff;
  --panel-2:#f1efe9;
  --line:rgba(28,32,40,.085);
  --line-2:rgba(28,32,40,.15);
  --text:#1f2329;
  --muted:#6b7280;
  --dim:#9aa1ab;
  --buy:#0a7d52;
  --buy-dim:rgba(10,125,82,.10);
  --sell:#c63a2f;
  --sell-dim:rgba(198,58,47,.10);
  --hold:#a85c12;
  --hold-dim:rgba(168,92,18,.11);
  --brand:#965b0e;
  --brand-fill:#cf9836;
  --brand-2:#1d736a;
  --ink-on-gold:#1f2329;
  --ring:color-mix(in srgb,var(--brand) 30%,transparent);
  --ink-soft:#4f5560;
  --warn-ink:#6e4a0e;
  --shadow:0 18px 46px -22px rgba(20,28,45,.22);
  --elev:0 1px 2px rgba(20,28,45,.05), 0 10px 24px -14px rgba(20,28,45,.16);
  --elev-hover:0 2px 4px rgba(20,28,45,.07), 0 18px 34px -16px rgba(20,28,45,.22);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  background:var(--bg);
  color:var(--text);
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  font-size:15px;line-height:1.55;letter-spacing:-.011em;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
.mono{font-family:'JetBrains Mono',monospace;font-variant-numeric:tabular-nums}
/* tabular, slashed-zero figures — the mark of a serious data UI, not a generic dashboard */
.tcard .px,.stat .v,.stock-px .p,.stock-px .c,.reco-stats .v,.metric .v,.gauge-val b,
.cpill .v,.alloc-d,.cap-input input,.fund-metrics .fm .v,.val-grid .vt .v,.opp-num,
.wtable td.r,.score-cap,.bw .g{font-variant-numeric:tabular-nums slashed-zero}

/* small craft details that separate "designed" from "generated" */
::selection{background:color-mix(in srgb,var(--brand) 26%,transparent)}
:focus-visible{outline:2px solid var(--brand);outline-offset:2px}
*{scrollbar-width:thin;scrollbar-color:var(--line-2) transparent}
::-webkit-scrollbar{width:11px;height:11px}
::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:10px;border:3px solid transparent;background-clip:padding-box}
::-webkit-scrollbar-thumb:hover{background:var(--dim);background-clip:padding-box}
::-webkit-scrollbar-track{background:transparent}

/* ── celestial backdrop ──────────────────────────────────────────
   Cool night-sky ink with one gold dusk glow (Hesperus, top-right) and
   a cool milky wash (bottom-left) on opposing corners so warm and cool
   balance instead of muddying. Star sheets ride the pseudo-elements;
   all motion is transform/opacity only, so it stays on the compositor. */
#bg-glow{
  position:fixed;inset:0;z-index:-2;pointer-events:none;
  --constellation:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='1100' height='760'%3E%3Cg stroke='%23aebbe6' stroke-width='.6' fill='none' opacity='.28'%3E%3Cpolyline points='150,130 240,170 280,110 360,150 330,230'/%3E%3Cpolyline points='760,520 820,480 880,530 850,600 920,570'/%3E%3C/g%3E%3Cg fill='%23cdd6f2' opacity='.55'%3E%3Ccircle cx='150' cy='130' r='1.1'/%3E%3Ccircle cx='240' cy='170' r='1.1'/%3E%3Ccircle cx='280' cy='110' r='1.1'/%3E%3Ccircle cx='360' cy='150' r='1.1'/%3E%3Ccircle cx='330' cy='230' r='1.1'/%3E%3Ccircle cx='760' cy='520' r='1.1'/%3E%3Ccircle cx='820' cy='480' r='1.1'/%3E%3Ccircle cx='880' cy='530' r='1.1'/%3E%3Ccircle cx='850' cy='600' r='1.1'/%3E%3Ccircle cx='920' cy='570' r='1.1'/%3E%3C/g%3E%3C/svg%3E");
  background:
    radial-gradient(620px 460px at 78% 6%, color-mix(in srgb,var(--brand) 4%,transparent), transparent 60%),
    radial-gradient(1200px 700px at 12% 108%, color-mix(in srgb,#5b73be 7%,transparent), transparent 64%),
    linear-gradient(180deg,#0c0e14 0%,#0d1018 54%,#0f1320 100%);
}
/* star sheets + a folded-in constellation, drifting as one slow plane */
#bg-glow::after{
  content:'';position:absolute;inset:-8% -8%;background-repeat:repeat;
  background-image:
    var(--constellation),
    radial-gradient(1.4px 1.4px at 40px 60px,  rgba(232,238,255,.95), transparent 60%),
    radial-gradient(1.2px 1.2px at 160px 120px,rgba(214,224,255,.80), transparent 60%),
    radial-gradient(1.3px 1.3px at 300px 40px, color-mix(in srgb,var(--brand) 72%,#fff), transparent 60%),
    radial-gradient(1.1px 1.1px at 230px 200px,rgba(226,232,255,.70), transparent 60%),
    radial-gradient(1px 1px at 80px 30px,  rgba(208,219,255,.62), transparent 55%),
    radial-gradient(1px 1px at 190px 90px, rgba(198,210,250,.52), transparent 55%),
    radial-gradient(1px 1px at 20px 150px, rgba(214,224,255,.58), transparent 55%),
    radial-gradient(1px 1px at 130px 170px,color-mix(in srgb,var(--brand) 55%,#fff), transparent 55%),
    radial-gradient(.8px .8px at 50px 50px,  rgba(190,202,240,.40), transparent 50%),
    radial-gradient(.8px .8px at 110px 20px, rgba(180,194,236,.36), transparent 50%),
    radial-gradient(.8px .8px at 10px 90px,  rgba(196,208,244,.38), transparent 50%),
    radial-gradient(.8px .8px at 90px 130px, rgba(186,200,240,.34), transparent 50%);
  background-size:
    900px 600px,
    360px 260px,360px 260px,360px 260px,360px 260px,
    220px 200px,220px 200px,220px 200px,220px 200px,
    140px 160px,140px 160px,140px 160px,140px 160px;
  opacity:.85;animation:atlas-drift 220s linear infinite;will-change:transform;
}
/* a lighter sheet that breathes — the faint twinkle */
#bg-glow::before{
  content:'';position:absolute;inset:-8% -8%;pointer-events:none;background-repeat:repeat;
  background-image:
    radial-gradient(1.3px 1.3px at 70px 40px,  color-mix(in srgb,var(--brand) 60%,#fff), transparent 55%),
    radial-gradient(1.2px 1.2px at 250px 150px,rgba(236,240,255,.9), transparent 55%),
    radial-gradient(1.1px 1.1px at 150px 90px, rgba(220,228,255,.8), transparent 55%);
  background-size:420px 320px,420px 320px,420px 320px;
  opacity:.5;animation:atlas-twinkle 9s ease-in-out infinite;will-change:opacity;
}
@keyframes atlas-drift{from{transform:translate3d(0,0,0)}to{transform:translate3d(0,-260px,0)}}
@keyframes atlas-twinkle{0%,100%{opacity:.32}50%{opacity:.58}}
/* fine film grain — kills the flat, plasticky look that reads as machine-made */
body::before{
  content:'';position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
/* light = paper: retire the night sky, keep only a whisper of the
   celestial motif so white dots never read as dust on ivory */
body.light #bg-glow{
  background:
    radial-gradient(700px 520px at 80% 4%, color-mix(in srgb,var(--brand) 3%,transparent), transparent 62%),
    radial-gradient(1100px 640px at 8% 106%, color-mix(in srgb,#5b73be 4%,transparent), transparent 66%),
    linear-gradient(180deg,#fcfcfb 0%,#f7f7f4 50%,#f0f1ee 100%);
}
body.light #bg-glow::after{
  opacity:.05;mix-blend-mode:multiply;animation:none;
  background-image:
    radial-gradient(1px 1px at 60px 80px,  rgba(70,82,120,.9), transparent 55%),
    radial-gradient(1px 1px at 240px 160px,rgba(70,82,120,.7), transparent 55%),
    radial-gradient(.9px .9px at 150px 40px,rgba(70,82,120,.7), transparent 55%);
  background-size:380px 300px,380px 300px,380px 300px;
}
body.light #bg-glow::before{display:none}
@media (prefers-reduced-motion:reduce){
  #bg-glow::after{animation:none}
  #bg-glow::before{animation:none;opacity:.42}
}
body.light::before{opacity:.03;mix-blend-mode:multiply}
body.light .topbar{background:rgba(247,246,243,.82)}

/* ───────────── top bar ───────────── */
.topbar{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;gap:22px;
  padding:13px clamp(16px,4vw,40px);
  background:rgba(13,16,22,.66);
  backdrop-filter:blur(20px) saturate(1.4);
  -webkit-backdrop-filter:blur(20px) saturate(1.4);
  border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:9px;font-weight:700;font-size:17.5px}
.brand-mark{
  display:inline-flex;align-items:center;justify-content:center;
  width:26px;height:26px;color:var(--brand);
}
.brand-mark svg{width:22px;height:22px}
/* compass-rose mark: a faceted gold star-rose (lit right, shadowed left)
   with a knocked-out pivot. Facets adapt to the theme via the page ground. */
.brand-mark .bm-sh{fill:color-mix(in srgb,var(--brand) 72%,var(--bg))}
.brand-mark .bm-lt{fill:var(--brand)}
.brand-mark .bm-core{fill:var(--bg)}
/* wordmark: serif, moonlit ivory in dark with a slow gold sheen passing through */
.brand-name{
  font-family:var(--font-display);font-weight:600;font-size:19.5px;letter-spacing:-.008em;line-height:1;
  color:#eef1f6;
  background:linear-gradient(105deg,#dfe3ea 0%,#ffffff 22%,#ecd9a6 48%,#eef1f6 74%,#dfe3ea 100%);
  background-size:230% 100%;
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
body.light .brand-name{
  background:linear-gradient(105deg,#8a5d10 0%,#b8861f 26%,#7a5210 56%,#a8761e 80%,#7a5210 100%);
  background-size:230% 100%;
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
@keyframes brand-sheen{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
@media(prefers-reduced-motion:no-preference){.brand-name{animation:brand-sheen 14s ease-in-out infinite}}

.search{position:relative;flex:1;max-width:560px}
.search-ico{
  position:absolute;left:14px;top:50%;transform:translateY(-50%);
  width:18px;height:18px;fill:none;stroke:var(--muted);stroke-width:2;stroke-linecap:round;
}
#search-input{
  width:100%;padding:11px 16px 11px 42px;
  background:var(--panel);border:1px solid var(--line-2);border-radius:12px;
  color:var(--text);font-size:14.5px;font-family:inherit;outline:none;transition:.18s;
}
#search-input:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--ring)}
#search-input::placeholder{color:var(--dim)}
.search-results{
  position:absolute;top:calc(100% + 8px);left:0;right:0;
  background:var(--panel-2);border:1px solid var(--line-2);border-radius:12px;
  box-shadow:var(--shadow);overflow:hidden;display:none;z-index:60;
}
.search-results.show{display:block}
.sr-item{display:flex;align-items:center;gap:12px;padding:11px 14px;cursor:pointer;border-bottom:1px solid var(--line)}
.sr-item:last-child{border-bottom:0}
.sr-item:hover,.sr-item.active{background:color-mix(in srgb,var(--brand) 12%,transparent)}
.sr-sym{font-weight:700;min-width:62px}
.sr-name{color:var(--muted);font-size:13.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sr-tag{margin-left:auto;font-size:11px;color:var(--dim);border:1px solid var(--line-2);padding:2px 7px;border-radius:6px}

.nav{display:flex;gap:6px}
.nav a{padding:8px 14px;border-radius:10px;color:var(--muted);font-weight:500;font-size:14px;transition:.15s;white-space:nowrap}
.nav a:hover{color:var(--text);background:var(--panel)}
.nav a.active{color:var(--text);background:var(--panel-2);box-shadow:inset 0 0 0 1px var(--line-2)}
.nav-icons{display:flex;align-items:center;gap:2px}
/* ── persistent free-tier "Upgrade to Pro" pill (injected at boot) ───────
   Clean copper pill: one gradient fill, a soft top highlight, a tinted drop
   shadow, hover lift. No shimmer / halo ring / double border (those read as
   busy and buggy). */
.go-pro{display:inline-flex;align-items:center;gap:6px;margin-right:8px;
  padding:8px 16px;border-radius:999px;font-size:12px;font-weight:700;letter-spacing:.02em;
  color:var(--ink-on-gold);text-decoration:none;white-space:nowrap;border:1px solid var(--gold-edge);
  background:var(--gold-grad);
  box-shadow:var(--gold-hi),
    0 6px 16px -8px color-mix(in srgb,var(--brand) 55%,transparent);
  transition:transform .14s ease, box-shadow .14s ease, filter .14s ease}
.go-pro:hover{transform:translateY(-1px);filter:brightness(1.05);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.42),
    0 12px 24px -10px color-mix(in srgb,var(--brand) 60%,transparent)}
.go-pro:active{transform:translateY(0);filter:brightness(.97)}
.go-pro svg{width:13px;height:13px;flex:none;opacity:.9}
@media (max-width:640px){.go-pro span{display:none}.go-pro{padding:7px 10px}.go-pro svg{width:15px;height:15px}}
/* sidebar mode: the pill gets its own full-width row above the icon strip */
@media (min-width:1080px){
  body.app .nav-icons{flex-wrap:wrap}
  body.app .go-pro{flex:1 0 100%;justify-content:center;margin:0 0 10px;padding:9px 14px;font-size:12.5px}
}
.icon-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:9px;flex:none;
  background:none;border:none;color:var(--muted);cursor:pointer;
  text-decoration:none;transition:background .14s,color .14s;
}
.icon-btn:hover{color:var(--text);background:var(--panel)}
.icon-btn svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}

/* inline status dot — replaces 🟢/🔴/⚪ emoji */
.sdot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--dim);margin-right:7px;vertical-align:1px}
.sdot.b{background:var(--buy)}
.sdot.s{background:var(--sell)}

/* drawn glyphs that flow with text — replace ✦ / ⚠️ emoji */
.gi{width:1em;height:1em;display:inline-block;vertical-align:-.12em;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
.gi-fill{fill:currentColor;stroke:none}
.trim-flag>.gi,.conc-warn>.gi{width:16px;height:16px;flex:none;margin-top:1px}
.upgrade-banner .gi{vertical-align:-.16em;margin-right:2px}

/* ───────────── layout ───────────── */
main{padding:clamp(18px,3.5vw,40px);max-width:1240px;margin:0 auto;min-height:70vh}
.foot{
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  padding:22px clamp(16px,4vw,40px);border-top:1px solid var(--line);
  color:var(--muted);font-size:12.5px;margin-top:40px;
}
.foot-dim{color:var(--dim)}

.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--elev)}
.section-title{font-size:13px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-weight:600;margin-bottom:14px}

/* ───────────── hero / dashboard ───────────── */
.hero{text-align:center;padding:46px 20px 18px}
.hero h1{font-size:clamp(30px,5vw,52px);font-weight:800;letter-spacing:-.03em;line-height:1.05}
.hero h1 .grad{color:var(--brand)}
.hero p{color:var(--muted);max-width:600px;margin:16px auto 0;font-size:17px}
.hero-cta{margin-top:26px;display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.chip{
  padding:9px 16px;border-radius:999px;background:var(--panel);border:1px solid var(--line-2);
  cursor:pointer;font-weight:600;font-size:14px;transition:.15s;color:var(--muted)
}
.chip:hover{color:var(--text);border-color:var(--brand)}

/* ── market compass (dashboard lead) ── */
.compass{display:flex;align-items:center;gap:22px;padding:24px 26px;border-radius:13px;border:1px solid var(--line-2);position:relative;overflow:hidden;flex-wrap:wrap;box-shadow:var(--elev)}
.compass:before{content:'';position:absolute;inset:0;opacity:.5;pointer-events:none}
.compass.on{background:linear-gradient(120deg,var(--buy-dim),transparent 70%);border-color:color-mix(in srgb,var(--buy) 35%,transparent)}
.compass.neutral{background:linear-gradient(120deg,var(--hold-dim),transparent 70%);border-color:color-mix(in srgb,var(--hold) 32%,transparent)}
.compass.off{background:linear-gradient(120deg,var(--sell-dim),transparent 70%);border-color:color-mix(in srgb,var(--sell) 35%,transparent)}
.compass-ico{width:64px;height:64px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:30px;flex-shrink:0}
.compass.on .compass-ico{background:var(--buy-dim);color:var(--buy)}
.compass.neutral .compass-ico{background:var(--hold-dim);color:var(--hold)}
.compass.off .compass-ico{background:var(--sell-dim);color:var(--sell)}
.compass-main{flex:1;min-width:220px}
.compass-main .lab{font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-weight:600}
.compass-main .reg{font-size:28px;font-weight:800;letter-spacing:-.02em;line-height:1.1;margin:2px 0 5px}
.compass.on .reg{color:var(--buy)}.compass.neutral .reg{color:var(--hold)}.compass.off .reg{color:var(--sell)}
.compass-main .desc{color:var(--muted);font-size:14px}
.compass-pills{display:flex;gap:8px;flex-wrap:wrap}
.cpill{padding:8px 13px;border-radius:12px;background:var(--panel);border:1px solid var(--line);text-align:center;min-width:74px}
.cpill .k{font-size:11px;color:var(--dim);font-weight:600}
.cpill .v{font-size:13px;font-weight:700;margin-top:2px}

/* global market — broad index strip on the dashboard */
.gm-sub{font-size:12.5px;color:var(--muted)}
.gmkt{display:grid;grid-template-columns:repeat(auto-fit,minmax(184px,1fr));gap:12px}
.gmkt-card{padding:15px 17px;cursor:pointer;transition:.16s;display:flex;flex-direction:column;gap:6px;text-align:left;width:100%;font:inherit;color:var(--text)}
.gmkt-card:hover{background:var(--panel-2);border-color:var(--line-2);box-shadow:var(--elev-hover)}
.gmkt-card .gm-head{display:flex;justify-content:space-between;align-items:center;gap:8px}
.gmkt-card .gm-name{font-weight:700;font-size:14px}
.gmkt-card .gm-tkr{font-weight:600;font-size:11px;color:var(--dim);letter-spacing:.04em}
.gmkt-card .gm-px{font-size:24px;font-weight:800;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.gmkt-card .gm-trend{font-size:12px;font-weight:600;color:var(--muted)}
.gmkt-card .gm-trend.up{color:var(--buy)}
.gmkt-card .gm-trend.down{color:var(--sell)}
.gmkt-card.vix{cursor:default}
.gmkt-card.vix:hover{background:var(--panel);border-color:var(--line);box-shadow:var(--elev)}
.gm-vstate{font-size:11.5px;font-weight:700;padding:3px 9px;border-radius:999px;white-space:nowrap;background:var(--line);color:var(--muted)}
.gm-vstate.up{color:var(--buy);background:var(--buy-dim)}
.gm-vstate.down{color:var(--sell);background:var(--sell-dim)}

.sec-head{display:flex;justify-content:space-between;align-items:baseline;margin:30px 4px 14px;gap:12px}
.sec-head .section-title{margin:0}
.sec-head a{color:var(--brand);font-size:13px;font-weight:600}

/* ── just changed ── */
.changed{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:640px){.changed{grid-template-columns:1fr}}
.changed-col{padding:16px 18px}
.changed-col h4{font-size:13px;font-weight:700;margin-bottom:12px;display:flex;align-items:center;gap:9px}
.hdot{width:8px;height:8px;border-radius:50%;flex:none}
.hdot.buy{background:var(--buy);box-shadow:0 0 0 3px var(--buy-dim)}
.hdot.sell{background:var(--sell);box-shadow:0 0 0 3px var(--sell-dim)}
.chg-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-top:1px solid var(--line);cursor:pointer}
.chg-item:hover{opacity:.8}
.chg-item .sym{font-weight:700;min-width:62px}
.chg-item .nm{color:var(--dim);font-size:12.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}
.chg-item .dt{color:var(--dim);font-size:11.5px}
.chg-empty{color:var(--dim);font-size:13px;padding:6px 0}
a.chg-lock{display:inline-block;text-decoration:none;color:var(--brand);font-weight:600;cursor:pointer}
a.chg-lock:hover{text-decoration:underline}

.stat-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin:18px 0}
.stat{padding:18px 20px}
.stat .v{font-size:30px;font-weight:800;letter-spacing:-.02em}
.stat .l{color:var(--muted);font-size:13px;margin-top:2px}

.grid{display:grid;gap:14px}
.cards{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}

/* ticker mini-card */
.tcard{padding:16px 18px;cursor:pointer;transition:.16s;position:relative;overflow:hidden}
.tcard:hover{border-color:var(--line-2);background:var(--panel-2);box-shadow:var(--elev-hover)}
.tcard .top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;padding-right:22px}
.tcard .sym{font-weight:700;font-size:16px}
.tcard .nm{color:var(--dim);font-size:12.5px;margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}
.tcard .tsig{margin-top:11px}
.tcard .px{font-weight:600;font-size:15px;margin-top:13px}
.tcard .meta{display:flex;justify-content:space-between;align-items:center;margin-top:6px;color:var(--muted);font-size:12.5px}

/* signal badge */
.badge{display:inline-flex;align-items:center;gap:7px;font-weight:700;font-size:12.5px;padding:5px 11px;border-radius:999px;letter-spacing:.02em;white-space:nowrap}
.badge .dot{width:7px;height:7px;border-radius:50%}
.sig-buy,.sig-strong-buy{color:var(--buy);background:var(--buy-dim)}.sig-buy .dot,.sig-strong-buy .dot{background:var(--buy)}
.sig-hold,.sig-watch{color:var(--hold);background:var(--hold-dim)}.sig-hold .dot,.sig-watch .dot{background:var(--hold)}
.sig-sell,.sig-reduce,.sig-avoid{color:var(--sell);background:var(--sell-dim)}.sig-sell .dot,.sig-reduce .dot,.sig-avoid .dot{background:var(--sell)}

.up{color:var(--buy)}.down{color:var(--sell)}

@media(max-width:680px){
  .topbar{flex-wrap:wrap;gap:8px 12px;padding-bottom:9px}
  .brand{order:1}
  .nav-icons{order:2;margin-left:auto}
  .nav{order:3;flex-basis:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;
    scrollbar-width:none;margin:0 -16px;padding:0 16px}
  .nav::-webkit-scrollbar{display:none}
  .search{order:4;flex-basis:100%;max-width:none}
  .nav a{padding:7px 11px;font-size:13px}
  .bell-panel.show{top:auto;bottom:12px;right:12px;left:12px;width:auto;max-height:70vh}
}

/* ───────────── stock view ───────────── */
.stock-head{display:flex;align-items:flex-start;gap:18px;flex-wrap:wrap;margin-bottom:18px}
.stock-id .sym{font-size:30px;font-weight:800;letter-spacing:-.02em}
.stock-id .nm{color:var(--muted);font-size:15px}
.stock-id .exch{color:var(--dim);font-size:12.5px;margin-top:2px}
.stock-px{margin-left:auto;text-align:right}
.stock-px .p{font-size:30px;font-weight:800;letter-spacing:-.02em}
.stock-px .c{font-size:15px;font-weight:600;margin-top:2px}

.stock-grid{display:grid;grid-template-columns:1.7fr 1fr;gap:16px;align-items:start}
@media(max-width:900px){.stock-grid{grid-template-columns:1fr}}

.chart-wrap{padding:14px 14px 6px}
.chart-tabs{display:flex;gap:6px;margin:0 0 8px 4px;align-items:center;flex-wrap:wrap}
.mk-toggle{display:flex;align-items:center;gap:3px;margin-left:auto;background:var(--bg-2);border:1px solid var(--line);border-radius:9px;padding:3px}
.mk-toggle .lab{font-size:10.5px;letter-spacing:.07em;text-transform:uppercase;color:var(--dim);padding:0 5px 0 8px}
.mk-toggle button{padding:4px 10px;border:none;background:transparent;color:var(--muted);font-weight:600;font-size:12px;border-radius:7px;cursor:pointer;font-family:inherit;transition:.14s}
.mk-toggle button:hover{color:var(--text)}
.mk-toggle button.active{background:var(--panel-2);color:var(--text);box-shadow:inset 0 0 0 1px var(--line-2)}
.rbtn{padding:5px 12px;border-radius:8px;background:transparent;border:1px solid var(--line);color:var(--muted);cursor:pointer;font-size:12.5px;font-weight:600;font-family:inherit;transition:.14s}
.rbtn:hover{color:var(--text)}
.rbtn.active{background:var(--panel-2);color:var(--text);border-color:var(--line-2)}
.legend{display:flex;gap:16px;flex-wrap:wrap;padding:6px 8px 10px;color:var(--muted);font-size:12px}
.legend span{display:inline-flex;align-items:center;gap:6px}
.legend i{width:14px;height:3px;border-radius:2px;display:inline-block}
#price-chart{width:100%;height:380px}
#score-chart{width:100%;height:128px}
.score-cap{display:flex;justify-content:space-between;color:var(--dim);font-size:11.5px;padding:2px 8px 8px}

/* recommendation card */
.reco{padding:22px}
.reco-badge{font-size:30px;font-weight:800;letter-spacing:-.02em;display:flex;align-items:center;gap:12px}
.reco-badge .dot{width:11px;height:11px;border-radius:50%;box-shadow:0 0 0 4px color-mix(in srgb,currentColor 16%,transparent)}
.reco .sub{color:var(--muted);margin-top:8px;font-size:14px}

/* gauge */
.gauge{margin:20px 0 6px}
.gauge-track{height:10px;border-radius:999px;background:linear-gradient(90deg,var(--sell),#5a6577 47%,#5a6577 53%,var(--buy));position:relative;overflow:visible}
.gauge-needle{position:absolute;top:50%;width:3px;height:22px;background:#fff;border-radius:2px;transform:translate(-50%,-50%);box-shadow:0 0 0 2px rgba(0,0,0,.25),0 0 6px rgba(255,255,255,.35);transition:left .5s cubic-bezier(.2,.8,.2,1)}
.gauge-scale{display:flex;justify-content:space-between;color:var(--dim);font-size:11px;margin-top:7px}
.gauge-val{text-align:center;margin-top:10px}
.gauge-val b{font-size:26px;font-weight:800}
.gauge-val span{color:var(--muted);font-size:12.5px;display:block}

.possize{margin-top:18px;padding:14px 15px;border-radius:12px;background:var(--panel-2);border:1px solid var(--line)}
.ps-head{display:flex;justify-content:space-between;align-items:baseline;font-size:13px;color:var(--muted)}
.ps-head b{font-size:20px;font-weight:800;color:var(--text)}
.ps-track{height:8px;border-radius:999px;background:rgba(255,255,255,.07);margin:9px 0 8px;overflow:hidden}
.ps-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--brand-2),var(--brand));transition:width .5s}
.ps-note{font-size:11.5px;color:var(--dim);line-height:1.4}
/* the trade plan — buy / add / trim / sell, one glance */
.tplan{margin-top:14px;border:1px solid var(--line);border-radius:12px;background:var(--panel-2);overflow:hidden}
.tp-head{padding:10px 14px 8px;font-size:11px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--line)}
.tp-row{display:grid;grid-template-columns:58px 1fr;gap:10px;padding:10px 14px;border-bottom:1px solid var(--line);align-items:baseline}
.tp-row:last-child{border-bottom:none}
.tp-k{font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.tp-v{font-size:12.5px;line-height:1.5;color:var(--text)}
.tp-v b{font-weight:750}
.tp-now .tp-k{color:var(--brand)}
.tp-good .tp-k{color:var(--buy)}
.tp-warn .tp-k{color:var(--hold)}
.tp-sell .tp-k{color:var(--sell)}
.sell-risk{margin-top:16px;padding:14px 15px;border-radius:12px;background:var(--panel-2);border:1px solid var(--line)}
.sell-risk.risk-medium{border-color:color-mix(in srgb,var(--hold) 28%,transparent);background:var(--hold-dim)}
.sell-risk.risk-high,.sell-risk.risk-critical{border-color:color-mix(in srgb,var(--sell) 32%,transparent);background:var(--sell-dim)}
.sr-head{display:flex;justify-content:space-between;align-items:center;color:var(--muted);font-size:13px}
.sr-head b{font-size:26px;color:var(--text);font-weight:800}
.sr-track{height:8px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden;margin:8px 0 12px}
.sr-track i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--buy),var(--hold),var(--sell))}
.sr-triggers{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.sr-triggers div{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:10px 11px}
.sr-triggers span{display:block;color:var(--muted);font-size:11.5px}
.sr-triggers b{display:block;font-size:16px;margin-top:2px}
.sr-triggers em{display:block;color:var(--dim);font-size:11px;font-style:normal;margin-top:1px}
.sr-triggers em.hot{color:var(--sell);font-weight:700}
.sr-factors{display:flex;flex-wrap:wrap;gap:6px;margin-top:11px}
.sr-factors span{font-size:11.5px;color:var(--muted);background:rgba(255,255,255,.06);border:1px solid var(--line);padding:4px 8px;border-radius:999px}
.sell-risk .why{font-size:12px;color:var(--muted);line-height:1.45;margin-top:10px}
.life-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border-radius:12px;overflow:hidden;margin-top:18px}
.life-grid>div{background:var(--panel);padding:10px 11px}
.life-grid .k{font-size:11px;color:var(--muted)}
.life-grid .v{font-weight:800;font-size:14px;margin-top:2px}
@media(max-width:480px){.life-grid{grid-template-columns:repeat(2,1fr)}.sr-triggers{grid-template-columns:1fr}}
.reco-stats{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border-radius:12px;overflow:hidden;margin-top:18px}
.reco-stats div{background:var(--panel);padding:12px 14px}
.reco-stats .k{color:var(--muted);font-size:12px}
.reco-stats .v{font-weight:700;font-size:15px;margin-top:2px}

.subscores{margin-top:18px;display:flex;flex-direction:column;gap:10px}
.ss-row{display:grid;grid-template-columns:78px 1fr 44px;align-items:center;gap:10px;font-size:13px}
.ss-row .lab{color:var(--muted)}
.ss-bar{height:6px;background:rgba(255,255,255,.06);border-radius:999px;position:relative;overflow:hidden}
.ss-fill{position:absolute;top:0;bottom:0;left:50%;border-radius:999px}
.ss-row .num{text-align:right;font-weight:600}

/* backtest */
.bt{padding:20px;margin-top:16px}
.bt-head{display:flex;justify-content:space-between;align-items:baseline;gap:12px;flex-wrap:wrap;margin-bottom:6px}
.bt-note{color:var(--dim);font-size:12.5px;max-width:560px}
.bt-verdict{display:flex;gap:11px;align-items:flex-start;margin:16px 0 4px;padding:13px 15px;border-radius:11px;font-size:13.5px;line-height:1.5}
.bt-verdict span:first-child{font-weight:800;font-size:15px}
.bt-verdict b{color:var(--text)}
.bt-good{background:var(--buy-dim);border:1px solid color-mix(in srgb,var(--buy) 28%,transparent)}.bt-good span:first-child{color:var(--buy)}
.bt-mixed{background:var(--hold-dim);border:1px solid color-mix(in srgb,var(--hold) 28%,transparent)}.bt-mixed span:first-child{color:var(--hold)}
.bt-bad{background:var(--sell-dim);border:1px solid color-mix(in srgb,var(--sell) 30%,transparent)}.bt-bad span:first-child{color:var(--sell)}
.bt-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;margin:18px 0}
.metric{background:var(--panel-2);border:1px solid var(--line);border-radius:12px;padding:13px 15px}
.metric .k{color:var(--muted);font-size:11.5px;text-transform:uppercase;letter-spacing:.06em}
.metric .v{font-size:22px;font-weight:800;margin-top:4px;letter-spacing:-.02em}
.metric .vs{font-size:12px;color:var(--dim);margin-top:3px}
#equity-chart{width:100%;height:240px;margin-top:8px}
.eq-tabs{margin:10px 0 2px}
.eq-tip{position:absolute;top:8px;left:8px;display:none;z-index:6;pointer-events:none;
  background:color-mix(in srgb,var(--panel) 50%,transparent);
  border:1px solid color-mix(in srgb,var(--line-2) 50%,transparent);border-radius:10px;padding:9px 12px;
  font-size:12.5px;line-height:1.7;box-shadow:0 6px 18px rgba(0,0,0,.09);white-space:nowrap}
.eq-tip .t{color:var(--dim);font-size:10.5px;margin-bottom:3px}
.eq-tip div i{display:inline-block;width:9px;height:3px;border-radius:2px;margin:0 7px 3px 0;vertical-align:middle}
.eq-tip div b{margin-left:9px;font-variant-numeric:tabular-nums;float:right}

/* recent buys */
.tabs{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}
.tab{padding:9px 16px;border-radius:10px;background:var(--panel);border:1px solid var(--line);color:var(--muted);cursor:pointer;font-weight:600;font-size:14px}
.tab.active{background:var(--panel-2);color:var(--text);border-color:var(--line-2)}
.tab .n{margin-left:7px;font-size:12px;opacity:.8}

.buy-card{padding:18px 20px;cursor:pointer;transition:.16s;display:flex;flex-direction:column;gap:2px}
.buy-card:hover{background:var(--panel-2);border-color:var(--line-2);box-shadow:var(--elev-hover)}
.buy-card .row1::before{content:'';width:8px;height:8px;border-radius:50%;flex:none;background:var(--dim)}
.buy-card.b .row1::before{background:var(--buy)}
.buy-card.s .row1::before{background:var(--sell)}
.buy-card .row1{display:flex;align-items:center;gap:10px}
.buy-card .sym{font-weight:700;font-size:17px}
.buy-card .nm{color:var(--dim);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.buy-card .row2{display:flex;justify-content:space-between;align-items:center;margin-top:12px;color:var(--muted);font-size:13px}
.buy-card .when{color:var(--dim);font-size:12px;margin-top:6px}

/* table */
.wtable{width:100%;border-collapse:collapse;font-size:14px}
.wtable th{text-align:left;color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.05em;padding:10px 14px;border-bottom:1px solid var(--line)}
.wtable td{padding:12px 14px;border-bottom:1px solid var(--line)}
.wtable tr{cursor:pointer;transition:.12s}
.wtable tbody tr:hover{background:var(--panel-2)}
.wtable th.r,.wtable td.r{text-align:right}
.wtable th.sortable{cursor:pointer;user-select:none;white-space:nowrap}
.wtable th.sortable:hover{color:var(--text)}
.wtable th.sortable.on{color:var(--brand)}

/* at-risk page */
.risk-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:14px}
.risk-card{padding:16px 18px;cursor:pointer;transition:.16s;position:relative}
.risk-card:hover{background:var(--panel-2);box-shadow:var(--elev-hover)}
.risk-card.medium .risk-score{background:var(--hold-dim);border-color:transparent}
.risk-card.high .risk-score,.risk-card.critical .risk-score{background:var(--sell-dim);border-color:transparent}
.risk-top{display:flex;justify-content:space-between;gap:12px;padding-right:22px}
.risk-top .sym{font-size:17px;font-weight:800}
.risk-top .nm{font-size:12.5px;color:var(--dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:170px}
.risk-score{width:42px;height:42px;border-radius:12px;background:var(--panel-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px}
.risk-card.medium .risk-score{color:var(--hold)}
.risk-card.high .risk-score,.risk-card.critical .risk-score{color:var(--sell)}
.risk-meter{height:7px;border-radius:999px;background:rgba(255,255,255,.07);overflow:hidden;margin:12px 0}
.risk-meter i{display:block;height:100%;background:linear-gradient(90deg,var(--buy),var(--hold),var(--sell));border-radius:999px}
.risk-lines{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.risk-lines div{background:var(--panel-2);border:1px solid var(--line);border-radius:9px;padding:8px 9px}
.risk-lines span{display:block;color:var(--muted);font-size:10.5px}
.risk-lines b{font-size:13px}
.risk-meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:11px;color:var(--muted);font-size:12px}
.risk-factors{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}
.risk-factors span{font-size:11.5px;color:var(--muted);border:1px solid var(--line);background:rgba(255,255,255,.05);border-radius:999px;padding:4px 8px}
.risk-pill{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:24px;border-radius:7px;font-weight:800;font-size:12px;background:var(--panel-2);border:1px solid var(--line)}
.risk-pill.medium{color:var(--hold)}.risk-pill.high,.risk-pill.critical{color:var(--sell)}

/* ───────────── favorites ───────────── */
.fav-btn{background:none;border:none;cursor:pointer;color:var(--dim);font-size:22px;line-height:1;padding:2px 4px;transition:.15s;outline:none}
.fav-btn:hover{transform:scale(1.15);color:var(--hold)}
.fav-btn.on{color:var(--hold);text-shadow:0 0 7px color-mix(in srgb,var(--hold) 30%,transparent)}
.stock-fav{font-size:26px;margin-top:6px}
.tcard .fav-btn{position:absolute;top:10px;right:10px;font-size:17px;z-index:2}

/* ───────────── conviction ───────────── */
.conviction{display:flex;align-items:center;gap:9px;margin-top:14px;padding:11px 13px;border-radius:11px;background:var(--panel-2);border:1px solid var(--line)}
.conviction .lv{font-weight:700;font-size:13.5px;white-space:nowrap}
.conviction .nt{color:var(--muted);font-size:12.5px;line-height:1.35}
.cv-high .lv{color:var(--buy)}.cv-solid .lv{color:var(--brand-2)}
.cv-spec .lv{color:var(--hold)}.cv-low .lv{color:var(--sell)}
.trim-flag{display:flex;gap:9px;align-items:center;margin-top:12px;padding:11px 13px;border-radius:11px;background:var(--hold-dim);border:1px solid color-mix(in srgb,var(--hold) 30%,transparent);font-size:13px;color:var(--warn-ink)}
.trim-flag b{color:var(--hold)}

/* ───────────── grade pills ───────────── */
.grade-pill{display:inline-flex;align-items:center;justify-content:center;min-width:30px;height:22px;padding:0 7px;border-radius:7px;font-weight:800;font-size:12.5px;letter-spacing:-.02em}
.g-a{color:#0a1f17;background:var(--buy)}
.g-b{color:#06201e;background:var(--brand-2)}
.g-c{color:#241a06;background:var(--hold)}
.g-d,.g-f{color:#260a0e;background:var(--sell)}
.g-na{color:var(--dim);background:rgba(255,255,255,.06)}

/* ───────────── fundamentals panel ───────────── */
.fund{padding:22px;margin-top:16px}
.fund-head{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.fund-grade{display:flex;align-items:center;gap:14px}
.fund-grade .letter{width:62px;height:62px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:30px;font-weight:800;letter-spacing:-.03em}
.fund-grade .meta b{font-size:17px;font-weight:700}
.fund-grade .meta span{display:block;color:var(--muted);font-size:13px;margin-top:2px}
.fund-cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin:20px 0 4px}
.fcol .lab{display:flex;justify-content:space-between;font-size:13px;color:var(--muted);margin-bottom:6px}
.fcol .lab b{color:var(--text)}
.fcol .bar{height:7px;border-radius:999px;background:rgba(255,255,255,.06);overflow:hidden}
.fcol .bar i{display:block;height:100%;border-radius:999px}
.fund-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1px;background:var(--line);border-radius:12px;overflow:hidden;margin-top:18px}
.fund-metrics .fm{background:var(--panel);padding:12px 14px}
.fund-metrics .fm .k{color:var(--muted);font-size:11.5px}
.fund-metrics .fm .v{font-weight:700;font-size:15.5px;margin-top:3px}
.fund-outlook{margin-top:16px;padding:13px 15px;border-radius:11px;background:color-mix(in srgb,var(--brand) 7%,transparent);border:1px solid color-mix(in srgb,var(--brand) 18%,transparent);font-size:13.5px;color:var(--ink-soft)}
.fund-outlook b{color:var(--text)}
.fund-na{padding:30px;text-align:center;color:var(--muted)}

/* ── valuation / de-rating risk ── */
.val-block{margin-top:22px;border-top:1px solid var(--line);padding-top:20px}
.val-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:1px;background:var(--line);border-radius:12px;overflow:hidden}
.val-grid .vt{background:var(--panel);padding:12px 14px}
.val-grid .vt .k{color:var(--muted);font-size:11.5px}
.val-grid .vt .v{font-weight:700;font-size:17px;margin-top:3px}
.trend-up{color:var(--buy)}.trend-down{color:var(--sell)}.trend-flat{color:var(--muted)}
.risk-banner{display:flex;gap:11px;align-items:flex-start;margin-top:14px;padding:13px 15px;border-radius:11px;font-size:13.5px;line-height:1.45}
.risk-banner .rl{font-weight:800;white-space:nowrap}
.risk-High{background:var(--sell-dim);border:1px solid color-mix(in srgb,var(--sell) 30%,transparent)}.risk-High .rl{color:var(--sell)}
.risk-Elevated,.risk-Moderate{background:var(--hold-dim);border:1px solid color-mix(in srgb,var(--hold) 30%,transparent)}.risk-Elevated .rl,.risk-Moderate .rl{color:var(--hold)}
.risk-Low{background:var(--buy-dim);border:1px solid color-mix(in srgb,var(--buy) 25%,transparent)}.risk-Low .rl{color:var(--buy)}
.risk-Speculative{background:color-mix(in srgb,var(--brand) 10%,transparent);border:1px solid color-mix(in srgb,var(--brand) 25%,transparent)}.risk-Speculative .rl{color:var(--brand)}

/* ── financials bar charts ── */
.fin-block{margin-top:22px;border-top:1px solid var(--line);padding-top:18px}
.fin-head{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;margin-bottom:16px}
.fin-toggle{display:flex;gap:4px;background:var(--bg-2);border:1px solid var(--line);border-radius:9px;padding:3px}
.fin-toggle button{padding:5px 14px;border:none;background:transparent;color:var(--muted);font-weight:600;font-size:12.5px;border-radius:7px;cursor:pointer;font-family:inherit}
.fin-toggle button.active{background:var(--panel-2);color:var(--text)}
.fin-charts{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media(max-width:760px){.fin-charts{grid-template-columns:1fr}}
.fin-chart .ct{font-size:12.5px;color:var(--muted);margin-bottom:12px;font-weight:600}
.fin-bars{display:flex;gap:7px;height:150px}
.bw{flex:1;display:flex;flex-direction:column;min-width:0}
.bw .top{display:flex;flex-direction:column;justify-content:flex-end;align-items:center;border-bottom:1px solid var(--line-2)}
.bw .bot{display:flex;flex-direction:column;justify-content:flex-start;align-items:center}
.bw .g{font-size:10.5px;font-weight:700;margin-bottom:3px;white-space:nowrap}
.bw .bar{width:80%;max-width:36px;transition:height .45s ease;min-height:2px}
.bw .bar.up{border-radius:4px 4px 0 0}
.bw .bar.dn{border-radius:0 0 4px 4px}
.fin-labels{display:flex;gap:7px;margin-top:7px}
.fin-labels span{flex:1;text-align:center;font-size:10px;color:var(--dim);white-space:nowrap;overflow:hidden}
.fin-legend{margin-top:18px;font-size:11.5px;color:var(--dim);text-align:center}

/* ───────────── portfolio ───────────── */
.pf-head{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;margin-bottom:8px}
.pf-controls{display:flex;align-items:center;flex-wrap:wrap;gap:12px}
.donut-panel{display:flex;align-items:center;gap:28px;flex-wrap:wrap;padding:18px 22px;margin-bottom:16px}
.donut-wrap{flex:0 0 auto}
.donut{width:160px;height:160px;display:block}
.donut-big{font-size:26px;font-weight:800;fill:var(--text);letter-spacing:-.02em}
.donut-sub{font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;fill:var(--dim)}
.donut-legend{display:flex;flex-wrap:wrap;gap:6px 14px;max-width:560px}
.donut-key{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;color:var(--muted)}
.donut-key b{color:var(--text);font-weight:700}
.donut-key i{width:9px;height:9px;border-radius:3px;display:inline-block}
.donut-key[data-sym]{cursor:pointer}
.donut-key[data-sym]:hover{color:var(--text)}
.cap-input{display:flex;align-items:center;gap:8px;background:var(--panel);border:1px solid var(--line-2);border-radius:12px;padding:8px 14px}
.cap-input span{color:var(--muted);font-weight:600}
.cap-input input{background:none;border:none;color:var(--text);font-size:20px;font-weight:800;width:130px;outline:none;font-family:inherit;letter-spacing:-.02em}
.alloc-row,.alloc-cash,.alloc-head{display:grid;grid-template-columns:minmax(0,1fr) 150px 120px;align-items:center;gap:16px;padding:13px 16px}
.alloc-id{min-width:0}
.alloc-row{border-bottom:1px solid var(--line);cursor:pointer;transition:.12s}
.alloc-row:hover{background:var(--panel-2)}
.alloc-row:last-child{border-bottom:0}
.alloc-id .s{font-weight:700;display:flex;align-items:center;gap:8px}
.alloc-id .n{color:var(--dim);font-size:12.5px;display:flex;align-items:center;gap:8px;margin-top:4px}
.alloc-mid{display:flex;flex-direction:column;gap:6px}
.alloc-mid .w{font-weight:700;font-size:15px}
.alloc-bar{height:8px;background:rgba(255,255,255,.06);border-radius:999px;overflow:hidden}
.alloc-bar i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--brand-2),var(--brand))}
.alloc-d{font-weight:700;text-align:right;font-family:'JetBrains Mono',monospace;font-size:15px}
.alloc-cash{background:var(--panel-2)}
.alloc-cash .alloc-bar i{background:var(--dim)}
.alloc-head{padding:9px 16px;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.06em}
.alloc-head span:nth-child(3){text-align:right}
@media(max-width:560px){.alloc-row,.alloc-cash,.alloc-head{grid-template-columns:minmax(0,1fr) 80px 90px}.alloc-mid .alloc-bar{display:none}}
.sidelined{margin-top:16px;display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.sidelined .lab{color:var(--muted);font-size:13px;margin-right:4px}
.side-chip{padding:5px 11px;border-radius:999px;background:var(--panel);border:1px solid var(--line);font-size:12.5px;cursor:pointer}
.side-chip b{font-weight:700}
@media(max-width:720px){
  .alloc-row,.alloc-cash,.alloc-head{grid-template-columns:minmax(0,1.4fr) minmax(0,1fr) 90px}
  .alloc-row .alloc-bar,.alloc-cash .alloc-bar,.alloc-head span:nth-child(3){display:none}
}

/* ───────────── engine chip / settings / earnings ───────────── */
.engine-chip{display:inline-flex;align-items:center;gap:6px;margin-top:12px;padding:6px 11px;border-radius:999px;background:color-mix(in srgb,var(--brand) 10%,transparent);border:1px solid color-mix(in srgb,var(--brand) 22%,transparent);color:var(--ink-soft);font-size:12px;font-weight:600}

.settings-card{max-width:600px}
.set-row{display:flex;gap:10px;align-items:center;margin:14px 0;flex-wrap:wrap}
.set-row input{flex:1;min-width:0;padding:11px 14px;background:var(--bg-2);border:1px solid var(--line-2);border-radius:10px;color:var(--text);font-size:14px;font-family:'JetBrains Mono',monospace;outline:none}
.set-row input:focus{border-color:var(--brand)}
@media(max-width:560px){.set-row input{flex-basis:100%}.set-row .btn,.set-row button{flex:1}}
.btn{padding:11px 18px;border-radius:10px;border:1px solid var(--line-2);background:var(--panel-2);color:var(--text);font-weight:600;cursor:pointer;font-family:inherit;font-size:14px;transition:.15s}
.btn:hover{border-color:var(--brand)}
.btn.primary{background:var(--gold-grad);border:1px solid var(--gold-edge);color:var(--ink-on-gold);box-shadow:var(--gold-hi)}
.btn.primary:hover{filter:brightness(1.04);box-shadow:var(--gold-hi),0 8px 20px -10px color-mix(in srgb,var(--brand) 55%,transparent)}
.btn.danger:hover{border-color:var(--sell);color:var(--sell)}
.set-status{font-size:13px;margin-top:10px}
.set-ok{color:var(--buy)}.set-err{color:var(--sell)}
.key-state{display:inline-flex;align-items:center;gap:7px;padding:6px 12px;border-radius:999px;font-size:13px;font-weight:600}
.key-on{background:var(--buy-dim);color:var(--buy)}
.key-off{background:rgba(255,255,255,.06);color:var(--muted)}

.earnings{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-top:16px;padding:14px 16px;border-radius:11px;background:var(--panel-2);border:1px solid var(--line)}
.earnings .cd{font-weight:800;font-size:20px;color:var(--hold)}
.earnings .det{font-size:13px;color:var(--muted);line-height:1.4}
.earnings .det b{color:var(--text)}

/* ───────────── command palette (⌘K) ───────────── */
.kbar{position:fixed;inset:0;z-index:200;display:none;align-items:flex-start;justify-content:center;padding-top:14vh;background:rgba(3,6,12,.6);backdrop-filter:blur(4px)}
.kbar.show{display:flex}
.kbox{width:min(560px,92vw);background:var(--panel-2);border:1px solid var(--line-2);border-radius:13px;box-shadow:var(--shadow);overflow:hidden}
.kbox input{width:100%;padding:17px 20px;background:none;border:none;border-bottom:1px solid var(--line);color:var(--text);font-size:16px;outline:none;font-family:inherit}
.kres{max-height:50vh;overflow-y:auto}
.kitem{display:flex;align-items:center;gap:12px;padding:11px 18px;cursor:pointer}
.kitem.active,.kitem:hover{background:color-mix(in srgb,var(--brand) 13%,transparent)}
.kitem .ico{width:22px;text-align:center;color:var(--muted)}
.kitem .lbl{font-weight:600}.kitem .sub{color:var(--dim);font-size:12.5px;margin-left:auto}
.khint{padding:8px 18px;color:var(--dim);font-size:11.5px;border-top:1px solid var(--line);display:flex;gap:14px}

/* ───────────── themes (supply stack baskets) ───────────── */
.stack-label{display:flex;align-items:center;gap:12px;margin:26px 4px 14px;color:var(--muted);font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.1em}
.stack-label:before,.stack-label:after{content:'';height:1px;background:var(--line);flex:1}
.theme-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:14px}
.tbasket{padding:18px 20px;cursor:pointer;transition:.16s}
.tbasket:hover{background:var(--panel-2);border-color:var(--line-2);box-shadow:var(--elev-hover)}
.tbasket .th{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.tbasket .tname{font-weight:700;font-size:16px}
.tbasket .bsig{font-size:11.5px;font-weight:700;padding:3px 9px;border-radius:999px;white-space:nowrap}
.tbasket.bull .bsig{color:var(--buy);background:var(--buy-dim)}
.tbasket.mixed .bsig{color:var(--hold);background:var(--hold-dim)}
.tbasket.bear .bsig{color:var(--sell);background:var(--sell-dim)}
.tbasket .thesis{color:var(--muted);font-size:12.5px;line-height:1.45;margin:8px 0 12px;min-height:34px}
.tbasket .breadth{height:6px;border-radius:999px;background:rgba(255,255,255,.07);overflow:hidden;margin-bottom:5px}
.tbasket .breadth i{display:block;height:100%;border-radius:999px}
.tbasket.bull .breadth i{background:var(--buy)}.tbasket.mixed .breadth i{background:var(--hold)}.tbasket.bear .breadth i{background:var(--sell)}
.tbasket .bmeta{display:flex;justify-content:space-between;color:var(--dim);font-size:11.5px;margin-bottom:12px}
.tbasket .leaders{display:flex;flex-direction:column;gap:6px}
.tbasket .ld{display:flex;align-items:center;gap:8px;font-size:13px}
.tbasket .ld .s{font-weight:700;min-width:52px}
.tbasket .ld .o{margin-left:auto;font-weight:700;color:var(--brand-2)}

/* ───────────── methodology doc ───────────── */
.doc{max-width:760px;margin:0 auto}
.doc h1{font-family:var(--font-display);font-size:36px;font-weight:600;letter-spacing:-.01em;margin-bottom:6px}
.doc .lede{color:var(--muted);font-size:16px;margin-bottom:30px}
.doc h2{font-size:19px;font-weight:700;margin:30px 0 10px;display:flex;align-items:center;gap:10px}
.doc h2 .num{width:26px;height:26px;border-radius:8px;background:var(--panel-2);border:1px solid var(--line-2);display:inline-flex;align-items:center;justify-content:center;font-size:13px;color:var(--brand-2)}
.doc p{color:var(--ink-soft);line-height:1.65;margin-bottom:12px}
.doc .panel{padding:18px 20px;margin:14px 0}
.doc b{color:var(--text)}
.doc ul{margin:0 0 12px 2px;list-style:none}
.doc li{color:var(--ink-soft);line-height:1.6;padding-left:20px;position:relative;margin-bottom:7px}
.doc li:before{content:'▸';position:absolute;left:0;color:var(--brand-2)}
.doc ol li{padding-left:4px}
.doc ol li:before{content:none}  /* numbered lists keep their numbers — no double marker */
.doc .warn{background:var(--hold-dim);padding:14px 18px;border-radius:10px;color:var(--warn-ink);margin:16px 0}

/* ───────────── compare ───────────── */
.cmp-add{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px;align-items:center}
.cmp-grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.cmp-col{padding:0;overflow:hidden}
.cmp-top{padding:16px 18px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:flex-start;gap:8px}
.cmp-top .sym{font-weight:800;font-size:19px}
.cmp-top .nm{color:var(--dim);font-size:12px}
.cmp-rm{background:none;border:none;color:var(--dim);cursor:pointer;font-size:16px}
.cmp-rm:hover{color:var(--sell)}
.cmp-rows{padding:6px 0}
.cmp-r{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:9px 18px;font-size:13.5px}
.cmp-r .k{color:var(--muted)}
.cmp-r .v{font-weight:700;text-align:right}

/* ───────────── theme tags ───────────── */
.theme-tag{display:inline-block;padding:2px 9px;border-radius:999px;font-size:11px;font-weight:600;background:color-mix(in srgb,var(--brand) 12%,transparent);color:var(--ink-soft);white-space:nowrap}
.theme-sel{padding:8px 12px;background:var(--panel);border:1px solid var(--line-2);border-radius:10px;color:var(--text);font-family:inherit;font-size:13.5px;font-weight:600;cursor:pointer;outline:none}
.theme-sel:focus{border-color:var(--brand)}

/* ───────────── opportunities ───────────── */
.opp-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px;align-items:center}
.opp-row{display:grid;grid-template-columns:40px 1.7fr 1fr auto;align-items:center;gap:14px;padding:14px 16px;border-bottom:1px solid var(--line);cursor:pointer;transition:.12s}
.opp-row:hover{background:var(--panel-2)}
.opp-rank{font-weight:800;font-size:18px;color:var(--dim);text-align:center}
.opp-score{display:flex;align-items:center;gap:10px}
.opp-meter{width:70px;height:7px;background:rgba(255,255,255,.07);border-radius:999px;overflow:hidden}
.opp-meter i{display:block;height:100%;border-radius:999px}
.opp-num{font-weight:800;font-size:17px;min-width:30px}
.opp-tags{display:flex;gap:7px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.opp-why{color:var(--muted);font-size:12.5px}
@media(max-width:720px){
  .opp-row{grid-template-columns:26px 1fr auto;gap:10px;padding:13px 12px}
  .opp-score{display:none}
  .alloc-id .s{flex-wrap:wrap;gap:4px 7px;min-width:0}
  .opp-row .theme-tag{display:none}   /* theme shows on the stock page; space is precious here */
  .opp-tags{flex-direction:column;align-items:flex-end;gap:4px}
}

/* states */
.loading,.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;color:var(--muted);gap:14px;text-align:center}
.spinner{width:34px;height:34px;border:3px solid var(--line-2);border-top-color:var(--brand);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.skeleton{background:linear-gradient(90deg,var(--panel),var(--panel-2),var(--panel));background-size:200% 100%;animation:sh 1.3s infinite;border-radius:12px}
@keyframes sh{to{background-position:-200% 0}}
.err{color:var(--sell)}
.muted{color:var(--muted)}
.fade-in{animation:fade .4s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ════════════ market-improvement features (froth / ballast / rank / benchmark / concentration) ════════════ */
/* P3 — froth gauge inside the compass */
.froth{margin-left:auto;min-width:170px;display:flex;flex-direction:column;gap:6px}
.froth-top{display:flex;align-items:baseline;gap:8px}
.froth-lab{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-weight:600}
.froth-level{font-weight:800;font-size:15px}
.froth-num{margin-left:auto;font-size:12px;color:var(--muted)}
.froth-meter{height:7px;border-radius:5px;background:var(--line-2);overflow:hidden}
.froth-meter i{display:block;height:100%;border-radius:5px;transition:width .5s}
/* free-tier locks + upgrade CTA */
.locked-row{opacity:.75;cursor:default}
.lock-blur{letter-spacing:2px;color:var(--dim);filter:blur(3px);user-select:none}
.upgrade-banner{display:flex;align-items:center;gap:16px;flex-wrap:wrap;justify-content:space-between;
  margin:14px 0;padding:15px 18px;border-radius:13px;
  background:color-mix(in srgb,var(--brand) 9%,transparent);border:1px solid color-mix(in srgb,var(--brand) 28%,transparent)}
.upgrade-banner .ub-txt b{display:block;font-size:14px;margin-bottom:2px}
.upgrade-banner .ub-txt span{font-size:12.5px;color:var(--muted);line-height:1.5}
.upgrade-banner .btn{white-space:nowrap;text-decoration:none}

/* alerts bell + inbox */
.bell{position:relative}
.bell-dot{position:absolute;top:1px;right:1px;min-width:15px;height:15px;border-radius:999px;background:var(--sell);
  color:#fff;font-size:9.5px;font-weight:800;line-height:15px;text-align:center;padding:0 3px}
.bell-panel{position:fixed;top:64px;right:18px;width:min(400px,calc(100vw - 24px));max-height:min(560px,75vh);
  display:none;flex-direction:column;background:var(--panel);border:1px solid var(--line-2);border-radius:14px;
  box-shadow:var(--shadow);z-index:90;overflow:hidden}
.bell-panel.show{display:flex}
.bp-head{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;border-bottom:1px solid var(--line);font-size:13.5px}
.bp-head a{color:var(--brand);text-decoration:none}
.bp-list{overflow-y:auto;flex:1}
.bp-item{display:flex;gap:10px;padding:11px 15px;border-bottom:1px solid var(--line);cursor:pointer;align-items:flex-start}
.bp-item:hover{background:var(--panel-2)}
.bp-ico{flex:0 0 auto;font-size:14px;line-height:1.4}
.bp-ico .sdot{margin-right:0;vertical-align:2px}
.bp-ico .gi{color:var(--hold)}
.bp-main{flex:1;min-width:0}
.bp-main b{display:block;font-size:12.5px}
.bp-main span{display:block;font-size:11.5px;color:var(--muted);line-height:1.45;margin-top:1px}
.bp-ts{flex:0 0 auto;font-size:10.5px;color:var(--dim);white-space:nowrap}
.bp-empty{padding:22px 18px;font-size:12.5px;color:var(--muted);line-height:1.55}
.bp-foot{padding:9px 15px;border-top:1px solid var(--line);font-size:11px;color:var(--dim)}
.bp-foot a{color:var(--brand);text-decoration:none}
.al-toggle{display:flex;align-items:center;gap:8px;font-size:13.5px;font-weight:600;cursor:pointer}
.al-toggle input{accent-color:var(--brand);width:16px;height:16px}

/* cycle panel — market heat + macro tiles */
.cyc{margin-top:14px;padding:18px 20px}
.cyc-grid{display:grid;grid-template-columns:300px 1fr;gap:24px}
.cyc-lab{font-size:11px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--muted)}
.cyc-score{font-size:46px;font-weight:850;line-height:1.1;margin:4px 0 2px;display:flex;align-items:baseline;gap:10px}
.cyc-level{font-size:17px;font-weight:750}
.cyc-meter{position:relative;height:10px;margin:8px 0 4px}
.cyc-zones{display:flex;height:100%;border-radius:999px;overflow:hidden;opacity:.85}
.cyc-zones i{flex:1}
.cyc-zones i:nth-child(1){flex:0 0 25%}.cyc-zones i:nth-child(2){flex:0 0 15%}
.cyc-zones i:nth-child(3){flex:0 0 20%}.cyc-zones i:nth-child(4){flex:0 0 15%}
.cyc-zones i:nth-child(5){flex:0 0 25%}
.cyc-pin{position:absolute;top:-3px;width:4px;height:16px;border-radius:2px;background:var(--text);
  box-shadow:0 0 0 2px var(--panel);transform:translateX(-50%)}
.cyc-zone-labs{display:flex;justify-content:space-between;font-size:9.5px;color:var(--dim);
  text-transform:uppercase;letter-spacing:.05em;line-height:1.25}
.cyc-zone-labs em{font-style:normal;color:var(--muted);text-transform:none;letter-spacing:0}
.cyc-verdict{font-size:13px;color:var(--text);line-height:1.5;margin-top:12px}
.cyc-backdrop{font-size:12.5px;color:var(--muted);margin-top:10px;line-height:1.5}
.cyc-backdrop b.bd-tailwind{color:var(--buy)}
.cyc-backdrop b.bd-headwind{color:var(--sell)}
.cyc-backdrop b.bd-neutral{color:var(--hold)}
.bd-parts{display:flex;flex-wrap:wrap;gap:5px 7px;margin-top:7px}
.bd-part{font-size:11px;color:var(--muted);background:var(--panel-2);border:1px solid var(--line);
  border-radius:999px;padding:3px 9px;white-space:nowrap;cursor:default}
.bd-part b{color:var(--text);font-weight:650}
.bd-part.st-good b{color:var(--buy)}
.bd-part.st-bad b{color:var(--sell)}
.cyc-tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:9px;align-content:start}
.ctile{background:var(--panel-2);border:1px solid var(--line);border-radius:11px;padding:9px 11px;cursor:default;overflow:hidden}
.ctile .ct-name::before{content:'';display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:6px;vertical-align:1px;background:var(--dim)}
.ctile.st-good .ct-name::before{background:var(--buy)}
.ctile.st-warn .ct-name::before{background:var(--hold)}
.ctile.st-bad .ct-name::before{background:var(--sell)}
.ct-top{display:flex;justify-content:space-between;align-items:center;gap:6px}
.ct-name{font-size:10.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--muted)}
.ct-spark{flex:0 1 auto;min-width:0}  /* shrink inside narrow tiles instead of bleeding past the border */
.ct-val{font-size:16px;font-weight:800;margin-top:2px}
.ct-note{font-size:10.5px;color:var(--dim);line-height:1.35;margin-top:2px;display:-webkit-box;
  -webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
@media(max-width:760px){.cyc-grid{grid-template-columns:1fr}}

/* market picture chart (dashboard) */
.mchart{padding:16px 18px}
.mchart-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:8px}
.mchart-sub{font-size:12.5px;color:var(--muted)}
.mchart-sub b{color:var(--text)}
.mchart-sub b.up{color:var(--buy)}
.mchart-sub b.down{color:var(--sell)}
.mchart-actions{display:flex;align-items:center;gap:12px}
.mchart-actions a{font-size:12.5px;color:var(--brand);text-decoration:none;white-space:nowrap}
.mchart-note{font-size:11.5px;color:var(--dim);line-height:1.5;margin-top:8px}
.mchart-note b{color:var(--muted)}
@media(max-width:560px){.mchart-head{flex-direction:column}}

/* P5 — ballast prompt (sibling of .compass within #compass-wrap) */
.ballast{display:flex;gap:13px;align-items:flex-start;margin-top:12px;padding:14px 16px;border-radius:14px;
  background:var(--panel);border:1px solid var(--line-2)}
.ballast-ico{font-size:20px;line-height:1.3;color:var(--brand)}
.ballast-txt b{display:block;font-size:13.5px;margin-bottom:2px;color:var(--text)}
.ballast-txt span{font-size:13px;color:var(--muted);line-height:1.5}
/* tape check — the froth gauge surfaced at the point of decision (Opportunities /
   Undervalued): a good stock ≠ a good time */
.tape-check{display:flex;gap:22px;align-items:center;margin:0 0 14px;padding:14px 16px;border-radius:14px;
  background:var(--panel);border:1px solid var(--line-2)}
.tape-check.hot{background:color-mix(in srgb,var(--hold) 9%,transparent);border-color:color-mix(in srgb,var(--hold) 32%,transparent)}
.tape-main{flex:1;min-width:0}
.tape-main > b{display:block;font-size:13.5px;margin-bottom:2px;color:var(--text)}
.tape-main span{font-size:13px;color:var(--muted);line-height:1.5}
.tape-check .froth{flex:0 0 190px}
.size-chip{font-size:11px;font-weight:600;color:var(--muted);border:1px solid var(--line-2);
  border-radius:999px;padding:3px 9px;white-space:nowrap;cursor:default}
.size-chip.trim{color:var(--hold);border-color:color-mix(in srgb,var(--hold) 35%,transparent)}
/* P1 — universe caveat + rank-any-ticker box */
/* informational fine print — deliberately NEUTRAL, not amber: caution washes on
   every page made the whole app read yellow. Amber stays reserved for panels
   that actually warn (.trim-flag, .conc-warn, .doc .warn). */
.caveat{padding:12px 15px;border-radius:12px;font-size:13px;line-height:1.5;color:var(--muted);margin:0 0 14px;
  background:var(--panel);border:1px solid var(--line-2)}
.caveat b{color:var(--text)}
.caveat.soft{border-color:var(--line)}
.caveat.soft b{color:var(--text)}
/* active 5-day selloff chip — the tape disagreeing with the thesis */
.r5-chip{display:inline-block;padding:2px 8px;border-radius:999px;font-size:10.5px;font-weight:750;letter-spacing:.02em;
  background:color-mix(in srgb,var(--sell) 13%,transparent);border:1px solid color-mix(in srgb,var(--sell) 35%,transparent);color:var(--sell);white-space:nowrap;cursor:default}
/* methodology label glossary */
.label-gloss{padding:6px 16px}
.lg-row{display:flex;align-items:center;gap:12px;padding:9px 0;border-bottom:1px solid var(--line);font-size:13px;color:var(--muted)}
.lg-row:last-child{border-bottom:none}
.lg-row .badge{flex:0 0 112px;justify-content:center}
.rankbox{padding:14px 16px;margin-bottom:14px}
.rankbox-in{display:flex;gap:10px}
.rankbox-in input{flex:1;padding:10px 13px;border-radius:10px;background:var(--panel-2);border:1px solid var(--line-2);
  color:var(--text);font:inherit;font-size:14px;outline:none}
.rankbox-in input:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--ring)}
.rankbox-in button{padding:10px 18px;border-radius:10px;border:1px solid var(--gold-edge);background:var(--gold-grad);
  box-shadow:var(--gold-hi);color:var(--ink-on-gold);font:inherit;font-weight:700;font-size:13.5px;cursor:pointer;transition:.15s}
.rankbox-in button:hover{filter:brightness(1.08)}
.rankbox-out{margin-top:11px}
.rank-res{cursor:pointer}
.rank-main{font-size:15px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.rank-score{font-size:13px;color:var(--muted);margin-top:4px}
.rank-pill{margin-left:6px;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600}
.rank-pill.in{background:var(--buy-dim);color:var(--buy)}
.rank-pill.out{background:var(--line-2);color:var(--muted)}
/* P4 — top-N vs QQQ benchmark */
.bench{padding:15px 17px;margin-bottom:16px}
.bench-head{font-size:14px;font-weight:700;margin-bottom:12px}
.bench-head .muted{font-weight:400;font-size:12.5px}
.bench-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}
.bm-col{padding:12px 14px;border-radius:11px;background:var(--panel-2);border:1px solid var(--line)}
.bm-win{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:600;margin-bottom:6px}
.bm-v{font-size:14px;color:var(--text)}
.bm-x{font-size:12.5px;font-weight:700;margin-top:5px}
.bench-caveat{font-size:11.5px;color:var(--dim);line-height:1.5;margin-top:11px;font-style:italic}
/* P2 — concentration & correlation */
.conc-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:14px 0 16px}
.conc-stat{text-align:center;padding:11px;border-radius:11px;background:var(--panel-2);border:1px solid var(--line)}
.conc-stat .v{font-size:21px;font-weight:800}
.conc-stat .v.warn{color:var(--hold)}
.conc-stat .l{font-size:11.5px;color:var(--muted);margin-top:2px}
.conc-bar{display:flex;height:13px;border-radius:7px;overflow:hidden;background:var(--line-2)}
.conc-seg{height:100%}
.conc-legend{display:flex;flex-wrap:wrap;gap:7px 15px;margin-top:11px}
.conc-key{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:6px}
.conc-key i{width:10px;height:10px;border-radius:3px;display:inline-block}
.conc-key b{color:var(--text)}
.conc-warn{margin-top:13px;padding:11px 14px;border-radius:10px;font-size:13px;line-height:1.5;
  background:color-mix(in srgb,var(--hold) 9%,transparent);border:1px solid color-mix(in srgb,var(--hold) 22%,transparent);color:var(--warn-ink)}
.conc-ok{margin-top:13px;font-size:13px;color:var(--buy)}
/* P6 — forward / earnings chips on opportunity rows */
.fwd-chip{display:inline-block;padding:1px 7px;border-radius:999px;font-size:10.5px;font-weight:600;
  background:var(--panel-2);border:1px solid var(--line-2);color:var(--muted);white-space:nowrap}
.fwd-chip.ern{background:color-mix(in srgb,var(--hold) 14%,transparent);border-color:color-mix(in srgb,var(--hold) 28%,transparent);color:var(--hold)}
/* relative-strength chip — leader/laggard at a glance */
.rs-chip{display:inline-block;padding:1px 7px;border-radius:999px;font-size:10.5px;font-weight:650;
  background:var(--panel-2);border:1px solid var(--line-2);color:var(--muted);white-space:nowrap}
.rs-chip.hi{background:color-mix(in srgb,var(--buy) 12%,transparent);border-color:color-mix(in srgb,var(--buy) 26%,transparent);color:var(--buy)}
.rs-chip.lo{background:color-mix(in srgb,var(--sell) 10%,transparent);border-color:color-mix(in srgb,var(--sell) 24%,transparent);color:var(--sell)}
/* opportunity tier chip — explains the tier-first ranking */
.tier-chip{display:inline-block;padding:1px 7px;border-radius:999px;font-size:10.5px;font-weight:650;
  text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}
.tier-chip.t3{background:color-mix(in srgb,var(--buy) 12%,transparent);border:1px solid color-mix(in srgb,var(--buy) 26%,transparent);color:var(--buy)}
.tier-chip.t2{background:color-mix(in srgb,var(--brand-2) 10%,transparent);border:1px solid color-mix(in srgb,var(--brand-2) 24%,transparent);color:var(--brand-2)}
@media(max-width:560px){.conc-stats{grid-template-columns:1fr}.froth{margin-left:0;width:100%}}

/* ───────────── desktop sidebar (app shell only — body.app) ───────────── */
@media(min-width:1080px){
  body.app .topbar{
    position:fixed;top:0;left:0;bottom:0;width:232px;z-index:50;
    flex-direction:column;align-items:stretch;gap:18px;
    padding:22px 16px 16px;
    border-bottom:none;border-right:1px solid var(--line);
    background:color-mix(in srgb,var(--panel) 55%,var(--bg));
    backdrop-filter:none;-webkit-backdrop-filter:none;
    overflow-y:auto;
  }
  body.app .brand{padding:0 6px}
  body.app .search{max-width:none;flex:none}
  body.app #search-input{font-size:13.5px;padding:10px 14px 10px 38px}
  body.app .nav{flex-direction:column;gap:3px}
  body.app .nav a{padding:9px 12px;font-size:13.5px;border-radius:9px}
  body.app .nav a.active{background:var(--panel-2);box-shadow:inset 0 0 0 1px var(--line)}
  body.app .nav-icons{margin-top:auto;justify-content:space-between;border-top:1px solid var(--line);padding-top:12px}
  body.app main{margin:0 0 0 232px;max-width:1400px}
  body.app .foot{margin-left:232px}
  body.app .bell-panel{top:auto;bottom:14px;left:244px;right:auto}
}

/* ───────────── density pass (app shell only) — more data per screen ───────────── */
body.app{font-size:14px;line-height:1.5}
body.app main{padding:clamp(14px,2vw,26px)}
body.app .grid{gap:10px}
body.app .sec-head{margin:22px 4px 10px}
body.app .section-title{font-size:11.5px;margin-bottom:10px}
body.app .stat{padding:12px 14px}
body.app .stat .v{font-size:23px}
body.app .stat-row{gap:10px;margin:12px 0}
body.app .compass{padding:16px 18px;gap:16px}
body.app .compass-ico{width:46px;height:46px;border-radius:11px;font-size:22px}
body.app .compass-main .reg{font-size:21px}
body.app .compass-main .desc{font-size:13px}
body.app .ballast{padding:10px 13px;margin-top:9px}
body.app .ballast-txt span{font-size:12.5px}
body.app .cyc{padding:13px 15px;margin-top:10px}
body.app .cyc-score{font-size:34px}
body.app .cyc-level{font-size:14.5px}
body.app .cyc-grid{grid-template-columns:270px 1fr;gap:16px}
@media(max-width:760px){body.app .cyc-grid{grid-template-columns:1fr}}  /* keep the mobile stack — the 270px split overflows phones */
body.app .cyc-tiles{gap:7px;grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}
body.app .ctile{padding:7px 9px}
body.app .ctile .ct-val{font-size:14.5px}
body.app .gmkt{gap:9px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}
body.app .gmkt-card{padding:10px 12px;gap:4px}
body.app .gmkt-card .gm-px{font-size:19px}
body.app .changed{gap:9px}
body.app .changed-col{padding:11px 13px}
body.app .chg-item{padding:6px 0}
body.app .mchart{padding:12px 14px}
body.app .mchart-note,body.app .legend{font-size:11px}
body.app .cards{grid-template-columns:repeat(auto-fill,minmax(190px,1fr))}
body.app .tcard{padding:11px 13px}
body.app .tcard .px{margin-top:9px}
body.app .tcard .tsig{margin-top:8px}
body.app .badge{font-size:11.5px;padding:4px 9px}
body.app .wtable{font-size:13px}
body.app .wtable td{padding:8px 10px}
body.app .wtable th{padding:8px 10px;font-size:11px}
body.app .opp-row{padding:10px 12px;gap:11px}
body.app .alloc-row,body.app .alloc-cash{padding:10px 12px}
body.app .buy-card{padding:12px 14px}
body.app .risk-card{padding:12px 14px}
body.app .risk-grid{gap:10px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}
body.app .theme-grid{gap:10px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}
body.app .tbasket{padding:13px 15px}
body.app .reco{padding:15px 16px}
body.app .reco-badge{font-size:24px}
body.app .reco-stats div{padding:9px 11px}
body.app .metric{padding:10px 12px}
body.app .metric .v{font-size:19px}
body.app .bt{padding:14px 16px}
body.app .fund{padding:15px 16px}
body.app .hero{padding:24px 16px 8px}
body.app .hero p{font-size:15px;margin-top:10px}
body.app .foot{padding:16px clamp(16px,4vw,40px);margin-top:24px}

/* ───────────── daily briefing (dashboard) ───────────── */
.briefing{margin-top:10px;padding:11px 15px 7px}
.bf-head{display:flex;align-items:center;gap:10px;margin-bottom:4px}
.bf-head .bh{display:flex;align-items:center;gap:9px;font-size:11.5px;text-transform:uppercase;letter-spacing:.13em;color:var(--brand);font-weight:700}
.bf-head .bh::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--brand);box-shadow:0 0 0 3px color-mix(in srgb,var(--brand) 18%,transparent)}
.bf-sub{font-size:11px;color:var(--dim)}
.bf-row{display:flex;gap:10px;align-items:flex-start;padding:7px 0}
.bf-row + .bf-row{border-top:1px solid var(--line)}
.bf-lab{flex:0 0 108px;font-size:12px;font-weight:650;color:var(--muted);padding-top:3px;white-space:nowrap}
.bf-lab.up{color:var(--buy)}
.bf-lab.down{color:var(--sell)}
.bf-lab.warn{color:var(--hold)}
.bf-body{display:flex;flex-wrap:wrap;gap:6px;align-items:center;min-width:0}
.bf-chip{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border:1px solid var(--line);border-radius:999px;background:var(--panel-2);font-size:12px;cursor:pointer;line-height:1.4}
.bf-chip b{font-weight:650}
.bf-chip em{font-style:normal;color:var(--dim);font-size:10.5px}
.bf-chip:hover{border-color:color-mix(in srgb,var(--brand) 45%,var(--line))}
.bf-chip.ern.held{box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--brand) 40%,transparent)}
.bf-note{font-size:12px;color:var(--muted)}
.bf-link{color:var(--brand);text-decoration:none}
.bf-link:hover{text-decoration:underline}

/* ───────────── correlation matrix (portfolio) ───────────── */
.conc{padding:14px 16px}
.cmx{padding:14px 16px}
.cm-table{border-collapse:collapse;font-size:11px;font-variant-numeric:tabular-nums}
.cm-table th{font-weight:650;color:var(--muted);padding:3px 6px;text-align:right;font-size:10.5px}
.cm-table tr th:first-child{text-align:left;cursor:pointer}
.cm-c{padding:3px 6px;text-align:right;border:1px solid color-mix(in srgb,var(--line) 60%,transparent);min-width:38px;color:var(--text)}
.cm-diag{color:var(--dim);text-align:center}
.cm-stress{font-size:12.5px;color:var(--muted);margin-top:10px;border-top:1px solid var(--line);padding-top:9px;line-height:1.55}

/* ───────────── regime page (structural backdrop) ───────────── */
.rg-verdict{display:flex;gap:18px;align-items:center;padding:14px 17px;margin:12px 0}
.rg-vmain{flex:0 0 auto;min-width:170px}
.rg-vlab{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--dim)}
.rg-vval{font-size:30px;font-weight:750;line-height:1.15}
.rg-vcount{font-size:11.5px;color:var(--muted)}
.rg-vnote{font-size:13px;color:var(--muted);line-height:1.55;border-left:1px solid var(--line);padding-left:18px}
.rg-tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(215px,1fr));gap:9px;margin:12px 0}
.rg-charts{display:grid;grid-template-columns:repeat(auto-fit,minmax(330px,1fr));gap:12px;margin:14px 0}
.rg-chart{padding:13px 15px}
.rg-sub{font-size:12px;color:var(--muted);line-height:1.5;margin-bottom:8px}
.rg-action{padding:14px 17px;margin-top:4px}
.rg-action p{margin:0;font-size:13px;color:var(--muted);line-height:1.6}
@media(max-width:700px){.rg-verdict{flex-direction:column;align-items:flex-start;gap:8px}.rg-vnote{border-left:none;padding-left:0}}

/* ───────────── base rates (stock page) ───────────── */
.brate{margin-top:14px;padding:15px 16px}
.brate .br-note{margin:2px 0 10px;font-size:12.5px;color:var(--muted)}
.br-block{padding:10px 0 8px;border-top:1px solid var(--line)}
.br-block:first-of-type{border-top:none;padding-top:2px}
.br-head{font-size:12.5px;color:var(--muted);margin-bottom:8px}
.br-head b{color:var(--text)}
.br-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:7px}
.br-stat{background:var(--panel-2);border:1px solid var(--line);border-radius:9px;padding:7px 9px}
.br-stat .k{font-size:10.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--dim)}
.br-stat .v{font-size:15px;font-weight:650;margin-top:2px}
.br-strip{display:block;margin:9px 2px 0;color:var(--muted)}
.br-strip-cap{font-size:10.5px;color:var(--dim);margin-top:3px}
.br-caveat{font-size:11px;color:var(--dim);margin-top:10px;border-top:1px solid var(--line);padding-top:8px}

/* ───────────── pullback map (stock page) ───────────── */
.pbmap{margin-top:14px;padding:15px 16px}
.pbmap .pb-sub{margin:2px 0 10px;font-size:12.5px;color:var(--muted)}
.pbmap .pb-sub b{color:var(--text)}
.pb-rows{display:flex;flex-direction:column;gap:2px}
.pb-row{display:grid;grid-template-columns:48px 1fr 1.3fr;gap:8px;align-items:center;font-size:11px;padding:3px 6px;border:1px solid transparent;border-radius:7px}
.pb-row .d{color:var(--dim);font-variant-numeric:tabular-nums;white-space:nowrap}
.pb-cell{display:flex;align-items:center;gap:6px;min-width:0}
.pb-cell i{height:9px;border-radius:3px;flex:0 1 auto}
.pb-cell em{font-style:normal;font-variant-numeric:tabular-nums;white-space:nowrap;color:var(--muted)}
.pb-depth{justify-content:flex-end}
.pb-depth i{background:var(--brand);opacity:.5}
.pb-out.paid i{background:var(--buy);opacity:.65}
.pb-out.paid em{color:var(--buy)}
.pb-out.broke i{background:var(--sell);opacity:.5}
.pb-out.broke em{color:var(--sell)}
.pb-analog{border-color:var(--line-2);background:var(--panel-2)}
.pb-tag{font-size:9.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--dim);border:1px solid var(--line-2);border-radius:99px;padding:1px 6px;white-space:nowrap}
.pb-out{flex-wrap:wrap;row-gap:1px}
.pb-current{background:var(--hold-dim);border-color:color-mix(in srgb,var(--hold) 38%,transparent)}
.pb-current em{color:var(--hold);white-space:normal;line-height:1.35}
.pb-current .pb-depth i{background:var(--hold);opacity:.6}
.pb-stats{font-size:11.5px;color:var(--muted);margin-top:10px;border-top:1px solid var(--line);padding-top:8px}
.pb-stats b{font-variant-numeric:tabular-nums;color:var(--text)}
.pb-stats b.up{color:var(--buy)}
.pb-engine{font-size:11.5px;color:var(--muted);margin-top:4px}
.pb-engine b{color:var(--text)}

/* ───────────── nav groups (Today / Ideas / Context / Yours) ───────────── */
.nav-group{display:flex;gap:6px;align-items:center}
.nav-lab{display:none}
@media(min-width:1080px){
  body.app .nav-group{flex-direction:column;align-items:stretch;gap:2px;
    padding:9px 6px 7px;border-radius:12px;
    background:color-mix(in srgb,var(--panel-2) 55%,transparent);
    border:1px solid var(--line)}
  body.app .nav-group + .nav-group{margin-top:10px}
  body.app .nav-lab{display:block;font-size:10px;font-weight:700;letter-spacing:.13em;
    text-transform:uppercase;color:var(--dim);padding:0 8px 5px}
  body.app .nav-group a{padding:7px 8px}
}

/* "how it works →" links surfaced where trust is earned */
.how-link{color:var(--brand);font-size:12px;font-weight:600;text-transform:none;letter-spacing:0}
.how-link:hover{text-decoration:underline}

/* trade-plan footer link → journal */
.tp-foot{padding:8px 14px;border-top:1px solid var(--line)}
.tp-foot a{font-size:11.5px;color:var(--brand);font-weight:600}
.tp-foot a:hover{text-decoration:underline}

/* ───────────── toast — background failures get one visible line ───────────── */
#toast{position:fixed;left:50%;bottom:26px;transform:translate(-50%,16px);z-index:300;
  max-width:min(480px,90vw);padding:11px 16px;border-radius:11px;font-size:13px;line-height:1.45;
  background:var(--panel-2);border:1px solid color-mix(in srgb,var(--sell) 40%,transparent);color:var(--text);
  box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:opacity .2s,transform .2s}
#toast.show{opacity:1;transform:translate(-50%,0)}
#toast.ok{border-color:color-mix(in srgb,var(--buy) 40%,transparent)}

/* ───────────── settings tabs + account ───────────── */
.set-tabs{display:flex;gap:8px;margin:4px 0 22px}
.set-tabs button{padding:9px 18px;border-radius:10px;background:var(--panel);border:1px solid var(--line);
  color:var(--muted);cursor:pointer;font-weight:600;font-size:14px;font-family:inherit;transition:.14s}
.set-tabs button:hover{color:var(--text)}
.set-tabs button.active{background:var(--panel-2);color:var(--text);border-color:var(--line-2)}
.acct-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border-radius:12px;overflow:hidden}
.acct-grid>div{background:var(--panel-2);padding:12px 14px}
.acct-grid .k{color:var(--muted);font-size:12px}
.acct-grid .v{font-weight:700;font-size:15px;margin-top:2px;overflow:hidden;text-overflow:ellipsis}
@media(max-width:560px){.acct-grid{grid-template-columns:1fr}}

/* ───────────── earnings calendar ───────────── */
.ern-table .ern-when{white-space:nowrap;color:var(--muted)}
.ern-table .ern-when .hot{color:var(--sell)}
.ern-table .ern-date{white-space:nowrap;font-variant-numeric:tabular-nums}
.ern-held{background:color-mix(in srgb,var(--hold) 4%,transparent)}
.ern-gap{font-size:11px;font-weight:650;color:var(--hold);background:var(--hold-dim);
  border:1px solid color-mix(in srgb,var(--hold) 25%,transparent);border-radius:999px;padding:3px 9px;white-space:nowrap}

/* ───────────── trade journal ───────────── */
.jr-form{display:flex;gap:9px;flex-wrap:wrap;align-items:center;padding:14px 16px}
.jr-form input,.jr-form select{padding:10px 12px;background:var(--bg-2);border:1px solid var(--line-2);
  border-radius:10px;color:var(--text);font-size:13.5px;font-family:inherit;outline:none;min-width:0}
.jr-form input:focus,.jr-form select:focus{border-color:var(--brand)}
.jr-form #jr-sym{flex:0 0 96px;font-weight:700}
.jr-form #jr-qty,.jr-form #jr-price{flex:0 0 104px}
.jr-form #jr-date{flex:0 0 140px;color-scheme:dark}
body.light .jr-form #jr-date{color-scheme:light}
.jr-form #jr-note{flex:1}
@media(max-width:680px){.jr-form input,.jr-form select{flex:1 1 45% !important}.jr-form .btn{flex-basis:100%}}
.jr-side{display:inline-block;padding:3px 10px;border-radius:999px;font-size:11.5px;font-weight:700;white-space:nowrap}
.jr-buy{color:var(--buy);background:var(--buy-dim)}
.jr-add{color:var(--brand-2);background:color-mix(in srgb,var(--brand-2) 13%,transparent)}
.jr-trim{color:var(--hold);background:var(--hold-dim)}
.jr-sell{color:var(--sell);background:var(--sell-dim)}
.jr-table .jr-note{color:var(--muted);font-size:12.5px;max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.jr-table tr{cursor:default}
.jr-del{background:none;border:none;color:var(--dim);cursor:pointer;font-size:14px;padding:4px 6px;border-radius:7px}
.jr-del:hover{color:var(--sell);background:var(--sell-dim)}

/* correlation matrix on phones — keep the cells readable instead of overflowing */
@media(max-width:560px){
  .cm-table{font-size:10px}
  .cm-c{min-width:30px;padding:2px 4px}
}

/* ───────────── trade-plan calculator + EOD note ───────────── */
.tp-calc{padding:9px 14px;border-top:1px solid var(--line);font-size:12px;color:var(--muted);line-height:1.6}
.tp-calc b{color:var(--text)}
.tp-calc b.down{color:var(--sell)}
#tpc-full{width:64px;padding:2px 6px;background:var(--bg-2);border:1px solid var(--line-2);border-radius:7px;
  color:var(--text);font:inherit;font-size:12px;font-weight:700;outline:none;text-align:right;
  font-variant-numeric:tabular-nums}
#tpc-full:focus{border-color:var(--brand)}
.tp-foot{display:flex;justify-content:space-between;align-items:baseline;gap:12px;flex-wrap:wrap}
.tp-eod{font-size:11px;color:var(--dim);line-height:1.5;flex:1;min-width:200px}

/* ───────────── "Your position" (journal → stock page) ───────────── */
.mypos{margin-top:14px;padding:14px 16px}
.mp-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border-radius:11px;overflow:hidden}
.mp-grid>div{background:var(--panel-2);padding:9px 11px}
.mp-grid .k{font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--dim)}
.mp-grid .v{font-size:13.5px;font-weight:700;margin-top:2px;font-variant-numeric:tabular-nums}
.mp-note{font-size:11.5px;color:var(--dim);margin-top:8px;line-height:1.5}
.mp-note a{color:var(--brand);font-weight:600}

/* ───────────── headlines panel (stock page, left column) ─────────────
   Compact two-column grid — context, not a news reader. */
.newsp{margin-top:14px;padding:12px 16px 10px}
.news-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 22px}
@media(max-width:760px){.news-grid{grid-template-columns:1fr}}
.news-it{display:block;padding:7px 2px;border-top:1px solid var(--line);transition:.12s;min-width:0}
.news-it:hover .t{color:var(--brand)}
.news-it .t{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  font-size:12.5px;font-weight:600;line-height:1.4;color:var(--text);transition:.12s}
.news-it .m{display:block;font-size:11px;color:var(--dim);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.news-cav{font-size:11px;color:var(--dim);line-height:1.5;margin-top:8px;border-top:1px solid var(--line);padding-top:7px}

/* ───────────── theme peers (stock page) ───────────── */
.peers{padding:15px 16px}

/* ───────────── "You: …" line on At Risk cards ───────────── */
.risk-mine{margin-top:10px;padding:8px 11px;border-radius:9px;font-size:12px;color:var(--muted);
  background:var(--panel-2);border:1px solid var(--line-2);font-variant-numeric:tabular-nums}
.risk-mine b{font-weight:750}

/* ════════════════════════ The cycle / outlook page ════════════════════════ */
.oc{max-width:1000px}
.oc-anchor{font-family:'Newsreader',Georgia,serif;font-style:italic;color:var(--brand);font-size:18px;margin:2px 0 12px}
.oc-sub{color:var(--muted);font-size:15px;line-height:1.62;max-width:780px;margin-bottom:14px}
.oc h3.oc-h{font-family:'Newsreader',Georgia,serif;font-weight:600;font-size:21px;letter-spacing:-.01em;margin:30px 0 4px}
.oc .oc-hsub{color:var(--dim);font-size:12.5px;margin-bottom:12px}
.oc-curve{padding:16px 8px 10px;text-align:center}
.oc-curve svg{width:100%;height:auto;display:block}
.oc-here-dot{animation:oc-pulse 2.4s ease-in-out infinite;transform-origin:center}
@keyframes oc-pulse{0%,100%{r:6.5;opacity:1}50%{r:10;opacity:.5}}
.oc-conf{display:inline-block;margin-top:8px;text-align:center;font-size:13px}
.oc-conf .v{font-weight:750;color:var(--brand)}
.oc-conf .s{display:block;color:var(--dim);font-size:11.5px;margin-top:1px}
.oc-phases{display:flex;flex-direction:column;gap:12px}
.oc-phase{border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);overflow:hidden}
.oc-phase>summary{list-style:none;cursor:pointer;padding:15px 18px;display:flex;align-items:center;gap:11px;flex-wrap:wrap}
.oc-phase>summary::-webkit-details-marker{display:none}
.oc-phase .nm{font-weight:700;font-size:16.5px}
.oc-phase .hz{color:var(--dim);font-size:12px;margin-left:auto;text-align:right}
.oc-tag{font-size:10px;font-weight:750;letter-spacing:.07em;padding:3px 8px;border-radius:999px;text-transform:uppercase}
.oc-tag.t-now{color:var(--brand);background:color-mix(in srgb,var(--brand) 16%,transparent)}
.oc-tag.t-next{color:#e2a64f;background:color-mix(in srgb,#e2a64f 18%,transparent)}
.oc-tag.t-past{color:var(--dim);background:var(--panel-2)}
.oc-tag.t-future{color:var(--muted);background:var(--panel-2)}
.oc-body{padding:0 18px 16px}
.oc-wh{color:var(--muted);font-size:13.5px;line-height:1.55;margin-bottom:11px}
.oc-mnote{color:var(--dim);font-style:italic;font-size:12.5px;margin-top:11px;line-height:1.5}
.oc-themes{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:11px}
.oc-themes span{font-size:11px;color:var(--muted);background:var(--panel-2);border:1px solid var(--line);border-radius:6px;padding:3px 8px}
.oc-now{border-color:color-mix(in srgb,var(--brand) 45%,var(--line));box-shadow:0 0 0 1px color-mix(in srgb,var(--brand) 20%,transparent),var(--elev)}
.oc-next{border-color:color-mix(in srgb,#e2a64f 40%,var(--line))}
.oc-past>summary .nm,.oc-future>summary .nm{color:var(--muted)}
.oc-future{border-style:dashed;opacity:.85}
.oc-chips{display:flex;flex-wrap:wrap;gap:6px}
.oc-chip{display:inline-flex;align-items:center;gap:6px;padding:3px 9px 3px 8px;border:1px solid var(--line);border-radius:999px;background:var(--panel-2);font-size:12.5px;cursor:pointer;line-height:1.4;transition:.14s}
.oc-chip:hover{border-color:color-mix(in srgb,var(--brand) 50%,var(--line));background:var(--panel)}
.oc-chip b{font-weight:680}
.oc-chip .dot{width:6px;height:6px;border-radius:50%;flex:none}
.oc-chip .sg{font-size:10px;color:var(--dim)}
.oc-chip.s-buy .dot{background:var(--buy)}.oc-chip.s-buy .sg{color:var(--buy)}
.oc-chip.s-hold .dot{background:var(--hold)}.oc-chip.s-hold .sg{color:var(--hold)}
.oc-chip.s-sell .dot{background:var(--sell)}.oc-chip.s-sell .sg{color:var(--sell)}
.oc-chip.s-none .dot{background:var(--dim)}
.oc-rot{display:flex;gap:6px;flex-wrap:wrap;align-items:stretch;margin:4px 0 12px}
.oc-seg{flex:1 1 175px;border:1px solid var(--line);border-radius:12px;padding:12px;background:var(--panel-2)}
.oc-seg.now{border-color:color-mix(in srgb,var(--brand) 40%,var(--line))}
.oc-seg.later{border-style:dashed;opacity:.9}
.oc-seg .sh{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:8px}
.oc-seg.now .sh{color:var(--brand)}
.oc-seg.later .sh{color:#e2a64f}
.oc-arrow{align-self:center;color:var(--dim);font-size:16px;flex:none}
.oc-flags{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.oc-flags span{font-size:11.5px;color:var(--dim);background:var(--panel-2);border:1px solid var(--line);border-radius:7px;padding:4px 9px}
.oc-case{border:1px solid var(--line);border-radius:12px;padding:14px 16px;background:var(--panel-2);margin-top:12px}
.oc-case h4{font-size:13px;font-weight:700;margin-bottom:4px}
.oc-case .arc{display:flex;flex-wrap:wrap;gap:7px;align-items:center;color:var(--muted);font-size:12px;margin:9px 0 6px}
.oc-case .arc b{color:var(--text);font-weight:650}
.oc-case .arc .a{color:var(--dim)}
.oc-case p{color:var(--muted);font-size:12.5px;line-height:1.5;margin-top:6px}
.oc-scenbar{display:flex;height:30px;border-radius:8px;overflow:hidden;border:1px solid var(--line)}
.oc-scenbar i{display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:750;color:#16130f;white-space:nowrap;min-width:0}
.oc-scens{display:flex;flex-direction:column;gap:10px;margin-top:12px}
.oc-scen{border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;background:var(--panel)}
.oc-scen.bear{border-color:color-mix(in srgb,var(--sell) 30%,var(--line))}
.oc-scen .top{display:flex;align-items:baseline;gap:11px}
.oc-scen .pct{font-weight:800;font-size:23px;color:var(--brand);font-variant-numeric:tabular-nums;flex:none}
.oc-scen.bear .pct{color:var(--sell)}
.oc-scen .snm{font-weight:700;font-size:15px}
.oc-scen .ds{color:var(--muted);font-size:13px;line-height:1.5;margin:8px 0 10px}
.oc-row{margin-top:7px}
.oc-row .lab{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-bottom:5px}
.oc-row.ben .lab{color:var(--buy)}
.oc-row.lag .lab{color:var(--sell)}
.oc-future-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(265px,1fr));gap:12px;margin-top:12px}
.oc-wave{border:1px solid var(--line);border-radius:12px;padding:13px 15px;background:var(--panel)}
.oc-wave .wn{font-weight:700;font-size:14px}
.oc-wave .gate{color:var(--dim);font-size:11.5px;margin:3px 0 9px}
.oc-soft{opacity:.92}
/* live rotation overlay */
.oc-live{margin-top:10px;font-size:12px;color:var(--brand);background:color-mix(in srgb,var(--brand) 9%,transparent);border:1px solid color-mix(in srgb,var(--brand) 24%,transparent);border-radius:8px;padding:7px 11px;line-height:1.45;text-align:left}
.oc-rotgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(215px,1fr));gap:16px}
.oc-rl{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:9px;display:flex;align-items:center;gap:6px}
.oc-rl:before{content:'';width:8px;height:8px;border-radius:50%;flex:none}
.oc-rl.lead{color:var(--brand)}.oc-rl.lead:before{background:var(--brand)}
.oc-rl.emerg{color:var(--buy)}.oc-rl.emerg:before{background:var(--buy)}
.oc-rl.cool{color:var(--muted)}.oc-rl.cool:before{background:var(--dim)}
.oc-lchips{display:flex;flex-direction:column;gap:6px}
.oc-lchip{display:inline-flex;align-items:center;gap:8px;padding:5px 10px;border:1px solid var(--line);border-radius:9px;background:var(--panel-2);font-size:12.5px;cursor:pointer;transition:.14s}
.oc-lchip:hover{border-color:var(--brand);background:var(--panel)}
.oc-lchip b{font-weight:620;flex:1}
.oc-lchip .rs{font-variant-numeric:tabular-nums;color:var(--muted);font-size:11.5px}
.oc-lchip .tr{font-weight:700;color:var(--dim);width:10px;text-align:center}
.oc-lchip.st-leading{border-color:color-mix(in srgb,var(--brand) 40%,var(--line))}.oc-lchip.st-leading .tr{color:var(--brand)}
.oc-lchip.st-emerging{border-color:color-mix(in srgb,var(--buy) 38%,var(--line))}.oc-lchip.st-emerging .tr{color:var(--buy)}
.oc-lchip.st-cooling .tr{color:var(--sell)}
.oc-none{color:var(--dim);font-size:12px;font-style:italic}
.oc-lanetag{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:2px 6px;border-radius:6px;margin-left:7px;white-space:nowrap}
.oc-lanetag.lt-leading{color:var(--brand);background:color-mix(in srgb,var(--brand) 15%,transparent)}
.oc-lanetag.lt-emerging{color:var(--buy);background:var(--buy-dim)}
.oc-lanetag.lt-cooling{color:var(--sell);background:var(--sell-dim)}
.oc-lanetag.lt-steady{color:var(--dim);background:var(--panel-2)}

/* ── cycle page: colour system + motion ── */
.oc{--oc-p0:#9079e6;--oc-p1:#eba63a;--oc-p2:#36b8a0;--oc-p3:#56a6e8;--oc-p4:#dd77b4}
.oc-curve{position:relative;overflow:hidden;background:
  radial-gradient(120% 80% at 50% 0%, color-mix(in srgb,var(--oc-p1) 7%,transparent), transparent 70%)}
.oc-draw{stroke-dasharray:980;stroke-dashoffset:980;animation:oc-draw 1.9s cubic-bezier(.4,0,.2,1) .15s forwards}
@keyframes oc-draw{to{stroke-dashoffset:0}}
.oc-fadein{opacity:0;animation:oc-fade 1.3s ease forwards}
@keyframes oc-fade{to{opacity:1}}
.oc-wavg path{animation:oc-drift 14s linear infinite}
.oc-wavg path:nth-child(2){animation-duration:20s;animation-direction:reverse}
@keyframes oc-drift{to{transform:translateX(-200px)}}
.oc-here-dot{filter:drop-shadow(0 0 7px currentColor)}
.oc-flow{animation:oc-flowfade 1s ease forwards .9s;opacity:0}
@keyframes oc-flowfade{to{opacity:.9}}
.oc-plabel{cursor:pointer;transition:.15s}
.oc-plabel:hover,.oc-plabel.hot{font-weight:700}
/* phase-coloured cards (no left bar, per the design system: colour lives in the
   tag, the name dot, and a soft glow) */
.oc-phase .nm:before{content:'';display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:9px;vertical-align:middle;background:var(--pc,var(--dim))}
.oc-phase[data-phase="0"]{--pc:var(--oc-p0)}.oc-phase[data-phase="1"]{--pc:var(--oc-p1)}
.oc-phase[data-phase="2"]{--pc:var(--oc-p2)}.oc-phase[data-phase="3"]{--pc:var(--oc-p3)}
.oc-phase[data-phase="4"]{--pc:var(--oc-p4)}
.oc-phase{transition:box-shadow .18s,border-color .18s,transform .18s}
.oc-phase:hover,.oc-phase.hot{border-color:color-mix(in srgb,var(--pc) 55%,var(--line));box-shadow:0 0 0 1px color-mix(in srgb,var(--pc) 26%,transparent),0 10px 30px -16px color-mix(in srgb,var(--pc) 70%,transparent)}
.oc-now{border-color:color-mix(in srgb,var(--pc) 50%,var(--line));box-shadow:0 0 0 1px color-mix(in srgb,var(--pc) 24%,transparent),0 12px 34px -18px color-mix(in srgb,var(--pc) 75%,transparent)}
.oc-tag.t-now{color:var(--oc-p1);background:color-mix(in srgb,var(--oc-p1) 18%,transparent)}
.oc-tag.t-next{color:var(--oc-p2);background:color-mix(in srgb,var(--oc-p2) 18%,transparent)}
.oc-phase[data-phase="3"] .oc-tag,.oc-phase[data-phase="4"] .oc-tag{color:var(--pc);background:color-mix(in srgb,var(--pc) 16%,transparent)}
.oc-mnote{border-left:2px solid color-mix(in srgb,var(--pc,var(--dim)) 45%,transparent);padding-left:11px}
/* scenario bar fill animation */
.oc-scenbar i{transform-origin:left;animation:oc-grow .9s cubic-bezier(.3,0,.2,1) forwards;transform:scaleX(0)}
@keyframes oc-grow{to{transform:scaleX(1)}}
/* research / further reading */
.oc-reads{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;margin-top:12px}
.oc-read{display:block;border:1px solid var(--line);border-radius:12px;padding:13px 15px;background:var(--panel);text-decoration:none;transition:.16s;position:relative}
.oc-read:hover{border-color:color-mix(in srgb,var(--brand) 45%,var(--line));background:var(--panel-2);transform:translateY(-2px)}
.oc-read .rt{font-weight:650;font-size:13.5px;color:var(--text);display:flex;align-items:center;gap:7px}
.oc-read .rt .ext{margin-left:auto;color:var(--dim);font-size:12px}
.oc-read .rs2{color:var(--muted);font-size:12px;line-height:1.45;margin-top:5px}
.oc-read .src{color:var(--dim);font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;margin-top:7px}
/* capability clock (the demand axis) */
.oc-capsteps{display:flex;gap:6px;flex-wrap:wrap;align-items:stretch;margin:8px 0 12px}
.oc-capstep{flex:1 1 205px;border:1px solid var(--line);border-top:2px solid var(--ac,var(--oc-p2));border-radius:0 0 12px 12px;padding:12px 14px;background:linear-gradient(180deg,color-mix(in srgb,var(--ac,var(--oc-p2)) 7%,var(--panel)),var(--panel))}
.oc-capstep .cn{font-weight:700;font-size:14px}
.oc-capstep .ch{font-size:11px;color:var(--ac,var(--oc-p2));font-weight:650;margin:2px 0 8px;text-transform:uppercase;letter-spacing:.03em}
.oc-capstep .cnote{color:var(--muted);font-size:12px;line-height:1.45}
/* entrance stagger for cards + chips (visible-tab friendly; off for reduced motion) */
.oc-rise{opacity:0;transform:translateY(8px);animation:oc-rise .55s ease forwards}
@keyframes oc-rise{to{opacity:1;transform:none}}
@media (prefers-reduced-motion: reduce){
  .oc-draw,.oc-fadein,.oc-flow,.oc-wavg path,.oc-scenbar i,.oc-rise,.oc-here-dot{animation:none!important;opacity:1!important;transform:none!important;stroke-dashoffset:0!important}
}
