/* ══════════════════════════════════════════════════════
   Financial Monitor — Design System
   4 themes: linen (default) · pure · aurora · slate
══════════════════════════════════════════════════════ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

body {
  font-family: -apple-system, BlinkMacSystemFont, "SF Pro Display", "Helvetica Neue", Arial, sans-serif;
  min-height: 100vh;
  transition: background 0.3s, color 0.3s;
  -webkit-font-smoothing: antialiased;
}

/* ── LINEN (default) ── */
body, body.linen {
  background: #ede8e0; color: #1a1714;
  --accent: #d4a853; --accent-dim: rgba(212,168,83,0.13);
  --card-bg: #faf8f5; --card-border: #e8e3dc;
  --card-shadow: 0 1px 4px rgba(0,0,0,0.04), 0 6px 24px rgba(0,0,0,0.07);
  --card-hover: 0 4px 16px rgba(0,0,0,0.08), 0 12px 40px rgba(0,0,0,0.09);
  --nav-bg: rgba(250,248,245,0.88); --nav-border: #ddd8d0;
  --divider: #ece7e0;
  --text-1: #1a1714; --text-2: #8a8480; --text-3: #a09a93;
  --chip-up-bg: rgba(52,180,90,0.10); --chip-up-c: #1e6b3a;
  --chip-dn-bg: rgba(210,55,45,0.10); --chip-dn-c: #9e2b23;
  --chip-nt-bg: rgba(160,154,147,0.10); --chip-nt-c: #6e6860;
  --green: #34b45a; --red: #d2372d; --orange: #d4a853;
  --strip-bg: #1a1714; --strip-c: rgba(255,255,255,0.82);
  --btn-bg: #1a1714; --btn-c: #faf8f5; --btn-accent: #d4a853;
  --val-na: #f0ece6; --track: #ece7e0;
  --toggle-on-bg: #1a1714; --toggle-on-c: #faf8f5;
  --input-bg: rgba(0,0,0,0.05);
  --card-hdr-bg: linear-gradient(135deg, rgba(212,168,83,0.07) 0%, transparent 55%);
  --card-top: linear-gradient(90deg, #d4a853, transparent 60%);
  --sw-bg: rgba(0,0,0,0.07); --sw-act: #faf8f5; --sw-act-c: #1a1714;
}

/* ── PURE ── */
body.pure {
  background: #f2f2f7; color: #1d1d1f;
  --accent: #0071e3; --accent-dim: rgba(0,113,227,0.10);
  --card-bg: #ffffff; --card-border: transparent;
  --card-shadow: 0 2px 8px rgba(0,0,0,0.06), 0 8px 32px rgba(0,0,0,0.07);
  --card-hover: 0 4px 16px rgba(0,0,0,0.09), 0 16px 48px rgba(0,0,0,0.09);
  --nav-bg: rgba(255,255,255,0.88); --nav-border: rgba(0,0,0,0.08);
  --divider: #e5e5ea;
  --text-1: #1d1d1f; --text-2: #6e6e73; --text-3: #8e8e93;
  --chip-up-bg: rgba(52,199,89,0.10); --chip-up-c: #1d7a3a;
  --chip-dn-bg: rgba(255,59,48,0.10); --chip-dn-c: #c0392b;
  --chip-nt-bg: rgba(142,142,147,0.10); --chip-nt-c: #636366;
  --green: #34c759; --red: #ff3b30; --orange: #ff9f0a;
  --strip-bg: #1d1d1f; --strip-c: rgba(255,255,255,0.82);
  --btn-bg: #0071e3; --btn-c: #ffffff; --btn-accent: transparent;
  --val-na: #f5f5f7; --track: #e5e5ea;
  --toggle-on-bg: #1d1d1f; --toggle-on-c: #ffffff;
  --input-bg: rgba(0,0,0,0.05);
  --card-hdr-bg: linear-gradient(135deg, rgba(0,113,227,0.05) 0%, transparent 55%);
  --card-top: linear-gradient(90deg, #0071e3, transparent 60%);
  --sw-bg: rgba(0,0,0,0.07); --sw-act: #ffffff; --sw-act-c: #1d1d1f;
}

/* ── AURORA (dark · green) ── */
body.aurora {
  background: #08080d; color: #f5f5f7;
  --accent: #30d158; --accent-dim: rgba(48,209,88,0.13);
  --card-bg: #0f0f16; --card-border: rgba(255,255,255,0.07);
  --card-shadow: 0 2px 12px rgba(0,0,0,0.4), 0 8px 32px rgba(0,0,0,0.5);
  --card-hover: 0 4px 20px rgba(0,0,0,0.5), 0 12px 40px rgba(0,0,0,0.55);
  --nav-bg: rgba(10,10,16,0.9); --nav-border: rgba(255,255,255,0.07);
  --divider: rgba(255,255,255,0.07);
  --text-1: #f5f5f7; --text-2: #8e8e93; --text-3: #636366;
  --chip-up-bg: rgba(48,209,88,0.14); --chip-up-c: #30d158;
  --chip-dn-bg: rgba(255,69,58,0.14); --chip-dn-c: #ff453a;
  --chip-nt-bg: rgba(99,99,102,0.20); --chip-nt-c: #8e8e93;
  --green: #30d158; --red: #ff453a; --orange: #ffd60a;
  --strip-bg: #000000; --strip-c: rgba(255,255,255,0.75);
  --btn-bg: #30d158; --btn-c: #000000; --btn-accent: transparent;
  --val-na: rgba(99,99,102,0.16); --track: rgba(255,255,255,0.09);
  --toggle-on-bg: rgba(255,255,255,0.12); --toggle-on-c: #f5f5f7;
  --input-bg: rgba(255,255,255,0.07);
  --card-hdr-bg: linear-gradient(135deg, rgba(48,209,88,0.08) 0%, transparent 55%);
  --card-top: linear-gradient(90deg, #30d158, transparent 60%);
  --sw-bg: rgba(255,255,255,0.08); --sw-act: rgba(255,255,255,0.14); --sw-act-c: #f5f5f7;
}

/* ── SLATE (dark · indigo) ── */
body.slate {
  background: #07070f; color: #f5f5f7;
  --accent: #5e5ce6; --accent-dim: rgba(94,92,230,0.14);
  --card-bg: #0d0d18; --card-border: rgba(94,92,230,0.15);
  --card-shadow: 0 2px 12px rgba(0,0,0,0.45), 0 8px 32px rgba(0,0,0,0.5);
  --card-hover: 0 4px 20px rgba(0,0,0,0.55), 0 12px 40px rgba(0,0,0,0.6);
  --nav-bg: rgba(9,9,20,0.92); --nav-border: rgba(94,92,230,0.14);
  --divider: rgba(255,255,255,0.07);
  --text-1: #f5f5f7; --text-2: #8e8e93; --text-3: #636366;
  --chip-up-bg: rgba(48,209,88,0.13); --chip-up-c: #30d158;
  --chip-dn-bg: rgba(255,69,58,0.13); --chip-dn-c: #ff453a;
  --chip-nt-bg: rgba(99,99,102,0.18); --chip-nt-c: #8e8e93;
  --green: #30d158; --red: #ff453a; --orange: #bf5af2;
  --strip-bg: #04040d; --strip-c: rgba(255,255,255,0.75);
  --btn-bg: #5e5ce6; --btn-c: #ffffff; --btn-accent: transparent;
  --val-na: rgba(99,99,102,0.15); --track: rgba(255,255,255,0.08);
  --toggle-on-bg: rgba(94,92,230,0.25); --toggle-on-c: #c7c7ff;
  --input-bg: rgba(255,255,255,0.06);
  --card-hdr-bg: linear-gradient(135deg, rgba(94,92,230,0.09) 0%, transparent 55%);
  --card-top: linear-gradient(90deg, #5e5ce6, transparent 60%);
  --sw-bg: rgba(255,255,255,0.07); --sw-act: rgba(255,255,255,0.12); --sw-act-c: #f5f5f7;
}

/* ── FAIR colour per theme ── */
.vc.fair { background: rgba(212,168,83,0.12); color: #7a5a10; }
body.pure  .vc.fair { background: rgba(255,159,10,0.09); color: #b36200; }
body.aurora .vc.fair { background: rgba(255,214,10,0.12); color: #ffd60a; }
body.slate  .vc.fair { background: rgba(191,90,242,0.12); color: #bf5af2; }
.c-hold { color: #7a5a10; }
body.pure  .c-hold { color: #b36200; }
body.aurora .c-hold, body.slate .c-hold { color: var(--orange); }

/* ══════════════════════════════════════════════════════
   NAV
══════════════════════════════════════════════════════ */
nav {
  position: sticky; top: 0; z-index: 200;
  background: var(--nav-bg); border-bottom: 1px solid var(--nav-border);
  backdrop-filter: blur(24px) saturate(180%);
  -webkit-backdrop-filter: blur(24px) saturate(180%);
  height: 56px; display: flex; align-items: center;
  padding: 0 28px; gap: 14px;
}
.nav-brand {
  font-size: 15px; font-weight: 800; letter-spacing: -0.3px;
  color: var(--text-1); display: flex; align-items: center; gap: 7px;
  text-decoration: none; flex-shrink: 0;
}
.nav-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--accent); }
.nav-search {
  display: flex; align-items: center; gap: 7px;
  background: var(--input-bg); border-radius: 10px;
  padding: 7px 12px; max-width: 240px; flex: 1;
}
.nav-search input {
  border: none; background: transparent; outline: none;
  font-size: 13px; color: var(--text-1); width: 100%; font-family: inherit;
}
.nav-search input::placeholder { color: var(--text-3); }
.nav-spacer { flex: 1; }
.nav-right  { display: flex; align-items: center; gap: 10px; }

/* Updated indicator */
.nav-updated { display: flex; align-items: center; gap: 6px; font-size: 11px; color: var(--text-3); flex-shrink: 0; }
.nav-updated-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--green); }

/* Refresh button */
.btn-refresh {
  width: 34px; height: 34px; border-radius: 50%;
  background: var(--input-bg); border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  color: var(--text-2); transition: background 0.15s, color 0.15s;
}
.btn-refresh:hover { background: var(--accent-dim); color: var(--accent); }
.btn-refresh.spinning svg { animation: spin 0.7s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

/* User */
.nav-user { display: flex; align-items: center; gap: 7px; }
.nav-avatar {
  width: 30px; height: 30px; border-radius: 50%;
  background: var(--accent-dim); color: var(--accent);
  font-size: 12px; font-weight: 800;
  display: flex; align-items: center; justify-content: center;
}
.nav-username { font-size: 13px; font-weight: 600; color: var(--text-2); }

/* Add to Watchlist */
.btn-primary {
  display: flex; align-items: center; gap: 6px;
  background: var(--btn-bg); color: var(--btn-c);
  border: none; border-radius: 20px; padding: 8px 16px;
  font-size: 13px; font-weight: 600; font-family: inherit; cursor: pointer;
  text-decoration: none; white-space: nowrap;
  transition: opacity 0.15s, transform 0.1s;
  position: relative; overflow: hidden;
}
body.linen .btn-primary::after {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0;
  width: 3px; background: var(--btn-accent);
}
.btn-primary:hover { opacity: 0.85; transform: scale(0.98); }

/* Theme switcher */
.theme-sw { display: flex; background: var(--sw-bg); border-radius: 18px; padding: 3px; gap: 2px; }
.theme-btn {
  border: none; cursor: pointer; padding: 4px 11px; border-radius: 14px;
  font-size: 9px; font-weight: 700; letter-spacing: 1px;
  transition: all 0.2s; background: transparent; color: var(--text-3); font-family: inherit;
}
.theme-btn.active { background: var(--sw-act); color: var(--sw-act-c); box-shadow: 0 1px 4px rgba(0,0,0,0.14); }

/* ══════════════════════════════════════════════════════
   TICKER STRIP
══════════════════════════════════════════════════════ */
.ticker-strip {
  background: var(--strip-bg); height: 38px;
  display: flex; align-items: center; padding: 0 44px 0 28px;
  overflow-x: auto; overflow-y: visible; scrollbar-width: none;
  position: relative;
}
.ticker-strip::-webkit-scrollbar { display: none; }
.tick { display: flex; align-items: center; gap: 9px; padding: 0 18px; height: 100%; flex-shrink: 0; border-right: 1px solid rgba(255,255,255,0.06); }
.tick:first-child { padding-left: 0; }
.tick-name { font-size: 9.5px; font-weight: 700; letter-spacing: 0.7px; color: rgba(255,255,255,0.35); }
.tick-val  { font-size: 12px; font-weight: 700; color: var(--strip-c); }
.tick-chg  { font-size: 10px; font-weight: 600; }
.tick-chg.up { color: #34c759; }
.tick-chg.dn { color: #ff453a; }
.tick-spacer { flex: 1; }
.tick-time   { font-size: 10px; color: rgba(255,255,255,0.25); }
/* Strip edit button — pinned to right edge, always visible */
.tick-edit-btn {
  position: fixed; right: 12px; top: 56px;
  height: 38px;
  background: none; border: none; cursor: pointer; padding: 0;
  display: flex; align-items: center; z-index: 201;
}
.tick-edit-btn-inner {
  display: flex; align-items: center; gap: 5px;
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 6px; padding: 3px 9px;
  color: rgba(255,255,255,0.75); font-size: 11px; font-weight: 600;
  letter-spacing: 0.3px;
  transition: background .15s, color .15s;
}
.tick-edit-btn:hover .tick-edit-btn-inner { background: rgba(255,255,255,0.2); color: #fff; }
.tick-edit-btn.active .tick-edit-btn-inner { background: var(--accent); border-color: var(--accent); color: #fff; }
.tick-remove {
  background: none; border: none; cursor: pointer; padding: 0 2px;
  color: rgba(255,255,255,0); font-size: 11px; line-height: 1;
  transition: color .15s; flex-shrink: 0;
}
.ticker-strip.editing .tick-remove { color: rgba(255,100,90,0.5); }
.ticker-strip.editing .tick-remove:hover { color: #ff453a; }
/* Index card remove button */
.idx-card { position: relative; }
.idx-remove {
  position: absolute; top: 6px; right: 6px;
  width: 18px; height: 18px;
  display: flex; align-items: center; justify-content: center;
  border: none; background: none; padding: 0; cursor: pointer;
  color: var(--text-3); font-size: 11px;
  border-radius: 4px;
  opacity: 0; transition: opacity .15s, background .15s, color .15s;
}
.idx-card:hover .idx-remove { opacity: 1; }
.idx-card:hover .idx-remove:hover { background: rgba(220,50,50,.12); color: var(--red); }

/* ══════════════════════════════════════════════════════
   MAIN LAYOUT
══════════════════════════════════════════════════════ */
main { padding: 30px 28px 72px; max-width: 1320px; margin: 0 auto; }
section { margin-bottom: 46px; }

.sec-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 16px; gap: 12px; }
.sec-head h2 { font-size: 20px; font-weight: 800; letter-spacing: -0.4px; color: var(--text-1); }
.sec-count   { font-size: 12px; font-weight: 600; color: var(--text-3); margin-left: 6px; }
.sec-sub     { font-size: 11px; color: var(--text-3); margin-top: 2px; }
.sec-controls { display: flex; align-items: center; gap: 8px; }

.mag7-toggle { display: flex; background: rgba(0,0,0,0.05); border-radius: 18px; padding: 2px; }
body.aurora .mag7-toggle, body.slate .mag7-toggle { background: rgba(255,255,255,0.06); }
.mag7-toggle span { font-size: 9.5px; font-weight: 700; letter-spacing: 0.4px; padding: 4px 11px; border-radius: 14px; cursor: pointer; color: var(--text-2); transition: all 0.18s; }
.mag7-toggle span.on { background: var(--toggle-on-bg); color: var(--toggle-on-c); }

.sort-btn { font-size: 11px; font-weight: 600; color: var(--text-2); background: rgba(0,0,0,0.04); border: none; border-radius: 8px; padding: 5px 10px; cursor: pointer; font-family: inherit; }
body.aurora .sort-btn, body.slate .sort-btn { background: rgba(255,255,255,0.05); }

.grid-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; }
.grid-2 { display: grid; grid-template-columns: repeat(2,1fr); gap: 16px; }
.grid-4 { display: grid; grid-template-columns: repeat(4,1fr); gap: 12px; }

/* ══════════════════════════════════════════════════════
   HERO
══════════════════════════════════════════════════════ */
.hero {
  background: var(--card-bg); border: 1px solid var(--card-border);
  border-radius: 20px; box-shadow: var(--card-shadow);
  padding: 20px 24px; margin-bottom: 32px;
  display: flex; align-items: center; position: relative; overflow: hidden;
}
.hero::after {
  content: ''; position: absolute; right: -30px; top: -30px;
  width: 180px; height: 180px; border-radius: 50%;
  background: radial-gradient(circle, var(--accent-dim), transparent 70%);
  pointer-events: none;
}
.hero-stat { display: flex; flex-direction: column; gap: 2px; padding: 0 24px; }
.hero-stat:first-child { padding-left: 0; }
.hero-lbl { font-size: 9.5px; font-weight: 700; letter-spacing: 0.8px; text-transform: uppercase; color: var(--text-3); }
.hero-val { font-size: 22px; font-weight: 800; letter-spacing: -0.7px; color: var(--text-1); line-height: 1.1; }
.hero-sub { font-size: 11px; font-weight: 600; }
.hero-sub.up { color: var(--chip-up-c); }
.hero-sub.dn { color: var(--chip-dn-c); }
.hero-sub.neu { color: var(--text-3); }
.hero-div    { width: 1px; height: 36px; background: var(--divider); flex-shrink: 0; }
.hero-spacer { flex: 1; }
.hero-time   { font-size: 10px; color: var(--text-3); }

/* ══════════════════════════════════════════════════════
   STOCK / ETF CARD
══════════════════════════════════════════════════════ */
.card {
  background: var(--card-bg); border: 1px solid var(--card-border);
  border-radius: 20px; overflow: hidden; box-shadow: var(--card-shadow);
  transition: transform 0.18s, box-shadow 0.18s;
}
.card:hover { transform: translateY(-2px); box-shadow: var(--card-hover); }

.card-hdr {
  padding: 14px 15px 12px; border-bottom: 1px solid var(--divider);
  background: var(--card-hdr-bg); position: relative; overflow: hidden;
}
body.linen .card-hdr::before, body.pure .card-hdr::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: var(--card-top); opacity: 0.6;
}
.hdr-top      { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 6px; position: relative; }
.card-remove  {
  position: absolute; top: -2px; right: -2px;
  width: 20px; height: 20px;
  display: flex; align-items: center; justify-content: center;
  border: none; background: none; padding: 0; cursor: pointer;
  color: var(--text-3); font-size: 13px; line-height: 1;
  border-radius: 4px;
  opacity: 0; transition: opacity .15s, background .15s, color .15s;
}
.card:hover .card-remove { opacity: 1; }
.card-remove:hover { background: rgba(220,50,50,.12); color: var(--red); }
.hdr-ticker   { font-size: 9.5px; font-weight: 700; letter-spacing: 1.8px; color: var(--text-3); }
.hdr-exch     { font-size: 8.5px; font-weight: 700; background: rgba(0,0,0,0.04); color: var(--text-3); padding: 2px 7px; border-radius: 6px; }
body.aurora .hdr-exch, body.slate .hdr-exch { background: rgba(255,255,255,0.07); }
.hdr-mag7     { background: var(--accent-dim) !important; color: var(--accent) !important; }
.hdr-name     { font-size: 11px; color: var(--text-2); margin-bottom: 8px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.hdr-pr-row   { display: flex; align-items: baseline; gap: 7px; }
.hdr-price    { font-size: 26px; font-weight: 800; letter-spacing: -1px; color: var(--text-1); }
.hdr-currency { font-size: 12px; font-weight: 600; color: var(--text-3); }
.hdr-badge    { display: inline-flex; align-items: center; gap: 3px; font-size: 11px; font-weight: 700; padding: 3px 9px; border-radius: 20px; margin-left: auto; }
.hdr-badge.up { background: var(--chip-up-bg); color: var(--chip-up-c); }
.hdr-badge.dn { background: var(--chip-dn-bg); color: var(--chip-dn-c); }
.hdr-badge.nt { background: var(--chip-nt-bg); color: var(--chip-nt-c); }

.c-sec { padding: 11px 15px; border-bottom: 1px solid var(--divider); }
.c-sec:last-child { border-bottom: none; }
.c-lbl { font-size: 7.5px; font-weight: 700; letter-spacing: 1.4px; text-transform: uppercase; color: var(--text-3); margin-bottom: 7px; }

.sparkwrap { overflow: hidden; line-height: 0; }

.chips { display: flex; gap: 3px; flex-wrap: wrap; }
.chip  { padding: 4px 6px; border-radius: 8px; display: flex; flex-direction: column; align-items: center; min-width: 32px; }
.chip .p { font-size: 7px; font-weight: 700; letter-spacing: 0.3px; }
.chip .v { font-size: 10px; font-weight: 700; margin-top: 1px; }
.chip.up { background: var(--chip-up-bg); color: var(--chip-up-c); }
.chip.dn { background: var(--chip-dn-bg); color: var(--chip-dn-c); }
.chip.nt { background: var(--chip-nt-bg); color: var(--chip-nt-c); }

.rsi-row   { display: flex; align-items: center; gap: 10px; }
.rsi-num   { font-size: 24px; font-weight: 900; letter-spacing: -1px; }
.rsi-lbl   { font-size: 9px; color: var(--text-2); margin-top: 1px; }
.rsi-hints { flex: 1; text-align: right; font-size: 8px; color: var(--text-3); line-height: 1.9; }

.thermo     { position: relative; height: 4px; border-radius: 3px; background: linear-gradient(90deg,var(--red),var(--orange) 35%,var(--green) 65%,var(--orange) 82%,var(--red)); margin: 7px 0 4px; }
.t-dot      { position: absolute; top: -5px; width: 14px; height: 14px; border-radius: 50%; transform: translateX(-50%); border: 2px solid var(--card-bg); background: var(--text-1); }
.t-labels   { display: flex; justify-content: space-between; font-size: 8.5px; font-weight: 600; color: var(--text-3); }
.t-cur      { color: var(--text-1); font-weight: 700; }

.bb-pill { display: flex; height: 24px; border-radius: 8px; overflow: hidden; margin: 6px 0 2px; }
.bb-z    { display: flex; align-items: center; justify-content: center; font-size: 7.5px; font-weight: 700; padding: 0 6px; }
.bb-sub  { font-size: 8px; color: var(--text-2); }

.macd-row   { display: flex; align-items: center; gap: 9px; }
.macd-icon  { width: 30px; height: 30px; border-radius: 9px; display: flex; align-items: center; justify-content: center; font-size: 14px; flex-shrink: 0; }
.macd-title { font-size: 12px; font-weight: 700; color: var(--text-1); }
.macd-sub   { font-size: 9px; font-weight: 600; margin-top: 1px; }
.macd-vals  { display: flex; gap: 10px; margin-top: 5px; }
.mv         { font-size: 8.5px; color: var(--text-2); }
.mv span    { font-weight: 700; }

.val-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 3px; }
.vc       { border-radius: 8px; padding: 6px 4px; text-align: center; }
.vc .l    { font-size: 7px; font-weight: 600; opacity: 0.45; margin-bottom: 2px; }
.vc .v    { font-size: 10px; font-weight: 700; }
.vc .vd   { font-size: 6.5px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.7px; margin-top: 2px; opacity: 0.7; }
.vc.cheap  { background: var(--chip-up-bg); color: var(--chip-up-c); }
.vc.pricey { background: var(--chip-dn-bg); color: var(--chip-dn-c); }
.vc.na     { background: var(--val-na); color: var(--text-3); }

.pe-row   { display: flex; align-items: center; gap: 10px; }
.pe-ring  { position: relative; width: 48px; height: 48px; flex-shrink: 0; }
.pe-ring svg { transform: rotate(-90deg); }
.pe-inner { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; line-height: 1.2; }
.pe-inner .n { font-size: 12px; font-weight: 800; color: var(--text-1); }
.pe-inner .l { font-size: 6.5px; font-weight: 700; letter-spacing: 0.5px; color: var(--text-3); }
.pe-info .r  { font-size: 10px; font-weight: 700; }
.pe-info .d  { font-size: 9px; color: var(--text-2); margin-top: 1px; }

.analyst-row    { display: flex; align-items: baseline; gap: 8px; margin-bottom: 5px; }
.analyst-verdict { font-size: 19px; font-weight: 800; letter-spacing: -0.4px; color: var(--accent); }
.analyst-target  { font-size: 12px; font-weight: 600; color: var(--text-2); }
.analyst-upside  { font-size: 10px; font-weight: 700; margin-left: auto; }
.analyst-upside.up { color: var(--chip-up-c); }
.analyst-upside.dn { color: var(--chip-dn-c); }
.c-bar   { display: flex; height: 4px; border-radius: 3px; overflow: hidden; margin-bottom: 4px; }
.c-counts { display: flex; justify-content: space-between; font-size: 8.5px; font-weight: 600; }
.c-buy  { color: var(--chip-up-c); }
.c-sell { color: var(--chip-dn-c); }

/* Empty-slot card */
.card-empty {
  border: 1.5px dashed var(--card-border); background: transparent;
  box-shadow: none; display: flex; flex-direction: column;
  align-items: center; justify-content: center; min-height: 220px;
  opacity: 0.45; transition: opacity 0.2s;
}
.card-empty:hover { opacity: 0.75; }
.card-empty-plus { font-size: 26px; color: var(--text-3); margin-bottom: 6px; }
.card-empty-lbl  { font-size: 12px; font-weight: 600; color: var(--text-2); }

/* ══════════════════════════════════════════════════════
   INDEX CARDS
══════════════════════════════════════════════════════ */
.idx-card {
  background: var(--card-bg); border: 1px solid var(--card-border);
  border-radius: 16px; box-shadow: var(--card-shadow);
  padding: 14px 15px; position: relative; overflow: hidden;
  transition: transform 0.18s;
}
.idx-card:hover { transform: translateY(-2px); }
body.linen .idx-card::before, body.pure .idx-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: var(--card-top); opacity: 0.5;
}
.idx-ticker { font-size: 9px; font-weight: 700; letter-spacing: 1.3px; color: var(--text-3); margin-bottom: 2px; }
.idx-name   { font-size: 10px; color: var(--text-2); margin-bottom: 8px; }
.idx-price  { font-size: 19px; font-weight: 800; letter-spacing: -0.6px; color: var(--text-1); line-height: 1; }
.idx-chg    { display: inline-flex; align-items: center; gap: 3px; font-size: 10px; font-weight: 700; padding: 2px 8px; border-radius: 16px; margin-top: 5px; }
.idx-chg.up { background: var(--chip-up-bg); color: var(--chip-up-c); }
.idx-chg.dn { background: var(--chip-dn-bg); color: var(--chip-dn-c); }
.idx-chg.nt { background: var(--chip-nt-bg); color: var(--chip-nt-c); }
.idx-spark  { margin-top: 7px; line-height: 0; }
.idx-range  { display: flex; justify-content: space-between; margin-top: 3px; font-size: 8px; color: var(--text-3); }

/* ══════════════════════════════════════════════════════
   GLOBAL MACRO — Country cards
══════════════════════════════════════════════════════ */
.country-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 14px; }
.country-card {
  background: var(--card-bg); border: 1px solid var(--card-border);
  border-radius: 16px; box-shadow: var(--card-shadow);
  padding: 16px 18px; position: relative;
  transition: transform .18s, box-shadow .18s;
}
.country-card:hover { transform: translateY(-2px); box-shadow: var(--card-hover); }
.country-hdr  { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; }
.country-flag { font-size: 24px; line-height: 1; }
.country-name { font-size: 13px; font-weight: 700; color: var(--text-1); }
.country-code { font-size: 9px; font-weight: 700; letter-spacing: 1.2px; color: var(--text-3); margin-top: 1px; }
.country-rows { display: flex; flex-direction: column; gap: 7px; }
.country-row  { display: flex; justify-content: space-between; align-items: center; }
.country-row-lbl { font-size: 10.5px; color: var(--text-2); }
.country-row-val { font-size: 12px; font-weight: 700; color: var(--text-1); }
.country-row-period { font-size: 9px; color: var(--text-3); margin-left: 4px; }
.country-row-val.up { color: var(--green); }
.country-row-val.dn { color: var(--red); }
.country-row--hdr .country-row-lbl { font-size: 9.5px; font-weight: 700; letter-spacing: 0.4px; color: var(--text-3); text-transform: uppercase; }
.country-row--bond { gap: 4px; }
.country-row--bond .country-row-lbl--sm { font-size: 10px; color: var(--text-3); min-width: 56px; }
.country-row--bond .country-row-val { font-size: 11.5px; }
.country-divider { height: 1px; background: var(--divider); margin: 8px 0; }
.country-index  { display: flex; align-items: center; gap: 6px; }
.country-index-name  { font-size: 9.5px; font-weight: 700; letter-spacing: 0.5px; color: var(--text-3); flex: 1; }
.country-index-price { font-size: 11px; font-weight: 700; color: var(--text-1); }
.country-index-chg   { font-size: 10px; font-weight: 600; }
.country-index-chg.up { color: var(--green); }
.country-index-chg.dn { color: var(--red); }
.country-remove {
  position: absolute; top: 10px; right: 10px;
  width: 20px; height: 20px;
  display: flex; align-items: center; justify-content: center;
  border: none; background: none; padding: 0; cursor: pointer;
  color: var(--text-3); font-size: 12px; border-radius: 4px;
  opacity: 0; transition: opacity .15s, background .15s, color .15s;
}
.country-card:hover .country-remove { opacity: 1; }
.country-card:hover .country-remove:hover { background: rgba(220,50,50,.12); color: var(--red); }

/* ══════════════════════════════════════════════════════
   AI INSIGHTS
══════════════════════════════════════════════════════ */
.ai-card {
  background: var(--card-bg); border: 1px solid var(--card-border);
  border-radius: 20px; box-shadow: var(--card-shadow);
  padding: 15px; transition: transform 0.18s;
}
.ai-card:hover { transform: translateY(-2px); }
.ai-hdr     { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 11px; }
.ai-pill    { font-size: 9.5px; font-weight: 700; letter-spacing: 0.8px; background: var(--chip-up-bg); color: var(--chip-up-c); padding: 3px 8px; border-radius: 8px; }
.ai-pill.dn { background: var(--chip-dn-bg); color: var(--chip-dn-c); }
.ai-name    { font-size: 11px; font-weight: 700; color: var(--text-1); margin-bottom: 1px; }
.ai-date    { font-size: 9px; color: var(--text-3); }
.ai-verdict { font-size: 10px; font-weight: 800; letter-spacing: 0.4px; padding: 4px 11px; border-radius: 20px; }
.ai-verdict.bullish { background: var(--chip-up-bg); color: var(--chip-up-c); }
.ai-verdict.bearish { background: var(--chip-dn-bg); color: var(--chip-dn-c); }
.ai-verdict.neutral { background: rgba(212,168,83,0.13); color: var(--orange); }
body.aurora .ai-verdict.neutral, body.slate .ai-verdict.neutral { background: rgba(255,255,255,0.08); color: var(--text-2); }

.ai-conf-row  { display: flex; justify-content: space-between; margin-bottom: 4px; }
.ai-conf-lbl  { font-size: 8px; font-weight: 700; letter-spacing: 0.8px; text-transform: uppercase; color: var(--text-3); }
.ai-conf-pct  { font-size: 10px; font-weight: 700; }
.ai-conf-bar  { height: 4px; border-radius: 3px; background: var(--track); overflow: hidden; margin-bottom: 12px; }
.ai-conf-fill { height: 100%; border-radius: 3px; background: linear-gradient(90deg, var(--green), var(--orange)); }

.ai-cases      { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 11px; }
.ai-case       { border-radius: 12px; padding: 10px 11px; }
.ai-case.bull  { background: var(--chip-up-bg); }
.ai-case.bear  { background: var(--chip-dn-bg); }
.case-head     { font-size: 8px; font-weight: 800; letter-spacing: 0.8px; text-transform: uppercase; margin-bottom: 6px; }
.ai-case.bull .case-head { color: var(--chip-up-c); }
.ai-case.bear .case-head { color: var(--chip-dn-c); }
.ai-case ul    { list-style: none; display: flex; flex-direction: column; gap: 4px; }
.ai-case li    { font-size: 9.5px; line-height: 1.4; padding-left: 10px; position: relative; }
.ai-case.bull li { color: var(--chip-up-c); }
.ai-case.bear li { color: var(--chip-dn-c); }
.ai-case li::before { content: '·'; position: absolute; left: 2px; }

.ai-tags { display: flex; flex-wrap: wrap; gap: 4px; }
.ai-tag  { font-size: 9px; font-weight: 600; padding: 2px 8px; border-radius: 20px; background: var(--chip-nt-bg); color: var(--text-2); }
.ai-tag.pos { background: var(--chip-up-bg); color: var(--chip-up-c); }
.ai-tag.neg { background: var(--chip-dn-bg); color: var(--chip-dn-c); }
.ai-tag.neu { background: rgba(212,168,83,0.13); color: var(--orange); }
body.aurora .ai-tag.neu, body.slate .ai-tag.neu { background: rgba(255,255,255,0.07); color: var(--text-2); }

/* ══════════════════════════════════════════════════════
   CALENDAR
══════════════════════════════════════════════════════ */
.cal-card { background: var(--card-bg); border: 1px solid var(--card-border); border-radius: 20px; box-shadow: var(--card-shadow); padding: 17px; }
.cal-hdr  { margin-bottom: 13px; padding-bottom: 11px; border-bottom: 1px solid var(--divider); }
.cal-hdr-title { font-size: 13px; font-weight: 800; color: var(--text-1); }
.cal-hdr-sub   { font-size: 10px; color: var(--text-3); margin-top: 1px; }
.cal-day       { margin-bottom: 12px; }
.cal-day-lbl   { font-size: 8.5px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: var(--text-3); margin-bottom: 5px; }
.cal-event {
  display: flex; align-items: center; gap: 9px;
  padding: 8px 10px; border-radius: 11px; margin-bottom: 3px;
  background: rgba(0,0,0,0.025); transition: background 0.12s;
}
body.aurora .cal-event, body.slate .cal-event { background: rgba(255,255,255,0.03); }
.cal-event:hover { background: rgba(0,0,0,0.05); }
body.aurora .cal-event:hover, body.slate .cal-event:hover { background: rgba(255,255,255,0.05); }
.cal-ticker { font-size: 8.5px; font-weight: 700; letter-spacing: 0.4px; padding: 2px 7px; border-radius: 6px; flex-shrink: 0; min-width: 54px; text-align: center; }
.cal-event-name { font-size: 11px; font-weight: 600; color: var(--text-1); }
.cal-event-meta { font-size: 9px; color: var(--text-3); margin-top: 1px; }
.cal-badge { font-size: 8px; font-weight: 700; letter-spacing: 0.4px; padding: 2px 7px; border-radius: 6px; flex-shrink: 0; margin-left: auto; }
.cal-badge.amc  { background: rgba(212,168,83,0.13); color: var(--orange); }
body.pure .cal-badge.amc { background: rgba(255,159,10,0.10); color: #b36200; }
.cal-badge.bmo  { background: var(--chip-up-bg); color: var(--chip-up-c); }
.cal-badge.high { background: var(--chip-dn-bg); color: var(--chip-dn-c); }
.cal-badge.med  { background: var(--accent-dim); color: var(--accent); }
.macro-dot      { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
.macro-dot.high { background: var(--red); }
.macro-dot.med  { background: var(--orange); }
.cal-empty      { font-size: 11px; color: var(--text-3); font-style: italic; padding: 6px 0; }

/* ══════════════════════════════════════════════════════
   NEWS
══════════════════════════════════════════════════════ */
.news-filters { display: flex; gap: 6px; flex-wrap: wrap; }
.news-filter  { font-size: 10px; font-weight: 600; padding: 4px 12px; border-radius: 16px; background: rgba(0,0,0,0.04); color: var(--text-2); cursor: pointer; border: none; font-family: inherit; transition: all 0.15s; }
body.aurora .news-filter, body.slate .news-filter { background: rgba(255,255,255,0.06); }
.news-filter.active { background: var(--toggle-on-bg); color: var(--toggle-on-c); }
.news-card    { background: var(--card-bg); border: 1px solid var(--card-border); border-left: 3px solid; border-radius: 14px; padding: 13px 15px; box-shadow: var(--card-shadow); transition: transform 0.15s; cursor: pointer; }
.news-card:hover { transform: translateY(-2px); }
.news-card.pos { border-left-color: var(--green); }
.news-card.neg { border-left-color: var(--red); }
.news-card.neu { border-left-color: var(--divider); }
.news-meta    { display: flex; align-items: center; gap: 7px; margin-bottom: 7px; }
.news-source  { font-size: 10px; font-weight: 700; color: var(--text-1); }
.news-time    { font-size: 9px; color: var(--text-3); }
.news-sent    { margin-left: auto; font-size: 8.5px; font-weight: 700; letter-spacing: 0.4px; padding: 2px 7px; border-radius: 6px; }
.news-sent.pos { background: var(--chip-up-bg); color: var(--chip-up-c); }
.news-sent.neg { background: var(--chip-dn-bg); color: var(--chip-dn-c); }
.news-sent.neu { background: var(--chip-nt-bg); color: var(--chip-nt-c); }
.news-headline { font-size: 13px; font-weight: 600; line-height: 1.45; color: var(--text-1); margin-bottom: 9px; }
.news-tickers  { display: flex; gap: 4px; flex-wrap: wrap; }
.nt { font-size: 9px; font-weight: 700; background: var(--val-na); color: var(--text-2); padding: 2px 7px; border-radius: 6px; }

/* ══════════════════════════════════════════════════════
   GLOSSARY
══════════════════════════════════════════════════════ */
.gloss-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 10px; }
.gloss-card { background: var(--card-bg); border: 1px solid var(--card-border); border-radius: 14px; padding: 13px; cursor: pointer; box-shadow: var(--card-shadow); transition: transform 0.15s, border-color 0.2s; }
.gloss-card:hover { transform: translateY(-1px); }
.gloss-card.open  { border-color: var(--accent); }
.gloss-term  { display: flex; align-items: center; gap: 7px; }
.gloss-abbr  { font-size: 11px; font-weight: 800; color: var(--accent); flex-shrink: 0; }
.gloss-name  { font-size: 10px; font-weight: 600; color: var(--text-2); flex: 1; }
.gloss-arrow { font-size: 15px; color: var(--text-3); transition: transform 0.2s; }
.gloss-card.open .gloss-arrow { transform: rotate(90deg); }
.gloss-def   { font-size: 11px; line-height: 1.55; color: var(--text-2); margin-top: 10px; display: none; }
.gloss-ex    { font-size: 9.5px; font-weight: 600; color: var(--accent); margin-top: 8px; padding-top: 8px; border-top: 1px solid var(--divider); display: none; }
.gloss-card.open .gloss-def { display: block; }
.gloss-card.open .gloss-ex  { display: block; }

/* ══════════════════════════════════════════════════════
   AUTH PAGES
══════════════════════════════════════════════════════ */
.auth-page { display: flex; align-items: center; justify-content: center; min-height: 100vh; }
.auth-card { background: var(--card-bg); border: 1px solid var(--card-border); border-radius: 24px; box-shadow: var(--card-shadow); padding: 36px; width: 100%; max-width: 400px; }
.auth-title { font-size: 22px; font-weight: 800; letter-spacing: -0.4px; color: var(--text-1); margin-bottom: 6px; }
.auth-sub   { font-size: 13px; color: var(--text-2); margin-bottom: 26px; }
.flash-msg  { padding: 10px 14px; border-radius: 10px; font-size: 12px; font-weight: 600; margin-bottom: 14px; }
.flash-msg.error   { background: var(--chip-dn-bg); color: var(--chip-dn-c); }
.flash-msg.success { background: var(--chip-up-bg); color: var(--chip-up-c); }

/* ── Watchlist inline search ──────────────────── */
.wl-wrap { position: relative; }
.wl-active { display: flex; flex-direction: column; position: relative; }

.wl-search-box {
  display: flex; align-items: center; gap: 7px;
  background: var(--card-bg); border: 1.5px solid var(--accent);
  border-radius: 20px; padding: 7px 12px; min-width: 200px;
  color: var(--text-2);
}
.wl-search-box input {
  border: none; background: none; outline: none;
  font-size: 12px; font-weight: 600; color: var(--text-1);
  font-family: inherit; flex: 1; min-width: 0;
}
.wl-search-box input::placeholder { color: var(--text-3); font-weight: 400; }
.wl-clear {
  background: none; border: none; cursor: pointer;
  font-size: 11px; color: var(--text-3); padding: 0; line-height: 1;
}
.wl-clear:hover { color: var(--text-1); }

.wl-dropdown {
  position: absolute; top: calc(100% + 4px); right: 0;
  min-width: 320px; background: var(--card-bg);
  border: 1px solid var(--card-border);
  border-radius: 10px; box-shadow: 0 8px 24px rgba(0,0,0,0.12);
  z-index: 300; overflow: hidden;
}
.wl-dd-header {
  font-size: 10px; color: var(--text-3); text-transform: uppercase;
  letter-spacing: .06em; padding: 8px 12px 4px;
}
.wl-row {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 12px; cursor: pointer; transition: background .1s;
}
.wl-row:hover, .wl-row-focus { background: var(--accent-dim); }
.wl-row-watching { cursor: not-allowed; opacity: .5; }
.wl-ticker {
  font-size: 13px; font-weight: 700; min-width: 60px;
  color: var(--text-1); font-variant-numeric: tabular-nums;
}
.wl-name {
  font-size: 11px; color: var(--text-2); flex: 1;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.wl-badge {
  font-size: 10px; padding: 2px 7px; border-radius: 4px;
  white-space: nowrap; font-weight: 500; flex-shrink: 0;
}
.wl-badge-stock  { background: #f0f8ff; color: #4a90d9; }
.wl-badge-etf    { background: #f0fff4; color: #38a169; }
.wl-badge-crypto { background: var(--accent-dim); color: var(--accent); }
.wl-badge-index  { background: #f5f0ff; color: #805ad5; }
.wl-badge-fx     { background: var(--card-bg); color: var(--text-2); border: 1px solid var(--card-border); }
.wl-plus { font-size: 16px; color: var(--accent); font-weight: 300; padding-left: 6px; flex-shrink: 0; }
.wl-row-watching .wl-plus { font-size: 11px; color: var(--text-3); }

.wl-loading {
  display: flex; align-items: center; gap: 8px;
  padding: 12px; font-size: 11px; color: var(--text-3);
}
.wl-spinner {
  width: 14px; height: 14px; border: 2px solid var(--card-border);
  border-top-color: var(--accent); border-radius: 50%;
  animation: spin .7s linear infinite; flex-shrink: 0;
}
.wl-empty { padding: 12px; font-size: 11px; color: var(--text-3); }
.wl-hints { display: flex; gap: 12px; padding: 6px 12px; border-top: 1px solid var(--divider); }
.wl-hint { font-size: 10px; color: var(--text-3); }

.wl-toast {
  position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%);
  background: var(--text-1); color: var(--nav-bg);
  border-radius: 8px; padding: 10px 18px;
  font-size: 13px; font-weight: 500;
  display: flex; align-items: center; gap: 8px;
  z-index: 999; box-shadow: 0 4px 16px rgba(0,0,0,0.2);
  animation: wl-toast-in .2s ease;
}
/* Badge overrides for dark themes */
body.aurora .wl-badge-stock,
body.slate  .wl-badge-stock  { background: rgba(74,144,217,.15); }
body.aurora .wl-badge-etf,
body.slate  .wl-badge-etf    { background: rgba(56,161,105,.15); }
body.aurora .wl-badge-index,
body.slate  .wl-badge-index  { background: rgba(128,90,213,.15); }

@keyframes wl-toast-in {
  from { opacity: 0; transform: translateX(-50%) translateY(8px); }
  to   { opacity: 1; transform: translateX(-50%) translateY(0); }
}

/* ── Indicator Tooltip ───────────────────────────────── */
#indicator-tip {
  position: fixed;
  z-index: 9999;
  pointer-events: none;
  max-width: 240px;
  background: var(--text-1);
  color: var(--nav-bg);
  border-radius: 8px;
  padding: 8px 12px;
  font-size: 12px;
  line-height: 1.5;
  box-shadow: 0 4px 16px rgba(0,0,0,0.18);
  opacity: 0;
  transition: opacity .12s ease;
}
#indicator-tip.visible { opacity: 1; }
[data-tip] { cursor: help; }
[data-tip]:hover { color: var(--accent); }
