/* ============================================================
   PSX Tactics -- Styles.css  v3
   Master stylesheet. nav.js injects the nav + sidebar HTML.
   Import order: fonts -> tokens -> reset -> layout -> nav ->
                 sidebar -> utilities -> news -> mobile
   ============================================================ */

/* ============================================================
   STYLE LOG -- track changes per page session
   ============================================================
   v3 -- Stock Watch (page 1)
   ─────────────────────────────────────────────────────────────
   BRAND:
   * Renamed FolioPSX -> PSX Tactics everywhere
   * nav-logo: font-family -> var(--font-display) [Sora 700]
   * page-title: font-family -> var(--font-display) [Sora 700]
     across ALL pages for headline consistency
   * Added --font-display: 'Sora', sans-serif CSS token
   * Added Sora to Google Fonts @import

   DARK MODE TOKENS (v3 vs v2):
   * --text-primary:   #e8eaf4 -> #eceef8  (slightly brighter)
   * --text-secondary: #a0aac8 -> #b8c4e0  (much brighter -- nav links, dropdown triggers)
   * --text-muted:     #6b7799 -> #8a96b8  (much brighter -- page-sub, timestamp, placeholder)

   DARK MODE SPECIFIC OVERRIDES (element-level):
   * .nav-link (dark):           color #b8c4e0
   * .nav-link:hover (dark):     color #eceef8
   * .dropdown-trigger (dark):   color #b8c4e0
   * .page-sub (dark):           color #9daac8
   * .timestamp (dark):          color #9daac8
   * search placeholder (dark):  color #7a8aac
   * .col-h (dark):              color #9db0d8, bg #1c2035
   * .col-headers (dark):        stronger border, shadow
   * .stat-label (dark):         color #8a9bbf
   * .ssym (dark):               color #6b7fa8

   PAGES DONE: 1 / ? -- Stock Watch
              2 / ? -- Fund Breakdown
              3 / ? -- Islamic Funds
              4 / ? -- Conventional Funds
   ─────────────────────────────────────────────────────────────
   v3 -- Conventional Funds (page 4)
   * Title: FolioPSX -> PSX Tactics
   * Footer: FolioPSX -> PSX Tactics
   * data-page="conventional-funds" added to body
   * Theme init script added (psxtactics_theme)
   * ALL inline <style> stripped -- all rules already in Styles.css
     from Islamic Funds pass -- zero new CSS needed
   * AMC chips: 13 AMCs (no Meezan/Lucky/Faysal/Mahaana)
   * Type chips: 3 types only -- no Commodity (conventional funds)
   * setAMC(): .filter-bar:not(.type-bar) .chip -> .amc-bar .amc-chip
   * setType(): .type-bar .chip -> .type-bar .type-chip
   * Mobile table/cards: handled by page-scoped CSS in Styles.css
     [data-page="conventional-funds"] scoping already in place
   ============================================================ 
   * .table-card was global -- now page-scoped:
     [data-page="stock-watch"] .table-card { overflow: visible }
     Fund NAV .table-card { overflow: hidden } (further down)
   * Mobile table hide/show is now PAGE-SCOPED via data-page:
     [data-page="islamic-funds|conventional-funds|pension-funds"]
     .table-card { display:none } / .mobile-fund-list { display:block }
     Stock Watch and all other pages are UNAFFECTED.
   * RULE FOR FUTURE SESSIONS:
     - Global classes = identical behaviour on ALL pages -> no scoping needed
     - Page-specific show/hide or layout differences -> ALWAYS scope with
       [data-page="page-name"] to avoid breaking other pages
     - Add page name to comment when adding a new scoped rule
   ============================================================ */

/* ── GOOGLE FONTS ────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&family=Sora:wght@600;700&display=swap');

/* ── DESIGN TOKENS -- LIGHT ───────────────────────────────── */
:root {
  --bg:              #f0f2f7;
  --bg-surface:      #ffffff;
  --bg-surface-rgb:  255, 255, 255;
  --bg-card:         #f8f9fc;
  --bg-nav:          rgba(255, 255, 255, 0.92);
  --border:          rgba(0, 0, 0, 0.07);
  --border-md:       rgba(0, 0, 0, 0.11);
  --text-primary:    #0d1117;
  --text-secondary:  #5a6478;
  --text-muted:      #9ba3b8;
  --accent:          #1847d4;
  --accent-soft:     rgba(24, 71, 212, 0.08);
  --accent-border:   rgba(24, 71, 212, 0.2);
  --green:           #0a8a5c;
  --green-soft:      rgba(10, 138, 92, 0.09);
  --green-border:    rgba(10, 138, 92, 0.2);
  --red:             #d92b4b;
  --red-soft:        rgba(217, 43, 75, 0.09);
  --red-border:      rgba(217, 43, 75, 0.2);
  --amber:           #c47f00;
  --amber-soft:      rgba(196, 127, 0, 0.09);
  --sector-bg:       #1847d4;
  --sector-text:     #ffffff;
  --shadow:          0 2px 12px rgba(0, 0, 0, 0.06);
  --shadow-lg:       0 12px 40px rgba(0, 0, 0, 0.12);
  --nav-h:           56px;
  --radius:          10px;
  --radius-sm:       6px;
  --font:            'Inter', sans-serif;
  --font-display:    'Sora', sans-serif;
  --mono:            'JetBrains Mono', monospace;
}

/* ── DESIGN TOKENS -- DARK ────────────────────────────────── */
[data-theme="dark"] {
  --bg:              #0c0e14;
  --bg-surface:      #13161f;
  --bg-surface-rgb:  19, 22, 31;
  --bg-card:         #181c28;
  --bg-nav:          rgba(13, 16, 25, 0.95);
  --border:          rgba(255, 255, 255, 0.09);
  --border-md:       rgba(255, 255, 255, 0.14);
  --text-primary:    #eceef8;
  --text-secondary:  #b8c4e0;
  --text-muted:      #8a96b8;
  --accent:          #5d8fff;
  --accent-soft:     rgba(93, 143, 255, 0.12);
  --accent-border:   rgba(93, 143, 255, 0.28);
  --green:           #22c88a;
  --green-soft:      rgba(34, 200, 138, 0.12);
  --green-border:    rgba(34, 200, 138, 0.28);
  --red:             #f5476a;
  --red-soft:        rgba(245, 71, 106, 0.12);
  --red-border:      rgba(245, 71, 106, 0.28);
  --amber:           #f0a500;
  --amber-soft:      rgba(240, 165, 0, 0.12);
  --sector-bg:       #1a2444;
  --sector-text:     #90b4ff;
  --shadow:          0 2px 12px rgba(0, 0, 0, 0.25);
  --shadow-lg:       0 12px 40px rgba(0, 0, 0, 0.45);
}

/* ── DARK MODE -- NAV & PAGE TEXT BRIGHTNESS FIXES ────────── */
[data-theme="dark"] .nav-link               { color: #b8c4e0; }
[data-theme="dark"] .nav-link:hover         { color: #eceef8; }
[data-theme="dark"] .dropdown-trigger       { color: #b8c4e0; }
[data-theme="dark"] .dropdown-trigger:hover { color: #eceef8; }
[data-theme="dark"] .page-sub              { color: #9daac8; }
[data-theme="dark"] .timestamp             { color: #9daac8; }
[data-theme="dark"] .search-wrap input::placeholder { color: #7a8aac; }
[data-theme="dark"] .search-wrap svg       { color: #7a8aac; }

/* ── RESET ───────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 14px; }
body {
  font-family: var(--font);
  background: var(--bg);
  color: var(--text-primary);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  transition: background 0.25s ease, color 0.25s ease;
}
button { cursor: pointer; border: none; background: none; font-family: inherit; }
a { text-decoration: none; color: inherit; }

/* ── NAV ─────────────────────────────────────────────────── */
nav {
  position: sticky;
  top: 0;
  z-index: 200;
  height: var(--nav-h);
  background: var(--bg-nav);
  border-bottom: 1px solid var(--border);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  display: flex;
  align-items: center;
  padding: 0 28px;
  gap: 0;
}
.nav-logo {
  font-size: 17px;
  font-weight: 700;
  font-family: var(--font-display);
  color: var(--text-primary);
  text-decoration: none;
  letter-spacing: -0.3px;
  margin-right: 32px;
  flex-shrink: 0;
}
.nav-logo em { color: var(--accent); font-style: normal; }

.nav-links {
  display: flex;
  align-items: center;
  gap: 2px;
  flex: 1;
  overflow: visible;
  scrollbar-width: none;
}
.nav-links::-webkit-scrollbar { display: none; }

.nav-link {
  font-size: 13px;
  font-weight: 400;
  color: var(--text-secondary);
  text-decoration: none;
  padding: 6px 14px;
  border-radius: var(--radius-sm);
  transition: all 0.15s ease;
  white-space: nowrap;
  flex-shrink: 0;
}
.nav-link:hover  { color: var(--text-primary); background: var(--border); }
.nav-link.active { color: var(--accent); background: var(--accent-soft); font-weight: 500; }

.nav-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
  margin-left: 16px;
}

/* ── NAV DROPDOWN (Fund NAVs) ────────────────────────────── */
.nav-dropdown { position: relative; display: flex; align-items: center; flex-shrink: 0; }
.dropdown-trigger {
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 4px;
  user-select: none;
  font-size: 13px;
  color: var(--text-secondary);
  padding: 6px 14px;
  border-radius: var(--radius-sm);
  transition: all 0.15s;
  white-space: nowrap;
}
.dropdown-trigger:hover,
.dropdown-trigger.open,
.nav-dropdown:hover .dropdown-trigger { color: var(--text-primary); background: var(--border); }
.dropdown-trigger svg { width: 10px; height: 10px; transition: transform 0.2s; flex-shrink: 0; }
.dropdown-trigger.open svg,
.nav-dropdown:hover .dropdown-trigger svg { transform: rotate(180deg); }
.dropdown-trigger.active { color: var(--accent); background: var(--accent-soft); font-weight: 500; }

.dropdown-menu { display: none; position: absolute; top: 100%; left: 0; padding-top: 4px; z-index: 400; }
.dropdown-menu.open,
.nav-dropdown:hover .dropdown-menu { display: block; }

.dropdown-menu-inner {
  background: var(--bg-surface);
  border: 1px solid var(--border-md);
  border-radius: var(--radius);
  padding: 4px;
  min-width: 180px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
}
.dropdown-item {
  display: block;
  font-size: 12.5px;
  color: var(--text-secondary);
  text-decoration: none;
  padding: 8px 14px;
  border-radius: var(--radius-sm);
  transition: all 0.15s;
  white-space: nowrap;
}
.dropdown-item:hover  { color: var(--text-primary); background: var(--border); }
.dropdown-item.active { color: var(--accent); background: var(--accent-soft); font-weight: 500; }

/* ── NAV ACTION BUTTONS ──────────────────────────────────── */
.live-badge {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-family: var(--mono);
  color: var(--text-muted);
  padding: 4px 10px;
  border-radius: 20px;
  border: 1px solid var(--border-md);
}
.live-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--green);
  flex-shrink: 0;
  animation: livePulse 2.5s ease-in-out infinite;
}
.icon-btn {
  width: 34px; height: 34px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border-md);
  background: transparent;
  color: var(--text-secondary);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all 0.15s ease;
  flex-shrink: 0;
}
.icon-btn:hover { background: var(--border); color: var(--text-primary); }
.icon-btn svg { width: 15px; height: 15px; }
.theme-btn {
  width: 34px; height: 34px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border-md);
  background: transparent;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 15px;
  transition: all 0.15s ease;
  flex-shrink: 0;
}
.theme-btn:hover { background: var(--border); }

/* ── PAGE LAYOUT ─────────────────────────────────────────── */
.page {
  max-width: 1480px;
  margin: 0 auto;
  padding: 28px 28px 80px;
}
.page-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 22px;
  gap: 16px;
  flex-wrap: wrap;
}
.page-title {
  font-size: 24px;
  font-weight: 700;
  font-family: var(--font-display);
  letter-spacing: -0.6px;
  color: var(--text-primary);
  line-height: 1.2;
}
.page-sub { font-size: 13px; color: var(--text-muted); margin-top: 4px; }
.head-controls { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }

/* ── SHARED CONTROLS ─────────────────────────────────────── */
.search-wrap {
  display: flex; align-items: center; gap: 8px;
  background: var(--bg-surface);
  border: 1px solid var(--border-md);
  border-radius: var(--radius-sm);
  padding: 0 12px;
  height: 36px;
  min-width: 240px;
  transition: border-color 0.15s;
}
.search-wrap:focus-within { border-color: var(--accent); }
.search-wrap svg { flex-shrink: 0; color: var(--text-muted); width: 14px; height: 14px; }
.search-wrap input {
  background: none; border: none; outline: none;
  font-size: 13px; font-family: var(--font); color: var(--text-primary); width: 100%;
}
.search-wrap input::placeholder { color: var(--text-muted); }

.refresh-btn {
  display: flex; align-items: center; gap: 6px;
  height: 36px; padding: 0 14px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--accent-border);
  background: var(--accent-soft);
  color: var(--accent);
  font-size: 13px; font-family: var(--font); font-weight: 500;
  cursor: pointer;
  transition: all 0.15s ease;
  white-space: nowrap; user-select: none;
}
.refresh-btn:hover:not(:disabled) { background: var(--accent); color: #fff; border-color: var(--accent); }
.refresh-btn:disabled { opacity: 0.55; cursor: not-allowed; border-color: var(--border-md); background: var(--bg-card); color: var(--text-muted); }
.refresh-btn svg { width: 13px; height: 13px; flex-shrink: 0; }
.refresh-btn.spinning svg { animation: spin 0.7s linear infinite; }

.timestamp { font-size: 12px; font-family: var(--mono); color: var(--text-muted); white-space: nowrap; }

/* Chips */
.chip {
  font-size: 12px; font-weight: 500;
  padding: 5px 12px; border-radius: 20px;
  border: 1px solid var(--border-md);
  background: var(--bg-surface);
  color: var(--text-secondary);
  cursor: pointer; transition: all 0.15s ease;
  white-space: nowrap; user-select: none;
}
.chip:hover  { border-color: var(--accent-border); color: var(--accent); background: var(--accent-soft); }
.chip.active { border-color: var(--accent); background: var(--accent); color: #fff; }

/* ── SHARED STAT CARDS ───────────────────────────────────── */
.stat-card {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 16px 18px;
  transition: border-color 0.15s;
}
.stat-card:hover { border-color: var(--border-md); }
.stat-label {
  font-size: 10.5px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.6px;
  color: var(--text-muted); margin-bottom: 8px;
}
.stat-val {
  font-size: 22px; font-weight: 600;
  font-family: var(--mono); letter-spacing: -0.5px;
  color: var(--text-primary); line-height: 1;
}
.stat-val.up   { color: var(--green); }
.stat-val.down { color: var(--red); }
.stat-val.sm   { font-size: 13.5px; letter-spacing: -0.2px; }

/* .table-card for Stock Watch -- overflow visible for sticky headers
   Used by: stock-watch only
   Fund NAV pages (islamic-funds, conventional-funds, pension-funds)
   have their own .table-card definition further down with overflow: hidden */
[data-page="stock-watch"] .table-card {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: visible;
}

/* Number cells */
.snum { font-size: 12.5px; font-family: var(--mono); color: var(--text-secondary); text-align: right; letter-spacing: -0.2px; }
.snum.hi   { color: var(--green); }
.snum.lo   { color: var(--red); }
.snum.cur  { color: var(--text-primary); font-weight: 500; }
.snum.pos  { color: var(--green); }
.snum.neg  { color: var(--red); }
.snum.dash { color: var(--text-muted); opacity: 0.35; }

/* Percent pill */
.pct-pill {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 3px 9px; border-radius: 4px;
  font-size: 11.5px; font-family: var(--mono); font-weight: 500;
  letter-spacing: -0.2px; min-width: 76px;
}
.pct-pill.up   { background: var(--green-soft); color: var(--green); }
.pct-pill.down { background: var(--red-soft);   color: var(--red); }
.pct-pill.flat { background: var(--border);      color: var(--text-muted); }

/* ── FOOTER ──────────────────────────────────────────────── */
.footer {
  margin-top: 36px; padding-top: 18px;
  border-top: 1px solid var(--border);
  display: flex; align-items: center;
  justify-content: space-between; flex-wrap: wrap; gap: 8px;
}
.footer-copy { font-size: 11.5px; color: var(--text-muted); line-height: 1.6; }
.footer-logo { font-size: 14px; font-weight: 600; color: var(--text-secondary); letter-spacing: -0.3px; }
.footer-logo em { color: var(--accent); font-style: normal; }

/* ── STATE / LOADING ─────────────────────────────────────── */
.state-block {
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding: 72px 24px; gap: 14px;
}
.spinner {
  width: 28px; height: 28px;
  border: 2px solid var(--border-md);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: spin 0.75s linear infinite;
}
.state-text  { font-size: 13px; color: var(--text-muted); }
.error-text  { font-size: 13px; color: var(--red); text-align: center; max-width: 420px; line-height: 1.6; }

/* ── KEYFRAMES ───────────────────────────────────────────── */
@keyframes spin { to { transform: rotate(360deg); } }
@keyframes livePulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: 0.35; transform: scale(0.8); }
}

/* ── INDEX / FILTER TABS ─────────────────────────────────── */
.index-tabs {
  display: flex; align-items: center; gap: 4px;
  background: var(--bg-card);
  border: 1px solid var(--border-md);
  border-radius: var(--radius-sm);
  padding: 3px;
}
.idx-tab {
  height: 30px; padding: 0 16px; border-radius: 4px;
  border: none; background: transparent;
  color: var(--text-secondary);
  font-size: 12.5px; font-family: var(--font); font-weight: 500;
  cursor: pointer; transition: all 0.15s ease; white-space: nowrap;
}
.idx-tab:hover  { color: var(--text-primary); background: var(--border); }
.idx-tab.active { background: var(--accent); color: #fff; }

/* ── STALE BANNER / PRE-MARKET ───────────────────────────── */
.stale-banner {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 20px;
  background: var(--amber-soft);
  border-bottom: 1px solid rgba(196, 127, 0, 0.15);
  font-size: 12.5px; color: var(--amber);
}
.stale-banner svg { width: 14px; height: 14px; flex-shrink: 0; }
.premarket-block {
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding: 72px 24px; gap: 10px; text-align: center;
}
.premarket-label {
  font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 1px;
  color: var(--amber); background: var(--amber-soft);
  padding: 4px 12px; border-radius: 20px; margin-bottom: 6px;
}
.premarket-title { font-size: 18px; font-weight: 600; color: var(--text-primary); letter-spacing: -0.3px; }
.premarket-countdown {
  font-size: 48px; font-weight: 600; font-family: var(--mono);
  letter-spacing: -2px; color: var(--accent); line-height: 1; margin: 8px 0;
}
.premarket-sub { font-size: 12.5px; color: var(--text-muted); }

/* ── SORT ICONS ──────────────────────────────────────────── */
.sort-icon { display: inline-flex; flex-direction: column; gap: 1.5px; margin-left: 5px; vertical-align: middle; opacity: 0.35; transition: opacity 0.15s; position: relative; top: -1px; }
.col-h:hover .sort-icon { opacity: 0.7; }
.col-h.sort-asc .sort-icon, .col-h.sort-desc .sort-icon { opacity: 1; }
.sort-icon span { display: block; width: 0; height: 0; }
.sort-icon .arr-up { border-left: 3.5px solid transparent; border-right: 3.5px solid transparent; border-bottom: 4px solid var(--text-muted); }
.sort-icon .arr-dn { border-left: 3.5px solid transparent; border-right: 3.5px solid transparent; border-top: 4px solid var(--text-muted); }
.col-h.sort-asc  .sort-icon .arr-up { border-bottom-color: var(--accent); }
.col-h.sort-asc  .sort-icon .arr-dn { opacity: 0.2; }
.col-h.sort-desc .sort-icon .arr-dn { border-top-color: var(--accent); }
.col-h.sort-desc .sort-icon .arr-up { opacity: 0.2; }

/* ============================================================
   MOBILE SIDEBAR -- Glassmorphic (injected by nav.js)
   ============================================================ */

/* Hamburger -- hidden on desktop, shown via media query */
.hamburger {
  display: none;
  align-items: center; justify-content: center;
  width: 38px; height: 38px;
  background: var(--accent-soft);
  border: 1px solid var(--accent-border);
  border-radius: 10px;
  cursor: pointer; flex-shrink: 0;
  transition: all 0.2s ease;
  order: -1; margin-right: 10px;
}
.hamburger:active { transform: scale(0.93); }
.hamburger svg { width: 18px; height: 18px; stroke: var(--accent); stroke-width: 2.2; }

/* Backdrop */
.sidebar-overlay {
  position: fixed; inset: 0;
  background: rgba(0, 0, 0, 0.55);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  z-index: 1000;
  visibility: hidden; opacity: 0;
  transition: visibility 0.28s, opacity 0.28s;
}
.sidebar-overlay.open { visibility: visible; opacity: 1; }

/* Panel */
.sidebar {
  position: fixed; top: 0; left: -88%;
  width: 88%; max-width: 310px; height: 100%;
  background: rgba(var(--bg-surface-rgb), 0.97);
  backdrop-filter: blur(24px) saturate(1.6);
  -webkit-backdrop-filter: blur(24px) saturate(1.6);
  box-shadow: 12px 0 40px rgba(0, 0, 0, 0.22), 1px 0 0 var(--border-md);
  z-index: 1001;
  transition: left 0.32s cubic-bezier(0.22, 1, 0.36, 1);
  display: flex; flex-direction: column; overflow: hidden;
}
.sidebar.open { left: 0; }

.sidebar-header {
  display: flex; justify-content: space-between; align-items: center;
  padding: 22px 18px 18px;
  border-bottom: 1px solid var(--border); flex-shrink: 0;
  background: linear-gradient(135deg, rgba(24, 71, 212, 0.07) 0%, transparent 70%);
}
[data-theme="dark"] .sidebar-header {
  background: linear-gradient(135deg, rgba(93, 143, 255, 0.09) 0%, transparent 70%);
}
.sidebar-brand       { display: flex; flex-direction: column; gap: 2px; }
.sidebar-brand-name  {
  font-size: 19px; font-weight: 700; letter-spacing: -0.5px;
  background: linear-gradient(120deg, var(--accent) 0%, #6f9fff 100%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.sidebar-brand-tag   { font-size: 10px; font-family: var(--mono); color: var(--text-muted); letter-spacing: 0.3px; }
.sidebar-close {
  display: flex; align-items: center; justify-content: center;
  width: 30px; height: 30px; border-radius: 8px;
  border: 1px solid var(--border-md); background: var(--bg-card);
  color: var(--text-secondary); font-size: 18px;
  cursor: pointer; transition: all 0.18s; line-height: 1; flex-shrink: 0;
}
.sidebar-close:active { background: var(--accent); color: #fff; border-color: var(--accent); }

.sidebar-links {
  padding: 14px 12px; flex: 1; overflow-y: auto;
  display: flex; flex-direction: column; gap: 3px; scrollbar-width: none;
}
.sidebar-links::-webkit-scrollbar { display: none; }

.sidebar-link {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px; font-size: 14px; font-weight: 500;
  color: var(--text-primary); text-decoration: none;
  border-radius: 11px; transition: all 0.18s ease;
}
.sidebar-link:active { transform: scale(0.98); }
.sidebar-link.active { background: var(--accent-soft); color: var(--accent); }
.sidebar-link.active .sb-icon-wrap { background: var(--accent); box-shadow: 0 4px 12px rgba(24, 71, 212, 0.35); }
.sidebar-link.active .sb-icon-wrap svg { stroke: #fff; }

/* Icon badge */
.sb-icon-wrap {
  width: 34px; height: 34px; border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; transition: all 0.18s ease;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1), inset 0 1px 0 rgba(255, 255, 255, 0.2);
}
.sb-icon-wrap svg { width: 17px; height: 17px; stroke-width: 1.8; fill: none; transition: stroke 0.18s; }

/* Icon colour themes */
.sb-c-blue   { background: linear-gradient(145deg, #e8eeff, #d0dcff); } .sb-c-blue   svg { stroke: #1847d4; }
.sb-c-teal   { background: linear-gradient(145deg, #e0f5ef, #c4ece0); } .sb-c-teal   svg { stroke: #0a8a5c; }
.sb-c-amber  { background: linear-gradient(145deg, #fff5e0, #fde8b0); } .sb-c-amber  svg { stroke: #c47f00; }
.sb-c-rose   { background: linear-gradient(145deg, #ffe8ee, #ffd0d9); } .sb-c-rose   svg { stroke: #d92b4b; }
.sb-c-violet { background: linear-gradient(145deg, #f0e8ff, #dfd0ff); } .sb-c-violet svg { stroke: #7c3aed; }
.sb-c-sky    { background: linear-gradient(145deg, #e0f3ff, #c0e6ff); } .sb-c-sky    svg { stroke: #0284c7; }
.sb-c-orange { background: linear-gradient(145deg, #fff0e0, #ffe0c0); } .sb-c-orange svg { stroke: #ea580c; }
.sb-c-slate  { background: linear-gradient(145deg, #eef0f5, #dde0eb); } .sb-c-slate  svg { stroke: #475569; }
.sb-c-green  { background: linear-gradient(145deg, #e0ffe8, #c0f0d0); } .sb-c-green  svg { stroke: #16a34a; }
[data-theme="dark"] .sb-c-blue   { background: linear-gradient(145deg, #1e2a4a, #1a2444); } [data-theme="dark"] .sb-c-blue   svg { stroke: #4d7fff; }
[data-theme="dark"] .sb-c-teal   { background: linear-gradient(145deg, #0f2820, #0d2418); } [data-theme="dark"] .sb-c-teal   svg { stroke: #1fba7e; }
[data-theme="dark"] .sb-c-amber  { background: linear-gradient(145deg, #2a2210, #24200c); } [data-theme="dark"] .sb-c-amber  svg { stroke: #f0a500; }
[data-theme="dark"] .sb-c-rose   { background: linear-gradient(145deg, #2e1420, #28101a); } [data-theme="dark"] .sb-c-rose   svg { stroke: #f5476a; }
[data-theme="dark"] .sb-c-violet { background: linear-gradient(145deg, #20143a, #1c1030); } [data-theme="dark"] .sb-c-violet svg { stroke: #a78bfa; }
[data-theme="dark"] .sb-c-sky    { background: linear-gradient(145deg, #0e2030, #0a1e2c); } [data-theme="dark"] .sb-c-sky    svg { stroke: #38bdf8; }
[data-theme="dark"] .sb-c-orange { background: linear-gradient(145deg, #2a1c0c, #241808); } [data-theme="dark"] .sb-c-orange svg { stroke: #fb923c; }
[data-theme="dark"] .sb-c-slate  { background: linear-gradient(145deg, #1e2030, #1a1c28); } [data-theme="dark"] .sb-c-slate  svg { stroke: #94a3b8; }
[data-theme="dark"] .sb-c-green  { background: linear-gradient(145deg, #0f2818, #0d2414); } [data-theme="dark"] .sb-c-green  svg { stroke: #4ade80; }
[data-theme="dark"] .sidebar-link.active .sb-icon-wrap { background: var(--accent); }
[data-theme="dark"] .sidebar-link.active .sb-icon-wrap svg { stroke: #fff; }

/* Fund NAVs sub-dropdown in sidebar -- overflow: visible so menu is never clipped */
.sidebar-dropdown { border-radius: 11px; overflow: visible; }
.sidebar-dropdown-trigger {
  display: flex; justify-content: space-between; align-items: center;
  padding: 10px 12px; cursor: pointer;
  font-size: 14px; font-weight: 500; color: var(--text-primary);
  border-radius: 11px; transition: background 0.18s; gap: 12px;
}
.sidebar-dropdown-trigger:active { background: var(--border); }
.sidebar-dropdown-trigger .trigger-left { display: flex; align-items: center; gap: 12px; }
.sidebar-dropdown-trigger .trigger-arrow {
  font-size: 16px; font-weight: 700;
  color: var(--text-secondary);
  transition: transform 0.25s ease; flex-shrink: 0; line-height: 1;
}
.sidebar-dropdown.funds-open .trigger-arrow { transform: rotate(180deg); }

.sidebar-dropdown-menu {
  display: none;
  background: var(--bg-card);
  margin: 4px 0 6px 46px;
  border-radius: 10px;
  border: 1px solid var(--border-md);
  overflow: hidden;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
}
.sidebar-dropdown-menu.open { display: block; }
.sidebar-dropdown-item {
  display: block; padding: 11px 16px;
  font-size: 13.5px; font-weight: 500;
  color: var(--text-secondary); text-decoration: none;
  transition: background 0.15s, color 0.15s;
  border-bottom: 1px solid var(--border);
}
.sidebar-dropdown-item:last-child { border-bottom: none; }
.sidebar-dropdown-item:active { background: var(--accent-soft); color: var(--accent); }
.sidebar-dropdown-item.active-item { color: var(--accent); font-weight: 600; background: var(--accent-soft); }

.sidebar-divider { height: 1px; background: var(--border); margin: 6px 4px; }
body.sidebar-open { overflow: hidden; }

/* ============================================================
   MOBILE FUND CARDS (Islamic / Conventional / Pension pages)
   All card styles live here so the inline <style> in each
   page only needs the desktop table CSS.
   ============================================================ */

/* Hidden on desktop, shown as flex on mobile */
.mobile-fund-list { display: none; flex-direction: column; gap: 10px; }

/* Filter card wrapper -- transparent passthrough on desktop */
.filter-bars-card { background: none; border: none; padding: 0; margin-bottom: 0; }

/* ── Cards ─────────────────────────────────────────────── */
.m-fund-card {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.m-fund-card:active { border-color: var(--accent-border); box-shadow: 0 2px 12px rgba(24,71,212,0.08); }

.m-card-head {
  display: flex; justify-content: space-between; align-items: flex-start;
  gap: 10px; padding: 14px 15px 12px;
  border-bottom: 1px solid var(--border);
}
.m-card-head-left { display: flex; flex-direction: column; gap: 5px; flex: 1; min-width: 0; }
.m-fund-name {
  font-size: 13.5px; font-weight: 600;
  color: var(--text-primary); line-height: 1.4; letter-spacing: -0.2px;
  flex: 1; min-width: 0;
}
.m-nav-block { display: flex; flex-direction: column; align-items: flex-end; flex-shrink: 0; gap: 1px; }
.m-nav-label { font-size: 9px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; color: var(--text-muted); }
.m-nav-val   { font-size: 13px; font-weight: 500; font-family: var(--mono); color: var(--text-secondary); letter-spacing: -0.2px; }
.m-nav-date  { font-size: 9.5px; font-family: var(--mono); color: var(--text-muted); }

.m-card-body { padding: 11px 15px 13px; }

/* Returns grid -- 4 columns */
.m-returns-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 6px; }

/* Base cell */
.m-ret-cell {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 9px; padding: 8px 4px;
  transition: border-color 0.15s;
}
.m-ret-label {
  font-size: 9px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.5px;
  color: var(--text-muted);
}
.m-ret-val {
  font-size: 12.5px; font-family: var(--mono); font-weight: 600;
  letter-spacing: -0.2px; color: var(--text-secondary);
}
.m-ret-val.pos  { color: var(--green); }
.m-ret-val.neg  { color: var(--red); }
.m-ret-val.dash { color: var(--text-muted); opacity: 0.45; }

/* 1D hero cell -- full-width banner at top */
.m-ret-cell.hero {
  grid-column: span 4;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  padding: 10px 16px;
  border-radius: 9px;
  background: var(--bg-card);
  border: 1px solid var(--border-md);
}
.m-ret-cell.hero .m-ret-label { font-size: 10px; color: var(--text-secondary); letter-spacing: 0.6px; }
.m-ret-cell.hero .m-ret-val   { font-size: 18px; letter-spacing: -0.5px; }
.m-ret-cell.hero.pos-cell { background: var(--green-soft); border-color: var(--green-border); }
.m-ret-cell.hero.neg-cell { background: var(--red-soft);   border-color: var(--red-border); }
.m-ret-cell.hero.pos-cell .m-ret-label { color: var(--green); opacity: 0.8; }
.m-ret-cell.hero.neg-cell .m-ret-label { color: var(--red);   opacity: 0.8; }

/* Pension sub-type badges */
.m-subtype-badge {
  display: inline-flex; align-items: center;
  font-size: 9.5px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.4px;
  padding: 2px 7px; border-radius: 4px; width: fit-content;
  background: var(--accent-soft); color: var(--accent); border: 1px solid var(--accent-border);
}
.m-subtype-badge.debt   { background: rgba(196,127,0,0.08);  color: #b45309; border-color: rgba(196,127,0,0.2); }
.m-subtype-badge.equity { background: rgba(124,58,237,0.08); color: #6d28d9; border-color: rgba(124,58,237,0.2); }
.m-subtype-badge.mm     { background: var(--green-soft);     color: var(--green); border-color: var(--green-border); }
.m-subtype-badge.comm   { background: var(--red-soft);       color: var(--red);   border-color: var(--red-border); }
[data-theme="dark"] .m-subtype-badge.debt   { background: rgba(240,165,0,0.12); color: #fbbf24; }
[data-theme="dark"] .m-subtype-badge.equity { background: rgba(139,92,246,0.12); color: #a78bfa; }

/* ============================================================
   NEWS PAGE STYLES
   ============================================================ */

/* News page needs full-width flex layout */
.page.news-page {
  max-width: none;
  padding: 0;
  display: flex;
  flex-direction: column;
  min-height: calc(100vh - var(--nav-h));
}

/* Top bar */
.top-bar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 28px 0; flex-shrink: 0; flex-wrap: wrap; gap: 12px;
}
.top-bar-left  { display: flex; align-items: center; gap: 14px; flex: 1 1 auto; min-width: 0; }
.top-bar-right { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }

.page-icon {
  width: 42px; height: 42px; border-radius: 12px;
  background: var(--accent-soft);
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.page-icon svg { width: 20px; height: 20px; stroke: var(--accent); fill: none; stroke-width: 2; }

.top-bar .page-title { font-size: 20px; font-weight: 700; letter-spacing: -0.4px; white-space: nowrap; }
.top-bar .page-sub   { font-size: 12px; color: var(--text-muted); margin-top: 1px; white-space: nowrap; }

/* News search + refresh */
.news-search-wrap { position: relative; min-width: 0; }
.news-search-wrap svg {
  position: absolute; left: 11px; top: 50%; transform: translateY(-50%);
  width: 15px; height: 15px; stroke: var(--text-muted); fill: none; stroke-width: 2;
  pointer-events: none;
}
.news-search-input {
  width: 240px; height: 38px; padding: 0 14px 0 34px;
  background: var(--bg); border: 1px solid var(--border);
  border-radius: 10px; font-size: 13px; font-family: var(--font);
  color: var(--text-primary); outline: none;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.news-search-input::placeholder { color: var(--text-muted); }
.news-search-input:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }

.news-refresh-btn {
  width: 38px; height: 38px; border-radius: 10px;
  border: 1px solid var(--border); background: transparent;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  color: var(--text-secondary); transition: all 0.2s; padding: 0;
}
.news-refresh-btn:hover { background: var(--border); color: var(--text-primary); }
.news-refresh-btn svg { width: 15px; height: 15px; stroke: currentColor; fill: none; stroke-width: 2; }
.news-refresh-btn.spinning svg { animation: spin 0.7s linear infinite; }

/* News filter bar */
.news-filter-bar {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 28px 16px; flex-shrink: 0; flex-wrap: wrap;
}

/* Source dropdown */
.filter-dropdown-wrap { position: relative; }
.filter-trigger {
  display: inline-flex; align-items: center; gap: 8px;
  height: 34px; padding: 0 14px;
  background: var(--bg-surface); border: 1px solid var(--border);
  border-radius: 20px; cursor: pointer;
  font-size: 12.5px; font-weight: 600; font-family: var(--font);
  color: var(--text-secondary);
  transition: all 0.18s; white-space: nowrap; user-select: none;
}
.filter-trigger:hover { border-color: var(--accent); color: var(--accent); }
.filter-trigger.has-filter { background: var(--accent); border-color: var(--accent); color: #fff; }
.filter-trigger svg { width: 13px; height: 13px; stroke: currentColor; fill: none; stroke-width: 2.5; }
.filter-trigger.open svg.chevron { transform: rotate(180deg); }

.filter-panel {
  position: absolute; top: calc(100% + 8px); left: 0;
  width: 280px; background: var(--bg-surface);
  border: 1px solid var(--border); border-radius: 16px;
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.28);
  z-index: 50;
  opacity: 0; pointer-events: none;
  transform: translateY(-6px) scale(0.98);
  transition: opacity 0.18s, transform 0.18s;
  display: flex; flex-direction: column;
  max-height: min(480px, 70vh); overflow: hidden;
}
.filter-panel.open { opacity: 1; pointer-events: all; transform: none; }

.filter-panel-scroll { overflow-y: auto; flex: 1; }
.filter-panel-scroll::-webkit-scrollbar { width: 4px; }
.filter-panel-scroll::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }

.panel-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px 10px; border-bottom: 1px solid var(--border);
}
.panel-header-label { font-size: 11px; font-weight: 700; letter-spacing: 0.8px; text-transform: uppercase; color: var(--text-muted); }
.panel-clear {
  font-size: 11px; font-weight: 600; color: var(--accent);
  background: none; border: none; cursor: pointer; padding: 0; font-family: var(--font);
  opacity: 0; pointer-events: none; transition: opacity 0.15s;
}
.panel-clear.visible { opacity: 1; pointer-events: all; }

.panel-section { padding: 10px 0; }
.panel-section + .panel-section { border-top: 1px solid var(--border); }

.panel-cat-label {
  display: flex; align-items: center; gap: 8px;
  padding: 4px 16px 8px;
  font-size: 10px; font-weight: 700; letter-spacing: 1px;
  color: var(--text-muted); text-transform: uppercase;
}
.cat-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.cat-dot.local         { background: #00d4aa; }
.cat-dot.regional      { background: var(--amber); }
.cat-dot.international { background: var(--accent); }

.panel-option {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 16px; cursor: pointer; transition: background 0.15s;
}
.panel-option:hover { background: var(--border); }
.panel-option input[type="checkbox"] { display: none; }
.custom-check {
  width: 16px; height: 16px; border-radius: 4px;
  border: 1.5px solid var(--border-md); background: var(--bg-card);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; transition: all 0.15s;
}
.panel-option.checked .custom-check { background: var(--accent); border-color: var(--accent); }
.custom-check svg { width: 10px; height: 10px; stroke: #fff; fill: none; stroke-width: 2.5; opacity: 0; transition: opacity 0.15s; }
.panel-option.checked .custom-check svg { opacity: 1; }
.option-label { font-size: 13px; color: var(--text-primary); }

/* Category quick-chips */
.cat-chip {
  height: 32px; padding: 0 16px; border-radius: 20px;
  border: 1.5px solid var(--border-md); background: transparent;
  font-size: 12px; font-weight: 600; font-family: var(--font);
  cursor: pointer; transition: all 0.18s; white-space: nowrap;
}
.cat-chip.local         { color: #00a688; }
.cat-chip.regional      { color: var(--amber); }
.cat-chip.international { color: var(--accent); }
.cat-chip.active.local         { background: #00d4aa; color: #fff; border-color: #00d4aa; }
.cat-chip.active.regional      { background: var(--amber);  color: #fff; border-color: var(--amber); }
.cat-chip.active.international { background: var(--accent); color: #fff; border-color: var(--accent); }

/* Active filter pills */
.active-filters { display: flex; flex-wrap: wrap; gap: 6px; }
.filter-pill {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 10px;
  border-radius: 20px; font-size: 11.5px; font-weight: 600;
  cursor: pointer; transition: all 0.15s;
}
.filter-pill svg { width: 10px; height: 10px; stroke: currentColor; fill: none; stroke-width: 2.5; }
.filter-pill.local         { background: rgba(0,212,170,0.12); color: #00a688; border: 1px solid rgba(0,212,170,0.2); }
.filter-pill.regional      { background: var(--amber-soft); color: var(--amber); border: 1px solid rgba(196,127,0,0.2); }
.filter-pill.international { background: var(--accent-soft); color: var(--accent); border: 1px solid var(--accent-border); }
.filter-pill:hover { opacity: 0.75; }

.result-count { font-size: 12px; color: var(--text-muted); font-family: var(--mono); margin-left: auto; white-space: nowrap; }

/* News grid */
.grid-wrap  { flex: 1; padding: 0 28px 40px; overflow-y: auto; min-height: 0; }
.news-grid  { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 16px; }

/* News cards */
.card {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  cursor: pointer;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.card:hover { border-color: var(--border-md); box-shadow: var(--shadow); }

/* Thumbnail -- position: relative so children can be absolute */
.card-thumb {
  position: relative;
  width: 100%;
  padding-top: 52%;      /* aspect-ratio box */
  background: var(--bg-card);
  overflow: hidden;
}
.card-thumb:not(.card-thumb-logo) img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s;
  display: block;
}
.card:hover .card-thumb:not(.card-thumb-logo) img { transform: scale(1.04); }

/* Gradient overlay on real images */
.card-thumb-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, transparent 40%, rgba(0,0,0,0.35) 100%);
  pointer-events: none;
}

/* Placeholder when no real image (shows source abbreviation) */
.card-source-placeholder {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: var(--bg-card);
}
.src-abbr {
  font-size: 22px; font-weight: 700;
  color: var(--text-muted); font-family: var(--mono);
  text-transform: uppercase; letter-spacing: 2px;
}
.src-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--accent); }

/* No-image fallback icon */
.card-no-thumb {
  position: relative;
  width: 100%; padding-top: 52%;
  background: var(--bg-card);
}
.card-no-thumb svg {
  position: absolute; inset: 0; margin: auto;
  width: 36px; height: 36px;
  stroke: var(--border-md); fill: none;
}

/* Card body */
.card-body { padding: 14px 16px 16px; }
.card-meta {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 8px; gap: 8px;
}
.card-time {
  font-size: 11px; color: var(--text-muted);
  font-family: var(--mono); white-space: nowrap;
  display: inline-flex; align-items: center; gap: 4px;
}
.card-time svg { width: 12px; height: 12px; stroke: currentColor; fill: none; }
.card-title {
  font-size: 14px; font-weight: 600;
  color: var(--text-primary); line-height: 1.5; letter-spacing: -0.2px;
  margin-bottom: 8px;
  display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden;
}
.card-summary {
  font-size: 12.5px; color: var(--text-secondary); line-height: 1.6;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}

/* Source badge */
.source-badge {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 10.5px; font-weight: 700; letter-spacing: 0.4px;
  text-transform: uppercase; padding: 3px 8px; border-radius: 4px; white-space: nowrap;
}
.source-badge.source-tribune,
.source-badge.source-nation,
.source-badge.source-brecorder,
.source-badge.source-dawn,
.source-badge.source-profit,
.source-badge.source-propakistani,
.source-badge.source-mettis { background: rgba(0,212,170,0.12); color: #00a688; }
.source-badge.source-arabnews,
.source-badge.source-gulfnews,
.source-badge.source-khaleejtimes { background: var(--amber-soft); color: var(--amber); }
.source-badge.source-reuters,
.source-badge.source-cnbc,
.source-badge.source-marketwatch,
.source-badge.source-investing,
.source-badge.source-default { background: var(--accent-soft); color: var(--accent); }
[data-theme="dark"] .source-badge.source-tribune,
[data-theme="dark"] .source-badge.source-dawn,
[data-theme="dark"] .source-badge.source-profit,
[data-theme="dark"] .source-badge.source-propakistani,
[data-theme="dark"] .source-badge.source-brecorder,
[data-theme="dark"] .source-badge.source-nation,
[data-theme="dark"] .source-badge.source-mettis { background: rgba(0,212,170,0.12); color: #00d4aa; }

/* Drawer */
.overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.5); z-index: 200;
  opacity: 0; pointer-events: none; transition: opacity 0.25s;
}
.overlay.open { opacity: 1; pointer-events: all; }

.drawer {
  position: fixed; top: 0; right: -100%;
  width: min(520px, 100vw); height: 100%;
  background: var(--bg-surface);
  border-left: 1px solid var(--border);
  z-index: 300; display: flex; flex-direction: column;
  transition: right 0.32s cubic-bezier(0.22, 1, 0.36, 1); overflow: hidden;
}
.drawer.open { right: 0; }

.drawer-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px; border-bottom: 1px solid var(--border);
  flex-shrink: 0; gap: 12px;
}
.close-btn {
  width: 32px; height: 32px; border-radius: 8px;
  border: 1px solid var(--border); background: transparent;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  color: var(--text-muted); transition: all 0.2s; flex-shrink: 0;
}
.close-btn:hover { background: var(--red-soft); color: var(--red); border-color: var(--red-border); }
.close-btn svg { width: 14px; height: 14px; stroke: currentColor; fill: none; stroke-width: 2.5; }

.drawer-body { flex: 1; overflow-y: auto; padding: 20px; }
.drawer-thumb { width: 100%; border-radius: var(--radius); overflow: hidden; margin-bottom: 16px; display: block; }
.drawer-thumb img { width: 100%; display: block; }
.drawer-date {
  font-size: 12px; color: var(--text-muted); font-family: var(--mono);
  display: inline-flex; align-items: center; gap: 6px; margin-bottom: 10px;
}
.drawer-date svg { width: 14px; height: 14px; stroke: currentColor; fill: none; }
.drawer-title {
  font-size: 18px; font-weight: 700; color: var(--text-primary);
  line-height: 1.45; letter-spacing: -0.4px; margin-bottom: 12px;
}
.drawer-summary { font-size: 14px; color: var(--text-secondary); line-height: 1.75; margin-bottom: 20px; }
.drawer-cta { margin-top: 24px; padding-top: 20px; border-top: 1px solid var(--border); }
.drawer-cta p { font-size: 12px; color: var(--text-muted); margin-bottom: 16px; line-height: 1.5; }
.read-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 11px 24px; border-radius: 10px;
  background: var(--accent); color: #fff;
  font-size: 14px; font-weight: 700; border: none; cursor: pointer;
  text-decoration: none; transition: opacity 0.2s, transform 0.15s;
}
.read-btn:hover { opacity: 0.9; transform: translateY(-1px); }
.read-btn svg { width: 16px; height: 16px; stroke: currentColor; fill: none; stroke-width: 2.5; }

/* Loading states (news) */
.state-center {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  min-height: 300px; gap: 12px;
}
.spin-icon { width: 28px; height: 28px; stroke: var(--accent); fill: none; animation: spin 0.8s linear infinite; }
.retry-btn {
  padding: 8px 16px;
  background: var(--accent-soft); border: 1px solid var(--accent-border);
  color: var(--accent); border-radius: 6px;
  font-size: 13px; font-weight: 600; cursor: pointer; transition: all 0.15s;
}
.retry-btn:hover { background: var(--accent); color: #fff; }

/* ============================================================
   RESPONSIVE
   ============================================================ */

/* Desktop: hide mobile-only elements */
@media (min-width: 769px) {
  .hamburger, .sidebar-overlay, .sidebar { display: none !important; }
  .mobile-fund-list { display: none !important; }
}

/* Tablet */
@media (max-width: 900px) {
  .stats-strip { grid-template-columns: repeat(3, 1fr); }
}

/* Mobile */
@media (max-width: 768px) {
  .hamburger     { display: flex; flex-shrink: 0; }
  .nav-links     { display: none; }
  nav            { padding: 0 14px; gap: 8px; }
  .nav-logo      { flex: 1; min-width: 0; }          /* fills the dead centre space */
  .nav-actions   { flex-shrink: 0; min-width: 0; gap: 6px; max-width: calc(100vw - 160px); overflow: hidden; }
  .page          { padding: 14px 12px 60px; }
  .page-head     { margin-bottom: 14px; flex-direction: column; gap: 10px; }
  .head-controls { width: 100%; }
  .search-wrap   { flex: 1; min-width: 0; }
  .index-tabs    { width: 100%; justify-content: stretch; }
  .idx-tab       { flex: 1; }
  .timestamp     { display: none; }

  .stats-strip { grid-template-columns: repeat(2, 1fr); gap: 8px; margin-bottom: 14px; }
  .stat-card   { padding: 12px 14px; }
  .stat-val    { font-size: 18px; }
  .stat-val.sm { font-size: 12px; }

  .premarket-countdown { font-size: 36px; }

  /* Fund NAV mobile -- show cards, hide table */
  .mobile-fund-list { display: flex; }

  /* Filter bars become a surface card on mobile */
  .filter-bars-card {
    background: var(--bg-surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 14px 14px 12px;
    margin-bottom: 14px;
    display: flex; flex-direction: column; gap: 12px;
  }
  /* Individual filter rows wrap freely */
  .filter-bar        { flex-wrap: wrap !important; overflow: visible !important; padding: 0 !important; margin-bottom: 0 !important; gap: 6px !important; }
  .filter-bar.type-bar { flex-wrap: wrap !important; overflow: visible !important; }
  .filter-label      { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.6px; color: var(--text-muted); width: 100%; margin: 0 0 2px; }

  /* News mobile */
  .top-bar          { padding: 14px 14px 0; }
  .news-filter-bar  { padding: 10px 14px 12px; }
  .grid-wrap        { padding: 0 14px 30px; }
  .news-grid        { grid-template-columns: 1fr; }
  .news-search-input { width: 160px; }
  .drawer           { width: 100%; }
}

@media (max-width: 640px) {
  .page { padding: 16px 14px 60px; }
  nav   { padding: 0 14px; }
}

@media (max-width: 480px) {
  .stats-strip { grid-template-columns: 1fr 1fr; }
}

/* ============================================================
   YOUTUBERS PAGE  [data-page="youtubers"]
   Paste this block into Styles.css in the page-specific section
   ASCII only — no unicode in comments
============================================================ */

/* -- tokens -- */
[data-page="youtubers"] { --yt-red: #ff0000; --yt-red-soft: rgba(255,0,0,0.08); }
[data-page="youtubers"][data-theme="dark"] { --yt-red: #ff4444; --yt-red-soft: rgba(255,68,68,0.1); }

/* -- api status chip -- */
[data-page="youtubers"] .api-active {
  display: none; align-items: center; gap: 8px;
  padding: 6px 12px; border-radius: 20px;
  background: var(--green-soft); border: 1px solid rgba(10,138,92,0.2);
}
[data-page="youtubers"] .api-active.show { display: flex; }
[data-page="youtubers"] .api-active-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--green); }
[data-page="youtubers"] .api-active span { font-size: 12px; font-family: var(--mono); color: var(--green); }

/* -- filter bar -- */
[data-page="youtubers"] .filter-bar {
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 20px; flex-wrap: wrap;
}
[data-page="youtubers"] .filter-chip {
  height: 30px; padding: 0 14px; border-radius: 20px;
  border: 1px solid var(--border-md); background: var(--bg-surface);
  color: var(--text-secondary); font-size: 12.5px; font-family: var(--font);
  cursor: pointer; transition: all 0.15s; white-space: nowrap; flex-shrink: 0;
}
[data-page="youtubers"] .filter-chip:hover { border-color: var(--accent-border); color: var(--accent); background: var(--accent-soft); }
[data-page="youtubers"] .filter-chip.active { border-color: var(--accent); color: var(--accent); background: var(--accent-soft); font-weight: 500; }

/* -- channels grid -- */
[data-page="youtubers"] .channels-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(480px, 1fr));
  gap: 16px;
}
[data-page="youtubers"] .channel-card {
  background: var(--bg-surface); border: 1px solid var(--border);
  border-radius: var(--radius); overflow: hidden;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  animation: cardIn 0.4s ease both;
}
[data-page="youtubers"] .channel-card:hover {
  border-color: var(--border-md);
  box-shadow: 0 4px 24px rgba(0,0,0,0.06);
}
@keyframes cardIn {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* -- channel header -- */
[data-page="youtubers"] .channel-header {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 16px; border-bottom: 1px solid var(--border);
  text-decoration: none; transition: background 0.15s;
}
[data-page="youtubers"] .channel-header:hover { background: var(--accent-soft); }
[data-page="youtubers"] .channel-avatar {
  width: 44px; height: 44px; border-radius: 50%; object-fit: cover;
  border: 2px solid var(--border-md); flex-shrink: 0; background: var(--bg-card);
}
[data-page="youtubers"] .channel-avatar-placeholder {
  width: 44px; height: 44px; border-radius: 50%; background: var(--accent-soft);
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; font-weight: 600; color: var(--accent); flex-shrink: 0;
  border: 2px solid var(--accent-border);
}
[data-page="youtubers"] .channel-meta { flex: 1; min-width: 0; }
[data-page="youtubers"] .channel-name {
  font-size: 14px; font-weight: 600; color: var(--text-primary);
  letter-spacing: -0.2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
[data-page="youtubers"] .channel-handle {
  font-size: 12px; font-family: var(--mono); color: var(--text-muted); margin-top: 1px;
}
[data-page="youtubers"] .channel-stats { display: flex; align-items: center; gap: 12px; flex-shrink: 0; }
[data-page="youtubers"] .channel-stat { text-align: right; }
[data-page="youtubers"] .channel-stat-val {
  font-size: 13px; font-weight: 600; font-family: var(--mono);
  color: var(--text-primary); letter-spacing: -0.3px;
}
[data-page="youtubers"] .channel-stat-label {
  font-size: 10px; font-weight: 500; text-transform: uppercase;
  letter-spacing: 0.5px; color: var(--text-muted); margin-top: 1px;
}
[data-page="youtubers"] .yt-link-icon { color: var(--yt-red); flex-shrink: 0; }
[data-page="youtubers"] .yt-link-icon svg { width: 20px; height: 20px; }

/* -- video embed -- */
[data-page="youtubers"] .video-embed-wrap {
  position: relative; width: 100%; padding-top: 56.25%; background: #000;
}
[data-page="youtubers"] .video-embed-wrap iframe {
  position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: none;
}
[data-page="youtubers"] .video-thumb-wrap {
  position: absolute; top: 0; left: 0; width: 100%; height: 100%;
  cursor: pointer; overflow: hidden;
}
[data-page="youtubers"] .video-thumb-wrap img {
  width: 100%; height: 100%; object-fit: cover; transition: transform 0.3s ease;
}
[data-page="youtubers"] .video-thumb-wrap:hover img { transform: scale(1.02); }
[data-page="youtubers"] .play-overlay {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  width: 56px; height: 56px; background: rgba(0,0,0,0.75); border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  transition: background 0.2s, transform 0.2s; pointer-events: none;
}
[data-page="youtubers"] .video-thumb-wrap:hover .play-overlay {
  background: var(--yt-red); transform: translate(-50%, -50%) scale(1.08);
}
[data-page="youtubers"] .play-overlay svg { width: 22px; height: 22px; color: #fff; margin-left: 3px; }
[data-page="youtubers"] .duration-badge {
  position: absolute; bottom: 8px; right: 8px;
  background: rgba(0,0,0,0.82); color: #fff;
  font-size: 11px; font-family: var(--mono); font-weight: 500;
  padding: 2px 7px; border-radius: 4px; pointer-events: none;
}

/* -- video info -- */
[data-page="youtubers"] .video-info { padding: 12px 16px 14px; }
[data-page="youtubers"] .video-title {
  font-size: 13.5px; font-weight: 500; color: var(--text-primary);
  line-height: 1.45; letter-spacing: -0.15px; margin-bottom: 8px;
  display: -webkit-box; -webkit-line-clamp: 2;
  -webkit-box-orient: vertical; overflow: hidden;
}
[data-page="youtubers"] .video-meta-row {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
}
[data-page="youtubers"] .video-meta-chip {
  display: flex; align-items: center; gap: 5px;
  font-size: 11.5px; font-family: var(--mono); color: var(--text-muted);
}
[data-page="youtubers"] .video-meta-chip svg { width: 12px; height: 12px; }
[data-page="youtubers"] .video-open-btn {
  margin-left: auto; height: 28px; padding: 0 12px;
  border-radius: var(--radius-sm); border: 1px solid var(--yt-red);
  background: var(--yt-red-soft); color: var(--yt-red);
  font-size: 12px; font-family: var(--font); font-weight: 500;
  cursor: pointer; text-decoration: none;
  display: flex; align-items: center; gap: 5px;
  transition: all 0.15s; flex-shrink: 0; white-space: nowrap;
}
[data-page="youtubers"] .video-open-btn:hover { background: var(--yt-red); color: #fff; }
[data-page="youtubers"] .video-open-btn svg { width: 12px; height: 12px; }

/* -- skeleton / loading -- */
[data-page="youtubers"] .channel-card.skeleton .channel-name,
[data-page="youtubers"] .channel-card.skeleton .channel-handle,
[data-page="youtubers"] .channel-card.skeleton .channel-stat-val,
[data-page="youtubers"] .channel-card.skeleton .channel-stat-label,
[data-page="youtubers"] .channel-card.skeleton .video-title,
[data-page="youtubers"] .channel-card.skeleton .video-meta-chip {
  background: var(--bg-card); border-radius: 4px; color: transparent;
  animation: shimmer 1.4s ease-in-out infinite; position: relative; overflow: hidden;
}
[data-page="youtubers"] .channel-card.skeleton .channel-avatar,
[data-page="youtubers"] .channel-card.skeleton .video-embed-wrap {
  background: var(--bg-card); animation: shimmer 1.4s ease-in-out infinite;
}
@keyframes shimmer { 0%, 100% { opacity: 1; } 50% { opacity: 0.5; } }

/* -- error state -- */
[data-page="youtubers"] .no-key-state {
  grid-column: 1 / -1; background: var(--bg-surface); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 64px 32px; text-align: center;
}
[data-page="youtubers"] .no-key-icon {
  width: 56px; height: 56px; border-radius: 12px; background: var(--yt-red-soft);
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 16px; color: var(--yt-red);
}
[data-page="youtubers"] .no-key-icon svg { width: 28px; height: 28px; }
[data-page="youtubers"] .no-key-title { font-size: 18px; font-weight: 600; color: var(--text-primary); margin-bottom: 8px; }
[data-page="youtubers"] .no-key-sub { font-size: 13px; color: var(--text-secondary); line-height: 1.6; max-width: 420px; margin: 0 auto 24px; }
[data-page="youtubers"] .no-key-sub a { color: var(--accent); text-decoration: none; }
[data-page="youtubers"] .no-key-sub a:hover { text-decoration: underline; }

/* -- responsive -- */
@media (min-width: 769px) {
  [data-page="youtubers"] .stats-strip { display: grid !important; grid-template-columns: repeat(4, 1fr) !important; gap: 10px; margin-bottom: 20px; }
  [data-page="youtubers"] .filter-bar { display: flex !important; flex-direction: row !important; flex-wrap: wrap; align-items: center; }
  [data-page="youtubers"] .filter-chip { width: auto !important; }
}
@media (max-width: 900px) {
  [data-page="youtubers"] .channels-grid { grid-template-columns: 1fr; }
  [data-page="youtubers"] .stats-strip { display: grid !important; grid-template-columns: repeat(2, 1fr) !important; gap: 10px; margin-bottom: 20px; }
}
@media (max-width: 768px) {
  [data-page="youtubers"] .stats-strip { display: grid !important; grid-template-columns: 1fr !important; gap: 10px; }
  [data-page="youtubers"] .filter-bar { display: grid !important; grid-template-columns: repeat(2, 1fr) !important; gap: 8px; }
  [data-page="youtubers"] .filter-chip { width: 100% !important; text-align: center; justify-content: center; display: flex; align-items: center; }
}

/* ============================================================
   ANALYSIS PAGE  [data-page="analysis"]
   Paste after the Youtubers section in Styles.css.
   ASCII only -- no unicode in comments.
============================================================ */

/* -- index cards grid -- */
[data-page="analysis"] .index-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 20px; }
[data-page="analysis"] .index-card { background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 20px 24px; transition: border-color 0.15s; }
[data-page="analysis"] .ic-top { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 10px; }
[data-page="analysis"] .ic-name { font-size: 12px; font-weight: 600; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.8px; }
[data-page="analysis"] .ic-badge { font-size: 11px; font-weight: 700; padding: 3px 10px; border-radius: 20px; letter-spacing: 0.3px; }
[data-page="analysis"] .ic-badge.bull { background: var(--green-soft); color: var(--green); }
[data-page="analysis"] .ic-badge.bear { background: var(--red-soft); color: var(--red); }
[data-page="analysis"] .ic-value { font-size: 34px; font-weight: 600; font-family: var(--mono); letter-spacing: -1.5px; line-height: 1; }
[data-page="analysis"] .ic-change { font-size: 13px; font-family: var(--mono); margin-top: 5px; }
[data-page="analysis"] .ic-change.up { color: var(--green); }
[data-page="analysis"] .ic-change.dn { color: var(--red); }
[data-page="analysis"] .ic-date { font-size: 11px; color: var(--text-muted); margin-top: 3px; font-family: var(--mono); }
[data-page="analysis"] .ic-divider { border: none; border-top: 1px solid var(--border); margin: 14px 0; }
[data-page="analysis"] .ic-dmas { display: grid; grid-template-columns: repeat(4,1fr); gap: 10px; }
[data-page="analysis"] .ic-dma-item { display: flex; flex-direction: column; gap: 3px; }
[data-page="analysis"] .ic-dma-label { font-size: 10px; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.4px; }
[data-page="analysis"] .ic-dma-val { font-size: 12px; font-family: var(--mono); font-weight: 500; }
[data-page="analysis"] .ic-dma-val.above { color: var(--green); }
[data-page="analysis"] .ic-dma-val.below { color: var(--red); }

/* -- controls bar -- */
[data-page="analysis"] .controls-bar { background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 14px 20px; margin-bottom: 16px; display: flex; align-items: center; gap: 20px; flex-wrap: wrap; }
[data-page="analysis"] .ctrl-group { display: flex; align-items: center; gap: 8px; }
[data-page="analysis"] .ctrl-label { font-size: 11px; font-weight: 600; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.5px; white-space: nowrap; }
[data-page="analysis"] .ctrl-select { background: var(--bg-card); border: 1px solid var(--border-md); border-radius: var(--radius-sm); padding: 6px 10px; color: var(--text-primary); font-size: 13px; font-family: var(--font); }
[data-page="analysis"] .ctrl-select:focus { outline: none; border-color: var(--accent); }
[data-page="analysis"] .ctrl-divider { width: 1px; height: 24px; background: var(--border-md); flex-shrink: 0; }

/* -- DMA chips -- */
[data-page="analysis"] .dma-chips { display: flex; flex-wrap: wrap; gap: 6px; }
[data-page="analysis"] .dma-chip { padding: 4px 11px; border-radius: 20px; font-size: 12px; font-weight: 500; font-family: var(--mono); border: 1px solid var(--border-md); background: var(--bg-card); color: var(--text-secondary); transition: all 0.15s; cursor: pointer; }
[data-page="analysis"] .dma-chip:hover { border-color: var(--accent); color: var(--accent); }
[data-page="analysis"] .dma-chip.on { background: var(--accent); color: #fff; border-color: var(--accent); }

/* -- chart panels -- */
[data-page="analysis"] .chart-panel { background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 20px; margin-bottom: 16px; }
[data-page="analysis"] .chart-panel-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 4px; }
[data-page="analysis"] .chart-panel-title { font-size: 14px; font-weight: 600; }
[data-page="analysis"] .chart-legend { display: flex; flex-wrap: wrap; gap: 18px; margin-bottom: 14px; padding-bottom: 12px; border-bottom: 1px solid var(--border); }
[data-page="analysis"] .legend-item { display: flex; align-items: center; gap: 8px; }
[data-page="analysis"] .legend-line-solid { width: 28px; height: 3px; border-radius: 2px; flex-shrink: 0; }
[data-page="analysis"] .legend-line-dashed { width: 28px; height: 0; flex-shrink: 0; border-bottom: 3px dashed; }
[data-page="analysis"] .legend-label { font-size: 12px; font-weight: 500; color: var(--text-secondary); font-family: var(--mono); white-space: nowrap; }
[data-page="analysis"] .chart-wrap { position: relative; height: 420px; }
[data-page="analysis"] .candle-wrap { position: relative; height: 340px; }

/* -- DMA grid cards -- */
[data-page="analysis"] .dma-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 20px; }
[data-page="analysis"] .dma-card { background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; }
[data-page="analysis"] .dma-card-head { padding: 13px 18px; background: var(--bg-card); border-bottom: 1px solid var(--border); font-size: 13px; font-weight: 600; }
[data-page="analysis"] .dma-row { display: flex; justify-content: space-between; align-items: center; padding: 9px 18px; border-bottom: 1px solid var(--border); }
[data-page="analysis"] .dma-row:last-child { border-bottom: none; }
[data-page="analysis"] .dma-row-label { font-size: 13px; font-family: var(--mono); color: var(--text-secondary); }
[data-page="analysis"] .dma-row-right { display: flex; align-items: center; gap: 12px; }
[data-page="analysis"] .dma-row-val { font-size: 13px; font-family: var(--mono); color: var(--text-secondary); }
[data-page="analysis"] .dma-emoji { font-size: 16px; }

/* -- states -- */
[data-page="analysis"] .intraday-closed { display: flex; align-items: center; justify-content: center; height: 180px; color: var(--text-muted); font-size: 13px; border: 1px dashed var(--border-md); border-radius: var(--radius); flex-direction: column; gap: 8px; }
[data-page="analysis"] .intraday-closed-icon { font-size: 28px; }
[data-page="analysis"] .error-block { background: var(--red-soft); border: 1px solid var(--red); border-radius: var(--radius); padding: 28px; text-align: center; margin: 20px 0; }
[data-page="analysis"] .error-title { font-weight: 600; margin-bottom: 6px; }
[data-page="analysis"] .error-msg { font-size: 13px; color: var(--text-secondary); }

/* -- mobile maximize button -- */
[data-page="analysis"] .chart-maximize-btn {
  display: none; align-items: center; justify-content: center;
  width: 34px; height: 34px; border-radius: 8px;
  background: var(--bg-card); border: 1px solid var(--border-md);
  color: var(--text-secondary); cursor: pointer; transition: all 0.15s; flex-shrink: 0;
}
[data-page="analysis"] .chart-maximize-btn svg { width: 16px; height: 16px; }

/* -- mobile fullscreen overlay (landscape rotated) -- */
[data-page="analysis"] .analysis-fullscreen {
  position: fixed; top: 0; left: 0;
  width: 100dvh; height: 100dvw;
  transform-origin: top left;
  transform: rotate(90deg) translate(0, -100%);
  background: var(--bg-surface); z-index: 1000;
  display: none; flex-direction: column;
  padding: calc(env(safe-area-inset-top, 0px) + 28px) 20px 20px 20px;
  overflow: hidden; box-sizing: border-box;
}
[data-page="analysis"] .analysis-fullscreen.active { display: flex; }
[data-page="analysis"] .analysis-fs-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; flex-shrink: 0; }
[data-page="analysis"] .analysis-fs-title { font-size: 15px; font-weight: 600; color: var(--text-primary); }
[data-page="analysis"] .analysis-fs-close {
  width: 44px; height: 44px; border-radius: 12px;
  background: var(--accent); border: none; color: #fff;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; font-size: 22px; font-weight: 700; flex-shrink: 0;
  box-shadow: 0 2px 8px rgba(0,0,0,0.2); transition: all 0.15s;
}
[data-page="analysis"] .analysis-fs-close:active { opacity: 0.8; transform: scale(0.95); }
[data-page="analysis"] .analysis-fs-wrap {
  flex: 1; position: relative; min-height: 0;
  border-radius: 12px; border: 1px solid var(--border); overflow: hidden;
}
[data-page="analysis"] .analysis-fs-wrap canvas { width: 100% !important; height: 100% !important; display: block; }

/* -- responsive -- */
@media (max-width: 900px) {
  [data-page="analysis"] .index-cards { grid-template-columns: 1fr; }
  [data-page="analysis"] .ic-dmas { grid-template-columns: repeat(2,1fr); }
  [data-page="analysis"] .dma-grid { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  [data-page="analysis"] .ic-value { font-size: 26px; }
  [data-page="analysis"] .controls-bar { gap: 12px; }
}
@media (max-width: 768px) {
  [data-page="analysis"] .chart-maximize-btn { display: flex; }
}

/* ============================================================
   WORLD VIEW PAGE  [data-page="world-view"]
   Paste after the Analysis section in Styles.css.
   ASCII only -- no unicode in comments.
============================================================ */

/* -- stats strip -- */
[data-page="world-view"] .wv-stats-strip { display: grid; grid-template-columns: repeat(4,1fr); gap: 10px; margin-bottom: 20px; }

/* -- update tag -- */
[data-page="world-view"] .update-tag { font-size: 11px; font-family: var(--mono); color: var(--text-muted); padding: 4px 10px; border-radius: 20px; border: 1px solid var(--border); white-space: nowrap; align-self: flex-start; margin-top: 4px; }

/* -- filter card -- */
[data-page="world-view"] .wv-filter-card { background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 14px 20px; margin-bottom: 18px; display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
[data-page="world-view"] .wv-chip-row { display: flex; gap: 5px; flex-wrap: wrap; }
[data-page="world-view"] .wv-chip { height: 28px; padding: 0 13px; border-radius: 4px; border: 1px solid var(--border-md); background: transparent; color: var(--text-secondary); font-size: 12.5px; font-family: var(--font); font-weight: 500; cursor: pointer; transition: all 0.15s; }
[data-page="world-view"] .wv-chip:hover { color: var(--text-primary); background: var(--bg-card); }
[data-page="world-view"] .wv-chip.active { background: var(--accent); color: #fff; border-color: var(--accent); }

/* -- map -- */
[data-page="world-view"] .map-wrap { background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; margin-bottom: 18px; position: relative; touch-action: pan-y; }
[data-page="world-view"] #map-container { width: 100%; height: 580px; position: relative; overflow: hidden; }
[data-page="world-view"] #map-container svg { width: 100%; height: 100%; display: block; }
[data-page="world-view"] .country-path { transition: opacity 0.12s; cursor: pointer; }
[data-page="world-view"] .country-path:hover { opacity: 0.78; }
[data-page="world-view"] .country-path.no-data { cursor: default; }
[data-page="world-view"] .country-path.no-data:hover { opacity: 1; }
[data-page="world-view"] .map-loading { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; background: var(--bg-surface); z-index: 5; gap: 6px; font-size: 12px; color: var(--text-muted); font-family: var(--mono); }
[data-page="world-view"] .ld { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); animation: pulse 1.2s ease-in-out infinite; }
[data-page="world-view"] .ld:nth-child(2) { animation-delay: .2s; }
[data-page="world-view"] .ld:nth-child(3) { animation-delay: .4s; }

/* -- map legend -- */
[data-page="world-view"] .map-legend { position: absolute; bottom: 16px; left: 20px; display: flex; align-items: center; gap: 8px; z-index: 10; }
[data-page="world-view"] .legend-label { font-size: 11px; font-family: var(--mono); color: var(--text-muted); }
[data-page="world-view"] .legend-gradient { width: 160px; height: 7px; border-radius: 4px; background: linear-gradient(to right, #d92b4b, #e8632a, #f0a020, #8fba3c, #0a8a5c); }
[data-page="world-view"] .map-attr { position: absolute; bottom: 8px; right: 12px; font-size: 10px; color: var(--text-muted); opacity: 0.45; }

/* -- map fullscreen toggle buttons -- */
[data-page="world-view"] .map-maximize-btn,
[data-page="world-view"] .map-close-btn { position: absolute; top: 12px; right: 12px; z-index: 20; width: 36px; height: 36px; border-radius: 8px; border: 1px solid var(--border-md); background: var(--bg-surface); color: var(--text-secondary); cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all 0.15s; padding: 0; }
[data-page="world-view"] .map-maximize-btn:hover,
[data-page="world-view"] .map-close-btn:hover { background: var(--bg-card); color: var(--text-primary); border-color: var(--accent); }
[data-page="world-view"] .map-close-btn { display: none; }
[data-page="world-view"] .map-rotate-hint { display: none; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); background: rgba(0,0,0,0.7); color: #fff; padding: 12px 20px; border-radius: 20px; font-size: 13px; font-family: var(--font); pointer-events: none; z-index: 15; white-space: nowrap; }

/* -- fullscreen state -- */
[data-page="world-view"] .map-wrap.fullscreen { position: fixed; top: 0; left: 0; width: 100vw; height: 100vh; z-index: 9999; border-radius: 0; margin: 0; display: flex; flex-direction: column; touch-action: none; }
[data-page="world-view"] .map-wrap.fullscreen #map-container { flex: 1; height: auto; min-height: 0; }
[data-page="world-view"] .map-wrap.fullscreen .map-maximize-btn { display: none; }
[data-page="world-view"] .map-wrap.fullscreen .map-close-btn { display: flex; }

/* -- tooltip -- */
[data-page="world-view"] #tooltip { position: fixed; z-index: 100; pointer-events: none; background: var(--bg-surface); border: 1px solid var(--border-md); border-radius: var(--radius-sm); padding: 11px 14px; box-shadow: 0 8px 28px rgba(0,0,0,0.14); opacity: 0; transition: opacity 0.1s; min-width: 175px; will-change: transform, opacity; }
[data-page="world-view"] #tooltip.show { opacity: 1; }
[data-page="world-view"] .tt-head { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
[data-page="world-view"] .tt-flag { font-size: 20px; line-height: 1; }
[data-page="world-view"] .tt-country { font-size: 13px; font-weight: 600; color: var(--text-primary); }
[data-page="world-view"] .tt-index-name { font-size: 11px; color: var(--text-muted); }
[data-page="world-view"] .tt-div { height: 1px; background: var(--border); margin-bottom: 8px; }
[data-page="world-view"] .tt-row { display: flex; justify-content: space-between; gap: 24px; margin-bottom: 3px; }
[data-page="world-view"] .tt-key { font-size: 11px; color: var(--text-muted); }
[data-page="world-view"] .tt-val { font-size: 12px; font-family: var(--mono); font-weight: 600; }
[data-page="world-view"] .tt-val.up { color: var(--green); }
[data-page="world-view"] .tt-val.down { color: var(--red); }
[data-page="world-view"] .tt-val.flat { color: var(--text-secondary); }

/* -- table -- */
[data-page="world-view"] .table-wrap { background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; }
[data-page="world-view"] .table-head { display: grid; grid-template-columns: 1.8fr 1.2fr 1fr 1fr 1fr 72px; padding: 10px 20px; border-bottom: 1px solid var(--border); background: var(--bg-card); }
[data-page="world-view"] .th { font-size: 10.5px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.6px; color: var(--text-muted); }
[data-page="world-view"] .th.r { text-align: right; }
[data-page="world-view"] .region-divider { padding: 7px 20px; font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.8px; color: var(--text-muted); background: var(--bg-card); border-bottom: 1px solid var(--border); }
[data-page="world-view"] .table-row { display: grid; grid-template-columns: 1.8fr 1.2fr 1fr 1fr 1fr 72px; padding: 10px 20px; border-bottom: 1px solid var(--border); align-items: center; transition: background 0.12s; }
[data-page="world-view"] .table-row:last-child { border-bottom: none; }
[data-page="world-view"] .table-row:hover { background: var(--bg-card); }
[data-page="world-view"] .td-country { display: flex; align-items: center; gap: 10px; min-width: 0; }
[data-page="world-view"] .td-flag { font-size: 18px; line-height: 1; }
[data-page="world-view"] .td-name { font-size: 13px; font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
[data-page="world-view"] .td-idx { font-size: 11px; color: var(--text-muted); }
[data-page="world-view"] .td-idx-col { font-size: 12px; color: var(--text-muted); display: flex; align-items: center; }
[data-page="world-view"] .td-updated { font-size: 11px; font-family: var(--mono); color: var(--text-muted); text-align: right; white-space: nowrap; display: flex; align-items: center; justify-content: flex-end; }
[data-page="world-view"] .td-live-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--green); display: inline-block; margin-left: 5px; animation: pulse 2.5s ease-in-out infinite; vertical-align: middle; }
[data-page="world-view"] .td-num { font-size: 13px; font-family: var(--mono); font-weight: 500; text-align: right; color: var(--text-secondary); letter-spacing: -0.3px; }
[data-page="world-view"] .td-chg { font-size: 13px; font-family: var(--mono); font-weight: 600; text-align: right; letter-spacing: -0.3px; }
[data-page="world-view"] .td-chg.up { color: var(--green); }
[data-page="world-view"] .td-chg.down { color: var(--red); }
[data-page="world-view"] .td-chg.flat { color: var(--text-secondary); }
[data-page="world-view"] .bar-wrap { display: flex; align-items: center; justify-content: flex-end; }
[data-page="world-view"] .bar-track { width: 80px; height: 4px; background: var(--border-md); border-radius: 2px; position: relative; overflow: hidden; }
[data-page="world-view"] .bar-fill { position: absolute; top: 0; height: 100%; border-radius: 2px; }

/* -- footer -- */
[data-page="world-view"] .footer { margin-top: 40px; padding-top: 24px; border-top: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; }
[data-page="world-view"] .footer-copy { font-size: 11.5px; color: var(--text-muted); line-height: 1.7; }
[data-page="world-view"] .footer-logo { font-size: 16px; font-weight: 600; color: var(--text-muted); letter-spacing: -0.3px; }
[data-page="world-view"] .footer-logo em { color: var(--accent); font-style: normal; }

/* -- responsive -- */
@media (max-width: 860px) {
  [data-page="world-view"] .wv-stats-strip { grid-template-columns: repeat(2,1fr); }
  [data-page="world-view"] .table-head,
  [data-page="world-view"] .table-row { grid-template-columns: 2fr 1.4fr 1fr 1fr; }
  [data-page="world-view"] .table-head .th:nth-child(4),
  [data-page="world-view"] .table-row > div:nth-child(4),
  [data-page="world-view"] .table-head .th:nth-child(6),
  [data-page="world-view"] .table-row > div:nth-child(6) { display: none !important; }
  [data-page="world-view"] #map-container { height: 340px; }
}
@media (max-width: 768px) {
  [data-page="world-view"] .wv-filter-card { flex-direction: column; align-items: flex-start; gap: 10px; }
  [data-page="world-view"] .wv-chip-row { display: grid; grid-template-columns: repeat(3, 1fr); width: 100%; gap: 6px; }
  [data-page="world-view"] .wv-chip { justify-content: center; text-align: center; padding: 0 6px; }
  [data-page="world-view"] #tooltip { max-width: 90vw; padding: 10px 12px; }
  [data-page="world-view"] .tt-country { font-size: 12px; }
  [data-page="world-view"] .tt-index-name { font-size: 10px; }
  [data-page="world-view"] .tt-val { font-size: 11px; }
  [data-page="world-view"] .map-wrap.fullscreen .map-rotate-hint { display: block; }
}
@media (max-width: 768px) and (orientation: landscape) {
  [data-page="world-view"] .map-wrap.fullscreen .map-rotate-hint { display: none; }
}
@media (max-width: 640px) {
  [data-page="world-view"] .table-head,
  [data-page="world-view"] .table-row { grid-template-columns: 2fr 1.5fr 1fr; padding: 12px 16px; gap: 8px; }
  [data-page="world-view"] .table-head .th:nth-child(3),
  [data-page="world-view"] .table-row > div:nth-child(3),
  [data-page="world-view"] .table-head .th:nth-child(4),
  [data-page="world-view"] .table-row > div:nth-child(4),
  [data-page="world-view"] .table-head .th:nth-child(6),
  [data-page="world-view"] .table-row > div:nth-child(6) { display: none !important; }
  [data-page="world-view"] .td-name { font-size: 14px; max-width: 140px; }
  [data-page="world-view"] .td-idx-col { font-size: 12px; line-height: 1.2; }
  [data-page="world-view"] .td-chg { font-size: 14px; font-weight: 600; }
  [data-page="world-view"] .th { font-size: 9px; letter-spacing: 0.4px; }
  [data-page="world-view"] .table-head .th:nth-child(5) { text-align: right; }
}

/* ============================================================
   TRENDS PAGE  [data-page="trends"]
   Paste after the World View section in Styles.css.
   ASCII only -- no unicode in comments.
============================================================ */

/* -- tokens -- */
[data-page="trends"] { --bg2: #ffffff; --bg3: #edf0f5; --bg4: #e2e6ef; --border2: rgba(0,0,0,0.13); --text2: #5a6070; --text3: #9aa0b0; --accent-glow: rgba(37,99,235,0.10); --green-bg: rgba(22,163,74,0.08); --red-bg: rgba(220,38,38,0.08); --radius2: 8px; }
[data-page="trends"][data-theme="dark"] { --bg2: #0f1117; --bg3: #151821; --bg4: #1c2030; --border2: rgba(255,255,255,0.12); --text2: #8b90a0; --text3: #555c70; --accent-glow: rgba(79,142,255,0.15); --green-bg: rgba(34,199,122,0.08); --red-bg: rgba(240,91,91,0.08); }

/* -- page layout -- */
[data-page="trends"] .trends-page { max-width: 1400px; margin: 0 auto; padding: 28px 24px 80px; }
[data-page="trends"] .page-header { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 20px; gap: 20px; flex-wrap: wrap; }
[data-page="trends"] .page-title { font-family: var(--font, 'Inter', sans-serif); font-size: 24px; font-weight: 600; letter-spacing: -0.6px; line-height: 1.2; }
[data-page="trends"] .page-title span { color: var(--accent); }
[data-page="trends"] .page-sub { font-size: 12px; color: var(--text3); margin-top: 4px; font-family: var(--mono); }

/* -- search -- */
[data-page="trends"] .search-wrap { position: relative; width: 260px; flex-shrink: 0; }
[data-page="trends"] .search-icon { position: absolute; left: 11px; top: 50%; transform: translateY(-50%); color: var(--text3); pointer-events: none; }
[data-page="trends"] .search-input { width: 100%; height: 38px; background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); padding: 0 12px 0 34px; color: var(--text); font-family: var(--font); font-size: 13px; outline: none; transition: border-color 0.15s; }
[data-page="trends"] .search-input::placeholder { color: var(--text3); }
[data-page="trends"] .search-input:focus { border-color: var(--accent); }
[data-page="trends"] .search-dropdown { position: absolute; top: calc(100% + 5px); left: 0; right: 0; background: var(--bg2); border: 1px solid var(--border2); border-radius: var(--radius); z-index: 50; box-shadow: 0 12px 40px rgba(0,0,0,0.15); display: none; max-height: 260px; overflow-y: auto; }
[data-page="trends"] .search-dropdown.open { display: block; }
[data-page="trends"] .drop-item { display: flex; align-items: center; justify-content: space-between; padding: 9px 13px; cursor: pointer; border-bottom: 1px solid var(--border); transition: background 0.1s; }
[data-page="trends"] .drop-item:last-child { border-bottom: none; }
[data-page="trends"] .drop-item:hover { background: var(--bg3); }
[data-page="trends"] .drop-name { font-size: 13px; font-weight: 500; }
[data-page="trends"] .drop-sector { font-size: 11px; color: var(--text3); font-family: var(--mono); }

/* -- desktop sector chips -- */
[data-page="trends"] .sector-bar { display: flex; align-items: center; gap: 6px; overflow-x: auto; padding-bottom: 12px; margin-bottom: 20px; scrollbar-width: thin; scrollbar-color: var(--border2) transparent; cursor: grab; }
[data-page="trends"] .sector-bar:active { cursor: grabbing; }
[data-page="trends"] .sector-bar::-webkit-scrollbar { height: 4px; }
[data-page="trends"] .sector-bar::-webkit-scrollbar-track { background: var(--bg3); border-radius: 2px; margin-top: 6px; }
[data-page="trends"] .sector-bar::-webkit-scrollbar-thumb { background: var(--border2); border-radius: 2px; }
[data-page="trends"] .chip { font-size: 12px; font-weight: 500; padding: 5px 14px; border-radius: 20px; border: 1px solid var(--border); color: var(--text2); background: var(--bg2); white-space: nowrap; flex-shrink: 0; transition: all 0.15s; }
[data-page="trends"] .chip:hover { border-color: var(--accent); color: var(--accent); }
[data-page="trends"] .chip.active { background: var(--accent); border-color: var(--accent); color: #fff; }

/* -- mobile sector filter -- */
[data-page="trends"] .mobile-sector-filter { display: none; margin-bottom: 20px; }
[data-page="trends"] .sector-trigger { width: 100%; display: flex; align-items: center; justify-content: space-between; padding: 12px 16px; background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); color: var(--text); font-family: var(--font); font-size: 14px; font-weight: 500; cursor: pointer; transition: all 0.15s; }
[data-page="trends"] .sector-trigger:hover { border-color: var(--accent); }
[data-page="trends"] .sector-trigger.active-filter { border-color: var(--accent); background: var(--accent-glow); color: var(--accent); }
[data-page="trends"] .trigger-left { display: flex; align-items: center; gap: 10px; }
[data-page="trends"] .trigger-label { color: var(--text3); font-weight: 400; }
[data-page="trends"] .trigger-value { font-weight: 600; color: var(--text); }
[data-page="trends"] .trigger-icon { width: 20px; height: 20px; color: var(--text3); }

/* -- mobile bottom sheet drawer -- */
[data-page="trends"] .sector-drawer-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,0.5); backdrop-filter: blur(4px); z-index: 200; opacity: 0; visibility: hidden; transition: opacity 0.25s, visibility 0.25s; }
[data-page="trends"] .sector-drawer-backdrop.open { opacity: 1; visibility: visible; }
[data-page="trends"] .sector-drawer { position: fixed; bottom: 0; left: 0; right: 0; background: var(--bg2); border-radius: 20px 20px 0 0; z-index: 201; transform: translateY(100%); transition: transform 0.3s cubic-bezier(0.22, 1, 0.36, 1); max-height: 60vh; display: flex; flex-direction: column; }
[data-page="trends"] .sector-drawer.open { transform: translateY(0); }
[data-page="trends"] .drawer-header { display: flex; align-items: center; justify-content: space-between; padding: 16px 20px; border-bottom: 1px solid var(--border); flex-shrink: 0; }
[data-page="trends"] .drawer-title { font-size: 17px; font-weight: 600; color: var(--text); }
[data-page="trends"] .drawer-close { width: 32px; height: 32px; border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--text2); font-size: 20px; cursor: pointer; transition: background 0.15s; }
[data-page="trends"] .drawer-close:active { background: var(--bg3); }
[data-page="trends"] .sector-list { flex: 1; overflow-y: auto; padding: 8px 0 20px 0; }
[data-page="trends"] .sector-option { display: flex; align-items: center; justify-content: space-between; padding: 16px 20px; cursor: pointer; transition: background 0.15s; border-bottom: 1px solid var(--border); }
[data-page="trends"] .sector-option:last-child { border-bottom: none; }
[data-page="trends"] .sector-option:active { background: var(--bg3); }
[data-page="trends"] .sector-option.active { background: var(--accent-glow); }
[data-page="trends"] .option-name { font-size: 16px; color: var(--text); font-weight: 500; }
[data-page="trends"] .sector-option.active .option-name { color: var(--accent); font-weight: 600; }
[data-page="trends"] .check-icon { width: 20px; height: 20px; color: var(--accent); opacity: 0; }
[data-page="trends"] .sector-option.active .check-icon { opacity: 1; }

/* -- ticker -- */
[data-page="trends"] .ticker-wrap { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); padding: 8px 12px 16px; margin-bottom: 20px; overflow-x: auto; position: relative; scrollbar-width: thin; cursor: grab; }
[data-page="trends"] .ticker-wrap:active { cursor: grabbing; }
[data-page="trends"] .ticker-wrap::-webkit-scrollbar { height: 4px; }
[data-page="trends"] .ticker-wrap::-webkit-scrollbar-track { background: var(--bg3); border-radius: 2px; margin-top: 6px; }
[data-page="trends"] .ticker-wrap::-webkit-scrollbar-thumb { background: var(--border2); border-radius: 2px; }
[data-page="trends"] .ticker-track { display: flex; gap: 10px; width: max-content; animation: ticker-scroll 80s linear infinite; }
[data-page="trends"] .ticker-track:hover { animation-play-state: paused; }
@keyframes ticker-scroll { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }
[data-page="trends"] .ticker-item { display: inline-flex; align-items: center; gap: 6px; padding: 4px 11px; border-radius: 14px; background: var(--bg3); border: 1px solid var(--border); font-family: var(--mono); font-size: 11px; color: var(--text2); cursor: pointer; flex-shrink: 0; transition: all 0.15s; white-space: nowrap; }
[data-page="trends"] .ticker-item:hover { background: var(--accent); border-color: var(--accent); color: #fff; }

/* -- stock grid -- */
[data-page="trends"] .section-row { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
[data-page="trends"] .section-label { font-size: 12px; font-weight: 600; letter-spacing: 1.2px; text-transform: uppercase; color: var(--text3); }
[data-page="trends"] .sort-note { font-size: 11px; color: var(--text3); font-family: var(--mono); }
[data-page="trends"] .stock-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(192px, 1fr)); gap: 10px; margin-bottom: 24px; }
[data-page="trends"] .stock-card { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); padding: 14px 14px 10px; cursor: pointer; position: relative; overflow: hidden; transition: border-color 0.15s, transform 0.15s, box-shadow 0.15s; }
[data-page="trends"] .stock-card:hover { border-color: var(--border2); transform: translateY(-2px); box-shadow: 0 6px 20px rgba(0,0,0,0.08); }
[data-page="trends"] .stock-card.selected { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent), 0 6px 24px var(--accent-glow); }
[data-page="trends"] .sc-check { position: absolute; top: 10px; right: 10px; width: 16px; height: 16px; border-radius: 4px; border: 1.5px solid var(--border2); background: var(--bg); display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: all 0.15s; pointer-events: none; }
[data-page="trends"] .stock-card.checked .sc-check { background: var(--accent); border-color: var(--accent); }
[data-page="trends"] .stock-card.checked .sc-check::after { content: ''; width: 5px; height: 9px; border: 2px solid #fff; border-top: none; border-left: none; transform: rotate(42deg) translate(-1px,-1px); display: block; }
[data-page="trends"] .sc-name { font-size: 12px; font-weight: 500; color: var(--text); line-height: 1.3; margin-bottom: 6px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; padding-right: 26px; }
[data-page="trends"] .sc-price { font-family: var(--mono); font-size: 17px; font-weight: 500; letter-spacing: -0.3px; }
[data-page="trends"] .sc-bottom { display: flex; align-items: flex-end; justify-content: space-between; margin-top: 8px; }
[data-page="trends"] .sc-badges { display: flex; flex-direction: column; gap: 3px; }
[data-page="trends"] .sc-chg { font-family: var(--mono); font-size: 11px; font-weight: 500; padding: 2px 6px; border-radius: 4px; display: inline-block; }
[data-page="trends"] .sc-chg.pos { color: var(--green); background: var(--green-bg); }
[data-page="trends"] .sc-chg.neg { color: var(--red); background: var(--red-bg); }
[data-page="trends"] .sc-period { font-family: var(--mono); font-size: 10px; }
[data-page="trends"] .sc-period.pos { color: var(--green); }
[data-page="trends"] .sc-period.neg { color: var(--red); }
[data-page="trends"] .sparkline-wrap { width: 64px; height: 30px; flex-shrink: 0; }
[data-page="trends"] .no-results { text-align: center; padding: 40px; color: var(--text3); font-family: var(--mono); font-size: 13px; }

/* -- stats strip -- */
[data-page="trends"] .stats-strip { display: grid; grid-template-columns: repeat(4,1fr); gap: 10px; margin-bottom: 24px; }
[data-page="trends"] .stat-card { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); padding: 14px; }
[data-page="trends"] .stat-label { font-size: 10px; color: var(--text3); font-family: var(--mono); letter-spacing: 0.8px; text-transform: uppercase; }
[data-page="trends"] .stat-val { font-family: var(--mono); font-size: 18px; font-weight: 500; margin-top: 4px; letter-spacing: -0.4px; }
[data-page="trends"] .stat-sub { font-size: 11px; color: var(--text3); margin-top: 2px; }

/* -- chart panel -- */
[data-page="trends"] .chart-panel { background: var(--bg2); border: 1px solid var(--border); border-radius: 16px; padding: 22px; position: relative; overflow: hidden; }
[data-page="trends"] .chart-panel::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--accent), transparent); opacity: 0.3; }
[data-page="trends"] .chart-header { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 16px; gap: 16px; flex-wrap: wrap; }
[data-page="trends"] .chart-info { flex: 1; min-width: 0; }
[data-page="trends"] .chart-name { font-size: 18px; font-weight: 700; letter-spacing: -0.3px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
[data-page="trends"] .chart-meta { font-family: var(--mono); font-size: 11px; color: var(--text3); margin-top: 2px; }
[data-page="trends"] .chart-price-block { text-align: right; flex-shrink: 0; }
[data-page="trends"] .chart-price { font-family: var(--mono); font-size: 26px; font-weight: 500; letter-spacing: -0.8px; }
[data-page="trends"] .chart-change { font-family: var(--mono); font-size: 12px; margin-top: 2px; }
[data-page="trends"] .chart-change.pos { color: var(--green); }
[data-page="trends"] .chart-change.neg { color: var(--red); }
[data-page="trends"] .chart-maximize-btn { display: none; align-items: center; justify-content: center; width: 36px; height: 36px; border-radius: 8px; background: var(--bg3); border: 1px solid var(--border); color: var(--text2); cursor: pointer; transition: all 0.15s; margin-left: auto; }
[data-page="trends"] .chart-maximize-btn:hover { background: var(--accent-glow); border-color: var(--accent); color: var(--accent); }
[data-page="trends"] .chart-maximize-btn svg { width: 18px; height: 18px; }
[data-page="trends"] .tf-bar { display: flex; align-items: center; gap: 3px; margin-bottom: 14px; }
[data-page="trends"] .tf-btn { font-family: var(--mono); font-size: 11px; font-weight: 500; padding: 4px 10px; border-radius: 6px; color: var(--text3); border: 1px solid transparent; letter-spacing: 0.3px; transition: all 0.12s; }
[data-page="trends"] .tf-btn:hover { color: var(--text2); background: var(--bg3); }
[data-page="trends"] .tf-btn.active { color: var(--accent); background: var(--accent-glow); border-color: rgba(37,99,235,0.2); }
[data-page="trends"][data-theme="dark"] .tf-btn.active { border-color: rgba(79,142,255,0.2); }
[data-page="trends"] .chart-wrap { position: relative; height: 400px; width: 100%; }
[data-page="trends"] .chart-overlay { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; background: var(--bg2); border-radius: 12px; z-index: 2; }
[data-page="trends"] .spinner { width: 30px; height: 30px; border: 2px solid var(--border2); border-top-color: var(--accent); border-radius: 50%; animation: spin 0.8s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
[data-page="trends"] .overlay-text { font-size: 12px; color: var(--text3); font-family: var(--mono); }
[data-page="trends"] .chart-legend { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 14px; }
[data-page="trends"] .legend-item { display: flex; align-items: center; gap: 6px; font-size: 11px; color: var(--text2); font-family: var(--mono); padding: 3px 8px; border-radius: 4px; border: 1px solid var(--border); }
[data-page="trends"] .legend-line { width: 20px; height: 3px; border-radius: 2px; flex-shrink: 0; }

/* -- mobile fullscreen chart overlay -- */
[data-page="trends"] .chart-fullscreen { position: fixed; top: 0; left: 0; width: 100dvh; height: 100dvw; transform-origin: top left; transform: rotate(90deg) translate(0, -100%); background: var(--bg2); z-index: 1000; display: none; flex-direction: column; padding: calc(env(safe-area-inset-top, 0px) + 28px) 20px 20px 20px; overflow: hidden; box-sizing: border-box; }
[data-page="trends"] .chart-fullscreen.active { display: flex; }
[data-page="trends"] .chart-fullscreen-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; flex-shrink: 0; }
[data-page="trends"] .chart-fullscreen-title { font-size: 16px; font-weight: 600; color: var(--text); }
[data-page="trends"] .chart-fullscreen-close { width: 44px; height: 44px; border-radius: 12px; background: var(--accent); border: none; color: #fff; display: flex; align-items: center; justify-content: center; cursor: pointer; font-size: 22px; font-weight: 700; flex-shrink: 0; transition: all 0.15s; box-shadow: 0 2px 8px rgba(0,0,0,0.2); }
[data-page="trends"] .chart-fullscreen-close:active { opacity: 0.8; transform: scale(0.95); }
[data-page="trends"] .chart-fullscreen-wrap { flex: 1; position: relative; min-height: 0; background: var(--bg2); border-radius: 12px; border: 1px solid var(--border); overflow: hidden; }
[data-page="trends"] .chart-fullscreen-hint { position: absolute; bottom: 16px; left: 50%; transform: translateX(-50%); background: rgba(0,0,0,0.7); color: #fff; padding: 6px 14px; border-radius: 20px; font-size: 11px; font-family: var(--mono); pointer-events: none; opacity: 0; transition: opacity 0.3s; }
[data-page="trends"] .chart-fullscreen-hint.show { opacity: 1; }

/* -- canvas -- */
[data-page="trends"] #mainChart { width: 100% !important; height: 100% !important; display: block; }
[data-page="trends"] canvas { max-width: 100%; }

/* -- responsive -- */
@media (max-width: 768px) {
  [data-page="trends"] .trends-page { padding: 16px 12px 60px; }
  [data-page="trends"] .chart-wrap { height: 260px; }
  [data-page="trends"] .page-title { font-size: 22px; }
  [data-page="trends"] .search-wrap { width: 100%; }
  [data-page="trends"] .page-header { flex-direction: column; }
  [data-page="trends"] .stats-strip { grid-template-columns: repeat(2,1fr); }
  [data-page="trends"] .sector-bar { display: none !important; }
  [data-page="trends"] .mobile-sector-filter { display: block; }
  [data-page="trends"] .chart-maximize-btn { display: flex; }
  [data-page="trends"] .ticker-wrap { margin-bottom: 16px; }
  [data-page="trends"] .ticker-track { animation-duration: 60s; }
}

/* ============================================================
   FUND BREAKDOWN -- page-specific styles
   (fund cards, badges, exposure, filter chips, sparklines)
   ============================================================ */

/* ── STATS STRIP (fund-breakdown variant: 4 cols) ─────────── */
.fund-page .stats-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin-bottom: 20px;
}
.stat-val.blue { color: var(--accent); }

/* ── FILTER CARD ──────────────────────────────────────────── */
.filter-card {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 16px 20px;
  margin-bottom: 18px;
  display: flex; flex-direction: column; gap: 12px;
}
.filter-row {
  display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
}
.filter-label {
  font-size: 10.5px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.6px;
  color: var(--text-muted); white-space: nowrap; min-width: 56px;
}
.chip-row  { display: flex; gap: 5px; flex-wrap: wrap; align-items: center; }
.amc-row   { display: flex; gap: 5px; flex-wrap: wrap; align-items: center; flex: 1; }

/* Fund-page chips (square corners, different from stock-watch pill chips) */
.fund-page .chip {
  height: 28px; padding: 0 13px;
  border-radius: 4px;
  border: 1px solid var(--border-md);
  background: transparent; color: var(--text-secondary);
  font-size: 12.5px; font-family: var(--font); font-weight: 500;
  cursor: pointer; transition: all 0.15s ease; white-space: nowrap;
}
.fund-page .chip:hover        { color: var(--text-primary); background: var(--bg-card); }
.fund-page .chip.active       { background: var(--accent); color: #fff; border-color: var(--accent); }
.fund-page .chip.active-green { background: var(--green);  color: #fff; border-color: var(--green); }

/* AMC chips (mono font) */
/* ── AMC LOGO CHIPS ───────────────────────────────────────── */
.amc-chip {
  display: inline-flex; align-items: center; gap: 6px;
  height: 34px; padding: 0 10px 0 6px;
  border-radius: 8px; border: 1px solid var(--border-md);
  background: var(--bg-surface); color: var(--text-secondary);
  font-size: 12px; font-weight: 500;
  cursor: pointer; transition: all 0.15s ease; white-space: nowrap;
}
.amc-chip:hover  { border-color: var(--accent-border); background: var(--bg-card); color: var(--text-primary); }
.amc-chip.active { border-color: var(--accent); background: var(--accent-soft); color: var(--accent); }
.amc-chip.active .amc-logo-img { filter: none; }

/* "All" chip -- text only, no logo */
.amc-chip.amc-all { padding: 0 14px; font-weight: 600; }
.amc-chip.amc-all.active { background: var(--accent); color: #fff; border-color: var(--accent); }

/* Logo image inside chip */
.amc-logo-img {
  height: 20px; width: auto; max-width: 52px;
  object-fit: contain; display: block; flex-shrink: 0;
  border-radius: 3px;
}

/* Avatar initials fallback */
.amc-avatar {
  width: 22px; height: 22px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 8px; font-weight: 700; flex-shrink: 0;
  color: #fff; letter-spacing: 0;
}

/* Dark mode -- slightly brighten logos */
[data-theme="dark"] .amc-logo-img { filter: brightness(1.1); }
[data-theme="dark"] .amc-chip { background: var(--bg-card); }
[data-theme="dark"] .amc-chip:hover { background: var(--bg-surface); }

/* Mobile -- full width chips */
@media (max-width: 768px) {
  .amc-chip { height: 38px; padding: 0 10px 0 7px; }
}

/* ── RESULTS ROW ──────────────────────────────────────────── */
.results-row        { font-size: 12px; color: var(--text-muted); margin-bottom: 14px; }
.results-row strong { color: var(--text-primary); }

/* ── FUNDS GRID ───────────────────────────────────────────── */
.funds-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(400px, 1fr));
  gap: 12px;
}

/* ── FUND CARD ────────────────────────────────────────────── */
.fund-card {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  transition: border-color 0.15s, box-shadow 0.15s;
  display: flex; flex-direction: column;
}
.fund-card:hover {
  border-color: var(--border-md);
  box-shadow: 0 2px 12px rgba(0,0,0,0.06);
}
.card-head {
  padding: 14px 16px 11px;
  border-bottom: 1px solid var(--border);
}
.card-top {
  display: flex; justify-content: space-between;
  align-items: flex-start; gap: 8px; margin-bottom: 10px;
}
.card-name {
  font-size: 13px; font-weight: 600;
  color: var(--text-primary); line-height: 1.4; letter-spacing: -0.2px;
}
.card-badges {
  display: flex; flex-direction: column;
  align-items: flex-end; gap: 4px; flex-shrink: 0;
}

/* ── BADGES ───────────────────────────────────────────────── */
.badge {
  font-size: 9.5px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.5px;
  padding: 2px 7px; border-radius: 3px; white-space: nowrap;
}
.badge-islamic  { background: var(--green-soft);  color: var(--green);  border: 1px solid var(--green-border); }
.badge-conv     { background: var(--accent-soft); color: var(--accent); border: 1px solid var(--accent-border); }
.badge-balanced { background: rgba(14,165,233,0.08); color: #0284c7; border: 1px solid rgba(14,165,233,0.2); }
.badge-asset    { background: var(--accent-soft); color: var(--accent); border: 1px solid var(--accent-border); }
.badge-dividend { background: rgba(217,119,6,0.08); color: #b45309; border: 1px solid rgba(217,119,6,0.2); }
.badge-energy   { background: rgba(234,88,12,0.08); color: #c2410c; border: 1px solid rgba(234,88,12,0.2); }
.badge-stock    { background: rgba(124,58,237,0.08); color: #6d28d9; border: 1px solid rgba(124,58,237,0.2); }
.badge-sector   { background: var(--red-soft); color: var(--red); border: 1px solid var(--red-border); }
.badge-etf      { background: rgba(100,116,139,0.08); color: #475569; border: 1px solid rgba(100,116,139,0.2); }

[data-theme="dark"] .badge-balanced { background: rgba(14,165,233,0.12); color: #38bdf8; }
[data-theme="dark"] .badge-dividend { background: rgba(245,158,11,0.12); color: #fbbf24; }
[data-theme="dark"] .badge-energy   { background: rgba(251,146,60,0.12);  color: #fb923c; }
[data-theme="dark"] .badge-stock    { background: rgba(139,92,246,0.12);  color: #a78bfa; }
[data-theme="dark"] .badge-etf      { background: rgba(148,163,184,0.1);  color: #94a3b8; }

/* ── EXPOSURE BAR ─────────────────────────────────────────── */
.exposure-row { display: flex; align-items: center; gap: 10px; }
.exp-track    { flex: 1; height: 3px; background: var(--border-md); border-radius: 2px; overflow: hidden; }
.exp-fill     { height: 100%; border-radius: 2px; background: var(--accent); opacity: 0.45; }
.exp-label    { font-size: 11px; font-family: var(--mono); color: var(--text-muted); white-space: nowrap; }
.exp-label span { color: var(--text-secondary); font-weight: 500; }

/* ── HOLDINGS TABLE ───────────────────────────────────────── */
.card-body      { padding: 10px 16px 0; display: flex; flex-direction: column; flex: 1; }
.card-body-rows { flex: 1; }
.h-total        { margin-top: auto; }

.holdings-head {
  display: grid; grid-template-columns: 1fr 36px 46px 68px 60px;
  gap: 6px; align-items: center;
  font-size: 9.5px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.5px;
  color: var(--text-muted); margin-bottom: 6px;
  padding-bottom: 4px; border-bottom: 1px solid var(--border-md);
}
.holdings-head span              { text-align: right; }
.holdings-head span:first-child  { text-align: left; }

.h-row {
  display: grid; grid-template-columns: 1fr 36px 46px 68px 60px;
  align-items: center; gap: 6px;
  padding: 5px 0; border-bottom: 1px solid var(--border);
}
.h-row:last-child { border-bottom: none; }

.h-name { font-size: 12px; color: var(--text-primary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.h-wt   { font-size: 11.5px; font-family: var(--mono); color: var(--text-secondary); text-align: right; font-weight: 500; }
.h-spark { display: flex; align-items: center; justify-content: center; }
.h-spark svg { display: block; }
.h-chg  { font-size: 11px; font-family: var(--mono); text-align: right; font-weight: 500; }
.h-chg.pos  { color: var(--green); }
.h-chg.neg  { color: var(--red); }
.h-chg.flat { color: var(--text-muted); }
.h-pl   { font-size: 11px; font-family: var(--mono); text-align: right; font-weight: 500; padding: 2px 5px; border-radius: 3px; }
.h-pl.pos  { background: var(--green-soft); color: var(--green); }
.h-pl.neg  { background: var(--red-soft);   color: var(--red); }
.h-pl.flat { color: var(--text-muted); }

/* Unknown exposure row */
.h-unknown {
  display: grid; grid-template-columns: 1fr 36px 46px 68px 60px;
  align-items: center; gap: 6px;
  padding: 5px 0 6px;
  border-top: 1px dashed var(--border-md); margin-top: 2px;
}
.h-unknown .h-name { color: var(--text-muted); font-style: italic; font-size: 11.5px; }
.h-unknown .h-wt   { color: var(--text-muted); }

/* Total row */
.h-total {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 0 10px; border-top: 1px solid var(--border-md);
  margin-top: 2px; gap: 10px;
}
.h-total-label { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; color: var(--text-secondary); }
.h-total-note  { font-size: 10.5px; color: var(--text-muted); line-height: 1.5; margin-top: 2px; }
.h-total-val   { font-size: 13px; font-family: var(--mono); font-weight: 600; padding: 3px 8px; border-radius: 4px; white-space: nowrap; flex-shrink: 0; }
.h-total-val.pos  { background: var(--green-soft); color: var(--green); }
.h-total-val.neg  { background: var(--red-soft);   color: var(--red); }
.h-total-val.flat { color: var(--text-muted); }

/* Loading shimmer */
.h-loading {
  display: inline-block; width: 36px; height: 10px;
  background: var(--border-md); border-radius: 3px;
  animation: shimmer 1.4s ease infinite;
}
@keyframes shimmer { 0%,100%{ opacity:0.5; } 50%{ opacity:1; } }

/* Empty state */
.empty-state {
  grid-column: 1 / -1;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding: 72px 24px;
}
.empty-state p { font-size: 13px; color: var(--text-muted); }

/* ── FOOTER ───────────────────────────────────────────────── */
.footer {
  margin-top: 36px; padding-top: 18px;
  border-top: 1px solid var(--border);
  display: flex; align-items: center;
  justify-content: space-between; flex-wrap: wrap; gap: 8px;
}
.footer-copy { font-size: 11.5px; color: var(--text-muted); line-height: 1.6; }
.footer-logo { font-size: 14px; font-weight: 600; color: var(--text-secondary); letter-spacing: -0.3px; }
.footer-logo em { color: var(--accent); font-style: normal; }

/* ── FUND BREAKDOWN RESPONSIVE ────────────────────────────── */
@media (max-width: 1100px) { .fund-page .stats-strip { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) {
  .funds-grid { grid-template-columns: 1fr; }
  .filter-card { padding: 14px 12px; }
  .filter-row  { gap: 8px; }
  .fund-page .chip-row, .fund-page .amc-row {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(80px, auto));
    justify-content: center; gap: 8px; width: 100%;
  }
  .fund-page .chip, .amc-chip { width: 100%; text-align: center; padding: 0 8px; }
  .filter-label    { min-width: 100%; margin-bottom: 4px; }
  .fund-page .stats-strip { grid-template-columns: repeat(2, 1fr); }
  .fund-card .card-head { padding: 12px 12px 8px; }
  .card-name { font-size: 12.5px; }
  .holdings-head, .h-row, .h-unknown { grid-template-columns: 1fr 30px 40px 55px 45px; gap: 4px; }
  .h-name { font-size: 11px; }
  .h-wt, .h-chg, .h-pl { font-size: 10px; }
  .h-spark svg { width: 40px; height: 16px; }
  .h-total-val { font-size: 12px; padding: 2px 6px; }
}

/* ============================================================
   ADMIN TRADES -- page-specific tokens + layout
   ============================================================ */

:root {
  --green-row:       rgba(10,138,92,0.035);
  --green-row-solid: #f2faf6;
  --red-row:         rgba(217,43,75,0.035);
  --red-row-solid:   #fdf3f5;
  --pin1-bg:         #1847d4;
  --pin1-text:       #fff;
  --pin2-bg:         #e8ecf6;
  --pin2-text:       #1847d4;
  --grp-bg:          #2a2f45;
  --grp-text:        #c8d4ff;
  --idx-pos-bg:      rgba(10,138,92,0.12);
  --idx-neg-bg:      rgba(217,43,75,0.09);
  --col-div:         rgba(0,0,0,0.09);
  --frz-shadow:      3px 0 8px rgba(0,0,0,0.08);
  --row-even:        #fff;
  --row-odd:         #f8f9fc;
  --today-bg:        rgba(24,71,212,0.05);
  --today-bg-solid:  #f0f3fd;
  --hdr-bg:          #e4e8f2;
  --cg-bg:           #1a2040;
}
[data-theme="dark"] {
  --green-row:       rgba(34,200,138,0.05);
  --green-row-solid: #121f1a;
  --red-row:         rgba(245,71,106,0.05);
  --red-row-solid:   #1f1318;
  --pin1-bg:         #1e2c6a;
  --pin1-text:       #c0d0ff;
  --pin2-bg:         #1a2040;
  --pin2-text:       #7aa8ff;
  --grp-bg:          #1a2040;
  --grp-text:        #9ab8ff;
  --idx-pos-bg:      rgba(34,200,138,0.13);
  --idx-neg-bg:      rgba(245,71,106,0.11);
  --col-div:         rgba(255,255,255,0.09);
  --frz-shadow:      3px 0 12px rgba(0,0,0,0.4);
  --row-even:        #13161f;
  --row-odd:         #161a26;
  --today-bg:        rgba(93,143,255,0.07);
  --today-bg-solid:  #13172a;
  --hdr-bg:          #1c2035;
  --cg-bg:           #0d1022;
}

/* KPI strip */
.kpi-strip { display: grid; grid-template-columns: repeat(6,1fr); gap: 10px; margin-bottom: 16px; }
.kpi-card  { background: var(--bg-surface); border: 1px solid var(--border-md); border-radius: var(--radius); padding: 14px 16px; }
.kpi-label { font-size: 11px; color: var(--text-muted); text-transform: uppercase; letter-spacing: .5px; margin-bottom: 6px; }
.kpi-val   { font-family: var(--mono); font-size: 15px; font-weight: 500; }
.kpi-val.pos { color: var(--green); } .kpi-val.neg { color: var(--red); } .kpi-val.acc { color: var(--accent); }
.kpi-sub   { font-size: 11px; color: var(--text-muted); margin-top: 3px; }
.exp-track { height: 4px; background: var(--border-md); border-radius: 2px; overflow: hidden; margin-top: 7px; }
.exp-fill  { height: 100%; border-radius: 2px; background: var(--green); transition: width .5s; }

/* Charts */
.charts-top    { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 10px; }
.charts-bottom { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px; margin-bottom: 16px; }
.chart-card    { background: var(--bg-surface); border: 1px solid var(--border-md); border-radius: var(--radius); padding: 18px 20px; }
.chart-title   { font-size: 13px; font-weight: 600; color: var(--text-primary); margin-bottom: 2px; }
.chart-sub     { font-size: 11px; color: var(--text-muted); margin-bottom: 14px; }
.chart-area     { position: relative; width: 100%; height: 130px; }
.chart-area-pie { position: relative; width: 100%; height: 150px; display: flex; align-items: center; justify-content: center; margin-top: 10px; }
canvas { width: 100% !important; height: 100% !important; }

/* Toolbar */
.toolbar     { display: flex; align-items: center; gap: 8px; margin-bottom: 12px; flex-wrap: wrap; }
.filter-wrap { display: flex; align-items: center; gap: 6px; background: var(--bg-surface); border: 1px solid var(--border-md); border-radius: var(--radius-sm); padding: 0 10px; height: 34px; }
.filter-wrap label  { font-size: 11px; color: var(--text-muted); white-space: nowrap; text-transform: uppercase; letter-spacing: .4px; }
.filter-wrap select { background: transparent; border: none; outline: none; font-size: 13px; font-family: var(--font); color: var(--text-primary); cursor: pointer; padding: 0 2px; }
.btn-sm  { height: 34px; padding: 0 14px; border-radius: var(--radius-sm); border: 1px solid var(--border-md); background: var(--bg-surface); color: var(--text-secondary); font-size: 12px; font-family: var(--font); cursor: pointer; transition: all .15s; white-space: nowrap; display: flex; align-items: center; gap: 5px; }
.btn-sm:hover { color: var(--text-primary); background: var(--border); }
.sep     { width: 1px; height: 22px; background: var(--border-md); }
.showing { font-size: 12px; color: var(--text-muted); margin-left: auto; }

/* Sheet / Table */
.sheet-outer  { background: var(--bg-surface); border: 1px solid var(--border-md); border-radius: var(--radius); overflow: hidden; }
.sheet-scroll { overflow-x: auto; scrollbar-width: thin; scrollbar-color: var(--border-md) transparent; }
.sheet-scroll::-webkit-scrollbar       { height: 5px; }
.sheet-scroll::-webkit-scrollbar-thumb { background: var(--border-md); border-radius: 3px; }
.t { width: 100%; min-width: 1500px; border-collapse: collapse; font-family: var(--mono); font-size: 11.5px; }

/* Pinned header rows */
.t thead tr.pr1 th { position: sticky; top: var(--nav-h); z-index: 22; height: 30px; background: var(--pin1-bg); color: var(--pin1-text); font-family: var(--mono); font-size: 12px; font-weight: 500; border-bottom: 1px solid rgba(255,255,255,.1); vertical-align: middle; white-space: nowrap; padding: 0 8px; text-align: center; }
.t thead tr.pr2 th { position: sticky; top: calc(var(--nav-h) + 30px); z-index: 22; height: 30px; background: var(--pin2-bg); color: var(--pin2-text); font-family: var(--mono); font-size: 11.5px; font-weight: 500; border-bottom: 2px solid var(--accent-border); vertical-align: middle; white-space: nowrap; padding: 0 8px; text-align: center; }
.t thead tr.cg  th { position: sticky; top: calc(var(--nav-h) + 60px); z-index: 22; height: 20px; background: var(--cg-bg); font-family: var(--font); font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .8px; border-bottom: 1px solid rgba(255,255,255,.08); text-align: center; vertical-align: middle; padding: 0 4px; }
.t thead tr.ch  th { position: sticky; top: calc(var(--nav-h) + 80px); z-index: 22; height: 28px; background: var(--hdr-bg); border-bottom: 2px solid var(--border-md); padding: 0 7px; vertical-align: middle; white-space: nowrap; text-align: center; font-family: var(--font); font-size: 10.5px; font-weight: 600; color: var(--text-secondary); user-select: none; }

/* Column group labels */
.cg-date { color: #6a7fb5; } .cg-trades { color: #6ab3ff; } .cg-idx { color: #7dd9b5; } .cg-res { color: #67c99b; } .cg-sum { color: #f0c070; }

/* Frozen first column */
tr.pr1 th.frz { position: sticky !important; left: 0; z-index: 24 !important; background: var(--pin1-bg) !important; box-shadow: var(--frz-shadow); border-right: 1px solid rgba(255,255,255,.15) !important; text-align: left !important; padding-left: 12px !important; }
tr.pr2 th.frz { position: sticky !important; left: 0; z-index: 24 !important; background: var(--pin2-bg) !important; box-shadow: var(--frz-shadow); border-right: 1px solid var(--col-div) !important; text-align: left !important; padding-left: 12px !important; }
tr.cg  th.frz { position: sticky !important; left: 0; z-index: 24 !important; background: var(--cg-bg) !important; box-shadow: var(--frz-shadow); border-right: 1px solid rgba(255,255,255,.06) !important; text-align: left !important; padding-left: 12px !important; color: #6a7fb5; }
tr.ch  th.frz { position: sticky !important; left: 0; z-index: 24 !important; background: var(--hdr-bg) !important; box-shadow: var(--frz-shadow); border-right: 1px solid var(--col-div) !important; text-align: left !important; }
td.frz { position: sticky !important; left: 0; z-index: 6 !important; background: var(--bg-surface) !important; box-shadow: var(--frz-shadow); border-right: 1px solid var(--col-div) !important; }
tr.even  td.frz { background: var(--row-even) !important; }
tr.odd   td.frz { background: var(--row-odd)  !important; }
tr.today td.frz { background: var(--today-bg-solid) !important; }
tr.ipos  td.frz { background: var(--green-row-solid) !important; }
tr.ineg  td.frz { background: var(--red-row-solid)   !important; }
tr:hover td.frz { background: #eef1fb !important; }
[data-theme="dark"] tr:hover td.frz { background: #1c2035 !important; }

/* Divider column */
.dv { width: 6px; min-width: 6px; padding: 0 !important; background: var(--col-div) !important; border: none !important; }
tr.pr1 th.dv, tr.cg th.dv { background: rgba(0,0,0,.22) !important; }
tr.pr2 th.dv               { background: var(--col-div) !important; }

/* Body rows */
tbody tr.even  { background: var(--row-even); }
tbody tr.odd   { background: var(--row-odd); }
tbody tr:hover { background: var(--accent-soft) !important; }
tbody tr.today { background: var(--today-bg) !important; }
tbody tr.today td.dc { border-left: 3px solid var(--accent) !important; }
tbody tr.hidden { display: none; }
tbody tr.ipos  { background: var(--green-row) !important; }
tbody tr.ineg  { background: var(--red-row)   !important; }

/* Table cells */
.t td  { padding: 0 7px; height: 30px; border-bottom: 1px solid var(--border); white-space: nowrap; vertical-align: middle; text-align: center; }
td.dc  { font-family: var(--font); font-size: 11.5px; font-weight: 500; color: var(--text-primary); min-width: 108px; padding-left: 12px; text-align: left; }
td.idx-pos { background: var(--idx-pos-bg); color: var(--green); font-weight: 500; }
td.idx-neg { background: var(--idx-neg-bg); color: var(--red);   font-weight: 500; }
td.pos { color: var(--green); font-weight: 600; }
td.neg { color: var(--red);   font-weight: 600; }
td.muted { color: var(--text-muted); }
td.bold  { font-weight: 700; }

/* Footer row */
.t tfoot td       { position: sticky; bottom: 0; z-index: 10; background: var(--pin2-bg); color: var(--pin2-text); font-family: var(--mono); font-size: 11px; font-weight: 700; padding: 6px 7px; border-top: 2px solid var(--accent-border); text-align: center; white-space: nowrap; }
.t tfoot td.frz   { background: var(--pin2-bg) !important; z-index: 12 !important; text-align: left; padding-left: 12px; }

/* Group header row */
.gh    { background: var(--grp-bg) !important; cursor: pointer; user-select: none; }
.gh:hover { opacity: .92; }
.ghd   { padding: 0 12px !important; font-family: var(--font); font-size: 12px; font-weight: 600; color: var(--grp-text); text-align: left !important; letter-spacing: .2px; }
.ga    { display: inline-block; margin-right: 8px; font-size: 9px; transition: transform .2s; color: var(--grp-text); }
.ga.open { transform: rotate(90deg); }

/* Trade input / result cells */
.t-in  { color: var(--accent); font-weight: 500; }
.t-out { color: var(--red);    font-weight: 500; }
.zero  { color: var(--text-muted); opacity: .4; }
.acc   { color: var(--accent); }

/* Move % badge */
.mp      { font-weight: 500; }
.mp.pos  { color: var(--green); }
.mp.neg  { color: var(--red); }
.mp.flat { color: var(--text-muted); }

/* Live indicator in date cell */
.lr  { display: inline-flex; align-items: center; gap: 4px; margin-left: 6px; font-size: 9px; font-weight: 700; letter-spacing: .6px; color: var(--green); vertical-align: middle; }
.lrd { width: 5px; height: 5px; border-radius: 50%; background: var(--green); flex-shrink: 0; animation: livePulse 2.5s ease-in-out infinite; }

/* Future / placeholder rows */
.future-row { opacity: .55; }

/* Admin Trades responsive */
@media (max-width: 900px) {
  .kpi-strip { grid-template-columns: repeat(3,1fr); }
  .charts-top, .charts-bottom { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .kpi-strip { grid-template-columns: repeat(2,1fr); }
}

/* ============================================================
   ISLAMIC FUNDS PAGE -- moved from inline <style>
   ============================================================ */

/* ── Filter bars ────────────────────────────────────────────── */
.filter-bars-card       { background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 14px 16px; margin-bottom: 16px; display: flex; flex-direction: column; gap: 12px; }
.filter-bar             { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.filter-bar.type-bar    { border-top: 1px solid var(--border); padding-top: 12px; }
.filter-label           { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; color: var(--text-muted); margin-right: 2px; flex-shrink: 0; min-width: 36px; }

/* AMC bar -- 2-row grid desktop, wrap on mobile */
.filter-bar.amc-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}
.filter-bar.amc-bar .amc-chip {
  justify-content: center;
  flex: 0 0 auto;
}

/* Desktop only: force exactly 2 even rows */
@media (min-width: 769px) {
  .filter-bar.amc-bar {
    display: grid;
    grid-template-columns: auto repeat(8, 1fr);
    gap: 6px;
    align-items: stretch;
  }
  .filter-bar.amc-bar .filter-label { grid-column: 1; grid-row: 1; }
  .filter-bar.amc-bar .amc-chip:nth-child(2)  { grid-column: 2; grid-row: 1; }
  .filter-bar.amc-bar .amc-chip:nth-child(3)  { grid-column: 3; grid-row: 1; }
  .filter-bar.amc-bar .amc-chip:nth-child(4)  { grid-column: 4; grid-row: 1; }
  .filter-bar.amc-bar .amc-chip:nth-child(5)  { grid-column: 5; grid-row: 1; }
  .filter-bar.amc-bar .amc-chip:nth-child(6)  { grid-column: 6; grid-row: 1; }
  .filter-bar.amc-bar .amc-chip:nth-child(7)  { grid-column: 7; grid-row: 1; }
  .filter-bar.amc-bar .amc-chip:nth-child(8)  { grid-column: 8; grid-row: 1; }
  .filter-bar.amc-bar .amc-chip:nth-child(9)  { grid-column: 9; grid-row: 1; }
  .filter-bar.amc-bar .amc-chip:nth-child(10) { grid-column: 2; grid-row: 2; }
  .filter-bar.amc-bar .amc-chip:nth-child(11) { grid-column: 3; grid-row: 2; }
  .filter-bar.amc-bar .amc-chip:nth-child(12) { grid-column: 4; grid-row: 2; }
  .filter-bar.amc-bar .amc-chip:nth-child(13) { grid-column: 5; grid-row: 2; }
  .filter-bar.amc-bar .amc-chip:nth-child(14) { grid-column: 6; grid-row: 2; }
  .filter-bar.amc-bar .amc-chip:nth-child(15) { grid-column: 7; grid-row: 2; }
  .filter-bar.amc-bar .amc-chip:nth-child(16) { grid-column: 8; grid-row: 2; }
  .filter-bar.amc-bar .amc-chip:nth-child(17) { grid-column: 9; grid-row: 2; }
}

/* ============================================================
   MOBILE -- AMC BAR (desktop: 2-row grid / mobile: 3-col grid)
   Used by: Islamic Funds, Conventional Funds, Pension Funds
   ============================================================ */
@media (min-width: 769px) {
  .filter-bar.amc-bar {
    display: grid;
    grid-template-columns: auto repeat(8, 1fr);
    gap: 6px;
    align-items: stretch;
  }
  .filter-bar.amc-bar .filter-label     { grid-column: 1; grid-row: 1; align-self: center; }
  .filter-bar.amc-bar .amc-chip:nth-child(2)  { grid-column: 2; grid-row: 1; }
  .filter-bar.amc-bar .amc-chip:nth-child(3)  { grid-column: 3; grid-row: 1; }
  .filter-bar.amc-bar .amc-chip:nth-child(4)  { grid-column: 4; grid-row: 1; }
  .filter-bar.amc-bar .amc-chip:nth-child(5)  { grid-column: 5; grid-row: 1; }
  .filter-bar.amc-bar .amc-chip:nth-child(6)  { grid-column: 6; grid-row: 1; }
  .filter-bar.amc-bar .amc-chip:nth-child(7)  { grid-column: 7; grid-row: 1; }
  .filter-bar.amc-bar .amc-chip:nth-child(8)  { grid-column: 8; grid-row: 1; }
  .filter-bar.amc-bar .amc-chip:nth-child(9)  { grid-column: 9; grid-row: 1; }
  .filter-bar.amc-bar .amc-chip:nth-child(10) { grid-column: 2; grid-row: 2; }
  .filter-bar.amc-bar .amc-chip:nth-child(11) { grid-column: 3; grid-row: 2; }
  .filter-bar.amc-bar .amc-chip:nth-child(12) { grid-column: 4; grid-row: 2; }
  .filter-bar.amc-bar .amc-chip:nth-child(13) { grid-column: 5; grid-row: 2; }
  .filter-bar.amc-bar .amc-chip:nth-child(14) { grid-column: 6; grid-row: 2; }
  .filter-bar.amc-bar .amc-chip:nth-child(15) { grid-column: 7; grid-row: 2; }
  .filter-bar.amc-bar .amc-chip:nth-child(16) { grid-column: 8; grid-row: 2; }
  .filter-bar.amc-bar .amc-chip:nth-child(17) { grid-column: 9; grid-row: 2; }
  .filter-bar.amc-bar .amc-chip { justify-content: center; }
}

@media (max-width: 768px) {
  .filter-bar.amc-bar {
    display: grid;
    grid-template-columns: auto repeat(3, 1fr);
    gap: 6px;
  }
  .filter-bar.amc-bar .filter-label    { grid-column: 1; align-self: center; }
  .filter-bar.amc-bar .amc-chip        { width: 100%; justify-content: center; padding: 0 6px; font-size: 11px; }
  .filter-bar.amc-bar .amc-chip .amc-logo-img { height: 16px; }
  .type-chip                           { height: 36px; }
}

/* ============================================================
   TYPE CHIP COLOURS
   Used by: Islamic Funds, Conventional Funds, Pension Funds
   ============================================================ */
.type-chip {
  display: inline-flex; align-items: center; gap: 6px;
  height: 34px; padding: 0 13px 0 10px;
  border-radius: 8px; border: 1px solid var(--border-md);
  background: var(--bg-surface); color: var(--text-secondary);
  font-size: 12.5px; font-weight: 500;
  cursor: pointer; transition: all 0.15s ease; white-space: nowrap;
}
.type-chip svg           { width: 15px; height: 15px; stroke: currentColor; fill: none; stroke-width: 1.75; stroke-linecap: round; stroke-linejoin: round; flex-shrink: 0; }
.type-chip:hover         { border-color: var(--accent-border); background: var(--accent-soft); color: var(--accent); }
.type-chip.active        { border-color: var(--green); background: var(--green-soft); color: var(--green); }
.type-chip.active svg    { stroke: var(--green); }

.type-chip.tc-all:hover,     .type-chip.tc-all.active     { border-color: var(--accent);  background: var(--accent-soft);  color: var(--accent);  }
.type-chip.tc-all.active svg                               { stroke: var(--accent); }
.type-chip.tc-mm:hover,      .type-chip.tc-mm.active      { border-color: #0ea5e9; background: rgba(14,165,233,0.12); color: #0ea5e9; }
.type-chip.tc-mm.active svg                                { stroke: #0ea5e9; }
.type-chip.tc-income:hover,  .type-chip.tc-income.active  { border-color: var(--green);   background: var(--green-soft);   color: var(--green);   }
.type-chip.tc-income.active svg                            { stroke: var(--green); }
.type-chip.tc-equity:hover,  .type-chip.tc-equity.active  { border-color: var(--accent);  background: var(--accent-soft);  color: var(--accent);  }
.type-chip.tc-equity.active svg                            { stroke: var(--accent); }
.type-chip.tc-commodity:hover, .type-chip.tc-commodity.active { border-color: var(--amber); background: var(--amber-soft); color: var(--amber); }
.type-chip.tc-commodity.active svg                         { stroke: var(--amber); }

[data-theme="dark"] .type-chip        { background: var(--bg-card); }
[data-theme="dark"] .type-chip:hover  { background: var(--accent-soft); }

/* ============================================================
   FUND NAV TABLE -- desktop scrollable table
   GLOBAL -- used by: Islamic Funds, Conventional Funds, Pension Funds
   Changes here affect ALL three Fund NAV pages.
   ============================================================ */
.table-card             { overflow: hidden; display: flex; flex-direction: column; background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--radius); }
.table-scroll-wrap      { overflow-x: auto; overflow-y: auto; max-height: calc(100vh - 260px); border-radius: 0 0 var(--radius) var(--radius); }
.islamic-funds-grid     { min-width: 1280px; }
.grid-row               { display: grid; grid-template-columns: 360px 72px 90px repeat(11, 72px); padding: 0; border-bottom: 1px solid var(--border); align-items: center; }
.col-headers            { background: var(--bg-card); border-bottom: 2px solid var(--border-md); min-width: 1280px; position: sticky; top: 0; z-index: 20; }
.col-h                  { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; color: var(--text-secondary); text-align: right; padding: 10px 12px; cursor: pointer; user-select: none; white-space: nowrap; transition: color 0.15s; }
.col-h:first-child      { text-align: left; padding-left: 15px; }
.col-h:hover            { color: var(--accent); }
.col-h.sort-asc,
.col-h.sort-desc        { color: var(--accent); }
.col-resize-wrap        { display: flex; align-items: center; justify-content: space-between; width: 100%; }
.col-resize-handle      { width: 4px; height: 20px; background: var(--border-md); border-radius: 2px; cursor: col-resize; flex-shrink: 0; margin-left: 6px; transition: background 0.15s; }
.col-resize-handle:hover { background: var(--accent); }
.col-headers .sticky-col { background: var(--bg-card); z-index: 6; }
.fund-data-row          { transition: background 0.12s; cursor: default; }
.fund-data-row:hover    { background: var(--accent-soft); }
.fund-data-row:last-child { border-bottom: none; }
.cell                   { padding: 11px 12px; text-align: right; }
.cell:first-child       { text-align: left; padding-left: 15px; }
.sticky-col             { position: sticky; left: 0; background: var(--bg-surface); z-index: 5; font-weight: 500; font-size: 13px; border-right: 1px solid var(--border); transition: background 0.25s; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.fund-data-row:hover .sticky-col                  { filter: brightness(0.97); }
[data-theme="dark"] .fund-data-row:hover .sticky-col { filter: brightness(1.2); }
[data-theme="dark"] .col-headers                  { background: #1c2035; border-bottom-color: rgba(255,255,255,0.16); }
[data-theme="dark"] .col-headers .sticky-col      { background: #1c2035; }

/* ============================================================
   FUND NAV MOBILE CARDS
   PAGE-SCOPED -- only hides .table-card and shows .mobile-fund-list
   on Fund NAV pages. Does NOT affect Stock Watch or any other page.
   Pages using this: islamic-funds, conventional-funds, pension-funds
   ============================================================ */
.mobile-fund-list { display: none; }
.m-fund-card      { background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 14px 16px; margin-bottom: 10px; }
.m-card-head      { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 12px; gap: 8px; }
.m-fund-name      { font-size: 13px; font-weight: 600; color: var(--text-primary); line-height: 1.35; flex: 1; }
.m-nav-block      { text-align: right; flex-shrink: 0; }
.m-nav-label      { font-size: 10px; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.4px; display: block; }
.m-nav-val        { font-size: 14px; font-weight: 600; color: var(--text-primary); display: block; }
.m-nav-date       { font-size: 10px; color: var(--text-muted); display: block; }
.m-returns-grid   { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.m-ret-cell       { background: var(--bg-card); border-radius: 6px; padding: 8px 10px; display: flex; flex-direction: column; gap: 3px; }
.m-ret-cell.hero  { grid-column: 1 / -1; flex-direction: row; align-items: center; justify-content: space-between; padding: 10px 14px; }
.m-ret-cell.pos-cell { background: var(--green-soft); border: 1px solid var(--green-border); }
.m-ret-cell.neg-cell { background: var(--red-soft);   border: 1px solid var(--red-border); }
.m-ret-label      { font-size: 10px; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.4px; }
.m-ret-val        { font-size: 13px; font-weight: 600; color: var(--text-primary); }
.m-ret-val.pos    { color: var(--green); }
.m-ret-val.neg    { color: var(--red); }
.m-ret-val.dash   { color: var(--text-muted); }

/* PAGE-SCOPED mobile switch -- ONLY these 3 pages swap table -> cards */
@media (max-width: 768px) {
  [data-page="islamic-funds"] .table-card,
  [data-page="conventional-funds"] .table-card,
  [data-page="pension-funds"] .table-card      { display: none !important; }

  [data-page="islamic-funds"] .mobile-fund-list,
  [data-page="conventional-funds"] .mobile-fund-list,
  [data-page="pension-funds"] .mobile-fund-list { display: block !important; }
}

/* ============================================================
   NEWS PAGE — source logo fallback thumbnails
   Used by: news page only
   When Profit, CNBC, Arab News have no usable thumbnail,
   their logo is shown centered in the card-thumb area.
   ============================================================ */
.card-thumb-logo {
  padding-top: 0 !important;
  height: 160px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-card);
  border-bottom: 1px solid var(--border);
  overflow: hidden;
}

/* Per-source brand backgrounds — matched to actual logo background colors */
.card-thumb-logo[data-source="profit"]    { background: #F0E0D0; }
.card-thumb-logo[data-source="arab-news"] { background: #F0F2ED; }
.card-thumb-logo[data-source="cnbc"]      { background: var(--bg-card); }

[data-theme="dark"] .card-thumb-logo[data-source="profit"]    { background: #2a1f0f; }
[data-theme="dark"] .card-thumb-logo[data-source="arab-news"] { background: #1e1d1a; }
[data-theme="dark"] .card-thumb-logo[data-source="cnbc"]      { background: var(--bg-card); }

.card-source-logo-img {
  position: static !important;
  width: auto;
  height: 68px;
  max-width: 62%;
  object-fit: contain;
  opacity: 0.92;
  filter: var(--logo-news-filter, none);
}

/* CNBC — bigger peacock, neutral bg */
.card-thumb-logo[data-source="cnbc"] .card-source-logo-img {
  height: 90px;
  max-width: 65%;
  opacity: 1;
  filter: none;
}
[data-theme="dark"] .card-thumb-logo:not([data-source="cnbc"]) .card-source-logo-img {
  opacity: 0.80;
  filter: brightness(1.1);
}
/* ============================================================
   LOSS TRACKING PAGE  [data-page="loss-tracking"]
   ASCII only -- no unicode in comments.
============================================================ */

/* -- AMC color tokens -- */
[data-page="loss-tracking"] {
  --amc-mcb:#1847d4;     --amc-mcb-s:rgba(24,71,212,.09);
  --amc-hbl:#0a6e3f;     --amc-hbl-s:rgba(10,110,63,.09);
  --amc-meezan:#9b1c1c;  --amc-meezan-s:rgba(155,28,28,.09);
  --amc-ubl:#b45309;     --amc-ubl-s:rgba(180,83,9,.09);
  --amc-habib:#5b21b6;   --amc-habib-s:rgba(91,33,182,.09);
  --amc-faysal:#0e7490;  --amc-faysal-s:rgba(14,116,144,.09);
  --amc-nbp:#166534;     --amc-nbp-s:rgba(22,101,52,.09);
  --amc-alfalah:#9d174d; --amc-alfalah-s:rgba(157,23,77,.09);
  --amc-abl:#1e3a8a;     --amc-abl-s:rgba(30,58,138,.09);
  --amc-atlas:#78350f;   --amc-atlas-s:rgba(120,53,15,.09);
  --amc-js:#374151;      --amc-js-s:rgba(55,65,81,.09);
  --amc-awt:#064e3b;     --amc-awt-s:rgba(6,78,59,.09);
  --amc-nit:#4c1d95;     --amc-nit-s:rgba(76,29,149,.09);
  --amc-lucky:#991b1b;   --amc-lucky-s:rgba(153,27,27,.09);
  --amc-lakson:#134e4a;  --amc-lakson-s:rgba(19,78,74,.09);
}
[data-page="loss-tracking"][data-theme="dark"] {
  --amc-mcb:#4d7fff;     --amc-mcb-s:rgba(77,127,255,.13);
  --amc-hbl:#34d399;     --amc-hbl-s:rgba(52,211,153,.13);
  --amc-meezan:#f87171;  --amc-meezan-s:rgba(248,113,113,.13);
  --amc-ubl:#fbbf24;     --amc-ubl-s:rgba(251,191,36,.13);
  --amc-habib:#a78bfa;   --amc-habib-s:rgba(167,139,250,.13);
  --amc-faysal:#22d3ee;  --amc-faysal-s:rgba(34,211,238,.13);
  --amc-nbp:#86efac;     --amc-nbp-s:rgba(134,239,172,.13);
  --amc-alfalah:#f472b6; --amc-alfalah-s:rgba(244,114,182,.13);
  --amc-abl:#60a5fa;     --amc-abl-s:rgba(96,165,250,.13);
  --amc-atlas:#fcd34d;   --amc-atlas-s:rgba(252,211,77,.13);
  --amc-js:#9ca3af;      --amc-js-s:rgba(156,163,175,.13);
  --amc-awt:#6ee7b7;     --amc-awt-s:rgba(110,231,183,.13);
  --amc-nit:#c4b5fd;     --amc-nit-s:rgba(196,181,253,.13);
  --amc-lucky:#fca5a5;   --amc-lucky-s:rgba(252,165,165,.13);
  --amc-lakson:#2dd4bf;  --amc-lakson-s:rgba(45,212,191,.13);
}

/* -- page layout -- */
[data-page="loss-tracking"] .lt-page { max-width: 1480px; margin: 0 auto; padding: 20px 16px 100px; }
@media(min-width:640px){ [data-page="loss-tracking"] .lt-page { padding: 28px 28px 100px; } }

/* -- header -- */
[data-page="loss-tracking"] .lt-header { background: var(--bg-surface); border: 1px solid var(--border); border-radius: 16px; padding: 16px; margin-bottom: 14px; display: flex; flex-direction: column; gap: 12px; animation: lt-fadeUp .35s ease both; }
@media(min-width:640px){ [data-page="loss-tracking"] .lt-header { flex-direction: row; align-items: center; justify-content: space-between; padding: 18px 24px; gap: 20px; } }
[data-page="loss-tracking"] .lt-header-left { display: flex; align-items: center; gap: 12px; }
[data-page="loss-tracking"] .lt-header-icon { width: 40px; height: 40px; background: linear-gradient(135deg, var(--red) 0%, #ff6b6b 100%); border-radius: 10px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; box-shadow: 0 4px 12px rgba(200,50,70,.3); }
[data-page="loss-tracking"] .lt-header-text h1 { font-size: 20px; font-weight: 800; letter-spacing: -.6px; line-height: 1.1; margin-bottom: 3px; }
@media(min-width:640px){ [data-page="loss-tracking"] .lt-header-text h1 { font-size: 24px; } }
[data-page="loss-tracking"] .lt-subtitle { font-size: 12px; color: var(--text-muted); line-height: 1.5; }
[data-page="loss-tracking"] .lt-subtitle strong { color: var(--text-secondary); font-weight: 600; }
[data-page="loss-tracking"] .lt-updated-card { display: flex; align-items: center; gap: 8px; background: var(--bg-card); border: 1px solid var(--border); border-radius: 10px; padding: 8px 14px; flex-shrink: 0; align-self: flex-start; }
@media(max-width:639px){ [data-page="loss-tracking"] .lt-updated-card { align-self: stretch; justify-content: center; padding: 9px 14px; } }
[data-page="loss-tracking"] .lt-updated-label { font-size: 10px; font-weight: 600; letter-spacing: .7px; text-transform: uppercase; color: var(--text-muted); }
[data-page="loss-tracking"] .lt-updated-time { font-size: 12px; font-weight: 600; color: var(--text-primary); }
[data-page="loss-tracking"] .lt-updated-dot { display: inline-block; width: 7px; height: 7px; border-radius: 50%; background: var(--green); flex-shrink: 0; box-shadow: 0 0 0 2px rgba(16,185,129,.2); animation: lt-pulse 2s ease-in-out infinite; }
@keyframes lt-pulse { 0%,100%{opacity:1;box-shadow:0 0 0 2px rgba(16,185,129,.2)} 50%{opacity:.6;box-shadow:0 0 0 4px rgba(16,185,129,.08)} }

/* -- control panel -- */
[data-page="loss-tracking"] .lt-control-panel { background: var(--bg-surface); border: 1px solid var(--border); border-radius: 16px; margin-bottom: 14px; overflow: hidden; animation: lt-fadeUp .35s .05s ease both; }
[data-page="loss-tracking"] .lt-cp-section { padding: 14px 16px; border-bottom: 1px solid var(--border); display: flex; flex-direction: column; gap: 10px; }
[data-page="loss-tracking"] .lt-cp-section:last-child { border-bottom: none; }
@media(min-width:640px){ [data-page="loss-tracking"] .lt-cp-section { padding: 14px 20px; flex-direction: row; align-items: center; gap: 12px; flex-wrap: wrap; } }
[data-page="loss-tracking"] .lt-cp-label { font-size: 10px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: var(--text-muted); flex-shrink: 0; min-width: 52px; }
[data-page="loss-tracking"] .lt-presets { display: flex; gap: 5px; flex-wrap: wrap; }
[data-page="loss-tracking"] .lt-preset { height: 34px; padding: 0 14px; border-radius: 9px; font-size: 13px; font-weight: 500; cursor: pointer; border: 1px solid var(--border-md); background: transparent; color: var(--text-secondary); font-family: var(--font); transition: all .15s; white-space: nowrap; }
[data-page="loss-tracking"] .lt-preset:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-soft); }
[data-page="loss-tracking"] .lt-preset.active { background: var(--accent); border-color: var(--accent); color: #fff; font-weight: 600; }
[data-page="loss-tracking"] .lt-custom { display: none; align-items: center; gap: 8px; flex-wrap: wrap; margin-top: 4px; }
[data-page="loss-tracking"] .lt-custom.visible { display: flex !important; }
[data-page="loss-tracking"] .lt-custom label { font-size: 12px; color: var(--text-muted); font-weight: 500; white-space: nowrap; }
[data-page="loss-tracking"] .lt-date-in { height: 34px; padding: 0 10px; border-radius: 9px; border: 1px solid var(--border-md); background: var(--bg-card); color: var(--text-primary); font-size: 12px; font-family: var(--font); transition: border-color .15s; cursor: pointer; flex: 1; min-width: 130px; }
[data-page="loss-tracking"] .lt-date-in:focus { outline: none; border-color: var(--accent); }
[data-page="loss-tracking"] .lt-fgroup { display: flex; gap: 5px; flex-wrap: wrap; }
[data-page="loss-tracking"] .lt-fbtn { height: 34px; padding: 0 16px; border-radius: 9px; font-size: 13px; font-weight: 500; cursor: pointer; border: 1px solid var(--border-md); background: transparent; color: var(--text-secondary); font-family: var(--font); transition: all .15s; }
[data-page="loss-tracking"] .lt-fbtn:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-soft); }
[data-page="loss-tracking"] .lt-fbtn.active { background: var(--accent); border-color: var(--accent); color: #fff; font-weight: 600; }
[data-page="loss-tracking"] .lt-sort-cap-row { display: flex; flex-direction: column; align-items: flex-start; gap: 8px; flex-wrap: wrap; }
@media(min-width:640px){ [data-page="loss-tracking"] .lt-sort-cap-row { flex-direction: row; align-items: center; } }
[data-page="loss-tracking"] .lt-sortsel { height: 34px; padding: 0 12px; border-radius: 9px; border: 1px solid var(--border-md); background: var(--bg-card); color: var(--text-secondary); font-size: 13px; font-family: var(--font); cursor: pointer; font-weight: 500; }
[data-page="loss-tracking"] .lt-sortsel:focus { outline: none; border-color: var(--accent); }
[data-page="loss-tracking"] .lt-cap { display: flex; align-items: center; gap: 8px; }
[data-page="loss-tracking"] .lt-cap-lbl { font-size: 12px; color: var(--text-muted); font-weight: 500; white-space: nowrap; }
[data-page="loss-tracking"] .lt-cap-in { width: 130px; height: 34px; padding: 0 12px; border: 1px solid var(--border-md); border-radius: 9px; background: var(--bg-card); color: var(--text-primary); font-size: 13px; font-family: var(--mono, monospace); transition: border-color .15s; }
[data-page="loss-tracking"] .lt-cap-in:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }

/* -- period dropdown (mobile) / pills (desktop) -- */
[data-page="loss-tracking"] .lt-period-sel { height: 38px; padding: 0 36px 0 14px; border-radius: 10px; border: 1.5px solid var(--border-md); background: var(--bg-card); color: var(--text-primary); font-size: 14px; font-weight: 600; font-family: var(--font); cursor: pointer; appearance: none; -webkit-appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239ba3b8' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 12px center; transition: border-color .15s; flex-shrink: 0; }
[data-page="loss-tracking"] .lt-period-sel:focus { outline: none; border-color: var(--accent); }
[data-page="loss-tracking"] .lt-presets-desktop { display: none; }
@media(min-width:640px){
  [data-page="loss-tracking"] .lt-period-sel { display: none; }
  [data-page="loss-tracking"] .lt-presets-desktop { display: flex; gap: 5px; flex-wrap: wrap; }
}

/* -- summary cards -- */
[data-page="loss-tracking"] .lt-summary { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 14px; animation: lt-fadeUp .35s .10s ease both; }
@media(max-width:359px){ [data-page="loss-tracking"] .lt-summary { grid-template-columns: 1fr; } }
@media(min-width:800px){ [data-page="loss-tracking"] .lt-summary { grid-template-columns: repeat(4,1fr); } }
[data-page="loss-tracking"] .lt-stat { background: var(--bg-surface); border: 1px solid var(--border); border-radius: 14px; padding: 16px 18px; transition: box-shadow .15s, transform .15s; position: relative; overflow: hidden; }
[data-page="loss-tracking"] .lt-stat:hover { box-shadow: var(--shadow); transform: translateY(-1px); }
[data-page="loss-tracking"] .lt-stat::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 4px; border-radius: 14px 0 0 14px; }
[data-page="loss-tracking"] .lt-stat.profit::before { background: var(--green); }
[data-page="loss-tracking"] .lt-stat.loss::before { background: var(--red); }
[data-page="loss-tracking"] .lt-stat.neutral::before { background: var(--border-md); }
[data-page="loss-tracking"] .lt-stat.clickable { cursor: pointer; }
[data-page="loss-tracking"] .lt-stat.clickable:hover { box-shadow: var(--shadow); transform: translateY(-2px); }
[data-page="loss-tracking"] .lt-stat.clickable:active { transform: translateY(0); transition: transform .08s; }
[data-page="loss-tracking"] .lt-stat-lbl { font-size: 10px; color: var(--text-muted); margin-bottom: 8px; font-weight: 700; letter-spacing: .6px; text-transform: uppercase; }
[data-page="loss-tracking"] .lt-stat-row { display: flex; align-items: baseline; gap: 8px; margin-bottom: 4px; flex-wrap: wrap; }
[data-page="loss-tracking"] .lt-stat-val { font-size: 20px; font-weight: 800; letter-spacing: -.8px; line-height: 1; margin-bottom: 5px; }
@media(min-width:640px){ [data-page="loss-tracking"] .lt-stat-val { font-size: 22px; } }
[data-page="loss-tracking"] .lt-stat-val.green { color: var(--green); }
[data-page="loss-tracking"] .lt-stat-val.red { color: var(--red); }
[data-page="loss-tracking"] .lt-stat-val.plain { color: var(--text-primary); }
[data-page="loss-tracking"] .lt-stat-pct { font-size: 13px; font-weight: 600; font-family: var(--mono, monospace); }
[data-page="loss-tracking"] .lt-stat-pct.green { color: var(--green); opacity: .8; }
[data-page="loss-tracking"] .lt-stat-pct.red { color: var(--red); opacity: .8; }
[data-page="loss-tracking"] .lt-stat-sub { font-size: 11px; color: var(--text-muted); line-height: 1.4; }
[data-page="loss-tracking"] .lt-stat-hint { font-size: 10px; color: var(--text-muted); opacity: .55; margin-top: 5px; font-style: italic; }

/* -- AMC panel -- */
[data-page="loss-tracking"] .lt-amc-panel { background: var(--bg-surface); border: 1px solid var(--border); border-radius: 16px; padding: 14px 16px; margin-bottom: 14px; animation: lt-fadeUp .35s .15s ease both; }
[data-page="loss-tracking"] .lt-amc-panel-head { font-size: 10px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: var(--text-muted); margin-bottom: 12px; }
[data-page="loss-tracking"] #ltPills { display: grid; grid-template-columns: repeat(2, 1fr); gap: 6px; }
@media(min-width:480px){ [data-page="loss-tracking"] #ltPills { grid-template-columns: repeat(3, 1fr); } }
@media(min-width:640px){ [data-page="loss-tracking"] #ltPills { grid-template-columns: repeat(5, 1fr); } }
@media(min-width:960px){ [data-page="loss-tracking"] #ltPills { grid-template-columns: repeat(8, 1fr); } }
[data-page="loss-tracking"] .amc-chip.amc-all { grid-column: 1 / -1; }
[data-page="loss-tracking"] .amc-chip.dimmed { opacity: .28; pointer-events: none; }
[data-page="loss-tracking"] .lt-pill-count { font-size: 10px; font-weight: 700; line-height: 1.4; background: rgba(0,0,0,.07); border-radius: 4px; padding: 1px 5px; margin-left: auto; flex-shrink: 0; }
[data-page="loss-tracking"] .amc-chip.active .lt-pill-count { background: rgba(255,255,255,.22); }
[data-page="loss-tracking"][data-theme="dark"] .lt-pill-count { background: rgba(255,255,255,.1); }

/* -- group cards -- */
[data-page="loss-tracking"] .lt-group { background: var(--bg-surface); border: 1px solid var(--border); border-radius: 14px; margin-bottom: 10px; overflow: hidden; }
[data-page="loss-tracking"] .lt-group.hidden { display: none; }
[data-page="loss-tracking"] .lt-group-head { display: flex; align-items: center; gap: 10px; padding: 12px 14px; cursor: pointer; user-select: none; transition: background .12s; border-bottom: 1px solid transparent; }
[data-page="loss-tracking"] .lt-group-head:hover { background: var(--bg-card); }
[data-page="loss-tracking"] .lt-group:not(.collapsed) .lt-group-head { border-bottom-color: var(--border); }
[data-page="loss-tracking"] .lt-gbar { width: 4px; height: 36px; border-radius: 3px; flex-shrink: 0; }
[data-page="loss-tracking"] .lt-ghead-info { flex: 1; min-width: 0; }
[data-page="loss-tracking"] .lt-gname { font-size: 15px; font-weight: 700; letter-spacing: -.3px; line-height: 1.2; }
[data-page="loss-tracking"] .lt-gcount { font-size: 12px; color: var(--text-muted); margin-top: 2px; }
[data-page="loss-tracking"] .lt-ghead-stats { display: flex; flex-direction: column; align-items: flex-end; gap: 2px; flex-shrink: 0; }
[data-page="loss-tracking"] .lt-gavg-rs { font-size: 17px; font-weight: 800; font-family: var(--mono, monospace); letter-spacing: -.4px; line-height: 1; }
[data-page="loss-tracking"] .lt-gavg-pct { font-size: 12px; font-weight: 600; font-family: var(--mono, monospace); color: var(--text-muted); }
[data-page="loss-tracking"] .lt-gavg-rs.profit, [data-page="loss-tracking"] .lt-gavg-pct.profit { color: var(--green); }
[data-page="loss-tracking"] .lt-gavg-rs.loss, [data-page="loss-tracking"] .lt-gavg-pct.loss { color: var(--red); }
[data-page="loss-tracking"] .lt-chevron { color: var(--text-muted); transition: transform .2s; flex-shrink: 0; }
[data-page="loss-tracking"] .lt-group.collapsed .lt-chevron { transform: rotate(-90deg); }
[data-page="loss-tracking"] .lt-group.collapsed .lt-tbody { display: none; }

/* -- fund row left accent -- */
[data-page="loss-tracking"] .lt-row { position: relative; }
[data-page="loss-tracking"] .lt-row::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--row-accent, var(--border-md)); opacity: 0; transition: opacity .18s; }
[data-page="loss-tracking"] .lt-row:hover::before { opacity: 1; }

/* -- table -- */
[data-page="loss-tracking"] .lt-thead { display: none; grid-template-columns: 1fr 100px 150px 110px 150px; padding: 9px 20px; background: var(--bg-card); border-bottom: 1px solid var(--border); }
@media(min-width:640px){ [data-page="loss-tracking"] .lt-thead { display: grid; } }
[data-page="loss-tracking"] .lt-th { font-size: 10px; font-weight: 700; letter-spacing: .7px; text-transform: uppercase; color: var(--text-muted); }
[data-page="loss-tracking"] .lt-th.r { text-align: right; }
[data-page="loss-tracking"] .lt-th.c { text-align: center; }
[data-page="loss-tracking"] .lt-row { display: flex; align-items: center; gap: 8px; padding: 11px 14px; border-bottom: 1px solid var(--border); transition: background .12s; cursor: pointer; }
[data-page="loss-tracking"] .lt-row:last-child { border-bottom: none; }
[data-page="loss-tracking"] .lt-row:hover { background: var(--bg-card); }
@media(min-width:640px){
  [data-page="loss-tracking"] .lt-row { display: grid; grid-template-columns: 1fr 100px 150px 110px 150px; align-items: center; gap: 0; padding: 13px 20px; min-height: 58px; }
}
[data-page="loss-tracking"] .lt-fname { flex: 1; min-width: 0; padding-right: 6px; }
[data-page="loss-tracking"] .lt-fname-full { font-size: 12.5px; font-weight: 600; color: var(--text-primary); line-height: 1.35; margin-bottom: 2px; display: block; }
[data-page="loss-tracking"] .lt-ftype { font-size: 10.5px; color: var(--text-muted); font-weight: 500; }
[data-page="loss-tracking"] .lt-mob-right { display: flex; flex-direction: column; align-items: flex-end; gap: 2px; flex-shrink: 0; }
@media(min-width:640px){ [data-page="loss-tracking"] .lt-mob-right { display: none; } }
[data-page="loss-tracking"] .lt-scell { display: none; align-items: center; justify-content: center; }
@media(min-width:640px){ [data-page="loss-tracking"] .lt-scell { display: flex; } }
[data-page="loss-tracking"] .lt-badge { font-size: 11px; font-weight: 700; letter-spacing: .3px; padding: 4px 11px; border-radius: 20px; white-space: nowrap; display: inline-block; line-height: 1.4; }
[data-page="loss-tracking"] .lt-badge.profit { background: var(--green-soft); color: var(--green); border: 1px solid var(--green-border); }
[data-page="loss-tracking"] .lt-badge.loss { background: var(--red-soft); color: var(--red); border: 1px solid var(--red-border); }
[data-page="loss-tracking"] .lt-rs { display: none; font-size: 14px; font-weight: 700; font-family: var(--mono, monospace); text-align: right; padding-right: 14px; letter-spacing: -.3px; }
[data-page="loss-tracking"] .lt-pct { display: none; font-size: 13px; font-weight: 600; text-align: right; padding-right: 14px; font-family: var(--mono, monospace); }
@media(min-width:640px){ [data-page="loss-tracking"] .lt-rs { display: block; } [data-page="loss-tracking"] .lt-pct { display: block; } }
[data-page="loss-tracking"] .lt-rs.profit, [data-page="loss-tracking"] .lt-mob-rs.profit, [data-page="loss-tracking"] .lt-mob-pct.profit { color: var(--green); }
[data-page="loss-tracking"] .lt-rs.loss, [data-page="loss-tracking"] .lt-mob-rs.loss, [data-page="loss-tracking"] .lt-mob-pct.loss { color: var(--red); }
[data-page="loss-tracking"] .lt-pct.profit { color: var(--green); }
[data-page="loss-tracking"] .lt-pct.loss { color: var(--red); }
[data-page="loss-tracking"] .lt-mob-rs { font-size: 13px; font-weight: 700; font-family: var(--mono, monospace); letter-spacing: -.3px; }
[data-page="loss-tracking"] .lt-mob-pct { font-size: 11.5px; font-weight: 600; font-family: var(--mono, monospace); }
[data-page="loss-tracking"] .lt-barcell { display: none; align-items: center; padding-right: 8px; }
@media(min-width:640px){ [data-page="loss-tracking"] .lt-barcell { display: flex; } }
[data-page="loss-tracking"] .lt-track { flex: 1; height: 6px; border-radius: 4px; background: var(--bg-card); overflow: hidden; border: 1px solid var(--border); }
[data-page="loss-tracking"] .lt-fill { height: 100%; border-radius: 4px; transition: width .5s cubic-bezier(.4,0,.2,1); }
[data-page="loss-tracking"] .lt-fill.profit { background: var(--green); }
[data-page="loss-tracking"] .lt-fill.loss { background: var(--red); }
[data-page="loss-tracking"] .lt-mob-badge { display: inline-flex; align-items: center; font-size: 10px; font-weight: 700; padding: 2px 7px; border-radius: 5px; margin-top: 3px; letter-spacing: .15px; }
[data-page="loss-tracking"] .lt-mob-badge.profit { background: var(--green-soft); color: var(--green); border: 1px solid var(--green-border); }
[data-page="loss-tracking"] .lt-mob-badge.loss { background: var(--red-soft); color: var(--red); border: 1px solid var(--red-border); }

/* -- loading and skeleton -- */
[data-page="loss-tracking"] .lt-loading { text-align: center; padding: 80px 20px; color: var(--text-muted); font-size: 14px; line-height: 1.7; }
[data-page="loss-tracking"] .lt-spinner { width: 28px; height: 28px; border: 2.5px solid var(--border-md); border-top-color: var(--accent); border-radius: 50%; animation: lt-spin .7s linear infinite; margin: 0 auto 14px; }
@keyframes lt-spin { to { transform: rotate(360deg); } }
[data-page="loss-tracking"] .lt-skeleton { border-radius: 14px; overflow: hidden; background: var(--bg-surface); border: 1px solid var(--border); margin-bottom: 10px; }
[data-page="loss-tracking"] .lt-skel-head { height: 66px; padding: 14px 18px; display: flex; align-items: center; gap: 12px; }
[data-page="loss-tracking"] .lt-skel-bar { width: 4px; height: 36px; border-radius: 3px; background: var(--border-md); flex-shrink: 0; }
[data-page="loss-tracking"] .lt-skel-block { background: linear-gradient(90deg, var(--border) 25%, var(--bg-card) 50%, var(--border) 75%); background-size: 200% 100%; animation: lt-shimmer 1.6s infinite; border-radius: 6px; }
@keyframes lt-shimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }
[data-page="loss-tracking"] .lt-skel-name { flex: 1; display: flex; flex-direction: column; gap: 7px; }
[data-page="loss-tracking"] .lt-skel-name .lt-skel-block:first-child { height: 13px; width: 52%; }
[data-page="loss-tracking"] .lt-skel-name .lt-skel-block:last-child { height: 10px; width: 28%; }
[data-page="loss-tracking"] .lt-skel-val { width: 68px; height: 16px; }

/* -- modal -- */
[data-page="loss-tracking"] .lt-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.55); backdrop-filter: blur(8px); z-index: 9000; align-items: flex-end; justify-content: center; padding: 0; }
@media(min-width:600px){ [data-page="loss-tracking"] .lt-overlay { align-items: center; padding: 24px; } }
[data-page="loss-tracking"] .lt-overlay.open { display: flex; }
[data-page="loss-tracking"] .lt-modal { background: var(--bg-surface); border: 1px solid var(--border-md); border-radius: 20px 20px 0 0; width: 100%; max-width: 680px; box-shadow: 0 -8px 40px rgba(0,0,0,.18); overflow: hidden; max-height: 92vh; display: flex; flex-direction: column; }
@media(min-width:600px){ [data-page="loss-tracking"] .lt-modal { border-radius: 20px; box-shadow: 0 32px 80px rgba(0,0,0,.25); max-height: 88vh; } }
[data-page="loss-tracking"] .lt-modal-handle { width: 36px; height: 4px; border-radius: 2px; background: var(--border-md); margin: 10px auto 4px; flex-shrink: 0; }
@media(min-width:600px){ [data-page="loss-tracking"] .lt-modal-handle { display: none; } }
[data-page="loss-tracking"] .lt-mhead { display: flex; align-items: flex-start; gap: 14px; padding: 16px 20px 14px; border-bottom: 1px solid var(--border); flex-shrink: 0; }
[data-page="loss-tracking"] .lt-mhead-bar { width: 5px; border-radius: 3px; flex-shrink: 0; align-self: stretch; min-height: 40px; }
[data-page="loss-tracking"] .lt-mhead-text { flex: 1; }
[data-page="loss-tracking"] .lt-mtitle { font-size: 15px; font-weight: 700; letter-spacing: -.3px; color: var(--text-primary); margin-bottom: 4px; line-height: 1.3; }
[data-page="loss-tracking"] .lt-msub { font-size: 12px; color: var(--text-muted); }
[data-page="loss-tracking"] .lt-mclose { width: 32px; height: 32px; border-radius: 8px; flex-shrink: 0; background: var(--bg-card); border: 1px solid var(--border); cursor: pointer; display: flex; align-items: center; justify-content: center; color: var(--text-muted); font-size: 16px; transition: all .15s; }
[data-page="loss-tracking"] .lt-mclose:hover { background: var(--red-soft); color: var(--red); border-color: var(--red-border); }
[data-page="loss-tracking"] .lt-mbody { padding: 18px 20px 22px; overflow-y: auto; flex: 1; }
[data-page="loss-tracking"] .lt-mstats { display: grid; grid-template-columns: repeat(3,1fr); gap: 10px; margin-bottom: 20px; }
@media(max-width:400px){ [data-page="loss-tracking"] .lt-mstats { grid-template-columns: 1fr 1fr; } }
[data-page="loss-tracking"] .lt-mstat { background: var(--bg-card); border: 1px solid var(--border); border-radius: 12px; padding: 14px; }
[data-page="loss-tracking"] .lt-mstat-lbl { font-size: 10px; color: var(--text-muted); margin-bottom: 8px; font-weight: 700; letter-spacing: .5px; text-transform: uppercase; }
[data-page="loss-tracking"] .lt-mstat-val { font-size: 19px; font-weight: 800; font-family: var(--mono, monospace); letter-spacing: -.5px; line-height: 1; }
[data-page="loss-tracking"] .lt-mstat-val.profit { color: var(--green); }
[data-page="loss-tracking"] .lt-mstat-val.loss { color: var(--red); }
[data-page="loss-tracking"] .lt-mstat-val.plain { color: var(--text-primary); }
[data-page="loss-tracking"] .lt-best-amt { font-size: 19px; font-weight: 800; font-family: var(--mono, monospace); letter-spacing: -.5px; line-height: 1; margin-bottom: 4px; }
[data-page="loss-tracking"] .lt-best-month { font-size: 11.5px; font-weight: 600; color: var(--text-muted); }
[data-page="loss-tracking"] .lt-best-amt.profit { color: var(--green); }
[data-page="loss-tracking"] .lt-best-amt.loss { color: var(--red); }
[data-page="loss-tracking"] .lt-chart-lbl { font-size: 10px; font-weight: 700; color: var(--text-muted); text-transform: uppercase; letter-spacing: .7px; margin-bottom: 12px; }
[data-page="loss-tracking"] .lt-chart-wrap { height: 210px; position: relative; }
[data-page="loss-tracking"] .lt-mperiod-badge { display: inline-flex; align-items: center; gap: 4px; font-size: 10px; font-weight: 700; letter-spacing: .4px; text-transform: uppercase; background: var(--accent-soft); color: var(--accent); border: 1px solid currentColor; border-radius: 5px; padding: 2px 8px; margin-top: 5px; opacity: .85; }
[data-page="loss-tracking"] .lt-chart-empty { height: 210px; display: flex; align-items: center; justify-content: center; flex-direction: column; gap: 8px; color: var(--text-muted); font-size: 13px; }
[data-page="loss-tracking"] .lt-chart-empty-icon { font-size: 28px; opacity: .35; }

/* -- daily breakdown table -- */
[data-page="loss-tracking"] #mDailyTable { margin-top: 18px; }
[data-page="loss-tracking"] .lt-daily-lbl { font-size: 10px; font-weight: 700; color: var(--text-muted); text-transform: uppercase; letter-spacing: .7px; margin-bottom: 10px; }
[data-page="loss-tracking"] .lt-daily-grid { display: grid; grid-template-columns: 1fr auto auto; border-radius: 12px; border: 1px solid var(--border); overflow: hidden; }
[data-page="loss-tracking"] .lt-dg-cell { padding: 8px 12px; font-size: 12px; border-bottom: 1px solid var(--border); display: flex; align-items: center; }
[data-page="loss-tracking"] .lt-dg-cell:nth-child(3n+2), [data-page="loss-tracking"] .lt-dg-cell:nth-child(3n+3) { justify-content: flex-end; }
[data-page="loss-tracking"] .lt-dg-cell.head { font-size: 10px; font-weight: 700; letter-spacing: .6px; text-transform: uppercase; color: var(--text-muted); background: var(--bg-card); padding: 7px 12px; }
[data-page="loss-tracking"] .lt-dg-cell:nth-last-child(-n+3) { border-bottom: none; }
[data-page="loss-tracking"] .lt-dg-cell.profit { color: var(--green); font-weight: 700; font-family: var(--mono, monospace); }
[data-page="loss-tracking"] .lt-dg-cell.loss { color: var(--red); font-weight: 700; font-family: var(--mono, monospace); }
[data-page="loss-tracking"] .lt-dg-cell.zero { color: var(--text-muted); font-weight: 600; font-family: var(--mono, monospace); }
[data-page="loss-tracking"] .lt-dg-cell.date-cell { font-weight: 600; color: var(--text-secondary); font-size: 12px; }
[data-page="loss-tracking"] .lt-dg-cell.weekend { opacity: .4; font-style: italic; }
[data-page="loss-tracking"] .lt-dg-total-row .lt-dg-cell { background: var(--accent-soft); border-top: 2px solid var(--accent); border-bottom: none !important; font-weight: 800; }
[data-page="loss-tracking"] .lt-dg-total-row .lt-dg-cell.date-cell { color: var(--accent); font-size: 11px; letter-spacing: .3px; }
[data-page="loss-tracking"] .lt-day-dot { display: inline-block; width: 6px; height: 6px; border-radius: 50%; margin-right: 7px; flex-shrink: 0; }
[data-page="loss-tracking"] .lt-day-dot.profit { background: var(--green); }
[data-page="loss-tracking"] .lt-day-dot.loss { background: var(--red); }
[data-page="loss-tracking"] .lt-day-dot.zero { background: var(--border-md); }

/* -- rankings chart -- */
[data-page="loss-tracking"] .lt-rankings { background: var(--bg-surface); border: 1px solid var(--border); border-radius: 16px; margin-top: 14px; overflow: hidden; animation: lt-fadeUp .35s .25s ease both; }
[data-page="loss-tracking"] .lt-rankings-head { padding: 14px 16px 0; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 8px; }
@media(min-width:640px){ [data-page="loss-tracking"] .lt-rankings-head { padding: 16px 20px 0; } }
[data-page="loss-tracking"] .lt-rankings-title { font-size: 15px; font-weight: 800; letter-spacing: -.4px; }
[data-page="loss-tracking"] .lt-rankings-controls { display: flex; gap: 6px; align-items: center; }
[data-page="loss-tracking"] .lt-rankings-tabs { display: flex; gap: 4px; }
[data-page="loss-tracking"] .lt-rtab { height: 30px; padding: 0 12px; border-radius: 8px; font-size: 12px; font-weight: 600; cursor: pointer; border: 1px solid var(--border-md); background: transparent; color: var(--text-secondary); font-family: var(--font); transition: all .15s; white-space: nowrap; }
[data-page="loss-tracking"] .lt-rtab:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-soft); }
[data-page="loss-tracking"] .lt-rtab.active { background: var(--accent); border-color: var(--accent); color: #fff; }
[data-page="loss-tracking"] .lt-rtab.red-active { background: var(--red); border-color: var(--red); color: #fff; }
[data-page="loss-tracking"] .lt-rank-expand { width: 30px; height: 30px; border-radius: 8px; cursor: pointer; border: 1px solid var(--border-md); background: var(--bg-card); color: var(--text-muted); display: flex; align-items: center; justify-content: center; transition: all .15s; flex-shrink: 0; }
[data-page="loss-tracking"] .lt-rank-expand:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-soft); }
[data-page="loss-tracking"] .lt-rankings-body { padding: 12px 14px 16px; }
@media(min-width:640px){ [data-page="loss-tracking"] .lt-rankings-body { padding: 16px 20px 20px; } }
[data-page="loss-tracking"] .lt-rank-chart-wrap { position: relative; height: 360px; }
@media(min-width:640px){ [data-page="loss-tracking"] .lt-rank-chart-wrap { height: 420px; } }
[data-page="loss-tracking"] .lt-rank-sub { font-size: 11px; color: var(--text-muted); margin-bottom: 10px; }
[data-page="loss-tracking"] .lt-rank-legend { display: flex; align-items: center; gap: 14px; margin-bottom: 12px; flex-wrap: wrap; }
[data-page="loss-tracking"] .lt-rank-legend-item { display: flex; align-items: center; gap: 6px; font-size: 11px; font-weight: 600; color: var(--text-muted); }
[data-page="loss-tracking"] .lt-rank-legend-dot { width: 10px; height: 10px; border-radius: 3px; }

/* -- rankings fullscreen overlay -- */
[data-page="loss-tracking"] .lt-rank-fullscreen { display: none; position: fixed; inset: 0; z-index: 8500; background: var(--bg-surface); flex-direction: column; }
[data-page="loss-tracking"] .lt-rank-fullscreen.open { display: flex; }
[data-page="loss-tracking"] .lt-rank-fs-head { display: flex; align-items: center; justify-content: space-between; padding: 14px 18px; border-bottom: 1px solid var(--border); flex-shrink: 0; gap: 10px; flex-wrap: wrap; }
[data-page="loss-tracking"] .lt-rank-fs-title { font-size: 14px; font-weight: 800; letter-spacing: -.3px; }
[data-page="loss-tracking"] .lt-rank-fs-close { width: 32px; height: 32px; border-radius: 8px; cursor: pointer; border: 1px solid var(--border-md); background: var(--bg-card); color: var(--text-muted); display: flex; align-items: center; justify-content: center; font-size: 16px; transition: all .15s; }
[data-page="loss-tracking"] .lt-rank-fs-close:hover { background: var(--red-soft); color: var(--red); border-color: var(--red-border); }
[data-page="loss-tracking"] .lt-rank-fs-body { flex: 1; padding: 16px 18px; display: flex; flex-direction: column; min-height: 0; }
[data-page="loss-tracking"] .lt-rank-fs-wrap { flex: 1; position: relative; min-height: 0; }

/* -- entrance animations -- */
@keyframes lt-fadeUp { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }
@keyframes lt-fadeIn { from { opacity: 0; } to { opacity: 1; } }
[data-page="loss-tracking"] #ltGroups { animation: lt-fadeIn .4s .2s ease both; }

/* ============================================================
   MARKET STRATEGY PAGE  [data-page="market-strategy"]
   Paste after the Loss Tracking section in Styles.css.
   ASCII only -- no unicode in comments.
============================================================ */

[data-page="market-strategy"] .page { max-width: 1600px; padding: 20px 20px 80px; }

/* -- market hero -- */
[data-page="market-strategy"] .market-hero { background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 16px 22px; margin-bottom: 16px; display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; box-shadow: var(--shadow); position: relative; overflow: hidden; }
[data-page="market-strategy"] .market-hero::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(90deg, var(--accent), var(--green)); border-radius: var(--radius) var(--radius) 0 0; }
[data-page="market-strategy"] .hero-left { display: flex; flex-direction: column; gap: 3px; }
[data-page="market-strategy"] .hero-title { font-size: 18px; font-weight: 700; letter-spacing: -0.5px; }
[data-page="market-strategy"] .hero-sub { font-size: 12px; color: var(--text-muted); }
[data-page="market-strategy"] .hero-right { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
[data-page="market-strategy"] .idx-badge { display: flex; align-items: center; gap: 10px; padding: 8px 16px; background: var(--bg-card); border: 1px solid var(--border-md); border-radius: var(--radius-sm); font-family: var(--mono); }
[data-page="market-strategy"] .idx-badge-label { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.8px; color: var(--text-muted); }
[data-page="market-strategy"] .idx-badge-val { font-size: 15px; font-weight: 600; color: var(--text-primary); letter-spacing: -0.4px; }
[data-page="market-strategy"] .idx-badge-pct { font-size: 12px; font-weight: 600; padding: 2px 8px; border-radius: 4px; }
[data-page="market-strategy"] .idx-badge-pct.up   { background: var(--green-soft); color: var(--green); }
[data-page="market-strategy"] .idx-badge-pct.dn   { background: var(--red-soft); color: var(--red); }
[data-page="market-strategy"] .idx-badge-pct.flat { background: var(--border); color: var(--text-muted); }

/* -- sentiment strip -- */
[data-page="market-strategy"] .sentiment-strip { background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 12px 20px; margin-bottom: 16px; display: flex; align-items: center; gap: 16px; box-shadow: var(--shadow); flex-wrap: wrap; }
[data-page="market-strategy"] .sentiment-label { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--text-muted); white-space: nowrap; flex-shrink: 0; }
[data-page="market-strategy"] .votes-btns { display: flex; gap: 6px; }
[data-page="market-strategy"] .vote-btn { display: flex; align-items: center; gap: 6px; padding: 6px 14px; border-radius: 20px; border: 1.5px solid var(--border-md); background: var(--bg-card); font-size: 12px; font-weight: 700; font-family: var(--font); cursor: pointer; transition: all 0.18s; white-space: nowrap; user-select: none; }
[data-page="market-strategy"] .vote-btn:hover { transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,0.1); }
[data-page="market-strategy"] .vote-btn.buy  { color: var(--green); border-color: var(--green-border); }
[data-page="market-strategy"] .vote-btn.hold { color: var(--accent); border-color: var(--accent-border); }
[data-page="market-strategy"] .vote-btn.sell { color: var(--red); border-color: var(--red-border); }
[data-page="market-strategy"] .vote-btn.buy:hover  { background: var(--green-soft); }
[data-page="market-strategy"] .vote-btn.hold:hover { background: var(--accent-soft); }
[data-page="market-strategy"] .vote-btn.sell:hover { background: var(--red-soft); }
[data-page="market-strategy"] .vote-btn.selected.buy  { background: var(--green-soft); border-color: var(--green); box-shadow: 0 0 0 2px rgba(10,138,92,0.15); }
[data-page="market-strategy"] .vote-btn.selected.hold { background: var(--accent-soft); border-color: var(--accent); box-shadow: 0 0 0 2px rgba(24,71,212,0.15); }
[data-page="market-strategy"] .vote-btn.selected.sell { background: var(--red-soft); border-color: var(--red); box-shadow: 0 0 0 2px rgba(217,43,75,0.15); }
[data-page="market-strategy"] .vote-btn.selected { transform: none; }
[data-page="market-strategy"] .vote-btn.disabled { opacity: 0.55; cursor: not-allowed; pointer-events: none; }
[data-page="market-strategy"] .vote-count { font-family: var(--mono); font-size: 12px; font-weight: 700; }
[data-page="market-strategy"] .votes-results { flex: 1; display: flex; align-items: center; gap: 10px; min-width: 180px; }
[data-page="market-strategy"] .votes-bar-track { flex: 1; height: 8px; border-radius: 4px; background: var(--bg-card); border: 1px solid var(--border-md); overflow: hidden; display: flex; }
[data-page="market-strategy"] .votes-bar-seg { height: 100%; transition: width 0.5s ease; }
[data-page="market-strategy"] .votes-bar-seg.buy  { background: var(--green); }
[data-page="market-strategy"] .votes-bar-seg.hold { background: var(--accent); }
[data-page="market-strategy"] .votes-bar-seg.sell { background: var(--red); }
[data-page="market-strategy"] .votes-summary { font-size: 11px; font-family: var(--mono); color: var(--text-secondary); white-space: nowrap; font-weight: 600; flex-shrink: 0; }
[data-page="market-strategy"] .votes-reset { font-size: 10px; color: var(--text-muted); font-family: var(--mono); white-space: nowrap; flex-shrink: 0; margin-left: auto; }

/* -- strategy grid -- */
[data-page="market-strategy"] .strategy-grid { display: grid; grid-template-columns: 272px 1fr 272px; gap: 14px; align-items: start; }
@media(max-width:1200px){ [data-page="market-strategy"] .strategy-grid { grid-template-columns: 252px 1fr 252px; } }
@media(max-width:980px){
  [data-page="market-strategy"] .strategy-grid { grid-template-columns: 1fr; }
  [data-page="market-strategy"] .side-panel { position: static; max-height: none; overflow: visible; }
  [data-page="market-strategy"] .side-panel .panel-scroll { overflow-y: auto; max-height: 400px; }
}

/* -- side panels -- */
[data-page="market-strategy"] .side-panel { background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; position: sticky; top: calc(var(--nav-h) + 14px); max-height: calc(100vh - var(--nav-h) - 28px); display: flex; flex-direction: column; }
[data-page="market-strategy"] .side-panel .panel-header { padding: 10px 14px; border-bottom: 1px solid var(--border); background: var(--bg-card); flex-shrink: 0; }
[data-page="market-strategy"] .side-panel .panel-title { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.7px; color: var(--text-secondary); }
[data-page="market-strategy"] .side-panel .panel-sub { font-size: 11px; color: var(--text-muted); margin-top: 2px; }
[data-page="market-strategy"] .side-panel .panel-scroll { overflow-y: auto; flex: 1; scrollbar-width: thin; scrollbar-color: var(--border-md) transparent; }
[data-page="market-strategy"] .side-panel .panel-disclaimer { padding: 8px 12px; font-size: 10px; color: var(--text-muted); border-top: 1px solid var(--border); background: var(--bg-card); text-align: center; font-style: italic; }

/* -- fund rows -- */
[data-page="market-strategy"] .amc-group { margin-bottom: 8px; }
[data-page="market-strategy"] .amc-label { display: flex; align-items: center; gap: 6px; padding: 6px 12px 4px; border-bottom: 1px solid var(--border); font-size: 11px; font-weight: 600; color: var(--text-secondary); }
[data-page="market-strategy"] .amc-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
[data-page="market-strategy"] .fund-row { display: flex; align-items: center; justify-content: space-between; padding: 7px 12px; border-bottom: 1px solid var(--border); gap: 8px; transition: background 0.12s; cursor: pointer; border-left: 3px solid transparent; }
[data-page="market-strategy"] .fund-row:last-child { border-bottom: none; }
[data-page="market-strategy"] .fund-row:hover { background: var(--accent-soft); }
[data-page="market-strategy"] .fund-row.suspended { opacity: 0.4; }
[data-page="market-strategy"] .fund-name { font-size: 11.5px; color: var(--text-primary); line-height: 1.3; flex: 1; min-width: 0; }
[data-page="market-strategy"] .fund-est { font-size: 11.5px; font-family: var(--mono); font-weight: 600; text-align: right; white-space: nowrap; flex-shrink: 0; padding: 3px 8px; border-radius: 4px; min-width: 72px; }
[data-page="market-strategy"] .fund-est.pos     { background: var(--green-soft); color: var(--green); }
[data-page="market-strategy"] .fund-est.neg     { background: var(--red-soft); color: var(--red); }
[data-page="market-strategy"] .fund-est.sus     { background: var(--border); color: var(--text-muted); font-size: 10px; }
[data-page="market-strategy"] .fund-est.loading { background: var(--border); color: var(--text-muted); font-size: 11px; }

/* -- center panel -- */
[data-page="market-strategy"] .center-panel { display: flex; flex-direction: column; gap: 14px; }
[data-page="market-strategy"] .center-card { background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow); }
[data-page="market-strategy"] .center-section { padding: 20px 24px; border-bottom: 1px solid var(--border); }
[data-page="market-strategy"] .center-section:last-child { border-bottom: none; }

/* -- writeup -- */
[data-page="market-strategy"] .writeup-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; gap: 12px; }
[data-page="market-strategy"] .writeup-title-row { display: flex; align-items: center; gap: 10px; }
[data-page="market-strategy"] .writeup-eyebrow { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--accent); }
[data-page="market-strategy"] .writeup-date { font-size: 11px; font-family: var(--mono); color: var(--text-muted); background: var(--bg-card); border: 1px solid var(--border-md); padding: 2px 8px; border-radius: 4px; }
[data-page="market-strategy"] .writeup-body { display: flex; flex-direction: column; }
[data-page="market-strategy"] .writeup-section { padding: 12px 0; border-bottom: 1px solid var(--border); display: flex; gap: 14px; align-items: flex-start; }
[data-page="market-strategy"] .writeup-section:last-child { border-bottom: none; padding-bottom: 0; }
[data-page="market-strategy"] .writeup-section:first-child { padding-top: 0; }
[data-page="market-strategy"] .ws-tag { flex-shrink: 0; margin-top: 2px; font-size: 9px; font-weight: 800; text-transform: uppercase; letter-spacing: 0.7px; padding: 3px 7px; border-radius: 4px; white-space: nowrap; width: 90px; text-align: center; }
[data-page="market-strategy"] .ws-tag.regional      { background: rgba(24,71,212,0.12); color: var(--accent); }
[data-page="market-strategy"] .ws-tag.international { background: rgba(107,96,0,0.12); color: #7a6d00; }
[data-page="market-strategy"] .ws-tag.local         { background: rgba(10,138,92,0.12); color: var(--green); }
[data-page="market-strategy"] .ws-tag.technicals    { background: rgba(201,90,0,0.12); color: #C95A00; }
[data-page="market-strategy"] .ws-tag.closing       { background: rgba(139,26,46,0.12); color: #8B1A2E; }
[data-page="market-strategy"][data-theme="dark"] .ws-tag.international { background: rgba(240,165,0,0.12); color: var(--amber); }
[data-page="market-strategy"] .ws-text { font-size: 13px; line-height: 1.75; color: var(--text-primary); flex: 1; }
[data-page="market-strategy"] .writeup-loading { display: flex; align-items: center; gap: 10px; color: var(--text-muted); font-size: 13px; padding: 12px 0; }

/* -- risk tiers -- */
[data-page="market-strategy"] .risk-tier { margin-bottom: 14px; border-radius: 8px; overflow: hidden; border: 1px solid var(--border-md); }
[data-page="market-strategy"] .risk-tier:last-child { margin-bottom: 0; }
[data-page="market-strategy"] .risk-tier-header { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.8px; padding: 8px 14px; color: #fff; display: flex; align-items: center; gap: 8px; }
[data-page="market-strategy"] .risk-tier-header.low   { background: #1a7a4a; }
[data-page="market-strategy"] .risk-tier-header.mid   { background: #1847d4; }
[data-page="market-strategy"] .risk-tier-header.high  { background: #c2410c; }
[data-page="market-strategy"] .risk-tier-header.allin { background: #1e293b; }
[data-page="market-strategy"] .risk-tier-table { width: 100%; border-collapse: collapse; font-size: 12px; font-family: var(--mono); }
[data-page="market-strategy"] .risk-tier-table th { font-size: 9.5px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.4px; color: var(--text-muted); background: var(--bg-card); padding: 6px 8px; text-align: center; border-bottom: 1px solid var(--border-md); }
[data-page="market-strategy"] .risk-tier-table td { padding: 8px; text-align: center; color: var(--text-primary); font-weight: 600; border-right: 1px solid var(--border); }
[data-page="market-strategy"] .risk-tier-table td:last-child { border-right: none; }
[data-page="market-strategy"] .risk-alloc-bar { display: flex; align-items: center; justify-content: center; gap: 6px; }
[data-page="market-strategy"] .risk-bar-fill { display: inline-block; height: 4px; border-radius: 2px; background: var(--accent); opacity: 0.5; min-width: 4px; transition: width 0.3s; }
[data-page="market-strategy"] .risk-note { font-size: 11px; color: var(--text-muted); margin-top: 10px; line-height: 1.6; font-style: italic; }

/* -- fund popover -- */
[data-page="market-strategy"] .popover-overlay { position: fixed; inset: 0; z-index: 500; background: rgba(0,0,0,0.45); backdrop-filter: blur(4px); display: none; align-items: center; justify-content: center; padding: 24px; }
[data-page="market-strategy"] .popover-overlay.open { display: flex; }
[data-page="market-strategy"] .popover { background: var(--bg-surface); border: 1px solid var(--border-md); border-radius: 14px; width: 100%; max-width: 740px; max-height: 88vh; overflow: hidden; display: flex; flex-direction: column; box-shadow: 0 32px 80px rgba(0,0,0,0.22); }
[data-page="market-strategy"] .popover-head { padding: 20px 24px 16px; border-bottom: 1px solid var(--border); display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; flex-shrink: 0; background: var(--bg-card); }
[data-page="market-strategy"] .popover-head-left { flex: 1; min-width: 0; }
[data-page="market-strategy"] .popover-title { font-size: 17px; font-weight: 700; color: var(--text-primary); line-height: 1.3; letter-spacing: -0.4px; margin-bottom: 8px; }
[data-page="market-strategy"] .popover-badges { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
[data-page="market-strategy"] .popover-exposure { display: flex; align-items: center; gap: 10px; margin-top: 10px; }
[data-page="market-strategy"] .popover-exp-track { flex: 1; max-width: 200px; height: 4px; background: var(--border-md); border-radius: 2px; overflow: hidden; }
[data-page="market-strategy"] .popover-exp-fill { height: 100%; background: var(--accent); opacity: 0.5; border-radius: 2px; }
[data-page="market-strategy"] .popover-exp-label { font-size: 11px; font-family: var(--mono); color: var(--text-muted); white-space: nowrap; }
[data-page="market-strategy"] .popover-exp-label span { color: var(--text-secondary); font-weight: 500; }
[data-page="market-strategy"] .popover-close { width: 32px; height: 32px; border-radius: 8px; border: 1px solid var(--border-md); background: var(--bg-surface); color: var(--text-muted); cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all 0.15s; flex-shrink: 0; }
[data-page="market-strategy"] .popover-close:hover { background: var(--red-soft); color: var(--red); border-color: var(--red-border); }
[data-page="market-strategy"] .popover-close svg { width: 14px; height: 14px; }
[data-page="market-strategy"] .popover-body { overflow-y: auto; flex: 1; padding: 0 24px; }
[data-page="market-strategy"] .popover-col-head { display: grid; grid-template-columns: 1fr 70px 90px 90px 80px; gap: 8px; font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.6px; color: var(--text-muted); padding: 12px 0 8px; border-bottom: 1px solid var(--border-md); position: sticky; top: 0; background: var(--bg-surface); z-index: 1; }
[data-page="market-strategy"] .popover-col-head span { text-align: right; }
[data-page="market-strategy"] .popover-col-head span:first-child { text-align: left; }
[data-page="market-strategy"] .popover-row { display: grid; grid-template-columns: 1fr 70px 90px 90px 80px; gap: 8px; align-items: center; padding: 8px 0; border-bottom: 1px solid var(--border); transition: background 0.1s; }
[data-page="market-strategy"] .popover-row:hover { background: var(--accent-soft); margin: 0 -8px; padding: 8px; border-radius: 6px; border-bottom-color: transparent; }
[data-page="market-strategy"] .popover-row:last-child { border-bottom: none; }
[data-page="market-strategy"] .pr-name { font-size: 13px; font-weight: 500; color: var(--text-primary); }
[data-page="market-strategy"] .pr-wt   { font-size: 12px; font-family: var(--mono); color: var(--text-secondary); text-align: right; }
[data-page="market-strategy"] .pr-spark{ display: flex; align-items: center; justify-content: flex-end; }
[data-page="market-strategy"] .pr-chg  { font-size: 12px; font-family: var(--mono); text-align: right; font-weight: 500; }
[data-page="market-strategy"] .pr-chg.pos { color: var(--green); }
[data-page="market-strategy"] .pr-chg.neg { color: var(--red); }
[data-page="market-strategy"] .pr-chg.flat { color: var(--text-muted); }
[data-page="market-strategy"] .pr-pl  { font-size: 12px; font-family: var(--mono); text-align: right; font-weight: 600; padding: 3px 8px; border-radius: 4px; }
[data-page="market-strategy"] .pr-pl.pos { background: var(--green-soft); color: var(--green); }
[data-page="market-strategy"] .pr-pl.neg { background: var(--red-soft); color: var(--red); }
[data-page="market-strategy"] .popover-unknown { display: grid; grid-template-columns: 1fr 70px 90px 90px 80px; gap: 8px; align-items: center; padding: 8px 0; border-top: 1px dashed var(--border-md); margin-top: 4px; }
[data-page="market-strategy"] .popover-unknown .pr-name { font-style: italic; color: var(--text-muted); font-size: 12px; font-weight: 400; }
[data-page="market-strategy"] .popover-total { display: flex; align-items: center; justify-content: space-between; padding: 16px 24px; border-top: 1px solid var(--border-md); background: var(--bg-card); gap: 16px; flex-shrink: 0; }
[data-page="market-strategy"] .popover-total-left { flex: 1; }
[data-page="market-strategy"] .popover-total-label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.7px; color: var(--text-secondary); margin-bottom: 3px; }
[data-page="market-strategy"] .popover-total-note  { font-size: 11px; color: var(--text-muted); line-height: 1.55; }
[data-page="market-strategy"] .popover-total-val { font-size: 22px; font-family: var(--mono); font-weight: 700; padding: 8px 16px; border-radius: 8px; white-space: nowrap; letter-spacing: -0.5px; }
[data-page="market-strategy"] .popover-total-val.pos { background: var(--green-soft); color: var(--green); border: 1px solid var(--green-border); }
[data-page="market-strategy"] .popover-total-val.neg { background: var(--red-soft); color: var(--red); border: 1px solid var(--red-border); }

/* -- fund type badges -- */
[data-page="market-strategy"] .badge { display: inline-flex; align-items: center; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; padding: 2px 8px; border-radius: 4px; }
[data-page="market-strategy"] .badge-islamic  { background: var(--green-soft); color: var(--green); border: 1px solid var(--green-border); }
[data-page="market-strategy"] .badge-conv     { background: var(--accent-soft); color: var(--accent); border: 1px solid var(--accent-border); }
[data-page="market-strategy"] .badge-stock    { background: var(--red-soft); color: var(--red); border: 1px solid var(--red-border); }
[data-page="market-strategy"] .badge-balanced { background: rgba(201,90,0,0.08); color: #b35000; border: 1px solid rgba(201,90,0,0.25); }
[data-page="market-strategy"] .badge-asset    { background: rgba(91,45,142,0.08); color: #5B2D8E; border: 1px solid rgba(91,45,142,0.25); }
[data-page="market-strategy"] .badge-energy   { background: rgba(0,89,76,0.08); color: #00594C; border: 1px solid rgba(0,89,76,0.2); }
[data-page="market-strategy"] .badge-sector   { background: rgba(27,42,94,0.08); color: #1B2A5E; border: 1px solid rgba(27,42,94,0.2); }
[data-page="market-strategy"] .badge-dividend { background: rgba(155,106,0,0.08); color: #9B6A00; border: 1px solid rgba(155,106,0,0.25); }
[data-page="market-strategy"] .badge-etf      { background: var(--border); color: var(--text-muted); border: 1px solid var(--border-md); }

/* -- chat FAB -- */
[data-page="market-strategy"] .chat-fab { position: fixed; bottom: 24px; left: 24px; z-index: 900; display: flex; align-items: center; gap: 8px; height: 46px; padding: 0 18px; border-radius: 23px; background: var(--accent); color: #fff; border: none; cursor: pointer; font-size: 13px; font-weight: 700; font-family: var(--font); box-shadow: 0 4px 24px rgba(24,71,212,0.4); transition: all 0.2s; user-select: none; }
[data-page="market-strategy"] .chat-fab:hover { transform: translateY(-2px); box-shadow: 0 8px 32px rgba(24,71,212,0.5); }
[data-page="market-strategy"] .chat-fab svg { width: 16px; height: 16px; flex-shrink: 0; }
[data-page="market-strategy"] .chat-fab-unread { background: var(--red); color: #fff; font-size: 10px; font-weight: 800; min-width: 18px; height: 18px; border-radius: 9px; padding: 0 4px; display: none; align-items: center; justify-content: center; margin-left: 2px; }
[data-page="market-strategy"] .chat-fab-unread.show { display: flex; }

/* -- chat panel -- */
[data-page="market-strategy"] .chat-panel { position: fixed; bottom: 82px; left: 24px; z-index: 901; width: 380px; height: 560px; background: var(--bg-surface); border: 1px solid var(--border-md); border-radius: 16px; box-shadow: 0 24px 80px rgba(0,0,0,0.22); display: flex; flex-direction: column; overflow: hidden; transform: translateY(24px) scale(0.93); opacity: 0; pointer-events: none; transition: all 0.24s cubic-bezier(0.34,1.56,0.64,1); transform-origin: bottom left; min-width: 300px; min-height: 380px; max-width: 600px; max-height: 80vh; }
[data-page="market-strategy"] .chat-panel.open { transform: translateY(0) scale(1); opacity: 1; pointer-events: all; }
[data-page="market-strategy"] .chat-resize-handle { position: absolute; top: 0; left: 0; width: 18px; height: 18px; cursor: nw-resize; z-index: 10; display: flex; align-items: flex-start; justify-content: flex-start; padding: 4px; opacity: 0; transition: opacity 0.2s; }
[data-page="market-strategy"] .chat-panel:hover .chat-resize-handle { opacity: 1; }
[data-page="market-strategy"] .chat-resize-handle::before { content: ''; width: 10px; height: 10px; border-top: 2px solid var(--border-md); border-left: 2px solid var(--border-md); border-radius: 2px 0 0 0; }
[data-page="market-strategy"] .chat-head { display: flex; align-items: center; justify-content: space-between; padding: 13px 16px 11px; border-bottom: 1px solid var(--border); flex-shrink: 0; background: linear-gradient(135deg, var(--accent) 0%, #2e5fd4 100%); color: #fff; }
[data-page="market-strategy"] .chat-head-left { display: flex; align-items: center; gap: 10px; }
[data-page="market-strategy"] .chat-avatar { width: 34px; height: 34px; border-radius: 10px; background: rgba(255,255,255,0.2); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
[data-page="market-strategy"] .chat-avatar svg { width: 16px; height: 16px; color: #fff; }
[data-page="market-strategy"] .chat-head-title { font-size: 14px; font-weight: 700; color: #fff; line-height: 1.2; }
[data-page="market-strategy"] .chat-head-sub { font-size: 11px; color: rgba(255,255,255,0.75); display: flex; align-items: center; gap: 5px; margin-top: 1px; }
[data-page="market-strategy"] .chat-online-dot { width: 6px; height: 6px; border-radius: 50%; background: #4ade80; animation: ms-livePulse 2.5s ease-in-out infinite; }
@keyframes ms-livePulse { 0%,100%{opacity:1} 50%{opacity:0.4} }
[data-page="market-strategy"] .chat-head-actions { display: flex; gap: 6px; align-items: center; }
[data-page="market-strategy"] .chat-icon-btn { width: 28px; height: 28px; border-radius: 7px; border: 1px solid rgba(255,255,255,0.25); background: rgba(255,255,255,0.1); color: rgba(255,255,255,0.85); cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all 0.15s; }
[data-page="market-strategy"] .chat-icon-btn:hover { background: rgba(255,255,255,0.22); color: #fff; }
[data-page="market-strategy"] .chat-icon-btn svg { width: 13px; height: 13px; }
[data-page="market-strategy"] .chat-messages { flex: 1; overflow-y: auto; padding: 14px 14px 8px; display: flex; flex-direction: column; gap: 6px; scrollbar-width: thin; scrollbar-color: var(--border-md) transparent; }
[data-page="market-strategy"] .chat-messages::-webkit-scrollbar { width: 3px; }
[data-page="market-strategy"] .chat-messages::-webkit-scrollbar-thumb { background: var(--border-md); border-radius: 2px; }
[data-page="market-strategy"] .chat-date-divider { text-align: center; font-size: 10px; color: var(--text-muted); font-family: var(--mono); padding: 4px 0; display: flex; align-items: center; gap: 8px; }
[data-page="market-strategy"] .chat-date-divider::before,[data-page="market-strategy"] .chat-date-divider::after { content: ''; flex: 1; height: 1px; background: var(--border); }
[data-page="market-strategy"] .chat-msg { display: flex; flex-direction: column; gap: 2px; max-width: 86%; }
[data-page="market-strategy"] .chat-msg.own { align-self: flex-end; align-items: flex-end; }
[data-page="market-strategy"] .chat-msg.other { align-self: flex-start; align-items: flex-start; }
[data-page="market-strategy"] .chat-msg-top { display: flex; align-items: center; gap: 6px; padding: 0 3px; }
[data-page="market-strategy"] .chat-msg-name { font-size: 10px; font-weight: 700; font-family: var(--mono); color: var(--text-muted); }
[data-page="market-strategy"] .admin-crown { font-size: 9px; font-weight: 800; text-transform: uppercase; letter-spacing: 0.4px; background: linear-gradient(135deg,#f59e0b,#d97706); color: #fff; padding: 1px 5px; border-radius: 3px; }
[data-page="market-strategy"] .chat-msg-bubble { padding: 9px 12px; border-radius: 14px; font-size: 13px; line-height: 1.55; word-break: break-word; position: relative; }
[data-page="market-strategy"] .chat-msg.own .chat-msg-bubble { background: var(--accent); color: #fff; border-bottom-right-radius: 4px; }
[data-page="market-strategy"] .chat-msg.own.admin-msg .chat-msg-bubble { background: linear-gradient(135deg,#1847d4,#0f2f9a); border: 1px solid rgba(255,255,255,0.15); }
[data-page="market-strategy"] .chat-msg.other .chat-msg-bubble { background: var(--bg-card); border: 1px solid var(--border); color: var(--text-primary); border-bottom-left-radius: 4px; }
[data-page="market-strategy"] .chat-msg.other.admin-msg .chat-msg-bubble { background: linear-gradient(135deg,rgba(245,158,11,0.12),rgba(217,119,6,0.08)); border-color: rgba(245,158,11,0.3); }
[data-page="market-strategy"] .chat-msg-footer { display: flex; align-items: center; gap: 8px; padding: 0 3px; }
[data-page="market-strategy"] .chat-msg-time { font-size: 9.5px; color: var(--text-muted); font-family: var(--mono); }
[data-page="market-strategy"] .chat-system-msg { text-align: center; font-size: 11px; color: var(--text-muted); padding: 6px 0; font-style: italic; }

/* -- emoji picker -- */
[data-page="market-strategy"] .emoji-picker { position: absolute; bottom: calc(100% + 8px); left: 0; background: var(--bg-surface); border: 1px solid var(--border-md); border-radius: 12px; padding: 8px; z-index: 910; box-shadow: var(--shadow-lg); display: flex; flex-wrap: wrap; gap: 3px; width: 240px; visibility: hidden; opacity: 0; pointer-events: none; transform: translateY(6px); transition: opacity 0.15s, transform 0.15s, visibility 0s linear 0.15s; }
[data-page="market-strategy"] .emoji-picker.open { visibility: visible; opacity: 1; pointer-events: all; transform: translateY(0); transition: opacity 0.15s, transform 0.15s, visibility 0s linear 0s; }
[data-page="market-strategy"] .emoji-btn { width: 32px; height: 32px; border-radius: 6px; border: none; background: transparent; font-size: 17px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background 0.1s; }
[data-page="market-strategy"] .emoji-btn:hover { background: var(--bg-card); }

/* -- chat footer / input -- */
[data-page="market-strategy"] .chat-footer { padding: 10px 12px 12px; border-top: 1px solid var(--border); flex-shrink: 0; background: var(--bg-card); }
[data-page="market-strategy"] .chat-toolbar { display: flex; gap: 6px; margin-bottom: 8px; align-items: center; }
[data-page="market-strategy"] .chat-tool-btn { width: 30px; height: 30px; border-radius: 7px; border: 1px solid var(--border-md); background: var(--bg-surface); color: var(--text-muted); cursor: pointer; font-size: 15px; display: flex; align-items: center; justify-content: center; transition: all 0.15s; position: relative; }
[data-page="market-strategy"] .chat-tool-btn:hover { background: var(--border); color: var(--text-primary); }
[data-page="market-strategy"] .chat-charcount { margin-left: auto; font-size: 10px; font-family: var(--mono); color: var(--text-muted); }
[data-page="market-strategy"] .chat-charcount.warn { color: var(--red); }
[data-page="market-strategy"] .chat-input-row { display: flex; gap: 8px; align-items: flex-end; }
[data-page="market-strategy"] .chat-input { flex: 1; min-height: 38px; max-height: 100px; padding: 9px 12px; background: var(--bg-surface); border: 1.5px solid var(--border-md); border-radius: 10px; color: var(--text-primary); font-size: 13px; font-family: var(--font); resize: none; outline: none; transition: border-color 0.15s; line-height: 1.45; }
[data-page="market-strategy"] .chat-input:focus { border-color: var(--accent); }
[data-page="market-strategy"] .chat-input::placeholder { color: var(--text-muted); }
[data-page="market-strategy"] .chat-send { width: 38px; height: 38px; flex-shrink: 0; border-radius: 10px; background: var(--accent); border: none; color: #fff; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all 0.15s; }
[data-page="market-strategy"] .chat-send:hover { filter: brightness(1.12); transform: scale(1.05); }
[data-page="market-strategy"] .chat-send:disabled { opacity: 0.4; cursor: not-allowed; transform: none; }
[data-page="market-strategy"] .chat-send svg { width: 15px; height: 15px; }

/* -- name prompt overlay -- */
[data-page="market-strategy"] .name-prompt-overlay { position: absolute; inset: 0; background: var(--bg-surface); z-index: 10; display: flex; align-items: center; justify-content: center; flex-direction: column; gap: 14px; padding: 28px; border-radius: 16px; }
[data-page="market-strategy"] .name-prompt-overlay.hidden { display: none; }
[data-page="market-strategy"] .name-prompt-icon { width: 52px; height: 52px; border-radius: 14px; background: var(--accent-soft); border: 1px solid var(--accent-border); display: flex; align-items: center; justify-content: center; color: var(--accent); }
[data-page="market-strategy"] .name-prompt-icon svg { width: 24px; height: 24px; }
[data-page="market-strategy"] .name-prompt-title { font-size: 17px; font-weight: 700; color: var(--text-primary); }
[data-page="market-strategy"] .name-prompt-sub { font-size: 12px; color: var(--text-muted); text-align: center; line-height: 1.55; }
[data-page="market-strategy"] .name-input { width: 100%; padding: 11px 14px; background: var(--bg-card); border: 1.5px solid var(--border-md); border-radius: 9px; color: var(--text-primary); font-size: 14px; font-family: var(--font); outline: none; text-align: center; transition: border-color 0.15s; }
[data-page="market-strategy"] .name-input:focus { border-color: var(--accent); }
[data-page="market-strategy"] .name-submit-btn { width: 100%; padding: 11px; background: var(--accent); color: #fff; border: none; border-radius: 9px; font-size: 14px; font-weight: 700; font-family: var(--font); cursor: pointer; transition: filter 0.15s; }
[data-page="market-strategy"] .name-submit-btn:hover { filter: brightness(1.1); }

/* -- error banner + debug -- */
[data-page="market-strategy"] .error-banner { background: var(--red-soft); border: 1px solid var(--red-border); border-radius: var(--radius-sm); padding: 12px 16px; margin-bottom: 16px; color: var(--red); font-size: 13px; display: none; }
[data-page="market-strategy"] .error-banner.show { display: block; }
[data-page="market-strategy"] .debug-info { position: fixed; bottom: 10px; right: 10px; background: var(--bg-surface); border: 1px solid var(--border); padding: 8px; font-size: 11px; font-family: monospace; z-index: 9999; display: none; }

/* -- mobile -- */
@media(max-width:640px){
  [data-page="market-strategy"] .page { padding: 12px 12px 60px; }
  [data-page="market-strategy"] .market-hero { padding: 12px 14px; flex-direction: column; align-items: flex-start; gap: 10px; overflow-x: hidden; }
  [data-page="market-strategy"] .hero-right { flex-direction: column; width: 100%; gap: 8px; }
  [data-page="market-strategy"] .index-strip { width: 100%; }
  [data-page="market-strategy"] .index-strip > div { flex: 1; }
  [data-page="market-strategy"] .idx-badge { flex: 1 1 auto; min-width: 0; padding: 7px 10px; }
  [data-page="market-strategy"] .idx-badge-val { font-size: 13px; }
  [data-page="market-strategy"] .timestamp { display: none; }
  [data-page="market-strategy"] .sentiment-strip { padding: 10px 14px; gap: 10px; }
  [data-page="market-strategy"] .votes-btns { gap: 4px; }
  [data-page="market-strategy"] .vote-btn { padding: 5px 10px; font-size: 11px; }
  [data-page="market-strategy"] .votes-results { min-width: 0; }
  [data-page="market-strategy"] .votes-reset { font-size: 9px; }
  [data-page="market-strategy"] .strategy-grid { display: flex; flex-direction: column; gap: 0; }
  [data-page="market-strategy"] .side-panel { position: static !important; max-height: none !important; height: auto !important; overflow: visible !important; border-radius: 0; border-left: none; border-right: none; border-top: none; }
  [data-page="market-strategy"] #islamicPanel { border-top: 1px solid var(--border); border-radius: var(--radius) var(--radius) 0 0; margin-top: 16px; }
  [data-page="market-strategy"] #conventionalPanel { border-radius: 0 0 var(--radius) var(--radius); border-bottom: 1px solid var(--border); }
  [data-page="market-strategy"] .side-panel .panel-scroll { overflow: visible; max-height: none; flex: none; }
  [data-page="market-strategy"] .center-panel { gap: 0; }
  [data-page="market-strategy"] .center-card { border-radius: 0; border-left: none; border-right: none; border-top: none; box-shadow: none; }
  [data-page="market-strategy"] .popover-overlay { padding: 12px; }
  [data-page="market-strategy"] .popover { max-width: 100%; }
  [data-page="market-strategy"] .popover-body { overflow-x: auto; padding: 0 16px; }
  [data-page="market-strategy"] .popover-col-head,
  [data-page="market-strategy"] .popover-row,
  [data-page="market-strategy"] .popover-unknown { grid-template-columns: 100px 50px 60px 60px 70px; min-width: 500px; gap: 4px; }
}

/* ============================================================
   FOOTER + MODALS — paste at the very end of Styles.css
   ASCII only — no unicode in comments
============================================================ */

/* ================================================================
   SITE FOOTER  — paste into Styles.css under /* FOOTER
================================================================ */

.site-footer {
  background: var(--bg-surface);
  border-top: 1px solid var(--border);
  padding: 48px 0 0;
  margin-top: 60px;
  position: relative;
  overflow: hidden;
}

/* subtle top accent line */
.site-footer::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg,
    transparent 0%,
    var(--accent) 30%,
    var(--green) 70%,
    transparent 100%);
  opacity: 0.6;
}

.footer-inner {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 28px;
}

/* ── TOP GRID ── */
.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 40px 32px;
  padding-bottom: 40px;
  border-bottom: 1px solid var(--border);
}

/* ── COL 1: BRAND ── */
.footer-brand {}
.footer-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
  text-decoration: none;
}
.footer-logo-icon {
  width: 32px;
  height: 32px;
  background: linear-gradient(135deg, var(--accent), #3a6fd8);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.footer-logo-icon svg { width: 18px; height: 18px; color: #fff; }
.footer-logo-text {
  font-size: 17px;
  font-weight: 800;
  letter-spacing: -0.5px;
  color: var(--text-primary);
}
.footer-logo-text span { color: var(--accent); }
.footer-tagline {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 18px;
}
.footer-socials {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.footer-social-btn {
  display: flex;
  align-items: center;
  gap: 7px;
  height: 34px;
  padding: 0 12px;
  border-radius: 8px;
  border: 1px solid var(--border-md);
  background: var(--bg-card);
  color: var(--text-secondary);
  font-size: 12px;
  font-weight: 500;
  font-family: var(--font);
  text-decoration: none;
  transition: all 0.15s;
  white-space: nowrap;
}
.footer-social-btn svg { width: 14px; height: 14px; flex-shrink: 0; }
.footer-social-btn:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-soft); transform: translateY(-1px); }
.footer-social-btn.whatsapp:hover { border-color: #25d366; color: #25d366; background: rgba(37,211,102,0.08); }
.footer-social-btn.facebook:hover { border-color: #1877f2; color: #1877f2; background: rgba(24,119,242,0.08); }
.footer-social-btn.youtube:hover  { border-color: #ff0000; color: #ff0000; background: rgba(255,0,0,0.08); }

/* ── COL 2-4: LINKS ── */
.footer-col-title {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 16px;
}
.footer-links {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.footer-links a {
  font-size: 13px;
  color: var(--text-secondary);
  text-decoration: none;
  transition: color 0.12s;
  display: flex;
  align-items: center;
  gap: 6px;
}
.footer-links a:hover { color: var(--text-primary); }
.footer-links a .flink-dot {
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: var(--border-md);
  flex-shrink: 0;
  transition: background 0.12s;
}
.footer-links a:hover .flink-dot { background: var(--accent); }

/* ── BOTTOM BAR ── */
.footer-bottom {
  padding: 20px 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.footer-disclaimer {
  font-size: 11px;
  color: var(--text-muted);
  line-height: 1.75;
  padding: 14px 16px;
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--border);
  border-radius: 8px;
  border-left: 3px solid var(--accent);
}
.footer-disclaimer strong {
  color: var(--text-secondary);
  font-weight: 600;
}

.footer-legal-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px;
}
.footer-copy {
  font-size: 11.5px;
  color: var(--text-muted);
  font-family: var(--mono);
}
.footer-copy span { color: var(--text-secondary); }
.footer-legal-links {
  display: flex;
  align-items: center;
  gap: 4px;
}
.footer-legal-links button {
  background: none;
  border: none;
  font-size: 11.5px;
  color: var(--text-muted);
  cursor: pointer;
  font-family: var(--font);
  padding: 2px 8px;
  border-radius: 4px;
  transition: all 0.12s;
}
.footer-legal-links button:hover { color: var(--accent); background: var(--accent-soft); }
.footer-legal-sep { color: var(--border-md); font-size: 11px; }

/* ── RESPONSIVE ── */
@media (max-width: 960px) {
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 32px 24px; }
  .footer-brand { grid-column: 1 / -1; }
}
@media (max-width: 600px) {
  .site-footer { padding: 36px 0 0; }
  .footer-inner { padding: 0 16px; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 28px 16px; }
  .footer-brand { grid-column: 1 / -1; }
  .footer-legal-row { flex-direction: column; align-items: flex-start; gap: 8px; }
}

/* ================================================================
   CONTACT MODAL
================================================================ */
.psx-modal-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.65);
  backdrop-filter: blur(8px);
  z-index: 9900;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.psx-modal-overlay.open { display: flex; }
.psx-modal {
  background: var(--bg-surface);
  border: 1px solid var(--border-md);
  border-radius: 20px;
  width: 100%;
  max-width: 500px;
  max-height: 90vh;
  overflow-y: auto;
  box-shadow: 0 40px 100px rgba(0,0,0,0.4);
  position: relative;
}
.psx-modal-head {
  padding: 24px 24px 20px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.psx-modal-title { font-size: 18px; font-weight: 700; letter-spacing: -0.3px; }
.psx-modal-sub { font-size: 12px; color: var(--text-muted); margin-top: 3px; }
.psx-modal-close {
  width: 32px; height: 32px; border-radius: 8px; flex-shrink: 0;
  border: 1px solid var(--border-md); background: var(--bg-card);
  color: var(--text-muted); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; transition: all 0.15s;
}
.psx-modal-close:hover { background: rgba(232,48,75,0.1); color: var(--red); border-color: var(--red); }
.psx-modal-body { padding: 24px; }

/* contact form */
.psx-form { display: flex; flex-direction: column; gap: 14px; }
.psx-field { display: flex; flex-direction: column; gap: 6px; }
.psx-label { font-size: 11px; font-weight: 700; letter-spacing: 0.5px; text-transform: uppercase; color: var(--text-muted); }
.psx-input, .psx-textarea, .psx-select {
  background: var(--bg-card);
  border: 1.5px solid var(--border-md);
  border-radius: 10px;
  padding: 10px 14px;
  color: var(--text-primary);
  font-size: 13px;
  font-family: var(--font);
  outline: none;
  transition: border-color 0.15s;
  width: 100%;
}
.psx-input:focus, .psx-textarea:focus, .psx-select:focus { border-color: var(--accent); }
.psx-input::placeholder, .psx-textarea::placeholder { color: var(--text-muted); }
.psx-textarea { resize: vertical; min-height: 100px; line-height: 1.6; }
.psx-select { appearance: none; cursor: pointer; }
.psx-submit {
  height: 44px; border-radius: 10px;
  background: var(--accent); color: #fff;
  border: none; cursor: pointer;
  font-size: 14px; font-weight: 700; font-family: var(--font);
  transition: all 0.15s; margin-top: 4px;
}
.psx-submit:hover { filter: brightness(1.1); transform: translateY(-1px); }
.psx-submit:disabled { opacity: 0.5; cursor: not-allowed; transform: none; }
.psx-form-success {
  display: none; text-align: center; padding: 28px 0;
  flex-direction: column; align-items: center; gap: 12px;
}
.psx-form-success.show { display: flex; }
.psx-success-icon {
  width: 52px; height: 52px; border-radius: 50%;
  background: rgba(10,196,122,0.12); border: 1px solid rgba(10,196,122,0.3);
  display: flex; align-items: center; justify-content: center; color: var(--green);
}
.psx-success-title { font-size: 17px; font-weight: 700; }
.psx-success-sub { font-size: 13px; color: var(--text-muted); }

/* privacy modal body */
.psx-modal-body.prose {
  font-size: 13px;
  line-height: 1.8;
  color: var(--text-secondary);
}
.psx-modal-body.prose h3 {
  font-size: 13px; font-weight: 700;
  color: var(--text-primary);
  text-transform: uppercase; letter-spacing: 0.5px;
  margin: 20px 0 8px;
}
.psx-modal-body.prose h3:first-child { margin-top: 0; }
.psx-modal-body.prose p { margin-bottom: 10px; }
.psx-modal-body.prose ul { padding-left: 18px; margin-bottom: 10px; }
.psx-modal-body.prose li { margin-bottom: 5px; }
.psx-modal-body.prose a { color: var(--accent); text-decoration: none; }

/* SEO static content block — hidden from users, readable by crawlers */
.seo-static-block {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}
