  :root {
    --font-ar: 'Tajawal', sans-serif;
    --font-en: 'Inter', -apple-system, sans-serif;
    --font-mono: 'JetBrains Mono', monospace;
    --bg-primary: #080c14; --bg-secondary: #0d1220; --bg-card: #111827;
    --bg-card-hover: #161e30; --bg-input: #0f1724;
    --border-subtle: rgba(255,255,255,0.05); --border-card: rgba(255,255,255,0.07);
    --border-strong: rgba(255,255,255,0.10); --text-primary: #e8ecf2;
    --text-secondary: #9ca3b5; --text-muted: #5c6a80;
    --accent-buy: #10b981; --accent-buy-bg: rgba(16,185,129,0.10); --accent-buy-border: rgba(16,185,129,0.25);
    --accent-watch: #f59e0b; --accent-watch-bg: rgba(245,158,11,0.10); --accent-watch-border: rgba(245,158,11,0.25);
    --accent-avoid: #ef4444; --accent-avoid-bg: rgba(239,68,68,0.10); --accent-avoid-border: rgba(239,68,68,0.25);
    --accent-cyan: #22d3ee; --accent-gold: #facc15; --accent-violet: #a78bfa;
    --accent-brand: #3b82f6; --accent-brand-bg: rgba(59,130,246,0.10);
    --shadow-card: 0 1px 3px rgba(0,0,0,0.4); --shadow-lg: 0 8px 32px rgba(0,0,0,0.6);
    --radius-sm: 6px; --radius-md: 10px; --radius-lg: 14px; --radius-pill: 999px;
  }
  [data-theme="light"] {
    --bg-primary: #F0EEE8; --bg-secondary: #F7F5F2; --bg-card: #FCFBF9;
    --bg-card-hover: #F3F1ED; --bg-input: #E9E6E1;
    --border-subtle: rgba(0,0,0,0.05); --border-card: rgba(0,0,0,0.07);
    --border-strong: rgba(0,0,0,0.10); --text-primary: #2D3340;
    --text-secondary: #556270; --text-muted: #788590;
    --accent-buy: #0f8c5c; --accent-buy-bg: rgba(15,140,92,0.08); --accent-buy-border: rgba(15,140,92,0.20);
    --accent-watch: #b87808; --accent-watch-bg: rgba(184,120,8,0.08); --accent-watch-border: rgba(184,120,8,0.20);
    --accent-avoid: #c53030; --accent-avoid-bg: rgba(197,48,48,0.08); --accent-avoid-border: rgba(197,48,48,0.20);
    --accent-brand: #3b6fcc; --accent-brand-bg: rgba(59,111,204,0.10);
    --accent-violet-bg: rgba(120,100,200,0.08);
    --shadow-card: 0 1px 4px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04);
    --shadow-lg: 0 8px 24px rgba(0,0,0,0.07);
  }
  * { box-sizing: border-box; margin: 0; padding: 0; }
  html { font-size: 15px; -webkit-font-smoothing: antialiased; }
  body {
    font-family: var(--font-ar); background: var(--bg-primary); color: var(--text-primary);
    min-height: 100vh;
    background-image: radial-gradient(ellipse 1200px 600px at 50% -10%, rgba(34,211,238,0.04), transparent 60%), radial-gradient(ellipse 800px 500px at 90% 40%, rgba(167,139,250,0.03), transparent 60%);
    background-attachment: fixed;
  }
  .app-shell { max-width: 1440px; margin: 0 auto; padding: 0 20px; }

  /* ── Nav Bar ── */
  .navbar {
    position: sticky; top: 0; z-index: 30;
    background: var(--bg-primary); border-bottom: 1px solid var(--border-subtle);
    backdrop-filter: blur(12px); padding: 8px 0;
  }
  .nav-inner { display: flex; align-items: center; justify-content: space-between; max-width: 1440px; margin: 0 auto; padding: 0 20px; gap: 12px; }
  .nav-brand { display: flex; align-items: center; gap: 10px; font-weight: 700; font-size: 0.95rem; }
  .nav-brand-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--accent-brand); box-shadow: 0 0 8px var(--accent-brand); }
  .nav-tabs { display: flex; gap: 2px; background: var(--bg-input); border-radius: var(--radius-md); padding: 3px; }
  .nav-tab {
    padding: 6px 16px; border-radius: var(--radius-sm); font-size: 0.8rem; font-weight: 500;
    cursor: pointer; border: none; background: none; color: var(--text-muted);
    transition: all 0.15s; font-family: var(--font-ar);
  }
  .nav-tab:hover { color: var(--text-primary); }
  .nav-tab.active { background: var(--bg-card); color: var(--text-primary); box-shadow: 0 1px 3px rgba(0,0,0,0.3); }
  .nav-actions { display: flex; align-items: center; gap: 6px; }

  .btn {
    display: inline-flex; align-items: center; gap: 5px; padding: 6px 12px;
    border-radius: var(--radius-sm); font-size: 0.78rem; font-weight: 500;
    border: 1px solid var(--border-strong); background: var(--bg-card); color: var(--text-secondary);
    cursor: pointer; transition: all 0.15s; font-family: var(--font-ar);
  }
  .btn:hover { background: var(--bg-card-hover); color: var(--text-primary); }
  .btn-icon { padding: 6px 8px; }
  .btn-primary { background: var(--accent-brand); color: #fff; border-color: var(--accent-brand); }
  .btn-primary:hover { opacity: 0.9; }
  .btn-sm { padding: 4px 10px; font-size: 0.7rem; }

  /* ── Ticker ── */
  .ticker-tape {
    overflow: hidden;
    padding: 12px 0;
    border-bottom: 1px solid var(--border-subtle);
    position: relative;
  }
  .ticker-track {
    display: flex;
    gap: 32px;
    width: max-content;
    animation: tickerScroll 30s linear infinite;
  }
  .ticker-tape:hover .ticker-track { animation-play-state: paused; }
  @keyframes tickerScroll {
    0%   { transform: translateX(0%); }
    100% { transform: translateX(var(--shift-pct, -25%)); }
  }
  .ticker-item { display: flex; align-items: center; gap: 6px; white-space: nowrap; flex-shrink: 0; }
  .ticker-label { font-size: 0.68rem; font-weight: 600; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.05em; }
  .ticker-value { font-size: 1rem; font-weight: 700; font-family: var(--font-mono); }
  .ticker-change { font-size: 0.72rem; font-weight: 600; font-family: var(--font-mono); padding: 2px 6px; border-radius: var(--radius-pill); }
  .ticker-up { color: var(--accent-buy); } .ticker-up-bg { background: var(--accent-buy-bg); }
  .ticker-down { color: var(--accent-avoid); } .ticker-down-bg { background: var(--accent-avoid-bg); }

  /* ── Stats ── */
  .stats-row { display: grid; grid-template-columns: repeat(5, 1fr); gap: 10px; padding: 14px 0; }
  .stat-card {
    background: var(--bg-card); border: 1px solid var(--border-card);
    border-radius: var(--radius-md); padding: 14px; cursor: pointer;
    box-shadow: var(--shadow-card); transition: all 0.15s;
  }
  .stat-card:hover { border-color: var(--border-strong); }
  .stat-card.active { border-color: var(--accent-brand); box-shadow: 0 0 0 1px var(--accent-brand); }
  .stat-label { font-size: 0.68rem; color: var(--text-muted); font-weight: 500; text-transform: uppercase; letter-spacing: 0.04em; margin-bottom: 3px; }
  .stat-value { font-size: 1.5rem; font-weight: 800; font-family: var(--font-mono); }
  .stat-delta { font-size: 0.65rem; font-weight: 600; font-family: var(--font-mono); }
  .dist-bar { display: flex; height: 3px; border-radius: 2px; overflow: hidden; margin-top: 8px; }
  .dist-buy { background: var(--accent-buy); }
  .dist-watch { background: var(--accent-watch); }
  .dist-avoid { background: var(--accent-avoid); }

  /* ── Controls ── */
  .controls-bar { display: flex; align-items: center; gap: 8px; padding: 8px 0; flex-wrap: wrap; border-bottom: 1px solid var(--border-subtle); }
  .chip {
    display: inline-flex; align-items: center; gap: 4px; padding: 4px 10px;
    border-radius: var(--radius-pill); font-size: 0.72rem; font-weight: 500;
    cursor: pointer; border: 1px solid var(--border-strong); background: var(--bg-card);
    color: var(--text-secondary); transition: all 0.15s; white-space: nowrap;
    font-family: var(--font-ar);
  }
  .chip:hover { background: var(--bg-card-hover); }
  .chip.active { background: var(--accent-brand); color: #fff; border-color: var(--accent-brand); }
  .chip.buy { border-color: var(--accent-buy-border); color: var(--accent-buy); }
  .chip.buy.active { background: var(--accent-buy); color: #fff; }
  .chip.watch { border-color: var(--accent-watch-border); color: var(--accent-watch); }
  .chip.watch.active { background: var(--accent-watch); color: #000; }
  .chip.avoid { border-color: var(--accent-avoid-border); color: var(--accent-avoid); }
  .chip.avoid.active { background: var(--accent-avoid); color: #fff; }
  .chip-count { font-size: 0.62rem; opacity: 0.7; }
  .chip-sep { color: var(--border-strong); margin: 0 2px; font-size: 0.8rem; }
  #sectorChips { display: inline-flex; flex-wrap: nowrap; gap: 4px; max-width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; padding: 2px 0; }
  #sectorChips::-webkit-scrollbar { height: 0; }

  .search-box {
    display: flex; align-items: center; gap: 6px; padding: 5px 12px;
    background: var(--bg-input); border: 1px solid var(--border-strong);
    border-radius: var(--radius-pill); flex: 1; min-width: 180px; max-width: 280px;
  }
  .search-box input { border: none; background: none; outline: none; width: 100%; font-size: 0.78rem; color: var(--text-primary); font-family: var(--font-ar); }
  .search-box input::placeholder { color: var(--text-muted); }

  /* ── Freshness ── */
  .freshness-bar { display: flex; align-items: center; justify-content: space-between; padding: 8px 0; font-size: 0.65rem; color: var(--text-muted); gap: 8px; flex-wrap: wrap; }
  .freshness-warning { color: var(--accent-watch); }

  /* ── Table ── */
  .table-wrap { background: var(--bg-card); border: 1px solid var(--border-card); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-card); margin: 8px 0; }
  .th-row, .tr-row { display: grid; grid-template-columns: 3px 1fr 80px 70px 70px 80px 70px 80px 80px 50px; gap: 6px; align-items: center; padding: 10px 14px; }
  .th-row { grid-template-columns: 3px 1fr 80px 70px 70px 80px 70px 80px 80px 50px; border-bottom: 1px solid var(--border-card); font-size: 0.68rem; font-weight: 600; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.04em; }
  .tr-row { grid-template-columns: 3px 1fr 80px 70px 70px 80px 70px 80px 80px 50px; border-bottom: 1px solid var(--border-subtle); cursor: pointer; transition: background 0.12s; font-size: 0.8rem; }
  .tr-row:hover { background: var(--bg-card-hover); }
  .tr-row:last-child { border-bottom: none; }
  .th-sort { cursor: pointer; user-select: none; display: flex; align-items: center; gap: 2px; }
  .th-sort:hover { color: var(--text-primary); }
  .sort-arrow { font-size: 0.6rem; opacity: 0.4; }
  .sort-arrow.active { opacity: 1; color: var(--accent-brand); }
  /* ── News ── */
  .news-wrap { background: var(--bg-card); border: 1px solid var(--border-card); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-card); margin: 8px 0; }
  .news-row { display: grid; grid-template-columns: 3px 70px 1fr 110px 100px; gap: 6px; align-items: center; padding: 5px 12px; border-bottom: 1px solid var(--border-subtle); cursor: pointer; transition: background 0.12s; text-decoration: none; color: inherit; font-size: 0.78rem; }
  .news-row:hover { background: var(--bg-card-hover); }
  .news-row:last-child { border-bottom: none; }
  .news-row__category { font-size: 0.68rem; font-weight: 600; padding: 3px 10px; border-radius: var(--radius-pill); white-space: nowrap; text-align: center; background: var(--bg-input); color: var(--text-muted); border: 1px solid var(--border-subtle); }
  .news-row__title { font-size: 0.8rem; font-weight: 500; line-height: 1.4; color: var(--text-primary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .news-row__source { font-size: 0.7rem; font-weight: 500; color: var(--text-secondary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .news-row__time { font-size: 0.68rem; color: var(--text-muted); white-space: nowrap; font-family: var(--font-mono); }
  .news-skeleton { display: grid; grid-template-columns: 3px 70px 1fr 110px 100px; gap: 6px; padding: 5px 12px; border-bottom: 1px solid var(--border-subtle); }
  .news-skeleton__line { height: 11px; background: var(--bg-input); border-radius: var(--radius-sm); animation: skPulse 1.5s ease-in-out infinite; }
  @keyframes skPulse { 0%,100% { opacity: 0.4; } 50% { opacity: 0.8; } }
  .news-empty { text-align: center; padding: 48px 20px; }
  .news-empty__icon { font-size: 2.2rem; margin-bottom: 8px; opacity: 0.5; }
  .news-empty__text { font-size: 0.85rem; color: var(--text-secondary); font-weight: 600; margin-bottom: 4px; }
  .news-empty__sub { font-size: 0.7rem; color: var(--text-muted); }


  .rail-buy { background: var(--accent-buy); }
  .rail-watch { background: var(--accent-watch); }
  .rail-avoid { background: var(--accent-avoid); }

  .stock-name { font-weight: 600; }
  .stock-ticker { font-size: 0.68rem; color: var(--text-muted); font-family: var(--font-mono); }
  .price-mono { font-family: var(--font-mono); font-weight: 600; }
  .pct-up { color: var(--accent-buy); font-weight: 600; font-family: var(--font-mono); }
  .pct-down { color: var(--accent-avoid); font-weight: 600; font-family: var(--font-mono); }
  .score-flex { display: flex; align-items: center; gap: 6px; }
  .score-bars { display: flex; gap: 1.5px; }
  .score-seg { width: 7px; height: 14px; border-radius: 2px; background: rgba(255,255,255,0.08); }
  .seg-buy { background: var(--accent-buy); }
  .seg-watch { background: var(--accent-watch); }
  .seg-avoid { background: var(--accent-avoid); }
  .score-num { font-size: 0.85rem; font-weight: 700; font-family: var(--font-mono); }

  .badge { display: inline-block; padding: 2px 8px; border-radius: var(--radius-pill); font-size: 0.68rem; font-weight: 600; }
  .badge-buy { background: var(--accent-buy-bg); color: var(--accent-buy); }
  .badge-watch { background: var(--accent-watch-bg); color: var(--accent-watch); }
  .badge-avoid { background: var(--accent-avoid-bg); color: var(--accent-avoid); }

  .sector-tag { font-size: 0.68rem; color: var(--text-muted); }

  /* ── Expandable row detail (inline) ── */
  .row-detail { display: none; padding: 14px 18px; border-bottom: 1px solid var(--border-card); background: var(--bg-secondary); grid-template-columns: 1fr 1fr 1fr; gap: 16px; font-size: 0.76rem; }
  .row-detail.open { display: grid; }
  .detail-section h4 { font-size: 0.65rem; font-weight: 600; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 6px; }
  .detail-item { display: flex; justify-content: space-between; padding: 3px 0; color: var(--text-secondary); border-bottom: 1px solid var(--border-subtle); }
  .detail-item span:last-child { font-weight: 500; color: var(--text-primary); font-family: var(--font-mono); font-size: 0.72rem; }
  .detail-actions { display: flex; gap: 6px; margin-top: 8px; }

  /* ── Drawer (slide-out panel) ── */
  .drawer-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.6); z-index: 40; }
  .drawer-overlay.open { display: block; }
  .drawer {
    position: fixed; top: 0; right: 0; height: 100vh; width: 520px; max-width: 95vw;
    background: var(--bg-primary); z-index: 50; overflow-y: auto;
    box-shadow: var(--shadow-lg); transform: translateX(100%); transition: transform 0.25s ease;
    border-left: 1px solid var(--border-card);
  }
  .drawer.open { transform: translateX(0); }
  .drawer-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 16px 20px; border-bottom: 1px solid var(--border-card);
    position: sticky; top: 0; background: var(--bg-primary); z-index: 2;
  }
  .drawer-body { padding: 20px; }
  .drawer-section { margin-bottom: 20px; }
  .drawer-section h3 { font-size: 0.85rem; font-weight: 700; margin-bottom: 10px; display: flex; align-items: center; gap: 8px; }
  .drawer-section p { font-size: 0.8rem; color: var(--text-secondary); line-height: 1.8; }
  .metric-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
  .metric-card { background: var(--bg-card); border: 1px solid var(--border-card); border-radius: var(--radius-sm); padding: 10px 12px; }
  .metric-label { font-size: 0.65rem; color: var(--text-muted); text-transform: uppercase; }
  .metric-value { font-size: 1rem; font-weight: 700; font-family: var(--font-mono); }
  .metric-value.pos { color: var(--accent-buy); }
  .metric-value.neg { color: var(--accent-avoid); }
  .metric-value.warn { color: var(--accent-watch); }

  /* Mobile: bottom sheet */
  @media (max-width: 768px) {
    .drawer {
      top: auto; bottom: 0; left: 0; right: 0; height: 92vh; width: 100vw; max-width: 100vw;
      border-radius: var(--radius-lg) var(--radius-lg) 0 0;
      border-left: none; border-right: none;
      transform: translateY(100%);
      box-shadow: 0 -4px 24px rgba(0,0,0,0.5);
    }
    .drawer.open { transform: translateY(0); }
    .drawer-body { padding: 14px 16px; }
    .metric-grid { grid-template-columns: 1fr 1fr; }
    /* Action buttons full-width on mobile */
    .btn-analyze { width: 100%; justify-content: center; }
    .drawer-section .btn-analyze + div { flex-direction: column; }
    .drawer-section .btn-analyze + div button { flex: 1; }
  }
  @media (max-width: 420px) {
    .metric-grid, .drawer-section div[style*="grid-template-columns:1fr 1fr"] { grid-template-columns: 1fr !important; }
    .drawer-section h3 { font-size: 0.78rem; }
  }

  .ai-block { background: var(--accent-violet-bg); border: 1px solid var(--border-card); border-radius: var(--radius-md); padding: 14px; margin-top: 10px; }
  .ai-block h4 { font-size: 0.75rem; font-weight: 600; color: var(--accent-violet); margin-bottom: 6px; }
  .ai-block p { font-size: 0.78rem; color: var(--text-secondary); line-height: 1.7; }

  /* ── Settings Modal ── */
  .modal-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.7); z-index: 60; align-items: center; justify-content: center; }
  .modal-overlay.open { display: flex; }
  .modal { background: var(--bg-card); border: 1px solid var(--border-card); border-radius: var(--radius-lg); padding: 24px; width: 420px; max-width: 90vw; box-shadow: var(--shadow-lg); }
  .modal h3 { font-size: 1rem; font-weight: 700; margin-bottom: 16px; }
  .modal label { font-size: 0.72rem; font-weight: 600; color: var(--text-secondary); display: block; margin-bottom: 4px; margin-top: 12px; }
  .modal input, .modal select {
    width: 100%; padding: 8px 12px; border-radius: var(--radius-sm);
    background: var(--bg-input); border: 1px solid var(--border-strong);
    color: var(--text-primary); font-size: 0.82rem; font-family: var(--font-mono);
  }
  .modal select { font-family: var(--font-ar); }
  .modal-actions { display: flex; gap: 8px; margin-top: 16px; justify-content: flex-end; }

  /* ── Consensus Tab ── */
  .consensus-shell { max-width: 1100px; margin: 0 auto; padding: 0 20px; }
  .stock-picker-row { display: flex; align-items: center; gap: 10px; padding: 14px 0; flex-wrap: wrap; }
  .stock-picker-row select { padding: 8px 14px; border-radius: var(--radius-md); background: var(--bg-card); border: 1px solid var(--border-strong); color: var(--text-primary); font-family: var(--font-ar); font-size: 0.85rem; min-width: 280px; }
  .verdict-card { background: var(--bg-card); border: 1px solid var(--border-card); border-radius: var(--radius-lg); padding: 24px; margin: 8px 0; box-shadow: var(--shadow-card); }
  .verdict-header { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; flex-wrap: wrap; }
  .verdict-badge { font-size: 1rem; font-weight: 800; padding: 8px 20px; border-radius: var(--radius-pill); }
  .verdict-buy { background: var(--accent-buy-bg); color: var(--accent-buy); border: 1px solid var(--accent-buy); }
  .verdict-watch { background: var(--accent-watch-bg); color: var(--accent-watch); border: 1px solid var(--accent-watch); }
  .verdict-avoid { background: var(--accent-avoid-bg); color: var(--accent-avoid); border: 1px solid var(--accent-avoid); }
  .verdict-confidence { font-size: 0.78rem; color: var(--text-secondary); }
  .verdict-reason { font-size: 0.82rem; color: var(--text-secondary); line-height: 1.8; margin-bottom: 14px; }
  .verdict-meta { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; padding-top: 14px; border-top: 1px solid var(--border-card); }
  .meta-label { font-size: 0.62rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 3px; }
  .meta-value { font-size: 0.95rem; font-weight: 700; font-family: var(--font-mono); }
  .agent-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px; margin: 12px 0; }
  .agent-card { background: var(--bg-secondary); border: 1px solid var(--border-card); border-radius: var(--radius-md); padding: 12px; text-align: center; transition: all 0.3s; }
  .agent-card.done { border-color: rgba(16,185,129,0.25); }
  .agent-card.working { border-color: var(--accent-gold); animation: pulse-border 1.2s infinite; }
  .agent-card.pending { opacity: 0.5; border-style: dashed; }
  @keyframes pulse-border { 0%,100% { border-color: var(--accent-gold); box-shadow: 0 0 8px rgba(245,158,11,0.3); } 50% { border-color: rgba(245,158,11,0.15); box-shadow: none; } }
  .agent-icon { font-size: 1.6rem; margin-bottom: 4px; }
  .agent-name { font-size: 0.72rem; font-weight: 600; }
  .agent-status { font-size: 0.62rem; font-weight: 500; padding: 2px 8px; border-radius: var(--radius-pill); display: inline-block; margin-top: 4px; }
  .status-done { background: var(--accent-buy-bg); color: var(--accent-buy); }
  .status-working { background: rgba(245,158,11,0.15); color: var(--accent-gold); animation: pulse-text 1.2s infinite; }
  .status-pending { background: var(--bg-input); color: var(--text-muted); }
  @keyframes pulse-text { 0%,100% { opacity: 1; } 50% { opacity: 0.5; } }
  .agent-analysis { background: var(--bg-card); border: 1px solid var(--border-card); border-radius: var(--radius-md); padding: 14px; margin-bottom: 8px; box-shadow: var(--shadow-card); }
  .agent-analysis.technical { border-right: 3px solid var(--accent-cyan); }
  .agent-analysis.fundamental { border-right: 3px solid var(--accent-buy); }
  .agent-analysis.sentiment { border-right: 3px solid #f472b6; }
  .agent-analysis.risk { border-right: 3px solid #fb923c; }
  .agent-analysis.lead { border-right: 3px solid var(--accent-violet); }
  .analysis-header { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
  .analysis-agent-name { font-size: 0.78rem; font-weight: 700; }
  .analysis-score-badge { font-size: 0.7rem; font-family: var(--font-mono); padding: 3px 10px; border-radius: var(--radius-pill); font-weight: 600; }
  .score-positive { background: var(--accent-buy-bg); color: var(--accent-buy); }
  .score-neutral { background: var(--accent-watch-bg); color: var(--accent-watch); }
  .score-negative { background: var(--accent-avoid-bg); color: var(--accent-avoid); }
  .analysis-body { font-size: 0.78rem; color: var(--text-secondary); line-height: 1.8; }
  .kw-tags { display: flex; gap: 5px; flex-wrap: wrap; margin-top: 8px; }
  .kw { font-size: 0.62rem; padding: 2px 8px; border-radius: var(--radius-pill); background: var(--bg-input); color: var(--text-muted); }
  .kw.bullish { background: var(--accent-buy-bg); color: var(--accent-buy); }
  .kw.bearish { background: var(--accent-avoid-bg); color: var(--accent-avoid); }
  .position-card { background: var(--bg-card); border: 1px solid var(--border-card); border-radius: var(--radius-md); padding: 14px; margin-top: 10px; display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; box-shadow: var(--shadow-card); }
  @media (max-width: 768px) { .agent-grid { grid-template-columns: repeat(3, 1fr); } .verdict-meta { grid-template-columns: 1fr 1fr; } .position-card { grid-template-columns: 1fr 1fr; } }

  /* ── Agent live analysis ── */
  .btn-analyze {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 8px 20px; border-radius: var(--radius-md); font-size: 0.82rem;
    font-weight: 700; font-family: var(--font-ar); cursor: pointer; border: none;
    background: linear-gradient(135deg, var(--accent-brand), var(--accent-violet));
    color: #fff; transition: all 0.2s; box-shadow: 0 2px 12px rgba(59,130,246,0.3);
  }
  .btn-analyze:hover { transform: translateY(-1px); box-shadow: 0 4px 20px rgba(59,130,246,0.4); }
  .btn-analyze:disabled { opacity: 0.5; cursor: not-allowed; transform: none; }
  .btn-analyze.stop { background: linear-gradient(135deg, #ef4444, #dc2626); box-shadow: 0 2px 12px rgba(239,68,68,0.3); }
  .agent-progress-wrap { margin: 12px 0; }
  .agent-progress-bar { height: 5px; background: var(--bg-input); border-radius: var(--radius-pill); overflow: hidden; }
  .agent-progress-fill { height: 100%; background: linear-gradient(90deg, var(--accent-violet), var(--accent-cyan)); border-radius: var(--radius-pill); transition: width 0.4s ease; }
  .agent-progress-label { font-size: 0.68rem; color: var(--text-muted); margin-top: 4px; text-align: center; }
  .debate-question { background: rgba(167,139,250,0.06); border: 1px solid rgba(167,139,250,0.2); border-radius: var(--radius-md); padding: 12px; margin-bottom: 8px; }
  .debate-question-header { font-size: 0.7rem; font-weight: 700; color: var(--accent-violet); margin-bottom: 6px; }
  .debate-question-body { font-size: 0.73rem; color: var(--text-secondary); white-space: pre-wrap; line-height: 1.7; }
  .agent-error { background: var(--accent-avoid-bg); border: 1px solid var(--accent-avoid-border); border-radius: var(--radius-md); padding: 12px; color: var(--accent-avoid); font-size: 0.78rem; }

  /* ── Skeleton ── */
  @keyframes shimmer { 0% { background-position: -200px 0; } 100% { background-position: 200px 0; } }
  .skeleton { background: linear-gradient(90deg, var(--bg-card) 25%, var(--bg-card-hover) 50%, var(--bg-card) 75%); background-size: 400px 100%; animation: shimmer 1.5s infinite; border-radius: 4px; display: inline-block; }

  /* ── Portfolio bar ── */
  .portfolio-bar {
    display: flex; align-items: center; gap: 10px; padding: 10px 14px;
    background: var(--bg-card); border: 1px solid var(--border-card);
    border-radius: var(--radius-md); margin-bottom: 10px;
  }
  .portfolio-bar .msg { font-size: 0.78rem; color: var(--text-secondary); flex: 1; }
  .portfolio-bar .close-btn { cursor: pointer; color: var(--text-muted); background: none; border: none; font-size: 1rem; }

  /* ── Density toggle ── */
  .density-compact .tr-row, .density-compact .th-row { padding: 6px 14px; font-size: 0.72rem; }

  /* ── Status bar ── */
  .status-bar { display: flex; align-items: center; justify-content: space-between; padding: 10px 0; font-size: 0.68rem; color: var(--text-muted); border-top: 1px solid var(--border-subtle); margin-top: 12px; flex-wrap: wrap; gap: 8px; }
  .status-dot { width: 6px; height: 6px; border-radius: 50%; display: inline-block; }
  .dot-open { background: var(--accent-buy); box-shadow: 0 0 6px var(--accent-buy); }
  .dot-closed { background: var(--accent-avoid); }

  /* ── Tabs content ── */
  .tab-content { display: none; }
  .tab-content.active { display: block; }

  /* ═══════════════════════════════════════════
     RESPONSIVE BREAKPOINTS
     ═══════════════════════════════════════════ */

  /* Tablet: 640–1024px */
  @media (max-width: 1024px) {
    .stats-row { grid-template-columns: repeat(3, 1fr); }
    /* Table — keep all cols, let it scroll */
    .table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
    .th-row, .tr-row { min-width: 600px; }
    .nav-brand span { display: none; }
    .nav-brand-dot { width: 10px; height: 10px; }
  }

  /* Phone landscape / large phones: 480–640px */
  @media (max-width: 640px) {
    .app-shell { padding: 0 10px; }
    .stats-row { grid-template-columns: 1fr 1fr; gap: 6px; }
    .stat-card { padding: 10px; }
    .stat-value { font-size: 1.2rem; }
    .navbar { padding: 4px 0; }
    .nav-inner { padding: 0 8px; gap: 4px; }
    .nav-tab { padding: 4px 10px; font-size: 0.7rem; }
    .nav-actions .btn { padding: 4px 6px; font-size: 0.7rem; }
    .search-box { min-width: 0; max-width: none; flex: 1 1 100%; }
    .controls-bar { gap: 4px; padding: 6px 0; }
    .chip { padding: 3px 8px; font-size: 0.68rem; }
    /* Table scroll with all columns visible */
    .th-row, .tr-row { min-width: 580px; font-size: 0.72rem; }
    /* News scroll */
    .news-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
    .news-row, .news-skeleton { min-width: 480px; }
    .ticker-tape { padding: 8px 0; }
    .ticker-value { font-size: 0.85rem; }
  }

  /* Phone portrait: < 480px */
  @media (max-width: 480px) {
    .stats-row { grid-template-columns: 1fr 1fr; gap: 4px; }
    .stat-card { padding: 8px; }
    .stat-label { font-size: 0.6rem; }
    .stat-value { font-size: 1rem; }
    .nav-brand-dot { display: none; }
    .nav-tab { padding: 3px 6px; font-size: 0.62rem; }
    .nav-tabs { gap: 0; }
    .nav-actions { gap: 2px; }
    .nav-actions .btn { padding: 3px 5px; font-size: 0.65rem; }
    .nav-actions .btn-icon { padding: 3px 4px; }
    .th-row, .tr-row { min-width: 520px; font-size: 0.68rem; }
    .news-row, .news-skeleton { min-width: 440px; }
    .status-bar { font-size: 0.6rem; flex-direction: column; align-items: flex-start; }
    .modal { width: 95vw; padding: 16px; }
  }

  /* Tiny phones: < 380px — stats go single-column */
  @media (max-width: 380px) {
    .stats-row { grid-template-columns: 1fr; }
  }
