:root {
      --bg: #16181d;
      --panel: #1d2027;
      --panel-2: #292d36;
      --surface-content: #20242c;
      --surface-content-2: #2b303a;
      --line: rgba(215,226,245,.10);
      --text: #eef2f7;
      --muted: #9aa6b7;
      --accent: #e8572a;
      --accent-2: #d97941;
      --info: #4aa3ff;
      --danger: #e05c5c;
      --green: #2bb58a;
      --red: #e05c5c;
      --gold: #d4a843;
      --radius: 18px;
      --radius-card: 14px;
      --radius-control: 10px;
      --radius-pill: 999px;
      --shadow: 0 4px 20px rgba(0,0,0,.3);
      --hover: rgba(215,226,245,.10);
      --active: rgba(215,226,245,.15);
      --glow: rgba(215,226,245,.10);
      --max: 1280px;
      --gpt-color: #e8572a;
      --claude-color: #d97941;
      --gemini-color: #4a9fd4;
      --judge-color: #2bb58a;
      --sidebar-w: 260px;
      /* For-You editorial cover — dark mode */
      --fy-bg:        #15181d;
      --fy-bg-paper:  #1e232b;
      --fy-ink:       #eef2f7;
      --fy-ink-muted: #9aa6b7;
      --fy-rule:      rgba(255, 255, 255, .08);
      --fy-accent:    #e85722;
      --fy-up:        #2bd596;
      --fy-down:      #ff6b6b;
    }
    html[data-theme="light"] {
      --bg: #faf9f7;
      --panel: #ffffff;
      --panel-2: #f0eeeb;
      --surface-content: #ffffff;
      --surface-content-2: #f6f3ef;
      --line: rgba(0,0,0,.08);
      --text: #1a1a1a;
      --muted: #6b6b6b;
      --shadow: 0 4px 20px rgba(0,0,0,.07);
      --hover: rgba(0,0,0,.05);
      --active: rgba(0,0,0,.1);
      --glow: rgba(0,0,0,.06);
      --green: #0a9e6a;
      --red: #d43d3d;
      --info: #1677c7;
      /* For-You editorial cover — light mode */
      --fy-bg:        #f4ede0;
      --fy-bg-paper:  #ffffff;
      --fy-ink:       #1a1410;
      --fy-ink-muted: #6b5b3e;
      --fy-rule:      rgba(26, 20, 16, .10);
      --fy-accent:    #c64a1a;
      --fy-up:        #2d6a3e;
      --fy-down:      #a8324a;
    }
    * { box-sizing: border-box; font-family: inherit; }
    html, body { margin: 0; padding: 0; background: var(--bg); color: var(--text); font-family: 'Inter', 'Google Sans', 'Helvetica Neue', Arial, sans-serif; transition: background .2s, color .2s; font-size: 16px; overflow-x: hidden; }
    body { min-height: 100vh; min-height: 100dvh; }
    @media (max-width: 768px) and (orientation: landscape) {
      body::before {
        content: '';
        position: fixed;
        inset: 0;
        z-index: 10000;
        background: var(--bg);
      }
      body::after {
        content: 'Portrait mode only';
        position: fixed;
        left: 50%;
        top: 50%;
        z-index: 10001;
        transform: translate(-50%, -50%);
        width: min(280px, calc(100vw - 48px));
        padding: 18px 20px;
        border: 1px solid var(--line);
        border-radius: 16px;
        background: var(--surface-content, var(--panel));
        color: var(--text);
        box-shadow: 0 22px 54px -30px rgba(232,87,42,.55);
        text-align: center;
        font-size: 15px;
        font-weight: 800;
      }
      .app,
      .mobile-bottom-nav {
        pointer-events: none;
        user-select: none;
      }
    }
    html.route-booting body::before {
      content: 'Loading Ask Clash...'; position: fixed; inset: 0; z-index: 9999;
      display: flex; align-items: center; justify-content: center;
      background: var(--bg); color: var(--muted); font-size: 14px; font-weight: 600;
    }
    .pro-chart-modal:not(.open),
    .login-modal-backdrop:not(.open),
    .settings-backdrop:not(.open),
    #feedbackModal:not(.open) {
      content-visibility: auto;
      contain-intrinsic-size: 1px 720px;
    }
    .app { height: 100vh; height: 100dvh; display: flex; overflow: hidden; }

    /* ── TOPBAR (mobile only — hidden on desktop) ── */
    .topbar { display:none; }
    .topbar-brand { display: none; align-items: center; gap: 8px; color: var(--text); font-size: 18px; font-weight: 850; letter-spacing: -.03em; text-decoration: none; }

    /* ── SIDEBAR ── */
    .sidebar {
      width: var(--sidebar-w); flex-shrink: 0; display: flex; flex-direction: column;
      background: var(--panel); border-right: 1px solid var(--line);
      height: 100dvh;
      max-height: 100dvh;
      padding: 0;
      overflow-x: hidden;
      overflow-y: auto;
      scrollbar-width: none;
      transition: transform .25s ease;
    }
    .sidebar::-webkit-scrollbar { display: none; }
    .sidebar-top {
      flex: 0 0 auto;
      padding: 16px 16px 12px;
      border-bottom: 1px solid var(--line);
      overflow: visible;
    }
    .brand { display:flex; align-items:center; gap:10px; }
    .brand h1 { margin:0; font-size:26px; letter-spacing:-.03em; font-weight:600; font-family: inherit; }
    .brand-mark {
      width: 30px;
      height: 30px;
      border-radius: 10px;
      object-fit: cover;
      display: block;
      box-shadow: 0 10px 28px -16px rgba(232,87,42,.85);
      flex: 0 0 auto;
    }
    .sidebar-actions { display: flex; gap: 6px; margin-top: 12px; }
    .new-chat-btn {
      flex: 1; padding: 9px 12px; border-radius: 10px;
      border: 1px solid var(--line); background: var(--panel-2); color: var(--text);
      font-size: 13px; font-weight: 700; cursor: pointer; font-family: inherit;
      transition: background .15s, border-color .15s; text-align: left;
    }
    .new-chat-btn:hover { background: var(--panel); border-color: rgba(255,255,255,.15); }
    .clear-history-btn {
      width: 36px; height: 36px; border-radius: 10px; border: 1px solid var(--line);
      background: var(--panel-2); color: var(--muted); cursor: pointer;
      display: flex; align-items: center; justify-content: center; font-size: 15px;
      transition: background .15s, border-color .15s, color .15s; flex-shrink: 0;
    }
    .clear-history-btn:hover { background: var(--panel); border-color: rgba(255,255,255,.15); color: var(--danger); }
    .recent-list {
      flex: 1 1 auto;
      min-height: 0;
      overflow-y: auto;
      padding: 8px;
      scrollbar-width: thin;
      scrollbar-color: rgba(255,255,255,.18) transparent;
    }
    .recent-list::-webkit-scrollbar { width: 6px; }
    .recent-list::-webkit-scrollbar-thumb { background: rgba(255,255,255,.16); border-radius: 999px; }
    .recent-empty { padding: 20px 8px; text-align: center; font-size: 13px; color: var(--muted); }
    .recent-item {
      position: relative;
      display: grid; grid-template-columns: minmax(0, 1fr) 28px; align-items: center; gap: 6px;
      width: 100%; min-height: 34px; text-align: left; padding: 5px 4px 5px 10px; border-radius: 8px;
      border: 1px solid transparent; background: transparent; color: var(--text); font-size: 13px; cursor: pointer;
      font-family: inherit; transition: background .15s, border-color .15s, color .15s; margin: 0 0 2px;
    }
    .recent-item:hover { background: var(--panel-2); border-color: var(--line); }
    .recent-item.active { background: rgba(232,87,42,.12); color: var(--accent); border-color: rgba(232,87,42,.22); font-weight: 650; }
    .recent-text { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; pointer-events: none; }
    .recent-item.pinned .recent-text::before { content: 'Pinned · '; color: var(--muted); font-weight: 600; }
    .recent-more {
      width: 100%; margin-top: 6px; padding: 8px 10px; border-radius: 8px;
      border: 1px solid var(--line); background: var(--panel-2); color: var(--muted);
      font-family: inherit; font-size: 12px; font-weight: 700; cursor: pointer; text-align: center;
    }
    .recent-more:hover { color: var(--text); background: var(--panel); }
    .recent-menu-btn {
      width: 28px; height: 26px; border: 0; border-radius: 7px; background: transparent; color: var(--muted);
      display: inline-flex; align-items: center; justify-content: center; cursor: pointer; font-size: 17px; line-height: 1;
    }
    .recent-menu-btn:hover, .recent-menu-btn.open { background: rgba(255,255,255,.08); color: var(--text); }
    .recent-menu {
      position: fixed; z-index: 1200; min-width: 144px; padding: 6px;
      border: 1px solid var(--line); border-radius: 10px; background: var(--panel);
      box-shadow: 0 16px 40px rgba(0,0,0,.38);
    }
    .recent-menu button {
      width: 100%; border: 0; border-radius: 7px; background: transparent; color: var(--text);
      padding: 8px 9px; text-align: left; font-family: inherit; font-size: 13px; cursor: pointer;
    }
    .recent-menu button:hover { background: var(--panel-2); }
    .recent-menu button.danger { color: var(--danger); }
    /* Sidebar nav — Discovery, Answers, Portfolio, Predictions, Notifications */
    .sidebar-nav { display: flex; flex-direction: column; gap: 2px; padding: 8px 0; }
    .sidebar-nav-item { display: flex; align-items: center; gap: 12px; padding: 10px 16px; background: none; border: none; color: var(--text); font-size: 14px; font-weight: 500; cursor: pointer; font-family: inherit; text-align: left; border-radius: 8px; margin: 0 8px; transition: all .15s; }
    .sidebar-nav-item:hover { background: var(--panel-2); color: var(--text); }
    .sidebar-nav-item.active { background: rgba(232,87,42,.12); color: var(--accent); font-weight: 750; }
    .sidebar-nav-label { flex: 1; min-width: 0; }
    .sidebar-expander {
      margin-left: auto; width: 22px; height: 20px; border: 1px solid var(--line);
      border-radius: 7px; display: inline-flex; align-items: center; justify-content: center;
      flex: 0 0 22px; color: var(--muted); background: rgba(255,255,255,.04);
      font-size: 16px; font-weight: 850; line-height: 18px;
      transition: transform .16s ease, color .16s ease, background .16s ease, border-color .16s ease;
    }
    .sidebar-nav-group:hover .sidebar-expander { color: var(--text); background: rgba(255,255,255,.08); }
    .sidebar-nav-group.open .sidebar-expander {
      transform: rotate(180deg); color: var(--accent); border-color: rgba(232,87,42,.4);
      background: rgba(232,87,42,.12);
    }
    .george-only-nav { display: none; }
    .app-icon { display: inline-flex; width: 18px; height: 18px; align-items: center; justify-content: center; color: currentColor; flex: 0 0 auto; }
    .app-icon svg { width: 100%; height: 100%; display: block; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
    .sni { width: 22px; text-align: center; display: inline-flex; align-items: center; justify-content: center; color: currentColor; }
    .sidebar-section { padding: 14px 16px 10px; margin: 6px 8px 2px; border-top: 1px solid var(--line); }
    .sidebar-subtopics { padding: 0 6px 6px 42px; margin-top: -2px; display: none; flex-direction: column; gap: 1px; }
    .sidebar-subtopics.open { display: flex; }
    .sidebar-section-title { color: var(--muted); font-size: 10.5px; font-weight: 850; text-transform: uppercase; letter-spacing: .1em; margin-bottom: 8px; }
    .sidebar-topic { display: flex; align-items: center; gap: 10px; width: 100%; padding: 6px 8px; background: none; border: 0; color: var(--text); font: inherit; font-size: 12.8px; text-align: left; border-radius: 7px; cursor: pointer; transition: background .15s, color .15s; }
    .sidebar-topic:hover { background: var(--panel-2); }
    .sidebar-topic.active { background: rgba(232,87,42,.14); color: var(--accent); font-weight: 750; }
    .sidebar-topic.active .sidebar-topic-icon { opacity: 1; }
    .sidebar-topic-icon { width: 20px; text-align: center; opacity: .9; display: inline-flex; align-items: center; justify-content: center; color: currentColor; }
    .sidebar-topic-label { flex: 1; }
    .sidebar-coming-soon { margin-left: auto; color: var(--accent); font-size: 10px; font-weight: 750; letter-spacing: .04em; text-transform: uppercase; opacity: .85; }
    .mobile-bottom-nav { display: none; }
    .mobile-bottom-nav .app-icon { width: 20px; height: 20px; }
    .mobile-bottom-link {
      appearance: none; border: 0; background: transparent; color: var(--muted);
      min-width: 0; padding: 7px 5px 6px; border-radius: 12px;
      display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 3px;
      font: inherit; font-size: 10px; font-weight: 760; cursor: pointer; transition: color .15s, background .15s, transform .12s;
    }
      .mobile-bottom-link:active { transform: translateY(1px); }
      .mobile-bottom-link.active { color: var(--accent); background: rgba(232,87,42,.12); }
      .mobile-bottom-link.mobile-bottom-ask { color: var(--text); font-weight: 900; }
      .mobile-bottom-link.mobile-bottom-ask.active { color: #fff; background: linear-gradient(135deg, var(--accent), #ffb347); }
      .mobile-bottom-link .app-icon svg { stroke-width: 2; }
    :where(a, button, input, textarea, select, summary, [tabindex]):focus-visible {
      outline: 2px solid color-mix(in srgb, var(--accent) 82%, white);
      outline-offset: 3px;
    }

    @media (prefers-reduced-motion: reduce) {
      *,
      *::before,
      *::after {
        animation-duration: .001ms !important;
        animation-iteration-count: 1 !important;
        scroll-behavior: auto !important;
        transition-duration: .001ms !important;
      }
    }
    .sidebar-tip { padding: 12px 14px; margin: 8px 12px 0; background: linear-gradient(145deg, rgba(232,87,42,.1), rgba(255,255,255,.02)); border: 1px solid rgba(232,87,42,.2); border-radius: 12px; }
    .sidebar-tip-label { font-size: 10.5px; font-weight: 850; color: var(--accent); text-transform: uppercase; letter-spacing: .09em; margin-bottom: 5px; }
    .sidebar-tip-text { font-size: 12.5px; line-height: 1.45; color: var(--muted); }
    .sidebar-divider { height: 1px; background: var(--line); margin: 4px 16px 8px; }
    .sidebar-history-label { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--muted); opacity: .5; padding: 0 24px 4px; }
    .notif-page {
      position: fixed; inset: 0; z-index: 50; background: var(--bg);
      overflow-y: auto; overflow-x: hidden; -webkit-overflow-scrolling: touch; color: var(--text);
    }
    .notif-topbar {
      display: flex; align-items: center; justify-content: space-between; gap: 12px;
      padding: 14px 20px; border-bottom: 1px solid var(--line);
      position: sticky; top: 0; background: rgba(5,6,7,.94); z-index: 2;
      backdrop-filter: blur(14px);
    }
    html[data-theme="light"] .notif-topbar { background: rgba(250,249,247,.94); }
    .notif-top-title { display: flex; align-items: center; gap: 9px; color: var(--text); font-size: 18px; font-weight: 900; letter-spacing: -.01em; }
    .notif-top-title .app-icon { width: 18px; height: 18px; color: var(--accent); }
    .notif-back-btn {
      display: inline-flex; align-items: center; gap: 6px; border: 1px solid var(--line);
      border-radius: 8px; background: var(--hover); color: var(--text);
      padding: 7px 13px; font: inherit; font-size: 12px; font-weight: 850; cursor: pointer;
    }
    .notif-content { width: min(960px, calc(100vw - 32px)); margin: 0 auto; padding: 22px 0 64px; }
    .notif-loading, .notif-error, .notif-filter-empty {
      border: 1px solid var(--line); border-radius: 12px; background: var(--hover);
      color: var(--muted); padding: 28px; text-align: center; font-size: 13px;
    }
    .notif-error b { display: block; color: var(--text); font-size: 15px; margin-bottom: 5px; }
    .notif-error span { display: block; }
    .notif-hero {
      display: grid; grid-template-columns: minmax(0, 1fr) minmax(320px, 420px); gap: 14px; align-items: stretch;
      border: 1px solid var(--line); border-radius: 14px; padding: 18px;
      background: radial-gradient(circle at 18% 0%, rgba(232,87,42,.16), transparent 36%), linear-gradient(180deg, #101620, #07090c);
      box-shadow: 0 24px 70px rgba(0,0,0,.38); margin-bottom: 14px;
    }
    html[data-theme="light"] .notif-hero {
      background: radial-gradient(circle at 18% 0%, rgba(232,87,42,.10), transparent 36%), linear-gradient(180deg, var(--panel), var(--panel-2));
      box-shadow: var(--shadow);
    }
    .notif-hero-main span, .notif-section-head span {
      display: block; color: #f0b35a; font-size: 10px; font-weight: 950; letter-spacing: .08em; text-transform: uppercase;
    }
    .notif-hero-main h2 { margin: 5px 0 6px; color: var(--text); font-size: 28px; font-weight: 950; letter-spacing: -.02em; }
    .notif-hero-main p { margin: 0; color: var(--muted); font-size: 13px; line-height: 1.5; max-width: 560px; }
    .notif-summary-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 9px; }
    .notif-summary-card {
      min-width: 0; border: 1px solid var(--line); border-radius: 10px; background: var(--hover); padding: 11px;
    }
    .notif-summary-card.accent { border-color: rgba(232,87,42,.36); background: rgba(232,87,42,.11); }
    .notif-summary-card span { display: block; color: var(--muted); font-size: 10px; font-weight: 900; text-transform: uppercase; letter-spacing: .07em; }
    .notif-summary-card b { display: block; color: var(--text); font-size: 24px; font-weight: 950; line-height: 1.05; margin-top: 5px; }
    .notif-summary-card em { display: block; color: var(--muted); font-size: 11px; font-style: normal; margin-top: 2px; }
    .notif-tabs {
      display: flex; align-items: center; gap: 7px; overflow-x: auto; scrollbar-width: none;
      margin: 0 0 14px; padding: 2px 0 6px;
    }
    .notif-tabs::-webkit-scrollbar { display: none; }
    .notif-tab {
      display: inline-flex; align-items: center; gap: 7px; flex: 0 0 auto;
      border: 1px solid var(--line); border-radius: 999px; background: var(--hover);
      color: var(--muted); min-height: 34px; padding: 0 12px; font: inherit; font-size: 12px; font-weight: 850; cursor: pointer;
    }
    .notif-tab b { color: var(--muted); font-size: 10px; font-weight: 900; }
    .notif-tab.active { background: var(--text); border-color: var(--text); color: var(--bg); }
    .notif-tab.active b { color: color-mix(in srgb, var(--bg) 70%, transparent); }
    .notif-toolbar {
      display: flex; align-items: center; justify-content: space-between; gap: 10px;
      border: 1px solid var(--line); border-radius: 12px; background: var(--panel);
      padding: 11px 12px; margin-bottom: 14px;
    }
    .notif-toolbar-actions { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
    .notif-tool-btn {
      display: inline-flex; align-items: center; gap: 6px;
      border: 1px solid rgba(43,181,138,.28); border-radius: 999px; background: rgba(43,181,138,.11);
      color: #8be7c5; min-height: 34px; padding: 0 12px; font: inherit; font-size: 11.5px; font-weight: 850; cursor: pointer;
    }
    .notif-tool-btn.ghost { border-color: var(--line); background: var(--hover); color: var(--muted); }
    .notif-tool-btn.active { border-color: rgba(232,87,42,.34); background: rgba(232,87,42,.12); color: var(--text); }
    .notif-tool-btn b { color: inherit; font-size: 11px; }
    .notif-section {
      border: 1px solid var(--line); border-radius: 12px; background: var(--panel);
      padding: 13px; margin-bottom: 14px;
    }
    .notif-section[hidden] { display: none !important; }
    .notif-section-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 11px; }
    .notif-section-head b { display: block; color: var(--text); font-size: 16px; font-weight: 900; margin-top: 2px; }
    .notif-section-head em {
      color: var(--accent); border: 1px solid rgba(232,87,42,.26); background: rgba(232,87,42,.10);
      border-radius: 999px; padding: 4px 8px; font-size: 11px; font-style: normal; font-weight: 900;
    }
    .notif-list { display: grid; gap: 8px; }
    .notif-card {
      display: grid; grid-template-columns: 42px minmax(0, 1fr) auto; gap: 11px; align-items: center;
      border: 1px solid var(--line); border-radius: 10px; background: var(--hover);
      padding: 12px; cursor: default;
    }
    .notif-card[onclick] { cursor: pointer; }
    .notif-card.unread { border-left: 3px solid var(--accent); background: rgba(232,87,42,.055); }
    .notif-card.trigger { border-color: rgba(43,181,138,.18); background: rgba(43,181,138,.045); }
    .notif-icon {
      display: flex; align-items: center; justify-content: center; width: 38px; height: 38px; border-radius: 9px;
      background: var(--hover); color: var(--text); font-size: 10px; font-weight: 950; letter-spacing: .04em;
    }
    .notif-icon.markets { background: rgba(232,87,42,.14); color: #ffb08b; }
    .notif-icon.alerts { background: rgba(43,181,138,.13); color: #8be7c5; }
    .notif-icon.sports { background: rgba(74,144,217,.14); color: #9cc9ff; }
    .notif-card-main { min-width: 0; }
    .notif-card-meta { display: flex; align-items: center; gap: 7px; color: var(--muted); font-size: 11px; font-weight: 760; margin-bottom: 4px; }
    .notif-card-meta i { display: inline-block; width: 7px; height: 7px; border-radius: 50%; background: var(--accent); margin-left: auto; }
    .notif-card-meta span i { display: inline-block; width: 6px; height: 6px; border-radius: 50%; margin: 0 5px 1px 0; vertical-align: middle; }
    .notif-urgency {
      color: #f0b35a !important; border: 1px solid rgba(240,179,90,.22); background: rgba(240,179,90,.10);
      border-radius: 999px; padding: 2px 7px; font-size: 9px; font-weight: 950; letter-spacing: .06em; text-transform: uppercase;
    }
    .notif-card-title { color: var(--text); font-size: 13.5px; font-weight: 850; line-height: 1.32; overflow-wrap: anywhere; }
    .notif-card-title span, .notif-card-copy { color: var(--muted); font-weight: 650; }
    .notif-card-copy { font-size: 12px; line-height: 1.42; margin-top: 4px; }
    .notif-actions { display: flex; align-items: center; gap: 6px; }
    .notif-actions button, .notif-empty-card button, .notif-signin-demo button {
      border: 1px solid rgba(43,181,138,.34); border-radius: 8px; background: rgba(43,181,138,.12);
      color: #8be7c5; padding: 7px 10px; font: inherit; font-size: 11px; font-weight: 900; cursor: pointer; white-space: nowrap;
    }
    .notif-actions button.ghost { border-color: var(--line); background: var(--hover); color: var(--muted); }
    .notif-actions button.danger { border-color: rgba(239,83,80,.25); background: rgba(239,83,80,.09); color: #ff8e8c; }
    .notif-email-toggle { display: inline-flex; align-items: center; gap: 7px; color: var(--muted); font-size: 10.5px; font-weight: 850; margin-top: 8px; cursor: pointer; }
    .notif-email-toggle input { position: absolute; opacity: 0; pointer-events: none; }
    .notif-email-toggle span { position: relative; display: inline-block; width: 28px; height: 16px; border-radius: 999px; background: var(--panel-2); }
    .notif-email-toggle span::after { content: ''; position: absolute; top: 2px; left: 2px; width: 12px; height: 12px; border-radius: 50%; background: #fff; transition: left .15s; }
    .notif-email-toggle input:checked + span { background: var(--accent); }
    .notif-email-toggle input:checked + span::after { left: 14px; }
    .notif-empty-card {
      border: 1px dashed var(--line); border-radius: 10px; background: var(--hover);
      padding: 18px; display: grid; gap: 6px; justify-items: start;
    }
    .notif-empty-card b { color: var(--text); font-size: 14px; }
    .notif-empty-card span { color: var(--muted); font-size: 12px; line-height: 1.45; }
    .notif-action-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 9px; }
    .notif-action-grid button {
      text-align: left; border: 1px solid var(--line); border-radius: 10px; background: var(--hover);
      color: var(--text); padding: 12px; font: inherit; cursor: pointer; min-width: 0;
    }
    .notif-action-grid b { display: block; color: var(--text); font-size: 13px; font-weight: 900; margin-bottom: 4px; }
    .notif-action-grid span { display: block; color: var(--muted); font-size: 11.5px; line-height: 1.35; }
    .notif-settings {
      border: 1px solid var(--line); border-radius: 12px; background: var(--panel);
      padding: 13px; margin-bottom: 14px;
    }
    .notif-settings-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; }
    .notif-setting-row {
      display: flex; align-items: center; justify-content: space-between; gap: 10px;
      border: 1px solid var(--line); border-radius: 10px; background: var(--hover);
      padding: 12px;
    }
    .notif-setting-row b { display: block; color: var(--text); font-size: 13px; font-weight: 900; }
    .notif-setting-row span { display: block; color: var(--muted); font-size: 11.5px; line-height: 1.35; margin-top: 3px; }
    .notif-toggle { position: relative; flex: 0 0 auto; }
    .notif-toggle input {
      appearance: none; -webkit-appearance: none;
      width: 38px; height: 22px; border-radius: 999px;
      border: 1px solid var(--line); background: var(--panel-2); cursor: pointer; outline: none;
      transition: background .15s ease, border-color .15s ease;
    }
    .notif-toggle i {
      position: absolute; top: 4px; left: 4px; width: 14px; height: 14px; border-radius: 50%;
      background: #fff; pointer-events: none; transition: transform .15s ease;
    }
    .notif-toggle input:checked { background: var(--accent); border-color: var(--accent); }
    .notif-toggle input:checked + i { transform: translateX(16px); }
    .notif-toggle input:disabled { opacity: .55; cursor: not-allowed; }
    .notif-signin-demo {
      display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 6px 12px; align-items: center;
      border: 1px solid rgba(232,87,42,.22); border-radius: 10px; background: rgba(232,87,42,.08);
      padding: 12px; margin-top: 10px;
    }
    .notif-signin-demo b { color: var(--text); font-size: 13px; }
    .notif-signin-demo span { color: var(--muted); font-size: 12px; line-height: 1.4; }
    .notif-signin-demo button { grid-row: 1 / span 2; grid-column: 2; border-color: rgba(232,87,42,.45); background: rgba(232,87,42,.18); color: var(--text); }
    @media (max-width: 700px) {
      .notif-page { z-index: 140; }
      .notif-topbar { padding: 12px 14px; }
      .notif-content { width: auto; margin: 0 12px; padding: 16px 0 calc(90px + env(safe-area-inset-bottom, 0px)); }
      .notif-hero { grid-template-columns: 1fr; padding: 14px; }
      .notif-hero-main h2 { font-size: 24px; }
      .notif-summary-grid { grid-template-columns: 1fr; }
      .notif-tabs { margin-left: -2px; margin-right: -2px; }
      .notif-tab { min-height: 32px; padding: 0 10px; font-size: 11px; }
      .notif-toolbar { padding: 10px; }
      .notif-toolbar-actions { width: 100%; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); }
      .notif-tool-btn { width: 100%; justify-content: center; min-height: 36px; padding: 0 10px; white-space: nowrap; }
      .notif-section { padding: 11px; }
      .notif-card { grid-template-columns: 34px minmax(0, 1fr); gap: 9px; align-items: start; }
      .notif-icon { width: 32px; height: 32px; border-radius: 8px; }
      .notif-card-title { font-size: 13px; }
      .notif-actions { grid-column: 2; justify-content: flex-start; flex-wrap: wrap; }
      .notif-action-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
      .notif-settings-grid { grid-template-columns: 1fr; }
      .notif-setting-row { align-items: flex-start; }
      .notif-signin-demo { grid-template-columns: 1fr; }
      .notif-signin-demo button { grid-column: auto; grid-row: auto; width: max-content; }
    }
    /* Sidebar bottom — holds theme + menu buttons */
    .sidebar-bottom {
      flex-shrink: 0;
      position: sticky;
      bottom: 0;
      z-index: 4;
      margin-top: auto;
      padding: 12px 16px;
      border-top: 1px solid var(--line);
      background: var(--panel);
      box-shadow: 0 -12px 24px rgba(0,0,0,.18);
    }
    .sidebar-bottom > button:not(.auth-btn):not(.auth-logout) {
      background: var(--panel-2); border: 1px solid var(--line); border-radius: 10px;
      color: var(--text); font-size: 16px; width: 36px; height: 36px; cursor: pointer;
      display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: border-color .2s;
    }
    .sidebar-bottom > button:not(.auth-btn):not(.auth-logout):hover { border-color: var(--accent); }
    /* Google auth */
    .auth-btn {
      display: flex; align-items: center; gap: 8px; width: 100%;
      padding: 8px 12px; border-radius: 10px; border: 1px solid var(--line);
      background: var(--panel-2); color: var(--text); font-size: 13px;
      font-weight: 500; cursor: pointer; font-family: inherit;
      transition: border-color .15s, background .15s;
    }
    .auth-btn:hover { border-color: var(--accent); background: var(--hover); }
    .auth-btn img { width: 16px; height: 16px; }
    .auth-btn-apple { background: #000; color: #fff; border-color: #333; }
    .auth-btn-apple:hover { background: #222; border-color: var(--accent); }
    html[data-theme="light"] .auth-btn-apple { background: #000; color: #fff; border-color: #000; }
    html[data-theme="light"] .auth-btn-apple:hover { background: #333; }
    .auth-user {
      display: flex; align-items: center; gap: 8px; width: 100%;
      padding: 4px 0; font-size: 13px; color: var(--muted);
    }
    .auth-user img { width: 28px; height: 28px; border-radius: 50%; flex-shrink: 0; }
    .auth-user-info { flex: 1; min-width: 0; }
    .auth-user-name { font-weight: 500; color: var(--text); font-size: 13px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .auth-user-email { font-size: 11px; color: var(--muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .auth-logout { background: none; border: none; color: var(--muted); font-size: 11px; cursor: pointer; padding: 2px 6px; border-radius: 4px; }
    .auth-logout:hover { color: var(--danger); }
    .auth-mobile { display: none; }

    /* ── LOGIN MODAL ── */
    .login-modal-backdrop {
      display: none; position: fixed; inset: 0; z-index: 900;
      background: rgba(0,0,0,.6); backdrop-filter: blur(4px);
      align-items: center; justify-content: center;
      pointer-events: none;
    }
    .login-modal-backdrop.open { display: flex; pointer-events: auto; }
    .login-modal {
      background: var(--panel); border-radius: 20px; padding: 40px 36px 32px;
      width: 380px; max-width: 90vw; box-shadow: 0 20px 60px rgba(0,0,0,.4);
      text-align: center; position: relative;
    }
    .login-modal-close {
      position: absolute; top: 14px; right: 14px; background: none; border: none;
      color: var(--muted); font-size: 20px; cursor: pointer; padding: 4px 8px; border-radius: 6px;
    }
    .login-modal-close:hover { color: var(--text); background: var(--hover); }
    .login-modal-logo { width: 48px; height: 48px; margin: 0 auto 16px; border-radius: 12px; }
    .login-modal h2 { font-size: 22px; font-weight: 600; color: var(--text); margin: 0 0 6px; }
    .login-modal p { font-size: 14px; color: var(--muted); margin: 0 0 28px; line-height: 1.5; }
    .login-modal .auth-btn {
      width: 100%; justify-content: center; padding: 12px 16px; font-size: 15px;
      border-radius: 12px; margin-bottom: 10px;
    }
    .login-modal .auth-btn:last-child { margin-bottom: 0; }
    .login-modal-footer { margin-top: 20px; font-size: 12px; color: var(--muted); line-height: 1.5; }
    .login-modal-footer a { color: var(--accent); text-decoration: none; }

    /* ── USER MENU (sidebar bottom) ── */
    .user-menu-trigger {
      display: flex; align-items: center; gap: 10px; width: 100%;
      padding: 10px 12px; border-radius: 10px; border: none; background: transparent;
      color: var(--text); font-size: 14px; font-weight: 500; cursor: pointer;
      font-family: inherit; transition: background .12s;
    }
    .user-menu-trigger:hover { background: var(--hover); }
    .user-menu-trigger img { width: 32px; height: 32px; border-radius: 50%; flex-shrink: 0; }
    .user-menu-trigger .user-initials {
      width: 32px; height: 32px; border-radius: 50%; flex-shrink: 0;
      background: var(--accent); color: #fff; display: flex; align-items: center;
      justify-content: center; font-size: 14px; font-weight: 600;
    }
    .user-menu-trigger .user-menu-name { flex: 1; text-align: left; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .user-menu-trigger .user-menu-chevron { color: var(--muted); font-size: 12px; transition: transform .2s; }
    .user-menu-trigger.open .user-menu-chevron { transform: rotate(180deg); }
    .user-menu-popover {
      display: none; flex-direction: column; gap: 2px; padding: 6px;
      background: var(--panel); border: 1px solid var(--line); border-radius: 12px;
      box-shadow: 0 8px 30px rgba(0,0,0,.25);
      position: absolute; left: 8px; right: 8px; bottom: calc(100% - 4px);
      max-height: calc(100vh - 120px); overflow-y: auto; z-index: 50;
    }
    .user-menu-popover.open { display: flex; }
    .user-menu-item {
      display: flex; align-items: center; gap: 10px; padding: 10px 12px;
      border-radius: 8px; border: none; background: none; color: var(--text);
      font-size: 14px; cursor: pointer; font-family: inherit; transition: background .1s;
      text-align: left; width: 100%; text-decoration: none;
    }
    .user-menu-item:hover { background: var(--hover); }
    .user-menu-item .umi { width: 18px; text-align: center; font-size: 15px; flex-shrink: 0; }
    .user-menu-divider { height: 1px; background: var(--line); margin: 4px 8px; }
    .user-menu-item.danger { color: var(--danger); }
    .user-menu-item.danger:hover { background: rgba(224,92,92,.1); }
    .user-menu-theme { padding: 8px 8px 10px; }
    .user-menu-theme-title { color: var(--muted); font-size: 11px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; margin: 0 4px 8px; }
    .user-menu-theme-options { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 6px; }
    .user-menu-theme-options button {
      min-height: 32px;
      border-radius: 8px;
      border: 1px solid var(--line);
      background: var(--panel-2);
      color: var(--muted);
      font: inherit;
      font-size: 12px;
      font-weight: 700;
      cursor: pointer;
    }
    .user-menu-theme-options button:hover { border-color: var(--accent); color: var(--text); }
    .user-menu-theme-options button.active { background: rgba(232,87,42,.14); border-color: rgba(232,87,42,.48); color: var(--text); }

    /* ── SETTINGS MODAL ── */
    .settings-backdrop {
      display: none; position: fixed; inset: 0; z-index: 910;
      background: rgba(0,0,0,.6); backdrop-filter: blur(4px);
      align-items: center; justify-content: center;
      pointer-events: none;
    }
    .settings-backdrop.open { display: flex; pointer-events: auto; }
    .settings-modal {
      background: var(--panel); border-radius: 16px; width: 600px; max-width: 92vw;
      max-height: 80vh; display: flex; flex-direction: column; box-shadow: 0 20px 60px rgba(0,0,0,.4);
      overflow: hidden;
    }
    .settings-header {
      display: flex; align-items: center; justify-content: space-between;
      padding: 20px 24px 0; flex-shrink: 0;
    }
    .settings-header h2 { font-size: 18px; font-weight: 600; color: var(--text); margin: 0; }
    .settings-close {
      background: none; border: none; color: var(--muted); font-size: 20px;
      cursor: pointer; padding: 4px 8px; border-radius: 6px;
    }
    .settings-close:hover { color: var(--text); background: var(--hover); }
    .settings-tabs {
      display: flex; gap: 0; padding: 12px 24px 0; border-bottom: 1px solid var(--line); flex-shrink: 0;
    }
    .settings-tab {
      padding: 10px 16px; border: none; background: none; color: var(--muted);
      font-size: 14px; font-weight: 500; cursor: pointer; font-family: inherit;
      border-bottom: 2px solid transparent; transition: all .15s; margin-bottom: -1px;
    }
    .settings-tab.active { color: var(--text); border-bottom-color: var(--accent); }
    .settings-tab:hover:not(.active) { color: var(--text); }
    .settings-body { flex: 1; overflow-y: auto; padding: 24px; }
    .settings-section { margin-bottom: 24px; }
    .settings-section h3 { font-size: 14px; font-weight: 600; color: var(--text); margin: 0 0 12px; text-transform: uppercase; letter-spacing: .04em; }
    .settings-row {
      display: flex; align-items: center; justify-content: space-between;
      padding: 12px 0; border-bottom: 1px solid var(--line);
    }
    .settings-row:last-child { border-bottom: none; }
    .settings-row-label { font-size: 14px; color: var(--text); }
    .settings-row-desc { font-size: 12px; color: var(--muted); margin-top: 2px; }
    .settings-row-value { font-size: 14px; color: var(--muted); }
    @media (max-width: 600px) {
      .settings-modal { max-width: 100vw; max-height: 100dvh; border-radius: 0; height: 100dvh; width: 100vw; padding-top: env(safe-area-inset-top, 0); }
      .settings-header { padding-top: max(16px, env(safe-area-inset-top, 16px)); }
      .settings-tabs { overflow-x: auto; scrollbar-width: none; }
      .settings-tabs::-webkit-scrollbar { display: none; }
      .settings-tab { font-size: 12px; padding: 8px 10px; white-space: nowrap; flex-shrink: 0; }
      .settings-body { padding: 16px; }
      .settings-row { flex-direction: column; align-items: flex-start; gap: 8px; }
    }

    /* ── PREDICTIONS PAGE ── */
    .predictions-page {
      display: none; flex: 1; flex-direction: column; overflow-y: auto;
      -webkit-overflow-scrolling: touch; touch-action: pan-y; background: var(--bg);
      scrollbar-width: thin; min-height: 0; width: 100%;
    }
    .predictions-page.visible { display: flex; }

    .pm-header {
      position: sticky; top: 0; z-index: 20; background: var(--bg);
      padding: 24px 32px 16px; border-bottom: 1px solid var(--line);
    }
    .pm-header-top { display: flex; align-items: center; justify-content: space-between; gap: 16px; }
    .pm-header-title { font-size: 24px; font-weight: 800; color: var(--text); display: flex; align-items: center; gap: 10px; }
    .pm-back-btn {
      display: flex; align-items: center; gap: 4px;
      padding: 6px 14px; border-radius: 8px; border: 1px solid var(--line);
      background: var(--panel); color: var(--text); cursor: pointer;
      font-size: 12px; font-weight: 600; font-family: inherit;
      transition: background .15s, color .15s, border-color .15s;
    }
    .pm-back-btn:hover { background: var(--hover); border-color: rgba(255,255,255,.18); }

    .pm-filters {
      display: flex; align-items: center; justify-content: space-between; gap: 12px;
      margin-top: 14px; flex-wrap: wrap;
    }
    .pm-category-pills {
      display: flex; gap: 6px; overflow-x: auto; scrollbar-width: none;
      -webkit-overflow-scrolling: touch; padding-bottom: 2px;
    }
    .pm-category-pills::-webkit-scrollbar { display: none; }
    .pm-cat-pill {
      padding: 6px 14px; border-radius: 20px; border: 1px solid var(--line);
      background: var(--panel-2); color: var(--muted); cursor: pointer;
      font-size: 12px; font-weight: 700; font-family: inherit;
      white-space: nowrap; transition: all .15s;
    }
    .pm-cat-pill:hover { border-color: var(--accent); color: var(--text); }
    .pm-cat-pill.active { background: var(--accent); color: #fff; border-color: var(--accent); }

    .pm-sort-wrap { position: relative; }
    .pm-sort-btn {
      padding: 6px 14px; border-radius: 10px; border: 1px solid var(--line);
      background: var(--panel-2); color: var(--muted); cursor: pointer;
      font-size: 12px; font-weight: 600; font-family: inherit;
      display: flex; align-items: center; gap: 6px; transition: all .15s;
    }
    .pm-sort-btn:hover { border-color: var(--accent); color: var(--text); }
    .pm-sort-dropdown {
      display: none; position: absolute; right: 0; top: 100%; margin-top: 4px;
      background: var(--panel); border: 1px solid var(--line); border-radius: 10px;
      box-shadow: 0 12px 40px rgba(0,0,0,.4); z-index: 30; min-width: 160px;
      overflow: hidden;
    }
    .pm-sort-dropdown.open { display: block; }
    .pm-sort-option {
      padding: 10px 16px; font-size: 13px; color: var(--text); cursor: pointer;
      transition: background .1s; font-family: inherit; border: none;
      background: transparent; width: 100%; text-align: left; display: block;
    }
    .pm-sort-option:hover { background: var(--hover); }
    .pm-sort-option.active { color: var(--accent); font-weight: 700; }

    /* Events grid — ClashPicks layout */
    .pm-markets {
      padding: 20px 32px 32px;
      overflow-x: hidden;
    }
    .pm-search-panel {
      display: grid; grid-template-columns: minmax(220px, .78fr) minmax(280px, 1.15fr);
      gap: 12px; align-items: center;
      background: color-mix(in srgb, var(--panel) 90%, var(--accent) 4%);
      border: 1px solid var(--line); border-radius: 0.625rem; padding: 14px 16px;
      margin-bottom: 12px;
    }
    .pm-search-title { color: var(--text); font-size: 16px; font-weight: 850; letter-spacing: -.01em; }
    .pm-search-sub { color: var(--muted); font-size: 12px; line-height: 1.4; margin-top: 3px; }
    .pm-search-box { display: flex; gap: 8px; min-width: 0; width: 100%; }
    .pm-search-box input {
      flex: 1; min-width: 0; border: 1px solid var(--line); border-radius: 999px;
      background: var(--bg); color: var(--text); padding: 11px 14px; font: inherit;
      font-size: 14px; outline: none;
    }
    .pm-search-box input:focus { border-color: rgba(232,87,42,.55); }
    .pm-search-box button {
      border: 0; border-radius: 999px; background: var(--accent); color: #fff;
      padding: 0 18px; font: inherit; font-size: 13px; font-weight: 850; cursor: pointer;
      flex: 0 0 auto;
    }
    .pm-search-chips { grid-column: 2; display: flex; gap: 6px; overflow-x: auto; scrollbar-width: none; }
    .pm-search-chips::-webkit-scrollbar { display: none; }
    .pm-search-chips button {
      border: 1px solid var(--line); border-radius: 999px; background: var(--panel-2);
      color: var(--muted); padding: 6px 10px; font: inherit; font-size: 11px;
      font-weight: 800; cursor: pointer; white-space: nowrap;
    }
    .pm-search-chips button:hover { color: var(--text); border-color: rgba(232,87,42,.4); }
    .pm-record-card {
      display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap;
      gap: 10px 22px;
      background: var(--panel); border: 1px solid var(--line); border-radius: 0.625rem;
      padding: 11px 16px; margin-bottom: 12px;
    }
    .pm-record-main span, .pm-record-kpis span {
      display: block; color: var(--muted); font-size: 9px; font-weight: 850;
      letter-spacing: .07em; text-transform: uppercase; margin-bottom: 3px;
    }
    .pm-record-main { flex: 0 0 auto; }
    .pm-record-main strong { color: var(--text); font-size: 24px; font-weight: 900; letter-spacing: -.02em; margin-right: 8px; }
    .pm-record-main b { font-size: 16px; font-weight: 900; }
    .pm-record-main em { display: inline-block; color: var(--muted); font-size: 10px; font-style: normal; font-weight: 850; text-transform: uppercase; letter-spacing: .06em; margin-left: 4px; }
    .pm-record-kpis { display: flex; align-items: flex-start; justify-content: flex-end; gap: 22px; flex: 1 1 auto; min-width: 360px; }
    .pm-record-kpis strong { color: var(--text); font-size: 14px; font-weight: 850; }
    .pm-record-kpis > div { min-width: max-content; }
    .pm-record-kpis > div:last-child strong { display: flex; gap: 5px; white-space: nowrap; }
    .pm-record-details { flex: 0 0 100%; color: var(--muted); font-size: 11px; }
    .pm-record-details summary { cursor: pointer; font-weight: 800; }
    .pm-record-details > div { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 8px; }
    .pm-record-details small { display: block; margin-top: 8px; color: var(--muted); font-size: 11px; }
    .pm-top-picks {
      margin: 0 0 16px; border: 1px solid var(--line); border-radius: 12px;
      background: linear-gradient(180deg, color-mix(in srgb, var(--panel) 92%, var(--accent) 4%), var(--panel));
      padding: 13px;
    }
    .pm-top-picks[hidden] { display: none; }
    .pm-top-picks-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
    .pm-top-picks-head span { display: block; color: var(--accent); font-size: 10px; font-weight: 950; letter-spacing: .08em; text-transform: uppercase; margin-bottom: 2px; }
    .pm-top-picks-head b { color: var(--text); font-size: 15px; font-weight: 900; }
    .pm-top-picks-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; }
    .pm-top-pick-card { border: 1px solid var(--line); border-radius: 10px; background: rgba(255,255,255,.035); padding: 11px; min-width: 0; }
    .pm-top-pick-kicker { display: flex; align-items: center; justify-content: space-between; gap: 8px; color: var(--muted); font-size: 10px; font-weight: 900; text-transform: uppercase; letter-spacing: .06em; }
    .pm-top-pick-kicker em { color: #f0b35a; font-style: normal; }
    .pm-top-pick-title { color: var(--text); font-size: 13px; font-weight: 850; line-height: 1.3; margin: 7px 0; min-height: 34px; }
    .pm-top-pick-meta { display: flex; flex-wrap: wrap; gap: 6px; color: var(--muted); font-size: 11px; }
    .pm-top-pick-lean { margin-top: 9px; display: grid; gap: 2px; }
    .pm-top-pick-lean span { color: var(--muted); font-size: 10px; font-weight: 850; text-transform: uppercase; letter-spacing: .06em; }
    .pm-top-pick-lean b { color: #00bb7f; font-size: 14px; font-weight: 900; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    .pm-top-pick-actions { display: grid; grid-template-columns: 1fr auto; gap: 7px; margin-top: 10px; }
    .pm-top-pick-actions button {
      border: 0; border-radius: 8px; background: #00bb7f; color: #fff;
      padding: 8px 10px; font: inherit; font-size: 12px; font-weight: 850; cursor: pointer;
    }
    .pm-top-pick-actions button.ghost { background: var(--panel-2); color: var(--text); border: 1px solid var(--line); }
    .pm-events-grid {
      display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 16px;
      list-style: none; margin: 0; padding: 0;
      align-items: stretch;
      min-width: 0;
    }
    .pm-events-grid > li { display: flex; min-width: 0; }
    @media (max-width: 1200px) { .pm-events-grid { grid-template-columns: repeat(3, 1fr); } }
    @media (max-width: 900px) { .pm-events-grid { grid-template-columns: repeat(2, 1fr); } }
    @media (max-width: 600px) { .pm-events-grid { grid-template-columns: 1fr; } }

    .pm-loading {
      text-align: center; color: var(--muted); font-size: 14px; padding: 64px 0;
    }
    .pm-empty {
      text-align: center; color: var(--muted); font-size: 15px; padding: 64px 24px;
    }

    /* Event card — 3-section layout */
    .pm-event-link {
      display: flex; flex-direction: column; justify-content: space-between;
      text-decoration: none; color: inherit;
      background: var(--panel); border: 1px solid var(--line);
      border-radius: 0.625rem; padding: 16px;
      transition: border-color .15s, box-shadow .15s, transform .12s;
      height: 100%; min-height: 214px; box-sizing: border-box;
      overflow: hidden; width: 100%; gap: 0;
    }
    .pm-event-link:hover {
      border-color: rgba(255,255,255,.18);
      box-shadow: 0 6px 24px rgba(0,0,0,.35);
      transform: translateY(-1px);
    }

    /* Section 1: Top — logo + title + outcomes */
    .pm-event-top { flex: 1; display: flex; flex-direction: column; }
    .pm-event-header { display: flex; align-items: center; gap: 12px; margin-bottom: 10px; }
    .pm-event-icon {
      flex-shrink: 0; width: 48px; height: 48px; border-radius: 8px;
      overflow: hidden;
    }
    .pm-event-icon img {
      width: 100%; height: 100%; object-fit: cover; border-radius: 8px;
    }
    .pm-event-icon-fallback {
      width: 100%; height: 100%; display: flex; align-items: center;
      justify-content: center; font-size: 20px; border-radius: 8px;
    }
    .pm-event-title {
      font-size: 14px; font-weight: 600; color: var(--text); line-height: 1.35;
      margin: 0; min-height: 38px; display: flex; align-items: center;
    }

    /* Outcome rows */
    .pm-outcomes { display: flex; flex-direction: column; gap: 4px; margin-bottom: 10px; }
    .pm-outcomes-label { color: var(--muted); font-size: 9px; font-weight: 900; letter-spacing: .08em; text-transform: uppercase; margin-bottom: 1px; }
    .pm-thin-market-badge { color: #f0b35a; background: rgba(240,179,90,.10); border: 1px solid rgba(240,179,90,.22); border-radius: 999px; padding: 3px 7px; font-size: 10px; font-weight: 850; width: max-content; margin-bottom: 2px; }
    .pm-outcome-row { display: flex; align-items: center; gap: 8px; }
    .pm-outcome-label {
      font-size: 13px; color: var(--muted); overflow: hidden;
      text-overflow: ellipsis; white-space: nowrap; flex: 1; min-width: 0;
    }
    .pm-outcome-pct { font-size: 12px; color: var(--muted); font-weight: 750; font-variant-numeric: tabular-nums; }

    /* AI Predict button */
    .pm-ai-predict {
      display: flex; align-items: center; justify-content: center; gap: 8px;
      width: 100%; padding: 10px 16px; border-radius: 10px; border: none;
      background: linear-gradient(135deg, #00bb7f, #00a06b);
      color: #fff; font-size: 14px; font-weight: 700; font-family: inherit;
      cursor: pointer; transition: transform .12s, box-shadow .15s;
      letter-spacing: .01em;
    }
    .pm-ai-predict:hover { transform: translateY(-1px); box-shadow: 0 4px 16px rgba(0,187,127,.35); }
    .pm-ai-predict:active { transform: scale(.98); }
    .pm-ai-predict svg { flex-shrink: 0; }

    /* Section 2: Volume line */
    .pm-event-volume {
      padding: 8px 0; font-size: 11px; display: flex; align-items: center;
      gap: 6px; font-variant-numeric: tabular-nums; white-space: nowrap;
    }
    .pm-vol-label { color: var(--muted); font-weight: 500; }
    .pm-vol-accent { color: #f97316; font-weight: 500; }
    .pm-vol-green { background: linear-gradient(to right, #9945FF, #14F195); -webkit-background-clip: text; -webkit-text-fill-color: transparent; font-weight: 500; }
    .pm-vol-sep { color: rgba(255,255,255,.15); }

    /* Section 3: Bottom — closing + follow */
    .pm-event-bottom {
      padding-top: 8px; border-top: 1px solid var(--line);
      display: flex; align-items: center; justify-content: space-between;
      gap: 8px; font-size: 11px; color: var(--muted); white-space: nowrap;
    }
    .pm-event-bottom > span {
      min-width: 0; overflow: hidden; text-overflow: ellipsis;
    }
    .pm-follow-btn {
      background: var(--panel-2); border: 1px solid var(--line); color: var(--text); cursor: pointer;
      padding: 5px 12px; transition: all .15s; display: flex; align-items: center;
      gap: 5px; font-size: 12px; font-weight: 700; font-family: inherit;
      border-radius: 8px; white-space: nowrap; flex: 0 0 auto;
    }
    .pm-follow-btn:hover { border-color: #00bb7f; color: #00bb7f; background: rgba(0,187,127,.06); }
    .pm-follow-btn.following { color: #00bb7f; border-color: #00bb7f; background: rgba(0,187,127,.08); }

    /* Follow popup */
    .pm-follow-popup {
      position: fixed; z-index: 1000; background: var(--panel); border: 1px solid var(--line);
      border-radius: 14px; box-shadow: 0 16px 48px rgba(0,0,0,.5); padding: 20px;
      width: 280px; animation: pm-popup-in .2s ease;
    }
    @keyframes pm-popup-in { from { opacity: 0; transform: scale(.95); } to { opacity: 1; transform: none; } }
    .pm-follow-popup-backdrop {
      position: fixed; inset: 0; z-index: 999; background: rgba(0,0,0,.4);
    }
    .pm-follow-popup h4 { font-size: 15px; font-weight: 700; color: var(--text); margin: 0 0 4px; }
    .pm-follow-popup .pm-fp-sub { font-size: 12px; color: var(--muted); margin-bottom: 14px; line-height: 1.4; }
    .pm-follow-popup .pm-fp-team {
      display: flex; align-items: center; justify-content: space-between;
      padding: 10px 12px; background: var(--panel-2); border: 1px solid var(--line);
      border-radius: 10px; margin-bottom: 8px; cursor: pointer; transition: border-color .15s;
    }
    .pm-follow-popup .pm-fp-team:hover { border-color: rgba(0,187,127,.3); }
    .pm-follow-popup .pm-fp-team.selected { border-color: #00bb7f; background: rgba(0,187,127,.06); }
    .pm-follow-popup .pm-fp-team-name { font-size: 14px; font-weight: 600; color: var(--text); }
    .pm-follow-popup .pm-fp-check {
      width: 20px; height: 20px; border-radius: 6px; border: 2px solid var(--line);
      display: flex; align-items: center; justify-content: center; transition: all .15s;
    }
    .pm-follow-popup .pm-fp-team.selected .pm-fp-check {
      background: #00bb7f; border-color: #00bb7f;
    }
    .pm-follow-popup .pm-fp-save {
      width: 100%; padding: 10px; border-radius: 10px; border: none;
      background: #00bb7f; color: #fff; font-size: 14px; font-weight: 700;
      font-family: inherit; cursor: pointer; margin-top: 6px; transition: opacity .15s;
    }
    .pm-follow-popup .pm-fp-save:hover { opacity: .9; }
    .pm-follow-popup .pm-fp-save:disabled { opacity: .4; cursor: default; }

    /* Prediction modal */
    .pm-predict-modal-backdrop {
      position: fixed; inset: 0; z-index: 1000; background: rgba(0,0,0,.55);
      display: flex; align-items: center; justify-content: center;
    }
    .pm-predict-modal {
      position: fixed; z-index: 1001; background: var(--bg); border: 1px solid var(--line);
      border-radius: 16px; box-shadow: 0 20px 60px rgba(0,0,0,.6);
      width: min(420px, calc(100vw - 32px)); max-height: calc(100vh - 60px);
      overflow: hidden; display: flex; flex-direction: column;
      top: 50%; left: 50%; transform: translate(-50%, -50%);
      animation: pm-modal-in .25s ease;
    }
    @keyframes pm-modal-in { from { opacity: 0; transform: translate(-50%, -50%) scale(.93); } to { opacity: 1; transform: translate(-50%, -50%) scale(1); } }
    .pm-pm-header {
      display: flex; align-items: center; justify-content: space-between; gap: 12px;
      padding: 16px 20px; border-bottom: 1px solid var(--line);
    }
    .pm-pm-header h3 { font-size: 15px; font-weight: 700; color: var(--text); margin: 0; line-height: 1.3; }
    .pm-pm-close {
      background: none; border: none; color: var(--muted); font-size: 22px; cursor: pointer;
      padding: 0; line-height: 1; flex-shrink: 0;
    }
    .pm-pm-close:hover { color: var(--text); }
    .pm-pm-body { padding: 16px 20px; overflow-y: auto; flex: 1; }
    .pm-pm-loading { text-align: center; padding: 40px 0; }
    .pm-pm-spinner {
      width: 36px; height: 36px; border: 3px solid var(--line); border-top-color: #00bb7f;
      border-radius: 50%; animation: pm-spin .7s linear infinite; margin: 0 auto;
    }
    @keyframes pm-spin { to { transform: rotate(360deg); } }
    .pm-pm-verdict {
      border: 1px solid; border-radius: 12px; padding: 14px 16px; margin-bottom: 14px;
    }
    .pm-pm-pick-row { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; }
    .pm-pm-pick { font-size: 18px; font-weight: 800; color: var(--text); }
    .pm-pm-tier {
      padding: 4px 12px; border-radius: 6px; font-size: 12px; font-weight: 800;
      border: 1px solid; letter-spacing: .03em;
    }
    .pm-pm-conf { font-size: 14px; color: var(--muted); margin-bottom: 8px; }
    .pm-pm-verdict-text { font-size: 14px; color: var(--text); line-height: 1.55; }
    .pm-pm-signals { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 4px; }
    .pm-pm-signal {
      background: rgba(74,159,212,.08); border: 1px solid rgba(74,159,212,.25);
      border-radius: 8px; padding: 8px 10px;
    }
    .pm-pm-signal-label { font-size: 9px; font-weight: 800; text-transform: uppercase; letter-spacing: .08em; color: #4a9fd4; margin-bottom: 3px; }
    .pm-pm-signal-val { font-size: 13px; font-weight: 700; color: var(--text); }
    .pm-pm-footer {
      padding: 12px 20px 16px; border-top: 1px solid var(--line);
    }
    .pm-pm-footer-actions { display: grid; grid-template-columns: 1fr auto; gap: 8px; }
    .pm-pm-full {
      width: 100%; padding: 10px; border-radius: 10px; border: 1px solid var(--line);
      background: var(--panel-2); color: var(--text); font-size: 14px; font-weight: 600;
      font-family: inherit; cursor: pointer; transition: background .15s;
    }
    .pm-pm-full.ghost { width: auto; white-space: nowrap; color: #00bb7f; border-color: rgba(0,187,127,.34); }
    .pm-pm-full:hover { background: var(--hover); }

    .pm-urgency-inline {
      font-size: 10px; font-weight: 700; padding: 2px 7px; border-radius: 8px;
      text-transform: uppercase; letter-spacing: .02em;
    }
    .pm-urgency-inline.closing-soon { background: rgba(239,83,80,.12); color: #ef5350; }
    .pm-urgency-inline.closing-now { background: rgba(255,23,68,.15); color: #ff1744; animation: pm-pulse .8s ease-in-out infinite; }
    @keyframes pm-pulse { 0%,100% { opacity: 1; } 50% { opacity: .6; } }

    /* Game-soon alerts */
    .pm-game-alerts { padding: 0 32px; }
    .pm-game-alerts:empty { display: none; }
    .pm-alert-card {
      display: flex; align-items: center; gap: 14px; padding: 14px 18px;
      background: linear-gradient(135deg, rgba(0,187,127,.08), rgba(0,187,127,.03));
      border: 1px solid rgba(0,187,127,.2); border-radius: 0.625rem;
      margin-bottom: 10px; animation: pm-alert-in .3s ease;
    }
    @keyframes pm-alert-in { from { opacity: 0; transform: translateY(-6px); } to { opacity: 1; transform: none; } }
    .pm-alert-icon { font-size: 20px; flex-shrink: 0; }
    .pm-alert-body { flex: 1; min-width: 0; }
    .pm-alert-title { font-size: 14px; font-weight: 700; color: var(--text); margin-bottom: 2px; }
    .pm-alert-sub { font-size: 12px; color: var(--muted); }
    .pm-alert-action {
      padding: 6px 14px; border-radius: 8px; border: 1px solid rgba(0,187,127,.3);
      background: rgba(0,187,127,.12); color: #00bb7f; cursor: pointer;
      font-size: 12px; font-weight: 700; font-family: inherit;
      white-space: nowrap; transition: background .15s;
    }
    .pm-alert-action:hover { background: rgba(0,187,127,.25); }
    @media (max-width: 600px) {
      .pm-game-alerts { padding: 0 12px; }
      .pm-alert-card { padding: 10px 12px; gap: 10px; }
    }

	    /* Tools page */
	    #toolsPage {
	      --tools-bg: #050607;
	      --tools-panel: #090c10;
	      --tools-panel-2: #0d1117;
	      --tools-panel-3: #111722;
	      --tools-line: rgba(255,255,255,.125);
	      background: var(--tools-bg);
	      color: var(--text);
	    }

	    #toolsContent {
	      max-width: 1240px;
	      margin: 0 auto;
	      padding: 30px 34px 56px;
	      box-sizing: border-box;
	    }

	    #toolsPage .disc-header {
	      background: var(--tools-bg);
	      border-bottom-color: var(--tools-line);
	    }

	    #toolsPage .disc-title {
	      color: var(--text);
	      letter-spacing: 0;
	    }

	    #toolsPage .disc-sub {
	      color: color-mix(in srgb, var(--muted) 88%, var(--text) 12%);
	    }

	    #toolsPage .disc-pill,
	    #toolsPage .tools-tabs .disc-pill {
	      border-color: var(--tools-line);
	      background: var(--tools-panel-3);
	      color: var(--muted);
	    }

	    #toolsPage .disc-pill.active,
	    #toolsPage .tools-tabs .disc-pill.active {
	      background: var(--text);
	      border-color: var(--text);
	      color: var(--bg);
	    }

	    #toolsPage .tools-tabs {
	      margin: 8px 0 18px;
	      padding: 4px;
	      border: 0;
	      border-radius: 0;
	      background: transparent;
	      position: sticky;
	      top: 0;
	      z-index: 12;
	    }

	    .tools-strip {
	      display: grid; grid-template-columns: repeat(6, 1fr);
	      gap: 10px; margin-bottom: 18px;
	    }
	    .tools-tabs { margin-top: 2px; }
	    .tools-panel { display: none; }
	    .tools-panel.active { display: block; }

    .ai-charts-page {
      background: var(--bg);
      color: var(--text);
    }
    @media (min-width: 641px) {
      .ai-charts-page.visible {
        overflow-y: hidden;
      }
      .ai-charts-page .disc-header {
        padding: 12px 32px 8px;
      }
      .ai-charts-page .disc-title {
        font-size: 20px;
        line-height: 1.05;
      }
      .ai-charts-page .disc-sub {
        font-size: 12.5px;
        line-height: 1.3;
        margin-top: 2px;
      }
    }
    .ai-charts-page .disc-header-top {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 14px;
      margin-bottom: 0;
    }
    .ai-charts-page .disc-header-right {
      display: flex;
      align-items: center;
      gap: 10px;
      flex-shrink: 0;
    }
    .ai-charts-shell {
      max-width: 1120px;
      margin: 0 auto;
      padding: 8px 24px 18px;
      box-sizing: border-box;
      display: grid;
      grid-template-columns: minmax(320px, .52fr) minmax(0, 1fr);
      column-gap: 10px;
      row-gap: 4px;
      align-items: center;
    }
    .ai-charts-search {
      display: grid;
      grid-template-columns: minmax(0, 1fr) auto;
      gap: 10px;
      align-items: center;
      margin-bottom: 0;
      position: relative;
      z-index: 6;
    }
    .ai-charts-autocomplete {
      position: relative;
      min-width: 0;
    }
    .ai-charts-search input {
      width: 100%;
      min-width: 0;
      height: 44px;
      border: 1px solid var(--line);
      border-radius: 8px;
      background: var(--panel);
      color: var(--text);
      padding: 0 14px;
      font: inherit;
      font-size: 15px;
      outline: none;
      box-sizing: border-box;
    }
    .ai-charts-search input:focus {
      border-color: color-mix(in srgb, var(--accent) 70%, var(--line) 30%);
      box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 18%, transparent);
    }
    .ai-charts-suggestions {
      position: absolute;
      top: calc(100% - 1px);
      left: 0;
      right: 0;
      max-height: 226px;
      overflow-y: auto;
      border: 1px solid var(--ai-charts-suggest-border, color-mix(in srgb, var(--accent) 38%, var(--line) 62%));
      border-top-color: var(--ai-charts-suggest-border-top, var(--line));
      border-radius: 0 0 8px 8px;
      background: var(--ai-charts-suggest-bg, var(--panel));
      color: var(--ai-charts-suggest-text, var(--text));
      box-shadow: 0 16px 34px rgba(0,0,0,.34);
      padding: 4px;
      box-sizing: border-box;
      color-scheme: var(--ai-charts-suggest-scheme, dark);
    }
    .ai-charts-suggestions[hidden] {
      display: none;
    }
    .ai-charts-suggestion {
      width: 100%;
      min-height: 36px;
      border: 0;
      border-radius: 6px;
      background: transparent;
      color: var(--ai-charts-suggest-text, var(--text));
      display: grid;
      grid-template-columns: 64px minmax(0, 1fr);
      gap: 8px;
      align-items: center;
      padding: 7px 9px;
      text-align: left;
      cursor: pointer;
      font: inherit;
    }
    .ai-charts-suggestion:hover,
    .ai-charts-suggestion.is-active {
      background: var(--ai-charts-suggest-hover, var(--hover));
    }
    .ai-charts-suggestion-symbol {
      font-size: 12px;
      font-weight: 850;
      color: var(--ai-charts-suggest-strong, #fff);
    }
    .ai-charts-suggestion-name {
      min-width: 0;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
      color: var(--ai-charts-suggest-muted, var(--muted));
      font-size: 12px;
      font-weight: 650;
    }
    .ai-charts-suggestions.is-dark {
      --ai-charts-suggest-bg: #1d2027;
      --ai-charts-suggest-text: #eef2f7;
      --ai-charts-suggest-strong: #eef2f7;
      --ai-charts-suggest-muted: #9aa6b7;
      --ai-charts-suggest-border: rgba(215,226,245,.10);
      --ai-charts-suggest-border-top: rgba(215,226,245,.10);
      --ai-charts-suggest-hover: rgba(215,226,245,.10);
      --ai-charts-suggest-scheme: dark;
    }
    .ai-charts-suggestions.is-light {
      --ai-charts-suggest-bg: #ffffff;
      --ai-charts-suggest-text: #1a1a1a;
      --ai-charts-suggest-strong: #1a1a1a;
      --ai-charts-suggest-muted: #6b6b6b;
      --ai-charts-suggest-border: rgba(0,0,0,.08);
      --ai-charts-suggest-border-top: rgba(0,0,0,.08);
      --ai-charts-suggest-hover: rgba(0,0,0,.05);
      --ai-charts-suggest-scheme: light;
      box-shadow: 0 14px 30px rgba(15,23,42,.16);
    }
    .ai-charts-search button,
    .ai-charts-quick button {
      border: 1px solid var(--line);
      border-radius: 8px;
      background: var(--text);
      color: var(--bg);
      font: inherit;
      font-size: 13px;
      font-weight: 750;
      cursor: pointer;
      white-space: nowrap;
    }
    .ai-charts-search button {
      height: 44px;
      padding: 0 18px;
    }
    .ai-charts-quick {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-bottom: 0;
      justify-content: flex-end;
    }
    .ai-charts-quick button {
      background: var(--panel-2);
      color: var(--text);
      padding: 7px 11px;
    }
    .ai-charts-status {
      grid-column: 1 / -1;
      min-height: 16px;
      color: var(--muted);
      font-size: 13px;
      font-weight: 650;
      margin: 0;
    }
    .ai-charts-result {
      grid-column: 1 / -1;
    }
    .ai-charts-result .message {
      margin: 0;
    }
    .ai-charts-result .bubble {
      width: 100%;
      box-sizing: border-box;
    }
    .ai-chart-message {
      width: 100%;
      margin: 0;
    }
    .ai-chart-workspace {
      border: 1px solid var(--line);
      background: var(--panel);
      border-radius: 8px;
      padding: 12px;
      box-sizing: border-box;
      overflow: hidden;
    }
    .ai-chart-toolbar {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 14px;
      margin-bottom: 12px;
    }
    .ai-chart-asset-meta {
      display: flex;
      align-items: baseline;
      gap: 10px;
      min-width: 0;
      flex-wrap: wrap;
    }
    .ai-chart-asset-name {
      color: var(--text);
      font-size: 18px;
      font-weight: 850;
      line-height: 1.1;
    }
    .ai-chart-price,
    .ai-chart-change {
      font-size: 13px;
      font-weight: 750;
    }
    .ai-chart-window {
      color: var(--muted);
      font-size: 10px;
      font-weight: 750;
      text-transform: uppercase;
    }
    .ai-chart-toolbar-actions {
      display: flex;
      align-items: center;
      justify-content: flex-end;
      gap: 5px;
      flex-wrap: wrap;
      min-width: 0;
    }
    .ai-chart-split {
      display: grid;
      grid-template-columns: minmax(0, 7fr) minmax(260px, 3fr);
      gap: 12px;
      align-items: start;
    }
    .ai-chart-main-card,
    .ai-chart-preview-rail {
      border: 1px solid var(--line);
      background: var(--panel-2);
      border-radius: 8px;
      min-width: 0;
      box-sizing: border-box;
    }
    .ai-chart-main-card {
      padding: 10px;
    }
    .ai-chart-main-card .ai-chart-read-compact {
      margin: 0 0 10px;
      overflow: visible;
      scrollbar-width: thin;
      scrollbar-color: rgba(238,242,247,.24) rgba(0,0,0,.12);
    }
    .ai-chart-main-card .ai-chart-read-compact::-webkit-scrollbar,
    .ai-chart-preview-rail::-webkit-scrollbar {
      width: 8px;
    }
    .ai-chart-main-card .ai-chart-read-compact::-webkit-scrollbar-track,
    .ai-chart-preview-rail::-webkit-scrollbar-track {
      background: rgba(0,0,0,.12);
      border-radius: 999px;
    }
    .ai-chart-main-card .ai-chart-read-compact::-webkit-scrollbar-thumb,
    .ai-chart-preview-rail::-webkit-scrollbar-thumb {
      background: rgba(238,242,247,.24);
      border-radius: 999px;
      border: 2px solid transparent;
      background-clip: padding-box;
    }
    html[data-theme="light"] .ai-chart-main-card .ai-chart-read-compact,
    html[data-theme="light"] .ai-chart-preview-rail {
      scrollbar-color: rgba(26,26,26,.24) rgba(0,0,0,.06);
    }
    html[data-theme="light"] .ai-chart-main-card .ai-chart-read-compact::-webkit-scrollbar-track,
    html[data-theme="light"] .ai-chart-preview-rail::-webkit-scrollbar-track {
      background: rgba(0,0,0,.06);
    }
    html[data-theme="light"] .ai-chart-main-card .ai-chart-read-compact::-webkit-scrollbar-thumb,
    html[data-theme="light"] .ai-chart-preview-rail::-webkit-scrollbar-thumb {
      background: rgba(26,26,26,.24);
      border: 2px solid transparent;
      background-clip: padding-box;
    }
    .ai-chart-main-card .ai-chart-read-compact > div {
      margin-bottom: 0 !important;
      padding: 9px 10px !important;
      background: color-mix(in srgb, var(--panel) 82%, transparent) !important;
      border-color: var(--line) !important;
    }
    .ai-chart-main-card .ai-chart-score-strip {
      margin-bottom: 8px !important;
    }
    .ai-chart-main-card .ai-chart-score-pills {
      display: grid !important;
      grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
      gap: 6px !important;
    }
    .ai-chart-main-card .ai-chart-score-pill {
      min-width: 0 !important;
      padding: 8px 6px !important;
      border-radius: 6px !important;
    }
    .ai-chart-main-card .ai-chart-score-pill [style*="font-size:11px"] {
      font-size: 10px !important;
      line-height: 1.12 !important;
      margin-bottom: 2px !important;
    }
    .ai-chart-main-card .ai-chart-score-pill [style*="font-size:22px"] {
      font-size: 21px !important;
    }
    .ai-chart-main-card .ai-chart-score-pill [style*="margin-top:2px"] {
      margin-top: 2px !important;
      white-space: nowrap !important;
      overflow: hidden !important;
      text-overflow: ellipsis !important;
    }
    .ai-chart-main-card .ai-chart-read-lines {
      grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
      gap: 5px 14px !important;
    }
    .ai-chart-main-card .ai-chart-read-lines > div {
      min-width: 0 !important;
    }
    .ai-chart-main-card .ai-chart-read-lines span {
      font-size: 12px !important;
      line-height: 1.32 !important;
    }
    .ai-chart-hero-head {
      display: flex;
      align-items: flex-start;
      justify-content: space-between;
      gap: 12px;
      margin-bottom: 10px;
    }
    .ai-chart-hero-title {
      color: var(--text);
      font-size: 15px;
      font-weight: 850;
      line-height: 1.2;
    }
    .ai-chart-hero-caption {
      color: var(--muted);
      font-size: 12px;
      line-height: 1.4;
      margin-top: 3px;
    }
    .ai-chart-hero-graphic {
      border: 1px solid rgba(255,255,255,.08);
      background: #070809;
      border-radius: 8px;
      padding: 5px;
      cursor: pointer;
      overflow: hidden;
    }
    .ai-chart-hero-graphic svg,
    .ai-chart-thumb-svg svg {
      display: block;
      width: 100%;
      height: auto;
    }
    @media (min-width: 641px) {
      .ai-chart-hero-graphic svg {
        height: clamp(240px, 30vh, 315px);
        object-fit: contain;
      }
    }
    .ai-chart-preview-rail {
      padding: 9px;
      display: flex;
      flex-direction: column;
      gap: 7px;
      max-height: min(76vh, 780px);
      overflow-y: auto;
      scrollbar-width: thin;
      scrollbar-color: rgba(238,242,247,.24) rgba(0,0,0,.12);
    }
    .ai-chart-rail-title {
      color: var(--muted);
      font-size: 11px;
      font-weight: 850;
      text-transform: uppercase;
      letter-spacing: .04em;
      padding: 2px 2px 4px;
    }
    .ai-chart-preview-btn {
      display: grid;
      grid-template-columns: minmax(0, 1fr) 104px;
      gap: 8px;
      align-items: stretch;
      width: 100%;
      border: 1px solid rgba(255,255,255,.09);
      background: color-mix(in srgb, var(--panel) 84%, transparent);
      color: var(--text);
      border-radius: 8px;
      padding: 7px;
      cursor: pointer;
      text-align: left;
      font: inherit;
      transition: border-color .15s, background .15s;
    }
    .ai-chart-preview-btn:hover,
    .ai-chart-preview-btn.active {
      border-color: color-mix(in srgb, var(--accent) 62%, var(--line) 38%);
      background: color-mix(in srgb, var(--accent) 10%, var(--panel) 90%);
    }
    .ai-chart-preview-copy {
      display: flex;
      flex-direction: column;
      gap: 4px;
      min-width: 0;
      justify-content: center;
    }
    .ai-chart-preview-copy strong {
      color: var(--text);
      font-size: 12px;
      font-weight: 850;
      line-height: 1.15;
    }
    .ai-chart-preview-copy small {
      color: var(--muted);
      font-size: 10.5px;
      line-height: 1.25;
      display: -webkit-box;
      -webkit-line-clamp: 2;
      -webkit-box-orient: vertical;
      overflow: hidden;
    }
    .ai-chart-preview-open {
      display: inline-flex;
      align-items: center;
      width: max-content;
      margin-top: 2px;
      color: var(--accent);
      font-size: 10px;
      font-weight: 850;
      text-transform: uppercase;
      letter-spacing: .04em;
    }
    .ai-chart-thumb-svg {
      align-self: stretch;
      min-height: 62px;
      border: 1px solid rgba(255,255,255,.06);
      background: #070809;
      border-radius: 6px;
      overflow: hidden;
      display: flex;
      align-items: center;
      cursor: zoom-in;
    }
    .ai-chart-thumb-svg.loading {
      justify-content: center;
    }
    .ai-chart-thumb-placeholder {
      color: var(--muted);
      font-size: 10px;
      font-weight: 800;
      text-transform: uppercase;
      letter-spacing: .04em;
      opacity: .7;
    }
    .ai-chart-read {
      margin-top: 12px;
    }
    .ai-chart-read > div {
      margin-bottom: 0 !important;
    }
    @media (max-width: 640px) {
      .ai-charts-page .disc-header {
        padding: 9px 12px 6px !important;
      }
      .ai-charts-page .disc-header-top {
        gap: 8px !important;
      }
      .ai-charts-page .disc-title {
        font-size: 22px !important;
        line-height: 1.05 !important;
        margin: 0 !important;
      }
      .ai-charts-page .disc-sub {
        display: none !important;
      }
      .ai-charts-shell {
        padding: 6px 8px calc(var(--mobile-bottom-nav-h, 64px) + 18px);
        grid-template-columns: 1fr;
        row-gap: 6px;
      }
      .ai-charts-search {
        grid-template-columns: minmax(0, 1fr) auto;
        gap: 6px;
      }
      .ai-charts-search input {
        height: 38px;
        font-size: 13px;
        padding: 0 10px;
      }
      .ai-charts-search button {
        height: 38px;
        width: auto;
        padding: 0 12px;
      }
      .ai-charts-quick {
        gap: 5px;
        justify-content: flex-start;
      }
      .ai-charts-quick button {
        padding: 5px 8px;
        font-size: 11px;
        border-radius: 7px;
      }
      .ai-charts-status {
        min-height: 14px;
        font-size: 11px;
        margin-bottom: 1px;
      }
      .ai-chart-workspace {
        padding: 8px;
      }
      .ai-chart-toolbar {
        align-items: flex-start;
        flex-direction: column;
        gap: 8px;
        margin-bottom: 8px;
      }
      .ai-chart-toolbar-actions {
        justify-content: flex-start;
      }
      .ai-chart-toolbar-actions button,
      .ai-chart-toolbar-actions .pro-chart-btn {
        padding: 3px 7px !important;
        font-size: 9.5px !important;
      }
      .ai-chart-split {
        grid-template-columns: 1fr;
        gap: 8px;
      }
      .ai-chart-main-card {
        padding: 8px;
      }
      .ai-chart-main-card .ai-chart-score-pills {
        grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
      }
      .ai-chart-main-card .ai-chart-read-lines span {
        font-size: 10.5px !important;
      }
      .ai-chart-preview-rail {
        max-height: none;
        overflow: visible;
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 6px;
        padding: 8px;
      }
      .ai-chart-rail-title {
        grid-column: 1 / -1;
        padding-bottom: 0;
      }
      .ai-chart-preview-btn {
        grid-template-columns: 1fr;
        gap: 5px;
        padding: 6px;
      }
      .ai-chart-preview-copy small,
      .ai-chart-preview-open {
        display: none;
      }
      .ai-chart-thumb-svg {
        min-height: 54px;
      }
    }

	    .tools-etf-head {
      display: flex; align-items: flex-start; justify-content: space-between;
      gap: 16px; margin-bottom: 12px;
    }
    .tools-etf-controls {
      display: flex; align-items: center; justify-content: space-between;
      gap: 12px; margin-bottom: 14px;
    }
    .tools-etf-assets {
      display: flex; gap: 6px; flex-shrink: 0;
      background: var(--panel); border: 1px solid var(--line);
      border-radius: 9px; padding: 4px; min-width: 0;
    }
    #toolsEtfAssets {
      flex: 1 1 auto; flex-wrap: wrap;
    }
    .tools-etf-asset {
      border: 0; border-radius: 7px; padding: 7px 12px;
      background: transparent; color: var(--muted);
      font: inherit; font-size: 12px; font-weight: 800; cursor: pointer; min-width: 0;
    }
    .tools-etf-asset.active { background: rgba(232,87,42,.18); color: var(--accent); }
    .tools-etf-ranges {
      display: flex; gap: 6px; overflow-x: auto; scrollbar-width: none;
      padding-bottom: 2px; justify-content: flex-end;
    }
    .tools-etf-ranges::-webkit-scrollbar { display: none; }
    .tools-etf-range {
      border: 1px solid var(--line); border-radius: 999px; padding: 6px 12px;
      background: var(--panel); color: var(--muted);
      font: inherit; font-size: 11px; font-weight: 850; cursor: pointer;
      white-space: nowrap; flex-shrink: 0;
    }
    .tools-etf-range.active { background: var(--accent); border-color: var(--accent); color: #fff; }
    .tools-etf-wrap { display: grid; gap: 14px; min-width: 0; }
    .tools-etf-loading {
      background: var(--panel); border: 1px solid var(--line);
      border-radius: 10px; padding: 24px; color: var(--muted); font-size: 13px;
    }
    .tools-etf-summary {
      display: grid; grid-template-columns: 1.35fr repeat(3, minmax(0, 1fr));
      gap: 10px;
    }
    .tools-etf-summary-card {
      background: var(--panel); border: 1px solid var(--line);
      border-radius: 10px; padding: 14px; min-width: 0;
    }
    .tools-etf-summary-card.primary { background: var(--panel-2); }
    .tools-etf-label {
      font-size: 10.5px; color: var(--muted); text-transform: uppercase;
      letter-spacing: .08em; font-weight: 850; margin-bottom: 5px;
    }
    .tools-etf-value {
      color: var(--text); font-size: 20px; font-weight: 850; letter-spacing: -.03em;
      white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    }
    .tools-etf-value.pos { color: #00bb7f; }
    .tools-etf-value.neg { color: #ef5350; }
    .tools-etf-sub { color: var(--muted); font-size: 11px; margin-top: 4px; line-height: 1.35; }
    .tools-etf-meta {
      display: flex; flex-wrap: wrap; gap: 8px; align-items: center;
      color: var(--muted); font-size: 11px; font-weight: 700;
    }
    .tools-etf-meta span {
      background: var(--panel); border: 1px solid var(--line);
      border-radius: 999px; padding: 5px 9px;
    }
    .tools-etf-note {
      background: rgba(240,179,90,.08); border: 1px solid rgba(240,179,90,.22);
      border-radius: 10px; padding: 10px 12px; color: #f0b35a;
      font-size: 12px; line-height: 1.45;
    }
    .tools-etf-read-card {
      display: flex; justify-content: space-between; gap: 16px; align-items: center;
      border: 1px solid var(--line); border-radius: 12px; padding: 16px;
    }
    .tools-etf-read-card.accumulation { background: color-mix(in srgb, var(--panel) 88%, #00bb7f 7%); border-color: rgba(0,187,127,.22); }
    .tools-etf-read-card.distribution { background: color-mix(in srgb, var(--panel) 88%, #ef5350 7%); border-color: rgba(239,83,80,.24); }
    .tools-etf-read-card.cooling,
    .tools-etf-read-card.improving { background: color-mix(in srgb, var(--panel) 88%, #f0b35a 7%); border-color: rgba(240,179,90,.24); }
    .tools-etf-read-card.flat { background: var(--panel); }
    .tools-etf-read-title { color: var(--text); font-size: 20px; font-weight: 850; margin-bottom: 3px; }
    .tools-etf-read-stats { display: flex; flex-direction: column; gap: 7px; flex-shrink: 0; }
    .tools-etf-read-stats span {
      background: var(--panel-2); border: 1px solid var(--line);
      border-radius: 999px; padding: 6px 10px; color: var(--muted);
      font-size: 11px; font-weight: 850; white-space: nowrap;
      display: inline-flex; align-items: baseline; gap: 4px;
    }
    .tools-etf-contrib-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; }
    .tools-etf-contrib-card {
      background: var(--panel); border: 1px solid var(--line);
      border-radius: 10px; padding: 13px; min-width: 0;
    }
    .tools-etf-contrib-main { color: var(--text); font-size: 17px; font-weight: 850; margin-bottom: 3px; }
    .tools-etf-num { color: var(--text); font-weight: 850; }
    .tools-etf-num.pos, .tools-etf-tooltip .pos { color: #00bb7f; }
    .tools-etf-num.neg, .tools-etf-tooltip .neg { color: #ef5350; }
    .tools-etf-chart-card, .tools-etf-table-card {
      background: var(--panel); border: 1px solid var(--line);
      border-radius: 12px; padding: 16px; min-width: 0;
    }
    .tools-etf-table-card { overflow: hidden; }
    .tools-etf-chart-top {
      display: flex; justify-content: space-between; gap: 12px; align-items: flex-start;
      margin-bottom: 12px; min-width: 0;
    }
    .tools-etf-chart-top > div { min-width: 0; }
    .tools-etf-chart-actions {
      display: flex; align-items: center; gap: 8px; flex-shrink: 0;
    }
    .tools-etf-share-btn {
      border: 1px solid var(--line); border-radius: 999px; padding: 6px 11px;
      background: var(--panel-2); color: var(--text);
      font: inherit; font-size: 11px; font-weight: 850; cursor: pointer;
      white-space: nowrap;
    }
    .tools-primary-share {
      border-radius: 7px; padding: 8px 12px;
      background: rgba(232,87,42,.18); border-color: rgba(232,87,42,.48);
      color: #fff;
    }
    .tools-etf-share-btn:hover { border-color: rgba(232,87,42,.45); color: var(--accent); }
    .tools-etf-share-btn:disabled { opacity: .62; cursor: wait; }
    .tools-etf-title { color: var(--text); font-size: 16px; font-weight: 760; }
    .tools-etf-copy { color: var(--muted); font-size: 12px; line-height: 1.45; margin-top: 3px; overflow-wrap: anywhere; }
    .tools-etf-legend { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 8px; color: var(--muted); font-size: 11px; }
    .tools-etf-legend span { display: inline-flex; align-items: center; gap: 5px; }
    .tools-etf-legend i { width: 15px; height: 7px; border-radius: 999px; display: inline-block; }
    .tools-etf-legend .bar-pos { background: rgba(0,187,127,.84); }
    .tools-etf-legend .bar-neg { background: rgba(239,83,80,.84); }
    .tools-etf-legend .line { height: 2px; background: #f0b35a; }
    .tools-etf-chart-shell { position: relative; min-width: 0; }
    .tools-etf-chart {
      width: 100%; height: 330px; display: block;
      background: linear-gradient(180deg, rgba(255,255,255,.025), rgba(0,0,0,.08));
      border: 1px solid var(--line); border-radius: 10px;
    }
    .tools-etf-tooltip {
      position: absolute; display: none; gap: 4px; min-width: 166px;
      background: rgba(26,26,26,.94); border: 1px solid var(--line);
      border-radius: 9px; padding: 9px 10px; pointer-events: none;
      box-shadow: 0 10px 28px rgba(0,0,0,.28); z-index: 3;
      color: var(--muted); font-size: 11px;
    }
    .tools-etf-tooltip strong { color: var(--text); font-size: 12px; }
    .tools-etf-tooltip span { display: block; }
    .tools-etf-table-scroll { overflow-x: auto; scrollbar-width: thin; }
    .tools-etf-table {
      width: 100%; border-collapse: collapse; min-width: 860px;
      color: var(--text); font-size: 12px;
    }
    .tools-etf-table th, .tools-etf-table td {
      padding: 9px 10px; border-bottom: 1px solid var(--line); text-align: right;
      white-space: nowrap;
    }
    .tools-etf-table th:first-child, .tools-etf-table td:first-child,
    .tools-etf-table th:nth-child(2), .tools-etf-table td:nth-child(2) { text-align: left; }
    .tools-etf-table th {
      color: var(--muted); font-size: 10.5px; text-transform: uppercase;
      letter-spacing: .07em; font-weight: 850;
    }
    .tools-etf-ticker { font-weight: 850; color: var(--text); }
    .tools-etf-fund { color: var(--muted); max-width: 150px; overflow: hidden; text-overflow: ellipsis; }
    .tools-etf-num.pos { color: #00bb7f; }
    .tools-etf-num.neg { color: #ef5350; }
    .tools-etf-num.zero { color: var(--muted); font-weight: 650; }
    .tools-treasury-wrap { display: grid; gap: 14px; min-width: 0; }
    .tools-treasury-summary {
      display: grid; grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: 10px;
    }
    .tools-treasury-card {
      background: var(--panel); border: 1px solid var(--line);
      border-radius: 12px; padding: 16px; min-width: 0; overflow: hidden;
    }
    .tools-treasury-adapters {
      display: flex; flex-wrap: wrap; gap: 7px;
    }
    .tools-treasury-adapters span {
      display: inline-flex; align-items: center; gap: 5px;
      border: 1px solid var(--line); border-radius: 999px;
      background: rgba(255,255,255,.035); color: var(--muted);
      padding: 6px 9px; font-size: 10.5px; font-weight: 800;
    }
    .tools-treasury-adapters span.live {
      color: #00bb7f; border-color: rgba(0,187,127,.26);
      background: rgba(0,187,127,.08);
    }
    .tools-treasury-adapters b { color: var(--text); }
    .tools-treasury-table th:first-child,
    .tools-treasury-table td:first-child { text-align: left; }
    .tools-treasury-company-row td:first-child {
      display: flex; align-items: center; gap: 10px; min-width: 220px;
    }
    .tools-treasury-toggle {
      width: 26px; height: 26px; flex: 0 0 26px; border-radius: 8px;
      border: 1px solid var(--line); background: rgba(255,255,255,.045);
      color: var(--text); display: inline-flex; align-items: center;
      justify-content: center; cursor: pointer; font-weight: 900;
      font-size: 15px; line-height: 1;
    }
    .tools-treasury-toggle:hover {
      border-color: rgba(232,87,42,.55); color: var(--accent);
      background: rgba(232,87,42,.10);
    }
    .tools-treasury-buy-row td {
      background: color-mix(in srgb, var(--panel-2) 76%, var(--accent) 4%);
      border-top: 0;
    }
    .tools-treasury-buy-panel {
      border: 1px solid var(--line); border-radius: 12px;
      background: rgba(0,0,0,.16); padding: 12px; display: grid; gap: 10px;
    }
    .tools-treasury-buy-title {
      color: var(--text); font-size: 12px; font-weight: 900;
      text-transform: uppercase; letter-spacing: .06em;
    }
    .tools-treasury-buy-list { display: grid; gap: 7px; }
    .tools-treasury-buy-item {
      display: grid; grid-template-columns: minmax(120px, 1.15fr) repeat(3, minmax(92px, .9fr)) minmax(112px, .8fr);
      gap: 10px; align-items: center; padding: 9px 10px; border: 1px solid var(--line);
      border-radius: 10px; background: rgba(255,255,255,.035);
    }
    .tools-treasury-buy-item strong,
    .tools-treasury-buy-item b {
      display: block; color: var(--text); font-size: 12px; font-weight: 900;
      white-space: nowrap;
    }
    .tools-treasury-buy-item span,
    .tools-treasury-buy-muted,
    .tools-treasury-buy-empty {
      display: block; color: var(--muted); font-size: 10.5px; margin-top: 2px;
    }
    .tools-treasury-buy-panel.empty {
      background: rgba(255,255,255,.025);
    }
    @media (max-width: 700px) {
      .tools-treasury-company-row td:first-child {
        min-width: 190px; gap: 8px;
      }
      .tools-treasury-toggle {
        width: 24px; height: 24px; flex-basis: 24px;
      }
      .tools-treasury-buy-panel {
        padding: 10px; min-width: 640px;
      }
      .tools-treasury-buy-item {
        grid-template-columns: 120px 90px 98px 100px 110px;
        gap: 8px; padding: 8px;
      }
    }
    .tools-treasury-btc-cell { min-width: 128px; }
    .tools-treasury-btc-value {
      color: var(--text); font-weight: 850; margin-bottom: 6px;
    }
    .tools-treasury-bar {
      height: 5px; border-radius: 999px; background: rgba(255,255,255,.08);
      overflow: hidden;
    }
    .tools-treasury-bar span {
      display: block; height: 100%; border-radius: inherit;
      background: linear-gradient(90deg, #ff6b2c, #f0b35a);
    }
    .tools-treasury-ticker { color: var(--text); font-weight: 850; }
    .tools-treasury-name { color: var(--muted); font-size: 11px; margin-top: 3px; }
    .tools-treasury-type {
      display: inline-flex; margin-top: 5px; border: 1px solid var(--line);
      border-radius: 999px; padding: 2px 6px; color: var(--muted);
      background: rgba(255,255,255,.04); font-size: 9.5px; font-weight: 850;
      text-transform: uppercase; letter-spacing: .05em;
    }
    .tools-treasury-source {
      color: var(--accent); text-decoration: none; font-weight: 800;
    }
    .tools-treasury-source:hover { text-decoration: underline; }
    .tools-treasury-spark-cell {
      padding: 6px 10px; min-width: 140px;
      text-align: right; vertical-align: middle;
    }
    .tools-treasury-spark {
      width: 130px; height: 34px;
      display: inline-block; vertical-align: middle;
    }
    .tools-treasury-spark-empty {
      color: var(--muted); font-size: 10px; font-weight: 700;
      text-transform: uppercase; letter-spacing: .05em;
    }
    .tools-treasury-private-mark {
      color: var(--accent); font-size: .72em; font-weight: 900;
      margin-left: 2px; vertical-align: super;
    }
    .tools-treasury-footnote {
      margin-top: 10px; padding: 0 4px;
      color: var(--muted); font-size: 11px; font-weight: 600;
    }
    .tools-treasury-footnote sup {
      color: var(--accent); font-weight: 900; margin-right: 4px;
    }
    .tools-treasury-visual-grid {
      display: grid; grid-template-columns: minmax(280px, .82fr) minmax(0, 1.45fr);
      gap: 10px;
    }
    .tools-treasury-donut-layout {
      display: grid; grid-template-columns: minmax(180px, 260px) minmax(0, 1fr);
      gap: 14px; align-items: center;
    }
    .tools-treasury-pie {
      width: 100%; height: 260px; display: block;
    }
    .tools-treasury-legend { display: grid; gap: 8px; min-width: 0; }
    .tools-treasury-legend-row {
      display: flex; align-items: center; justify-content: space-between; gap: 12px;
      color: var(--muted); font-size: 12px; font-weight: 750;
    }
    .tools-treasury-legend-row span {
      display: inline-flex; align-items: center; gap: 7px; min-width: 0;
      overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
    }
    .tools-treasury-legend-row i {
      width: 10px; height: 10px; border-radius: 999px; display: inline-block; flex-shrink: 0;
    }
    .tools-treasury-legend-row b { color: var(--text); font-size: 12px; }
    .tools-treasury-mstr-card { overflow: hidden; }
    .tools-treasury-mstr-stats {
      display: flex; flex-wrap: wrap; gap: 8px; margin: 0 0 10px;
    }
    .tools-treasury-mstr-stats span {
      background: var(--panel-2); border: 1px solid var(--line);
      border-radius: 999px; padding: 6px 10px; color: var(--text);
      font-size: 11px; font-weight: 850; white-space: nowrap;
    }
    .tools-treasury-mstr-stats span.pos { color: #00bb7f; }
    .tools-treasury-mstr-stats span.neg { color: #ef5350; }
    .tools-treasury-mstr-controls {
      display: flex; align-items: center; justify-content: space-between;
      gap: 10px; margin: 0 0 10px; min-width: 0;
    }
    .tools-treasury-segment {
      display: flex; gap: 4px; padding: 4px; border-radius: 999px;
      background: var(--panel-2); border: 1px solid var(--line);
      overflow-x: auto; scrollbar-width: none;
    }
    .tools-treasury-segment::-webkit-scrollbar { display: none; }
    .tools-treasury-segment button {
      border: 0; border-radius: 999px; background: transparent;
      color: var(--muted); font: inherit; font-size: 11px; font-weight: 850;
      padding: 5px 9px; cursor: pointer; white-space: nowrap;
    }
    .tools-treasury-segment button.active {
      background: rgba(232,87,42,.20); color: var(--accent);
    }
    .tools-treasury-buy-filter {
      display: inline-flex; align-items: center; gap: 7px; flex-shrink: 0;
      color: var(--muted); font-size: 11px; font-weight: 850;
    }
    .tools-treasury-buy-filter select {
      border: 1px solid var(--line); border-radius: 999px;
      background: var(--panel-2); color: var(--text);
      font: inherit; font-size: 11px; font-weight: 850; padding: 6px 8px;
    }
    .tools-treasury-mstr-chart {
      width: 100%; height: 340px; display: block;
      box-sizing: border-box;
      background: linear-gradient(180deg, rgba(255,255,255,.025), rgba(0,0,0,.08));
      border: 1px solid var(--line); border-radius: 10px;
    }
    .tools-treasury-mstr-shell { position: relative; min-width: 0; }
    .tools-treasury-mstr-tooltip { z-index: 4; }
    .tools-treasury-secondary-grid {
      grid-template-columns: minmax(0, 1.1fr) minmax(280px, .9fr);
    }
    .tools-treasury-adds-chart {
      width: 100%; height: 260px; display: block;
      box-sizing: border-box;
      background: linear-gradient(180deg, rgba(255,255,255,.025), rgba(0,0,0,.08));
      border: 1px solid var(--line); border-radius: 10px;
    }
    .tools-treasury-update-list {
      display: grid; gap: 7px; margin-top: 2px;
    }
    .tools-treasury-update-row {
      display: flex; align-items: center; justify-content: space-between; gap: 10px;
      padding: 10px 11px; border: 1px solid var(--line); border-radius: 10px;
      background: rgba(255,255,255,.035); text-decoration: none;
    }
    .tools-treasury-update-row span {
      display: grid; gap: 2px; min-width: 0;
    }
    .tools-treasury-update-row b,
    .tools-treasury-update-row strong {
      color: var(--text); font-size: 12px; font-weight: 900;
      font-variant-numeric: tabular-nums;
    }
    .tools-treasury-update-row em {
      color: var(--muted); font-size: 10.5px; font-style: normal; font-weight: 750;
    }
    .tools-treasury-update-row strong.pos { color: #00bb7f; }
    .tools-treasury-update-row strong.neg { color: #ef5350; }
    .tools-stat {
      background: var(--panel); border: 1px solid var(--line);
      border-radius: 10px; padding: 12px 14px; min-width: 0;
    }
    .tools-stat-label {
      font-size: 11px; color: var(--muted); text-transform: uppercase;
      letter-spacing: .04em; margin-bottom: 4px;
    }
    .tools-stat-value {
      font-size: 16px; font-weight: 700; color: var(--text);
      white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    }
    .tools-stat-sub { font-size: 11px; margin-top: 2px; }
    .tools-stat-up { color: #00bb7f; }
    .tools-stat-down { color: #ef5350; }
    .tools-alt-meter {
      background: var(--panel);
      border: 1px solid var(--line); border-radius: 10px;
      padding: 16px; margin-bottom: 18px;
    }
    .tools-alt-top { display: flex; justify-content: space-between; gap: 16px; align-items: flex-start; margin-bottom: 12px; }
    .tools-alt-title { font-size: 15px; font-weight: 700; color: var(--text); margin-bottom: 3px; }
    .tools-alt-sub { font-size: 12px; color: var(--muted); line-height: 1.45; }
    .tools-alt-badge { padding: 7px 10px; border-radius: 999px; font-size: 12px; font-weight: 700; white-space: nowrap; }
    .tools-alt-track { height: 10px; background: rgba(255,255,255,.08); border-radius: 999px; overflow: hidden; margin-bottom: 12px; }
    .tools-alt-fill { height: 100%; border-radius: 999px; background: linear-gradient(90deg, #f0b35a, #00bb7f); }
    .tools-alt-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
    .tools-alt-stat { background: var(--panel-2); border: 1px solid var(--line); border-radius: 8px; padding: 10px 12px; }
    .tools-alt-stat-label { font-size: 12px; color: var(--muted); text-transform: uppercase; letter-spacing: .04em; margin-bottom: 3px; }
    .tools-alt-stat-value { font-size: 15px; font-weight: 700; color: var(--text); }
    .tools-command-center {
      display: grid; grid-template-columns: minmax(0, 1fr) 220px;
      gap: 14px; align-items: stretch; margin: 0 0 18px;
      border: 1px solid rgba(255,255,255,.14); border-radius: 14px;
      background:
        radial-gradient(circle at 16% 0%, rgba(232,87,42,.16), transparent 35%),
        linear-gradient(180deg, #101620, #07090c);
      box-shadow: 0 24px 60px rgba(0,0,0,.36);
      padding: 18px; overflow: hidden;
    }
    .tools-command-kicker,
    .tools-card-action-row .tools-intel-kicker {
      font-size: 10.5px; color: #f0b35a; text-transform: uppercase;
      letter-spacing: .08em; font-weight: 950;
    }
    .tools-command-title { color: #fff; font-size: 26px; font-weight: 950; letter-spacing: 0; margin: 4px 0 6px; }
    .tools-command-copy { color: rgba(255,255,255,.72); font-size: 13px; line-height: 1.45; max-width: 760px; }
    .tools-command-drivers {
      display: grid; grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 8px; margin-top: 14px;
    }
    .tools-command-driver {
      border: 1px solid rgba(255,255,255,.12); border-radius: 10px;
      background: rgba(255,255,255,.04); padding: 10px; min-width: 0;
    }
    .tools-command-driver span {
      display: block; color: rgba(255,255,255,.48); font-size: 10px;
      text-transform: uppercase; letter-spacing: .07em; font-weight: 900; margin-bottom: 4px;
    }
    .tools-command-driver b { display: block; color: #fff; font-size: 13px; font-weight: 900; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    .tools-command-side {
      display: grid; align-content: center; justify-items: stretch; gap: 8px;
      border-left: 1px solid rgba(255,255,255,.12); padding-left: 16px;
    }
    .tools-command-score { color: #00bb7f; font-size: 42px; font-weight: 950; line-height: 1; letter-spacing: -.03em; }
    .tools-command-label { color: rgba(255,255,255,.72); font-size: 12px; font-weight: 900; text-transform: uppercase; letter-spacing: .08em; }
    .tools-command-center.risk .tools-command-score { color: #ef5350; }
    .tools-command-center.neutral .tools-command-score { color: #f0b35a; }
    .tools-card-action-row { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 2px; }
    .tools-card-action-row .tools-intel-kicker { margin: 0; }
    .tools-intel-grid {
      display: grid; grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: 12px; margin: 0 0 18px;
    }
    .tools-intel-card {
      position: relative; overflow: hidden; min-height: 150px;
      background: var(--panel);
      border: 1px solid var(--line); border-radius: 10px; padding: 16px;
    }
    .tools-intel-card::before { display: none; }
    .tools-intel-kicker {
      font-size: 12px; color: var(--muted); text-transform: uppercase;
      letter-spacing: .08em; font-weight: 800; margin-bottom: 7px;
    }
    .tools-intel-title { font-size: 16px; font-weight: 700; color: var(--text); margin-bottom: 6px; }
    .tools-intel-copy { font-size: 12px; color: var(--muted); line-height: 1.45; margin-bottom: 14px; }
    .tools-intel-read {
      display: flex; align-items: center; justify-content: space-between; gap: 10px;
      background: var(--panel-2); border: 1px solid var(--line);
      border-radius: 8px; padding: 10px;
    }
    .tools-intel-label { font-size: 12px; color: var(--muted); text-transform: uppercase; letter-spacing: .05em; }
    .tools-intel-value { font-size: 13px; font-weight: 700; color: #00bb7f; white-space: nowrap; }
    .tools-intel-value.neg { color: #ef5350; }
    .tools-macro-grid {
      display: grid; grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 7px; margin: 12px 0 14px;
    }
    .tools-macro-pill {
      min-width: 0; background: var(--panel-2); border: 1px solid var(--line);
      border-radius: 8px; padding: 8px 9px;
    }
    .tools-macro-pill span {
      display: block; color: var(--muted); font-size: 9.5px; font-weight: 850;
      text-transform: uppercase; letter-spacing: .06em; white-space: nowrap;
      overflow: hidden; text-overflow: ellipsis;
    }
    .tools-macro-pill b {
      display: block; color: var(--text); font-size: 13px; font-weight: 850;
      margin-top: 3px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    }
    .tools-macro-pill em {
      display: block; color: var(--muted); font-style: normal; font-size: 10px;
      margin-top: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    }
    .tools-macro-pill em.pos { color: #00bb7f; }
    .tools-macro-pill em.neg { color: #ef5350; }
    .tools-macro-map-controls {
      align-items: flex-start;
    }
    #toolsMacroMapMetrics,
    #toolsMacroMapGroups {
      min-width: 0;
    }
    .tools-macro-map-wrap {
      display: grid;
      gap: 8px;
      min-width: 0;
    }
    .tools-macro-map-layout {
      display: grid;
      grid-template-columns: minmax(0, 1.7fr) minmax(330px, .5fr);
      gap: 12px;
      align-items: stretch;
      min-width: 0;
    }
    .tools-macro-map-card {
      overflow: hidden;
      min-width: 0;
      padding: 8px !important;
    }
    .tools-macro-map-svg {
      display: block;
      width: 100%;
      height: auto;
      min-height: 0;
      border: 1px solid rgba(255,255,255,.10);
      border-radius: 14px;
      background: #080c12;
    }
    .tools-macro-map-svg text {
      fill: rgba(255,255,255,.78);
      font: 900 11px Inter, system-ui, sans-serif;
      letter-spacing: 0;
      pointer-events: none;
    }
    .tools-macro-map-country {
      fill: rgba(255,255,255,.06);
      stroke: rgba(255,255,255,.07);
      stroke-width: .45;
      vector-effect: non-scaling-stroke;
      transition: fill .15s ease, opacity .15s ease, filter .15s ease;
    }
    .tools-macro-map-country.is-active {
      opacity: .82;
      stroke: rgba(255,255,255,.13);
      stroke-width: .55;
      cursor: pointer;
    }
    .tools-macro-map-country.is-active:hover,
    .tools-macro-map-country.is-selected {
      filter: drop-shadow(0 0 14px rgba(240,179,90,.46));
      opacity: 1;
    }
    .tools-macro-map-country.is-selected {
      stroke: #ffe5aa;
      stroke-width: 1.8;
      fill-opacity: .98;
      paint-order: stroke fill;
      filter: drop-shadow(0 0 18px rgba(240,179,90,.55)) drop-shadow(0 0 8px rgba(255,229,170,.28));
    }
    .tools-macro-map-point {
      cursor: pointer;
      transition: filter .15s ease, opacity .15s ease;
    }
    .tools-macro-map-point:hover,
    .tools-macro-map-point.is-selected {
      filter: drop-shadow(0 0 12px rgba(255,255,255,.35));
    }
    .tools-macro-map-point.is-selected circle:nth-child(2) {
      stroke: #ffe5aa;
      stroke-width: 3;
    }
    .tools-macro-country-card {
      min-width: 0;
      padding: 16px !important;
    }
    .tools-macro-country-list {
      display: grid;
      gap: 8px;
      max-height: 560px;
      overflow: auto;
      padding: 2px 3px 2px 2px;
      scrollbar-width: none;
      scroll-behavior: smooth;
    }
    .tools-macro-country-list::-webkit-scrollbar {
      display: none;
    }
    .tools-macro-country-row {
      display: grid;
      grid-template-columns: 24px minmax(132px, 1fr) minmax(96px, auto);
      gap: 9px;
      align-items: center;
      border: 1px solid var(--line);
      border-radius: 10px;
      background: var(--panel-2);
      color: inherit;
      cursor: pointer;
      padding: 10px;
      text-decoration: none;
      transition: border-color .15s ease, background .15s ease, transform .15s ease;
    }
    .tools-macro-country-row:hover,
    .tools-macro-country-row.is-selected {
      border-color: rgba(45,212,191,.62);
      background:
        radial-gradient(circle at 8% 50%, rgba(45,212,191,.22), transparent 38%),
        linear-gradient(90deg, rgba(45,212,191,.18), transparent 58%),
        color-mix(in srgb, var(--panel-2) 82%, #2dd4bf 18%);
    }
    .tools-macro-country-row.is-selected {
      box-shadow: inset 3px 0 0 #2dd4bf, 0 10px 24px rgba(0,0,0,.22);
      transform: translateX(2px);
    }
    .tools-macro-country-row.is-popping {
      animation: toolsMacroPop .46s ease;
    }
    @keyframes toolsMacroPop {
      0% { transform: translateX(2px) scale(1); }
      45% { transform: translateX(2px) scale(1.025); }
      100% { transform: translateX(2px) scale(1); }
    }
    .tools-macro-rank {
      color: var(--muted);
      font-size: 11px;
      font-weight: 900;
      text-align: right;
      font-variant-numeric: tabular-nums;
    }
    .tools-macro-country {
      display: grid;
      grid-template-columns: auto minmax(0, 1fr);
      gap: 1px 7px;
      align-items: center;
      min-width: 0;
    }
    .tools-macro-country b {
      grid-row: 1 / span 2;
      position: relative;
      display: inline-flex;
      width: 28px;
      height: 28px;
      align-items: center;
      justify-content: center;
      overflow: visible;
      border-radius: 50%;
      background: rgba(255,255,255,.08);
      font-size: 16px;
      line-height: 1;
    }
    .tools-macro-country b img {
      display: block;
      width: 24px;
      height: 24px;
      border-radius: 50%;
      object-fit: cover;
      box-shadow: 0 0 0 1px rgba(255,255,255,.18);
    }
    .tools-macro-country b > span,
    .tools-macro-flag-fallback {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 22px;
      height: 22px;
      font-family: "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", sans-serif;
      font-size: 18px;
      line-height: 1;
    }
    .tools-macro-country b .tools-macro-flag-fallback {
      display: none;
    }
    .tools-macro-country b i {
      position: absolute;
      right: -1px;
      bottom: -2px;
      padding: 1px 2px;
      border-radius: 4px;
      background: #050607;
      color: rgba(255,255,255,.86);
      font-size: 7px;
      font-style: normal;
      font-weight: 950;
      letter-spacing: 0;
    }
    .tools-macro-country strong {
      overflow: hidden;
      color: var(--text);
      font-size: 12.5px;
      font-weight: 950;
      text-overflow: ellipsis;
      white-space: nowrap;
    }
    .tools-macro-country em,
    .tools-macro-value em {
      overflow: hidden;
      color: var(--muted);
      font-size: 10px;
      font-style: normal;
      font-weight: 800;
      text-overflow: ellipsis;
      white-space: nowrap;
    }
    .tools-macro-value {
      display: grid;
      gap: 2px;
      min-width: 0;
      text-align: right;
    }
    .tools-macro-value b {
      color: var(--text);
      font-size: 13px;
      font-weight: 950;
      font-variant-numeric: tabular-nums;
      white-space: nowrap;
    }
    .tools-preview-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 10px; margin-bottom: 18px; }
    .tools-preview-card { border: 1px solid var(--line); border-radius: 10px; background: var(--panel); padding: 14px; min-height: 118px; display: flex; flex-direction: column; gap: 9px; cursor: pointer; transition: background .15s, border-color .15s; }
    .tools-preview-card:hover { background: var(--panel-2); border-color: var(--line); }
    .tools-preview-mini { height: 34px; border-radius: 8px; overflow: hidden; display: grid; gap: 3px; background: var(--panel-2); padding: 5px; }
    .tools-preview-heat { grid-template-columns: 1.2fr .8fr 1fr; }
    .tools-preview-bubbles { display: flex; align-items: center; justify-content: center; gap: 6px; }
    .tools-preview-bubble { border-radius: 999px; background: rgba(0,187,127,.75); }
    .tools-preview-bubble.red { background: rgba(239,83,80,.75); }
    .tools-preview-meter { display: flex; align-items: center; }
    .tools-preview-meter::before { content: ''; width: 100%; height: 9px; border-radius: 999px; background: linear-gradient(90deg, #e8572a 0 36%, #f0b35a 36% 62%, #00bb7f 62%); }
    .tools-preview-table { grid-template-columns: repeat(6, 1fr); align-content: stretch; }
    .tools-preview-cell { border-radius: 3px; background: rgba(0,187,127,.35); }
    .tools-preview-cell.red { background: rgba(239,83,80,.38); }
    .tools-preview-title { color: var(--text); font-size: 14px; font-weight: 700; line-height: 1.2; }
    .tools-preview-copy { color: var(--muted); font-size: 12px; line-height: 1.4; }
    .tools-preview-action { color: var(--accent); font-size: 12px; font-weight: 700; margin-top: auto; }
    .tools-pm-card {
      background: var(--panel); border: 1px solid var(--line); border-radius: 12px;
      padding: 16px; margin-bottom: 18px; display: grid; gap: 14px;
    }
    .tools-pm-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; }
    .tools-pm-kicker { color: var(--accent); font-size: 10px; font-weight: 850; letter-spacing: .09em; text-transform: uppercase; margin-bottom: 5px; }
    .tools-pm-title { color: var(--text); font-size: 18px; font-weight: 760; letter-spacing: -.02em; }
    .tools-pm-copy { color: var(--muted); font-size: 12.5px; line-height: 1.45; max-width: 680px; margin-top: 5px; }
    .tools-pm-score { min-width: 118px; text-align: right; }
    .tools-pm-score-value { color: var(--text); font-size: 30px; font-weight: 850; line-height: 1; letter-spacing: -.04em; }
    .tools-pm-score-label { color: var(--muted); font-size: 10px; font-weight: 850; letter-spacing: .08em; text-transform: uppercase; margin-top: 5px; }
    .tools-pm-meter { height: 9px; border-radius: 999px; background: rgba(255,255,255,.08); overflow: hidden; }
    .tools-pm-meter-fill { height: 100%; border-radius: inherit; background: linear-gradient(90deg, #ef5350, #f0b35a 48%, #00bb7f); }
    .tools-pm-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; }
    .tools-pm-stat { background: var(--panel-2); border: 1px solid var(--line); border-radius: 9px; padding: 10px 12px; min-width: 0; }
    .tools-pm-stat-label { color: var(--muted); font-size: 10px; font-weight: 850; letter-spacing: .06em; text-transform: uppercase; margin-bottom: 4px; }
    .tools-pm-stat-value { color: var(--text); font-size: 15px; font-weight: 750; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .tools-pm-list { display: grid; gap: 8px; }
    .tools-pm-row { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 12px; align-items: center; border: 1px solid var(--line); border-radius: 9px; background: var(--panel-2); padding: 10px 12px; text-decoration: none; color: inherit; }
    .tools-pm-row:hover { border-color: rgba(232,87,42,.45); }
    .tools-pm-row-title { color: var(--text); font-size: 13px; font-weight: 700; line-height: 1.25; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    .tools-pm-row-meta { color: var(--muted); font-size: 11px; margin-top: 4px; }
    .tools-pm-outcome { color: var(--accent); font-size: 12px; font-weight: 850; white-space: nowrap; }
    .tools-mini-bars { display: grid; gap: 8px; margin: 12px 0 14px; }
    .tools-mini-bar-row { display: grid; grid-template-columns: 42px 1fr 78px; gap: 8px; align-items: center; font-size: 11px; color: var(--muted); }
    .tools-mini-bar-track { height: 8px; border-radius: 999px; background: rgba(255,255,255,.07); overflow: hidden; }
    .tools-mini-bar-fill { height: 100%; border-radius: inherit; background: linear-gradient(90deg, #e8572a, #00bb7f); }
    .tools-theme-list { display: grid; gap: 8px; margin: 12px 0 14px; }
    .tools-theme-pill { display: grid; grid-template-columns: 58px 1fr 34px; gap: 8px; align-items: center; font-size: 11px; color: var(--muted); }
    .tools-theme-track { height: 8px; border-radius: 999px; background: rgba(255,255,255,.07); overflow: hidden; }
    .tools-theme-fill { height: 100%; border-radius: inherit; background: linear-gradient(90deg, #7c5cff, #00bb7f); }
    .tools-market-structure-wrap { display: grid; gap: 14px; min-width: 0; }
    .tools-ms-grid {
      display: grid; grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 12px; min-width: 0;
    }
    .tools-ms-grid.three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .tools-ms-chart {
      width: 100%; height: 220px; display: block; margin-top: 12px;
      background: linear-gradient(180deg, rgba(255,255,255,.025), rgba(0,0,0,.08));
      border: 1px solid var(--line); border-radius: 10px;
    }
    .tools-ms-bar {
      height: 7px; border-radius: 999px; background: rgba(255,255,255,.08);
      overflow: hidden; min-width: 90px;
    }
    .tools-ms-bar span {
      display: block; height: 100%; border-radius: inherit;
      background: linear-gradient(90deg, #00bb7f, #f0b35a);
    }
    .tools-ms-chain-list { display: grid; gap: 9px; margin-top: 12px; }
    .tools-ms-chain-row {
      display: grid; grid-template-columns: 76px minmax(0, 1fr) 92px;
      gap: 10px; align-items: center; color: var(--muted); font-size: 12px;
    }
    .tools-ms-chain-row b { color: var(--text); text-align: right; font-weight: 850; }
    .tools-ms-asset-head {
      display: flex; justify-content: space-between; align-items: flex-start;
      gap: 12px; margin-bottom: 10px;
    }
    .tools-cq-section {
      background: var(--panel); border: 1px solid var(--line);
      border-radius: 12px; padding: 14px; min-width: 0;
    }
    .tools-cq-counts {
      display: flex; flex-wrap: wrap; gap: 7px; justify-content: flex-end;
      color: var(--muted); font-size: 11px; font-weight: 800;
    }
    .tools-cq-counts span {
      border: 1px solid var(--line); border-radius: 999px; padding: 5px 9px;
      background: var(--panel-2);
    }
    .tools-cq-read {
      margin: 12px 0; border: 1px solid rgba(240,179,90,.28);
      background: rgba(240,179,90,.08); color: #f0b35a;
      border-radius: 10px; padding: 12px; font-size: 13px; line-height: 1.45;
      font-weight: 650; overflow-wrap: anywhere;
    }
    .tools-cq-grid {
      display: grid; grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: 10px; min-width: 0;
    }
    .tools-cq-card {
      border: 1px solid var(--line); border-radius: 10px;
      background: var(--panel-2); padding: 12px; min-width: 0;
      color: inherit; text-align: left; cursor: pointer; font: inherit;
      border-left: 3px solid var(--cq-accent, rgba(0,187,127,.42));
      transition: transform .16s ease, border-color .16s ease, background .16s ease;
    }
    .tools-cq-card.ok { border-color: rgba(0,187,127,.24); border-left-color: var(--cq-accent, #00bb7f); }
    .tools-cq-card.locked { border-color: rgba(240,179,90,.28); }
    .tools-cq-card.empty { opacity: .82; }
    .tools-cq-card:hover {
      transform: translateY(-1px);
      border-color: color-mix(in srgb, var(--cq-accent, #00bb7f) 54%, var(--line));
      background: color-mix(in srgb, var(--panel-2) 88%, var(--cq-accent, #00bb7f) 12%);
    }
    .tools-cq-title {
      color: var(--text); font-size: 14px; line-height: 1.25;
      font-weight: 850; margin-bottom: 8px;
    }
    .tools-cq-value {
      color: var(--text); font-size: 18px; font-weight: 850;
      white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    }
    .tools-cq-change {
      margin-top: 8px; font-size: 11px; font-weight: 850;
    }
    .tools-cq-change.pos { color: #00bb7f; }
    .tools-cq-change.neg { color: #ef5350; }
    .tools-cq-card .tools-ms-chart { height: 112px; margin-top: 10px; }
    .tools-cq-open {
      margin-top: 10px; display: inline-flex; align-items: center; justify-content: center;
      min-height: 30px; padding: 0 10px; border-radius: 999px;
      border: 1px solid color-mix(in srgb, var(--cq-accent, #00bb7f) 52%, var(--line));
      background: color-mix(in srgb, var(--panel-3, #121820) 78%, var(--cq-accent, #00bb7f) 22%);
      color: var(--text); font-size: 11px; font-weight: 900;
    }
    .tools-cq-placeholder {
      margin-top: 10px; height: 112px; border: 1px dashed var(--line);
      border-radius: 10px; display: flex; align-items: center; justify-content: center;
      color: var(--muted); font-size: 12px; font-weight: 750;
      background: rgba(255,255,255,.025);
    }
    .tools-cq-modal-backdrop {
      position: fixed; inset: 0; z-index: 10050;
      background: rgba(0,0,0,.72); backdrop-filter: blur(8px);
      display: flex; align-items: center; justify-content: center;
      padding: 22px;
    }
    .tools-cq-modal {
      width: min(1120px, 100%); max-height: calc(100vh - 44px);
      overflow: auto; background: #0b0f14; color: var(--text);
      border: 1px solid rgba(255,255,255,.16); border-radius: 14px;
      box-shadow: 0 28px 90px rgba(0,0,0,.58);
    }
    .tools-cq-modal-head {
      display: flex; justify-content: space-between; gap: 14px; align-items: flex-start;
      padding: 18px 18px 12px; border-bottom: 1px solid rgba(255,255,255,.10);
    }
    .tools-cq-modal-kicker {
      color: #f0b35a; font-size: 11px; line-height: 1.2;
      font-weight: 900; text-transform: uppercase; letter-spacing: .08em;
    }
    .tools-cq-modal h3 {
      margin: 4px 0 0; color: var(--text); font-size: 24px; line-height: 1.15;
      font-weight: 900; letter-spacing: 0;
    }
    .tools-cq-modal-actions {
      display: flex; gap: 8px; flex-wrap: wrap; justify-content: flex-end;
    }
    .tools-cq-modal-actions button {
      min-height: 34px; border: 1px solid rgba(255,255,255,.16);
      background: #151b23; color: var(--text); border-radius: 8px;
      padding: 0 12px; font-size: 12px; font-weight: 850; cursor: pointer;
    }
    .tools-cq-modal-chart { padding: 14px 18px 0; }
    .tools-cq-large-svg {
      display: block; width: 100%; height: auto; border-radius: 14px;
      border: 1px solid rgba(255,255,255,.10); background: #070a0e;
    }
    .tools-cq-explain-grid {
      display: grid; grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 12px; padding: 14px 18px 18px;
    }
    .tools-cq-explain-grid > div {
      border: 1px solid rgba(255,255,255,.10); border-radius: 10px;
      background: rgba(255,255,255,.035); padding: 13px;
    }
    .tools-cq-explain-label {
      color: #f0b35a; font-size: 11px; line-height: 1.2;
      font-weight: 900; text-transform: uppercase; letter-spacing: .08em;
      margin-bottom: 6px;
    }
    .tools-cq-explain-grid p {
      margin: 0; color: var(--muted); font-size: 13px; line-height: 1.5;
      overflow-wrap: anywhere;
    }
    .tools-ms-big {
      color: var(--text); font-size: 19px; font-weight: 850;
      white-space: nowrap; letter-spacing: -.02em;
    }
    .tools-ms-mini-stat {
      display: flex; justify-content: space-between; gap: 12px;
      border: 1px solid var(--line); border-radius: 9px; background: var(--panel-2);
      padding: 9px 10px; color: var(--muted); font-size: 11px; font-weight: 850;
      margin-bottom: 10px;
    }
    .tools-ms-mini-stat b { color: var(--text); }
    .tools-ms-mini-stat b.pos { color: #00bb7f; }
    .tools-ms-mini-stat b.neg { color: #ef5350; }
	    .tools-ms-table { min-width: 520px; }
	    .tools-ms-summary-three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
	    .tools-ms-summary-four { grid-template-columns: repeat(4, minmax(0, 1fr)); }
	    .tools-liq-summary-four { grid-template-columns: repeat(4, minmax(0, 1fr)); }
    .tools-liq-grid { align-items: start; }
    .tools-deriv-card { display: flex; flex-direction: column; gap: 0; }
    .tools-deriv-source-list { display: grid; gap: 8px; margin-top: 2px; }
    .tools-deriv-history { margin: 0 0 10px; }
    .tools-deriv-history .tools-ms-chart { height: 126px; margin-top: 0; }
    .tools-deriv-source-row {
      display: grid; grid-template-columns: minmax(92px, .72fr) minmax(0, 1.28fr);
      gap: 10px; align-items: center; border: 1px solid var(--line);
      background: var(--panel-2); border-radius: 9px; padding: 9px 10px;
      min-width: 0;
    }
    .tools-deriv-source-name {
      color: var(--text); font-size: 12px; font-weight: 850;
      text-transform: capitalize;
    }
    .tools-deriv-source-inst {
      color: var(--muted); font-size: 10.5px; margin-top: 3px;
      white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
      font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    }
    .tools-deriv-source-metrics {
      display: grid; grid-template-columns: repeat(auto-fit, minmax(58px, 1fr));
      gap: 7px; min-width: 0;
    }
    .tools-deriv-source-metrics span,
    .tools-liq-asset-row span {
      min-width: 0;
    }
    .tools-deriv-source-metrics em,
    .tools-liq-asset-row em {
      display: block; color: var(--muted); font-style: normal;
      font-size: 9.5px; font-weight: 850; letter-spacing: .06em;
      text-transform: uppercase; margin-bottom: 3px;
    }
    .tools-deriv-source-metrics b,
    .tools-liq-asset-row b {
      display: block; color: var(--text); font-size: 12px; font-weight: 850;
      white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    }
    .tools-deriv-source-metrics b.pos { color: #00bb7f; }
    .tools-deriv-source-metrics b.neg { color: #ef5350; }
    .tools-liq-asset-list { display: grid; gap: 9px; margin-top: 12px; }
    .tools-liq-asset-row {
      display: grid; grid-template-columns: minmax(72px, .74fr) repeat(3, minmax(78px, .72fr)) minmax(160px, 1.15fr);
      gap: 10px; align-items: center; border: 1px solid var(--line);
      background: var(--panel-2); border-radius: 9px; padding: 11px 12px;
      min-width: 0;
    }
    .tools-liq-split {
      height: 8px; border-radius: 999px; overflow: hidden;
      background: rgba(0,187,127,.32); border: 1px solid rgba(255,255,255,.05);
      margin: 7px 0 5px;
    }
    .tools-liq-split span {
      display: block; height: 100%; border-radius: inherit;
      background: #ef5350;
    }
    .tools-liq-asset-split small {
      display: block; color: var(--muted); font-size: 10.5px;
      white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    }
    .tools-liq-event-list {
      display: grid; grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 8px; margin-top: 12px;
    }
    .tools-liq-exchange-list {
      display: grid; grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: 9px; margin-top: 12px;
    }
    .tools-liq-exchange-row {
      border: 1px solid var(--line); background: var(--panel-2);
      border-radius: 11px; padding: 11px 12px; min-width: 0;
    }
    .tools-liq-exchange-row > div:first-child {
      display: flex; align-items: baseline; justify-content: space-between; gap: 10px;
      min-width: 0;
    }
    .tools-liq-exchange-row b {
      color: var(--text); font-size: 12px; font-weight: 900;
      white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    }
    .tools-liq-exchange-row em {
      color: var(--text); font-size: 12px; font-style: normal; font-weight: 850;
      white-space: nowrap;
    }
    .tools-liq-exchange-row small {
      color: var(--muted); font-size: 10.5px; white-space: nowrap;
      overflow: hidden; text-overflow: ellipsis;
    }
    .tools-exflow-grid { align-items: stretch; }
    .tools-exflow-read { margin: 0 0 12px; }
    .tools-exflow-coverage-note {
      border: 1px solid var(--line); background: var(--panel-2);
      border-radius: 10px; padding: 12px 14px; margin: 0 0 14px;
      color: var(--muted); font-size: 12px; font-weight: 750; line-height: 1.45;
    }
    .tools-exflow-card-top {
      display: flex; align-items: center; justify-content: space-between; gap: 8px;
      min-width: 0;
    }
    .tools-exflow-pill {
      border: 1px solid var(--line); border-radius: 999px; padding: 3px 7px;
      font-size: 9.5px; font-weight: 900; text-transform: uppercase; white-space: nowrap;
      color: var(--muted); background: var(--panel-2);
    }
    .tools-exflow-pill.ok { color: #00bb7f; border-color: rgba(0,187,127,.35); background: rgba(0,187,127,.08); }
    .tools-exflow-pill.locked { color: #f0b35a; border-color: rgba(240,179,90,.36); background: rgba(240,179,90,.09); }
    .tools-exflow-big {
      color: var(--text); font-size: clamp(26px, 4vw, 46px); font-weight: 950;
      line-height: 1; margin: 12px 0 10px; letter-spacing: 0;
    }
    .tools-exflow-stat-grid {
      display: grid; grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 8px; margin: 10px 0 12px;
    }
    .tools-exflow-stat-grid div,
    .tools-exflow-row {
      border: 1px solid var(--line); background: var(--panel-2);
      border-radius: 9px; padding: 10px 11px; min-width: 0;
    }
    .tools-exflow-stat-grid span {
      display: block; color: var(--muted); font-size: 10px; font-weight: 850;
      text-transform: uppercase; margin-bottom: 4px;
    }
    .tools-exflow-stat-grid b {
      color: var(--text); font-size: 13px; font-weight: 900;
      white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    }
    .tools-exflow-stat-grid b.pos,
    .tools-exflow-row small.pos { color: #00bb7f; }
    .tools-exflow-stat-grid b.neg,
    .tools-exflow-row small.neg { color: #ef5350; }
    .tools-exflow-venues { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .tools-exflow-list { display: grid; gap: 8px; margin-top: 12px; }
    .tools-exflow-row {
      display: grid; grid-template-columns: minmax(0, 1fr) auto auto;
      align-items: center; gap: 10px;
    }
    .tools-exflow-row span { min-width: 0; }
    .tools-exflow-row b {
      display: block; color: var(--text); font-size: 12px; font-weight: 900;
      white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    }
    .tools-exflow-row em {
      display: block; color: var(--muted); font-size: 10px; font-style: normal;
      font-weight: 850; text-transform: uppercase; margin-top: 2px;
    }
    .tools-exflow-row strong {
      color: var(--text); font-size: 12px; font-weight: 900; white-space: nowrap;
    }
    .tools-exflow-row small { font-size: 11px; font-weight: 850; white-space: nowrap; }
    .tools-liq-event-row {
      display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 8px;
      align-items: center; border: 1px solid var(--line);
      background: var(--panel-2); border-radius: 9px; padding: 10px 11px;
      min-width: 0;
    }
    .tools-liq-event-row span { display: flex; align-items: center; gap: 7px; min-width: 0; }
    .tools-liq-event-row span b { color: var(--text); font-size: 12px; font-weight: 900; }
    .tools-liq-event-row span em {
      font-style: normal; font-size: 10px; font-weight: 900;
      text-transform: uppercase; letter-spacing: .05em;
    }
    .tools-liq-event-row span em.neg { color: #ef5350; }
    .tools-liq-event-row span em.pos { color: #00bb7f; }
    .tools-liq-event-row strong {
      color: var(--text); font-size: 12px; font-weight: 900; white-space: nowrap;
    }
    .tools-liq-event-row small {
      grid-column: 1 / -1; color: var(--muted); font-size: 10.5px;
      font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    }
    [data-tools-panel="leverage-pressure"] .tools-liq-event-list {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    [data-tools-panel="leverage-pressure"] .tools-pressure-print-row {
      grid-template-columns: 1fr;
      gap: 5px;
      align-items: start;
      padding-left: 14px;
    }
    [data-tools-panel="leverage-pressure"] .tools-pressure-print-row span {
      justify-content: space-between;
      gap: 10px;
    }
    [data-tools-panel="leverage-pressure"] .tools-pressure-print-row strong {
      white-space: normal;
      line-height: 1.15;
    }
    [data-tools-panel="leverage-pressure"] .tools-pressure-print-row small {
      grid-column: auto;
      white-space: normal;
    }
    .tools-liq-heatmap {
      display: grid; gap: 5px; margin-top: 6px; padding-bottom: 2px;
    }
    .tools-liq-heat-head {
      display: grid; grid-template-columns: 76px repeat(3, minmax(0, 1fr));
      gap: 6px; align-items: center; margin-top: 10px;
      color: var(--muted); font-size: 9.5px; font-weight: 850;
      letter-spacing: .06em; text-transform: uppercase;
    }
    .tools-liq-heat-head b { text-align: center; color: var(--muted); }
    .tools-liq-heat-row {
      display: grid; grid-template-columns: 76px repeat(3, minmax(0, 1fr));
      gap: 6px; align-items: stretch;
    }
    .tools-liq-heat-row span {
      color: var(--muted); font: 10px ui-monospace, SFMono-Regular, Menlo, monospace;
      align-self: center;
    }
    .tools-liq-heat-row i {
      display: grid; align-content: center; justify-items: center; gap: 1px;
      min-height: 28px; border-radius: 7px;
      background:
        linear-gradient(90deg, rgba(239,83,80,var(--liq-alpha)), rgba(240,179,90,calc(var(--liq-alpha) * .72)));
      color: #fff; font-style: normal; box-shadow: inset 0 0 0 1px rgba(255,255,255,.05);
    }
    .tools-liq-heat-row i b {
      color: rgba(255,255,255,.9); font-size: 9.5px; font-weight: 900;
      line-height: 1;
    }
    .tools-liq-heat-row i em {
      color: rgba(255,255,255,.82); font-style: normal; font-size: 9px;
      line-height: 1; max-width: 100%; overflow: hidden; text-overflow: ellipsis;
    }
    .tools-liq-window-controls {
      display: inline-flex; align-items: center; gap: 5px; padding: 3px;
      border-radius: 999px; border: 1px solid var(--line); background: var(--panel-2);
    }
    .tools-liq-window-controls button {
      border: 0; border-radius: 999px; background: transparent; color: var(--muted);
      font-size: 10px; font-weight: 900; letter-spacing: .05em; padding: 6px 8px;
      cursor: pointer;
    }
    .tools-liq-window-controls button.active {
      background: rgba(232,87,42,.18); color: var(--text);
      box-shadow: inset 0 0 0 1px rgba(232,87,42,.28);
    }
    .tools-liq-treemap {
      position: relative; width: 100%; height: 380px;
      max-width: 100%; box-sizing: border-box;
      margin-top: 14px; border-radius: 14px; overflow: hidden;
      background: var(--panel); border: 1px solid var(--line);
      box-shadow: inset 0 0 60px rgba(0,0,0,.25);
    }
    .tools-liq-treemap-tile {
      position: absolute; box-sizing: border-box;
      display: flex; flex-direction: column; justify-content: center; align-items: center;
      text-align: center; gap: 4px; padding: 8px;
      background:
        radial-gradient(circle at 20% 10%, rgba(255,255,255,.20), transparent 34%),
        linear-gradient(135deg, rgba(239,83,80,var(--liq-alpha)), rgba(240,179,90,calc(var(--liq-alpha) * .74)));
      border: 1px solid rgba(0,0,0,.30);
      box-shadow: inset 0 0 0 1px rgba(255,255,255,.08);
      min-width: 0; overflow: hidden; color: #fff;
      transition: transform .14s ease, box-shadow .14s ease, z-index .14s;
    }
    .tools-liq-treemap-tile:hover {
      transform: scale(1.035); z-index: 5;
      box-shadow: 0 4px 18px rgba(0,0,0,.45);
      border-color: rgba(255,255,255,.42);
    }
    .tools-liq-treemap-tile b {
      color: #fff; font-size: 18px; font-weight: 950; letter-spacing: .04em;
      line-height: 1; text-shadow: 0 1px 3px rgba(0,0,0,.55);
    }
    .tools-liq-treemap-tile strong {
      color: #fff; font-size: 20px; font-weight: 950; line-height: 1.05;
      white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
      text-shadow: 0 1px 3px rgba(0,0,0,.55);
    }
    .tools-liq-treemap-tile em {
      color: rgba(255,255,255,.78); font-style: normal; font-size: 11px; font-weight: 850;
      text-transform: uppercase; letter-spacing: .05em;
    }
    .tools-chain-layout {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 14px;
      align-items: stretch;
    }
    .tools-chain-card {
      min-height: 430px;
      display: flex;
      flex-direction: column;
    }
    .tools-chain-card .tools-etf-chart-top {
      min-height: 64px;
    }
    .tools-chain-top-list {
      display: grid;
      gap: 11px;
      margin-top: 18px;
      flex: 1 1 auto;
      align-content: stretch;
    }
    .tools-chain-share-row {
      transition: border-color .16s ease, background .16s ease, transform .16s ease;
    }
    .tools-chain-share-row.is-hovered {
      border-color: rgba(232,87,42,.45);
      background: color-mix(in srgb, var(--panel-2) 76%, var(--accent) 12%);
      transform: translateX(2px);
    }
    .tools-chain-summary { grid-template-columns: repeat(4, minmax(0, 1fr)); }
    .tools-chain-pie {
      display: block;
      width: 100%;
      max-width: none;
      min-height: 260px;
      margin-top: 10px;
    }
    .tools-chain-slice {
      cursor: pointer;
      transform-box: fill-box;
      transform-origin: center;
      transition: transform .16s ease, opacity .16s ease, filter .16s ease;
    }
    .tools-chain-slice:hover,
    .tools-chain-slice.is-hovered {
      transform: scale(1.035);
      opacity: 1;
      filter: drop-shadow(0 6px 12px rgba(0,0,0,.34));
    }
    .tools-chain-pie-legend-row {
      cursor: pointer;
      transition: opacity .16s ease;
    }
    .tools-chain-pie-legend-row.is-hovered text {
      fill: var(--accent);
    }
    .tools-chain-pie text {
      fill: var(--text);
      font-size: 13px;
      font-weight: 800;
    }
    .tools-chain-pie .tools-chain-pie-main {
      font-size: 24px;
      font-weight: 900;
    }
    .tools-chain-pie .tools-chain-pie-sub {
      fill: var(--muted);
      font-size: 12px;
      text-transform: uppercase;
    }
    .tools-chain-name {
      display: grid;
      gap: 3px;
      min-width: 150px;
    }
    .tools-chain-name b {
      color: var(--text);
      font-size: 13px;
      font-weight: 850;
    }
    .tools-chain-name span {
      color: var(--muted);
      font-size: 11px;
      font-weight: 750;
    }
    .tools-chain-table .tools-ms-bar { min-width: 96px; }
    .tools-chain-protocol {
      display: grid;
      gap: 3px;
      min-width: 132px;
    }
    .tools-chain-protocol b {
      color: var(--text);
      font-size: 12px;
      font-weight: 850;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }
    .tools-chain-protocol span {
      color: var(--muted);
      font-size: 10.5px;
      font-weight: 750;
    }
    .tools-pressure-summary { grid-template-columns: repeat(4, minmax(0, 1fr)); }
    #toolsLeveragePressureAssets {
      width: 100%;
      overflow: hidden;
    }
    #toolsLeveragePressureAssets .tools-etf-asset {
      min-width: 0;
      text-align: center;
    }
    .tools-pressure-layout {
      display: grid;
      grid-template-columns: minmax(0, 1.62fr) minmax(290px, .78fr);
      gap: 14px;
      align-items: start;
      min-width: 0;
    }
    .tools-pressure-chart-card {
      overflow: hidden;
      padding: 14px;
    }
    .tools-pressure-action-read {
      display: grid;
      grid-template-columns: auto minmax(0, 1fr);
      gap: 10px;
      align-items: start;
      margin-bottom: 12px;
      padding: 11px 12px;
      border: 1px solid rgba(255,215,0,.18);
      border-radius: 10px;
      background: linear-gradient(135deg, rgba(255,215,0,.065), rgba(52,209,189,.035) 54%, transparent);
    }
    .tools-pressure-action-read b {
      color: #ffd700;
      font-size: 11px;
      font-weight: 950;
      text-transform: uppercase;
      letter-spacing: .06em;
      white-space: nowrap;
    }
    .tools-pressure-action-read span {
      color: var(--muted);
      font-size: 12px;
      line-height: 1.45;
      font-weight: 750;
      min-width: 0;
      overflow-wrap: anywhere;
      white-space: normal;
    }
    .tools-pressure-chart-card .tools-etf-chart-actions {
      display: flex;
      align-items: center;
      justify-content: flex-end;
      gap: 8px;
      flex-wrap: wrap;
    }
    .tools-pressure-window {
      display: inline-flex;
      align-items: center;
      gap: 3px;
      padding: 3px;
      border: 1px solid rgba(255,255,255,.12);
      border-radius: 10px;
      background: rgba(0,0,0,.22);
    }
    .tools-pressure-window button {
      appearance: none;
      border: 0;
      border-radius: 7px;
      background: transparent;
      color: rgba(255,255,255,.62);
      font-size: 11px;
      font-weight: 950;
      letter-spacing: 0;
      line-height: 1;
      padding: 8px 9px;
      cursor: pointer;
    }
    .tools-pressure-window button.active {
      color: #090d13;
      background: #ffd700;
      box-shadow: 0 0 18px rgba(255,215,0,.18);
    }
    .tools-pressure-chart {
      display: block; width: 100%; height: auto; margin-top: 12px;
      border: 1px solid rgba(255,255,255,.10); border-radius: 14px;
      background: #080c12;
    }
    .tools-pressure-mini-map {
      margin-top: 14px;
      padding-top: 14px;
      border-top: 1px solid rgba(255,255,255,.10);
    }
    .tools-pressure-mini-head {
      display: flex;
      align-items: flex-start;
      justify-content: space-between;
      gap: 12px;
      margin-bottom: 10px;
    }
    .tools-pressure-mini-map .tools-pressure-chart {
      max-height: none;
    }
    .tools-pressure-modal-backdrop {
      position: fixed;
      inset: 0;
      z-index: 9999;
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 22px;
      background: rgba(0,0,0,.82);
      backdrop-filter: blur(10px);
    }
    .tools-pressure-modal {
      width: min(1280px, 100%);
      max-height: calc(100vh - 44px);
      overflow: auto;
      border: 1px solid rgba(255,255,255,.16);
      border-radius: 14px;
      background: #090d13;
      box-shadow: 0 26px 80px rgba(0,0,0,.58);
    }
    .tools-pressure-modal-chart {
      padding: 14px 18px 18px;
    }
    .tools-pressure-pan {
      width: 100%;
      max-width: 100%;
      overflow: hidden;
      -webkit-overflow-scrolling: touch;
      scrollbar-width: thin;
    }
    .tools-pressure-modal-hint {
      display: none;
      color: var(--muted);
      font-size: 11px;
      font-weight: 800;
      margin: 0 0 8px;
    }
    .tools-pressure-modal .tools-pressure-heatmap,
    .tools-pressure-modal .tools-pressure-chart {
      margin-top: 0;
    }
    .tools-pressure-modal .tools-pressure-canvas-map {
      min-height: 724px;
      padding: 22px 18px 18px;
    }
    .tools-pressure-modal .tools-pressure-canvas-stage {
      grid-template-rows: minmax(606px, 1fr) 54px;
      gap: 12px;
    }
    .tools-pressure-modal .tools-pressure-canvas-stage canvas[data-pressure-heatmap-mini] {
      height: 54px;
    }
    .tools-pressure-chart text {
      fill: rgba(255,255,255,.62); font: 800 15px Inter, system-ui, sans-serif;
      letter-spacing: 0;
    }
    .tools-pressure-chart .tools-pressure-watermark {
      fill: rgba(255,255,255,.045); font-size: 78px; font-weight: 950;
    }
    .tools-pressure-chart.compact .tools-pressure-watermark { font-size: 52px; }
    .tools-pressure-chart .tools-pressure-current {
      fill: #ffd700; font-size: 15px; font-weight: 950;
    }
    .tools-pressure-chart .tools-pressure-axis-label {
      fill: rgba(255,255,255,.58); font-size: 14px; font-weight: 850;
    }
    .tools-pressure-chart .tools-pressure-zone-label {
      fill: #f5f1e8; font-size: 14px; font-weight: 950;
    }
    .tools-pressure-chart .tools-pressure-critical-label {
      fill: #f5f1e8;
      font-size: 13px;
      font-weight: 950;
    }
    .tools-pressure-chart .tools-pressure-critical-amount {
      fill: rgba(255,255,255,.62);
      font-size: 11px;
      font-weight: 850;
    }
    .tools-pressure-chart .tools-pressure-critical-badge {
      fill: #fff;
      font-size: 13px;
      font-weight: 950;
    }
    .tools-pressure-zone-marker {
      cursor: pointer;
      outline: none;
      transition: opacity .16s ease, filter .16s ease;
    }
    .tools-pressure-zone-marker.is-hovered {
      filter: drop-shadow(0 0 10px rgba(255,215,0,.78));
    }
    .tools-pressure-heatmap-wrap { margin-top: 12px; }
    .tools-pressure-canvas-map {
      display: grid;
      grid-template-columns: 54px minmax(0, 1fr);
      gap: 14px;
      width: 100%;
      min-height: 620px;
      padding: 14px;
      border: 1px solid rgba(255,255,255,.12);
      border-radius: 8px;
      background: #202020;
      overflow: hidden;
      box-shadow: none;
    }
    .tools-pressure-canvas-scale {
      display: grid;
      grid-template-rows: auto minmax(0, 1fr) auto;
      gap: 8px;
      align-items: stretch;
      justify-items: center;
      min-width: 0;
      color: rgba(255,255,255,.82);
      font-size: 11px;
      font-weight: 500;
      line-height: 1;
    }
    .tools-pressure-canvas-scale b,
    .tools-pressure-canvas-scale span {
      max-width: 100%;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
      font: inherit;
    }
    .tools-pressure-canvas-scale canvas {
      display: block;
      width: 22px;
      height: 100%;
      border-radius: 3px;
      border: 0;
      background: #22002f;
    }
    .tools-pressure-canvas-stage {
      display: grid;
      grid-template-rows: minmax(514px, 1fr) 44px;
      gap: 10px;
      min-width: 0;
      min-height: 0;
    }
    .tools-pressure-canvas-stage canvas {
      display: block;
      width: 100%;
      min-width: 0;
      border-radius: 0;
    }
    .tools-pressure-canvas-stage canvas[data-pressure-heatmap-main] {
      height: 100%;
      background: #171717;
    }
    .tools-pressure-canvas-stage canvas[data-pressure-heatmap-mini] {
      height: 44px;
      background: #202020;
      border: 0;
    }
    .tools-pressure-canvas-map.is-coinperps {
      border-color: rgba(255,255,255,.12);
      background: #202020;
      box-shadow: none;
    }
    .tools-pressure-canvas-map.is-coinperps .tools-pressure-canvas-scale canvas,
    .tools-pressure-canvas-map.is-coinperps .tools-pressure-canvas-stage canvas[data-pressure-heatmap-main] {
      background: #171717;
      border-color: transparent;
    }
    .tools-pressure-canvas-map.is-coinperps .tools-pressure-canvas-stage canvas[data-pressure-heatmap-mini] {
      background: #202020;
      border-color: transparent;
    }
    .tools-pressure-heatmap {
      display: block; width: 100%; height: auto;
      border: 1px solid rgba(255,255,255,.10); border-radius: 14px;
      background: #080c12;
    }
    .tools-pressure-zone-map {
      aspect-ratio: 1080 / 580;
    }
    .tools-pressure-heatmap text {
      fill: rgba(255,255,255,.62); font: 800 13px Inter, system-ui, sans-serif;
      letter-spacing: 0;
    }
    .tools-pressure-heatmap .tools-pressure-heat-title {
      fill: rgba(255,255,255,.78); font-size: 15px; font-weight: 900;
    }
    .tools-pressure-heatmap .tools-pressure-heat-label {
      fill: rgba(255,255,255,.66); font-size: 13px; font-weight: 900;
    }
    .tools-pressure-meaning {
      border-color: rgba(255,215,0,.24);
      background: linear-gradient(135deg, rgba(255,215,0,.055), transparent 48%), var(--tools-panel);
    }
    .tools-pressure-chart.compact text { font-size: 12px; }
    .tools-pressure-chart.compact .tools-pressure-axis-label,
    .tools-pressure-chart.compact .tools-pressure-zone-label,
    .tools-pressure-chart.compact .tools-pressure-current { font-size: 11px; }
    .tools-pressure-side {
      display: grid; gap: 12px; min-width: 0;
    }
    .tools-pressure-zone-list {
      display: grid;
      gap: 8px;
      margin-top: 12px;
    }
    .tools-pressure-zone-row {
      position: relative;
      display: grid; grid-template-columns: minmax(0, 1fr) auto;
      gap: 10px; align-items: center; min-width: 0;
      border: 1px solid var(--line); border-radius: 9px;
      background: var(--panel-2); padding: 10px 11px;
      outline: none;
      transition: border-color .16s ease, background .16s ease, box-shadow .16s ease, transform .16s ease;
      overflow: hidden;
    }
    .tools-pressure-zone-row::before {
      content: "";
      position: absolute;
      inset: 0 auto 0 0;
      width: 3px;
      background: rgba(255,255,255,.16);
    }
    .tools-pressure-zone-row.is-above::before { background: #34d1bd; }
    .tools-pressure-zone-row.is-below::before { background: #ff4158; }
    .tools-pressure-zone-row.is-above {
      border-color: color-mix(in srgb, var(--line) 74%, #34d1bd 26%);
    }
    .tools-pressure-zone-row.is-below {
      border-color: color-mix(in srgb, var(--line) 74%, #ff4158 26%);
    }
    .tools-pressure-zone-row.is-hovered,
    .tools-pressure-zone-row:focus-visible {
      border-color: rgba(255,215,0,.52);
      background: color-mix(in srgb, var(--panel-2) 84%, #ffd700 16%);
      box-shadow: 0 0 0 1px rgba(255,215,0,.16), 0 14px 30px rgba(0,0,0,.24);
      transform: translateY(-1px);
    }
    .tools-pressure-zone-row b {
      display: flex; align-items: center; gap: 7px; color: var(--text); font-size: 12px; font-weight: 950;
      white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    }
    .tools-pressure-zone-row b i {
      display: inline-grid; place-items: center; width: 18px; height: 18px;
      border-radius: 999px; flex: 0 0 18px; font-style: normal;
      color: #fff; background: rgba(255,255,255,.14); border: 1px solid rgba(255,255,255,.22);
      font-size: 10px; font-weight: 950;
    }
    .tools-pressure-zone-row span {
      display: block; color: var(--muted); font-size: 10.5px; font-weight: 800;
      margin-top: 2px;
    }
    .tools-pressure-zone-row strong {
      color: var(--text); font-size: 12px; font-weight: 950; white-space: nowrap;
    }
    .tools-pressure-zone-row strong.pos { color: #ff6b68; }
    .tools-pressure-zone-row strong.neg { color: #f0b35a; }
    .tools-pressure-print-row {
      position: relative;
      overflow: hidden;
    }
    .tools-pressure-print-row::before {
      content: "";
      position: absolute;
      inset: 0 auto 0 0;
      width: 3px;
      background: #34d1bd;
    }
    .tools-pressure-print-row.is-long::before { background: #ff4158; }
    .tools-ai-read-pressure {
      border-color: rgba(255,215,0,.42) !important;
      background:
        linear-gradient(135deg, rgba(255,215,0,.11), transparent 42%),
        linear-gradient(180deg, var(--tools-panel-2), var(--tools-panel)) !important;
    }
    .tools-pressure-method { border-color: rgba(255,255,255,.12); }
    .tools-pressure-empty {
      display: flex; align-items: center; justify-content: center;
      min-height: 220px; border: 1px dashed var(--line); border-radius: 12px;
      color: var(--muted); font-size: 13px; font-weight: 800;
      background: rgba(255,255,255,.025);
    }

	    #toolsPage .tools-stat,
	    #toolsPage .tools-alt-meter,
	    #toolsPage .tools-intel-card,
	    #toolsPage .tools-preview-card,
	    #toolsPage .tools-pm-card,
	    #toolsPage .tools-etf-loading,
	    #toolsPage .tools-etf-summary-card,
	    #toolsPage .tools-etf-contrib-card,
	    #toolsPage .tools-etf-chart-card,
	    #toolsPage .tools-etf-table-card,
	    #toolsPage .tools-treasury-card,
	    #toolsPage .tools-ms-grid > *,
	    #toolsPage .tools-deriv-card,
	    #toolsPage .tools-liq-card {
	      background: linear-gradient(180deg, var(--tools-panel-2), var(--tools-panel));
	      border-color: var(--tools-line);
	      box-shadow: 0 18px 45px rgba(0,0,0,.28);
	    }

	    #toolsPage .tools-strip .tools-stat {
	      background: linear-gradient(180deg, var(--tools-panel-2), var(--tools-panel));
	      border-color: var(--tools-line);
	      border-radius: 12px;
	    }

	    #toolsPage .tools-intel-card,
	    #toolsPage .tools-etf-chart-card,
	    #toolsPage .tools-etf-table-card,
	    #toolsPage .tools-treasury-card,
	    #toolsPage .tools-pm-card {
	      border-radius: 12px;
	    }

	    #toolsPage .tools-etf-summary-card.primary {
	      background: linear-gradient(180deg, var(--tools-panel-3), var(--tools-panel-2));
	    }

	    #toolsPage .tools-intel-read,
	    #toolsPage .tools-macro-pill,
	    #toolsPage .tools-alt-stat,
	    #toolsPage .tools-pm-stat,
	    #toolsPage .tools-pm-row,
	    #toolsPage .tools-preview-mini,
	    #toolsPage .tools-ms-mini-stat,
	    #toolsPage .tools-deriv-source-row,
	    #toolsPage .tools-liq-asset-row,
	    #toolsPage .tools-liq-event-row,
	    #toolsPage .tools-treasury-adapters span,
	    #toolsPage .tools-treasury-mstr-stats span,
	    #toolsPage .tools-treasury-update-row,
	    #toolsPage .tools-treasury-buy-item,
	    #toolsPage .tools-etf-meta span,
	    #toolsPage .tools-etf-read-stats span {
	      background: var(--tools-panel-3);
	      border-color: var(--tools-line);
	    }

	    #toolsPage .tools-etf-assets,
	    #toolsPage .tools-treasury-segment,
	    #toolsPage .tools-etf-range,
	    #toolsPage .tools-etf-share-btn,
	    #toolsPage .tools-treasury-toggle,
	    #toolsPage .tools-treasury-buy-filter select {
	      background: var(--tools-panel-3);
	      border-color: var(--tools-line);
	    }

	    #toolsPage .tools-etf-asset.active,
	    #toolsPage .tools-treasury-segment button.active {
	      background: var(--text);
	      color: var(--bg);
	    }

	    #toolsPage .tools-etf-range.active {
	      background: var(--text);
	      border-color: var(--text);
	      color: var(--bg);
	    }

	    #toolsPage .tools-etf-table th {
	      background: var(--tools-panel-2);
	      border-bottom-color: var(--tools-line);
	    }

	    #toolsPage .tools-etf-table td,
	    #toolsPage .tools-etf-table th {
	      border-bottom-color: var(--tools-line);
	    }

	    #toolsPage .tools-etf-chart,
	    #toolsPage .tools-treasury-mstr-chart,
	    #toolsPage .tools-treasury-adds-chart,
	    #toolsPage .tools-ms-chart {
	      background: var(--tools-panel);
	      border-color: var(--tools-line);
	    }

	    #toolsPage .tools-etf-tooltip {
	      background: rgba(16,16,16,.96);
	      border-color: var(--tools-line);
	    }

	    #toolsPage .tools-mini-bar-track,
	    #toolsPage .tools-theme-track,
	    #toolsPage .tools-alt-track,
	    #toolsPage .tools-pm-meter,
	    #toolsPage .tools-ms-bar,
	    #toolsPage .tools-treasury-bar {
	      background: rgba(255,255,255,.08);
	    }

	    #toolsPage .tools-etf-read-card.accumulation {
	      background: linear-gradient(180deg, color-mix(in srgb, var(--tools-panel-2) 88%, #00bb7f 12%), var(--tools-panel));
	      border-color: rgba(0,187,127,.34);
	    }

	    #toolsPage .tools-etf-read-card.distribution {
	      background: linear-gradient(180deg, color-mix(in srgb, var(--tools-panel-2) 88%, #ef5350 12%), var(--tools-panel));
	      border-color: rgba(239,83,80,.34);
	    }

	    #toolsPage .tools-etf-read-card.cooling,
	    #toolsPage .tools-etf-read-card.improving,
	    #toolsPage .tools-etf-note {
	      background: linear-gradient(180deg, color-mix(in srgb, var(--tools-panel-2) 88%, #f0b35a 12%), var(--tools-panel));
	      border-color: rgba(240,179,90,.34);
	    }

	    #toolsPage .tools-intel-kicker,
	    #toolsPage .tools-etf-label,
	    #toolsPage .tools-stat-label,
	    #toolsPage .tools-alt-stat-label,
	    #toolsPage .tools-pm-stat-label,
	    #toolsPage .tools-intel-label {
	      color: color-mix(in srgb, var(--muted) 82%, var(--text) 18%);
	    }

	    #toolsPage .tools-intel-title,
	    #toolsPage .tools-section-title,
	    #toolsPage .tools-etf-title,
	    #toolsPage .tools-alt-title,
	    #toolsPage .tools-pm-title {
	      color: var(--text);
	      font-weight: 900;
	      letter-spacing: 0;
	    }

	    #toolsPage .tools-intel-value,
	    #toolsPage .tools-etf-value,
	    #toolsPage .tools-ms-big,
	    #toolsPage .tools-pm-score-value {
	      font-weight: 950;
	    }

	    #toolsPage .tools-intel-copy,
	    #toolsPage .tools-section-sub,
	    #toolsPage .tools-etf-copy,
	    #toolsPage .tools-alt-sub,
	    #toolsPage .tools-pm-copy,
	    #toolsPage .tools-etf-sub,
	    #toolsPage .tools-pm-row-meta,
	    #toolsPage .tools-treasury-name {
	      color: color-mix(in srgb, var(--muted) 90%, var(--text) 10%);
	    }

	    #toolsPage .tools-etf-table tbody tr:hover,
	    #toolsPage .tools-pm-row:hover,
	    #toolsPage .tools-preview-card:hover {
	      background: var(--tools-panel-2);
	      border-color: color-mix(in srgb, var(--tools-line) 70%, var(--accent) 30%);
	    }

	    #toolsPage .tools-etf-note,
	    #toolsPage .tools-treasury-source,
	    #toolsPage .tools-preview-action,
	    #toolsPage .tools-pm-outcome,
	    #toolsPage .tools-pm-kicker {
	      color: #f0b35a;
	    }
    @media (max-width: 1000px) {
      .tools-intel-grid { grid-template-columns: 1fr; }
      .tools-preview-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
      .tools-ms-grid.three { grid-template-columns: 1fr; }
      .tools-cq-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
      .tools-liq-summary-four { grid-template-columns: repeat(2, minmax(0, 1fr)); }
      .tools-chain-layout { grid-template-columns: 1fr; }
      .tools-chain-summary { grid-template-columns: repeat(2, minmax(0, 1fr)); }
      .tools-liq-event-list { grid-template-columns: repeat(2, minmax(0, 1fr)); }
      .tools-liq-exchange-list { grid-template-columns: repeat(2, minmax(0, 1fr)); }
      .tools-liq-treemap { height: 340px; }
      .tools-pressure-layout { grid-template-columns: 1fr; }
    }
    @media (max-width: 900px) {
      .tools-strip { grid-template-columns: repeat(3, 1fr); }
      .tools-pm-grid { grid-template-columns: 1fr; }
      .tools-etf-summary { grid-template-columns: repeat(2, minmax(0, 1fr)); }
      .tools-treasury-summary { grid-template-columns: repeat(2, minmax(0, 1fr)); }
      .tools-treasury-visual-grid { grid-template-columns: 1fr; }
      .tools-ms-grid { grid-template-columns: 1fr; }
      .tools-exflow-venues { grid-template-columns: 1fr; }
    }
    @media (max-width: 600px) {
      #toolsContent {
        width: auto; max-width: 100%; overflow-x: hidden; box-sizing: border-box;
        padding: 14px 16px 96px !important;
      }
      .tools-page.visible { overflow-x: hidden; }
      .tools-tabs {
        max-width: 100%; overflow-x: auto; scrollbar-width: none;
        padding-bottom: 2px;
      }
      .tools-cq-grid { grid-template-columns: 1fr; }
      .tools-cq-counts { justify-content: flex-start; }
      .tools-cq-card { width: 100%; }
      .tools-cq-section {
        max-width: calc(100vw - 32px); overflow: hidden;
      }
      .tools-cq-section .tools-etf-chart-top {
        display: grid; grid-template-columns: 1fr; gap: 10px;
      }
      .tools-cq-read, .tools-etf-copy, .tools-section-sub {
        max-width: 100%; white-space: normal; overflow-wrap: anywhere; word-break: break-word;
      }
      .tools-cq-modal-backdrop { padding: 10px; align-items: stretch; }
      .tools-cq-modal { max-height: calc(100vh - 20px); border-radius: 12px; }
      .tools-cq-modal-head { flex-direction: column; }
      .tools-cq-modal-actions { width: 100%; justify-content: flex-start; }
      .tools-cq-explain-grid { grid-template-columns: 1fr; padding: 12px; }
      .tools-cq-modal-chart { padding: 12px 12px 0; }
      .tools-tabs::-webkit-scrollbar { display: none; }
      .tools-panel, .tools-etf-wrap, .tools-etf-summary,
      .tools-etf-summary-card, .tools-etf-chart-card, .tools-etf-table-card,
      .tools-treasury-wrap, .tools-treasury-summary, .tools-treasury-card,
      .tools-market-structure-wrap, .tools-ms-grid {
        width: 100%; max-width: 100%; min-width: 0; box-sizing: border-box;
      }
      .tools-etf-head { flex-direction: column; }
      .tools-etf-controls { flex-direction: column; align-items: stretch; }
      .tools-etf-assets {
        display: grid; grid-template-columns: repeat(3, minmax(0, 1fr));
        width: 100%; max-width: calc(100vw - 32px); justify-content: stretch;
      }
      .tools-etf-ranges { justify-content: flex-start; max-width: calc(100vw - 32px); }
      .tools-etf-asset { flex: 1 1 0; padding-left: 6px; padding-right: 6px; }
      .tools-etf-meta { display: grid; grid-template-columns: 1fr; gap: 6px; }
      .tools-etf-meta span { width: 100%; max-width: 100%; box-sizing: border-box; }
      #toolsPage [data-tools-panel="etf-flows"] .tools-section-sub,
      #toolsPage [data-tools-panel="treasury"] .tools-section-sub,
      #toolsPage [data-tools-panel="etf-flows"] .tools-etf-source-meta,
      #toolsPage [data-tools-panel="treasury"] .tools-treasury-source-meta,
      #toolsPage [data-tools-panel="treasury"] .tools-treasury-adapters {
        display: none;
      }
      #toolsPage [data-tools-panel="etf-flows"] .tools-etf-head,
      #toolsPage [data-tools-panel="treasury"] .tools-etf-head {
        gap: 8px;
      }
      #toolsPage [data-tools-panel="etf-flows"] .tools-section-title,
      #toolsPage [data-tools-panel="treasury"] .tools-section-title {
        font-size: 17px;
        line-height: 1.15;
      }
      #toolsPage [data-tools-panel="etf-flows"] .tools-etf-controls {
        gap: 7px;
      }
      #toolsPage [data-tools-panel="etf-flows"] .tools-etf-assets {
        display: flex;
        grid-template-columns: none;
        overflow-x: auto;
        scrollbar-width: none;
        gap: 5px;
        padding-bottom: 1px;
      }
      #toolsPage [data-tools-panel="etf-flows"] .tools-etf-assets::-webkit-scrollbar {
        display: none;
      }
      #toolsPage [data-tools-panel="etf-flows"] .tools-etf-asset,
      #toolsPage [data-tools-panel="etf-flows"] .tools-etf-range {
        flex: 0 0 auto;
        min-width: 42px;
        min-height: 30px;
        padding: 6px 8px;
        font-size: 11px;
        line-height: 1;
      }
      #toolsPage [data-tools-panel="etf-flows"] .tools-etf-ranges {
        gap: 5px;
      }
      #toolsPage [data-tools-panel="treasury"] .tools-etf-controls {
        gap: 6px;
        margin-bottom: 8px;
      }
      #toolsPage [data-tools-panel="treasury"] .tools-etf-assets {
        display: flex;
        grid-template-columns: none;
        gap: 6px;
      }
      #toolsPage [data-tools-panel="treasury"] .tools-etf-asset {
        flex: 0 0 auto;
        min-width: 48px;
        min-height: 30px;
        padding: 6px 10px;
        font-size: 11px;
        line-height: 1;
      }
      .tools-etf-summary { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; }
      .tools-ms-summary-three, .tools-ms-summary-four { grid-template-columns: 1fr; }
      .tools-ms-chain-row { grid-template-columns: 64px minmax(0, 1fr) 82px; gap: 7px; }
      .tools-ms-asset-head { flex-direction: column; }
      .tools-ms-mini-stat {
        display: grid; grid-template-columns: 1fr;
        align-items: start; gap: 4px;
      }
      .tools-ms-mini-stat b {
        min-width: 0; max-width: 100%; white-space: normal;
        overflow: visible; text-align: left; line-height: 1.2;
      }
      .tools-deriv-source-row { grid-template-columns: 1fr; gap: 8px; }
      .tools-deriv-source-metrics { grid-template-columns: repeat(auto-fit, minmax(64px, 1fr)); }
      .tools-liq-summary-four { grid-template-columns: 1fr; }
      .tools-chain-summary { grid-template-columns: 1fr; }
      .tools-chain-pie { min-height: 220px; }
      .tools-liq-asset-row { grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 8px; padding: 11px 12px; }
      .tools-liq-asset-row > div:first-child { grid-column: 1 / -1; }
      .tools-liq-asset-row b { font-size: 11px; white-space: normal; line-height: 1.15; }
      .tools-liq-asset-split { grid-column: 1 / -1; }
      .tools-liq-event-list { grid-template-columns: 1fr; }
      .tools-liq-exchange-list { grid-template-columns: 1fr; }
      .tools-liq-treemap { height: 300px; }
      .tools-liq-window-controls { width: 100%; justify-content: space-between; }
      .tools-liq-window-controls button { flex: 1 1 0; }
      .tools-liq-heat-head,
      .tools-liq-heat-row { grid-template-columns: 62px repeat(3, minmax(58px, 1fr)); gap: 5px; }
      .tools-liq-heat-row i { min-height: 30px; }
      .tools-liq-heat-row i em { display: none; }
      [data-tools-panel="leverage-pressure"] {
        padding-bottom: 156px;
      }
      [data-tools-panel="leverage-pressure"] .tools-etf-head {
        gap: 10px;
      }
      [data-tools-panel="leverage-pressure"] .tools-etf-head .tools-etf-controls,
      [data-tools-panel="leverage-pressure"] .tools-etf-head .tools-etf-share-btn {
        width: 100%;
        max-width: 100%;
      }
      [data-tools-panel="leverage-pressure"] .tools-etf-head > .tools-etf-share-btn {
        display: none;
      }
      .tools-pressure-summary { grid-template-columns: 1fr; gap: 8px; }
      #toolsLeveragePressureAssets .tools-etf-asset { padding-left: 4px; padding-right: 4px; }
      .tools-pressure-action-read {
        grid-template-columns: 1fr;
        gap: 5px;
        padding: 10px;
      }
      .tools-pressure-chart,
      .tools-pressure-heatmap {
        min-width: 0;
        width: 100%;
        max-width: 100%;
      }
      .tools-pressure-canvas-map {
        grid-template-columns: 42px minmax(0, 1fr);
        gap: 8px;
        min-height: 430px;
        padding: 10px;
      }
      .tools-pressure-canvas-stage {
        grid-template-rows: minmax(364px, 1fr) 38px;
        gap: 8px;
      }
      .tools-pressure-canvas-scale {
        font-size: 9px;
      }
      .tools-pressure-canvas-scale canvas {
        width: 26px;
      }
      .tools-pressure-canvas-stage canvas[data-pressure-heatmap-mini] {
        height: 38px;
      }
      .tools-pressure-mini-map .tools-pressure-chart { max-height: none; }
      .tools-pressure-chart-card {
        overflow: hidden;
        padding: 12px;
      }
      .tools-pressure-chart-card .tools-etf-chart-top { display: grid; grid-template-columns: 1fr; gap: 10px; }
      .tools-pressure-mini-head { display: grid; grid-template-columns: 1fr; gap: 10px; }
      .tools-pressure-chart-card .tools-etf-chart-actions {
        display: grid;
        grid-template-columns: 1fr 1fr;
        justify-content: stretch;
        width: 100% !important;
        max-width: 100% !important;
        gap: 7px;
      }
      .tools-pressure-window {
        grid-column: 1 / -1;
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
      }
      .tools-pressure-heat-window { grid-template-columns: repeat(4, minmax(0, 1fr)); }
      .tools-pressure-window button { padding-left: 4px; padding-right: 4px; }
      .tools-pressure-chart-card .tools-etf-share-btn { width: 100%; justify-content: center; }
      .tools-pressure-modal-backdrop { padding: 8px; align-items: stretch; }
      .tools-pressure-modal { max-height: calc(100vh - 16px); border-radius: 12px; }
      .tools-pressure-modal-chart { padding: 10px; min-width: 0; }
      .tools-pressure-modal-chart .tools-pressure-chart,
      .tools-pressure-modal-chart .tools-pressure-heatmap {
        min-width: 920px;
      }
      .tools-pressure-modal-chart .tools-pressure-canvas-map {
        min-width: 920px;
        min-height: 620px;
      }
      .tools-pressure-modal-hint { display: block; }
      .tools-pressure-zone-list { grid-template-columns: 1fr; }
      .tools-pressure-zone-row { grid-template-columns: 1fr; gap: 4px; }
      .tools-exflow-stat-grid { grid-template-columns: 1fr; }
      .tools-exflow-row { grid-template-columns: 1fr; align-items: start; }
      .tools-pressure-zone-row strong { white-space: normal; }
      .tools-etf-summary-card { padding: 11px; }
      .tools-etf-value { font-size: 17px; }
      .tools-etf-label { font-size: 9.5px; }
      .tools-etf-sub { font-size: 10.5px; }
      .tools-etf-read-card { flex-direction: column; align-items: stretch; }
      .tools-etf-read-stats { flex-direction: row; flex-wrap: wrap; }
      .tools-etf-contrib-grid { grid-template-columns: 1fr; }
      .tools-treasury-summary { grid-template-columns: 1fr; gap: 8px; }
      .tools-treasury-donut-layout { grid-template-columns: 1fr; }
      .tools-treasury-card { padding: 14px; }
      .tools-treasury-legend { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 7px 10px; }
      .tools-treasury-legend-row { gap: 6px; font-size: 11px; }
      .tools-treasury-mstr-controls { flex-direction: column; align-items: stretch; }
      .tools-treasury-buy-filter {
        justify-content: space-between; width: 100%; min-width: 0; flex-shrink: 1;
      }
      .tools-treasury-buy-filter select { width: 160px; max-width: 55%; min-width: 0; }
      .tools-treasury-pie { height: 230px; }
      .tools-treasury-mstr-chart { height: 280px; }
      .tools-treasury-adds-chart { height: 230px; }
      .tools-etf-chart { height: 280px; }
      .tools-alt-top { flex-direction: column; gap: 10px; }
      .tools-alt-grid { grid-template-columns: 1fr; }
      .tools-pm-head { flex-direction: column; }
      .tools-pm-score { text-align: left; }
      .tools-pm-row { grid-template-columns: 1fr; gap: 6px; }
      .tools-pm-row-title { white-space: normal; }
    }
    @media (max-width: 500px) {
      .tools-strip { grid-template-columns: repeat(2, 1fr); }
      .tools-preview-grid { grid-template-columns: 1fr; }
    }
    .tools-tf-row {
      display: flex; align-items: center; gap: 12px; margin-bottom: 14px;
    }
    .tools-tf-label {
      font-size: 12px; color: var(--muted); text-transform: uppercase;
      letter-spacing: .04em;
    }
    .tools-tf-pills { display: flex; gap: 6px; }
    .tools-tf-pill {
      background: var(--panel-2); border: 1px solid var(--line);
      color: var(--muted); padding: 6px 12px; border-radius: 8px;
      font-size: 12px; font-weight: 600; cursor: pointer;
    }
    .tools-tf-pill.active {
      background: rgba(0,187,127,.15); border-color: rgba(0,187,127,.4);
      color: #00bb7f;
    }
    .tools-section { margin-bottom: 28px; }
    .tools-section-head {
      display: flex; align-items: flex-start; justify-content: space-between;
      gap: 12px; margin-bottom: 10px;
    }
    .tools-section-head > div { min-width: 0; }
    .tools-section-title {
      font-size: 14px; font-weight: 700; color: var(--text);
      margin-bottom: 2px;
    }
    .tools-section-sub { font-size: 12px; color: var(--muted); }
    .tools-heatmap {
      position: relative; width: 100%; height: 420px;
      max-width: 100%; box-sizing: border-box;
      background: var(--panel); border: 1px solid var(--line);
      border-radius: 14px; overflow: hidden;
      box-shadow: inset 0 0 60px rgba(0,0,0,.25);
    }
    .tools-heatmap-tile {
      position: absolute; box-sizing: border-box; padding: 6px 8px;
      display: flex; flex-direction: column; justify-content: center;
      align-items: center; text-align: center; color: #fff;
      font-weight: 800; cursor: default; overflow: hidden;
      border: 1px solid rgba(0,0,0,.3);
      transition: transform .14s ease, box-shadow .14s ease, z-index .14s;
      background-image: linear-gradient(180deg, rgba(255,255,255,.12), rgba(0,0,0,.18));
      background-blend-mode: overlay;
    }
    .tools-heatmap-tile:hover {
      transform: scale(1.04); z-index: 5;
      box-shadow: 0 4px 18px rgba(0,0,0,.45);
      border-color: rgba(255,255,255,.5);
    }
    .tools-heatmap-tile .thmap-sym {
      font-size: 12px; line-height: 1.05; letter-spacing: .02em;
      text-shadow: 0 1px 3px rgba(0,0,0,.6), 0 0 1px rgba(0,0,0,.8);
    }
    .tools-heatmap-tile .thmap-pct {
      font-size: 11px; opacity: .95; line-height: 1.15; font-weight: 700;
      text-shadow: 0 1px 2px rgba(0,0,0,.55);
    }
    .tools-bubbles-wrap {
      position: relative;
      max-width: 100%; box-sizing: border-box;
      background: radial-gradient(ellipse at center, rgba(40,55,80,.35), var(--panel) 70%);
      border: 1px solid var(--line);
      border-radius: 14px; overflow: hidden; height: 420px;
      box-shadow: inset 0 0 80px rgba(0,0,0,.35);
    }
    .tools-bubbles { display: block; width: 100%; height: 100%; cursor: default; touch-action: none; user-select: none; }
    @media (max-width: 600px) {
      .tools-section-head { display: grid; grid-template-columns: 1fr; }
      .tools-section-head .tools-etf-share-btn { justify-self: start; }
      .tools-section { width: 100%; max-width: calc(100vw - 32px); overflow: hidden; }
      .tools-heatmap, .tools-bubbles-wrap {
        width: 100%; max-width: calc(100vw - 32px); height: 260px;
      }
      .tools-bubbles { touch-action: pan-y; }
    }

    /* BTC Monthly Returns + Average Price tables */
    .btc-mr-wrap {
      background: var(--panel); border: 1px solid var(--line);
      border-radius: 12px; overflow-x: auto; -webkit-overflow-scrolling: touch;
    }
    .btc-mr-table {
      border-collapse: separate; border-spacing: 2px;
      width: 100%; min-width: 760px;
      font-size: 12px; padding: 8px;
    }
    .btc-mr-table th, .btc-mr-table td {
      padding: 7px 6px; text-align: center; white-space: nowrap;
      border-radius: 4px; min-width: 52px;
    }
    .btc-mr-table thead th {
      font-size: 12px; font-weight: 700; color: var(--muted);
      text-transform: uppercase; letter-spacing: .04em;
      background: transparent; border: 0;
    }
    .btc-mr-table .btc-mr-year {
      font-weight: 800; color: var(--text); text-align: left;
      padding-left: 10px; min-width: 56px; background: transparent;
    }
    .btc-mr-cell {
      color: #fff; font-weight: 700;
      text-shadow: 0 1px 2px rgba(0,0,0,.4);
    }
    .btc-mr-cell.empty { background: transparent; color: var(--muted); font-weight: 400; opacity: .35; }
    .btc-mr-ytd { font-weight: 800; }
    .btc-mr-mtd::after { content: '*'; opacity: .7; margin-left: 2px; }
    .btc-mr-avg-cell {
      color: var(--text); font-weight: 600;
      background: rgba(255,255,255,.025);
    }
    .btc-mr-foot {
      padding: 8px 14px; font-size: 11px; color: var(--muted);
      border-top: 1px solid var(--line);
    }

    /* Your picks */
    .pm-your-picks { padding: 0 32px 32px; }
    .pm-picks-title {
      font-size: 13px; font-weight: 700; color: var(--muted); text-transform: uppercase;
      letter-spacing: .06em; margin-bottom: 12px; display: flex; align-items: center; gap: 8px;
    }
    .pm-pick-row {
      display: flex; align-items: center; gap: 12px; padding: 12px 16px;
      background: var(--panel); border: 1px solid var(--line); border-radius: 12px;
      margin-bottom: 8px;
    }
    .pm-pick-side {
      font-size: 12px; font-weight: 800; padding: 3px 10px; border-radius: 8px;
    }
    .pm-pick-side.yes { background: rgba(43,181,138,.12); color: #2bb58a; }
    .pm-pick-side.no { background: rgba(239,83,80,.12); color: #ef5350; }
    .pm-pick-title { font-size: 14px; color: var(--text); font-weight: 600; flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    .pm-pick-split { font-size: 12px; color: var(--muted); white-space: nowrap; }

    @media (max-width: 600px) {
      .pm-header { padding: 16px 16px 12px; }
      .pm-header-title { font-size: 20px; }
      .pm-markets { padding: 12px 12px 24px; }
      .pm-search-panel { grid-template-columns: 1fr; padding: 12px; gap: 10px; }
      .pm-search-sub { display: none; }
      .pm-search-box { display: grid; grid-template-columns: 1fr; width: 100%; }
      .pm-search-box input { width: 100%; min-width: 0; padding: 10px 12px; font-size: 13px; }
      .pm-search-box button { width: 100%; min-width: 0; padding: 0; min-height: 38px; }
      .pm-search-chips { grid-column: 1; }
      .pm-record-card { display: grid; grid-template-columns: 1fr; padding: 12px; gap: 10px; }
      .pm-record-main strong { font-size: 25px; }
      .pm-record-kpis { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; min-width: 0; }
      .pm-record-kpis > div { min-width: 0; }
      .pm-record-kpis > div:last-child { grid-column: 1 / -1; }
      .pm-record-kpis > div:last-child strong { display: flex; gap: 5px; flex-wrap: wrap; }
      .pm-event-link { padding: 12px; }
      .pm-event-title { font-size: 13px; }
      .pm-event-icon { width: 34px; height: 34px; }
      .pm-event-icon-fallback { font-size: 15px; }
      .pm-category-pills { gap: 4px; }
      .pm-cat-pill { padding: 5px 10px; font-size: 11px; }
      .pm-your-picks { padding: 0 12px 24px; }
      .pm-filters { gap: 8px; }
      .pm-event-footer { font-size: 10px; }
      .pm-event-footer-left { gap: 6px; }
    }

    /* ── PORTFOLIO MODAL ── */
    .watchlist-backdrop {
      display: none; position: fixed; inset: 0; z-index: 920;
      background: rgba(0,0,0,.65); backdrop-filter: blur(6px);
      align-items: center; justify-content: center; pointer-events: none;
    }
    .watchlist-backdrop.open { display: flex; pointer-events: auto; }
    .watchlist-modal {
      background: var(--panel); border-radius: 20px; width: 800px; max-width: 94vw;
      max-height: 90vh; display: flex; flex-direction: column;
      box-shadow: 0 24px 80px rgba(0,0,0,.5); overflow: hidden;
    }
    .watchlist-header {
      display: flex; align-items: center; justify-content: space-between;
      padding: 22px 24px 0; flex-shrink: 0;
    }
    .watchlist-header h2 { font-size: 20px; font-weight: 700; color: var(--text); margin: 0; display: flex; align-items: center; gap: 8px; }
    .wl-add-btn {
      background: var(--accent); color: #fff; border: none; border-radius: 8px;
      padding: 7px 14px; font-size: 13px; font-weight: 600; cursor: pointer; font-family: inherit;
    }
    .wl-add-btn:hover { opacity: .85; }
    .watchlist-close {
      background: var(--panel-2); border: 1px solid var(--line); color: var(--muted); font-size: 18px;
      cursor: pointer; padding: 6px 10px; border-radius: 10px;
    }
    .watchlist-close:hover { color: var(--text); background: var(--hover); }
    .pf-tabs {
      display: flex; gap: 4px; padding: 14px 24px 0; border-bottom: 1px solid var(--line);
    }
    .pf-tab {
      background: none; border: none; color: var(--muted); font-size: 13px; font-weight: 600;
      padding: 8px 16px; cursor: pointer; font-family: inherit; border-bottom: 2px solid transparent;
      transition: all .15s;
    }
    .pf-tab:hover { color: var(--text); }
    .pf-tab.active { color: var(--accent); border-bottom-color: var(--accent); }
    .watchlist-body { flex: 1; overflow-y: auto; padding: 20px 24px; -webkit-overflow-scrolling: touch; }
    .pf-summary {
      background: var(--panel-2); border: 1px solid var(--line); border-radius: 14px;
      padding: 18px 20px; margin-bottom: 20px; display: flex; align-items: center; gap: 20px;
    }
    .pf-summary-value { font-size: 28px; font-weight: 800; color: var(--text); letter-spacing: -.02em; }
    .pf-summary-label { font-size: 11px; font-weight: 600; color: var(--muted); text-transform: uppercase; letter-spacing: .05em; margin-bottom: 2px; }
    .pf-summary-pnl { font-size: 15px; font-weight: 700; }
    .wl-section { margin-bottom: 20px; }
    .wl-section-title {
      font-size: 11px; font-weight: 700; color: var(--muted); text-transform: uppercase;
      letter-spacing: .06em; margin: 0 0 8px; padding: 0 4px;
      display: flex; align-items: center; justify-content: space-between;
    }
    .wl-section-total { font-size: 11px; font-weight: 600; color: var(--muted); text-transform: none; letter-spacing: 0; }
    .wl-card {
      display: flex; flex-direction: column; gap: 0; padding: 0;
      border-radius: 10px; border: 1px solid var(--line); background: var(--panel-2);
      margin-bottom: 6px; cursor: pointer; transition: border-color .15s; overflow: hidden;
      position: relative;
    }
    .wl-card:hover { border-color: var(--accent); }
    .wl-card-top {
      display: flex; align-items: center; gap: 12px; padding: 10px 12px;
    }
    .wl-card-icon {
      width: 36px; height: 36px; border-radius: 10px; display: flex; align-items: center;
      justify-content: center; font-size: 18px; flex-shrink: 0; font-weight: 700;
    }
    .wl-card-info { flex: 1; min-width: 0; }
    .wl-card-name { font-size: 14px; font-weight: 600; color: var(--text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    .wl-card-sub { font-size: 12px; color: var(--muted); margin-top: 1px; }
    .wl-card-price { text-align: right; flex-shrink: 0; }
    .wl-card-price-val { font-size: 15px; font-weight: 700; color: var(--text); }
    .wl-card-change { font-size: 12px; font-weight: 600; }
    .wl-card-bottom {
      display: flex; align-items: center; justify-content: space-between;
      padding: 6px 12px 8px; background: rgba(255,255,255,.02); border-top: 1px solid var(--line);
      font-size: 12px;
    }
    .wl-card-position { color: var(--muted); }
    .wl-card-pnl { font-weight: 700; }
    .wl-card-alloc {
      height: 3px; background: var(--line); border-radius: 0 0 10px 10px; overflow: hidden;
    }
    .wl-card-alloc-bar { height: 100%; background: var(--accent); border-radius: 2px; transition: width .3s; }
    .wl-card-watching { font-size: 11px; color: var(--muted); font-weight: 600; padding: 0 12px 8px; }
    .wl-card-remove {
      background: none; border: none; color: var(--muted); font-size: 14px;
      cursor: pointer; padding: 4px; border-radius: 6px; opacity: 0; transition: opacity .15s;
    }
    .wl-card:hover .wl-card-remove { opacity: 1; }
    .wl-card-remove:hover { color: var(--danger); }
    .wl-card-edit {
      background: none; border: none; color: var(--muted); font-size: 12px;
      cursor: pointer; padding: 4px 6px; border-radius: 6px; opacity: 0; transition: opacity .15s;
    }
    .wl-card:hover .wl-card-edit { opacity: 1; }
    .wl-card-edit:hover { color: var(--accent); }
    .wl-search-wrap { position: relative; margin-bottom: 16px; }
    .wl-search-input {
      width: 100%; padding: 12px 14px; border-radius: 12px; border: 1px solid var(--line);
      background: var(--panel-2); color: var(--text); font-size: 15px; font-family: inherit;
      outline: none; box-sizing: border-box;
    }
    .wl-search-input:focus { border-color: var(--accent); }
    .wl-search-results { margin-top: 8px; }
    .wl-search-item {
      display: flex; align-items: center; gap: 12px; padding: 10px 12px;
      border-radius: 10px; cursor: pointer; transition: background .12s;
    }
    .wl-search-item:hover { background: var(--hover); }
    .wl-search-type {
      font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .05em;
      padding: 2px 6px; border-radius: 4px; flex-shrink: 0;
    }
    .wl-add-form {
      padding: 12px; background: var(--panel-2); border: 1px solid var(--line); border-radius: 10px;
      margin-top: 8px;
    }
    .wl-add-form-title { font-size: 14px; font-weight: 700; color: var(--text); margin-bottom: 10px; }
    .wl-add-form-row { display: flex; gap: 10px; margin-bottom: 10px; }
    .wl-add-form-input {
      flex: 1; padding: 8px 10px; border-radius: 8px; border: 1px solid var(--line);
      background: var(--panel); color: var(--text); font-size: 14px; font-family: inherit;
      outline: none; box-sizing: border-box;
    }
    .wl-add-form-input:focus { border-color: var(--accent); }
    .wl-add-form-btns { display: flex; gap: 8px; }
    .wl-add-form-btn {
      padding: 8px 16px; border-radius: 8px; border: none; font-size: 13px; font-weight: 600;
      cursor: pointer; font-family: inherit;
    }
    .wl-add-form-btn.primary { background: var(--accent); color: #fff; }
    .wl-add-form-btn.secondary { background: var(--panel); color: var(--muted); border: 1px solid var(--line); }
    .wl-add-form-btn:hover { opacity: .85; }
    .wl-edit-inline {
      display: flex; align-items: center; gap: 8px; padding: 8px 12px;
      background: rgba(255,255,255,.03); border-top: 1px solid var(--line);
    }
    .wl-edit-input {
      width: 80px; padding: 6px 8px; border-radius: 6px; border: 1px solid var(--line);
      background: var(--panel); color: var(--text); font-size: 13px; font-family: inherit; outline: none;
    }
    .wl-edit-input:focus { border-color: var(--accent); }
    .wl-edit-save {
      background: var(--accent); color: #fff; border: none; border-radius: 6px;
      padding: 6px 12px; font-size: 12px; font-weight: 600; cursor: pointer; font-family: inherit;
    }
    .wl-edit-cancel {
      background: none; border: 1px solid var(--line); color: var(--muted); border-radius: 6px;
      padding: 6px 10px; font-size: 12px; cursor: pointer; font-family: inherit;
    }
    .wl-empty { text-align: center; padding: 48px 24px; color: var(--muted); }
    .wl-empty-icon { font-size: 48px; margin-bottom: 12px; }
    .wl-empty-text { font-size: 15px; line-height: 1.6; }
    @media (max-width: 600px) {
      .watchlist-modal { max-width: 100vw; max-height: 100vh; height: 100vh; border-radius: 0; width: 100vw; }
      .watchlist-header { padding: 16px 18px 0; }
      .pf-tabs { padding: 12px 18px 0; }
      .watchlist-body { padding: 16px; }
      .pf-summary { flex-direction: column; align-items: flex-start; gap: 8px; padding: 14px 16px; }
      .pf-summary-value { font-size: 24px; }
      .wl-card-top { padding: 8px 10px; gap: 10px; }
      .wl-card-icon { width: 32px; height: 32px; font-size: 16px; }
      .wl-card-name { font-size: 13px; }
      .wl-card-price-val { font-size: 14px; }
      .wl-card-remove { opacity: 1; }
      .wl-card-edit { opacity: 1; }
      .wl-add-form-row { flex-direction: column; gap: 8px; }
    }

    /* ── FULL-PAGE PORTFOLIO ── */
    /* ── Discovery page ── */
    .discovery-page {
      display: none; flex: 1; flex-direction: column; overflow-y: auto;
      -webkit-overflow-scrolling: touch; background: var(--bg);
      scrollbar-width: thin; min-height: 0; width: 100%;
    }
    .discovery-page.visible { display: flex; }
    .george-only-nav { display: none !important; }
    body.george-mode-on .george-only-nav { display: flex !important; }
    .foryou-page { background: var(--bg); }
    .foryou-shell { width: 100%; max-width: 1320px; margin: 0 auto; padding: 18px 28px 110px; color: var(--text); }
    .foryou-shell:has(.fy-onboard) { min-height: calc(100dvh - 40px); display: flex; align-items: center; justify-content: center; padding-top: 34px; }
    .fy-top-actions { display: flex; justify-content: flex-end; gap: 8px; flex-wrap: wrap; margin-bottom: 12px; }
    .fy-kicker { font-size: 11px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; color: var(--accent); margin-bottom: 8px; }
    .fy-title { font-size: 32px; line-height: 1.05; font-weight: 800; letter-spacing: 0; margin: 0; }
    .fy-sub { max-width: 760px; color: var(--muted); font-size: 14px; line-height: 1.55; margin-top: 8px; }
    .fy-actions { display: flex; gap: 8px; flex-wrap: wrap; justify-content: flex-end; }
    .fy-btn { border: 1px solid var(--line); background: var(--panel); color: var(--text); border-radius: 8px; padding: 9px 12px; font-size: 12px; font-weight: 700; cursor: pointer; }
    .fy-btn:hover { background: var(--hover); }
    .fy-btn.primary { background: var(--accent); border-color: var(--accent); color: #fff; }
    .fy-setup { margin-top: 16px; border: 1px solid rgba(232,87,42,.28); border-radius: 8px; background: rgba(232,87,42,.06); padding: 18px; }
    .fy-onboard { width: min(820px, 100%); max-width: 820px; margin: 0 auto; border: 1px solid rgba(232,87,42,.32); border-radius: 8px; background: linear-gradient(180deg, rgba(232,87,42,.12), rgba(255,255,255,.025)); padding: 30px; box-shadow: 0 24px 70px rgba(0,0,0,.24); }
    .fy-animate-in { animation: fyStepIn .28s ease both; }
    @keyframes fyStepIn { from { opacity: 0; transform: translateY(10px) scale(.99); } to { opacity: 1; transform: translateY(0) scale(1); } }
    .fy-progress { height: 7px; border-radius: 999px; background: rgba(255,255,255,.08); overflow: hidden; margin-bottom: 18px; }
    .fy-progress span { display: block; height: 100%; border-radius: inherit; background: var(--accent); transition: width .28s ease; }
    .fy-dots { display: flex; gap: 6px; margin-bottom: 14px; }
    .fy-dots span { width: 7px; height: 7px; border-radius: 99px; background: rgba(255,255,255,.16); transition: width .22s ease, background .22s ease; }
    .fy-dots span.active { width: 24px; background: var(--accent); }
    .fy-dots span.done { background: rgba(43,213,150,.74); }
    .fy-onboard-kicker { color: var(--accent); text-transform: uppercase; letter-spacing: .08em; font-size: 11px; font-weight: 900; margin-bottom: 8px; }
    .fy-onboard-title { font-size: 30px; line-height: 1.12; font-weight: 850; letter-spacing: 0; max-width: 660px; }
    .fy-onboard-copy { color: var(--muted); font-size: 14px; line-height: 1.6; margin-top: 10px; max-width: 680px; }
    .fy-choice-row, .fy-onboard-actions { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 20px; }
    .fy-onboard-actions { justify-content: space-between; align-items: center; }
    .fy-choice { border: 1px solid var(--line); background: var(--panel); color: var(--text); border-radius: 8px; min-width: 112px; padding: 11px 16px; cursor: pointer; font-size: 13px; font-weight: 800; transition: transform .16s ease, background .16s ease, border-color .16s ease; }
    .fy-choice:hover { transform: translateY(-1px); background: var(--hover); }
    .fy-choice.primary { background: var(--accent); border-color: var(--accent); color: #fff; }
    .fy-choice-tile { flex: 1; min-width: 220px; text-align: left; border: 1px solid var(--line); background: rgba(255,255,255,.025); color: var(--text); border-radius: 8px; padding: 18px; cursor: pointer; transition: transform .16s ease, border-color .16s ease, background .16s ease; }
    .fy-choice-tile:hover { transform: translateY(-2px); border-color: rgba(232,87,42,.55); background: rgba(232,87,42,.08); }
    .fy-choice-tile b { display: block; font-size: 16px; margin-bottom: 5px; }
    .fy-choice-tile span { color: var(--muted); font-size: 13px; line-height: 1.45; }
    .fy-intro-preview { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; margin-top: 20px; }
    .fy-intro-preview div { border: 1px solid var(--line); border-radius: 8px; padding: 13px; background: rgba(255,255,255,.025); }
    .fy-intro-preview b { display: block; font-size: 13px; margin-bottom: 5px; }
    .fy-intro-preview span { display: block; color: var(--muted); font-size: 12px; line-height: 1.4; }
    .fy-wizard-input { width: 100%; border: 1px solid var(--line); background: var(--panel); color: var(--text); border-radius: 8px; padding: 11px 12px; font-size: 14px; }
    .fy-topic-groups { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; margin-top: 20px; }
    .fy-topic-group { border: 1px solid var(--line); border-radius: 8px; padding: 12px; background: rgba(255,255,255,.022); }
    .fy-topic-group-label { color: var(--muted); font-size: 11px; font-weight: 850; text-transform: uppercase; letter-spacing: .06em; }
    .fy-setup-head { display: flex; justify-content: space-between; gap: 12px; align-items: flex-start; margin-bottom: 16px; }
    .fy-setup-title { font-size: 20px; font-weight: 800; }
    .fy-setup-copy { color: var(--muted); font-size: 13px; line-height: 1.5; margin-top: 4px; }
    .fy-settings-section { border-top: 1px solid rgba(255,255,255,.08); padding-top: 15px; margin-top: 15px; }
    .fy-settings-section-head { display: flex; justify-content: space-between; align-items: baseline; gap: 16px; margin-bottom: 10px; }
    .fy-settings-section-head b { font-size: 14px; color: var(--text); }
    .fy-settings-section-head span { color: var(--muted); font-size: 12px; line-height: 1.4; text-align: right; }
    .fy-setup-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 8px; }
    .fy-module-toggle { border: 1px solid var(--line); border-radius: 8px; background: rgba(255,255,255,.025); padding: 10px 12px; cursor: pointer; display: grid; grid-template-columns: auto 1fr; gap: 10px; align-items: center; min-height: 52px; }
    .fy-module-toggle input { margin: 0; accent-color: var(--accent); }
    .fy-module-toggle b { display: block; font-size: 13px; margin-bottom: 2px; }
    .fy-module-toggle span { color: var(--muted); font-size: 11.5px; line-height: 1.35; }
    .fy-custom-fields { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 14px; }
    .fy-field { display: flex; flex-direction: column; gap: 6px; }
    .fy-field-wide { grid-column: 1 / -1; }
    .fy-settings-section .fy-field + .fy-field { margin-top: 16px; }
    .fy-field label { font-size: 12px; color: var(--muted); font-weight: 700; }
    .fy-field input { border: 1px solid var(--line); background: var(--panel); color: var(--text); border-radius: 8px; padding: 10px 12px; font-size: 13px; }
    .fy-pick-grid { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; }
    .fy-pick { display: inline-flex; align-items: center; justify-content: center; gap: 7px; min-height: 38px; border: 1px solid var(--line); background: var(--panel); color: var(--text); border-radius: 999px; padding: 8px 13px; cursor: pointer; text-align: center; white-space: nowrap; transition: background .16s ease, border-color .16s ease, color .16s ease, transform .16s ease; }
    .fy-pick:hover { background: var(--hover); border-color: rgba(232,87,42,.36); }
    .fy-pick.active { background: rgba(232,87,42,.18); border-color: var(--accent); color: #fff; }
    .fy-pick b { font-size: 12px; line-height: 1.2; font-weight: 800; }
    .fy-pick span { color: var(--muted); font-size: 11px; font-weight: 800; text-transform: uppercase; }
    .fy-pick.active span { color: rgba(255,255,255,.76); }
    .fy-topic-row { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 10px; }
    .fy-topic { min-height: 38px; border: 1px solid var(--line); background: var(--panel); color: var(--text); border-radius: 999px; padding: 8px 13px; font-size: 12px; font-weight: 800; line-height: 1.2; cursor: pointer; white-space: nowrap; transition: background .16s ease, border-color .16s ease, color .16s ease, transform .16s ease; }
    .fy-topic:hover, .fy-pick:hover { transform: translateY(-1px); }
    .fy-topic.active { color: #fff; border-color: var(--accent); background: var(--accent); }
    .fy-topic-row-large { margin-top: 20px; gap: 8px; }
    .fy-topic-row-large .fy-topic { min-height: 38px; padding: 8px 13px; font-size: 12px; }
    .fy-settings-topic-groups { grid-template-columns: 1fr; gap: 10px; margin-top: 10px; }
    .fy-settings-topic-groups .fy-topic-group { padding: 10px; }
    .fy-suggest-strip { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 14px; }
    .fy-suggest-strip button { min-height: 36px; text-align: left; border: 1px solid var(--line); background: var(--panel); color: var(--text); border-radius: 999px; padding: 8px 12px; cursor: pointer; font-size: 12px; font-weight: 800; line-height: 1.25; max-width: 310px; }
    .fy-suggest-strip button:hover { background: var(--hover); border-color: rgba(232,87,42,.38); }
    .fy-empty { color: var(--muted); font-size: 13px; line-height: 1.5; padding: 8px 0; }
    .fy-empty b { display: block; color: var(--text); margin-bottom: 4px; }
    .fy-empty span { display: block; color: var(--muted); }
    .fy-skeleton-list { display: grid; gap: 10px; padding: 6px 0; }
    .fy-skeleton-list span { display: block; height: 46px; border-radius: 8px; background: linear-gradient(90deg, rgba(255,255,255,.04), rgba(255,255,255,.09), rgba(255,255,255,.04)); background-size: 220% 100%; animation: fyShimmer 1.1s linear infinite; }
    @keyframes fyShimmer { to { background-position: -220% 0; } }
    .fy-question-grid { display: grid; gap: 8px; }
    .fy-question { text-align: left; border: 1px solid var(--line); background: rgba(255,255,255,.025); color: var(--text); border-radius: 8px; padding: 10px 12px; cursor: pointer; font-size: 13px; font-weight: 700; }
    .fy-question:hover { background: var(--hover); }
    .fy-loading { color: var(--muted); padding: 30px; }

    /* ============================================================
       For-You editorial cover — dual-lead with hairline column rule
       ============================================================ */
    .fy-cover { display: grid; grid-template-columns: minmax(0, 3fr) 1px minmax(0, 2fr); background: var(--fy-bg-paper); border: 1px solid var(--fy-rule); border-radius: 4px; margin: 0 0 28px; overflow: hidden; }
    .fy-cover-rule { background: var(--fy-rule); width: 1px; align-self: stretch; }
    .fy-cover-article { display: block; color: var(--fy-ink); text-decoration: none; border-top: 2px solid transparent; position: relative; isolation: isolate; transition: background-color .2s ease; }
    .fy-cover-article.fy-cover-primary   { padding: 38px 42px 36px; }
    .fy-cover-article.fy-cover-secondary { padding: 38px 36px 36px; }
    .fy-cover-article:hover { background: color-mix(in srgb, var(--fy-accent) 4%, transparent); }
    .fy-cover-article.fy-tone-up   { border-top-color: var(--fy-up); }
    .fy-cover-article.fy-tone-down { border-top-color: var(--fy-down); }
    .fy-cover-empty { background: transparent; }
    .fy-cover-eyebrow { display: flex; align-items: baseline; gap: 22px; margin-bottom: 22px; }
    .fy-cover-ordinal { font-family: "Source Serif 4", "Source Serif Pro", Georgia, serif; font-style: italic; font-weight: 400; font-size: 13px; line-height: 1; color: var(--fy-accent); position: relative; padding: 0 14px; white-space: nowrap; }
    .fy-cover-ordinal::before, .fy-cover-ordinal::after { content: ""; position: absolute; top: 50%; width: 10px; height: 1px; background: currentColor; opacity: .55; }
    .fy-cover-ordinal::before { left: 0; }
    .fy-cover-ordinal::after  { right: 0; }
    .fy-cover-secondary .fy-cover-ordinal { color: var(--fy-ink-muted); }
    .fy-cover-kicker { font-size: 11px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--fy-ink-muted); line-height: 1.1; }
    .fy-cover-image { display: block; width: 100%; aspect-ratio: 16 / 10; background: var(--fy-bg); margin-bottom: 24px; overflow: hidden; position: relative; }
    .fy-cover-image img { width: 100%; height: 100%; object-fit: cover; display: block; filter: saturate(.92) contrast(1.02); }
    .fy-cover-noimage { display: flex; flex-direction: column; justify-content: flex-end; align-items: flex-end; padding: 22px 24px; border: 1px solid var(--fy-rule); background: radial-gradient(110% 80% at 100% 100%, var(--fy-noimage-tint, color-mix(in srgb, var(--fy-accent) 18%, transparent)), transparent 70%), var(--fy-bg); }
    .fy-cover-noimage.fy-tone-up   { --fy-noimage-tint: color-mix(in srgb, var(--fy-up)   22%, transparent); }
    .fy-cover-noimage.fy-tone-down { --fy-noimage-tint: color-mix(in srgb, var(--fy-down) 22%, transparent); }
    .fy-cover-pct { font-family: ui-monospace, "JetBrains Mono", "SF Mono", Menlo, monospace; font-size: 46px; font-weight: 800; line-height: 1; letter-spacing: -.02em; }
    .fy-cover-secondary .fy-cover-pct { font-size: 36px; }
    .fy-cover-pct.up   { color: var(--fy-up); }
    .fy-cover-pct.down { color: var(--fy-down); }
    .fy-cover-symbol { font-family: ui-monospace, "JetBrains Mono", "SF Mono", Menlo, monospace; font-size: 13px; font-weight: 700; letter-spacing: .14em; color: var(--fy-ink-muted); margin-top: 8px; }
    .fy-cover-headline { font-family: "Source Serif 4", "Source Serif Pro", Georgia, "Times New Roman", serif; font-weight: 600; margin: 0; letter-spacing: -.005em; text-wrap: balance; color: var(--fy-ink); transition: color .18s ease; }
    .fy-cover-primary   .fy-cover-headline { font-size: 32px; line-height: 1.12; }
    .fy-cover-secondary .fy-cover-headline { font-size: 22px; line-height: 1.18; }
    .fy-cover-article:hover .fy-cover-headline { color: var(--fy-accent); }
    .fy-cover-body { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, system-ui, sans-serif; font-size: 15px; font-weight: 400; line-height: 1.55; color: var(--fy-ink-muted); margin: 14px 0 0; max-width: 62ch; text-wrap: pretty; }
    .fy-cover-secondary .fy-cover-body { font-size: 14.5px; margin-top: 12px; }
    .fy-cover-arrow { display: inline-block; margin-left: 8px; color: var(--fy-accent); font-weight: 600; transition: transform .2s ease; }
    .fy-cover-article:hover .fy-cover-arrow { transform: translateX(4px); }
    @keyframes fy-cover-rise { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
    .fy-cover-primary   { animation: fy-cover-rise .45s cubic-bezier(.2,.7,.2,1) both; }
    .fy-cover-secondary { animation: fy-cover-rise .45s cubic-bezier(.2,.7,.2,1) both .12s; }
    @media (prefers-reduced-motion: reduce) {
      .fy-cover-primary, .fy-cover-secondary { animation: none; }
      .fy-cover-arrow { transition: none; }
    }
    @media (max-width: 900px) {
      .fy-cover { grid-template-columns: 1fr; }
      .fy-cover-rule { display: none; }
      .fy-cover-article.fy-cover-primary, .fy-cover-article.fy-cover-secondary { padding: 24px 22px; }
      .fy-cover-article.fy-cover-secondary { border-top: 1px solid var(--fy-rule); }
      .fy-cover-article.fy-cover-secondary.fy-tone-up,
      .fy-cover-article.fy-cover-secondary.fy-tone-down { border-top-width: 2px; }
      .fy-cover-primary   .fy-cover-headline { font-size: 24px; }
      .fy-cover-secondary .fy-cover-headline { font-size: 18px; }
      .fy-cover-pct { font-size: 38px; }
      .fy-cover-secondary .fy-cover-pct { font-size: 30px; }
      .fy-cover-image { margin-bottom: 18px; }
    }

    /* ============================================================
       For-You hero — Briefing + Watch (variant A)
       Section heads match the rest of the page (serif title + meta).
       No chips block; data anchors row sits at the bottom of the brief.
       ============================================================ */
    .fy-brief { display: grid; grid-template-columns: minmax(0, 3fr) minmax(0, 2fr); background: var(--fy-bg-paper); border: 1px solid var(--fy-rule); border-radius: 4px; margin: 0 0 28px; overflow: hidden; }
    .fy-brief-main { padding: 28px 36px 26px; min-width: 0; display: flex; flex-direction: column; }
    .fy-onwatch { padding: 28px 32px 26px; min-width: 0; border-left: 1px solid var(--fy-rule); display: flex; flex-direction: column; }
    .fy-brief-head { gap: 14px; }
    .fy-brief-head .fy-section-title { font-size: 18px; }
    .fy-brief-mood { font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 10px; font-weight: 800; letter-spacing: .2em; text-transform: uppercase; padding: 3px 8px; border: 1px solid currentColor; line-height: 1; }
    .fy-brief-mood.up { color: var(--fy-up); }
    .fy-brief-mood.down { color: var(--fy-down); }
    .fy-brief-mood.neutral { color: var(--fy-ink-muted); }
    .fy-brief-fallback { font-family: ui-monospace, monospace; font-size: 9px; letter-spacing: .14em; text-transform: uppercase; color: var(--fy-ink-muted); padding: 2px 6px; border: 1px solid var(--fy-rule); border-radius: 2px; margin-left: 6px; }
    .fy-brief-settings { font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 11px; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; color: var(--fy-accent); text-decoration: none; white-space: nowrap; }
    .fy-brief-settings:hover { text-decoration: underline; }
    .fy-brief-take { font-family: "Source Serif 4", "Source Serif Pro", Georgia, "Times New Roman", serif; font-size: 26px; font-weight: 600; line-height: 1.22; color: var(--fy-ink); margin: 0 0 16px; max-width: none; letter-spacing: -.012em; text-wrap: balance; }
    .fy-brief-lead { font-family: "Source Serif 4", "Source Serif Pro", Georgia, "Times New Roman", serif; font-size: 17px; font-weight: 400; line-height: 1.5; color: var(--fy-ink-muted); margin: 0; max-width: none; text-wrap: pretty; }
    .fy-brief-read-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; margin-top: 15px; }
    .fy-brief-read-block { border-top: 1px solid var(--fy-rule); padding-top: 12px; min-width: 0; }
    .fy-brief-read-block.wide { grid-column: 1 / -1; }
    .fy-brief-read-label { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif; font-size: 13px; font-weight: 750; letter-spacing: 0; color: var(--fy-ink); margin-bottom: 8px; }
    .fy-brief-read-block ul { margin: 0; padding: 0 0 0 17px; display: grid; gap: 6px; }
    .fy-brief-read-block li, .fy-brief-read-block p { color: var(--fy-ink-muted); font-size: 15px; line-height: 1.48; margin: 0; }
    .fy-brief-read-block li::marker { color: var(--fy-accent); }
    .fy-brief-followups { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 14px; padding-top: 14px; border-top: 1px solid var(--fy-rule); }
    .fy-brief-followup { background: color-mix(in srgb, var(--fy-accent) 8%, transparent); border: 1px solid color-mix(in srgb, var(--fy-accent) 34%, var(--fy-rule)); border-radius: 999px; padding: 7px 14px; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif; font-size: 13px; font-weight: 700; color: var(--fy-accent); cursor: pointer; transition: background .15s ease, border-color .15s ease, transform .15s ease; }
    .fy-brief-followup:hover { background: color-mix(in srgb, var(--fy-accent) 13%, transparent); border-color: var(--fy-accent); transform: translateY(-1px); }
    .fy-brief-loading { display: grid; gap: 12px; padding: 2px 0 4px; }
    .fy-brief-loading.compact { gap: 10px; }
    .fy-brief-loading-line { display: flex; align-items: center; gap: 10px; font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 11px; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; color: var(--fy-ink-muted); min-height: 24px; }
    .fy-brief-loading-line span { width: 7px; height: 7px; border-radius: 50%; background: var(--fy-rule); flex: 0 0 auto; }
    .fy-brief-loading-line.active { color: var(--fy-accent); }
    .fy-brief-loading-line.active span { background: var(--fy-accent); box-shadow: 0 0 0 0 color-mix(in srgb, var(--fy-accent) 42%, transparent); animation: fyPulseDot 1.25s ease-out infinite; }
    @keyframes fyPulseDot { 0% { box-shadow: 0 0 0 0 color-mix(in srgb, var(--fy-accent) 42%, transparent); } 100% { box-shadow: 0 0 0 10px transparent; } }

    .fy-onwatch-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 14px; }
    .fy-onwatch-item { padding: 8px 0 10px 14px; border-left: 2px solid var(--fy-rule); transition: border-color .2s ease; }
    .fy-onwatch-item.portfolio { border-left-color: var(--fy-accent); }
    .fy-onwatch-item.macro { border-left-color: var(--fy-ink-muted); }
    .fy-onwatch-item.market { border-left-color: var(--fy-up); }
    .fy-onwatch-item.calendar { border-left-color: var(--fy-accent); }
    .fy-onwatch-item.news { border-left-color: var(--fy-ink-muted); }
    .fy-onwatch-tag { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif; font-size: 12px; font-weight: 750; letter-spacing: 0; color: var(--fy-ink-muted); margin-bottom: 5px; }
    .fy-onwatch-countdown { color: var(--fy-accent); font-weight: 700; }
    .fy-onwatch-title { font-family: "Source Serif 4", Georgia, serif; font-size: 17px; font-weight: 600; line-height: 1.24; color: var(--fy-ink); margin-bottom: 5px; text-wrap: balance; }
    .fy-onwatch-copy { font-size: 14px; line-height: 1.5; color: var(--fy-ink-muted); margin: 0; }
    .fy-onwatch-empty { font-family: "Source Serif 4", Georgia, serif; font-style: italic; font-size: 14px; color: var(--fy-ink-muted); margin: 0; }

    @keyframes fy-brief-rise { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
    .fy-brief-main { animation: fy-brief-rise .45s cubic-bezier(.2,.7,.2,1) both; }
    .fy-onwatch { animation: fy-brief-rise .45s cubic-bezier(.2,.7,.2,1) both .12s; }
    @media (prefers-reduced-motion: reduce) {
      .fy-brief-main, .fy-onwatch { animation: none; }
    }

    @media (max-width: 900px) {
      .fy-brief { grid-template-columns: 1fr; margin-bottom: 18px; }
      .fy-brief-main { padding: 20px 18px 18px; }
      .fy-onwatch { display: none; }
      .fy-brief-head { margin-bottom: 10px; }
      .fy-brief-head .fy-section-meta { margin-left: auto; }
      .fy-brief-take { font-size: 21px; margin-bottom: 12px; }
      .fy-brief-lead { font-size: 16px; }
      .fy-brief-read-grid { grid-template-columns: 1fr; gap: 11px; margin-top: 12px; }
      .fy-brief-read-block.wide { grid-column: auto; }
      .fy-brief-confirm,
      .fy-brief-change { display: none; }
      .fy-brief-summary li:nth-child(n+3) { display: none; }
      .fy-brief-read-block { padding-top: 10px; }
      .fy-brief-read-label { font-size: 14px; margin-bottom: 7px; }
      .fy-brief-read-block ul { gap: 5px; }
      .fy-brief-read-block li,
      .fy-brief-read-block p { font-size: 14px; line-height: 1.42; }
      .fy-brief-followups { gap: 8px; margin-top: 12px; padding-top: 12px; }
      .fy-brief-followup { width: 100%; border-radius: 6px; padding: 9px 12px; text-align: left; }
    }

    /* Quiet text-link top affordances (replace pill buttons) */
    .fy-top-actions.fy-top-text { gap: 18px; padding: 8px 0 14px; }
    .fy-top-actions.fy-top-text a { color: var(--fy-ink-muted); font-size: 12px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; text-decoration: none; cursor: pointer; }
    .fy-top-actions.fy-top-text a:hover { color: var(--fy-accent); }
    .fy-top-actions.fy-top-text a + a { border-left: 1px solid var(--fy-rule); padding-left: 18px; }

    /* ============================================================
       For-You editorial modules (sections / news rows / ticker /
       macro / x-posts) — replaces the old fy-card system
       ============================================================ */
    .fy-grid { display: grid; grid-template-columns: minmax(0, 8fr) minmax(0, 4fr); gap: 40px 32px; margin-top: 8px; align-items: start; }
    .fy-section { grid-column: 1 / -1; min-width: 0; color: var(--fy-ink); }
    .fy-grid > .fy-section.col-l { grid-column: 1; }
    .fy-rail { grid-column: 2; display: flex; flex-direction: column; gap: 32px; min-width: 0; }
    .fy-rail > .fy-section { grid-column: auto; }
    .fy-section-head { display: flex; align-items: baseline; gap: 18px; margin-bottom: 18px; padding-bottom: 14px; border-bottom: 1px solid var(--fy-rule); flex-wrap: wrap; }
    .fy-section-eyebrow { font-family: ui-monospace, "JetBrains Mono", "SF Mono", Menlo, monospace; font-size: 10px; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--fy-ink-muted); }
    .fy-section-title { font-family: "Source Serif 4", "Source Serif Pro", Georgia, serif; font-size: 22px; font-weight: 600; line-height: 1; letter-spacing: -.005em; margin: 0; color: var(--fy-ink); }
    .fy-section-meta { margin-left: auto; font-size: 11px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--fy-ink-muted); white-space: nowrap; }
    .fy-section-foot { margin-top: 16px; padding-top: 12px; border-top: 1px solid var(--fy-rule); }
    .fy-section-foot a { font-family: ui-monospace, "JetBrains Mono", monospace; letter-spacing: .14em; text-transform: uppercase; font-size: 11px; color: var(--fy-accent); text-decoration: none; font-weight: 700; }
    .fy-section-foot a:hover { text-decoration: underline; }
    /* Section meta as link — for Portfolio "Open Portfolio →" etc. */
    .fy-section-meta-link { color: var(--fy-accent); text-decoration: none; cursor: pointer; }
    .fy-section-meta-link:hover { text-decoration: underline; }
    .fy-meta-button { border: 0; background: transparent; padding: 0; font: inherit; }
    .fy-limited-note { margin-top: 10px; color: var(--fy-ink-muted); font-size: 12.5px; font-style: italic; }

    /* "Add" pill with tooltip — used in Watchlist section */
    .fy-add-meta { margin-left: auto; position: relative; }
    .fy-add-pill { font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 11px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--fy-accent); background: transparent; border: 1px solid var(--fy-accent); border-radius: 2px; padding: 5px 11px; cursor: pointer; transition: background .18s ease, color .18s ease; }
    .fy-add-pill:hover { background: var(--fy-accent); color: var(--fy-bg-paper); }
    .fy-add-meta::after {
      content: attr(data-tip);
      position: absolute;
      top: calc(100% + 10px);
      right: 0;
      width: 280px;
      max-width: calc(100vw - 32px);
      padding: 12px 14px;
      background: var(--fy-bg-paper);
      border: 1px solid var(--fy-rule);
      border-radius: 4px;
      font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
      font-size: 12.5px;
      font-weight: 400;
      line-height: 1.5;
      letter-spacing: 0;
      text-transform: none;
      color: var(--fy-ink);
      opacity: 0;
      pointer-events: none;
      transition: opacity .18s ease;
      z-index: 50;
      box-shadow: 0 8px 24px rgba(0,0,0,.30);
      white-space: normal;
    }
    .fy-add-meta:hover::after, .fy-add-pill:focus + ::after, .fy-add-pill:focus-visible ~ ::after { opacity: 1; }
    /* When user hovers anywhere within fy-add-meta the tooltip shows. We pass the tip via data-tip on the wrapper too. */
    .fy-section-empty { font-family: "Source Serif 4", Georgia, serif; font-style: italic; font-size: 15px; line-height: 1.55; color: var(--fy-ink-muted); margin: 0; padding: 6px 0; }

    /* News module */
    .fy-news-lead { display: grid; grid-template-columns: minmax(220px, 280px) minmax(0, 1fr); gap: 24px; padding-bottom: 24px; margin-bottom: 18px; border-bottom: 1px solid var(--fy-rule); }
    .fy-news-lead.no-thumb { grid-template-columns: 1fr; }
    .fy-news-lead-thumb { display: block; aspect-ratio: 4 / 3; background: var(--fy-bg); overflow: hidden; border-radius: 2px; }
    .fy-news-lead-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; filter: saturate(.92); }
    .fy-news-row-meta { font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 11.5px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--fy-ink-muted); margin-bottom: 7px; }
    .fy-news-lead-tag { color: var(--fy-accent); margin-right: 6px; }
    .fy-news-lead-title { display: block; font-family: "Source Serif 4", Georgia, serif; font-size: 22px; font-weight: 600; line-height: 1.18; color: var(--fy-ink); text-decoration: none; margin: 0 0 10px; transition: color .18s ease; text-wrap: balance; }
    .fy-news-lead-title:hover { color: var(--fy-accent); }
    .fy-news-lead-excerpt { font-size: 14.5px; line-height: 1.55; color: var(--fy-ink-muted); margin: 0; }
    .fy-news-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 16px; }
    .fy-news-row { display: grid; grid-template-columns: 84px minmax(0, 1fr); gap: 16px; padding-bottom: 16px; border-bottom: 1px solid var(--fy-rule); }
    .fy-news-row.no-thumb { grid-template-columns: 1fr; }
    .fy-news-row:last-child { border-bottom: 0; padding-bottom: 0; }
    .fy-news-row-thumb { display: block; width: 84px; height: 60px; background: var(--fy-bg); border-radius: 2px; overflow: hidden; flex-shrink: 0; }
    .fy-news-row-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
    .fy-news-row-thumb.placeholder { background: linear-gradient(135deg, var(--fy-bg-paper), color-mix(in srgb, var(--fy-bg) 70%, var(--fy-accent) 30%)); }
    .fy-news-row-title { display: block; font-family: "Source Serif 4", Georgia, serif; font-size: 16px; font-weight: 600; line-height: 1.25; color: var(--fy-ink); text-decoration: none; margin: 4px 0 0; transition: color .18s ease; }
    .fy-news-row-title:hover { color: var(--fy-accent); }
    .fy-news-row-excerpt { font-family: "Source Serif 4", Georgia, serif; font-size: 13.5px; line-height: 1.45; color: var(--fy-ink-muted); margin: 6px 0 0; }
    .fy-news-follow { margin-top: 8px; }
    .fy-news-follow-btn { background: transparent; border: 1px solid var(--fy-rule); padding: 6px 12px; border-radius: 999px; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif; font-size: 12.5px; font-weight: 600; color: var(--fy-accent); cursor: pointer; transition: background .15s ease, border-color .15s ease; }
    .fy-news-follow-btn:hover { background: color-mix(in srgb, var(--fy-accent) 8%, transparent); border-color: var(--fy-accent); }

    /* Ticker (watchlist / movers / portfolio) */
    .fy-ticker { margin: 0; padding: 0; display: grid; gap: 0; }
    .fy-ticker-subhead { font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 10px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--fy-ink-muted); margin: 14px 0 4px; padding-top: 10px; border-top: 1px solid var(--fy-rule); }
    .fy-ticker-subhead:first-child { margin-top: 0; padding-top: 0; border-top: 0; }
    .fy-ticker-row { display: grid; grid-template-columns: 22px minmax(0, 1fr) auto auto; gap: 14px; align-items: baseline; padding: 13px 0; border-bottom: 1px solid var(--fy-rule); }
    .fy-ticker-row:last-child { border-bottom: 0; }
    .fy-ticker-roman { font-family: "Source Serif 4", Georgia, serif; font-style: italic; font-size: 11px; color: var(--fy-ink-muted); text-align: right; line-height: 1; }
    .fy-ticker-sym { font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 14.5px; font-weight: 700; letter-spacing: .04em; color: var(--fy-ink); min-width: 0; overflow: hidden; text-overflow: ellipsis; }
    .fy-ticker-name { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; font-weight: 400; letter-spacing: 0; font-size: 12.5px; color: var(--fy-ink-muted); margin-left: 8px; text-transform: none; }
    .fy-ticker-price { font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 14.5px; color: var(--fy-ink); text-align: right; white-space: nowrap; }
    .fy-ticker-pct { font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 14px; font-weight: 700; text-align: right; white-space: nowrap; min-width: 70px; }
    .fy-ticker-pct.up { color: var(--fy-up); }
    .fy-ticker-pct.down { color: var(--fy-down); }
    .fy-ticker-pct.neutral { color: var(--fy-ink-muted); }

    /* Macro module */
    /* Global tape — at the top of Macro section, like a defensive stock ticker */
    /* Macro — global risk tape (mirrors /macro page logic) */
    .fy-risk-head { display: flex; align-items: baseline; justify-content: space-between; gap: 16px; padding-bottom: 12px; margin-bottom: 14px; border-bottom: 1px solid var(--fy-rule); flex-wrap: wrap; }
    .fy-risk-head-title { font-family: "Source Serif 4", Georgia, serif; font-size: 19px; font-weight: 600; letter-spacing: -.005em; }
    .fy-risk-up   .fy-risk-head-title { color: var(--fy-up); }
    .fy-risk-down .fy-risk-head-title { color: var(--fy-down); }
    .fy-risk-head-meta { display: flex; align-items: baseline; gap: 14px; font-family: ui-monospace, "JetBrains Mono", monospace; }
    .fy-risk-score { font-size: 22px; font-weight: 800; color: var(--fy-ink); letter-spacing: -.01em; }
    .fy-risk-greens { font-size: 11px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--fy-ink-muted); }
    .fy-risk-read { font-family: "Source Serif 4", Georgia, serif; font-style: italic; font-size: 15px; line-height: 1.5; color: var(--fy-ink); margin: 0 0 16px; max-width: 80ch; }
    .fy-risk-tape { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 8px; margin-bottom: 22px; }
    .fy-risk-card { display: flex; flex-direction: column; gap: 6px; padding: 12px 14px; background: var(--fy-bg); border: 1px solid var(--fy-rule); border-radius: 3px; }
    .fy-risk-card.up { border-color: color-mix(in srgb, var(--fy-up) 35%, var(--fy-rule)); }
    .fy-risk-card.down { border-color: color-mix(in srgb, var(--fy-down) 35%, var(--fy-rule)); }
    .fy-risk-card-top { display: flex; justify-content: space-between; align-items: baseline; gap: 8px; }
    .fy-risk-card-top span { font-family: "Source Serif 4", Georgia, serif; font-size: 14px; font-weight: 600; color: var(--fy-ink); }
    .fy-risk-card-top i { font-style: normal; font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 9.5px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--fy-ink-muted); }
    .fy-risk-card b { font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 14.5px; font-weight: 700; color: var(--fy-ink); letter-spacing: -.01em; }
    .fy-risk-card em { font-style: normal; font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 12.5px; font-weight: 700; }
    .fy-risk-card.up em { color: var(--fy-up); }
    .fy-risk-card.down em { color: var(--fy-down); }
    .fy-risk-card.neutral em { color: var(--fy-ink-muted); }
    .fy-macro-backdrop { padding: 14px 0; border-top: 1px solid var(--fy-rule); margin-bottom: 16px; }
    .fy-macro-backdrop-head { display: flex; align-items: baseline; gap: 14px; margin-bottom: 10px; flex-wrap: wrap; }
    .fy-macro-backdrop-label { font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 11px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--fy-ink-muted); }
    .fy-macro-statement { display: flex; align-items: baseline; gap: 14px; margin-bottom: 16px; }
    .fy-macro-regime { font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 11px; font-weight: 800; letter-spacing: .2em; text-transform: uppercase; padding: 5px 10px; border: 1px solid currentColor; }
    .fy-macro-regime.up { color: var(--fy-up); }
    .fy-macro-regime.down { color: var(--fy-down); }
    .fy-macro-regime.neutral { color: var(--fy-ink-muted); }
    .fy-macro-score { font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 24px; font-weight: 800; letter-spacing: -.02em; color: var(--fy-ink); line-height: 1; }
    .fy-macro-read { font-family: "Source Serif 4", Georgia, serif; font-style: italic; font-size: 18px; font-weight: 400; line-height: 1.4; color: var(--fy-ink); margin: 0 0 18px; max-width: 56ch; }
    .fy-macro-signals { list-style: none; margin: 0; padding: 0; }
    .fy-macro-signals li { display: grid; grid-template-columns: 160px minmax(0, 1fr); gap: 16px; padding: 12px 0; border-bottom: 1px solid var(--fy-rule); }
    .fy-macro-signals li:last-child { border-bottom: 0; }
    .fy-macro-signal-label { font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 10.5px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--fy-ink-muted); padding-top: 2px; }
    .fy-macro-signals em { font-style: italic; font-family: "Source Serif 4", Georgia, serif; color: var(--fy-ink); font-size: 14.5px; line-height: 1.45; }
    .fy-macro-crypto { display: flex; gap: 14px; align-items: baseline; margin: 18px 0 0; padding-top: 14px; border-top: 1px solid var(--fy-rule); }
    .fy-macro-crypto-label { font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 10px; font-weight: 800; letter-spacing: .18em; text-transform: uppercase; color: var(--fy-accent); white-space: nowrap; flex-shrink: 0; }
    .fy-macro-crypto-text { font-family: "Source Serif 4", Georgia, serif; font-size: 14.5px; line-height: 1.5; color: var(--fy-ink); }

    /* Macro module — flows + indices blocks. */
    .fy-macro-block { margin: 0 0 22px; }
    .fy-macro-block:last-child { margin-bottom: 0; }
    .fy-macro-block-head { font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 10.5px; font-weight: 800; letter-spacing: .18em; text-transform: uppercase; color: var(--fy-ink-muted); padding-bottom: 8px; margin-bottom: 6px; border-bottom: 1px solid var(--fy-rule); }
    .fy-idx-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 10px; }
    @media (max-width: 700px) {
      .fy-idx-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; }
      .fy-idx-card { padding: 10px 12px; }
    }
    .fy-idx-card { display: flex; flex-direction: column; gap: 6px; padding: 12px 14px; background: var(--fy-bg); border: 1px solid var(--fy-rule); border-radius: 3px; }
    .fy-idx-card.up   { border-color: color-mix(in srgb, var(--fy-up) 35%, var(--fy-rule)); }
    .fy-idx-card.down { border-color: color-mix(in srgb, var(--fy-down) 35%, var(--fy-rule)); }
    .fy-idx-top { display: flex; justify-content: space-between; align-items: baseline; gap: 8px; }
    .fy-idx-top span { font-family: "Source Serif 4", Georgia, serif; font-size: 14px; font-weight: 600; color: var(--fy-ink); }
    .fy-idx-top i { font-style: normal; font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 9.5px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--fy-ink-muted); }
    .fy-idx-card b { font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 14.5px; font-weight: 700; color: var(--fy-ink); letter-spacing: -.01em; }
    .fy-idx-card em { font-style: normal; font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 12.5px; font-weight: 700; }
    .fy-idx-card.up em   { color: var(--fy-up); }
    .fy-idx-card.down em { color: var(--fy-down); }
    .fy-idx-card.neutral em { color: var(--fy-ink-muted); }

    .fy-flows { display: grid; gap: 0; margin: 0; padding: 0; }
    .fy-flows-row { display: grid; grid-template-columns: minmax(180px, auto) auto minmax(0, 1fr); gap: 18px; align-items: baseline; padding: 14px 0; border-bottom: 1px solid var(--fy-rule); }
    .fy-flows-row:last-child { border-bottom: 0; }
    .fy-flows-row dt { font-family: "Source Serif 4", Georgia, serif; font-size: 16px; font-weight: 600; color: var(--fy-ink); margin: 0; }
    .fy-flows-value { font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 15px; font-weight: 700; margin: 0; white-space: nowrap; }
    .fy-flows-value.up { color: var(--fy-up); }
    .fy-flows-value.down { color: var(--fy-down); }
    .fy-flows-sub { font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 11.5px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--fy-ink-muted); margin: 0; }

    /* Today's Market — heatmap container; tile/text classes piggyback on .tools-heatmap-tile etc. */
    .fy-heatmap { position: relative; width: 100%; height: 480px; background: var(--fy-bg); border: 1px solid var(--fy-rule); overflow: hidden; }
    .fy-heatmap-mobile { display: grid; gap: 4px; }
    .fy-heatmap-mobile-row { display: grid; grid-template-columns: 1fr auto; align-items: baseline; padding: 10px 12px; border-bottom: 1px solid var(--fy-rule); }
    .fy-heatmap-mobile-row strong { font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 13px; color: var(--fy-ink); margin-right: 8px; }
    .fy-heatmap-mobile-row span { font-family: "Source Serif 4", Georgia, serif; font-size: 13px; color: var(--fy-ink-muted); }
    .fy-heatmap-mobile-row em { font-style: normal; font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 13px; font-weight: 700; }
    .fy-heatmap-mobile-row.pos em { color: var(--fy-up); }
    .fy-heatmap-mobile-row.neg em { color: var(--fy-down); }

    @media (max-width: 900px) {
      .fy-flows-row { grid-template-columns: 1fr; gap: 4px; }
      .fy-heatmap { height: auto; min-height: 0; border: 0; }
    }

    /* Crypto X */
    .fy-x-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 22px; }
    .fy-x-post { display: block; border-left: 2px solid var(--fy-rule); padding: 4px 0 8px 18px; transition: border-color .2s ease; }
    .fy-x-post:hover { border-left-color: var(--fy-accent); }
    .fy-x-author { display: flex; align-items: center; gap: 8px; font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 12px; font-weight: 700; letter-spacing: .04em; color: var(--fy-accent); margin-bottom: 6px; }
    .fy-x-author-link { color: inherit; text-decoration: none; }
    .fy-x-author-link:hover { text-decoration: underline; }
    .fy-x-priority { font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 9px; font-weight: 800; letter-spacing: .18em; text-transform: uppercase; color: var(--fy-bg-paper); background: var(--fy-accent); padding: 2px 6px; border-radius: 2px; }
    .fy-x-body { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif; font-size: 15px; line-height: 1.5; color: var(--fy-ink); margin: 0 0 8px; }
    .fy-x-row { display: grid; grid-template-columns: 88px minmax(0, 1fr); gap: 14px; align-items: start; }
    .fy-x-main { min-width: 0; }
    .fy-x-media { display: block; width: 88px; height: 88px; border-radius: 3px; overflow: hidden; background: var(--fy-bg); flex-shrink: 0; margin: 0; }
    .fy-x-media img { width: 100%; height: 100%; display: block; object-fit: cover; }
    @media (max-width: 540px) {
      .fy-x-row { grid-template-columns: 64px minmax(0, 1fr); gap: 10px; }
      .fy-x-media { width: 64px; height: 64px; }
    }
    .fy-x-meta { font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 11.5px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--fy-ink-muted); }
    .fy-x-permalink { color: var(--fy-accent); text-decoration: none; }
    .fy-x-permalink:hover { text-decoration: underline; }
    .fy-x-post.priority { border-left-color: var(--fy-accent); padding-left: 16px; }

    /* ClashPicks module — prediction-market list */
    .fy-cp-list { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 0; border-top: 1px solid var(--fy-rule); }
    .fy-cp-row { border-bottom: 1px solid var(--fy-rule); border-right: 1px solid var(--fy-rule); }
    .fy-cp-row:nth-child(2n) { border-right: 0; }
    @media (max-width: 700px) {
      .fy-cp-list { grid-template-columns: 1fr; }
      .fy-cp-row { border-right: 0; }
    }
    .fy-cp-link { display: grid; grid-template-columns: 64px minmax(0, 1fr); gap: 14px; padding: 16px 18px; text-decoration: none; color: inherit; transition: background .15s ease; align-items: start; }
    .fy-cp-link:hover { background: color-mix(in srgb, var(--fy-accent) 6%, transparent); }
    .fy-cp-thumb { width: 64px; height: 64px; border-radius: 4px; overflow: hidden; background: var(--fy-bg); border: 1px solid var(--fy-rule); flex-shrink: 0; }
    .fy-cp-thumb img { width: 100%; height: 100%; display: block; object-fit: cover; }
    .fy-cp-thumb.placeholder { background: var(--fy-rule); }
    .fy-cp-body { min-width: 0; }
    .fy-cp-title { font-family: "Source Serif 4", Georgia, serif; font-size: 16px; font-weight: 600; line-height: 1.25; color: var(--fy-ink); margin-bottom: 4px; }
    .fy-cp-sub { font-family: "Source Serif 4", Georgia, serif; font-size: 13px; line-height: 1.35; color: var(--fy-ink-muted); margin-bottom: 10px; }
    .fy-cp-odds { display: flex; flex-wrap: wrap; gap: 8px; margin: 8px 0 10px; }
    .fy-cp-odd { display: inline-flex; align-items: baseline; gap: 6px; padding: 4px 10px; border: 1px solid var(--fy-rule); background: var(--fy-bg); }
    .fy-cp-odd b { font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 11.5px; font-weight: 700; color: var(--fy-ink); letter-spacing: .04em; }
    .fy-cp-odd em { font-style: normal; font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 11.5px; font-weight: 700; color: var(--fy-accent); }
    .fy-cp-meta { font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 10.5px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--fy-ink-muted); }
    /* Tabs (used in news + x_posts modules) — editorial restyle */
    .fy-section .fy-tabs { display: flex; flex-wrap: wrap; padding: 4px 0 14px; margin-bottom: 18px; border-bottom: 1px solid var(--fy-rule); gap: 22px; }
    .fy-section .fy-tabs .fy-tab { background: transparent; border: 0; border-radius: 0; padding: 4px 0; color: var(--fy-ink-muted); font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif; font-size: 14px; font-weight: 600; letter-spacing: .01em; text-transform: none; cursor: pointer; line-height: 1.2; transition: color .12s ease; }
    .fy-section .fy-tabs .fy-tab:hover { background: transparent; color: var(--fy-ink); border-color: transparent; }
    .fy-section .fy-tabs .fy-tab.active { background: transparent; color: var(--fy-accent); border-color: transparent; border-bottom: 2px solid var(--fy-accent); }
    @media (max-width: 700px) {
      .fy-section .fy-tabs { gap: 14px; padding: 2px 0 10px; margin-bottom: 14px; overflow-x: auto; flex-wrap: nowrap; -webkit-overflow-scrolling: touch; }
      .fy-section .fy-tabs::-webkit-scrollbar { display: none; }
      .fy-section .fy-tabs .fy-tab { white-space: nowrap; font-size: 13.5px; }
    }

    /* Mobile */
    @media (max-width: 900px) {
      .fy-grid { grid-template-columns: 1fr; gap: 32px; }
      .fy-section, .fy-grid > .fy-section.col-l, .fy-rail { grid-column: 1; }
      .fy-rail { display: flex; order: 1; }
      .fy-grid > .fy-section.col-l { order: 2; }
      .fy-grid > .fy-section:not(.col-l) { order: 3; }
      .fy-news-lead { grid-template-columns: 1fr; gap: 14px; }
      .fy-news-lead-thumb { aspect-ratio: 16 / 10; }
      .fy-news-row { grid-template-columns: 64px minmax(0, 1fr); gap: 12px; }
      .fy-news-row.no-thumb { grid-template-columns: 1fr; }
      .fy-news-row-thumb { width: 64px; height: 48px; }
      .fy-macro-signals li { grid-template-columns: 1fr; gap: 4px; }
      .fy-macro-signal-label { padding-top: 0; }
    }

    .fy-tabs { display: flex; gap: 6px; flex-wrap: wrap; padding: 0 0 10px; border-bottom: 1px solid rgba(255,255,255,.06); margin-bottom: 10px; }
    .fy-tab { background: transparent; border: 1px solid var(--line); color: var(--muted); border-radius: 999px; padding: 4px 11px; font-size: 11px; font-weight: 700; cursor: pointer; }
    .fy-tab:hover { background: var(--hover); color: var(--text); }
    .fy-tab.active { background: var(--accent); color: #fff; border-color: var(--accent); }
    @media (max-width: 900px) {
      .foryou-shell { padding: 14px 14px 110px; }
      .fy-setup-head { flex-direction: column; }
      .fy-title { font-size: 26px; }
      .fy-onboard { padding: 20px; }
      .fy-onboard-title { font-size: 24px; }
      .fy-choice { flex: 1; min-width: 0; }
      .fy-choice-tile { min-width: 100%; }
      .fy-intro-preview, .fy-topic-groups { grid-template-columns: 1fr; }
      .fy-suggest-strip { grid-template-columns: 1fr; }
      .fy-pick-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
      .fy-setup-grid, .fy-custom-fields { grid-template-columns: 1fr; }
    }
    #answersPage {
      scrollbar-width: none;
      -ms-overflow-style: none;
    }
    #answersPage::-webkit-scrollbar {
      display: none;
    }
    .disc-header {
      position: sticky; top: 0; z-index: 20; background: var(--bg);
      padding: 20px 32px 14px; border-bottom: 1px solid var(--line);
    }
    .disc-header-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
    .disc-header-right { display: flex; align-items: center; gap: 10px; }
    .disc-title { font-size: 22px; font-weight: 800; color: var(--text); }
    .disc-sub { max-width: 720px; color: var(--muted); font-size: 13.5px; line-height: 1.55; margin-top: 4px; }
    .disc-back-btn {
      display: flex; align-items: center; gap: 5px; background: var(--panel); border: 1px solid var(--line);
      border-radius: 8px; color: var(--muted); padding: 6px 14px; font-size: 12px; font-weight: 600; cursor: pointer;
    }
    .disc-back-btn:hover { background: var(--hover); color: var(--text); }
    /* Pills — strong active vs muted inactive */
    .disc-pills { display: flex; gap: 6px; overflow-x: auto; scrollbar-width: none; padding-bottom: 2px; }
    .disc-pills::-webkit-scrollbar { display: none; }
    .disc-pill {
      padding: 6px 16px; border-radius: 20px; font-size: 12px; font-weight: 500; cursor: pointer;
      border: 1px solid transparent; background: var(--hover); color: var(--muted); transition: all .15s;
      white-space: nowrap; flex-shrink: 0; opacity: 0.7;
    }
    .disc-pill:hover { opacity: 1; color: var(--text); }
    .disc-pill.active { background: var(--accent); color: #fff; border-color: var(--accent); opacity: 1; font-weight: 700; }
    /* Feed container — more breathing room */
    .disc-feed { padding: 8px 32px 100px; display: flex; flex-direction: column; gap: 0; }
    .disc-item {
      display: flex; gap: 18px; padding: 26px 16px; border-bottom: 1px solid var(--line);
      cursor: default; border-radius: 6px; transition: background .15s;
    }
    .disc-item:nth-child(odd) { background: rgba(255,255,255,.015); }
    .disc-item:last-child { border-bottom: none; }
    @media (hover: hover) {
      .disc-item:hover { background: rgba(255,255,255,.04); }
      .disc-item:hover .disc-item-title { color: var(--accent); }
    }
    /* Image — real or fallback with category color */
    .disc-item-img {
      width: 180px; height: 120px; max-height: 120px; border-radius: 10px; object-fit: cover; flex-shrink: 0;
      background: var(--hover);
    }
    .disc-item-fallback {
      width: 180px; height: 120px; border-radius: 10px; flex-shrink: 0;
      display: flex; align-items: center; justify-content: center;
      font-size: 32px; border: none;
      background: linear-gradient(135deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
    }
    .disc-item-body { flex: 1; min-width: 0; }
    /* Meta — smaller, lighter, non-competing */
    .disc-item-meta { display: flex; align-items: center; gap: 6px; margin-bottom: 5px; flex-wrap: wrap; min-width: 0; overflow: hidden; }
    .disc-item-badge {
      font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em;
      padding: 2px 8px; border-radius: 4px;
    }
    /* Category-specific badge colors */
    .disc-badge-crypto { background: rgba(99,179,237,.15); color: #63b3ed; }
    .disc-badge-market { background: rgba(72,187,120,.15); color: #48bb78; }
    .disc-badge-tech { background: rgba(159,122,234,.15); color: #9f7aea; }
    .disc-badge-politics { background: rgba(237,100,100,.15); color: #ed6464; }
    .disc-badge-sports, .disc-badge-sports_daily, .disc-badge-sports_analysis, .disc-badge-sports_transactions {
      background: rgba(66,133,244,.15); color: #4285f4;
    }
    .disc-badge-culture, .disc-badge-entertainment, .disc-badge-lifestyle, .disc-badge-travel, .disc-badge-home { background: rgba(213,188,99,.15); color: #d5bc63; }
    .disc-badge-local { background: rgba(72,187,120,.15); color: #48bb78; }
    .disc-badge-crypto_breaking { background: rgba(99,179,237,.15); color: #63b3ed; }
    .disc-badge-general { background: var(--hover); color: var(--muted); }
    .disc-hot-badge {
      font-size: 10px; font-weight: 700; padding: 2px 8px; border-radius: 4px;
      letter-spacing: 0.02em; white-space: nowrap;
    }
    .disc-hot-hot { background: rgba(255,69,0,.15); color: #ff4500; }
    .disc-hot-reddit { background: rgba(255,69,0,.12); color: #ff6b35; }
    .disc-hot-x { background: rgba(29,161,242,.15); color: #1da1f2; }
    .disc-hot-crypto { background: rgba(247,147,26,.15); color: #f7931a; }
    .disc-hot-multi { background: rgba(160,174,192,.12); color: #a0aec0; }
    .disc-hot-trending { background: rgba(72,187,120,.12); color: #48bb78; }
    /* Event/place cards */
    .disc-badge-event, .disc-badge-music, .disc-badge-comedy, .disc-badge-theater,
    .disc-badge-conference, .disc-badge-food { background: rgba(255,159,67,.15); color: #ff9f43; }
    .disc-badge-restaurant, .disc-badge-cafe, .disc-badge-bar, .disc-badge-nightlife {
      background: rgba(255,107,129,.15); color: #ff6b81;
    }
    .disc-badge-museum, .disc-badge-park, .disc-badge-attraction, .disc-badge-place {
      background: rgba(72,187,120,.15); color: #48bb78;
    }
    .disc-hot-event { background: rgba(255,159,67,.12); color: #ff9f43; }
    .disc-hot-place { background: rgba(72,187,120,.12); color: #48bb78; }
    .disc-item.disc-event-card { border-left: 3px solid #ff9f43; }
    /* Reddit question cards */
    .disc-item.reddit-q { border-left: 3px solid #ff4500; }
    .disc-reddit-icon {
      width: 180px; height: 120px; border-radius: 10px; flex-shrink: 0;
      display: flex; align-items: center; justify-content: center;
      font-size: 36px; background: linear-gradient(135deg, rgba(255,69,0,.08), rgba(255,69,0,.02));
    }
    .disc-item.reddit-q .disc-item-title { color: var(--accent); }
    .disc-reddit-ask {
      display: inline-flex; align-items: center; gap: 6px;
      background: rgba(255,69,0,.1); border: 1px solid rgba(255,69,0,.25);
      border-radius: 8px; padding: 8px 16px; font-size: 14px; color: #ff6b35;
      cursor: pointer; font-weight: 600; transition: all .15s; margin-top: 8px;
    }
    .disc-reddit-ask:hover { background: rgba(255,69,0,.18); border-color: #ff4500; }
    .disc-item-source { font-size: 9px; color: var(--muted); opacity: 0.4; font-weight: 400; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 120px; }
    .disc-item-age { font-size: 9px; color: var(--muted); opacity: 0.4; font-weight: 400; white-space: nowrap; }
    .disc-item-dot { font-size: 5px; color: var(--line); opacity: 0.3; }
    .disc-meta-right { margin-left: auto; display: flex; align-items: center; gap: 4px; flex-shrink: 0; }
    @media (max-width: 600px) {
      .disc-meta-right { display: none; }
      .disc-item-body .disc-thumb-mobile { display: flex; }
    }
    .disc-thumb-mobile { display: none; align-items: center; gap: 4px; margin-top: 6px; }
    .disc-thumb {
      background: none; border: none; font-size: 16px; cursor: pointer;
      opacity: 0.85; transition: all .15s; padding: 2px 4px; line-height: 1;
    }
    .disc-thumb:hover { opacity: 1; transform: scale(1.2); }
    .disc-thumb.voted { opacity: 1; filter: brightness(1.3); text-shadow: 0 0 10px rgba(255,140,0,.8); }
    .disc-follow-btn {
      background: none; border: 1px solid var(--line); border-radius: 20px;
      color: var(--muted); font-size: 11px; font-weight: 600; cursor: pointer;
      padding: 3px 10px; transition: all .15s; white-space: nowrap;
    }
    .disc-follow-btn:hover { border-color: var(--accent); color: var(--accent); }
    .disc-follow-btn.following { background: var(--accent); border-color: var(--accent); color: #fff; }
    /* Title — the star */
    .disc-item-title { font-size: 18px; font-weight: 700; color: var(--text); line-height: 1.4; margin-bottom: 6px; transition: color .15s; }
    .disc-item-title a { color: inherit; text-decoration: none; }
    .disc-item-title a:hover { color: var(--accent); }
    .disc-item-excerpt {
      font-size: 15px; color: var(--muted); line-height: 1.6; margin-bottom: 12px;
      display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical;
      overflow: hidden; text-overflow: ellipsis; max-height: 4.8em;
    }
    .disc-ask-expand {
      background: none; border: none; color: var(--muted); font-size: 12px; cursor: pointer;
      padding: 8px 0 0; margin-top: 6px; border-top: 1px solid var(--line); opacity: 0.5;
      transition: all .15s; font-family: inherit; display: block; width: 100%;
      text-align: left;
    }
    .disc-ask-expand:hover { opacity: 1; color: var(--accent); }
    .disc-ask-custom-bar {
      display: none; align-items: center; gap: 8px; margin-top: 6px; width: 100%;
    }
    .disc-ask-custom-bar.open { display: flex; }
    .disc-ask-custom-bar.revealable { display: none; }
    .disc-mag-card:hover .disc-ask-custom-bar.revealable,
    .lane-mag-card:hover .disc-ask-custom-bar.revealable,
    .disc-mag-rail-item:hover .disc-ask-custom-bar.revealable,
    .lane-mag-rail-item:hover .disc-ask-custom-bar.revealable,
    .disc-ask-custom-bar.revealable.open { display: flex; }
    @media (hover: none) {
      .disc-mag-card:hover .disc-ask-custom-bar.revealable,
      .lane-mag-card:hover .disc-ask-custom-bar.revealable,
      .disc-mag-rail-item:hover .disc-ask-custom-bar.revealable,
      .lane-mag-rail-item:hover .disc-ask-custom-bar.revealable { display: none; }
      .disc-ask-custom-bar.revealable.open { display: flex; }
    }
    .disc-ask-custom-input {
      flex: 1; background: var(--hover); border: 1px solid var(--line); border-radius: 10px;
      padding: 8px 12px; font-size: 13px; color: var(--text); font-family: inherit;
      outline: none; transition: border-color .15s;
    }
    .disc-ask-custom-input::placeholder { color: var(--muted); opacity: 0.5; }
    .disc-ask-custom-input:focus { border-color: var(--accent); }
    .disc-ask-custom-send {
      background: var(--accent); border: none; border-radius: 8px; color: #fff;
      width: 32px; height: 32px; font-size: 14px; cursor: pointer; flex-shrink: 0;
      display: flex; align-items: center; justify-content: center; transition: opacity .15s;
    }
    .disc-ask-custom-send:hover { opacity: 0.85; }
    /* Questions — distinct interactive layer */
    .disc-item-questions {
      display: flex; gap: 8px; flex-wrap: wrap;
      padding-top: 10px; border-top: 1px solid var(--line);
    }
    .disc-ask-btn {
      display: inline-flex; align-items: center; gap: 5px;
      background: color-mix(in srgb, var(--accent) 8%, var(--panel)); border: 1px solid color-mix(in srgb, var(--accent) 30%, var(--line));
      border-radius: 999px; padding: 7px 12px; font-size: 13px; color: var(--accent); font-weight: 750; cursor: pointer;
      text-align: left; transition: all .15s;
    }
    .disc-ask-btn:hover { border-color: var(--accent); background: color-mix(in srgb, var(--accent) 13%, var(--panel)); transform: translateY(-1px); }
    .disc-ask-arrow { color: var(--accent); font-size: 13px; font-weight: 700; }
    .disc-loading { color: var(--muted); font-size: 13px; padding: 40px; text-align: center; }
    @media (max-width: 768px) {
      .disc-header { padding: 14px 16px 10px; }
      .disc-feed { padding: 6px 16px 100px; }
      .disc-item { gap: 12px; padding: 20px 0; }
      .disc-item-img { width: 110px; height: 74px; }
      .disc-item-fallback { width: 110px; height: 74px; font-size: 22px; }
      .disc-item-title { font-size: 14px; }
      .disc-item-questions { flex-direction: column; gap: 6px; }
      .disc-reddit-icon { width: 110px; height: 74px; font-size: 28px; }
      .disc-item-source { max-width: 80px; }
      .disc-item-meta { gap: 4px; row-gap: 2px; }
      .disc-item-badge { font-size: 8px; padding: 2px 6px; }
      .disc-hot-badge { font-size: 8px; padding: 2px 6px; }
    }

    .discovery-page.magazine-mode .disc-header { display: block; }
    .disc-categories-wrap { max-width: 1180px; width: 100%; margin: 0 auto 18px; position: relative; overflow: hidden; }
    .disc-categories-wrap::after { content: ''; position: absolute; top: 0; right: 0; width: 36px; height: 100%; background: linear-gradient(to right, transparent, var(--bg, #0b0b0c) 75%); pointer-events: none; opacity: var(--disc-cat-fade, 1); transition: opacity .2s; z-index: 1; }
    .disc-categories-wrap::before { content: ''; position: absolute; top: 0; left: 0; width: 24px; height: 100%; background: linear-gradient(to left, transparent, var(--bg, #0b0b0c) 75%); pointer-events: none; opacity: 0; transition: opacity .2s; z-index: 1; }
    .disc-categories-wrap.at-end::after { opacity: 0; }
    .disc-categories-wrap:not(.at-start)::before { opacity: 1; }
    .disc-categories-top { display: flex; gap: 8px; overflow-x: auto; padding-bottom: 6px; padding-right: 36px; scrollbar-width: thin; scrollbar-color: rgba(255,255,255,.22) transparent; scroll-behavior: smooth; -webkit-overflow-scrolling: touch; scroll-snap-type: x proximity; box-sizing: border-box; }
    .disc-categories-top::-webkit-scrollbar { height: 4px; }
    .disc-categories-top::-webkit-scrollbar-thumb { background: rgba(255,255,255,.22); border-radius: 999px; }
    @media (max-width: 720px) { .disc-categories-top { gap: 6px; padding-right: 16px; } .disc-category-tab { padding: 9px 12px; min-height: 38px; } .disc-category-label { font-size: 10.5px; gap: 6px; } }
    .disc-category-tab { position: relative; min-height: 38px; border: 1px solid var(--line); border-radius: 8px; background: var(--panel); color: var(--text); padding: 9px 13px; cursor: pointer; overflow: hidden; text-align: left; font: inherit; flex: 0 0 auto; scroll-snap-align: start; }
    .disc-mag-section-head .disc-mag-button { background: transparent; color: var(--accent); border: 1px solid rgba(232,87,42,.45); font-weight: 750; }
    .disc-mag-section-head .disc-mag-button:hover { background: rgba(232,87,42,.1); border-color: rgba(232,87,42,.65); }
    .disc-category-tab::after { display: none; }
    .disc-category-tab.active { border-color: var(--line); background: var(--panel-2); }
    .disc-category-tab:not(.active) .disc-category-label { color: var(--text); opacity: .78; }
    .disc-category-label { position: relative; z-index: 1; display: flex; align-items: center; gap: 7px; color: var(--accent); font-size: 11px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; white-space: nowrap; }
    .disc-category-question { display: none; }
    @media (min-width: 769px) {
      #macroPage #macroTabs,
      .discovery-page.visible .disc-categories-wrap {
        display: none;
      }
    }
    .lane-mag, .disc-mag { padding: 18px 32px 110px; max-width: 1180px; width: 100%; margin: 0 auto; }
    .lane-mag-board, .disc-mag { display: grid; grid-template-columns: minmax(0, 1fr); gap: 16px; }
    .lane-mag-topbar, .disc-mag-masthead { display: flex; justify-content: space-between; align-items: flex-end; gap: 16px; border-bottom: 1px solid var(--line); padding-bottom: 14px; }
    .lane-mag-kicker, .disc-mag-kicker { color: var(--accent); font-size: 11px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; margin-bottom: 8px; }
    .lane-mag-title, .disc-mag-title { color: var(--text); font-size: clamp(25px, 3.1vw, 36px); line-height: 1.06; letter-spacing: -.03em; font-weight: 700; max-width: 820px; margin-bottom: 4px; }
    .lane-news-board { display: grid; grid-template-columns: minmax(0, 1fr); gap: 14px; }
    .disc-news-list { display: grid; grid-template-columns: minmax(0, 1fr); gap: 10px; }
    .disc-news-card {
      display: grid; grid-template-columns: minmax(0, 172px) minmax(0, 1fr); gap: 14px;
      border: 1px solid var(--line); border-radius: 8px; background: var(--panel);
      padding: 12px; min-width: 0;
    }
    .disc-news-card.lead {
      grid-template-columns: minmax(260px, .82fr) minmax(0, 1fr);
      gap: 18px; padding: 16px; background: var(--panel-2);
    }
    .disc-news-visual, .disc-news-thumb {
      width: 100%; height: 100%; min-height: 112px; border-radius: 7px; overflow: hidden;
      background: rgba(255,255,255,.045);
    }
    .disc-news-visual { min-height: 280px; }
    .disc-news-visual img, .disc-news-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
    .disc-news-visual.no-image, .disc-news-thumb.no-image { display: none; }
    .disc-news-card:has(.disc-news-visual.no-image),
    .disc-news-card:has(.disc-news-thumb.no-image) { grid-template-columns: minmax(0, 1fr); }
    .disc-news-body { min-width: 0; display: flex; flex-direction: column; gap: 8px; }
    .disc-news-meta, .disc-news-meta .lane-mag-meta { display: flex; align-items: center; gap: 7px; flex-wrap: wrap; color: var(--muted); font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: .05em; }
    .disc-news-title { margin: 0; color: var(--text); font-size: 19px; line-height: 1.22; font-weight: 850; letter-spacing: 0; }
    .disc-news-card.lead .disc-news-title { font-size: clamp(26px, 3vw, 42px); line-height: 1.02; }
    .disc-news-title a { color: inherit; text-decoration: none; }
    .disc-news-title a:hover { color: var(--accent); }
    .disc-news-excerpt { margin: 0; color: var(--muted); font-size: 14px; line-height: 1.52; max-width: 72ch; }
    .disc-news-card.lead .disc-news-excerpt { font-size: 15px; color: color-mix(in srgb, var(--text) 74%, var(--muted)); }
    .disc-news-followups { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 4px; }
    .disc-news-followups .disc-ask-btn { border-radius: 8px; padding: 7px 10px; font-size: 12px; }
    .disc-news-skeleton { pointer-events: none; }
    .disc-news-card.skeleton { overflow: hidden; }
    .disc-skel-media, .disc-skel-thumb, .disc-skel-line, .disc-skel-title, .disc-skel-buttons span {
      display: block;
      border-radius: 8px;
      background: linear-gradient(90deg, rgba(255,255,255,.045), rgba(255,255,255,.09), rgba(255,255,255,.045));
      background-size: 220% 100%;
      animation: fyShimmer 1.1s linear infinite;
    }
    .disc-skel-media { width: 100%; min-height: 280px; height: 100%; }
    .disc-skel-thumb { width: 100%; min-height: 112px; height: 100%; }
    .disc-skel-line { width: 100%; height: 13px; }
    .disc-skel-line.short { width: 34%; height: 10px; }
    .disc-skel-line.mid { width: 68%; }
    .disc-skel-title { width: 92%; height: 28px; margin-top: 2px; }
    .disc-skel-title.narrow { width: 74%; }
    .disc-skel-title.small { height: 20px; width: 86%; }
    .disc-skel-buttons { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 4px; }
    .disc-skel-buttons span { width: 150px; height: 32px; border-radius: 8px; }
    .lane-mag-dek, .disc-mag-dek, .lane-mag-kicker, .disc-mag-kicker, .lane-mag-count, .disc-mag-count { display: none; }
    .lane-mag-layout, .disc-mag-cover { display: grid; grid-template-columns: minmax(0, 1.12fr) minmax(320px, .88fr); gap: 16px; align-items: stretch; }
    .lane-mag-layout.no-image-lead, .disc-mag-cover.no-image-lead { grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr); }
    .no-image-lead .lane-mag-rail, .no-image-lead .disc-mag-rail { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .lane-mag-hero, .lane-mag-card, .lane-mag-ask, .lane-mag-rail, .disc-mag-lead, .disc-mag-card, .disc-mag-rail, .disc-mag-section { background: var(--panel); border: 1px solid var(--line); border-radius: 12px; overflow: hidden; box-shadow: none; }
    .lane-mag-hero, .disc-mag-lead { min-height: 0; height: 100%; max-height: none; display: flex; flex-direction: column; justify-content: flex-start; background: var(--panel); }
    .disc-mag-cover > .disc-mag-lead { min-height: 0; justify-content: flex-start; }
    .lane-mag-body, .disc-mag-body { padding: 22px; }
    .disc-mag-cover > .disc-mag-lead .disc-mag-body { padding: 20px 26px 24px; }
    .lane-mag-visual, .disc-mag-visual { height: clamp(220px, 25vw, 330px); min-height: 0; display: flex; align-items: center; justify-content: center; font-size: 42px; background: var(--panel-2); overflow: hidden; }
    .lane-mag-visual.no-image, .disc-mag-visual.no-image, .lane-mag-thumb.no-image, .disc-mag-thumb.no-image { min-height: 0; height: 0; margin: 0; display: none; }
    .disc-mag-cover > .disc-mag-lead .disc-mag-visual { height: clamp(220px, 24vw, 320px); min-height: 0; position: relative; margin: 12px 12px 0; border-radius: 8px; overflow: hidden; }
    .disc-mag-cover > .disc-mag-lead .disc-mag-visual::after { display: none; }
    .disc-mag-cover > .disc-mag-lead .disc-mag-body { padding: 18px 26px 24px; }
    .lane-mag-hero .lane-mag-body, .disc-mag-lead .disc-mag-body { flex: 1; display: flex; flex-direction: column; }
    .disc-hero-copy { display: grid; gap: 10px; margin-top: 12px; color: var(--muted); font-size: 14px; line-height: 1.54; flex: 1; align-content: start; }
    .disc-hero-copy p { margin: 0; }
    .disc-hero-copy p:first-child { color: var(--text); font-size: 15px; line-height: 1.5; }
    .disc-hero-copy .disc-hero-support { color: var(--muted); border-top: 1px solid var(--line); padding-top: 10px; margin-top: 2px; }
    .no-image-lead .lane-mag-excerpt, .no-image-lead .disc-mag-excerpt { display: block; overflow: visible; }
    .disc-mag-cover > .disc-mag-lead .disc-mag-why { margin-top: 12px; padding: 12px 14px; }
    .disc-mag-cover > .disc-mag-lead .disc-mag-actions { display: none; }
    .lane-mag-visual img, .lane-mag-thumb img, .disc-mag-visual img, .disc-mag-thumb img { width: 100%; height: 100%; object-fit: cover; object-position: center center; display: block; }
    .lane-mag-meta, .disc-mag-meta { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; color: var(--muted); font-size: 11.5px; font-weight: 600; text-transform: none; letter-spacing: 0; margin-bottom: 7px; }
    .lane-mag-meta .disc-mag-badge, .disc-mag-meta .disc-mag-badge, .lane-mag-meta .lane-mag-badge, .disc-mag-meta .lane-mag-badge { text-transform: uppercase; letter-spacing: .06em; font-size: 10px; font-weight: 850; }
    .lane-mag-badge, .disc-mag-badge { color: var(--accent); background: rgba(232,87,42,.12); padding: 4px 8px; border-radius: 999px; }
    .disc-source-badge { color: var(--text); background: var(--panel-2); border: 1px solid var(--line); padding: 3px 7px; border-radius: 999px; font-size: 10px; font-weight: 700; white-space: nowrap; }
    .lane-mag-headline, .disc-mag-headline { color: var(--text); font-size: clamp(23px, 2.5vw, 34px); line-height: 1.08; letter-spacing: -.03em; font-weight: 700; }
    .lane-mag-headline a, .lane-mag-card-title a, .disc-mag-headline a, .disc-mag-card-title a { color: inherit; text-decoration: none; }
    .lane-mag-headline a:hover, .lane-mag-card-title a:hover, .disc-mag-headline a:hover, .disc-mag-card-title a:hover { color: var(--accent); }
    .lane-mag-excerpt, .disc-mag-excerpt { color: var(--muted); font-size: 14px; line-height: 1.5; margin-top: 8px; }
    .lane-mag-rail, .disc-mag-rail { height: 100%; padding: 0; display: grid; align-content: stretch; grid-template-rows: repeat(4, minmax(0, 1fr)); gap: 10px; background: transparent; border: 0; overflow: visible; }
    .lane-mag-rail-title, .disc-mag-rail-title { display: none; }
    .lane-mag-rail-item, .disc-mag-rail-item { border: 1px solid var(--line); background: var(--panel); border-radius: 10px; padding: 12px; min-width: 0; min-height: 0; }
    .lane-mag-rail-item:first-of-type, .disc-mag-rail-item:first-of-type { border-top: 1px solid var(--line); padding-top: 12px; }
    .lane-mag-card-title, .disc-mag-card-title { color: var(--text); font-size: 15.5px; line-height: 1.3; font-weight: 700; letter-spacing: -.01em; }
    .disc-mag-rail .disc-mag-card-title { font-size: 14px; line-height: 1.25; }
    .disc-mag-rail .disc-mag-excerpt, .lane-mag-rail .lane-mag-excerpt { font-size: 12.5px; line-height: 1.42; margin-top: 6px; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
    .disc-mag-rail .disc-mag-rail-item, .lane-mag-rail .lane-mag-rail-item { display: grid; grid-template-columns: 62px 1fr; gap: 10px; align-items: start; }
    .disc-mag-cover > .disc-mag-rail { align-content: stretch; grid-template-rows: repeat(4, minmax(0, 1fr)); }
    .disc-mag-cover > .disc-mag-rail .disc-mag-rail-item { align-content: start; }
    .disc-mag-cover > .disc-mag-rail .disc-mag-excerpt { -webkit-line-clamp: 3; }
    .disc-card-ask { display: inline-flex; margin-top: 9px; color: var(--accent); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; }
    .disc-section-foot { border-top: 1px solid var(--line); color: var(--muted); font-size: 12px; font-weight: 650; padding: 3px 2px 0; display: flex; justify-content: space-between; gap: 12px; align-items: center; }
    .disc-section-foot button { border: 0; background: transparent; color: var(--accent); font: inherit; font-weight: 800; cursor: pointer; padding: 0; }
    .disc-mag-rail-more { display: block; margin-top: 4px; padding-top: 12px; border-top: 1px solid var(--line); color: var(--accent); font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: .07em; text-decoration: none; }
    .disc-mag-rail-more:hover { color: var(--text); }
    .disc-mag-rail-thumb, .lane-mag-rail-thumb { width: 62px; height: 62px; border-radius: 8px; overflow: hidden; background: var(--panel-2); display: flex; align-items: center; justify-content: center; color: var(--muted); font-size: 20px; }
    .disc-mag-rail-thumb.no-image, .lane-mag-rail-thumb.no-image { display: none; }
    .disc-mag-rail-item:has(.disc-mag-rail-thumb.no-image),
    .lane-mag-rail-item:has(.lane-mag-rail-thumb.no-image) { grid-template-columns: 1fr; }
    .disc-mag-rail-thumb img, .lane-mag-rail-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
    .disc-mag-rail-text { min-width: 0; }
    .lane-mag-grid, .disc-mag-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
    .lane-mag-card, .disc-mag-card { display: flex; flex-direction: column; min-height: 250px; }
    .lane-mag-grid:empty, .disc-mag-grid:empty { display: none; }
    .lane-mag-thumb, .disc-mag-thumb { height: 104px; display: flex; align-items: center; justify-content: center; font-size: 30px; background: var(--panel-2); }
    .lane-mag-button, .disc-mag-button { border: 0; border-radius: 999px; background: var(--accent); color: #fff; padding: 10px 15px; font: inherit; font-size: 13px; font-weight: 700; cursor: pointer; }
    .lane-mag-action, .disc-mag-action { color: var(--accent); font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; margin-top: auto; padding-top: 14px; }
    .lane-story .lane-mag-hero { min-height: 320px; display: flex; flex-direction: column; }
    .disc-mag-section { padding: 18px; display: grid; gap: 14px; }
    .disc-mag-section-head { display: flex; align-items: baseline; justify-content: space-between; gap: 14px; border-bottom: 1px solid var(--line); padding-bottom: 12px; }
    .disc-mag-section-title { color: var(--text); font-size: 22px; font-weight: 700; letter-spacing: -.03em; }
    .disc-mag-section-sub { color: var(--muted); font-size: 12px; font-weight: 750; text-transform: uppercase; letter-spacing: .08em; }
    .disc-mag-section-layout { display: grid; grid-template-columns: minmax(0, .95fr) minmax(0, 1.35fr); gap: 14px; align-items: start; }
    .disc-mag-mini-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
    .disc-mag-mixed-head { margin-top: 28px; display: flex; flex-direction: column; gap: 4px; }
    .disc-mag-mixed-sub { color: var(--muted); font-size: 13px; font-weight: 600; }
    .disc-mag-mixed-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; margin-top: 14px; }
    @media (max-width: 1024px) { .disc-mag-mixed-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
    @media (max-width: 600px) { .disc-mag-mixed-grid { grid-template-columns: 1fr; } }
    .disc-mag-card.compact { min-height: 0; }
    .disc-mag-card.compact .disc-mag-body { padding: 18px; }
    .disc-mag-actions { display: none; }
    .disc-mag-why { margin-top: 16px; padding: 13px 14px; border: 1px solid var(--line); border-radius: 10px; background: var(--panel-2); }
    .disc-mag-why span { display: block; color: var(--accent); font-size: 11px; font-weight: 900; letter-spacing: .1em; text-transform: uppercase; margin-bottom: 6px; }
    .disc-mag-why p { margin: 0; color: var(--text); font-size: 14px; line-height: 1.5; }
    .disc-mag-data-strip { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; }
    .disc-mag-data-card { border: 1px solid var(--line); border-radius: 10px; background: var(--panel); padding: 14px; min-width: 0; }
    .disc-mag-data-label { color: var(--muted); font-size: 11px; font-weight: 850; text-transform: uppercase; letter-spacing: .08em; }
    .disc-mag-data-value { color: var(--text); font-size: 16px; line-height: 1.2; font-weight: 700; letter-spacing: -.02em; margin-top: 7px; }
    .disc-mag-data-copy { color: var(--muted); font-size: 12px; line-height: 1.45; margin-top: 6px; }
    @media (max-width: 900px) {
      .lane-mag, .disc-mag { padding: 14px 16px 100px; }
      .disc-news-card,
      .disc-news-card.lead { grid-template-columns: minmax(0, 1fr); gap: 11px; padding: 12px; }
      .disc-news-visual { min-height: 190px; }
      .disc-news-thumb { min-height: 150px; }
      .disc-news-card.lead .disc-news-title { font-size: 26px; line-height: 1.08; }
      .disc-news-title { font-size: 18px; }
      .disc-skel-media { min-height: 190px; }
      .disc-skel-thumb { min-height: 150px; }
      .disc-news-followups { flex-direction: column; }
      .disc-news-followups .disc-ask-btn { width: 100%; justify-content: flex-start; }
      .disc-categories-top { padding: 0 16px 7px; max-width: 100vw; }
      .disc-category-tab { min-height: 36px; padding: 8px 12px; }
      .lane-mag-board, .disc-mag { gap: 14px; }
      .lane-mag-topbar, .disc-mag-masthead, .disc-mag-section-head { display: block; }
      .disc-mag-masthead { padding-bottom: 14px; }
      .lane-mag-count, .disc-mag-count { display: none; }
      .lane-mag-layout, .lane-mag-layout.no-image-lead, .lane-mag-grid, .disc-mag-cover, .disc-mag-cover.no-image-lead, .disc-mag-grid, .disc-mag-section-layout, .disc-mag-mini-grid, .disc-mag-data-strip { grid-template-columns: 1fr; }
      .no-image-lead .lane-mag-rail, .no-image-lead .disc-mag-rail { grid-template-columns: 1fr; }
      .lane-mag-hero, .disc-mag-lead, .disc-mag-cover > .disc-mag-lead { min-height: auto; height: auto; max-height: none; }
      .lane-mag-rail, .disc-mag-rail, .disc-mag-cover > .disc-mag-rail { height: auto; grid-template-rows: none; align-content: start; }
      .disc-mag-cover > .disc-mag-lead .disc-mag-visual { height: 150px; margin: 10px 10px 0; }
      .disc-categories-wrap { margin-left: -16px; margin-right: -16px; width: auto; max-width: 100vw; }
      .disc-mag-cover > .disc-mag-lead .disc-mag-body { padding: 15px 18px 18px; }
      .lane-story .lane-mag-hero { min-height: auto; }
      .disc-mag-title { font-size: 30px; margin-bottom: 6px; }
      .disc-mag-dek { font-size: 14px; line-height: 1.45; }
      .disc-mag-masthead, .disc-mag-cover, .disc-mag-section, .disc-mag-card { min-width: 0; }
      .disc-mag-headline { font-size: 24px; line-height: 1.08; }
      .disc-mag-excerpt { margin-top: 7px; line-height: 1.45; display: block; overflow: visible; }
      .lane-mag-hero .lane-mag-excerpt, .disc-mag-lead .disc-mag-excerpt { display: block; overflow: visible; }
      .disc-hero-copy { font-size: 13.5px; line-height: 1.48; gap: 8px; }
      .disc-hero-copy p:first-child { font-size: 14px; }
      .disc-mag-why { margin-top: 10px; padding: 12px 14px; }
      .disc-mag-actions { margin-top: 8px; padding-top: 8px; }
      .disc-mag-headline, .disc-mag-card-title, .disc-mag-excerpt { overflow-wrap: anywhere; }
      .disc-mag-rail .disc-mag-rail-item, .lane-mag-rail .lane-mag-rail-item { grid-template-columns: 54px 1fr; }
      .disc-mag-rail-thumb, .lane-mag-rail-thumb { width: 54px; height: 54px; }
    }

    .answers-hero { padding: 20px 32px 8px; }
    .answers-kicker { font-size: 11px; font-weight: 700; color: var(--accent); text-transform: uppercase; letter-spacing: .08em; margin-bottom: 6px; }
    .answers-title { font-size: 26px; font-weight: 700; letter-spacing: -.03em; color: var(--text); margin-bottom: 6px; }
    .answers-sub { max-width: 720px; color: var(--muted); font-size: 14px; line-height: 1.6; }
    .answers-grid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 14px; align-items: stretch; }
    .answers-grid .disc-item { display: flex; flex-direction: column; min-width: 0; min-height: 286px; padding: 13px; border: 1px solid var(--line); border-radius: 12px; background: var(--panel); overflow: hidden; }
    .answers-grid .disc-item:nth-child(odd) { background: var(--panel); }
    .answers-card { cursor: pointer; }
    .answers-card:hover { border-color: var(--line); background: var(--panel-2); transform: none; }
    .answers-card:hover .disc-item-title { color: var(--accent); }
    .answers-card .disc-item-body { min-width: 0; display: flex; flex-direction: column; flex: 1; }
    .answers-card .disc-item-meta { min-width: 0; flex-wrap: wrap; }
    .answers-card .disc-item-title { font-size: 16px; line-height: 1.24; letter-spacing: -.01em; font-weight: 700; }
    .answers-card .disc-item-excerpt { display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
    .answers-photo { width: 100%; aspect-ratio: 1 / .72; border-radius: 8px; margin-bottom: 12px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; font-size: 34px; overflow: hidden; position: relative; background: var(--panel-2); }
    .answers-photo svg, .answers-wiki-photo svg { width: 100%; height: 100%; display: block; }
    .answers-photo span { position: relative; z-index: 1; }
    .answers-read { display: inline-flex; align-items: center; gap: 6px; color: var(--accent); font-size: 13px; font-weight: 700; margin-top: auto; padding-top: 10px; }
    .answers-search-row { margin-top: 12px; }
    .answers-search-input {
      width: min(520px, 100%); border: 1px solid var(--line); border-radius: 999px;
      background: var(--panel); color: var(--text); padding: 11px 15px;
      font: inherit; font-size: 14px; outline: none;
    }
    .answers-search-input:focus { border-color: rgba(232,87,42,.55); box-shadow: 0 0 0 3px rgba(232,87,42,.12); }
    .answers-featured-row { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; padding: 0 32px 14px; }
    .answers-featured-chip {
      text-align: left; border: 1px solid var(--line); border-radius: 10px;
      background: color-mix(in srgb, var(--panel) 92%, var(--accent) 4%);
      padding: 12px 13px; color: var(--text); font: inherit; cursor: pointer; min-width: 0;
    }
    .answers-featured-chip span { display: block; color: var(--accent); font-size: 10px; font-weight: 950; letter-spacing: .08em; text-transform: uppercase; margin-bottom: 5px; }
    .answers-featured-chip b { display: block; font-size: 13px; line-height: 1.35; font-weight: 850; }
    .answers-empty { margin: 0 32px; border: 1px solid var(--line); border-radius: 12px; background: var(--panel); color: var(--muted); padding: 24px; text-align: center; }
    .answers-page-detail .disc-header { display: none; }
    .answers-page-detail .answers-wiki { padding-top: 18px; }
    .answers-wiki { padding: 20px 32px 100px; max-width: 920px; }
    .answers-wiki-back { display: inline-flex; align-items: center; gap: 7px; background: var(--panel); border: 1px solid var(--line); border-radius: 8px; color: var(--muted); padding: 7px 13px; font-size: 12px; font-weight: 700; cursor: pointer; margin-bottom: 14px; font-family: inherit; }
    .answers-wiki-back:hover { color: var(--text); background: var(--hover); }
    .answers-related-panel { margin-top: 28px; border-top: 1px solid var(--line); padding-top: 22px; }
    .answers-related-head { display: block; margin-bottom: 14px; }
    .answers-related-head span { display: block; color: var(--accent); font-size: 13px; font-weight: 850; letter-spacing: .04em; margin-bottom: 3px; }
    .answers-related-head h2 { margin: 0 !important; font-size: 22px; line-height: 1.2; letter-spacing: -.01em; }
    .answers-related-list { list-style: none; padding: 0 !important; margin: 0 !important; display: grid; gap: 8px; }
    .answers-related-list button { width: 100%; display: block; text-align: left; background: color-mix(in srgb, var(--accent) 7%, var(--panel)); border: 1px solid color-mix(in srgb, var(--accent) 26%, var(--line)); border-radius: 8px; color: var(--accent); padding: 14px 15px; font: inherit; cursor: pointer; transition: border-color .15s ease, background .15s ease, color .15s ease, transform .15s ease; }
    .answers-related-list button span { font-size: 15px; line-height: 1.65; font-weight: 650; min-width: 0; }
    .answers-related-list button:hover { border-color: rgba(232,87,42,.55); background: var(--hover); color: var(--accent); }
    .answers-wiki-photo { height: 220px; border-radius: 10px; margin-bottom: 22px; display: flex; align-items: center; justify-content: center; font-size: 54px; background: var(--panel-2); position: relative; overflow: hidden; }
    .answers-wiki-photo span { position: relative; z-index: 1; }
    .answers-wiki h1 { font-size: 34px; line-height: 1.15; letter-spacing: -.035em; margin: 0 0 12px; font-weight: 700; }
    .answers-wiki-lede { font-size: 17px; line-height: 1.7; color: var(--muted); margin-bottom: 22px; }
    .answers-wiki h2 { font-size: 18px; margin: 24px 0 8px; }
    .answers-wiki p, .answers-wiki li { font-size: 15px; line-height: 1.75; color: var(--text); }
    .answers-wiki ul { padding-left: 20px; }
    .answers-callout { border-left: 3px solid var(--accent); background: var(--panel); border-radius: 0 12px 12px 0; padding: 14px 16px; margin: 20px 0; color: var(--text); line-height: 1.65; }
    @media (max-width: 768px) {
      .answers-hero { padding: 14px 16px 6px; }
      .answers-title { font-size: 22px; }
      .answers-grid { grid-template-columns: 1fr; gap: 12px; }
      .answers-grid .disc-item { min-height: 206px; padding: 10px; }
      .answers-card .disc-item-title { font-size: 15px; }
      .answers-card .disc-item-excerpt { -webkit-line-clamp: 2; }
      .answers-photo { width: 100%; height: auto; font-size: 24px; aspect-ratio: 1 / .45; margin-bottom: 9px; }
      .answers-featured-row { grid-template-columns: 1fr; padding: 0 16px 12px; }
      .answers-related-head h2 { font-size: 20px; }
      .answers-related-list button span { font-size: 15px; }
      .answers-wiki { padding: 16px 16px 100px; }
      .answers-wiki-photo { height: 150px; }
      .answers-wiki h1 { font-size: 25px; }
    }

    .portfolio-page {
      display: none; flex: 1; flex-direction: column; overflow-y: auto;
      -webkit-overflow-scrolling: touch; touch-action: pan-y; background: var(--bg);
      scrollbar-width: thin; font-family: "Geist", "Geist Fallback", ui-sans-serif, system-ui, sans-serif;
      min-height: 0; height: 100%;
    }
    .portfolio-page.visible { display: flex; }
    .portfolio-page.pf-logged-out .pf-hero-value,
    .portfolio-page.pf-logged-out .pf-hero-pnl,
    .portfolio-page.pf-logged-out .pf-period-pills,
    .portfolio-page.pf-logged-out .pf-charts-row,
    .portfolio-page.pf-logged-out .pf-page-tabs,
    .portfolio-page.pf-logged-out .pf-add-bar,
    .portfolio-page.pf-logged-out .pf-hero-add-btn,
    .portfolio-page.pf-logged-out #pfInsightBtn,
    .portfolio-page.pf-logged-out .pf-share-btn,
    .portfolio-page.pf-logged-out .pf-stealth-btn { display: none !important; }
    .portfolio-page.pf-logged-out .pf-hero { position: relative; padding-bottom: 8px; }
    .pf-page-inner { display: flex; flex-direction: column; gap: 24px; padding: 0 32px 120px; }
    .pf-public-banner {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 14px;
      padding: 13px 16px;
      border: 1px solid rgba(255,215,0,.22);
      border-radius: 8px;
      background: rgba(255,215,0,.07);
    }
    .pf-public-banner b { display: block; color: var(--text); font-size: 14px; line-height: 1.2; }
    .pf-public-banner span { display: block; margin-top: 2px; color: var(--muted); font-size: 12px; line-height: 1.35; }
    .pf-public-banner button {
      border: 0;
      border-radius: 7px;
      background: var(--accent);
      color: #111;
      font-size: 12px;
      font-weight: 700;
      padding: 8px 12px;
      cursor: pointer;
      white-space: nowrap;
    }

    .pf-hero {
      position: sticky; top: 0; z-index: 20; background: var(--bg);
      padding: 28px 32px 20px;
    }
    .pf-hero-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; }
    .pf-hero-left { flex: 1; min-width: 0; }
    .pf-hero-label { font-size: 11px; font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: .08em; margin-bottom: 6px; }
    .pf-hero-value { font-size: 48px; font-weight: 800; color: var(--text); letter-spacing: -.03em; line-height: 1.1; }
    .pf-hero-value.stealth { letter-spacing: .04em; }
    .pf-hero-pnl { font-size: 16px; font-weight: 700; margin-top: 8px; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
    .pf-hero-pnl-pill { display: inline-flex; align-items: center; gap: 4px; padding: 5px 14px; border-radius: 20px; font-size: 14px; font-weight: 700; line-height: 1.2; }
    .pf-hero-pnl-pill.up { background: rgba(0,187,127,.15); color: #00bb7f; }
    .pf-hero-pnl-pill.down { background: rgba(239,83,80,.14); color: #ef5350; }
    .pf-hero-pnl-period { font-size: 11px; font-weight: 600; color: var(--muted); text-transform: uppercase; letter-spacing: .04em; }
    .pf-hero-actions { display: flex; align-items: center; gap: 8px; flex-shrink: 0; padding-top: 4px; }
    .pf-stealth-btn {
      width: 36px; height: 36px; border-radius: 0.625rem; border: 1px solid var(--line);
      background: var(--panel-2); color: var(--muted); cursor: pointer;
      display: flex; align-items: center; justify-content: center; font-size: 16px;
      transition: background .15s, color .15s;
    }
    .pf-stealth-btn:hover { background: var(--panel); color: var(--text); }
    .pf-stealth-btn.active { background: var(--accent); color: #fff; border-color: var(--accent); }
    .pf-back-btn {
      display: flex; align-items: center; gap: 4px;
      padding: 6px 14px; border-radius: 8px; border: 1px solid var(--line);
      background: var(--panel); color: var(--text); cursor: pointer;
      font-size: 12px; font-weight: 600; font-family: inherit;
      transition: background .15s, color .15s, border-color .15s;
    }
    .pf-back-btn:hover { background: var(--hover); border-color: rgba(255,255,255,.18); }
    .pf-share-btn {
      width: 36px; height: 36px; border-radius: 0.625rem; border: 1px solid var(--line);
      background: var(--panel-2); color: var(--muted); cursor: pointer;
      display: flex; align-items: center; justify-content: center;
      transition: background .15s, color .15s;
    }
    .pf-share-btn:hover { background: var(--panel); color: var(--text); }
    .pf-more-btn {
      display: none; align-items: center; justify-content: center; gap: 3px;
      width: 36px; height: 36px; border-radius: 0.625rem; border: 1px solid var(--line);
      background: var(--panel-2); color: var(--muted); cursor: pointer;
    }
    .pf-more-btn span {
      width: 4px; height: 4px; border-radius: 50%; background: currentColor;
    }
    .pf-share-modal-overlay {
      position: fixed; inset: 0; z-index: 10050; background: rgba(0,0,0,.7);
      display: flex; align-items: center; justify-content: center;
      animation: pfShareFadeIn .2s ease;
    }
    @keyframes pfShareFadeIn { from { opacity: 0; } to { opacity: 1; } }
    .pf-share-modal {
      background: #242424; border-radius: 16px; padding: 24px; max-width: 520px; width: 90%;
      display: flex; flex-direction: column; align-items: center; gap: 16px;
    }
    .pf-share-modal img { width: 100%; border-radius: 10px; box-shadow: 0 4px 24px rgba(0,0,0,.4); }
    .pf-share-modal-btns { display: flex; gap: 10px; width: 100%; }
    .pf-share-modal-btns button {
      flex: 1; padding: 10px 0; border-radius: 8px; border: none; font-family: inherit;
      font-size: 13px; font-weight: 700; cursor: pointer; transition: opacity .15s;
    }
    .pf-share-modal-btns button:hover { opacity: .85; }
    .pf-share-modal-btns .pf-share-copy { background: #ffd700; color: #1a1a1a; }
    .pf-share-modal-btns .pf-share-dl { background: rgba(255,255,255,.1); color: #f5f5f5; }
    .pf-share-modal-close {
      position: absolute; top: 12px; right: 16px; background: none; border: none;
      color: #8c8c8c; font-size: 22px; cursor: pointer; line-height: 1;
    }
    .pf-period-pills { display: inline-flex; gap: 2px; margin-top: 14px; overflow-x: auto; scrollbar-width: none; background: var(--panel-2); border-radius: 0.625rem; padding: 3px; }
    .pf-period-pills::-webkit-scrollbar { display: none; }
    .pf-period-pill {
      padding: 7px 14px; border-radius: 6px; border: none;
      background: var(--panel-2); color: var(--muted); cursor: pointer;
      font-size: 12px; font-weight: 700; font-family: inherit;
      transition: all .15s; white-space: nowrap; flex-shrink: 0;
      min-width: 36px; text-align: center;
    }
    .pf-period-pill:hover { background: var(--panel-2); color: var(--text); }
    .pf-period-pill.active { background: var(--accent); color: #fff; }

    /* Asset chart header — shown when an individual asset is selected */
    .pf-asset-header { display: none; padding: 0 0 10px; }
    .pf-asset-header.visible { display: block; }
    .pf-asset-name { font-size: 18px; font-weight: 800; color: var(--text); letter-spacing: -.02em; }
    .pf-asset-price { font-size: 15px; font-weight: 700; margin-top: 2px; }
    .pf-asset-price.up { color: #00bb7f; }
    .pf-asset-price.down { color: #ef5350; }

    /* Charts card — shared container */
    .pf-charts-row {
      display: flex; gap: 0; flex-wrap: wrap;
      background: var(--panel); border: 1px solid var(--line); border-radius: 0.625rem;
      padding: 14px 16px; overflow: hidden;
      min-height: 176px;
    }
    .pf-area-chart {
      flex: 0 0 62%; min-width: 200px; height: 150px; max-height: 150px;
      padding: 8px 10px 20px 36px;
      display: flex; align-items: center; justify-content: center; overflow: hidden;
      position: relative;
    }
    .pf-area-chart svg { width: 100%; height: 100%; }
    .pf-chart-y-labels { position: absolute; left: 4px; top: 10px; bottom: 24px; display: flex; flex-direction: column; justify-content: space-between; pointer-events: none; }
    .pf-chart-y-label { font-size: 9px; color: var(--muted); font-weight: 600; font-variant-numeric: tabular-nums; }
    .pf-chart-x-labels { position: absolute; left: 40px; right: 10px; bottom: 4px; display: flex; justify-content: space-between; pointer-events: none; }
    .pf-chart-x-label { font-size: 9px; color: var(--muted); font-weight: 600; }
    .pf-chart-tooltip { position: absolute; background: var(--panel-2); border: 1px solid var(--line); border-radius: 8px; padding: 4px 8px; font-size: 11px; font-weight: 700; color: var(--text); pointer-events: none; display: none; z-index: 10; white-space: nowrap; box-shadow: 0 2px 8px rgba(0,0,0,.3); }
    .pf-donut {
      flex: 0 0 38%; min-width: 220px; min-height: 150px;
      padding: 0 0 0 20px; border-left: 1px solid var(--line);
      display: flex; align-items: center; gap: 14px; position: relative;
    }
    .pf-donut svg { flex-shrink: 0; }
    .pf-donut-center {
      position: absolute; top: 50%; transform: translate(-50%, -50%);
      text-align: center; pointer-events: none; width: 80px;
    }
    .pf-donut-center-val { display: none; }
    .pf-donut-center-label { font-size: 9px; font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: .06em; }
    .pf-chart-empty { font-size: 13px; color: var(--muted); text-align: center; }
    .pf-donut-legend-side { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 5px 8px; flex: 1; min-width: 0; align-content: center; }
    .pf-donut-legend-item { display: flex; align-items: center; gap: 6px; font-size: 11px; color: var(--muted); white-space: nowrap; }
    .pf-donut-legend-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
    .pf-donut-legend-pct { font-weight: 700; color: var(--text); font-variant-numeric: tabular-nums; margin-left: auto; }
    .pf-donut-legend-dollar { font-size: 10px; color: var(--muted); font-weight: 600; margin-left: 2px; }
    .pf-alloc-toggle { display: inline-flex; gap: 0; margin-bottom: 2px; background: var(--panel-2); border-radius: 6px; border: 1px solid var(--line); padding: 1px; grid-column: 1 / -1; width: max-content; }
    .pf-alloc-toggle-btn { background: none; border: none; color: var(--muted); font-size: 9px; font-weight: 700; padding: 2px 7px; cursor: pointer; font-family: inherit; border-radius: 5px; transition: all .12s; text-transform: uppercase; letter-spacing: .03em; }
    .pf-alloc-toggle-btn.active { background: var(--accent); color: #fff; }
    .pf-alloc-bars { display: flex; flex-direction: column; gap: 5px; flex: 1; }
    .pf-alloc-bar-row { display: flex; align-items: center; gap: 8px; font-size: 11px; }
    .pf-alloc-bar-label { width: 65px; color: var(--muted); flex-shrink: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .pf-alloc-bar-track { flex: 1; height: 8px; background: rgba(255,255,255,.06); border-radius: 4px; overflow: hidden; }
    .pf-alloc-bar-fill { height: 100%; border-radius: 4px; transition: width .3s; }
    .pf-alloc-bar-pct { width: 32px; text-align: right; font-weight: 700; color: var(--text); font-variant-numeric: tabular-nums; }

    .pf-page-tabs {
      display: flex; gap: 4px; padding: 0 32px; border-bottom: 1px solid var(--line);
      align-items: center;
    }
    .pf-page-tab {
      background: none; border: none; color: var(--muted); font-size: 13px; font-weight: 600;
      padding: 12px 18px; cursor: pointer; font-family: inherit; border-bottom: 2px solid transparent;
      transition: all .15s;
    }
    .pf-page-tab:hover { color: var(--text); }
    .pf-page-tab.active { color: var(--accent); border-bottom-color: var(--accent); }
    .pf-add-tab-btn {
      margin-left: auto; margin-right: 0; padding: 6px 14px; border-radius: 6px; border: none;
      background: var(--accent); color: #fff; font-size: 12px; font-weight: 700;
      cursor: pointer; font-family: inherit; transition: opacity .15s;
      align-self: center; flex-shrink: 0;
    }
    .pf-add-tab-btn:hover { opacity: .85; }
    .pf-hero-add-btn {
      display: inline-flex; align-items: center; gap: 6px; background: var(--accent); color: #fff;
      border: none; border-radius: 8px; padding: 7px 14px; font-size: 12px; font-weight: 800;
      cursor: pointer; font-family: inherit; box-shadow: 0 8px 20px rgba(232,87,42,.22);
    }
    .pf-hero-add-btn:hover { opacity: .9; }

    .pf-tab-content { padding: 0; }

    .pf-section { margin-bottom: 8px; }
    .pf-section-head {
      display: flex; align-items: center; justify-content: space-between;
      font-size: 10px; font-weight: 700; color: var(--muted); text-transform: uppercase;
      letter-spacing: .06em; padding: 10px 4px 6px;
    }
    .pf-section-total { font-size: 12px; font-weight: 700; color: var(--text); text-transform: none; letter-spacing: 0; }

    /* Shared grid for header + data rows — guarantees column alignment */
    .pf-grid { display: grid; grid-template-columns: 180px 1fr 1fr 1fr 1.3fr 1.2fr 1fr 28px; align-items: center; }
    .pf-holdings-header {
      padding: 0 10px 8px;
      font-size: 10px; font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: .04em;
      border-bottom: 1px solid var(--line); margin-bottom: 2px;
      user-select: none;
    }
    .pf-holdings-header > div { text-align: right; }
    .pf-holdings-header > div:first-child { text-align: left; padding-left: 46px; }
    .pf-hdr-sortable { cursor: pointer; transition: color .12s; display: inline-flex; align-items: center; gap: 3px; justify-content: flex-end; }
    .pf-hdr-sortable:hover { color: var(--text); }
    .pf-hdr-sortable.active { color: var(--text); }
    .pf-hdr-sort-arrow { font-size: 8px; transition: opacity .12s; }
    .pf-hdr-sortable .pf-hdr-sort-arrow { opacity: .35; }
    .pf-hdr-sortable:hover .pf-hdr-sort-arrow { opacity: .6; }
    .pf-hdr-sortable.active .pf-hdr-sort-arrow { opacity: 1; }
    .pf-row {
      padding: 8px 10px;
      border-radius: 8px; cursor: pointer; transition: background .12s; position: relative;
      min-height: 44px; border-bottom: 1px solid var(--line);
    }
    .pf-row:last-child { border-bottom: none; }
    .pf-row:hover { background: var(--hover); }
    .pf-row.highlight { animation: pfHighlight .8s ease; }
    @keyframes pfHighlight {
      0% { background: rgba(246,74,0,.15); }
      100% { background: transparent; }
    }
    .pf-row-icon {
      width: 32px; height: 32px; border-radius: 4px; display: flex; align-items: center;
      justify-content: center; font-size: 11px; font-weight: 800; letter-spacing: -.02em; flex-shrink: 0;
      margin-right: 10px;
    }
    .pf-row-info { min-width: 0; }
    .pf-row-name { font-size: 13px; font-weight: 600; color: var(--text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    .pf-row-sub { font-size: 11px; color: var(--muted); margin-top: 0; }
    .pf-row-cell-val { text-align: right; }
    .pf-row-cell-label { display: none; }
    .pf-row-mobile-data { display: none; font-size: 11px; color: var(--muted); margin-top: 2px; }
    .pf-row-chart-btn {
      background: none; border: none; color: var(--muted); cursor: pointer;
      padding: 4px; border-radius: 4px; display: flex; align-items: center;
      justify-content: center; flex-shrink: 0; margin-right: 4px;
      opacity: .4; transition: opacity .15s, color .15s;
    }
    .pf-row:hover .pf-row-chart-btn { opacity: .7; }
    .pf-row-chart-btn:hover { opacity: 1; color: var(--accent); }
    .pf-row-cell-val { font-size: 13px; font-weight: 600; color: var(--text); font-variant-numeric: tabular-nums; }
    .pf-row-alloc { width: 50px; height: 3px; background: rgba(255,255,255,.06); border-radius: 2px; overflow: hidden; flex-shrink: 0; margin-left: 8px; }
    .pf-row-alloc-bar { height: 100%; background: var(--accent); border-radius: 2px; transition: width .3s; }
    /* Hamburger menu button — NO opacity (it makes child dropdown transparent) */
    .pf-row-menu-btn {
      background: none; border: none; color: rgba(255,255,255,.6); cursor: pointer; padding: 6px 4px;
      border-radius: 6px; display: flex; align-items: center; justify-content: center;
      flex-shrink: 0; transition: color .15s, background .15s; position: relative;
      margin-left: 4px;
    }
    .pf-row:hover .pf-row-menu-btn { color: rgba(255,255,255,.85); }
    .pf-row-menu-btn:hover { color: var(--text); background: var(--panel-2); }
    /* Dropdown menu — must be fully opaque, no bleed-through */
    .pf-row-dropdown {
      display: none; position: absolute; right: 0; top: 100%; z-index: 200;
      background-color: var(--panel); border: 1px solid var(--line); border-radius: 10px;
      box-shadow: 0 4px 20px rgba(0,0,0,.6), 0 0 0 1px rgba(0,0,0,.2); min-width: 160px; padding: 4px;
    }
    html[data-theme="light"] .pf-row-dropdown { box-shadow: 0 4px 20px rgba(0,0,0,.15), 0 0 0 1px rgba(0,0,0,.06); }
    .pf-row-dropdown.open { display: block; }
    .pf-row-dropdown-item {
      display: flex; align-items: center; gap: 8px; padding: 10px 14px; font-size: 13px;
      font-weight: 500; color: var(--text); cursor: pointer; border-radius: 6px; border: none;
      background: none; width: 100%; text-align: left; font-family: inherit;
    }
    .pf-row-dropdown-item:hover { background: var(--hover); }
    .pf-row-dropdown-item.danger { color: #ef5350; }
    .pf-row-dropdown-item .pf-dd-icon { font-size: 14px; width: 18px; text-align: center; }
    /* Expand area */
    .pf-row-expand {
      padding: 12px 14px 14px; background: rgba(255,255,255,.02);
      border-top: 1px solid var(--line); border-radius: 0 0 12px 12px;
      display: none; margin-top: -2px;
    }
    .pf-row-expand.open { display: block; }
    /* Transaction list in expand */
    .pf-txn-list { display: flex; flex-direction: column; gap: 0; }
    .pf-txn-row {
      display: flex; align-items: center; gap: 10px; padding: 8px 0;
      border-bottom: 1px solid rgba(255,255,255,.04); font-size: 12px;
    }
    .pf-txn-row:last-child { border-bottom: none; }
    .pf-txn-badge {
      font-size: 10px; font-weight: 800; text-transform: uppercase; padding: 2px 8px;
      border-radius: 4px; letter-spacing: .04em; flex-shrink: 0;
    }
    .pf-txn-badge.buy { background: rgba(0,187,127,.15); color: #00bb7f; }
    .pf-txn-badge.sell { background: rgba(239,83,80,.14); color: #ef5350; }
    .pf-txn-detail { flex: 1; color: var(--muted); }
    .pf-txn-pnl { font-weight: 600; font-variant-numeric: tabular-nums; text-align: right; min-width: 70px; }
    .pf-txn-date { font-size: 10px; color: var(--muted); min-width: 60px; }
    .pf-txn-del {
      background: none; border: none; color: var(--muted); cursor: pointer; padding: 2px 4px;
      font-size: 12px; opacity: .4; border-radius: 4px;
    }
    .pf-txn-del:hover { opacity: 1; color: #ef5350; }
    .pf-txn-empty { font-size: 12px; color: var(--muted); padding: 8px 0; }
    /* Transaction input modal (inline) */
    .pf-txn-form {
      display: flex; gap: 8px; align-items: center; flex-wrap: wrap;
      padding: 10px 0 4px; border-top: 1px solid var(--line); margin-top: 8px;
    }
    .pf-txn-input {
      width: 80px; padding: 6px 8px; border-radius: 6px; border: 1px solid var(--line);
      background: var(--panel); color: var(--text); font-size: 12px; font-family: inherit; outline: none;
    }
    .pf-txn-input:focus { border-color: var(--accent); }
    .pf-txn-submit {
      padding: 6px 14px; border-radius: 6px; border: none; font-size: 12px; font-weight: 600;
      cursor: pointer; font-family: inherit; background: var(--accent); color: #fff;
    }
    .pf-txn-submit:hover { opacity: .85; }
    .pf-watching-badge {
      font-size: 10px; font-weight: 700; color: var(--muted); text-transform: uppercase;
      letter-spacing: .04em; background: var(--panel-2); padding: 2px 8px; border-radius: 6px;
    }

    /* Movers cards */
    .pf-mover {
      display: flex; align-items: center; gap: 12px; padding: 12px 14px;
      border-radius: 0.625rem; background: var(--panel); border: 1px solid var(--line);
      margin-bottom: 8px;
    }
    .pf-mover-icon { width: 32px; height: 32px; border-radius: 4px; display: flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 800; flex-shrink: 0; }
    .pf-mover-info { flex: 1; min-width: 0; }
    .pf-mover-name { font-size: 13px; font-weight: 600; color: var(--text); }
    .pf-mover-price { font-size: 12px; color: var(--muted); margin-top: 1px; }
    .pf-mover-change { font-size: 13px; font-weight: 600; flex-shrink: 0; font-variant-numeric: tabular-nums; }
    .pf-watchlist-list { display: grid; gap: 6px; }
    .pf-watchlist-row { display: flex; align-items: center; gap: 10px; padding: 10px 12px; border: 1px solid var(--line); border-radius: 10px; background: var(--hover); }
    .pf-watchlist-row:hover { background: var(--active); }
    .pf-watchlist-actions { display: flex; align-items: center; gap: 6px; flex-shrink: 0; }
    .pf-wl-alert-btn { flex-shrink: 0; border: 1px solid rgba(255,215,0,.28); border-radius: 7px; background: rgba(255,215,0,.08); color: var(--accent); padding: 5px 9px; font: inherit; font-size: 11px; font-weight: 800; cursor: pointer; white-space: nowrap; }
    .pf-wl-alert-btn:hover { background: rgba(255,215,0,.16); }
    .pf-wl-add-btn { flex-shrink: 0; border: 1px solid rgba(43,181,138,.3); border-radius: 7px; background: rgba(43,181,138,.10); color: #2bb58a; padding: 5px 9px; font: inherit; font-size: 11px; font-weight: 800; cursor: pointer; white-space: nowrap; }
    .pf-wl-add-btn:hover { background: rgba(43,181,138,.2); }
    .pf-wl-remove-btn { flex-shrink: 0; border: 1px solid var(--line); border-radius: 7px; background: transparent; color: var(--muted); padding: 5px 8px; font: inherit; font-size: 11px; cursor: pointer; }
    .pf-wl-remove-btn:hover { color: var(--danger); border-color: rgba(239,83,80,.3); }
    .pf-movers-label { font-size: 11px; font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: .06em; margin-bottom: 8px; padding: 0 4px; }

    /* Sports items */
    .pf-sport-row {
      display: flex; align-items: center; gap: 12px; padding: 12px 14px;
      border-radius: 0.625rem; cursor: pointer; transition: background .12s;
    }
    .pf-sport-row:hover { background: var(--hover); }
    .pf-sport-icon { font-size: 24px; flex-shrink: 0; }
    .pf-sport-info { flex: 1; min-width: 0; }
    .pf-sport-name { font-size: 14px; font-weight: 600; color: var(--text); }
    .pf-sport-meta { font-size: 12px; color: var(--muted); margin-top: 1px; display: flex; align-items: center; gap: 8px; }
    .pf-sport-badge {
      font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em;
      padding: 2px 6px; border-radius: 4px; background: rgba(0,187,127,.12); color: #00bb7f;
    }
    .pf-sport-remove {
      background: none; border: none; color: var(--muted); font-size: 14px;
      cursor: pointer; padding: 4px; border-radius: 6px; opacity: 0; transition: opacity .15s;
    }
    .pf-sport-row:hover .pf-sport-remove { opacity: 1; }
    .pf-sport-remove:hover { color: #ff6568; }

    /* Add bar — inline search */
    .pf-add-bar {
      background: var(--panel); border: 1px solid var(--line); border-radius: 0.625rem;
      padding: 12px 16px; margin: 0 0 12px;
    }
    .pf-add-bar-inner { position: relative; display: flex; gap: 8px; align-items: center; }
    .pf-add-input {
      flex: 1; padding: 10px 14px; border-radius: 0.625rem; border: 1px solid var(--line);
      background: var(--bg); color: var(--text); font-size: 14px; font-family: inherit;
      outline: none; box-sizing: border-box; transition: border-color .15s;
    }
    .pf-add-btn {
      padding: 10px 18px; border-radius: 0.625rem; border: none; background: var(--accent); color: #fff;
      font-size: 13px; font-weight: 700; cursor: pointer; font-family: inherit; white-space: nowrap;
      display: flex; align-items: center; gap: 4px; transition: opacity .15s; flex-shrink: 0;
    }
    .pf-add-btn:hover { opacity: .85; }
    .pf-add-input:focus { border-color: var(--accent); }
    .pf-add-dropdown {
      display: none; position: absolute; bottom: 100%; left: 0; right: 0;
      background: var(--panel); border: 1px solid var(--line); border-radius: 0.625rem;
      max-height: 320px; overflow-y: auto; margin-bottom: 8px;
      box-shadow: 0 -8px 32px rgba(0,0,0,.4);
    }
    .pf-add-dropdown.open { display: block; }
    .pf-add-result {
      display: flex; align-items: center; gap: 12px; padding: 10px 14px;
      cursor: pointer; transition: background .12s;
    }
    .pf-add-result:hover { background: var(--hover); }
    .pf-add-result:first-child { border-radius: 0.625rem 0.625rem 0 0; }
    .pf-add-result:last-child { border-radius: 0 0 0.625rem 0.625rem; }
    .pf-add-result-icon { font-size: 20px; flex-shrink: 0; }
    .pf-add-result-info { flex: 1; min-width: 0; }
    .pf-add-result-name { font-size: 14px; font-weight: 600; color: var(--text); }
    .pf-add-result-sub { font-size: 12px; color: var(--muted); }
    .pf-add-result-badge {
      font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .05em;
      padding: 3px 8px; border-radius: 5px; flex-shrink: 0;
    }
    .pf-add-form-inline {
      padding: 12px 14px; background: rgba(255,255,255,.03); border-top: 1px solid var(--line);
    }
    .pf-add-form-row { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
    .pf-add-form-input {
      width: 100px; padding: 8px 10px; border-radius: 8px; border: 1px solid var(--line);
      background: var(--panel-2); color: var(--text); font-size: 13px; font-family: inherit; outline: none;
    }
    .pf-add-form-input:focus { border-color: var(--accent); }
    .pf-add-form-btn {
      padding: 8px 14px; border-radius: 8px; border: none; font-size: 12px; font-weight: 600;
      cursor: pointer; font-family: inherit;
    }
    .pf-add-form-btn.primary { background: var(--accent); color: #fff; }
    .pf-add-form-btn.secondary { background: var(--panel-2); color: var(--muted); border: 1px solid var(--line); }
    .pf-add-form-btn:hover { opacity: .85; }

    .pf-empty { text-align: center; padding: 60px 24px; }
    .pf-empty-icon { font-size: 48px; margin-bottom: 16px; }
    .pf-empty-title { font-size: 20px; font-weight: 700; color: var(--text); margin-bottom: 8px; overflow-wrap: anywhere; }
    .pf-empty-text { font-size: 14px; color: var(--muted); line-height: 1.6; max-width: 360px; margin: 0 auto; overflow-wrap: anywhere; }
    .pf-empty-cta { margin-top: 18px; display: inline-flex; align-items: center; justify-content: center; border: 0; border-radius: 999px; background: var(--accent); color: #fff; padding: 10px 16px; font: inherit; font-size: 13px; font-weight: 850; cursor: pointer; }
    .pf-empty-secondary { margin-top: 18px; display: inline-flex; align-items: center; justify-content: center; border: 1px solid var(--line); border-radius: 999px; background: var(--panel); color: var(--text); padding: 10px 16px; font: inherit; font-size: 13px; font-weight: 800; cursor: pointer; }
    .pf-empty-actions { display: flex; justify-content: center; gap: 10px; flex-wrap: wrap; }
    .pf-empty-preview { max-width: 620px; margin: 24px auto 0; display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; }
    .pf-empty-preview-card { border: 1px solid var(--line); border-radius: 14px; background: rgba(255,255,255,.035); padding: 13px; text-align: left; }
    .pf-empty-preview-label { color: var(--accent); font-size: 10px; font-weight: 850; letter-spacing: .08em; text-transform: uppercase; margin-bottom: 6px; }
    .pf-empty-preview-copy { color: var(--muted); font-size: 12px; line-height: 1.45; }
    .pf-empty-product { display: grid; grid-template-columns: minmax(0, 1fr) 310px; align-items: center; gap: 28px; text-align: left; max-width: 920px; }
    .pf-empty-product .pf-empty-copy { text-align: center; min-width: 0; }
    .pf-empty-dashboard { border: 1px solid var(--line); border-radius: 16px; background: linear-gradient(145deg, color-mix(in srgb, var(--panel) 88%, var(--accent) 5%), var(--panel)); padding: 18px; box-shadow: 0 18px 50px rgba(0,0,0,.28); min-width: 0; }
    .pf-empty-dash-top { display: flex; align-items: center; justify-content: space-between; gap: 12px; color: var(--muted); font-size: 11px; font-weight: 800; letter-spacing: .06em; text-transform: uppercase; }
    .pf-empty-dash-top strong { color: #00bb7f; font-size: 12px; }
    .pf-empty-dash-value { color: var(--text); font-size: 34px; font-weight: 850; letter-spacing: -.03em; margin: 12px 0; }
    .pf-empty-dash-chart { height: 78px; border-radius: 12px; background: linear-gradient(180deg, rgba(0,187,127,.14), transparent), linear-gradient(135deg, transparent 12%, rgba(255,255,255,.05) 12%, rgba(255,255,255,.05) 13%, transparent 13%, transparent 28%, rgba(255,255,255,.06) 28%, rgba(255,255,255,.06) 29%, transparent 29%); overflow: hidden; position: relative; margin-bottom: 12px; }
    .pf-empty-dash-chart span { position: absolute; left: 10px; right: 10px; bottom: 18px; height: 36px; border-bottom: 3px solid #00bb7f; border-radius: 50% 25% 0 0; transform: skewX(-16deg); opacity: .95; }
    .pf-empty-dash-row { display: grid; grid-template-columns: 1fr auto auto; gap: 10px; padding: 9px 0; border-top: 1px solid var(--line); font-size: 12px; align-items: center; }
    .pf-empty-dash-row b { color: var(--text); }
    .pf-empty-dash-row span { color: var(--muted); font-variant-numeric: tabular-nums; }
    .pf-empty-dash-row em { color: var(--accent); font-style: normal; font-weight: 800; }

    .pf-snapshot-grid { display: grid; grid-template-columns: repeat(6, minmax(0, 1fr)); gap: 10px; }
    .pf-snapshot-card { border: 1px solid var(--line); border-radius: 0.625rem; background: color-mix(in srgb, var(--panel) 92%, var(--accent) 2%); padding: 12px; min-width: 0; }
    .pf-snapshot-label { color: var(--muted); font-size: 9px; font-weight: 850; letter-spacing: .07em; text-transform: uppercase; margin-bottom: 7px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .pf-snapshot-value { color: var(--text); font-size: 18px; font-weight: 850; letter-spacing: -.02em; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .pf-snapshot-sub { color: var(--muted); font-size: 11px; line-height: 1.35; margin-top: 3px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .pf-snapshot-card.up .pf-snapshot-value, .pf-snapshot-card.up .pf-snapshot-sub { color: #00bb7f; }
    .pf-snapshot-card.down .pf-snapshot-value, .pf-snapshot-card.down .pf-snapshot-sub { color: #ef5350; }
    .pf-snapshot-card.warn { border-color: rgba(255,215,0,.28); background: rgba(255,215,0,.045); }
    .pf-benchmark-panel, .pf-dca-panel {
      border: 1px solid var(--line); border-radius: 0.625rem; background: var(--panel);
      padding: 14px 16px;
    }
    .pf-panel-title { color: var(--accent); font-size: 10px; font-weight: 900; letter-spacing: .08em; text-transform: uppercase; margin-bottom: 8px; }
    .pf-modal-local-read { border: 1px solid var(--line); border-radius: 12px; background: var(--panel-2); padding: 13px 14px; margin-bottom: 14px; }
    .pf-modal-kicker { color: var(--accent); font-size: 10px; font-weight: 900; letter-spacing: .08em; text-transform: uppercase; margin-bottom: 8px; }
    .pf-modal-local-read ul { margin: 0; padding-left: 18px; color: var(--text); }
    .pf-modal-local-read li { margin: 5px 0; }
    .pf-modal-ai-block { border-top: 1px solid var(--line); padding-top: 12px; }
    .pf-modal-demo-note { border: 1px solid rgba(255,215,0,.22); border-radius: 10px; background: rgba(255,215,0,.07); padding: 12px 13px; margin-bottom: 12px; }
    .pf-modal-demo-note b { display: block; color: var(--text); font-size: 13px; line-height: 1.25; }
    .pf-modal-demo-note span { display: block; color: var(--muted); font-size: 12px; line-height: 1.4; margin-top: 3px; }
    .pf-benchmark-panel, .pf-dca-panel { display: grid; grid-template-columns: 120px repeat(4, minmax(0, 1fr)); align-items: center; gap: 10px; }
    .pf-benchmark-row, .pf-dca-row { min-width: 0; border-left: 1px solid var(--line); padding-left: 10px; display: grid; gap: 3px; }
    .pf-benchmark-row span, .pf-dca-row span { color: var(--muted); font-size: 10px; font-weight: 800; letter-spacing: .05em; text-transform: uppercase; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    .pf-benchmark-row strong, .pf-dca-row strong { color: var(--text); font-size: 14px; font-weight: 850; font-variant-numeric: tabular-nums; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .pf-benchmark-row strong.up, .pf-dca-row em.up { color: #00bb7f; }
    .pf-benchmark-row strong.down, .pf-dca-row em.down { color: #ef5350; }
    .pf-dca-row em { color: var(--muted); font-style: normal; font-size: 11px; font-weight: 800; }
    .pf-panel-loading, .pf-panel-note { color: var(--muted); font-size: 12px; line-height: 1.45; grid-column: span 4; }

    @media (max-width: 600px) {
      .pf-hero { padding: 18px 16px 14px; }
      .pf-hero-top { gap: 12px; }
      .pf-hero-actions { display: grid; grid-template-columns: minmax(130px, 1fr) 36px; gap: 6px; justify-content: end; max-width: 210px; }
      .pf-hero-add-btn { grid-column: 1; justify-content: center; min-height: 34px; padding: 7px 10px; }
      .pf-more-btn { display: inline-flex; grid-column: 2; grid-row: 1; width: 36px; height: 34px; padding: 0; }
      #pfInsightBtn { display: none !important; grid-column: 1 / -1; justify-content: center; min-height: 34px; padding: 7px 10px !important; }
      .pf-share-btn, .pf-stealth-btn { display: none; width: 36px; height: 34px; padding: 0; justify-content: center; }
      .pf-actions-open #pfInsightBtn { display: inline-flex !important; }
      .pf-actions-open .pf-share-btn,
      .pf-actions-open .pf-stealth-btn { display: flex; }
      .pf-actions-open .pf-share-btn { grid-column: 1; }
      .pf-actions-open .pf-stealth-btn { grid-column: 2; }
      .pf-back-btn { display: none !important; }
      .pf-hero-value { font-size: 32px; }
      .pf-hero-pnl { font-size: 13px; }
      .pf-hero-pnl-pill { font-size: 12px; padding: 3px 10px; }
      .pf-page-inner { padding: 0 12px 132px; gap: 16px; }
      .pf-asset-name { font-size: 16px; }
      .pf-asset-price { font-size: 14px; }
      .pf-charts-row { flex-direction: column; padding: 12px; max-height: none; min-height: 0; overflow: visible; }
      .pf-area-chart { flex: none; width: 100%; height: 120px; max-height: 120px; padding: 4px 4px 16px 28px; }
      .pf-chart-y-label { font-size: 7px; }
      .pf-chart-x-label { font-size: 7px; }
      .pf-donut { display: none; }
      .pf-donut-center { display: none; }
      .pf-page-tabs { padding: 0 12px; overflow-x: auto; scrollbar-width: none; }
      .pf-page-tabs::-webkit-scrollbar { display: none; }
      .pf-empty-preview { grid-template-columns: 1fr; }
      .pf-tab-content { padding: 0; }
      .pf-add-bar { margin: 0 12px 16px; padding: 12px 14px; }
      .pf-row { padding: 8px 6px; }
      .pf-row-icon { width: 28px; height: 28px; font-size: 10px; }
      .pf-row-info { min-width: 0; }
      .pf-row-name { font-size: 12px; }
      .pf-row-sub { font-size: 10px; }
      .pf-row-mobile-data { display: block; }
      /* On mobile, collapse grid to just asset + menu */
      .pf-grid.pf-row { grid-template-columns: 1fr 28px; }
      .pf-grid.pf-row > div:nth-child(n+2):nth-child(-n+7) { display: none; }
      .pf-row-cell-val { font-size: 11px; }
      .pf-row-alloc { display: none; }
      .pf-holdings-header { display: none; }
      /* Expand area + transaction form on mobile */
      .pf-row-expand { padding: 10px 8px; }
      .pf-txn-row { gap: 6px; flex-wrap: wrap; }
      .pf-txn-form { gap: 6px; }
      .pf-txn-input { width: 70px; font-size: 12px; }
      .pf-row-dropdown { right: -8px; min-width: 140px; }
      .pf-row-dropdown-item { padding: 10px 12px; }
      .pf-add-bar-label { display: none; }
      .pf-page-tabs { gap: 0; }
      .pf-page-tab { padding: 10px 10px; font-size: 11px; }
      .pf-add-tab-btn { padding: 5px 10px; font-size: 11px; }
      .pf-hero-value { font-size: 28px; }
      .pf-period-pills { margin-top: 10px; }
      .pf-period-pill { padding: 5px 10px; font-size: 11px; min-width: 28px; }
      .pf-empty { padding: 34px 12px; }
      .pf-empty-product { display: block; max-width: 100%; text-align: center; }
      .pf-empty-title { font-size: 18px; line-height: 1.2; max-width: 330px; margin-left: auto; margin-right: auto; }
      .pf-empty-text { font-size: 13px; max-width: 320px; }
      .pf-empty-preview { width: 100%; max-width: 100%; margin-top: 18px; }
      .pf-empty-preview-card { width: 100%; box-sizing: border-box; overflow: hidden; padding: 12px 14px; }
      .pf-empty-preview-copy { overflow-wrap: anywhere; }
      .pf-empty-dashboard { display: none; }
      .pf-empty-dash-value { font-size: 28px; }
      .pf-empty-dash-chart { height: 62px; }
      .pf-snapshot-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; }
      .pf-snapshot-card { padding: 10px; }
      .pf-snapshot-value { font-size: 16px; }
      .pf-watchlist-row { flex-wrap: wrap; }
      .pf-watchlist-row .pf-mover-info { flex: 1 1 120px; }
      .pf-watchlist-actions { flex: 1 1 100%; justify-content: flex-end; }
      .pf-benchmark-panel, .pf-dca-panel { padding: 12px; }
      .pf-benchmark-panel, .pf-dca-panel { grid-template-columns: repeat(2, minmax(0, 1fr)); }
      .pf-benchmark-panel .pf-panel-title, .pf-dca-panel .pf-panel-title { grid-column: 1 / -1; margin-bottom: 0; }
      .pf-panel-loading, .pf-panel-note { grid-column: 1 / -1; }
      .pf-benchmark-row, .pf-dca-row { border-left: 0; border-top: 1px solid var(--line); padding: 8px 0 0; }
    }

    /* ── LAYOUT (no grid, flex row) ── */
    .layout { display: contents; }

    /* ── MAIN AREA ── */
    .main {
      flex: 1; min-width: 0; display: flex; flex-direction: column;
      background: var(--bg); overflow: hidden;
      border: none; border-radius: 0; box-shadow: none;
      --home-bg: var(--bg);
      --home-panel: var(--surface-content);
      --home-panel-2: var(--surface-content-2);
      --home-line: var(--line);
      --home-line-2: color-mix(in srgb, var(--line) 76%, rgba(215,226,245,.18));
      --home-text: var(--text);
      --home-dim: var(--muted);
      --home-mute: color-mix(in srgb, var(--muted) 74%, var(--bg));
      --home-soft: rgba(232,87,42,.14);
      --home-green: var(--green);
      --home-red: var(--red);
      font-family: 'Geist', 'Inter', 'Google Sans', 'Helvetica Neue', Arial, sans-serif;
    }
    html[data-theme="light"] .main {
      background: #f4f0ea;
      --home-bg: #f4f0ea;
      --home-panel: #fffaf3;
      --home-panel-2: #fbf6ee;
      --home-line: rgba(60,48,36,.12);
      --home-line-2: rgba(60,48,36,.18);
      --home-text: #211d18;
      --home-dim: #665e54;
      --home-mute: #8d8276;
      --home-soft: rgba(232,87,42,.10);
      --home-green: #2f7a4d;
      --home-red: #b6483f;
    }
    .main-content {
      flex: 1; min-height: 0; display: flex; flex-direction: column;
      overflow-y: auto; -webkit-overflow-scrolling: touch;
    }
    .main .discovery-page, .main .portfolio-page, .main .predictions-page {
      background: var(--home-bg);
      font-family: 'Geist', 'Inter', 'Google Sans', 'Helvetica Neue', Arial, sans-serif;
    }
    .main .disc-header {
      background: var(--home-bg);
    }
    /* Push welcome+composer down from top — use flex-start so overflow scrolls down not up */
    .main-content:not(.has-chat) {
      justify-content: flex-start; align-items: center;
      padding: 84px 28px 68px;
      background: var(--home-bg);
    }
    .main-content.has-chat {
      justify-content: flex-start;
      scrollbar-width: none;
      -ms-overflow-style: none;
    }
    .main-content.has-chat::-webkit-scrollbar { display: none; }

    /* ── WELCOME AREA ── */
    .welcome { text-align: center; max-width: 860px; width: 100%; margin-bottom: 0; }
    .welcome-title { margin: 0 0 14px; font-size: clamp(38px, 4.6vw, 58px); font-weight: 500; letter-spacing: -.025em; color: var(--home-text); line-height: 1.05; font-family: inherit; transition: opacity .28s ease, transform .28s ease; }
    .welcome-title.title-swapping { opacity: 0; transform: translateY(5px); }
    .welcome-title em { font-family: 'Instrument Serif', Georgia, 'Times New Roman', serif; font-style: italic; font-weight: 400; color: var(--accent); }
    .welcome-subtitle { color: var(--home-dim); font-size: 16px; line-height: 1.5; max-width: 540px; margin: 0 auto 0; }
    .home-today-strip { display: none; }
    .feature-row {
      display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; text-align: left;
      max-width: 680px; width: 100%; margin: 0 auto;
    }
    .feature-card {
      background: var(--panel); border: 1px solid var(--line); border-radius: 14px;
      padding: 16px; transition: border-color .15s; cursor: pointer;
    }
    .feature-card:hover { border-color: rgba(255,255,255,.15); }
    .feature-card.glow { border-color: var(--accent); box-shadow: 0 0 20px rgba(232,87,42,.2); transition: all .3s; }
    .feature-card.glow .feature-name { color: var(--accent); }
    .feature-card.dimmed { opacity: 0.3; transition: opacity .3s; }
    .feature-name { margin: 0 0 6px; font-size: 15px; font-weight: 600; color: var(--text); }
    .feature-desc { margin: 0; font-size: 13px; color: var(--muted); line-height: 1.5; }
    #welcomeGuest { display: none !important; }
    .discovery-preview { display: none !important; }
    .disc-preview-pane { max-width: 1040px; width: 100%; margin: 30px auto 0; padding-bottom: 18px; }
    .main-content:not(.has-chat) #discPreviewPane { display: block !important; }
    .main-content.has-chat #discPreviewPane { display: none !important; }
    .home-v3 { display: grid; gap: 12px; text-align: left; }
    .home-v3-section { display: grid; gap: 12px; }
    .home-v3-head { display: flex; align-items: center; justify-content: space-between; gap: 14px; }
    .home-v3-title { color: var(--home-text); font-size: 18px; font-weight: 500; letter-spacing: -.01em; }
    .home-v3-meta { color: var(--home-mute); font-size: 11px; font-weight: 500; font-family: ui-monospace, SFMono-Regular, Menlo, monospace; letter-spacing: .04em; text-transform: uppercase; }
    .home-v3-link { color: var(--accent); font-family: 'Geist', 'Inter', 'Google Sans', 'Helvetica Neue', Arial, sans-serif; font-size: 12px; font-weight: 500; text-decoration: none; white-space: nowrap; display: inline-flex; align-items: center; gap: 4px; }
    .home-v3-link:hover { text-decoration: underline; }
    .home-v3-twin { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; }
    .home-briefing, .home-for-you-card, .home-intel-card, .home-watchlist, .home-agent-card, .home-trend-card, .home-module-card {
      background: var(--home-panel-2); border: 1px solid var(--home-line); border-radius: 16px;
      box-shadow: none;
    }
    .home-briefing, .home-for-you-card, .home-intel-card, .home-watchlist, .home-module-card { position: relative; overflow: hidden; transition: border-color .15s, background .15s; }
    .home-briefing:hover, .home-for-you-card:hover, .home-intel-card:hover, .home-watchlist:hover, .home-module-card:hover { border-color: var(--home-line-2); background: var(--home-panel); }
    .home-briefing::before, .home-for-you-card::before, .home-intel-card::before, .home-watchlist::before, .home-module-card::before {
      content: ''; position: absolute; inset: 0;
      background: radial-gradient(900px 180px at 0% 0%, var(--home-soft), transparent 60%);
      pointer-events: none;
    }
    .home-briefing > *, .home-for-you-card > *, .home-intel-card > *, .home-watchlist > *, .home-module-card > * { position: relative; z-index: 1; }
    .home-briefing { padding: 14px; min-height: 176px; cursor: pointer; display: flex; flex-direction: column; }
    .home-kicker { display: none; }
    .home-briefing-title { color: var(--home-text); font-family: inherit; font-size: 16px; font-weight: 650; line-height: 1.15; letter-spacing: 0; max-width: 720px; }
    .home-briefing-copy { color: var(--home-dim); font-size: 12px; line-height: 1.35; max-width: 720px; margin-top: 7px; }
    .home-marketcap-preview {
      margin-top: 10px;
      border: 1px solid var(--home-line);
      border-radius: 11px;
      background: #0b0b0b;
      overflow: hidden;
    }
    .home-marketcap-preview-top {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 5px;
      padding: 7px;
      border-bottom: 1px solid var(--home-line);
    }
    .home-marketcap-stat {
      min-width: 0;
      border: 1px solid rgba(255,255,255,.08);
      border-radius: 7px;
      background: rgba(255,255,255,.035);
      padding: 5px 6px;
    }
    .home-marketcap-stat span {
      display: block;
      color: var(--home-mute);
      font-size: 7.5px;
      font-weight: 800;
      letter-spacing: .06em;
      text-transform: uppercase;
      white-space: nowrap;
    }
    .home-marketcap-stat b {
      display: block;
      margin-top: 3px;
      color: var(--home-text);
      font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
      font-size: 10px;
      font-weight: 700;
      white-space: nowrap;
    }
    .home-marketcap-table {
      display: grid;
      gap: 0;
      padding: 2px 7px 7px;
    }
    .home-marketcap-row {
      display: grid;
      grid-template-columns: 22px minmax(0, 1fr) 58px 48px 58px;
      align-items: center;
      gap: 7px;
      min-height: 22px;
      border-bottom: 1px solid rgba(255,255,255,.055);
      color: var(--home-text);
      font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
      font-size: 9px;
    }
    .home-marketcap-row:last-child {
      border-bottom: 0;
    }
    .home-marketcap-coin {
      display: flex;
      align-items: center;
      gap: 6px;
      min-width: 0;
      font-family: 'Geist', 'Inter', sans-serif;
      font-size: 10px;
      font-weight: 650;
    }
    .home-marketcap-logo {
      display: inline-flex;
      width: 15px;
      height: 15px;
      flex: 0 0 15px;
      align-items: center;
      justify-content: center;
      border-radius: 50%;
      color: #111;
      background: #f7931a;
      font-size: 8px;
      font-weight: 900;
    }
    .home-marketcap-logo.eth { background: #627eea; color: #fff; }
    .home-marketcap-logo.sol { background: linear-gradient(135deg, #00ffa3, #9945ff); color: #fff; }
    .home-marketcap-spark {
      height: 14px;
      border-radius: 5px;
      background:
        linear-gradient(135deg, transparent 0 18%, #00bb7f 19% 22%, transparent 23% 39%, #00bb7f 40% 43%, transparent 44% 61%, #00bb7f 62% 66%, transparent 67%),
        linear-gradient(90deg, transparent, rgba(0,187,127,.42), transparent);
    }
    .home-marketcap-dim { color: var(--home-mute); }
    .home-marketcap-green { color: var(--home-green); }
    .home-marketcap-red { color: var(--home-red); }
    .home-for-you-card {
      min-height: 176px;
      padding: 14px;
      display: flex;
      flex-direction: column;
      gap: 8px;
      cursor: pointer;
    }
    .home-for-you-card::before {
      background: radial-gradient(900px 180px at 0% 0%, var(--home-soft), transparent 60%);
    }
    .home-for-you-kicker {
      color: var(--accent);
      font-size: 10.5px;
      font-weight: 950;
      letter-spacing: .08em;
      text-transform: uppercase;
    }
    .home-for-you-title { color: var(--home-text); font-size: 17px; font-weight: 700; line-height: 1.08; letter-spacing: 0; }
    .home-for-you-copy { color: var(--home-dim); font-size: 12px; line-height: 1.35; }
    .home-for-you-list { display: grid; gap: 5px; margin-top: 0; }
    .home-for-you-item {
      border: 1px solid var(--home-line); background: rgba(255,255,255,.02);
      border-radius: 7px; padding: 6px 8px; color: var(--home-text);
      font-size: 11px; font-weight: 550; line-height: 1.25;
    }
    .home-briefing-foot { display: flex; align-items: center; justify-content: space-between; gap: 14px; margin-top: auto; padding-top: 9px; color: var(--home-mute); font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 11px; }
    .home-for-you-foot { margin-top: auto; border-top: 1px solid var(--home-line); padding-top: 8px; display: flex; justify-content: space-between; gap: 12px; align-items: center; color: var(--home-dim); font-size: 12px; }
    .home-intel-card {
      padding: 14px;
      min-height: 176px;
      cursor: pointer;
      display: flex;
      flex-direction: column;
      gap: 8px;
      border-color: color-mix(in srgb, var(--accent) 44%, var(--home-line));
      background:
        radial-gradient(circle at 18% 0%, rgba(232,87,42,.22), transparent 42%),
        linear-gradient(180deg, color-mix(in srgb, var(--home-panel-2) 86%, var(--accent) 8%), var(--home-panel-2));
      box-shadow: 0 0 0 1px rgba(232,87,42,.08), 0 12px 34px rgba(232,87,42,.06);
    }
    .home-intel-card::before {
      background:
        radial-gradient(circle at 18% 0%, rgba(255,177,90,.22), transparent 42%),
        radial-gradient(circle at 86% 12%, rgba(232,87,42,.16), transparent 34%);
    }
    .home-intel-title { color: var(--home-text); font-size: 16px; font-weight: 650; line-height: 1.15; letter-spacing: 0; }
    .home-intel-copy { color: var(--home-dim); font-size: 12px; line-height: 1.35; }
    .home-intel-visual {
      position: relative; height: 44px; margin: 0;
      border: 1px solid var(--home-line); border-radius: 10px;
      background:
        linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.015)),
        radial-gradient(circle at 22% 38%, rgba(43,181,138,.20), transparent 26%),
        radial-gradient(circle at 72% 56%, rgba(232,87,42,.18), transparent 30%);
      overflow: hidden;
    }
    .home-intel-bubble {
      position: absolute; display: flex; align-items: center; justify-content: center;
      border-radius: 50%; color: #fff; font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
      font-size: 10px; font-weight: 850; letter-spacing: -.04em;
      box-shadow: inset 0 1px 0 rgba(255,255,255,.28), 0 8px 18px rgba(0,0,0,.20);
    }
    .home-intel-bubble.btc { width: 36px; height: 36px; left: 14px; top: 4px; background: linear-gradient(145deg, #f7931a, #bb5d10); font-size: 10px; }
    .home-intel-bubble.eth { width: 28px; height: 28px; left: 54px; top: 8px; background: linear-gradient(145deg, #627eea, #3851a8); font-size: 8px; }
    .home-intel-bubble.sol { width: 25px; height: 25px; right: 42px; top: 6px; background: linear-gradient(145deg, #2bb58a, #7d4cff); font-size: 8px; }
    .home-intel-bubble.xrp { width: 22px; height: 22px; right: 16px; bottom: 6px; background: linear-gradient(145deg, #67717f, #2f3742); font-size: 7px; }
    .home-intel-bubble.doge { width: 22px; height: 22px; left: 92px; bottom: 5px; background: linear-gradient(145deg, #d4a843, #8b6b21); font-size: 7px; }
    .home-intel-tools { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 5px; margin-top: 0; }
    .home-intel-tools button {
      appearance: none; border: 1px solid var(--home-line); border-radius: 8px;
      background: rgba(255,255,255,.025); color: var(--home-text); padding: 6px 5px;
      font: inherit; font-size: 10px; font-weight: 650; cursor: pointer; text-align: center;
      transition: border-color .15s, background .15s, color .15s;
    }
    .home-intel-tools button:hover { border-color: rgba(232,87,42,.38); background: rgba(232,87,42,.10); color: var(--accent); }
    .home-intel-foot { margin-top: auto; border-top: 1px solid var(--home-line); padding-top: 8px; display: flex; justify-content: space-between; gap: 12px; align-items: center; color: var(--home-dim); font-size: 12px; }
    .home-watchlist { padding: 20px; display: grid; gap: 12px; }
    .home-watchlist-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; }
    .home-watchlist-title { color: var(--home-text); font-size: 20px; font-weight: 600; line-height: 1.15; letter-spacing: -.01em; display: flex; align-items: center; gap: 8px; }
    .home-watchlist-title::before { display: none; }
    .home-watchlist-copy { color: var(--home-dim); font-size: 12.5px; line-height: 1.48; margin-top: 5px; }
    .home-watchlist-pill { color: var(--home-green); background: transparent; border: 0; border-radius: 0; padding: 0; font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 12px; font-weight: 500; white-space: nowrap; }
    .home-watchlist-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 9px; }
    .home-watch-item { background: rgba(255,255,255,.02); border: 1px solid var(--home-line); border-radius: 8px; padding: 12px; min-height: 92px; }
    .home-watch-sym { color: var(--home-text); font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 14px; font-weight: 700; }
    .home-watch-read { color: var(--home-mute); font-size: 12.5px; line-height: 1.25; margin-top: 6px; }
    .home-watch-val { color: var(--home-green); font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 14px; font-weight: 700; margin-top: 12px; }
    .home-watch-val.down { color: var(--home-red); }
    .home-watchlist-foot { margin-top: auto; border-top: 1px solid var(--home-line); padding-top: 12px; display: flex; justify-content: space-between; gap: 12px; align-items: center; color: var(--home-dim); font-size: 12px; }
    .home-agents-grid, .home-trends-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
    .home-agent-card, .home-trend-card { padding: 16px; min-height: 130px; display: flex; flex-direction: column; gap: 10px; border-radius: 12px; }
    .home-agent-card { border-style: dashed; background: transparent; }
    .home-agent-top, .home-trend-top { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
    .home-agent-name, .home-trend-title { color: var(--home-text); font-size: 14px; font-weight: 500; line-height: 1.35; }
    .home-coming-soon { color: var(--accent); background: var(--home-soft); border: 1px solid rgba(232,87,42,.24); border-radius: 999px; padding: 4px 7px; font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: .04em; white-space: nowrap; }
    .home-agent-copy, .home-trend-meta { color: var(--home-dim); font-size: 12px; line-height: 1.45; }
    .home-agent-schedule { margin-top: auto; color: var(--home-mute); font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 10.5px; font-weight: 500; letter-spacing: .04em; text-transform: uppercase; }
    .home-trend-card { cursor: pointer; text-decoration: none; color: inherit; }
    .home-trend-card:hover { border-color: var(--home-line-2); background: var(--home-panel); }
    .home-trend-delta { color: var(--home-green); background: rgba(107,163,104,.10); border-radius: 6px; padding: 4px 8px; font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 11px; font-weight: 600; }
    .home-trend-delta.down { color: var(--home-red); background: rgba(201,88,80,.10); }
    .home-module-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; }
    .home-module-card { min-height: 176px; padding: 14px; display: flex; flex-direction: column; gap: 8px; color: inherit; text-decoration: none; }
    .home-module-title { color: var(--home-text); font-size: 16px; font-weight: 650; line-height: 1.15; letter-spacing: 0; }
    .home-module-copy { color: var(--home-dim); font-size: 12px; line-height: 1.35; }
    .home-module-visual {
      position: relative; min-height: 74px; margin-top: 0; border: 1px solid var(--home-line);
      border-radius: 11px; background: #0b0b0b; overflow: hidden;
    }
    .home-module-visual.chart {
      background:
        linear-gradient(90deg, rgba(255,255,255,.045) 1px, transparent 1px) 0 0 / 34px 100%,
        linear-gradient(0deg, rgba(255,255,255,.045) 1px, transparent 1px) 0 0 / 100% 28px,
        #0b0b0b;
    }
    .home-module-visual.chart span {
      position: absolute; left: 11px; right: 11px; top: 34px; height: 28px;
      background: linear-gradient(135deg, transparent 0 10%, #00bb7f 11% 13%, transparent 14% 28%, #00bb7f 29% 31%, transparent 32% 44%, #00bb7f 45% 48%, transparent 49% 64%, #00bb7f 65% 68%, transparent 69%);
      filter: drop-shadow(0 0 10px rgba(0,187,127,.24));
    }
    .home-module-visual.chart i, .home-module-visual.chart b {
      position: absolute; left: 16px; right: 16px; height: 1px; background: rgba(232,87,42,.75);
    }
    .home-module-visual.chart i { bottom: 20px; }
    .home-module-visual.chart b { top: 20px; background: rgba(74,163,255,.55); }
    .home-module-visual.sports,
    .home-module-visual.portfolio { display: grid; align-content: center; gap: 5px; padding: 7px; background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01)), #0b0b0b; }
    .home-module-visual.sports span,
    .home-module-visual.portfolio span {
      display: flex; align-items: center; justify-content: space-between; border: 1px solid rgba(255,255,255,.075);
      border-radius: 7px; padding: 5px 7px; color: var(--home-text); font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 10px; font-weight: 750;
    }
    .home-module-visual.portfolio b { color: var(--home-green); font-weight: 850; }
    .home-module-visual.portfolio span:last-child b { color: var(--home-red); }
    .home-module-visual.sports i { color: var(--home-green); font-style: normal; font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 11px; font-weight: 700; }
    .home-module-visual.discovery { display: grid; grid-template-columns: 1.2fr .8fr; gap: 6px; padding: 7px; background: #0b0b0b; }
    .home-module-visual.discovery span { border: 1px solid rgba(255,255,255,.075); border-radius: 9px; background: rgba(255,255,255,.035); }
    .home-module-visual.discovery span:first-child {
      grid-row: span 2;
      background:
        linear-gradient(180deg, rgba(232,87,42,.28), transparent 54%),
        linear-gradient(90deg, rgba(255,255,255,.18), rgba(255,255,255,.03));
    }
    .home-module-visual.discovery span:nth-child(2) { background: linear-gradient(135deg, rgba(74,163,255,.22), rgba(255,255,255,.025)); }
    .home-module-visual.discovery span:nth-child(3) { background: linear-gradient(135deg, rgba(0,187,127,.18), rgba(255,255,255,.025)); }
    .home-module-foot {
      margin-top: auto; border-top: 1px solid var(--home-line); padding-top: 8px;
      display: flex; justify-content: space-between; gap: 12px; align-items: center;
      color: var(--home-dim); font-size: 12px;
    }
    html[data-theme="light"] .home-marketcap-preview {
      background: linear-gradient(180deg, #fffdf9, #f5efe7);
      border-color: rgba(49,39,31,.14);
      box-shadow: 0 14px 34px rgba(62,45,30,.08);
    }
    html[data-theme="light"] .home-marketcap-preview-top {
      border-bottom-color: rgba(49,39,31,.11);
    }
    html[data-theme="light"] .home-marketcap-stat {
      background: rgba(255,255,255,.92);
      border-color: rgba(49,39,31,.12);
    }
    html[data-theme="light"] .home-marketcap-stat span,
    html[data-theme="light"] .home-marketcap-row,
    html[data-theme="light"] .home-marketcap-dim {
      color: rgba(49,39,31,.68);
    }
    html[data-theme="light"] .home-marketcap-stat b,
    html[data-theme="light"] .home-marketcap-row,
    html[data-theme="light"] .home-marketcap-coin {
      color: var(--text);
    }
    html[data-theme="light"] .home-marketcap-row {
      border-bottom-color: rgba(49,39,31,.10);
    }
    html[data-theme="light"] .home-marketcap-logo {
      box-shadow: inset 0 1px 0 rgba(255,255,255,.38), 0 4px 10px rgba(232,87,42,.14);
    }
    html[data-theme="light"] .home-marketcap-spark {
      background:
        linear-gradient(135deg, transparent 0 18%, #1aa56f 19% 22%, transparent 23% 39%, #1aa56f 40% 43%, transparent 44% 61%, #1aa56f 62% 66%, transparent 67%),
        linear-gradient(90deg, transparent, rgba(26,165,111,.28), transparent);
      opacity: .95;
    }
    html[data-theme="light"] .home-module-visual.chart {
      background:
        linear-gradient(90deg, rgba(49,39,31,.07) 1px, transparent 1px) 0 0 / 34px 100%,
        linear-gradient(0deg, rgba(49,39,31,.07) 1px, transparent 1px) 0 0 / 100% 28px,
        linear-gradient(180deg, #fffdf9, #f4efe7);
      border-color: rgba(49,39,31,.14);
      box-shadow: inset 0 0 0 1px rgba(255,255,255,.4);
    }
    html[data-theme="light"] .home-module-visual.chart span {
      background:
        linear-gradient(135deg, transparent 0 10%, #1aa56f 11% 13%, transparent 14% 28%, #1aa56f 29% 31%, transparent 32% 44%, #1aa56f 45% 48%, transparent 49% 64%, #1aa56f 65% 68%, transparent 69%);
      filter: drop-shadow(0 0 8px rgba(26,165,111,.18));
    }
    html[data-theme="light"] .home-module-visual.chart i,
    html[data-theme="light"] .home-module-visual.chart b {
      background: rgba(232,87,42,.55);
    }
    html[data-theme="light"] .home-module-visual.chart b {
      background: rgba(74,163,255,.48);
    }
    html[data-theme="light"] .home-module-visual.portfolio {
      background: linear-gradient(180deg, #fffdf9, #f5efe7);
      border-color: rgba(49,39,31,.14);
    }
    html[data-theme="light"] .home-module-visual.portfolio span {
      border-color: rgba(49,39,31,.12);
      background: rgba(255,255,255,.9);
      color: var(--text);
    }
    html[data-theme="light"] .home-module-visual.portfolio b {
      color: #1aa56f;
    }
    html[data-theme="light"] .home-module-visual.portfolio span:last-child b {
      color: #d14f4f;
    }
    html[data-theme="light"] .home-module-visual.discovery {
      background: linear-gradient(180deg, #fffdf9, #f4efe7);
      border-color: rgba(49,39,31,.14);
    }
    html[data-theme="light"] .home-module-visual.discovery span {
      border-color: rgba(49,39,31,.12);
      background: rgba(255,255,255,.9);
    }
    html[data-theme="light"] .home-module-visual.discovery span:first-child {
      background:
        linear-gradient(180deg, rgba(232,87,42,.20), transparent 54%),
        linear-gradient(90deg, rgba(49,39,31,.08), rgba(49,39,31,.02));
    }
    html[data-theme="light"] .home-module-visual.discovery span:nth-child(2) {
      background: linear-gradient(135deg, rgba(74,163,255,.17), rgba(255,255,255,.85));
    }
    html[data-theme="light"] .home-module-visual.discovery span:nth-child(3) {
      background: linear-gradient(135deg, rgba(0,187,127,.14), rgba(255,255,255,.85));
    }
    .home-module-foot span { color: var(--home-mute); font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 11px; }
    .home-module-foot em { color: var(--accent); font-style: normal; font-size: 12px; font-weight: 500; white-space: nowrap; }
    @media (max-width: 768px) {
      .home-v3-twin .home-for-you-card { order: -3; }
      .home-v3-twin .home-briefing { order: -2; }
      .home-v3-twin .home-intel-card { order: -1; }
    }
    .query-chip-row { display: none; }
    .query-chip { border: 1px solid var(--line); border-radius: 999px; background: rgba(255,255,255,.04); color: var(--text); padding: 8px 12px; font: inherit; font-size: 12px; font-weight: 750; cursor: pointer; transition: background .15s, border-color .15s, transform .15s; }
    .query-chip:hover { border-color: rgba(74,163,255,.55); background: rgba(74,163,255,.08); transform: translateY(-1px); }
    .main-content.has-chat .query-chip-row { display: none; }
    .disc-preview-lede { border: 1px solid var(--line); border-radius: 18px; background: linear-gradient(145deg, rgba(255,255,255,.07), rgba(255,255,255,.025)); padding: 18px; box-shadow: 0 12px 32px rgba(0,0,0,.16); cursor: pointer; text-align: left; transition: border-color .15s, transform .15s; }
    .disc-preview-lede:hover { border-color: rgba(232,87,42,.55); transform: translateY(-1px); }
    .disc-preview-lede:focus-visible { outline: 2px solid var(--accent); outline-offset: 3px; }
    .disc-preview-kicker { color: var(--accent); font-size: 10px; font-weight: 850; letter-spacing: .12em; text-transform: uppercase; margin-bottom: 7px; }
    .disc-preview-question { color: var(--text); font-size: 18px; line-height: 1.25; font-weight: 850; letter-spacing: -.02em; }
    .disc-preview-copy { color: var(--muted); font-size: 13px; line-height: 1.55; margin-top: 8px; }
    .disc-preview-cta { color: var(--accent); font-size: 13px; font-weight: 850; margin-top: 12px; }
    .disc-starter-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; margin-top: 12px; }
    .disc-starter { border: 1px solid var(--line); border-radius: 14px; background: rgba(255,255,255,.035); padding: 12px; cursor: pointer; transition: border-color .15s, background .15s; }
    .disc-starter:hover { border-color: rgba(232,87,42,.45); background: rgba(232,87,42,.07); }
    .disc-starter-label { color: var(--accent); font-size: 10px; font-weight: 850; text-transform: uppercase; letter-spacing: .08em; margin-bottom: 5px; }
    .disc-starter-text { color: var(--text); font-size: 13.5px; line-height: 1.35; font-weight: 750; }
    .main-content:not(.has-chat) .composer { max-width: 780px; }
    .main-content:not(.has-chat) .input-container textarea { min-height: 64px; max-height: 160px; padding: 19px 74px 19px 22px; font-size: 16px; border-radius: 30px; }
    .main-content:not(.has-chat) #submit { width: 38px; height: 38px; right: 13px; bottom: 13px; }
    .main-content:not(.has-chat) #submit::before { font-size: 18px; }
    .disc-preview-img { width: 60px; height: 60px; border-radius: 8px; object-fit: cover; flex-shrink: 0; }
    .disc-preview-placeholder { width: 60px; height: 60px; border-radius: 8px; background: rgba(255,255,255,.06); flex-shrink: 0; display: flex; align-items: center; justify-content: center; font-size: 20px; }
    .disc-preview-title, .disc-card-question, .disc-card-excerpt { display: none; }
    @media (max-width: 600px) {
      .disc-preview-pane { margin-top: 14px; }
      .disc-starter-grid { grid-template-columns: 1fr; }
      .home-v3 { gap: 16px; }
      .home-v3-twin, .home-agents-grid, .home-trends-grid, .home-module-grid { grid-template-columns: 1fr; }
      .home-briefing, .home-for-you-card, .home-intel-card { min-height: 0; padding: 16px; }
      .home-for-you-card { order: -2; }
      .home-briefing { order: -1; }
      .home-briefing-foot, .home-for-you-foot, .home-intel-foot, .home-watchlist-foot { align-items: flex-start; flex-direction: column; }
      .home-watchlist-grid { grid-template-columns: 1fr 1fr; }
      .main-content:not(.has-chat) { padding: 34px 16px 92px; }
      .welcome-title { font-size: 36px; }
      .welcome-subtitle { font-size: 14px; }
      .main-content:not(.has-chat) .composer { margin-top: 22px; padding: 12px; border-radius: 16px; }
      .main-content:not(.has-chat) #submit { top: 16px; right: 12px; }
    }
    /* Trending grid for logged-in homepage */
    .trending-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; max-width: 680px; width: 100%; margin: 0 auto; }
    .trending-card { background: var(--panel); border: 1px solid var(--line); border-radius: 12px; padding: 0; cursor: pointer; transition: border-color .15s; overflow: hidden; }
    .trending-card:hover { border-color: rgba(255,255,255,.15); }
    .trending-card-img { width: 100%; height: 90px; object-fit: cover; display: block; }
    .trending-card-body { padding: 10px 12px; }
    .trending-card-badge { font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--accent); margin-bottom: 4px; }
    .trending-card-title { font-size: 13px; font-weight: 600; color: var(--text); line-height: 1.4; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; margin-bottom: 4px; }
    .trending-card-source { font-size: 10px; color: var(--muted); opacity: .6; }
    @media (max-width: 600px) {
      .trending-grid { grid-template-columns: repeat(2, 1fr); gap: 8px; }
      .trending-card-img { height: 70px; }
    }

    /* ── CHAT ── */
    .chat { padding: 16px 24px 8px; display: flex; flex-direction: column; gap: 8px; max-width: 840px; width: 100%; min-width: 0; margin: 0 auto; }
    .main-content.has-chat { min-width: 0; overflow-x: hidden; }
    .main-content.has-chat .chat {
      flex: 1; max-width: min(840px, 100%); overflow-x: hidden;
      scrollbar-width: none; -ms-overflow-style: none;
    }
    .main-content.has-chat .chat::-webkit-scrollbar { display: none; }
    #emptyState { display: none; }

    /* ── COMPOSER ── */
    .composer {
      position: relative;
      padding: 14px 14px 10px; display: grid; gap: 0;
      background: var(--home-panel); flex-shrink: 0;
      max-width: 760px; width: 100%; margin: 28px auto 0;
      border: 1px solid var(--home-line-2); border-radius: 18px;
      box-shadow: 0 22px 54px -30px rgba(232,87,42,.55), 0 1px 0 rgba(255,255,255,.03) inset;
      transition: border-color .2s, box-shadow .2s;
    }
    html[data-theme="light"] .main-content:not(.has-chat) .composer {
      box-shadow: 0 30px 60px -30px rgba(0,0,0,.16), 0 1px 0 rgba(255,255,255,.62) inset;
    }
    .main-content:not(.has-chat) .composer:focus-within {
      border-color: rgba(232,87,42,.55);
      box-shadow: 0 22px 54px -30px rgba(232,87,42,.55), 0 0 0 4px var(--home-soft);
    }
    html[data-theme="light"] .main-content:not(.has-chat) .composer:focus-within {
      box-shadow: 0 30px 60px -30px rgba(0,0,0,.16), 0 0 0 4px var(--home-soft);
    }
    /* Narrower composer on home screen only */
    /* When chatting, pin composer to bottom */
    .main-content.has-chat .composer {
      padding: 14px 14px 10px; background: var(--bg);
      position: sticky; bottom: env(safe-area-inset-bottom, 0px); z-index: 10;
      max-width: min(860px, 100%); min-width: 0; margin: 0 auto; border: 0; border-radius: 0;
      box-shadow: 0 -18px 28px -24px rgba(0,0,0,.72);
    }
    .main-content.has-chat .query-result,
    .main-content.has-chat .bubble,
    .main-content.has-chat .stream-answer,
    .main-content.has-chat .skeleton-bubble {
      max-width: 100%;
      min-width: 0;
      overflow-wrap: anywhere;
    }
    .main-content.has-chat .composer::before {
      content: '';
      position: absolute;
      left: 50%;
      top: -8px;
      width: 100vw;
      height: calc(100% + 12px);
      transform: translateX(-50%);
      background: linear-gradient(to top, var(--bg) 88%, color-mix(in srgb, var(--bg) 68%, transparent));
      z-index: -1;
      pointer-events: none;
    }
    .main-content.has-chat .input-container textarea {
      min-height: 62px;
      padding: 17px 78px 17px 20px;
      border-radius: 26px;
      background: var(--home-panel);
      border-color: var(--home-line-2);
      box-shadow: none;
    }
    .main-content.has-chat .input-container textarea:focus {
      border-color: rgba(232,87,42,.42);
      box-shadow: 0 0 0 3px var(--home-soft);
    }
    .main-content.has-chat #submit {
      width: 42px;
      height: 42px;
      right: 10px;
      bottom: 10px;
      box-shadow: none;
    }
    .main-content.has-chat .mode-row {
      justify-content: flex-start;
      gap: 7px;
      margin-top: 10px;
      padding-left: 4px;
    }
    .main-content.has-chat .mode-btn,
    .main-content.has-chat .tools-dropdown summary {
      padding: 7px 12px;
      font-size: 13px;
      font-weight: 500;
      border-color: var(--home-line);
      background: transparent;
      color: var(--home-dim);
      box-shadow: none;
    }
    .main-content.has-chat .mode-btn:hover,
    .main-content.has-chat .tools-dropdown summary:hover {
      background: var(--home-panel);
      color: var(--home-text);
      border-color: var(--home-line-2);
    }
    .main-content.has-chat .mode-btn.active {
      background: var(--home-soft);
      color: var(--accent);
      border-color: rgba(232,87,42,.28);
      font-weight: 650;
    }
    .main-content.has-chat .mode-toggle { display: none; }
    .main-content.has-chat .mode-select-wrap {
      display: inline-flex;
      align-items: center;
      gap: 7px;
      min-height: 30px;
      padding: 3px 4px 3px 10px;
      border: 1px solid var(--home-line);
      border-radius: 999px;
      background: color-mix(in srgb, var(--home-panel) 78%, transparent);
      color: var(--home-dim);
      font-size: 11px;
      font-weight: 750;
      text-transform: uppercase;
      letter-spacing: .04em;
    }
    .main-content.has-chat .mode-select {
      min-height: 26px;
      padding: 4px 24px 4px 8px;
      border: 0;
      border-radius: 999px;
      background: var(--home-soft);
      color: var(--accent);
      font-size: 12px;
      font-weight: 800;
      text-transform: none;
      letter-spacing: 0;
    }
    .input-wrap { display: flex; gap: 0; align-items: stretch; position: relative; }
    .input-container { flex: 1; position: relative; }
    .input-container textarea {
      width: 100%; min-height: 76px; max-height: 260px; resize: none; overflow-y: auto;
      background: var(--panel); border: 1px solid var(--line); color: var(--text);
      border-radius: 32px; padding: 22px 178px 22px 28px; font-size: 18px; outline: none;
      line-height: 1.45; transition: border-color .15s, box-shadow .15s; font-family: inherit; display: block;
      scrollbar-width: none; -ms-overflow-style: none; box-shadow: 0 10px 34px rgba(0,0,0,.18);
    }
    .main-content:not(.has-chat) .input-container textarea {
      min-height: 56px; max-height: 200px;
      background: transparent; border: 0; border-radius: 0;
      padding: 0 56px 2px 2px; font-size: 16px; line-height: 1.5;
      color: var(--home-text); box-shadow: none;
    }
    .main-content:not(.has-chat) .input-container textarea::placeholder { color: var(--home-mute); }
    .main-content:not(.has-chat) .input-container textarea:focus { box-shadow: none; border-color: transparent; }
    .input-container textarea::-webkit-scrollbar { display: none; }
    .input-container textarea:focus { border-color: rgba(255,255,255,.2); box-shadow: 0 12px 40px rgba(0,0,0,.24); }
    .input-container.drag-over textarea { border-color: rgba(255,255,255,.25); box-shadow: 0 12px 40px rgba(0,0,0,.24); }
    .input-actions { position: absolute; right: 90px; bottom: 24px; display: flex; align-items: center; gap: 4px; }
    #submit { position: absolute; right: 12px; bottom: 12px; display: flex; align-items: center; justify-content: center; width: 52px; height: 52px; padding: 0; border-radius: 999px; background: #9f3512; color: #fff; font-size: 0; font-weight: 700; border: none; cursor: pointer; transition: opacity .15s, transform .1s, box-shadow .15s; flex-shrink: 0; box-shadow: 0 8px 22px rgba(232,87,42,.24); }
    html[data-theme="light"] #submit { background: #87300f; color: #ffffff; }
    #submit::before { content: '➜'; font-size: 24px; line-height: 1; transform: translateX(1px); }
    #submit[disabled]::before { content: '•••'; font-size: 18px; letter-spacing: 1px; transform: none; animation: pulse 1.2s ease-in-out infinite; }
    #submit:hover { opacity: .92; box-shadow: 0 10px 28px rgba(232,87,42,.32); }
    #submit:active { transform: scale(.97); }
    .main-content:not(.has-chat) #submit { width: 36px; height: 36px; right: 14px; top: 20px; bottom: auto; background: var(--accent); color: #1a1816; box-shadow: none; }
    .main-content:not(.has-chat) #submit::before { font-size: 18px; }
    .main-content.has-chat #submit {
      top: 50%;
      bottom: auto;
      transform: translateY(-50%);
    }
    .main-content.has-chat #submit:active { transform: translateY(-50%) scale(.97); }
    .attach-btn-inline { cursor: pointer; font-size: 18px; opacity: 0.5; transition: opacity 0.2s; padding: 4px; }
    .attach-btn-inline:hover { opacity: 1; }
    .attach-btn-inline.has-file { opacity: 1; }
    .attach-btn-inline.has-file #file-label { color: var(--accent); }
    /* File preview strip */
    .file-preview-strip { display: flex; flex-wrap: wrap; gap: 5px; padding: 0 2px 6px; }
    .file-preview-strip:empty { display: none; }
    .fp-chip { display: inline-flex; align-items: center; gap: 4px; background: rgba(232,87,42,.12); border: 1px solid rgba(232,87,42,.35); border-radius: 20px; padding: 2px 7px 2px 5px; font-size: 11px; font-weight: 600; color: var(--accent); max-width: 160px; height: 22px; }
    .fp-chip-icon { font-size: 12px; flex-shrink: 0; line-height: 1; }
    .fp-chip-name { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 90px; font-size: 10px; font-weight: 500; color: var(--text); opacity: .85; }
    .fp-chip-remove { background: none; border: none; cursor: pointer; color: var(--muted); font-size: 11px; line-height: 1; padding: 0; margin-left: 1px; flex-shrink: 0; transition: color .15s; opacity: .7; }
    .fp-chip-remove:hover { color: var(--danger); opacity: 1; }
    textarea { width: 100%; min-height: 50px; max-height: 240px; resize: none; overflow-y: auto; background: var(--panel-2); border: 1px solid var(--line); color: var(--text); border-radius: 16px; padding: 14px 16px; font-size: 15px; outline: none; line-height: 1.5; font-family: inherit; scrollbar-width: none; -ms-overflow-style: none; }
    textarea::-webkit-scrollbar { display: none; }
    textarea:focus { border-color: rgba(255,255,255,.2); box-shadow: 0 1px 8px rgba(0,0,0,.12); }
    .btn { border: 0; border-radius: 14px; padding: 0 20px; font-weight: 700; font-size: 15px; cursor: pointer; transition: opacity .15s, transform .1s; flex-shrink: 0; height: 56px; align-self: flex-end; }
    .btn:active { transform: scale(.97); }
    .btn-primary { background: var(--accent); color: white; min-width: 72px; border-radius: 16px; }
    .btn-primary:hover { opacity: .88; }
    .helper { display: flex; justify-content: space-between; gap: 16px; color: var(--muted); font-size: 13px; }
    .mode-row { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; justify-content: center; position: relative; }
    .main-content:not(.has-chat) .mode-row {
      justify-content: flex-start;
      gap: 6px;
      padding-top: 8px;
      border-top: 1px solid var(--home-line);
      margin-top: 8px;
    }
    .mode-label { display: none; }
    .mode-select-wrap { display: none; }
    .mode-toggle { display: flex; gap: 8px; flex-wrap: wrap; }
    .main-content:not(.has-chat) .mode-toggle { gap: 4px; }
    .mode-btn {
      border: 1px solid var(--line); background: rgba(255,255,255,.035); color: #d7d7d7; border-radius: 999px;
      min-height: 44px; box-sizing: border-box; display: inline-flex; align-items: center; justify-content: center;
      padding: 11px 20px; font-size: 15px; font-weight: 700; line-height: 1; cursor: pointer;
      transition: background .12s, color .12s, box-shadow .2s, border-color .12s; font-family: inherit;
    }
    .main-content:not(.has-chat) .mode-btn {
      border: 1px solid transparent;
      background: transparent;
      color: var(--home-dim);
      border-radius: 8px;
      min-height: 31px;
      padding: 6px 10px;
      font-size: 12.5px;
      font-weight: 500;
      box-shadow: none;
    }
    .main-content:not(.has-chat) .mode-btn:hover { background: rgba(255,255,255,.04); color: var(--home-text); border-color: transparent; }
    html[data-theme="light"] .mode-btn { color: #424242; }
    .mode-btn:hover { background: var(--hover); color: var(--text); border-color: rgba(255,255,255,.16); }
    .mode-btn.active {
      background: rgba(255,255,255,.13); color: #ffffff; font-weight: 800;
      box-shadow: 0 8px 22px rgba(0,0,0,.14); border-color: rgba(255,255,255,.18);
    }
    .main-content:not(.has-chat) .mode-btn.active {
      background: var(--home-soft);
      color: var(--accent);
      border-color: rgba(232,87,42,.25);
      box-shadow: none;
      font-weight: 650;
    }
    html[data-theme="light"] .mode-btn.active { color: #111111; }
    .mode-btn-icon { font-size: 15px; margin-right: 4px; filter: grayscale(1) opacity(.45); transition: filter .15s; }
    .mode-btn:hover .mode-btn-icon { filter: grayscale(.3) opacity(.7); }
    .mode-btn.active .mode-btn-icon { filter: grayscale(0) opacity(1); }
    .mode-description { color: var(--muted); font-size: 12px; line-height: 1.45; margin-top: 4px; min-height: 0; text-align: center; }
    .mode-description:not([hidden]) { display: block; }
    .mode-drawer-toggle { display: none; }
    .sports-toggle-wrap { display: none; }
    .mode-select { background: var(--panel-2); border: 1px solid var(--line); border-radius: 10px; color: var(--text); font-size: 13px; font-weight: 500; padding: 7px 12px; cursor: pointer; font-family: inherit; appearance: auto; }
    .mode-select:focus { outline: none; border-color: rgba(255,255,255,.2); }
    @media (min-width: 769px) {
      .main-content.has-chat .composer {
        padding: 14px 14px 10px;
        bottom: 18px;
        background: linear-gradient(180deg, #252a33, #20242c);
        max-width: 780px;
        margin: 0 auto;
        border: 1px solid #3d4655;
        border-radius: 18px;
        box-shadow:
          0 20px 48px -18px rgba(232,87,42,.34),
          0 18px 42px -24px rgba(0,0,0,.78),
          0 0 0 1px rgba(255,255,255,.045) inset,
          0 1px 0 rgba(255,255,255,.06) inset;
      }
      .main-content.has-chat .composer::before {
        display: none;
      }
      html[data-theme="light"] .main-content.has-chat .composer {
        background: var(--home-panel);
        border-color: rgba(60,48,36,.20);
        box-shadow:
          0 30px 60px -28px rgba(0,0,0,.20),
          0 1px 0 rgba(255,255,255,.72) inset;
      }
      .main-content.has-chat .composer:focus-within {
        border-color: rgba(232,87,42,.60);
        box-shadow:
          0 22px 58px -16px rgba(232,87,42,.46),
          0 18px 42px -24px rgba(0,0,0,.78),
          0 0 0 4px rgba(232,87,42,.13),
          0 0 0 1px rgba(255,255,255,.05) inset,
          0 1px 0 rgba(255,255,255,.07) inset;
      }
      html[data-theme="light"] .main-content.has-chat .composer:focus-within {
        box-shadow:
          0 30px 60px -28px rgba(0,0,0,.20),
          0 0 0 4px var(--home-soft),
          0 1px 0 rgba(255,255,255,.72) inset;
      }
      .main-content.has-chat .input-container textarea {
        min-height: 56px;
        max-height: 200px;
        padding: 0 56px 2px 2px;
        border: 0;
        border-radius: 0;
        background: transparent;
        color: var(--home-text);
        box-shadow: none;
        font-size: 16px;
        line-height: 1.5;
      }
      .main-content.has-chat .input-container textarea::placeholder {
        color: var(--home-mute);
      }
      .main-content.has-chat .input-container textarea:focus {
        border-color: transparent;
        box-shadow: none;
      }
      .main-content.has-chat #submit {
        width: 36px;
        height: 36px;
        right: 14px;
        top: 20px;
        bottom: auto;
        transform: none;
        background: var(--accent);
        color: #1a1816;
        box-shadow: none;
      }
      .main-content.has-chat #submit:active {
        transform: scale(.97);
      }
      .main-content.has-chat .mode-row {
        justify-content: flex-start;
        gap: 6px;
        padding: 8px 0 0;
        border-top: 1px solid rgba(215,226,245,.14);
        margin-top: 8px;
      }
      .main-content.has-chat .mode-toggle {
        display: flex;
        gap: 4px;
      }
      .main-content.has-chat .mode-select-wrap,
      .main-content.has-chat .mode-drawer-toggle {
        display: none;
      }
      .main-content.has-chat .mode-btn {
        min-height: 31px;
        padding: 6px 10px;
        border: 1px solid transparent;
        border-radius: 8px;
        background: transparent;
        color: var(--home-dim);
        box-shadow: none;
        font-size: 12.5px;
        font-weight: 500;
      }
      .main-content.has-chat .mode-btn:hover {
        background: rgba(255,255,255,.04);
        color: var(--home-text);
        border-color: transparent;
      }
      .main-content.has-chat .mode-btn.active {
        background: var(--home-soft);
        color: var(--accent);
        border-color: rgba(232,87,42,.25);
        box-shadow: none;
        font-weight: 650;
      }
    }
    .tools-dropdown { position: relative; }
    .main-content:not(.has-chat) .tools-dropdown summary {
      border: 1px solid transparent;
      background: transparent;
      color: var(--home-dim);
      border-radius: 8px;
      min-height: 31px;
      padding: 6px 10px;
      font-size: 12.5px;
      font-weight: 500;
    }
    .main-content:not(.has-chat) .tools-dropdown summary:hover { background: rgba(255,255,255,.04); color: var(--home-text); }
    .tools-dropdown summary { list-style: none; display: flex; align-items: center; justify-content: center; min-height: 44px; box-sizing: border-box; gap: 8px; cursor: pointer; padding: 11px 20px; border: 1px solid var(--line); border-radius: 999px; background: rgba(255,255,255,.035); color: #d7d7d7; font-size: 15px; font-weight: 700; line-height: 1; }
    html[data-theme="light"] .tools-dropdown summary { color: #424242; }
    .tools-dropdown summary::-webkit-details-marker { display: none; }
    .tools-dropdown[open] summary, .tools-dropdown summary:hover { background: var(--hover); color: var(--text); border-color: rgba(255,255,255,.16); }
    .tools-popover { position: absolute; left: 50%; bottom: calc(100% + 10px); transform: translateX(-50%); width: min(360px, calc(100vw - 32px)); padding: 10px; border: 1px solid var(--line); border-radius: 22px; background: var(--surface-content); opacity: 1; box-shadow: 0 18px 60px rgba(0,0,0,.45); z-index: 100; }
    html[data-theme="light"] .tools-popover { background: #ffffff; border-color: #dedbd7; }
    .tools-popover::before { content: ''; position: absolute; inset: 0; border-radius: inherit; background: inherit; z-index: -1; }
    .tools-popover::after { content: ''; position: absolute; left: 50%; bottom: -7px; width: 14px; height: 14px; transform: translateX(-50%) rotate(45deg); background: var(--surface-content); border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); }
    html[data-theme="light"] .tools-popover::after { background: #ffffff; border-right-color: #dedbd7; border-bottom-color: #dedbd7; }
    .tools-popover-title { padding: 6px 8px 10px; color: var(--muted); font-size: 12px; line-height: 1.35; }
    .feature-pill {
      display: grid; grid-template-columns: auto 1fr; gap: 3px 10px; cursor: pointer;
      padding: 11px 12px; border: none; border-radius: 16px;
      background: transparent; transition: background .12s, box-shadow .2s;
    }
    .feature-pill:hover { background: var(--hover); }
    .feature-pill:hover .feature-pill-label { color: var(--text); }
    .feature-pill input { display: none; }
    .feature-pill-icon { grid-row: span 2; font-size: 18px; filter: grayscale(1) opacity(.45); transition: filter .15s; align-self: center; }
    .feature-pill:hover .feature-pill-icon { filter: grayscale(.3) opacity(.7); }
    .feature-pill input:checked ~ .feature-pill-icon { filter: grayscale(0) opacity(1); }
    .feature-pill-label { font-size: 15px; font-weight: 700; color: var(--muted); cursor: pointer; white-space: nowrap; transition: color .12s; }
    .feature-pill-desc { font-size: 12px; line-height: 1.35; color: var(--muted); opacity: .82; }
    .feature-pill input:checked ~ .feature-pill-label { color: var(--text); }
    .feature-pill:has(input:checked) {
      background: var(--active);
      box-shadow: 0 0 20px var(--glow);
    }
    .sports-mode-indicator { display: none; margin-top: 6px; padding: 6px 10px; background: rgba(255,69,0,.12); border: 1px solid rgba(255,69,0,.3); border-radius: 8px; font-size: 11px; color: #ffb088; }
    .sports-mode-indicator.visible { display: block; }
    .examples { display: flex; flex-wrap: wrap; gap: 6px; }
    .chip { padding: 6px 9px; border: 1px solid var(--line); background: var(--panel-2); border-radius: 999px; color: var(--text); font-size: 11px; cursor: pointer; transition: border-color .15s; }
    .chip:hover { border-color: var(--accent); }
    .demo-card { transition: opacity 0.3s, max-height 0.3s; overflow: hidden; }
    .demo-card.hidden { opacity: 0; max-height: 0; padding: 0; margin: 0; border: none; }

    /* ── MESSAGES ── */
    .message { display: flex; gap: 0; align-items: flex-start; }
    .message.user-msg .bubble { background: var(--surface-content); border: 1px solid color-mix(in srgb, var(--line) 70%, transparent); border-radius: 18px; padding: 12px 18px; display: inline-block; }
    .message.user-msg { justify-content: flex-start; }
    .message.user-msg .bubble p { color: var(--text); font-weight: 500; }
    .avatar { display: none; }
    .bubble { background: transparent; border: none; border-radius: 0; padding: 12px 0 12px; max-width: min(860px, 100%); flex: 1; }
    .bubble h3 { margin: 0 0 8px; font-size: 15px; letter-spacing: -.02em; }
    .bubble p { margin: 0 0 16px 0; line-height: 1.75; color: var(--text); font-size: 16px; font-family: inherit; }
    .bubble p:last-child { margin-bottom: 0; }
    .bubble small { display: block; margin-top: 6px; color: var(--muted); }
    .stage-grid { display: grid; gap: 10px; }
    .stage { background: var(--surface-content-2); border: 1px solid var(--line); border-radius: 14px; padding: 12px 14px; }
    .stage-head { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; }
    .stage-head strong { display: none; }
    .tag { font-size: 12px; font-weight: 600; letter-spacing: .02em; text-transform: none; padding: 4px 12px; border-radius: 999px; border: none; background: var(--hover); color: var(--muted); font-family: inherit; }
    .stage p { margin: 0; color: var(--text); font-size: 16px; line-height: 1.6; white-space: pre-line; font-family: inherit; font-weight: 400; }
    .stage .collapsed-text { display: block; }
    .stage .full-text { display: none; }
    .stage.expanded .collapsed-text { display: none; }
    .stage.expanded .full-text { display: block; }
    .stream-answer, .stream-answer p, .stream-answer div { font-size: 16px; line-height: 1.75; color: var(--text); font-family: inherit; }
    .stream-answer p { white-space: pre-line; margin: 0 0 18px 0; }
    .stream-answer p:last-child { margin-bottom: 0; }
    .stream-answer ul, .stream-answer ol { margin: 6px 0 12px 0; padding-left: 20px; }
    .stream-answer li { margin-bottom: 2px; line-height: 1.6; }
    .ask-drawer-root {
      position: fixed;
      inset: 0;
      z-index: 1200;
      pointer-events: none;
    }
    .ask-drawer-root.open {
      pointer-events: none;
    }
    .ask-drawer-reopen {
      position: fixed;
      right: 22px;
      bottom: 22px;
      z-index: 1060;
      display: grid;
      gap: 2px;
      min-width: 142px;
      border: 1px solid color-mix(in srgb, var(--accent) 42%, var(--line));
      border-radius: 999px;
      background: color-mix(in srgb, var(--panel) 86%, var(--accent) 10%);
      color: var(--text);
      padding: 10px 16px;
      box-shadow: 0 18px 42px rgba(0,0,0,.22);
      cursor: pointer;
      text-align: left;
    }
    .ask-drawer-reopen[hidden] { display: none; }
    .ask-drawer-reopen span {
      color: var(--accent);
      font-size: 10px;
      font-weight: 950;
      letter-spacing: .08em;
      text-transform: uppercase;
    }
    .ask-drawer-reopen b {
      font-size: 13px;
      font-weight: 850;
      line-height: 1.1;
    }
    .ask-drawer-reopen:hover {
      border-color: var(--accent);
      background: color-mix(in srgb, var(--panel) 78%, var(--accent) 16%);
    }
    .ask-drawer-backdrop {
      position: absolute;
      inset: 0;
      background: rgba(0,0,0,.18);
      opacity: 0;
      pointer-events: none;
      transition: opacity .28s ease;
    }
    .ask-drawer-root.open .ask-drawer-backdrop {
      opacity: 1;
    }
    .ask-drawer {
      position: absolute;
      top: 0;
      right: 0;
      width: min(560px, calc(100vw - 18px));
      height: 100dvh;
      display: grid;
      grid-template-rows: auto minmax(0, 1fr) auto;
      background: var(--bg);
      border-left: 1px solid var(--line);
      box-shadow: -24px 0 70px rgba(0,0,0,.34);
      pointer-events: auto;
      transform: translate3d(104%,0,0);
      transition: transform .36s cubic-bezier(.22,1,.36,1), box-shadow .36s ease;
      will-change: transform;
    }
    .ask-drawer-root.open .ask-drawer {
      transform: translate3d(0,0,0);
    }
    .ask-drawer-head {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 14px;
      padding: 16px 18px;
      border-bottom: 1px solid var(--line);
      background: color-mix(in srgb, var(--panel) 76%, transparent);
    }
    .ask-drawer-head span {
      display: block;
      color: var(--muted);
      font-size: 11px;
      font-weight: 800;
      text-transform: uppercase;
      letter-spacing: .06em;
    }
    .ask-drawer-head strong {
      display: block;
      margin-top: 3px;
      color: var(--text);
      font-size: 16px;
      font-weight: 850;
    }
    .ask-drawer-close {
      width: 34px;
      height: 34px;
      border: 1px solid var(--line);
      border-radius: 8px;
      background: var(--panel-2);
      color: var(--text);
      cursor: pointer;
      font-size: 22px;
      line-height: 1;
    }
    .ask-drawer-messages {
      display: flex;
      flex-direction: column;
      gap: 12px;
      padding: 16px 18px;
      overflow-y: auto;
      min-height: 0;
    }
    .ask-drawer-msg {
      max-width: 100%;
      min-width: 0;
    }
    .ask-drawer-msg.user {
      align-self: flex-end;
      max-width: 88%;
    }
    .ask-drawer-msg.user > div {
      border: 1px solid color-mix(in srgb, var(--accent) 34%, var(--line));
      border-radius: 14px 14px 4px 14px;
      background: color-mix(in srgb, var(--accent) 12%, var(--panel));
      color: var(--text);
      padding: 10px 12px;
      font-size: 14px;
      line-height: 1.45;
    }
    .ask-drawer-msg.assistant {
      align-self: stretch;
    }
    .ask-drawer-answer {
      border: 1px solid var(--line);
      border-radius: 14px;
      background: color-mix(in srgb, var(--panel) 86%, transparent);
      padding: 13px 14px;
    }
    .ask-drawer-answer,
    .ask-drawer-answer p,
    .ask-drawer-answer div {
      font-size: 14px;
      line-height: 1.68;
    }
    .ask-drawer-loading {
      color: var(--muted);
      font-size: 13px;
    }
    .ask-drawer-loading::after {
      content: '';
      display: inline-block;
      width: 1.5em;
      text-align: left;
      animation: ask-drawer-dots 1.15s infinite steps(1, end);
    }
    @keyframes ask-drawer-dots {
      0% { content: ''; }
      25% { content: '.'; }
      50% { content: '..'; }
      75%, 100% { content: '...'; }
    }
    .ask-drawer-trust {
      margin-top: 10px;
    }
    .ask-drawer-followups {
      display: flex;
      flex-direction: column;
      gap: 8px;
      margin-top: 10px;
    }
    .ask-drawer-followups span {
      color: var(--muted);
      font-size: 11px;
      font-weight: 800;
      text-transform: uppercase;
      letter-spacing: .05em;
    }
    .ask-drawer-followups button {
      border: 1px solid color-mix(in srgb, var(--accent) 30%, var(--line));
      border-radius: 999px;
      background: color-mix(in srgb, var(--accent) 8%, var(--panel));
      color: var(--accent);
      padding: 8px 10px;
      text-align: left;
      font-size: 12px;
      font-weight: 800;
      cursor: pointer;
    }
    .ask-drawer-followups button:hover {
      border-color: color-mix(in srgb, var(--accent) 55%, var(--line));
      background: color-mix(in srgb, var(--accent) 13%, var(--panel));
    }
    .ask-drawer-form {
      display: grid;
      grid-template-columns: minmax(0, 1fr) auto;
      gap: 8px;
      padding: 12px;
      border-top: 1px solid var(--line);
      background: color-mix(in srgb, var(--panel) 82%, transparent);
    }
    .ask-drawer-form textarea {
      min-height: 44px;
      max-height: 132px;
      resize: vertical;
      border: 1px solid var(--line);
      border-radius: 10px;
      background: var(--bg);
      color: var(--text);
      padding: 10px 11px;
      font: inherit;
      font-size: 14px;
      outline: none;
    }
    .ask-drawer-form textarea:focus {
      border-color: color-mix(in srgb, var(--accent) 55%, var(--line));
    }
    .ask-drawer-form button {
      min-width: 72px;
      border: 0;
      border-radius: 10px;
      background: var(--accent);
      color: #fff;
      padding: 0 14px;
      font-size: 13px;
      font-weight: 850;
      cursor: pointer;
    }
    .ask-drawer-form button:disabled {
      opacity: .62;
      cursor: wait;
    }
    .bottom-line-block { border-left: 3px solid var(--accent); padding: 10px 0 10px 14px; margin: 18px 0 8px 0; }
    .answer-actions { display: flex; gap: 8px; flex-wrap: wrap; }
    .answer-trust-layer { margin-top: 14px; }
    .answer-evidence-line {
      display: flex; align-items: center; flex-wrap: wrap; gap: 7px;
      color: var(--muted); font-size: 12px; font-weight: 600;
      margin: 2px 0 10px;
    }
    .answer-evidence-line span:not(.evidence-sep) { display: inline-flex; align-items: center; }
    .evidence-sep { color: color-mix(in srgb, var(--muted) 45%, transparent); }
    .answer-sources-drawer {
      border: 1px solid var(--line); border-radius: 12px;
      background: color-mix(in srgb, var(--surface-content) 86%, transparent);
      margin-top: 10px; overflow: hidden;
    }
    .answer-sources-drawer summary {
      cursor: pointer; list-style: none; padding: 10px 12px;
      color: var(--text); font-size: 13px; font-weight: 700;
      display: flex; align-items: center; justify-content: space-between;
    }
    .answer-sources-drawer summary::-webkit-details-marker { display: none; }
    .answer-sources-drawer summary::after { content: '+'; color: var(--muted); font-size: 15px; line-height: 1; }
    .answer-sources-drawer[open] summary::after { content: '-'; }
    .answer-source-list { border-top: 1px solid var(--line); }
    .answer-source-row { padding: 11px 12px; border-top: 1px solid color-mix(in srgb, var(--line) 55%, transparent); }
    .answer-source-row:first-child { border-top: 0; }
    .answer-source-title { font-size: 13px; font-weight: 700; line-height: 1.35; color: var(--text); }
    .answer-source-title a { color: inherit; text-decoration: none; }
    .answer-source-title a:hover { color: var(--accent); }
    .answer-source-meta { color: var(--muted); font-size: 11px; margin-top: 4px; }
    .answer-source-excerpt { color: var(--muted); font-size: 12px; line-height: 1.45; margin-top: 6px; }
    .answer-intel-tools { margin-top: 12px; }
    .answer-intel-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); gap: 8px; }
    .answer-intel-card {
      text-align: left; border: 1px solid var(--line); border-radius: 12px;
      background: color-mix(in srgb, var(--surface-content) 86%, transparent);
      padding: 10px 11px; cursor: pointer; font: inherit; color: var(--text);
      transition: border-color .16s, background .16s, transform .16s;
    }
    .answer-intel-card:hover {
      border-color: color-mix(in srgb, var(--accent) 55%, var(--line));
      background: color-mix(in srgb, var(--accent) 9%, var(--surface-content));
      transform: translateY(-1px);
    }
    .answer-intel-card strong { display: block; font-size: 13px; line-height: 1.25; margin-bottom: 4px; }
    .answer-intel-card em { display: block; font-style: normal; color: var(--muted); font-size: 12px; line-height: 1.35; }
    .answer-intel-card span { display: block; color: color-mix(in srgb, var(--accent) 80%, var(--text)); font-size: 11px; font-weight: 700; margin-top: 7px; }
    .answer-followups { margin-top: 12px; }
    .answer-followups-label {
      color: var(--muted); font-size: 11px; font-weight: 700;
      text-transform: uppercase; letter-spacing: .05em; margin-bottom: 8px;
    }
    .answer-followup-row { display: flex; flex-wrap: wrap; gap: 8px; }
    .answer-followup-chip {
      border: 1px solid color-mix(in srgb, var(--accent) 30%, var(--line)); background: color-mix(in srgb, var(--accent) 8%, var(--surface-content));
      color: var(--accent); border-radius: 999px; padding: 8px 12px;
      font: inherit; font-size: 13px; line-height: 1.2; font-weight: 800; cursor: pointer;
      transition: border-color .16s, background .16s, color .16s, transform .16s;
    }
    .answer-followup-chip:hover {
      border-color: color-mix(in srgb, var(--accent) 55%, var(--line));
      background: color-mix(in srgb, var(--accent) 13%, var(--surface-content));
      transform: translateY(-1px);
    }
    .answer { border: 1px solid rgba(33,201,162,.28); background: rgba(33,201,162,.12); }
    .answer p { color: var(--text); font-size: 16px; font-family: inherit; }
    .thinking { border: none; background: transparent; padding: 16px 18px 8px; }
    .thinking p { color: var(--muted); font-size: 15px; line-height: 1; display: flex; align-items: center; gap: 10px; }
    .thinking-text { color: var(--muted); font-size: 16px; font-weight: 500; font-family: inherit; transition: opacity .3s ease; }
    .thinking-dots { display: inline-flex; gap: 6px; }
    .thinking-dots span { width: 6px; height: 6px; border-radius: 999px; background: var(--muted); opacity: .3; animation: pulse 1.4s infinite ease-in-out; }
    .thinking-dots span:nth-child(2) { animation-delay: .2s; }
    .thinking-dots span:nth-child(3) { animation-delay: .4s; }
    @keyframes pulse { 0%, 80%, 100% { transform: scale(.7); opacity: .2; } 40% { transform: scale(1); opacity: .6; } }
    /* Instant skeleton bubble — shown immediately on submit so the user sees the answer "frame" appear before tokens arrive */
    .skeleton-bubble { padding: 16px 18px; }
    .skeleton-line { height: 14px; border-radius: 6px; background: linear-gradient(90deg, rgba(255,255,255,.05) 0%, rgba(255,255,255,.10) 50%, rgba(255,255,255,.05) 100%); background-size: 200% 100%; animation: shimmer 1.4s linear infinite; margin-bottom: 10px; }
    .skeleton-line:last-child { margin-bottom: 0; }
    .skeleton-line.w-90 { width: 90%; }
    .skeleton-line.w-75 { width: 75%; }
    .skeleton-line.w-60 { width: 60%; }
    @keyframes shimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }
    .recency-badge { display: inline-flex; align-items: center; gap: 6px; padding: 4px 10px; border-radius: 999px; background: rgba(0,200,120,.10); border: 1px solid rgba(0,200,120,.25); color: #2ecc71; font-size: 12px; font-weight: 600; margin-bottom: 12px; opacity: 0; transition: opacity .25s; }
    .recency-badge.show { opacity: 1; }
    .recency-badge .recency-dot { width: 6px; height: 6px; border-radius: 999px; background: #2ecc71; box-shadow: 0 0 8px rgba(46,204,113,.6); animation: recency-pulse 1.6s ease-in-out infinite; }
    @keyframes recency-pulse { 0%, 100% { opacity: 1; } 50% { opacity: .4; } }
    .expand-btn { margin-top: 8px; border: none; background: var(--hover); color: var(--muted); border-radius: 8px; padding: 5px 12px; font-size: 13px; font-weight: 500; cursor: pointer; font-family: inherit; transition: background .15s; }
    .expand-btn:hover { background: var(--active); color: var(--text); }
    .go-deeper-btn { border: none; background: var(--accent); color: #fff; border-radius: 8px; padding: 6px 16px; font-size: 13px; font-weight: 600; cursor: pointer; font-family: inherit; transition: all .15s; opacity: .9; }
    .go-deeper-btn:hover { opacity: 1; transform: translateY(-1px); }
    .message.collapsed .bubble { padding: 0; }
    .bubble.collapsed-row, .message .bubble.collapsed-row { padding: 10px 18px !important; display: flex; align-items: center; gap: 10px; background: var(--surface-content); border: 1px solid color-mix(in srgb, var(--line) 70%, transparent); border-radius: 12px; }
    .collapsed-question { font-size: 14px; color: var(--muted); font-family: inherit; flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    .expand-collapsed-btn { border: none; background: var(--hover); color: var(--muted); border-radius: 8px; padding: 5px 12px; font-size: 13px; font-weight: 500; cursor: pointer; font-family: inherit; flex-shrink: 0; transition: background .15s; }
    .expand-collapsed-btn:hover { background: var(--active); color: var(--text); }
    .fb-comment-inline { display: flex; gap: 6px; align-items: center; margin-left: auto; }
    .fb-comment-input { background: var(--panel-2); border: 1px solid var(--line); border-radius: 8px; padding: 5px 10px; font-size: 12px; color: var(--text); font-family: inherit; outline: none; width: 200px; }
    .fb-comment-input:focus { border-color: rgba(255,255,255,.2); }
    .fb-comment-send { border: none; background: var(--hover); color: var(--muted); border-radius: 6px; padding: 5px 10px; font-size: 12px; font-weight: 500; cursor: pointer; font-family: inherit; }
    .fb-comment-send:hover { background: var(--active); color: var(--text); }
    .query-result { margin-top: 8px; }
    .query-section { margin-bottom: 12px; }
    .query-section-title { font-size: 13px; font-weight: 600; letter-spacing: 0; text-transform: none; color: var(--muted); margin-bottom: 8px; font-family: inherit; }
    .model-stage { border-left: 3px solid var(--line); }
    .model-stage.gpt { border-left-color: var(--gpt-color); }
    .model-stage.claude { border-left-color: var(--claude-color); }
    .model-stage.gemini { border-left-color: var(--gemini-color); }
    .model-stage.final { border-left-color: var(--judge-color); border: 1px solid rgba(33,201,162,.28); background: rgba(33,201,162,.1); }
    .round-toggle { margin-top: 10px; border: 1px solid var(--line); background: var(--panel-2); color: var(--muted); border-radius: 8px; padding: 6px 12px; font-size: 11px; font-weight: 700; cursor: pointer; }
    .round-toggle:hover { background: var(--panel); color: var(--text); }
    .query-rounds { display: none; margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--line); }
    .query-rounds.visible { display: block; }
    .feedback-row { display: flex; align-items: center; gap: 8px; margin-top: 12px; padding-top: 10px; border-top: 1px solid var(--line); }
    @media (max-width: 600px) {
      .ask-drawer-backdrop {
        background: rgba(0,0,0,.34);
      }
      .ask-drawer {
        width: 100vw;
        border-left: 0;
        height: 100dvh;
      }
      .ask-drawer-head {
        padding: 10px 12px;
      }
      .ask-drawer-messages {
        padding: 10px 12px;
      }
      .ask-drawer-form {
        grid-template-columns: minmax(0, 1fr) 66px;
        align-items: stretch;
        gap: 7px;
        padding: 8px 10px calc(env(safe-area-inset-bottom, 0px) + 8px);
      }
      .ask-drawer-form textarea {
        min-height: 38px;
        max-height: 96px;
        resize: none;
        padding: 9px 10px;
        font-size: 13px;
      }
      .ask-drawer-form button {
        min-height: 38px;
        min-width: 0;
        padding: 0 10px;
      }
      .ask-drawer-reopen {
        display: none !important;
      }
      .feedback-row { justify-content: center; flex-wrap: wrap; }
      .feedback-row .copy-btn { margin-left: 0; }
    }
    .feedback-row span { font-size: 11px; color: var(--muted); }
    .copy-btn, .email-btn { background: none; border: none; font-size: 14px; cursor: pointer; padding: 2px 6px; border-radius: 4px; transition: color .15s, opacity .15s; }
    .copy-btn { margin-left: auto; color: var(--muted); opacity: 0.5; }
    .copy-btn:hover { color: var(--text); opacity: 1; }
    .copy-btn.copied { color: var(--green); opacity: 1; }
    .email-btn { color: var(--text); opacity: 0.85; }
    .email-btn:hover { color: var(--accent); opacity: 1; }

    /* ── Info Cards (entity + crypto) ── */
    .info-card {
      display: flex; gap: 16px; padding: 16px 18px; margin-bottom: 14px;
      background: var(--panel); border: 1px solid var(--line); border-radius: 14px;
      align-items: center; position: relative;
    }
    .info-card-img {
      width: 90px; height: 90px; border-radius: 12px; object-fit: cover; flex-shrink: 0;
      background: var(--panel-2); cursor: pointer; transition: transform .15s;
    }
    .info-card-img:hover { transform: scale(1.05); }
    .info-card-body { flex: 1; min-width: 0; }
    .info-card-title {
      font-size: 17px; font-weight: 700; color: var(--text); margin: 0 0 4px;
      display: flex; align-items: center; gap: 8px;
    }
    .info-card-desc { font-size: 13px; color: var(--muted); margin: 0 0 10px; line-height: 1.4; }
    .info-card-facts {
      display: flex; flex-wrap: wrap; gap: 6px 16px;
    }
    .info-card-fact {
      font-size: 12px; color: var(--muted);
    }
    .info-card-fact b { color: var(--text); font-weight: 500; }
    /* Image zoom overlay */
    .img-zoom-overlay {
      display: none; position: fixed; top: 0; left: 0; width: 100%; height: 100%;
      background: rgba(0,0,0,.85); z-index: 9999; cursor: zoom-out;
      justify-content: center; align-items: center;
    }
    .img-zoom-overlay.active { display: flex; }
    .img-zoom-overlay img {
      max-width: 90vw; max-height: 85vh; border-radius: 12px; object-fit: contain;
      box-shadow: 0 8px 40px rgba(0,0,0,.5);
    }

    /* Crypto-specific card styling */
    .crypto-card { background: var(--panel); }
    .crypto-card-row {
      display: grid; grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
      gap: 8px; margin-top: 8px;
    }
    .crypto-stat {
      font-size: 11px; color: var(--muted); line-height: 1.4;
    }
    .crypto-stat b { display: block; font-size: 13px; color: var(--text); font-weight: 600; }
    .crypto-change-up { color: var(--green); }
    .crypto-change-down { color: #ef4444; }
    .crypto-chart-pill {
      position: absolute; top: 10px; right: 10px;
      background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.12);
      color: var(--muted); font-size: 11px; font-weight: 600;
      padding: 4px 10px; border-radius: 12px; cursor: pointer;
      transition: all 0.2s; display: flex; align-items: center; gap: 4px;
    }
    .crypto-chart-pill:hover { background: rgba(99,179,237,.15); color: #63b3ed; border-color: rgba(99,179,237,.3); }
    .crypto-chart-pill svg { width: 12px; height: 12px; }
    .pro-chart-btn {
      display: inline-flex; align-items: center; gap: 6px; border: 1px solid rgba(43,181,138,.38);
      border-radius: 999px; background: rgba(43,181,138,.12); color: #26a69a;
      padding: 7px 12px; font: inherit; font-size: 12px; font-weight: 850; cursor: pointer;
      transition: background .15s, border-color .15s, transform .15s;
    }
    .pro-chart-btn:hover { background: rgba(43,181,138,.2); border-color: rgba(43,181,138,.6); transform: translateY(-1px); }
    .pro-chart-modal { display: none; position: fixed; inset: 0; z-index: 10000; background: #0f1318; overflow: hidden; padding: 0; }
    .pro-chart-modal.open { display: block; }
    .pro-chart-shell { width: 100vw; height: 100vh; background: #0f1318; border: 0; border-radius: 0; overflow: hidden; display: flex; flex-direction: column; box-shadow: none; }
    .pro-chart-head { position: relative; display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; padding: 10px 52px 10px 12px; border-bottom: 1px solid #252b36; background: #111720; flex: 0 0 auto; }
    .pro-chart-head-left { min-width: 0; flex: 1; }
    .pro-chart-symbol-row { display: flex; align-items: center; gap: 10px; min-width: 0; margin-bottom: 7px; }
    .pro-chart-exit { border: 1px solid #2a2e39; border-radius: 6px; background: #1a1f2a; color: #d1d4dc; height: 36px; padding: 0 12px; cursor: pointer; font: inherit; font-size: 12px; font-weight: 900; flex: 0 0 auto; }
    .pro-chart-search { display: flex; align-items: center; gap: 7px; flex: 0 1 360px; min-width: 220px; height: 36px; padding: 0 5px 0 10px; border: 1px solid #2a2e39; border-radius: 6px; background: #0b1017; }
    .pro-chart-search .app-icon { width: 15px; height: 15px; color: rgba(255,255,255,.55); flex: 0 0 auto; }
    .pro-chart-search input { min-width: 0; flex: 1; border: 0; outline: 0; background: transparent; color: #f2f5f8; font: inherit; font-size: 13px; font-weight: 750; text-transform: uppercase; }
    .pro-chart-search button { border: 0; border-radius: 4px; background: #e8572a; color: #fff; height: 26px; padding: 0 10px; font: inherit; font-size: 11px; font-weight: 900; cursor: pointer; }
    .pro-chart-quick { display: flex; align-items: center; gap: 5px; overflow-x: auto; scrollbar-width: none; min-width: 0; }
    .pro-chart-quick::-webkit-scrollbar { display: none; }
    .pro-chart-quick-btn { border: 1px solid #2a2e39; border-radius: 4px; background: #1a1f2a; color: rgba(255,255,255,.65); height: 30px; padding: 0 9px; cursor: pointer; font: inherit; font-size: 11px; font-weight: 900; white-space: nowrap; }
    .pro-chart-quick-btn.portfolio { border-color: rgba(43,181,138,.38); color: rgba(209,244,226,.86); }
    .pro-chart-quick-btn.recent { border-color: rgba(255,181,71,.28); color: rgba(255,226,180,.82); }
    .pro-chart-quick-btn.active { background: rgba(232,87,42,.18); border-color: rgba(232,87,42,.6); color: #fff; }
    .pro-chart-watch-add { height: 34px; border: 1px solid rgba(43,181,138,.48); border-radius: 7px; background: rgba(43,181,138,.14); color: rgba(218,247,232,.94); padding: 0 12px; font: inherit; font-size: 11px; font-weight: 950; cursor: pointer; white-space: nowrap; }
    .pro-chart-watch-add:hover { border-color: rgba(43,181,138,.74); color: #fff; }
    .pro-chart-watch-add.active { border-color: #2a2e39; background: #151b24; color: rgba(255,255,255,.5); }
    .pro-chart-title { display: none; color: #f2f5f8; font-size: 18px; font-weight: 900; letter-spacing: -.02em; }
    .pro-chart-sub { display: none; align-items: center; gap: 8px; flex-wrap: wrap; color: rgba(255,255,255,.46); font-size: 12px; margin-top: 5px; }
    .pro-chart-price { color: #d1d4dc; font-weight: 850; }
    .pro-chart-close { position: fixed; top: 10px; left: calc(100vw - 46px); width: 34px; height: 34px; z-index: 10002; border: 1px solid #2a2e39; border-radius: 8px; background: #1a1f2a; color: #d1d4dc; padding: 0; cursor: pointer; font: inherit; font-size: 0; font-weight: 800; }
    .pro-chart-close::before { content: 'X'; font-size: 13px; line-height: 1; }
    .pro-chart-mainbar, .pro-chart-toolbar, .pro-chart-scalebar { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; padding: 8px 12px; background: #0f1318; border-bottom: 1px solid #1e222d; }
    .pro-chart-mainbar { justify-content: space-between; }
    .pro-chart-mainbar .pro-chart-control-group:nth-child(2) { margin-left: auto; }
    .pro-chart-mobile-select { display: none; }
    .pro-chart-toolbar-label { font-size: 11px; color: rgba(255,255,255,.55); font-weight: 900; margin-right: 6px; text-transform: uppercase; letter-spacing: .06em; }
    .pro-chart-main-legend {
      position: absolute;
      top: 8px;
      left: 10px;
      z-index: 5;
      display: none;
      min-width: 238px;
      max-width: min(430px, calc(100vw - 86px));
      color: #d1d4dc;
      background: rgba(15,19,24,.86);
      border: 1px solid rgba(255,255,255,.12);
      border-radius: 6px;
      padding: 8px 10px;
      pointer-events: none;
      box-shadow: 0 12px 30px rgba(0,0,0,.26);
      backdrop-filter: blur(8px);
    }
    .pro-chart-main-legend .legend-date {
      margin-bottom: 5px;
      color: rgba(255,255,255,.58);
      font-size: 11px;
      font-weight: 850;
      letter-spacing: .02em;
    }
    .pro-chart-main-legend .legend-row {
      display: grid;
      grid-template-columns: minmax(76px, auto) minmax(0, 1fr);
      gap: 10px;
      align-items: baseline;
      min-height: 21px;
      font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    }
    .pro-chart-main-legend .legend-label {
      color: rgba(255,255,255,.66);
      font-size: 12px;
      font-weight: 900;
      white-space: nowrap;
    }
    .pro-chart-main-legend .legend-value {
      color: #f2f5f8;
      font-size: 14px;
      font-weight: 850;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }
    .pro-chart-main-legend .legend-price .legend-value {
      font-size: 13px;
    }
    .pro-chart-main-legend .legend-ohlc .legend-value {
      font-size: 13px;
    }
    .pro-chart-control-group { display: flex; align-items: center; gap: 8px; min-width: 0; }
    .pro-chart-control-label { color: rgba(255,255,255,.42); font-size: 10px; font-weight: 900; letter-spacing: .08em; text-transform: uppercase; white-space: nowrap; }
    .pro-chart-controls { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
	    .pro-chart-chip { border: 1px solid #2a2e39; border-radius: 999px; background: #1a1f2a; color: rgba(255,255,255,.62); padding: 5px 10px; cursor: pointer; font: inherit; font-size: 11px; font-weight: 800; }
	    .pro-chart-chip.active { background: rgba(43,181,138,.18); border-color: rgba(43,181,138,.5); color: #d1d4dc; }
	    .pro-chart-control-btn,
	    .pro-chart-scale-btn { border: 1px solid #2a2e39; border-radius: 5px; background: #151b24; color: rgba(255,255,255,.58); min-height: 28px; padding: 4px 10px; cursor: pointer; font: inherit; font-size: 11px; font-weight: 760; white-space: nowrap; transition: border-color .15s, background .15s, color .15s, box-shadow .15s; }
	    .pro-chart-control-btn:hover,
	    .pro-chart-scale-btn:hover { border-color: rgba(255,181,71,.5); color: #f2f5f8; }
	    .pro-chart-control-btn.active,
	    .pro-chart-scale-btn.active { background: rgba(43,181,138,.15); border-color: rgba(43,181,138,.45); color: #d1d4dc; box-shadow: inset 0 0 0 1px rgba(255,255,255,.04); }
	    .pro-chart-control-priority { border-color: #384355; background: #17202b; color: rgba(255,255,255,.78); border-radius: 6px; min-height: 30px; padding: 5px 12px; font-weight: 900; }
	    .pro-chart-control-priority.active.volume { background: rgba(43,181,138,.20); border-color: rgba(43,181,138,.58); color: #f2f5f8; }
	    .pro-chart-control-priority.active.levels { background: rgba(255,181,71,.17); border-color: rgba(255,181,71,.62); color: #f2f5f8; }
	    .pro-chart-control-secondary { background: #141b25; color: rgba(255,255,255,.68); border-radius: 6px; font-weight: 850; }
	    .pro-chart-control-secondary.active { background: rgba(255,181,71,.14); border-color: rgba(255,181,71,.46); color: rgba(255,226,180,.92); }
	    .pro-chart-control-clear { margin-left: 6px; background: transparent; color: rgba(255,255,255,.45); font-weight: 700; }
	    .pro-chart-scale-btn.reset { background: rgba(255,181,71,.13); border-color: rgba(255,181,71,.55); color: rgba(255,226,180,.96); border-radius: 6px; padding: 5px 12px; font-weight: 900; }
	    .pro-chart-scale-btn.unlock { background: rgba(74,159,212,.13); border-color: rgba(74,159,212,.48); color: rgba(205,226,244,.94); border-radius: 6px; padding: 5px 12px; font-weight: 900; }
	    .pro-chart-scale-btn.unlock.active { background: rgba(43,181,138,.22); border-color: rgba(43,181,138,.6); color: #dff8ec; }
    .pro-chart-actionbar { display: flex; justify-content: flex-end; align-items: center; gap: 10px; padding: 6px 12px; background: #10161f; border-bottom: 1px solid #1e222d; }
    .pro-chart-read-stack { display: grid; gap: 6px; min-width: 0; }
    .pro-chart-read-stack[hidden] { display: none !important; }
    .pro-chart-mtf-strip { display: flex; align-items: center; gap: 6px; min-width: 0; overflow-x: auto; scrollbar-width: none; }
    .pro-chart-mtf-strip::-webkit-scrollbar { display: none; }
    .pro-chart-mtf-chip { display: inline-flex; align-items: center; gap: 6px; height: 27px; border: 1px solid #2a2e39; border-radius: 999px; background: #151b24; color: rgba(255,255,255,.76); padding: 0 10px; font-size: 12px; font-weight: 900; white-space: nowrap; }
    .pro-chart-mtf-chip b { color: #f2f5f8; font-size: 12px; }
    .pro-chart-mtf-chip.bull { border-color: rgba(43,181,138,.5); background: rgba(43,181,138,.13); color: rgba(209,244,226,.92); }
    .pro-chart-mtf-chip.constructive { border-color: rgba(43,181,138,.36); background: rgba(43,181,138,.09); color: rgba(209,244,226,.86); }
    .pro-chart-mtf-chip.bear { border-color: rgba(239,83,80,.48); background: rgba(239,83,80,.13); color: rgba(255,214,212,.92); }
    .pro-chart-mtf-chip.fragile { border-color: rgba(239,83,80,.34); background: rgba(239,83,80,.09); color: rgba(255,214,212,.82); }
    .pro-chart-mtf-chip.neutral { border-color: rgba(255,181,71,.38); background: rgba(255,181,71,.1); color: rgba(255,226,180,.88); }
    .pro-chart-mtf-chip.loading { color: rgba(255,255,255,.42); }
    .pro-chart-mtf-summary { min-width: 260px; color: rgba(255,255,255,.72); font-size: 12px; font-weight: 760; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .pro-chart-mtf-strip.in-panel { margin: 0 0 8px; flex-wrap: wrap; overflow: visible; }
    .pro-chart-narrative { min-width: 0; color: rgba(255,255,255,.78); font-size: 12px; font-weight: 650; line-height: 1.35; }
    .pro-chart-narrative b { color: #f2f5f8; }
    .pro-chart-actions { display: flex; align-items: center; justify-content: flex-end; gap: 6px; min-width: 0; }
    .pro-chart-action-btn,
    .pro-chart-compare button { height: 28px; border: 1px solid #2a2e39; border-radius: 5px; background: #1a1f2a; color: rgba(255,255,255,.72); padding: 0 10px; font: inherit; font-size: 11px; font-weight: 850; cursor: pointer; white-space: nowrap; }
    .pro-chart-action-btn:hover,
    .pro-chart-compare button:hover { border-color: rgba(43,181,138,.55); color: #fff; }
    .pro-chart-action-primary { background: linear-gradient(135deg, #ff6a2a, #f0b35a); border-color: rgba(255,106,42,.8); color: #111820; box-shadow: 0 0 0 1px rgba(255,255,255,.06), 0 8px 22px rgba(232,87,42,.22); }
    .pro-chart-action-primary:hover { color: #080c10; border-color: rgba(255,190,90,.95); }
    .pro-chart-scale-spacer { flex: 1 1 auto; min-width: 12px; }
    .pro-chart-compare { display: flex; align-items: center; gap: 6px; min-width: 0; margin: 0; border: 1px solid rgba(255,181,71,.34); border-radius: 7px; background: rgba(255,181,71,.08); padding: 3px; }
    .pro-chart-compare span { color: rgba(255,226,180,.9); font-size: 10px; font-weight: 950; text-transform: uppercase; letter-spacing: .05em; white-space: nowrap; padding-left: 5px; }
    .pro-chart-compare input { width: 136px; height: 28px; border: 1px solid rgba(255,181,71,.36); border-radius: 5px; background: #0b0f14; color: #f2f5f8; padding: 0 8px; font: inherit; font-size: 12px; font-weight: 800; outline: none; }
    .pro-chart-compare-chips { display: flex; align-items: center; gap: 4px; min-width: 0; }
    .pro-chart-compare-chips button { height: 28px; border: 1px solid #2a2e39; border-radius: 999px; background: #141b25; color: rgba(255,255,255,.62); padding: 0 8px; font: inherit; font-size: 10.5px; font-weight: 900; cursor: pointer; white-space: nowrap; }
    .pro-chart-compare-chips button:hover { border-color: rgba(255,181,71,.65); color: #fff; }
    .pro-chart-panel { flex: 0 0 auto; border-bottom: 1px solid #1e222d; background: #0d131b; padding: 12px; color: rgba(255,255,255,.72); }
    .pro-chart-panel[hidden] { display: none !important; }
    .pro-chart-panel-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 10px; }
    .pro-chart-panel-head strong { color: #f2f5f8; font-size: 13px; font-weight: 900; }
    .pro-chart-panel-close { width: 28px; height: 28px; border: 1px solid #2a2e39; border-radius: 6px; background: #1a1f2a; color: rgba(255,255,255,.7); cursor: pointer; font-size: 16px; line-height: 1; }
    .pro-chart-panel-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 8px; }
    .pro-chart-plan-grid { grid-template-columns: repeat(6, minmax(0, 1fr)); }
    .pro-chart-panel-card { border: 1px solid #253142; border-radius: 8px; background: #121a25; padding: 10px; min-width: 0; }
    .pro-chart-panel-card.wide { grid-column: span 2; }
    .pro-chart-panel-kicker { color: rgba(255,255,255,.42); font-size: 10px; font-weight: 900; text-transform: uppercase; letter-spacing: .06em; margin-bottom: 5px; }
    .pro-chart-panel-title { color: #f2f5f8; font-size: 13px; font-weight: 900; margin-bottom: 4px; }
    .pro-chart-panel-text { font-size: 12px; line-height: 1.45; color: rgba(255,255,255,.68); }
    .pro-chart-alert-list { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
    .pro-chart-alert-list button { border: 1px solid #2a2e39; border-radius: 999px; background: #1a1f2a; color: rgba(255,255,255,.75); padding: 6px 10px; font: inherit; font-size: 11px; font-weight: 850; cursor: pointer; }
    .pro-chart-alert-list button:hover { border-color: rgba(232,87,42,.65); color: #fff; }
    .pro-chart-level-options { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
    .pro-chart-level-options button { border: 1px solid #2a2e39; border-radius: 999px; background: #1a1f2a; color: rgba(255,255,255,.62); padding: 6px 10px; font: inherit; font-size: 11px; font-weight: 850; cursor: pointer; }
    .pro-chart-level-options button.active { border-color: rgba(43,181,138,.55); background: rgba(43,181,138,.18); color: #d1d4dc; }
    .pro-chart-level-options button:hover { border-color: rgba(255,181,71,.65); color: #fff; }
    .pro-chart-alert-form { display: grid; grid-template-columns: minmax(150px, 1fr) minmax(150px, 1fr) minmax(120px, auto); gap: 8px; align-items: end; margin-top: 10px; }
    .pro-chart-alert-form label { display: grid; gap: 4px; color: rgba(255,255,255,.48); font-size: 10px; font-weight: 900; text-transform: uppercase; letter-spacing: .05em; }
    .pro-chart-alert-form select,
    .pro-chart-alert-form input { min-width: 0; height: 32px; border: 1px solid #2a2e39; border-radius: 6px; background: #0b0f14; color: #d1d4dc; padding: 0 8px; font: inherit; font-size: 12px; outline: none; }
    .pro-chart-alert-form button { width: 100%; min-width: 120px; height: 32px; border: 1px solid rgba(43,181,138,.55); border-radius: 6px; background: rgba(43,181,138,.18); color: #d1d4dc; padding: 0 12px; font: inherit; font-size: 11px; font-weight: 900; cursor: pointer; }
    .pro-chart-settings-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 8px; }
    .pro-chart-settings-grid label { display: grid; gap: 5px; min-width: 0; color: rgba(255,255,255,.48); font-size: 10px; font-weight: 900; text-transform: uppercase; letter-spacing: .05em; }
    .pro-chart-settings-grid select { height: 34px; border: 1px solid #2a2e39; border-radius: 6px; background: #0b0f14; color: #d1d4dc; padding: 0 8px; font: inherit; font-size: 12px; outline: none; }
    .pro-chart-panel-actions { display: flex; align-items: center; gap: 8px; margin-top: 10px; }
    .pro-chart-panel-actions button { height: 32px; border: 1px solid #2a2e39; border-radius: 6px; background: #1a1f2a; color: rgba(255,255,255,.72); padding: 0 12px; font: inherit; font-size: 11px; font-weight: 900; cursor: pointer; }
    .pro-chart-panel-actions button:first-child { border-color: rgba(43,181,138,.55); background: rgba(43,181,138,.18); color: #d1d4dc; }
    .pro-chart-workspace-main { flex: 1 1 auto; min-height: 0; display: grid; grid-template-columns: 42px minmax(0, 1fr) 284px; background: var(--pro-chart-bg, #131722); }
    .pro-chart-draw-rail { min-width: 0; border-right: 1px solid var(--pro-chart-rail-border, #1e222d); background: var(--pro-chart-panel, #0f1318); padding: 7px 5px; display: flex; flex-direction: column; gap: 6px; }
    .pro-chart-draw-rail button { width: 31px; height: 31px; border: 1px solid #2a2e39; border-radius: 6px; background: #151b24; color: rgba(255,255,255,.62); font: inherit; font-size: 9px; font-weight: 950; cursor: pointer; padding: 0; }
    .pro-chart-draw-rail button:hover { border-color: rgba(255,181,71,.55); color: #f2f5f8; }
    .pro-chart-draw-rail button.active { border-color: rgba(43,181,138,.58); background: rgba(43,181,138,.18); color: #dff8ec; }
    /* Theme cluster pinned to the bottom of the draw rail */
    .pro-chart-theme-group { margin-top: auto; display: flex; flex-direction: column; gap: 6px; padding-top: 8px; border-top: 1px solid var(--pro-chart-rail-border, #2a2e39); }
    .pro-chart-theme-group button[data-theme="dark"]  { background: linear-gradient(135deg, #131722 50%, #2a2e39 50%); color: #e1e6ee; }
    .pro-chart-theme-group button[data-theme="gray"]  { background: linear-gradient(135deg, #1c2128 50%, #3a414b 50%); color: #cdd2d9; }
    .pro-chart-theme-group button[data-theme="light"] { background: linear-gradient(135deg, #fafbfc 50%, #cfd2d6 50%); color: #1f2429; border-color: #b9bdc3; }
    .pro-chart-theme-group button.active { box-shadow: 0 0 0 2px rgba(255,181,71,.65) inset; border-color: rgba(255,181,71,.7); }
    /* Mobile rail is a horizontal row; the theme cluster sits at the right end. */
    @media (max-width: 720px) {
      .pro-chart-theme-group { margin-top: 0; margin-left: auto; flex-direction: row; padding-top: 0; padding-left: 8px; border-top: 0; border-left: 1px solid var(--pro-chart-rail-border, #2a2e39); }
    }
    /* Light-theme contrast: dark rail buttons need readable text on a light panel */
    [data-pro-theme="light"] .pro-chart-draw-rail button { background: #ffffff; color: #2c3038; border-color: #cfd2d6; }
    [data-pro-theme="light"] .pro-chart-draw-rail button.active { background: rgba(43,181,138,.14); color: #1c5a40; border-color: rgba(43,181,138,.65); }
    [data-pro-theme="light"] .pro-chart-draw-rail button:hover { border-color: rgba(232,87,42,.7); color: #1f2429; }
    [data-pro-theme="gray"]  .pro-chart-draw-rail button { background: #232a33; color: rgba(255,255,255,.74); border-color: #3a414b; }
    .pro-chart-body { position: relative; background: var(--pro-chart-bg, #131722); flex: 1 1 auto; min-height: 0; display: flex; flex-direction: column; overflow: hidden; }
    .pro-chart-canvas { width: 100%; flex: 1 1 0; height: auto; min-height: 220px; position: relative; }
    .pro-chart-draw-layer { position: absolute; inset: 0; z-index: 6; width: 100%; height: 100%; pointer-events: none; overflow: visible; }
    .pro-chart-draw-layer.active { pointer-events: auto; cursor: crosshair; }
    .pro-chart-draw-layer.selecting { pointer-events: auto; cursor: default; }
    .pro-chart-draw-layer .draw-shape { pointer-events: auto; cursor: move; }
    .pro-chart-draw-layer.active .draw-shape { pointer-events: none; cursor: crosshair; }
    .pro-chart-draw-layer line.draw-shape { stroke: rgba(255,181,71,.92); stroke-width: 2; vector-effect: non-scaling-stroke; }
    .pro-chart-draw-layer rect.draw-shape { fill: rgba(255,181,71,.10); stroke: rgba(255,181,71,.78); stroke-width: 1.5; vector-effect: non-scaling-stroke; }
    .pro-chart-draw-layer .draw-fib { stroke: rgba(255,181,71,.74); stroke-width: 1.3; vector-effect: non-scaling-stroke; }
    .pro-chart-draw-layer rect.draw-fib { fill: rgba(255,181,71,.045); stroke-dasharray: 4 4; }
    .pro-chart-draw-layer .draw-arrow-head { fill: rgba(255,181,71,.94); stroke: none; }
    .pro-chart-draw-layer .draw-hit { stroke: transparent; stroke-width: 16; fill: transparent; vector-effect: non-scaling-stroke; pointer-events: stroke; cursor: move; }
    .pro-chart-draw-layer.active .draw-hit { pointer-events: none; }
    .pro-chart-draw-layer.selecting .draw-hit { pointer-events: all; }
    .pro-chart-draw-layer .preview { opacity: .58; stroke-dasharray: 5 5; }
    .pro-chart-draw-layer .selected { stroke: #f2f5f8; stroke-width: 2.5; filter: drop-shadow(0 0 5px rgba(255,181,71,.45)); }
    .pro-chart-draw-layer text { fill: #f2f5f8; font-size: 11px; font-weight: 900; paint-order: stroke; stroke: rgba(15,19,24,.88); stroke-width: 3px; }
    .pro-chart-cme-layer { position: absolute; inset: 0; z-index: 5; width: 100%; height: 100%; pointer-events: none; overflow: visible; }
    .pro-chart-cme-layer .cme-gap-zone { fill: rgba(255,181,71,.13); stroke: rgba(255,181,71,.72); stroke-width: 1.2; vector-effect: non-scaling-stroke; }
    .pro-chart-cme-layer .cme-gap-mid { stroke: rgba(255,181,71,.58); stroke-width: 1; stroke-dasharray: 5 4; vector-effect: non-scaling-stroke; }
    .pro-chart-cme-layer .cme-gap-label { fill: #f7d58a; font-size: 11px; font-weight: 950; letter-spacing: .03em; paint-order: stroke; stroke: rgba(15,19,24,.88); stroke-width: 3px; }
    .pro-chart-cme-layer .filled { opacity: .34; }
    .pro-chart-whl-layer { position: absolute; inset: 0; z-index: 5; width: 100%; height: 100%; pointer-events: none; overflow: visible; }
    .pro-chart-whl-layer .whl-h { stroke: rgba(38,166,154,.95); stroke-width: 2; vector-effect: non-scaling-stroke; }
    .pro-chart-whl-layer .whl-l { stroke: rgba(239,83,80,.95); stroke-width: 2; vector-effect: non-scaling-stroke; }
    .pro-chart-side { min-width: 0; border-left: 1px solid #1e222d; background: #10161f; display: grid; grid-template-rows: auto minmax(0, 1fr); gap: 8px; padding: 8px; overflow: hidden; }
    .pro-chart-side-card { min-width: 0; min-height: 0; border: 1px solid #242c38; border-radius: 8px; background: #0d131b; overflow: hidden; }
    .pro-chart-side-head { height: 36px; padding: 0 10px; display: flex; align-items: center; justify-content: space-between; gap: 8px; border-bottom: 1px solid #1e222d; }
    .pro-chart-side-head span { color: #f2f5f8; font-size: 12px; font-weight: 950; text-transform: uppercase; letter-spacing: .04em; }
    .pro-chart-side-head small { color: rgba(255,255,255,.45); font-size: 11px; font-weight: 800; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .pro-chart-watchlist { display: grid; align-content: start; gap: 2px; padding: 6px; max-height: 100%; overflow-y: auto; scrollbar-width: thin; }
    .pro-chart-watch-row { width: 100%; min-width: 0; height: 34px; border: 1px solid transparent; border-radius: 6px; background: transparent; color: rgba(255,255,255,.74); display: grid; grid-template-columns: 18px minmax(0, 1fr) auto 20px; align-items: center; gap: 7px; padding: 0 4px 0 5px; cursor: pointer; font: inherit; text-align: left; }
    .pro-chart-watch-row:hover { background: #151b24; border-color: #2a2e39; color: #fff; }
    .pro-chart-watch-row.active { background: rgba(43,181,138,.14); border-color: rgba(43,181,138,.44); color: #f2f5f8; }
    .pro-chart-watch-row.dragging { opacity: .42; }
    .pro-chart-watch-row.drag-over { border-color: rgba(255,181,71,.72); background: rgba(255,181,71,.10); }
    .pro-chart-watch-row em { width: 18px; height: 22px; display: inline-flex; align-items: center; justify-content: center; color: rgba(255,255,255,.28); font-style: normal; font-size: 10px; letter-spacing: -2px; cursor: grab; }
    .pro-chart-watch-row em:active { cursor: grabbing; }
    .pro-chart-watch-row span { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: 12px; font-weight: 950; }
    .pro-chart-watch-row small { color: rgba(255,255,255,.42); font-size: 10px; font-weight: 850; }
    .pro-chart-watch-row i { width: 20px; height: 20px; border-radius: 5px; display: inline-flex; align-items: center; justify-content: center; color: rgba(255,255,255,.32); font-style: normal; font-size: 10px; font-weight: 900; }
    .pro-chart-watch-row i:hover { background: rgba(239,83,80,.16); color: rgba(255,214,212,.92); }
    .pro-chart-watch-empty { padding: 12px 10px; color: rgba(255,255,255,.48); font-size: 12px; line-height: 1.4; }
    .pro-chart-quote-card { padding-bottom: 10px; }
    .pro-chart-quote-price { padding: 12px 12px 0; color: #f2f5f8; font-size: 32px; line-height: 1; font-weight: 950; letter-spacing: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .pro-chart-quote-change { padding: 7px 12px 10px; font-size: 13px; font-weight: 900; }
    .pro-chart-quote-change.up { color: #26a69a; }
    .pro-chart-quote-change.down { color: #ef5350; }
    .pro-chart-quote-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; padding: 0 10px; }
    .pro-chart-quote-grid div { min-width: 0; border: 1px solid #202a36; border-radius: 6px; background: #111923; padding: 8px; }
    .pro-chart-quote-grid span { display: block; color: rgba(255,255,255,.42); font-size: 10px; font-weight: 900; text-transform: uppercase; letter-spacing: .05em; margin-bottom: 4px; }
    .pro-chart-quote-grid b { display: block; min-width: 0; color: rgba(255,255,255,.82); font-size: 12px; font-weight: 900; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    .pro-chart-quote-source { padding: 8px 12px 0; color: rgba(255,255,255,.38); font-size: 10px; font-weight: 800; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .pro-chart-indicator-pane a#tv-attr-logo { display: none !important; }
    .pro-chart-pane-resizer { display: none; flex: 0 0 8px; height: 8px; cursor: row-resize; background: #0f1318; border-top: 1px solid #1e222d; border-bottom: 1px solid #1e222d; position: relative; }
    .pro-chart-pane-resizer::before { content: ''; position: absolute; left: 50%; top: 50%; width: 46px; height: 2px; transform: translate(-50%, -50%); border-radius: 999px; background: rgba(255,255,255,.22); }
    .pro-chart-pane-resizer:hover::before { background: rgba(240,179,90,.75); }
    #proChartCanvas-rsi,
    #proChartCanvas-macd,
    #proChartCanvas-stochrsi {
      flex: 0 0 120px;
    }
    #proChartCanvas-vwrsi {
      flex: 0 0 140px;
    }
    .pro-chart-read { border-top: 1px solid #1e222d; background: #10161f; padding: 12px 16px; color: rgba(255,255,255,.7); font-size: 13px; line-height: 1.55; }
    .pro-chart-read strong { color: #f2f5f8; }
    .pro-chart-error { padding: 28px; text-align: center; color: #ef5350; font-size: 13px; line-height: 1.5; }
    .pro-chart-loading { padding: 28px; text-align: center; color: rgba(255,255,255,.55); font-size: 13px; }
    @media (max-width: 700px) {
      .pro-chart-modal { padding: 0; }
      .pro-chart-shell { min-height: 100vh; border-radius: 0; border-left: 0; border-right: 0; }
      .pro-chart-head { padding: 12px; }
      .pro-chart-symbol-row { position: relative; }
	      .pro-chart-symbol-row::after {
	        content: '';
	        position: sticky;
	        right: -1px;
        flex: 0 0 22px;
        align-self: stretch;
        pointer-events: none;
        background: linear-gradient(90deg, rgba(17,23,32,0), #111720 82%);
      }
	      .pro-chart-mainbar { align-items: flex-start; gap: 10px; overflow-x: auto; flex-wrap: nowrap; -webkit-overflow-scrolling: touch; }
	      .pro-chart-control-group { flex: 0 0 auto; }
	      .pro-chart-toolbar, .pro-chart-scalebar { flex-wrap: wrap; overflow-x: visible; gap: 7px; padding: 8px; }
	      .pro-chart-control-btn, .pro-chart-scale-btn { min-height: 30px; }
      .pro-chart-actionbar { grid-template-columns: 1fr; gap: 7px; padding: 8px; }
      .pro-chart-mtf-summary { min-width: 160px; }
      .pro-chart-narrative { max-height: 3.8em; overflow-y: auto; padding-right: 4px; }
      .pro-chart-actions { justify-content: flex-start; overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; }
      .pro-chart-actions::-webkit-scrollbar { display: none; }
      .pro-chart-compare-chips { flex: 0 0 auto; }
      .pro-chart-settings-grid { grid-template-columns: 1fr 1fr; }
      .pro-chart-compare input { width: 96px; }
      .pro-chart-panel { max-height: 34vh; overflow-y: auto; padding: 10px; }
      .pro-chart-panel-grid { grid-template-columns: 1fr; }
      .pro-chart-panel-card.wide { grid-column: auto; }
      .pro-chart-alert-form { grid-template-columns: 1fr; }
      .pro-chart-workspace-main { grid-template-columns: 1fr; grid-template-rows: auto minmax(0, 1fr); }
      .pro-chart-draw-rail { min-height: 38px; border-right: 0; border-bottom: 1px solid var(--pro-chart-rail-border, #1e222d); padding: 5px 8px; display: flex; flex-direction: row; align-items: center; gap: 6px; overflow-x: auto; scrollbar-width: none; }
      .pro-chart-draw-rail::-webkit-scrollbar { display: none; }
      .pro-chart-draw-rail button { flex: 0 0 auto; width: 36px; height: 28px; }
      .pro-chart-canvas { height: 64vh; min-height: 430px; }
      #claudeChatPanel {
        width: 100vw !important;
        max-width: 100vw !important;
        border-left: 0 !important;
      }
    }
    /* Social Pulse tweet cards */
    @keyframes fadeSlideIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
    .reveal-soft { animation: fadeSlideIn 0.6s ease-out forwards; }
    .social-pulse { margin-top: 16px; border-top: 1px solid var(--line); padding-top: 12px; }
    .social-pulse-title { font-size: 11px; font-weight: 600; color: var(--muted); text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 8px; }
    /* Inline tweet cards — woven into answer text */
    .inline-tweets { margin: 14px 0; display: flex; flex-direction: column; gap: 6px; }
    .inline-tweet {
      background: var(--panel-2); border: 1px solid var(--line); border-radius: 10px;
      padding: 9px 12px; text-decoration: none; display: flex; gap: 10px; color: inherit;
      transition: border-color .15s; font-size: 13px; line-height: 1.45; align-items: stretch;
    }
    .inline-tweet:hover { border-color: var(--accent); }
    .inline-tweet-media { width: auto; min-width: 60px; max-width: 90px; border-radius: 8px; object-fit: cover; flex-shrink: 0; background: var(--panel); align-self: stretch; }
    .inline-tweet-content { flex: 1; min-width: 0; }
    .inline-tweet-top { display: flex; align-items: center; gap: 5px; margin-bottom: 3px; }
    .inline-tweet-avatar { width: 18px; height: 18px; border-radius: 50%; background: var(--line); display: flex; align-items: center; justify-content: center; font-size: 10px; color: var(--muted); flex-shrink: 0; }
    .inline-tweet-name { font-weight: 600; font-size: 12px; color: var(--text); }
    .inline-tweet-handle { font-size: 11px; color: var(--muted); }
    .inline-tweet-body { color: var(--text); font-size: 14px; line-height: 1.45;
      display: -webkit-box; -webkit-line-clamp: 4; -webkit-box-orient: vertical; overflow: hidden; }
    .inline-tweet-meta { display: flex; gap: 10px; font-size: 10px; color: var(--muted); margin-top: 4px; }
    .inline-tweet-meta span { display: flex; align-items: center; gap: 2px; }
    .stream-answer p:last-child, .stream-answer div > p:last-child { margin-bottom: 0; }
    /* Article-style layout */
    .article-hero { margin: -12px -14px 0 -14px; margin-bottom: 16px; }
    .article-hero:empty { display: none; margin: 0; }
    .article-hero.title-only { margin-bottom: 4px; }
    .article-hero.title-only .hero-title { padding-bottom: 2px; }
    .hero-title {
      font-size: 20px; font-weight: 700; line-height: 1.3; color: var(--text);
      padding: 14px 14px 10px 14px;
    }
    .hero-image-wrap {
      position: relative; overflow: hidden; height: 240px;
      width: 100%; border-radius: 12px; background: #111;
    }
    .hero-image-wrap img {
      width: 100%; height: 100%; object-fit: cover; object-position: center 25%; display: block;
    }
    .hero-image-wrap.pillarbox img {
      width: auto; height: 100%; max-width: 80%; margin: 0 auto; object-fit: contain;
    }
    .hero-image-credit {
      position: absolute; bottom: 6px; right: 8px;
      font-size: 10px; color: rgba(255,255,255,0.7); background: rgba(0,0,0,0.45);
      padding: 2px 7px; border-radius: 4px; backdrop-filter: blur(4px);
    }
    .hero-image-wrap img[src=""] { display: none; }
    .hero-caption {
      text-align: center; font-style: italic; font-size: 13px; color: var(--muted);
      padding: 8px 14px 2px; line-height: 1.5;
    }
    /* Pull quote — CoinTelegraph-style big quote block */
    .pull-quote {
      margin: 20px 0; padding: 16px 20px 16px 24px; position: relative;
      border-left: 3px solid var(--accent); background: var(--panel-2);
      border-radius: 0 10px 10px 0;
    }
    .pull-quote::before {
      content: '\201C'; position: absolute; top: -8px; left: 8px;
      font-size: 48px; color: var(--accent); opacity: 0.3; font-family: Georgia, serif; line-height: 1;
    }
    .pull-quote-text {
      font-size: 17px; font-weight: 500; line-height: 1.5; color: var(--text);
      font-style: italic;
    }
    .pull-quote-attr {
      font-size: 12px; color: var(--muted); margin-top: 6px; font-style: normal;
    }
    /* Inline tweet with image */
    .inline-tweet-img {
      width: 100%; max-height: 200px; object-fit: cover; border-radius: 8px;
      margin-top: 6px;
    }
    /* Wikipedia-style infobox — floated right */
    .infobox {
      float: right; width: 180px; margin: 4px -4px 12px 14px;
      background: var(--panel-2); border: 1px solid var(--line); border-radius: 10px;
      overflow: hidden; font-size: 12px;
    }
    .infobox img { width: 100%; height: 120px; object-fit: cover; object-position: top; display: block; }
    .infobox-body { padding: 8px 10px; }
    .infobox-title { font-weight: 700; font-size: 13px; color: var(--text); margin-bottom: 4px; }
    .infobox-row { display: flex; justify-content: space-between; padding: 2px 0; color: var(--muted); }
    .infobox-row span:last-child { color: var(--text); font-weight: 500; }
    @media (max-width: 600px) {
      .article-hero { margin: -10px -10px 0 -10px; }
      .hero-title { font-size: 17px; padding: 10px 10px 8px 10px; }
      .hero-image-wrap { height: 180px; }
      .hero-image-wrap.pillarbox img { max-width: 90%; }
      .infobox { float: none; width: 100%; margin: 0 0 12px 0; }
      .infobox img { height: 140px; }
      .pull-quote { padding: 12px 14px 12px 18px; }
      .pull-quote-text { font-size: 15px; }
    }
    .pulse-cards { display: flex; flex-direction: column; gap: 8px; }
    .pulse-show-more { background: none; border: 1px solid var(--line); color: var(--muted); font-size: 12px; padding: 6px 14px; border-radius: 6px; cursor: pointer; margin-top: 6px; transition: all .15s; }
    .pulse-show-more:hover { color: var(--text); border-color: var(--accent); }
    .pulse-card {
      background: var(--panel-2); border: 1px solid var(--line); border-radius: 12px;
      padding: 10px 12px; cursor: pointer; transition: border-color .15s, transform .1s;
      text-decoration: none; display: block; color: inherit;
    }
    .pulse-card:hover { border-color: var(--accent); transform: translateY(-1px); }
    .pulse-card-header { display: flex; align-items: center; gap: 6px; margin-bottom: 4px; }
    .pulse-card-author { font-size: 13px; font-weight: 600; color: var(--text); }
    .pulse-card-handle { font-size: 12px; color: var(--muted); }
    .pulse-card-heat { font-size: 11px; margin-left: auto; }
    .pulse-card-body { display: flex; gap: 10px; align-items: flex-start; }
    .pulse-card-content { flex: 1; min-width: 0; }
    .pulse-card-img { width: 64px; height: 64px; border-radius: 8px; object-fit: cover; flex-shrink: 0; }
    .pulse-card-text { font-size: 15px; color: var(--text); line-height: 1.5; margin-bottom: 6px;
      display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
    .pulse-card-stats { display: flex; gap: 12px; font-size: 11px; color: var(--muted); }
    .pulse-card-stats span { display: flex; align-items: center; gap: 3px; }
    .pulse-card-list { font-size: 9px; color: var(--accent); opacity: 0.7; margin-left: auto; text-transform: uppercase; }

    /* ── PREDICTION MARKETS (ClashPicks) ── */
    .pred-markets { margin-top: 16px; border-top: 1px solid var(--line); padding-top: 12px; }
    .pred-markets-title { font-size: 11px; font-weight: 600; color: var(--muted); text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 8px; display: flex; align-items: center; gap: 6px; }
    .pred-markets-title img { width: 14px; height: 14px; border-radius: 3px; }
    .pred-cards { display: flex; flex-direction: column; gap: 8px; }
    .pred-card {
      display: flex; gap: 12px; align-items: center; padding: 12px 14px;
      background: var(--panel-2); border: 1px solid var(--line); border-radius: 12px;
      text-decoration: none; color: inherit; transition: border-color .15s, transform .15s;
    }
    .pred-card:hover { border-color: var(--accent); transform: translateY(-1px); }
    .pred-card-img { width: 44px; height: 44px; border-radius: 8px; object-fit: cover; flex-shrink: 0; background: var(--panel); }
    .pred-card-body { flex: 1; min-width: 0; }
    .pred-card-title { font-size: 14px; font-weight: 600; color: var(--text); line-height: 1.3; margin-bottom: 3px;
      display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
    .pred-card-meta { display: flex; gap: 10px; font-size: 12px; color: var(--muted); flex-wrap: wrap; }
    .pred-card-tag {
      font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em;
      padding: 2px 8px; border-radius: 4px; flex-shrink: 0; align-self: flex-start;
    }
    .pred-card-tag.matched { background: rgba(232,87,42,.15); color: var(--accent); }
    .pred-card-tag.hot { background: rgba(255,200,0,.15); color: #d4a843; }
    .pred-card-cta {
      font-size: 12px; font-weight: 600; color: var(--accent); white-space: nowrap;
      flex-shrink: 0; align-self: center;
    }

    .thumb-btn { background: none; border: 1px solid var(--line); border-radius: 8px; padding: 5px 10px; font-size: 14px; cursor: pointer; transition: all .15s; color: var(--muted); }
    .thumb-btn:hover { background: var(--panel-2); border-color: var(--accent); transform: scale(1.1); }
    .thumb-btn.voted-up   { background: #e8572a; border-color: #e8572a; transform: scale(1.15); box-shadow: 0 2px 12px rgba(232,87,42,.4); }
    .thumb-btn.voted-down { background: #c0392b; border-color: #c0392b; transform: scale(1.15); box-shadow: 0 2px 12px rgba(192,57,43,.4); }
    /* Feedback modal */
    #feedbackModal { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.55); z-index: 1000; align-items: center; justify-content: center; padding: 20px; }
    #feedbackModal.open { display: flex; }
    .feedback-modal-box { background: var(--panel); border: 1px solid var(--line); border-radius: 20px; padding: 24px; width: 100%; max-width: 420px; box-shadow: 0 20px 60px rgba(0,0,0,.3); }
    .feedback-modal-box h3 { margin: 0 0 6px; font-size: 17px; }
    .feedback-modal-box p { margin: 0 0 14px; font-size: 13px; color: var(--muted); }
    .feedback-modal-box textarea { width: 100%; min-height: 90px; resize: none; background: var(--panel-2); border: 1px solid var(--line); border-radius: 12px; padding: 12px; font-size: 14px; color: var(--text); font-family: inherit; outline: none; }
    .feedback-modal-box textarea:focus { border-color: var(--accent); }
    .feedback-modal-actions { display: flex; gap: 8px; margin-top: 12px; justify-content: flex-end; }
    .feedback-modal-actions button { border: none; border-radius: 10px; padding: 9px 18px; font-size: 14px; font-weight: 700; cursor: pointer; font-family: inherit; }
    .fbm-cancel { background: var(--panel-2); color: var(--muted); }
    .fbm-submit { background: var(--accent); color: #fff; }

    .mobile-tag { border: 1px solid var(--line); background: var(--panel-2); color: var(--text); border-radius: 20px; padding: 7px 12px; font-size: 12px; font-weight: 600; cursor: pointer; font-family: inherit; transition: background .15s; white-space: nowrap; }
    .mobile-tag:hover { background: var(--panel); border-color: var(--accent); }

    /* ── OLD CLASSES (kept for JS compat, hidden) ── */
    .pill { display: none; }
    .attach-btn { display: none; }
    .input-meta { display: none; }
    .hero { display: none; }

    /* ── HAMBURGER for mobile ── */
    .hamburger-btn {
      display: none; background: var(--panel-2); border: 1px solid var(--line); border-radius: 10px;
      color: var(--text); font-size: 18px; width: 36px; height: 36px; cursor: pointer;
      align-items: center; justify-content: center; flex-shrink: 0;
    }
    .sidebar-overlay {
      display: none; position: fixed; inset: 0; background: rgba(0,0,0,.12); z-index: 800;
    }
    .sidebar-overlay.open { display: block; }

    /* ── TABLET (sidebar collapses) ── */
    @media (max-width: 980px) {
      .sidebar {
        position: fixed; left: 0; top: 0; bottom: 0; z-index: 801;
        transform: translateX(-100%); width: 280px;
        box-shadow: 4px 0 20px rgba(0,0,0,.3);
      }
      .sidebar.open { transform: translateX(0); }
      .topbar {
        display: none;
      }
      .topbar-brand { display: inline-flex; }
      .hamburger-btn { display: none; }
      .app { flex-direction: column; }
      .mobile-bottom-nav {
        position: fixed; left: 0; right: 0; bottom: 0; z-index: 120;
        display: grid; grid-template-columns: repeat(6, minmax(0, 1fr)); gap: 2px;
        padding: 6px 9px max(6px, env(safe-area-inset-bottom, 0px));
        background: color-mix(in srgb, var(--bg) 88%, transparent);
        border-top: 1px solid var(--line);
        box-shadow: 0 -10px 30px rgba(0,0,0,.22);
        backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px);
      }
      .main, .discovery-page.visible, .answers-page.visible, .tools-page.visible, .portfolio-page.visible, .predictions-page.visible {
        padding-bottom: calc(84px + env(safe-area-inset-bottom, 0px));
      }
    }

    /* ── MOBILE ── */
    @media (max-width: 600px) {
      html, body { height: 100%; overflow: hidden; background: var(--bg); }
      .app { position: fixed; inset: 0; flex-direction: column; }
      .topbar {
        display: none;
      }
      .brand h1 { font-size: 16px; }
      .brand { gap: 8px; }
      .main { flex: 1; min-height: 0; display: flex; flex-direction: column; overflow: hidden; position: relative; }
      .main:has(.portfolio-page.visible), .main:has(.predictions-page.visible) { overflow: visible; }
      .portfolio-page.visible, .predictions-page.visible { position: absolute; inset: 0; z-index: 10; overflow-y: auto; -webkit-overflow-scrolling: touch; }
      .main-content { padding: 0 !important; flex: 1; min-height: 0; overflow-y: auto; display: flex; flex-direction: column; }
      .main-content.has-chat { padding-bottom: 0 !important; }
      .main-content:not(.has-chat) { justify-content: flex-start; align-items: center; padding: 2vh 12px calc(108px + env(safe-area-inset-bottom, 0px)) !important; }
      .main-content:not(.has-chat) > * { max-width: 100%; }
      .welcome { margin: 0 auto 6px; text-align: center; }
      .welcome-title { font-size: 28px; margin-bottom: 7px; font-weight: 500; line-height: 1.08; white-space: nowrap; }
      .welcome-title em { font-size: .96em; }
      .welcome-subtitle { font-size: 13px; line-height: 1.42; margin: 0 auto 10px; max-width: 340px; }
      .feature-row { grid-template-columns: 1fr; gap: 8px; }
      .discovery-preview { grid-template-columns: 1fr; gap: 10px; margin-top: 12px; }
      .feature-card { min-height: 82px; padding: 10px 12px; display: flex; flex-direction: column; justify-content: center; }
      .feature-card.glow { box-shadow: none; }
      .feature-name { font-size: 14px; margin-bottom: 3px; font-weight: 500; }
      .feature-desc { font-size: 12.5px; margin-bottom: 0; line-height: 1.35; }
      .disc-preview-pane { align-self: stretch; width: auto !important; max-width: none; margin-top: 14px; padding-bottom: calc(118px + env(safe-area-inset-bottom, 0px)); overflow: visible; }
      .home-v3 { gap: 16px; width: 100%; }
      .home-v3-twin, .home-agents-grid, .home-trends-grid, .home-module-grid { grid-template-columns: minmax(0, 1fr); }
      .home-briefing, .home-for-you-card, .home-intel-card, .home-watchlist, .home-agent-card, .home-trend-card, .home-module-card { width: 100%; max-width: 100%; min-width: 0; }
      .home-briefing, .home-for-you-card, .home-intel-card { min-height: 0; padding: 16px; }
      .home-briefing-title { font-size: 24px; line-height: 1.12; overflow-wrap: anywhere; word-break: normal; }
      .home-briefing-copy { font-size: 13px; line-height: 1.55; overflow-wrap: anywhere; word-break: normal; }
      .home-watchlist { padding: 14px; }
      .home-watchlist-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; }
      .home-watch-item { min-width: 0; }
      .home-briefing-foot, .home-for-you-foot, .home-intel-foot, .home-watchlist-foot { align-items: flex-start; flex-direction: column; gap: 8px; }
      .main-content:not(.has-chat) .composer {
        align-self: stretch; width: auto !important;
        margin-top: 22px; padding: 12px !important; gap: 0; max-width: none;
        border-radius: 16px; border: 1px solid var(--home-line-2); background: var(--home-panel);
      }
      .main-content:not(.has-chat) .input-container textarea {
        min-height: 56px; max-height: 110px; padding: 14px 58px 2px 6px;
        font-size: 15px; border-radius: 0; background: transparent; border: 0; box-shadow: none;
      }
      .main-content:not(.has-chat) #submit { right: 12px; top: 18px; bottom: auto; width: 36px; height: 36px; z-index: 2; }
      .chat { padding: 10px 16px 6px; gap: 8px; }
      .composer {
        padding: 8px 0 0 !important; gap: 4px; max-width: 100%;
      }
      .main-content.has-chat .composer {
        padding: 4px 12px 3px !important;
        padding-bottom: max(10px, env(safe-area-inset-bottom, 0px)) !important;
        position: fixed; bottom: calc(60px + env(safe-area-inset-bottom, 0px)); left: 0; right: 0; z-index: 50;
        background: var(--bg);
        border-top: 1px solid var(--line);
        max-width: 100%;
      }
      .main-content.has-chat .chat { padding-bottom: 112px; overflow-y: auto; min-height: 0; }
      .mode-row { gap: 6px; flex-wrap: nowrap; align-items: center; justify-content: center; overflow: visible; }
      .mode-toggle { display: flex !important; gap: 6px; flex-shrink: 0; }
      .mode-select-wrap { display: none !important; }
      .main-content.has-chat .mode-toggle { display: none !important; }
      .main-content.has-chat .mode-select-wrap { display: none !important; }
      .main-content.has-chat .mode-row {
        min-height: 18px;
        margin-top: 2px;
        justify-content: center;
        padding: 0;
      }
      .main-content.has-chat .mode-drawer-toggle {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 28px;
        height: 18px;
        padding: 0;
        border: 0;
        border-radius: 999px;
        background: transparent;
        color: var(--muted);
        font-size: 18px;
        line-height: 1;
        cursor: pointer;
      }
      .main-content.has-chat .mode-row.mode-drawer-open {
        min-height: 58px;
        align-items: flex-end;
        gap: 8px;
      }
      .main-content.has-chat .mode-row.mode-drawer-open .mode-toggle {
        display: flex !important;
        position: absolute;
        left: 50%;
        bottom: 22px;
        transform: translateX(-50%);
        padding: 5px;
        border: 1px solid var(--line);
        border-radius: 999px;
        background: color-mix(in srgb, var(--bg) 94%, transparent);
        box-shadow: 0 10px 28px rgba(0,0,0,.28);
      }
      .main-content.has-chat .mode-row.mode-drawer-open .mode-drawer-toggle {
        transform: rotate(180deg);
        color: var(--accent);
      }
      .mode-btn { padding: 9px 14px; font-size: 13px; flex-shrink: 0; }
      .mode-btn-icon { display: none; }
      .tools-dropdown summary { padding: 9px 14px; font-size: 13px; }
      .tools-popover {
        position: fixed;
        left: 12px;
        right: 12px;
        bottom: auto;
        top: max(12px, env(safe-area-inset-top, 0px));
        transform: none;
        width: auto;
        max-height: calc(100dvh - 128px - env(safe-area-inset-bottom, 0px));
        overflow-y: auto;
      }
      .tools-popover::after { display: none; }
      .feature-pill { padding: 9px 10px; flex-shrink: 0; }
      .feature-pill-label { font-size: 14px; font-weight: 700; }
      .feature-pill-icon { font-size: 16px; }
      .sports-toggle-wrap { display: none; }
      .mode-description { display: none; }
      .input-wrap { gap: 0; align-items: center; }
      .input-container textarea { min-height: 58px; max-height: 110px; padding: 16px 72px 16px 18px; font-size: 15px; border-radius: 26px; }
      .input-actions { right: 58px; bottom: 17px; }
      #submit { right: 8px; bottom: 8px; width: 42px; height: 42px; }
      .main-content.has-chat #submit { top: 33px !important; right: 18px !important; bottom: auto !important; transform: translateY(-50%) !important; }
      #submit::before { font-size: 21px; }
      #submit:not(:empty) { min-width: 42px; padding: 0; font-size: 0; }
      .main-content:not(.has-chat) .composer {
        align-self: stretch; width: auto !important; padding: 12px !important;
        border: 1px solid var(--home-line-2); border-radius: 16px; background: var(--home-panel);
      }
      .main-content:not(.has-chat) .input-container textarea {
        min-height: 56px; max-height: 110px; padding: 14px 58px 2px 6px;
        font-size: 15px; border-radius: 0; background: transparent; border: 0; box-shadow: none;
      }
      .main-content:not(.has-chat) #submit { right: 12px; top: 18px; bottom: auto; width: 36px; height: 36px; z-index: 2; }
      .main-content:not(.has-chat) #submit::before { font-size: 18px; }
      .message { gap: 0; }
      .bubble { padding: 8px 0; max-width: 100%; }
      .bubble p { font-size: 14px; line-height: 1.5; }
      .stage { padding: 7px 9px; border-radius: 9px; }
      .stage p { font-size: 14px; }
      .tag { font-size: 11px; padding: 3px 10px; }
      .stage-grid { gap: 5px; }
      .expand-btn { padding: 3px 7px; font-size: 10px; margin-top: 5px; }
      .query-result { max-width: 100% !important; }
      .discovery-page.visible, .answers-page.visible, .tools-page.visible, .portfolio-page.visible, .predictions-page.visible {
        padding-bottom: calc(108px + env(safe-area-inset-bottom, 0px));
        scroll-padding-bottom: calc(108px + env(safe-area-inset-bottom, 0px));
      }
      .disc-header { padding: 10px 14px 9px; }
      .lane-mag, .disc-mag { padding-bottom: calc(118px + env(safe-area-inset-bottom, 0px)) !important; }
      .disc-mag-cover > .disc-mag-lead .disc-mag-visual,
      .lane-mag-visual,
      .disc-mag-visual {
        height: min(220px, 25vh);
        max-height: 220px;
        min-height: 132px;
      }
      .disc-mag-cover > .disc-mag-lead .disc-mag-body { padding: 14px 16px 18px; }
      .lane-mag-body, .disc-mag-body { padding: 16px; }
      .lane-mag-headline, .disc-mag-headline { font-size: 23px; }
      .sidebar.open .sidebar-subtopics:not(.open) { display: none; }
      .sidebar.open .sidebar-nav { gap: 4px; }
      .sidebar {
        height: 100dvh;
        max-height: 100dvh;
      }
      .sidebar-top {
        padding-top: max(14px, env(safe-area-inset-top, 0px));
      }
    }

    @media (max-width: 980px) {
      .main-content:not(.has-chat) {
        align-items: stretch !important;
        padding-left: 12px !important;
        padding-right: 12px !important;
        padding-bottom: calc(118px + env(safe-area-inset-bottom, 0px)) !important;
      }
      .main-content:not(.has-chat) .welcome {
        align-self: center;
        max-width: min(100%, 520px);
      }
      .main-content:not(.has-chat) .composer,
      .main-content:not(.has-chat) .disc-preview-pane {
        align-self: center;
        width: min(100%, 760px) !important;
        max-width: 100% !important;
      }
      .main-content:not(.has-chat) .home-v3,
      .main-content:not(.has-chat) .home-v3-section,
      .main-content:not(.has-chat) .home-v3-twin {
        width: 100%;
        max-width: 100%;
        min-width: 0;
      }
      .main-content:not(.has-chat) .home-v3-twin,
      .main-content:not(.has-chat) .home-agents-grid,
      .main-content:not(.has-chat) .home-trends-grid {
        grid-template-columns: minmax(0, 1fr);
      }
      .main-content:not(.has-chat) .home-briefing,
      .main-content:not(.has-chat) .home-for-you-card,
      .main-content:not(.has-chat) .home-intel-card,
      .main-content:not(.has-chat) .home-watchlist,
      .main-content:not(.has-chat) .home-agent-card,
      .main-content:not(.has-chat) .home-trend-card {
        width: 100%;
        max-width: 100%;
        min-width: 0;
        overflow: hidden;
      }
      .main-content:not(.has-chat) .home-briefing-title,
      .main-content:not(.has-chat) .home-briefing-copy {
        white-space: normal;
        overflow-wrap: anywhere;
      }
      .main-content:not(.has-chat) #submit {
        right: 12px;
        top: 18px;
        bottom: auto;
        width: 36px;
        height: 36px;
        z-index: 2;
      }
    }

    @media (max-width: 980px) and (max-height: 900px) {
      .main-content:not(.has-chat) .composer,
      .main-content:not(.has-chat) .disc-preview-pane {
        align-self: center;
        width: min(calc(100vw - 48px), 366px) !important;
        max-width: min(calc(100vw - 48px), 366px) !important;
        margin-left: auto;
        margin-right: auto;
      }
      .main-content:not(.has-chat) .home-briefing-title {
        font-size: 23px;
        line-height: 1.12;
      }
    }

    @media (max-width: 980px) {
      .main-content:not(.has-chat) .composer,
      .main-content:not(.has-chat) .disc-preview-pane {
        width: min(calc(100vw - 48px), 760px) !important;
        max-width: min(calc(100vw - 48px), 760px) !important;
        margin-left: auto !important;
        margin-right: auto !important;
      }
    }

    /* ── ADMIN DRAWER COMPONENTS ── */
    .dtab {
      flex:1; padding:11px 4px; font-size:11px; font-weight:700; letter-spacing:.06em;
      text-transform:uppercase; border:none; background:none; color:var(--muted); cursor:pointer;
      border-bottom:2px solid transparent; transition:all .15s; font-family:inherit;
    }
    .dtab.active  { color:#FF4500; border-bottom-color:#FF4500; }
    .dtab:hover:not(.active) { color:var(--text); }

    .dsubtab {
      padding:5px 14px; border-radius:20px; font-size:11px; font-weight:700;
      border:1px solid var(--line); background:none; color:var(--muted); cursor:pointer;
      transition:all .15s; font-family:inherit;
    }
    .dsubtab.active { border-color:#FF4500; color:#FF4500; background:rgba(255,69,0,.1); }

    .dfbtn {
      padding:4px 12px; border-radius:20px; font-size:11px; font-weight:700;
      border:1px solid var(--line); background:none; color:var(--muted); cursor:pointer;
      transition:all .15s; font-family:inherit;
    }
    .dfbtn.active, .dfbtn:hover { border-color:#FF4500; color:#FF4500; background:rgba(255,69,0,.08); }

    .drefresh {
      background:none; border:1px solid var(--line); border-radius:6px;
      padding:4px 12px; font-size:11px; font-weight:600; color:var(--muted);
      cursor:pointer; font-family:inherit;
    }
    .drefresh:hover { color:var(--text); border-color:var(--accent); }

    .dpanel { display:block; }
    .dloading { text-align:center; color:var(--muted); font-size:12px; padding:32px 0; }
    .dempty   { text-align:center; color:var(--muted); font-size:13px; padding:40px 0; }

    .dcard {
      background:var(--panel-2); border:1px solid var(--line);
      border-radius:10px; padding:12px 10px; text-align:center;
    }
    .dcard.win    { background:rgba(34,197,94,.1);  border-color:rgba(34,197,94,.25); }
    .dcard.loss   { background:rgba(255,107,107,.1); border-color:rgba(255,107,107,.25); }
    .dcard.accent { background:rgba(255,69,0,.1);   border-color:rgba(255,69,0,.25); }
    .dnum { font-size:24px; font-weight:800; line-height:1; margin-bottom:3px; color:var(--text); }
    .dcard.win  .dnum { color:#22c55e; }
    .dcard.loss .dnum { color:#ff6b6b; }
    .dcard.accent .dnum { color:#FF4500; }
    .dlbl { font-size:9px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); }

    .dsection-title {
      font-size:10px; font-weight:700; letter-spacing:.12em; text-transform:uppercase;
      color:#FF4500; margin:14px 0 7px;
    }
    .drow {
      display:flex; justify-content:space-between; align-items:center;
      padding:7px 0; border-bottom:1px solid var(--line); font-size:12px;
    }
    .drow:last-child { border-bottom:none; }
    .drow-val { font-weight:700; color:var(--text); }
    .dbar-label { display:flex; justify-content:space-between; font-size:11px; color:var(--muted); margin-bottom:3px; }
    .dbar-track { height:5px; background:var(--panel-2); border-radius:3px; overflow:hidden; margin-bottom:8px; border:1px solid var(--line); }
    .dbar-fill  { height:100%; background:#FF4500; border-radius:3px; }

    .pred-row {
      background:var(--panel-2); border:1px solid var(--line);
      border-radius:10px; padding:11px 13px; margin-bottom:7px;
    }
    .pred-row.win-r  { border-left:3px solid #22c55e; }
    .pred-row.loss-r { border-left:3px solid #ff6b6b; }
    .pred-row.push-r { border-left:3px solid #ffcc66; }
    .pred-q    { font-size:11px; color:var(--muted); margin-bottom:6px; line-height:1.4; }
    .pred-pick { font-size:14px; font-weight:800; color:var(--text); }
    .pred-meta { display:flex; gap:5px; align-items:center; flex-wrap:wrap; margin-bottom:7px; }
    .pmb {
      font-size:9px; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
      padding:2px 7px; border-radius:4px; background:var(--panel); border:1px solid var(--line); color:var(--muted);
    }
    .pmb.play { background:rgba(34,197,94,.12);  color:#22c55e; border-color:rgba(34,197,94,.3); }
    .pmb.lean { background:rgba(255,204,102,.12); color:#ffcc66; border-color:rgba(255,204,102,.3); }
    .pred-btns { display:flex; gap:5px; flex-wrap:wrap; align-items:center; }
    .pgb {
      padding:5px 11px; border-radius:6px; font-size:11px; font-weight:700;
      border:1px solid var(--line); background:var(--panel);
      color:var(--muted); cursor:pointer; transition:all .15s; font-family:inherit;
    }
    .pgb.win  { background:rgba(34,197,94,.12);  color:#22c55e;  border-color:rgba(34,197,94,.3); }
    .pgb.loss { background:rgba(255,107,107,.12); color:#ff6b6b;  border-color:rgba(255,107,107,.3); }
    .pgb.push { background:rgba(255,204,102,.12); color:#ffcc66;  border-color:rgba(255,204,102,.3); }
    .pgb.clr  { font-size:10px; padding:3px 8px; }
    .ochip {
      font-size:11px; font-weight:800; letter-spacing:.08em; padding:4px 10px; border-radius:6px;
    }
    .ochip.WIN  { background:rgba(34,197,94,.15);  color:#22c55e; }
    .ochip.LOSS { background:rgba(255,107,107,.15); color:#ff6b6b; }
    .ochip.PUSH { background:rgba(255,204,102,.15); color:#ffcc66; }
    .pnotes {
      flex:1; min-width:0; padding:5px 9px; border-radius:6px;
      border:1px solid var(--line); background:var(--panel);
      color:var(--text); font-size:11px; font-family:inherit; outline:none; resize:none;
    }
    .pnotes:focus { border-color:#FF4500; }

    .fb-row {
      background:var(--panel-2); border:1px solid var(--line);
      border-radius:10px; padding:11px 13px; margin-bottom:7px;
    }
    .fb-row.down { border-left:3px solid #ff6b6b; }
    .fb-row.up   { border-left:3px solid #22c55e; }
    .fb-row:hover { background:var(--card); }
    .fb-q        { font-size:11px; color:var(--muted); margin-bottom:5px; }
    .fb-comment  { font-size:12px; color:var(--text); background:var(--panel); border:1px solid var(--line); border-radius:6px; padding:6px 10px; }
    .fb-detail.fb-open { display:block !important; }

@media (max-width: 600px) {
  html, body, .app, .layout, .main, .main-content {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden !important;
  }

  .main-content:not(.has-chat) {
    padding-top: 3.5vh !important;
  }

  .home-hero-block {
    margin-bottom: 18px !important;
  }

  .composer {
    margin-bottom: 12px !important;
  }

  .main-content:not(.has-chat) {
    align-items: stretch !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
    padding-bottom: calc(84px + env(safe-area-inset-bottom, 0px)) !important;
  }

  .main-content:not(.has-chat) .disc-preview-pane {
    align-self: stretch !important;
    width: calc(100vw - 48px) !important;
    max-width: calc(100vw - 48px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    overflow: visible !important;
    padding-bottom: 10px !important;
  }

  .main-content:not(.has-chat) .composer {
    width: calc(100vw - 48px) !important;
    max-width: calc(100vw - 48px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    box-sizing: border-box !important;
  }

  .main-content:not(.has-chat) .home-v3 {
    width: 100% !important;
    max-width: 100% !important;
    padding-bottom: 0;
  }

  .main-content:not(.has-chat) .home-v3-section,
  .main-content:not(.has-chat) .home-v3-twin,
  .main-content:not(.has-chat) .home-briefing,
  .main-content:not(.has-chat) .home-for-you-card,
  .main-content:not(.has-chat) .home-intel-card,
  .main-content:not(.has-chat) .home-watchlist {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }

  .main-content:not(.has-chat) .home-briefing-title,
  .main-content:not(.has-chat) .home-briefing-copy,
  .main-content:not(.has-chat) .home-intel-title,
  .main-content:not(.has-chat) .home-intel-copy,
  .main-content:not(.has-chat) .home-watchlist-title,
  .main-content:not(.has-chat) .home-watchlist-copy,
  .welcome-subtitle {
    white-space: normal !important;
    overflow-wrap: anywhere;
  }

  .input-wrap,
  .input-container {
    width: 100%;
    min-width: 0;
  }

  .main-content:not(.has-chat) #submit {
    right: 12px !important;
    top: 18px !important;
    bottom: auto !important;
    width: 34px !important;
    height: 34px !important;
    z-index: 2 !important;
  }
  .main-content:not(.has-chat) #submit::before { font-size: 16px !important; }

  .main-content:not(.has-chat) .home-intel-tools {
    grid-template-columns: 1fr;
  }

  .main-content:not(.has-chat) .home-intel-tools button {
    min-width: 0;
  }

  .main-content:not(.has-chat) .home-intel-bubble.sol {
    right: 18px;
  }

  .main-content:not(.has-chat) .home-intel-bubble.xrp {
    display: none;
  }

  /*
   * Mobile browsers, especially Telegram/Safari webviews, are brittle when the
   * whole SPA is fixed and the only scrollable area is a nested flex child.
   * Let the document own vertical scrolling on phones; keep only nav/composer
   * fixed where needed.
   */
  html,
  body {
    height: auto !important;
    min-height: 100% !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
  }

  .app {
    position: relative !important;
    height: auto !important;
    min-height: 100dvh !important;
    overflow: visible !important;
  }

  .main {
    min-height: calc(100dvh - 40px);
    overflow: visible !important;
  }

  .main-content {
    height: auto !important;
    min-height: calc(100dvh - 40px);
    overflow-y: visible !important;
    -webkit-overflow-scrolling: auto;
  }

  .main-content.has-chat .chat {
    overflow-y: visible !important;
  }

  .discovery-page.visible,
  .answers-page.visible,
  .tools-page.visible,
  .portfolio-page.visible,
  .predictions-page.visible {
    height: auto !important;
    min-height: calc(100dvh - 40px);
    overflow-y: visible !important;
  }

  .portfolio-page.visible,
  .predictions-page.visible {
    position: relative !important;
    inset: auto !important;
  }

  .predictions-page.visible {
    width: 100vw !important;
    max-width: 100vw !important;
    overflow-x: hidden !important;
  }

  .predictions-page .pm-header,
  .predictions-page .pm-markets {
    width: 100vw !important;
    max-width: 100vw !important;
    box-sizing: border-box;
  }

  .predictions-page .pm-events-grid,
  .predictions-page .pm-event-link {
    box-sizing: border-box;
  }

  .predictions-page .pm-events-grid {
    width: calc(100vw - 24px) !important;
    max-width: calc(100vw - 24px) !important;
  }

  .predictions-page .pm-event-link {
    width: 100% !important;
    max-width: 100% !important;
  }

  .predictions-page .pm-category-pills {
    max-width: 100%;
  }

  .predictions-page .pm-ai-predict {
    min-width: 0;
    box-sizing: border-box;
  }

  .predictions-page .pm-event-volume,
  .predictions-page .pm-event-bottom {
    min-width: 0;
    overflow: hidden;
  }

  .main-content:not(.has-chat) #submit {
    right: 12px !important;
    top: 18px !important;
    bottom: auto !important;
    width: 34px !important;
    height: 34px !important;
    z-index: 2 !important;
  }
  .main-content:not(.has-chat) #submit::before { font-size: 16px !important; }

  .main-content.has-chat .composer {
    bottom: calc(60px + env(safe-area-inset-bottom, 0px)) !important;
    margin-bottom: 0 !important;
    background: var(--bg) !important;
    box-shadow: 0 -6px 16px rgba(0,0,0,.24);
    box-sizing: border-box !important;
  }

  .main-content.has-chat #submit {
    right: 18px !important;
    top: 33px !important;
    bottom: auto !important;
    transform: translateY(-50%) !important;
    width: 40px !important;
    height: 40px !important;
    z-index: 2 !important;
  }
  .main-content.has-chat #submit:active {
    transform: translateY(-50%) scale(.97) !important;
  }

  .main-content.has-chat .composer::after {
    content: '';
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    height: calc(54px + env(safe-area-inset-bottom, 0px));
    background: var(--bg);
    z-index: -1;
  }

  #toolsPage.visible .tools-tabs,
  .discovery-page.visible .disc-categories-wrap {
    position: fixed !important;
    left: 8px !important;
    right: 8px !important;
    bottom: calc(62px + env(safe-area-inset-bottom, 0px)) !important;
    z-index: 118;
    width: auto !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 6px !important;
    border: 1px solid var(--line);
    border-radius: 16px;
    background: color-mix(in srgb, var(--bg) 92%, transparent);
    box-shadow: 0 -10px 26px rgba(0,0,0,.30);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    overflow-x: auto !important;
    overflow-y: hidden !important;
    scrollbar-width: none;
  }

  #toolsPage.visible .tools-tabs::-webkit-scrollbar,
  .discovery-page.visible .disc-categories-wrap::-webkit-scrollbar,
  .discovery-page.visible .disc-categories-top::-webkit-scrollbar {
    display: none;
  }

  #toolsPage.visible .tools-tabs {
    display: flex !important;
    gap: 6px !important;
  }

  #toolsPage.visible .tools-tabs::before,
  .discovery-page.visible .disc-categories-wrap::before {
    content: 'Swipe';
    flex: 0 0 auto;
    align-self: center;
    color: var(--muted);
    border: 1px solid var(--line);
    border-radius: 999px;
    padding: 6px 8px;
    font-size: 9px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
    background: var(--panel);
  }

  #toolsPage.visible .tools-tabs .disc-pill {
    padding: 7px 10px !important;
    font-size: 10.5px !important;
    flex: 0 0 auto;
  }

  .discovery-page.visible .disc-categories-top {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 6px !important;
    padding: 0 !important;
    overflow: visible !important;
    max-width: none !important;
    width: max-content !important;
    scroll-snap-type: none !important;
  }

  .discovery-page.visible .disc-category-tab {
    flex: 0 0 auto;
    width: auto !important;
    min-width: 72px !important;
    min-height: 34px !important;
    padding: 7px 9px !important;
  }

  .discovery-page.visible .disc-category-label {
    font-size: 9.5px !important;
  }

  .disc-categories-wrap {
    width: 100% !important;
    max-width: none !important;
    margin: 0 0 16px !important;
    overflow: visible !important;
  }

  .disc-categories-wrap::before,
  .disc-categories-wrap::after {
    display: none !important;
  }

  .disc-categories-top {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px !important;
    max-width: none !important;
    overflow: visible !important;
    padding: 0 !important;
    scroll-snap-type: none !important;
  }

  .disc-category-tab {
    justify-content: center;
    width: 100% !important;
    min-width: 0 !important;
    min-height: 38px !important;
    padding: 8px 6px !important;
  }

  .disc-category-label {
    justify-content: center;
    gap: 5px !important;
    font-size: 9.5px !important;
    white-space: nowrap;
  }

  .disc-category-label .app-icon {
    width: 14px;
    height: 14px;
  }

  .disc-mag-cover > .disc-mag-lead .disc-mag-visual {
    height: 124px !important;
    margin: 9px 9px 0 !important;
  }

  .disc-mag-cover > .disc-mag-lead .disc-mag-body {
    padding: 13px 16px 16px !important;
  }

  .disc-mag-cover > .disc-mag-lead {
    min-height: 0 !important;
  }

  .disc-mag-headline {
    font-size: 22px !important;
    line-height: 1.08 !important;
  }

  .disc-mag-excerpt {
    font-size: 14px !important;
    line-height: 1.42 !important;
  }

  .disc-mag-rail .disc-mag-rail-item,
  .lane-mag-rail .lane-mag-rail-item {
    min-height: 78px;
  }

  .tools-pm-card,
  .tools-alt-meter {
    margin-bottom: 14px;
  }

  .tools-pm-card {
    padding: 14px;
  }

  .tools-alt-sub,
  .tools-pm-copy {
    font-size: 12px;
    line-height: 1.4;
  }

  .tools-alt-stat {
    padding: 9px 10px;
  }

  #toolsContent {
    width: 100vw !important;
    max-width: 100vw !important;
    padding-left: 14px !important;
    padding-right: 14px !important;
    padding-bottom: calc(164px + env(safe-area-inset-bottom, 0px)) !important;
  }

  .answers-page .disc-header,
  #answersPage .disc-header,
  #toolsPage .disc-header {
    padding-bottom: 8px;
  }

  #answersPage .disc-header-top,
  #toolsPage .disc-header-top {
    flex-wrap: wrap;
    align-items: center;
    gap: 8px 12px;
    margin-bottom: 10px;
  }

  #toolsPage.visible .tools-tabs,
  .discovery-page.visible .disc-categories-wrap {
    position: fixed !important;
    left: 8px !important;
    right: 8px !important;
    bottom: calc(62px + env(safe-area-inset-bottom, 0px)) !important;
    z-index: 118 !important;
    display: flex !important;
    gap: 6px !important;
    width: auto !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 6px !important;
    border: 1px solid var(--line) !important;
    border-radius: 16px !important;
    background: color-mix(in srgb, var(--bg) 92%, transparent) !important;
    box-shadow: 0 -10px 26px rgba(0,0,0,.30) !important;
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    overflow-x: auto !important;
    overflow-y: hidden !important;
    scrollbar-width: none;
  }

  #toolsPage.visible .tools-tabs::before,
  .discovery-page.visible .disc-categories-wrap::before {
    content: 'Swipe' !important;
    display: inline-flex !important;
    flex: 0 0 auto;
    align-self: center;
    color: var(--muted);
    border: 1px solid var(--line);
    border-radius: 999px;
    padding: 6px 8px;
    font-size: 9px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
    background: var(--panel);
  }

  .discovery-page.visible .disc-categories-wrap::after {
    display: none !important;
  }

  .discovery-page.visible .disc-categories-top {
    display: flex !important;
    flex-wrap: nowrap !important;
    grid-template-columns: none !important;
    gap: 6px !important;
    width: max-content !important;
    max-width: none !important;
    padding: 0 !important;
    overflow: visible !important;
  }

  .discovery-page.visible .disc-category-tab {
    width: auto !important;
    min-width: 72px !important;
    min-height: 34px !important;
    flex: 0 0 auto !important;
    padding: 7px 9px !important;
  }

  #toolsPage.visible .tools-tabs .disc-pill {
    flex: 0 0 auto !important;
    padding: 7px 10px !important;
    font-size: 10.5px !important;
  }

  .discovery-page.visible .disc-feed,
  .discovery-page.visible .disc-mag,
  .discovery-page.visible .lane-mag {
    padding-bottom: calc(164px + env(safe-area-inset-bottom, 0px)) !important;
  }

  .tools-etf-chart-card,
  .tools-treasury-mstr-card,
  .tools-treasury-donut-card {
    overflow: hidden;
  }

  .tools-etf-summary,
  .tools-treasury-summary {
    grid-template-columns: 1fr !important;
  }

  .tools-etf-controls {
    width: 100%;
    max-width: 100%;
  }

  .tools-etf-assets {
    width: 100% !important;
    max-width: 100% !important;
  }

  .tools-etf-ranges {
    width: 100%;
    max-width: 100% !important;
  }

  .tools-etf-chart-top {
    flex-direction: column;
    align-items: stretch;
  }

  .tools-etf-chart-actions {
    justify-content: space-between;
    width: 100%;
  }

  .tools-etf-chart {
    height: 260px !important;
    min-width: 0;
  }

  .tools-treasury-mstr-stats span {
    max-width: 100%;
    white-space: normal;
    line-height: 1.2;
  }

  .tools-treasury-segment {
    border-radius: 12px;
  }

  .tools-treasury-mstr-chart {
    height: 258px !important;
    max-width: 100%;
  }

  .tools-treasury-pie {
    max-width: 100%;
  }

  .chart-modal {
    padding: 8px !important;
    overflow: auto !important;
  }

  .chart-modal > div {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 auto !important;
    padding: 10px !important;
    border-radius: 10px !important;
  }

  .chart-modal svg {
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
  }

  .pro-chart-modal {
    padding: 0 !important;
    overflow: hidden !important;
  }

  .pro-chart-shell {
    width: 100vw !important;
    height: 100dvh !important;
    min-height: 100dvh !important;
    border-radius: 0 !important;
    border-left: 0 !important;
    border-right: 0 !important;
    display: flex;
    flex-direction: column;
  }

  .pro-chart-head {
    padding: 9px 58px 9px 10px !important;
    flex-shrink: 0;
    gap: 8px;
    overflow: hidden;
  }

  .pro-chart-close {
    top: 9px;
    left: calc(100vw - 50px);
    width: 40px;
    height: 34px;
    padding: 0 !important;
    font-size: 0;
  }

  .pro-chart-close::before {
    content: 'X';
    font-size: 13px;
  }

  .pro-chart-head-left {
    min-width: 0;
    width: 100%;
  }

  .pro-chart-symbol-row {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 7px;
    margin-bottom: 6px;
    min-width: 0;
  }

  .pro-chart-search {
    min-width: 0;
    width: 100%;
    flex-basis: auto;
  }

  .pro-chart-watch-add {
    grid-column: 1 / -1;
    width: max-content;
  }

  .pro-chart-quick {
    grid-column: 1 / -1;
    width: 100%;
    max-width: 100%;
  }

  .pro-chart-title {
    display: none !important;
    font-size: 15px;
  }

  .pro-chart-sub {
    display: none !important;
    font-size: 10.5px;
    gap: 5px;
  }

	  .pro-chart-mainbar {
	    padding: 6px 8px !important;
	    overflow-x: auto;
	    flex-wrap: wrap !important;
	    flex-shrink: 0;
	    scrollbar-width: none;
	  }

	  .pro-chart-toolbar,
	  .pro-chart-scalebar {
	    padding: 6px 8px !important;
	    overflow-x: auto;
	    flex-wrap: nowrap !important;
	    flex-shrink: 0;
	    scrollbar-width: none;
	  }

  .pro-chart-actionbar {
    display: flex;
    justify-content: flex-start;
    gap: 6px;
    padding: 7px 8px !important;
    flex-shrink: 0;
  }

  .pro-chart-narrative {
    font-size: 11px;
    line-height: 1.3;
  }

  .pro-chart-actions {
    justify-content: flex-start;
    overflow-x: auto;
    flex-wrap: nowrap;
    scrollbar-width: none;
    flex: 0 0 auto;
  }

  .pro-chart-actions::-webkit-scrollbar {
    display: none;
  }

  .pro-chart-compare input {
    width: 92px;
  }

  .pro-chart-panel {
    max-height: 32dvh;
    overflow-y: auto;
    padding: 9px !important;
    flex-shrink: 0;
  }

  .pro-chart-panel-grid {
    grid-template-columns: 1fr;
  }

  .pro-chart-mainbar::-webkit-scrollbar,
  .pro-chart-toolbar::-webkit-scrollbar,
  .pro-chart-scalebar::-webkit-scrollbar {
    display: none;
  }

  .pro-chart-body {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
  }

  .pro-chart-workspace-main {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    min-height: 0;
  }

  .pro-chart-draw-rail {
    flex: 0 0 auto;
    min-height: 38px;
    border-right: 0;
    border-bottom: 1px solid #1e222d;
    padding: 5px 8px;
    display: flex;
    align-items: center;
    gap: 6px;
    overflow-x: auto;
    scrollbar-width: none;
  }

  .pro-chart-draw-rail::-webkit-scrollbar {
    display: none;
  }

  .pro-chart-draw-rail button {
    flex: 0 0 auto;
    width: 36px;
    height: 28px;
  }

  .pro-chart-side {
    display: none !important;
  }

  .pro-chart-canvas {
    flex: 1 1 0;
    height: auto !important;
    min-height: 0 !important;
  }

	  #proChartCanvas-rsi,
	  #proChartCanvas-macd,
	  #proChartCanvas-stochrsi {
	    height: 84px !important;
	    flex: 0 0 84px;
	  }

	  #proChartCanvas-vwrsi {
	    height: 96px !important;
	    flex: 0 0 96px;
	  }

  .pro-chart-read {
    max-height: 94px;
    overflow-y: auto;
    flex-shrink: 0;
    padding: 9px 10px !important;
    font-size: 12px;
  }

  #answersPage .disc-header-top > div:first-child,
  #toolsPage .disc-header-top > div:first-child {
    display: contents;
  }

  #answersPage .disc-title,
  #toolsPage .disc-title {
    flex: 1 1 auto;
    min-width: 0;
    order: 1;
  }

  #answersPage .disc-header-right,
  #toolsPage .disc-header-right {
    flex: 0 0 auto;
    align-self: center;
    order: 2;
  }

  #answersPage .disc-sub,
  #toolsPage .disc-sub {
    flex: 0 0 100%;
    max-width: none;
    margin-top: 0;
    order: 3;
  }

  .answers-grid .disc-item {
    min-height: 0 !important;
  }

  .answers-photo {
    aspect-ratio: 1 / .48 !important;
    margin-bottom: 10px !important;
  }

  .answers-card .disc-item-excerpt {
    -webkit-line-clamp: 3 !important;
  }

  .pf-hero-top {
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
  }

  .pf-hero-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    width: 100%;
    gap: 8px;
    padding-top: 0;
  }

  .pf-hero-actions > button {
    justify-content: center;
    width: 100%;
    min-width: 0;
    padding-left: 8px !important;
    padding-right: 8px !important;
    font-size: 11px !important;
    white-space: nowrap;
  }

  .pf-share-btn,
  .pf-stealth-btn,
  .pf-back-btn {
    min-height: 36px;
  }

  .pf-back-btn {
    grid-column: span 2;
  }
}

/* Wallet tracker hidden route */
.wallet-page .wallet-card {
  display: grid;
  gap: 14px;
}

.wallet-tabs,
.wallet-toolbar,
.wallet-profile-actions,
.wallet-add-row {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.wallet-tabs {
  border-bottom: 1px solid var(--line);
  padding-bottom: 10px;
}

.wallet-tabs button,
.wallet-profile-actions button,
.wallet-watch-row button,
.wallet-add-row button,
.wallet-back-btn {
  border: 1px solid var(--line);
  background: var(--panel-2);
  color: var(--text);
  border-radius: 8px;
  padding: 8px 11px;
  font: inherit;
  font-size: 12px;
  font-weight: 750;
  cursor: pointer;
}

.wallet-tabs button.active,
.wallet-add-row button {
  border-color: rgba(232, 87, 42, .5);
  background: rgba(232, 87, 42, .12);
  color: var(--accent);
}

.wallet-profile-actions .ghost,
.wallet-watch-row .ghost,
.wallet-back-btn {
  color: var(--muted);
  background: transparent;
}

.wallet-summary-grid,
.wallet-profile-grid,
.wallet-detail-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 12px;
}

.wallet-track-panel,
.wallet-profile-list,
.wallet-activity-list,
.wallet-directory-section {
  display: grid;
  gap: 12px;
}

.wallet-track-box {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) minmax(320px, 1.4fr);
  gap: 14px;
  align-items: end;
  border: 1px solid var(--line);
  background: var(--panel-2);
  border-radius: 8px;
  padding: 14px;
}

.wallet-track-box h2,
.wallet-track-box p {
  margin: 0;
}

.wallet-track-box p {
  margin-top: 5px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}

.wallet-summary-grid-compact {
  grid-template-columns: repeat(4, minmax(120px, 1fr));
}

.wallet-summary-grid > div,
.wallet-profile-card,
.wallet-profile-row,
.wallet-watch-row,
.wallet-alert-row,
.wallet-activity-row,
.wallet-profile-detail section,
.wallet-table-section,
.wallet-empty,
.wallet-link-row {
  border: 1px solid var(--line);
  background: var(--panel-2);
  border-radius: 8px;
}

.wallet-summary-grid > div {
  padding: 13px;
}

.wallet-summary-grid span,
.wallet-section-head span,
.wallet-profile-top span,
.wallet-alert-row span,
.wallet-watch-row span,
.wallet-profile-meta em,
.wallet-link-row em,
.wallet-notes,
.wallet-empty {
  color: var(--muted);
}

.wallet-summary-grid b {
  display: block;
  margin-top: 4px;
  font-size: 24px;
}

.wallet-section-head,
.wallet-detail-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 14px;
  margin-top: 4px;
}

.wallet-section-head h2,
.wallet-detail-head h2,
.wallet-profile-detail h3 {
  margin: 0;
}

.wallet-profile-card,
.wallet-profile-row,
.wallet-watch-row,
.wallet-alert-row,
.wallet-activity-row,
.wallet-profile-detail section,
.wallet-table-section {
  padding: 13px;
}

.wallet-profile-row {
  display: grid;
  grid-template-columns: minmax(180px, 1.5fr) auto minmax(90px, .7fr) auto auto;
  align-items: center;
  gap: 10px;
}

.wallet-profile-main strong,
.wallet-profile-main span,
.wallet-profile-source {
  display: block;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.wallet-profile-main span,
.wallet-profile-source {
  color: var(--muted);
  font-size: 12px;
}

.wallet-category-pill {
  display: inline-flex;
  align-items: center;
  width: max-content;
  min-height: 24px;
  padding: 3px 8px;
  border: 1px solid rgba(232, 87, 42, .28);
  border-radius: 999px;
  background: rgba(232, 87, 42, .08);
  color: var(--accent);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
}

.wallet-detail-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.wallet-detail-actions button {
  border: 1px solid rgba(232, 87, 42, .5);
  background: rgba(232, 87, 42, .12);
  color: var(--accent);
  border-radius: 8px;
  padding: 8px 11px;
  font: inherit;
  font-size: 12px;
  font-weight: 750;
  cursor: pointer;
}

.wallet-profile-top,
.wallet-watch-row,
.wallet-alert-row,
.wallet-activity-row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
}

.wallet-profile-top strong,
.wallet-alert-row strong,
.wallet-watch-row strong {
  display: block;
}

.wallet-profile-meta {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin: 12px 0;
}

.wallet-profile-meta span {
  min-width: 0;
  padding: 8px;
  border: 1px solid var(--line);
  border-radius: 8px;
}

.wallet-profile-meta em,
.wallet-profile-meta b {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.wallet-risk-badge.unknown {
  color: var(--muted);
}

.wallet-add-row input,
.wallet-add-row select {
  min-height: 38px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel-2);
  color: var(--text);
  padding: 8px 10px;
}

.wallet-add-row input {
  flex: 1 1 320px;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
}

.wallet-link-row,
.wallet-activity-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  padding: 10px;
  margin-bottom: 8px;
  font-size: 12px;
}

.wallet-link-button {
  width: 100%;
  color: var(--text);
  text-align: left;
  cursor: pointer;
}

.wallet-link-row span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
}

.wallet-profile-detail {
  display: grid;
  gap: 14px;
}

.wallet-detail-head p {
  margin: 4px 0 0;
  color: var(--muted);
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  word-break: break-all;
}

.wallet-mini-table td[colspan] {
  color: var(--muted);
}

.wallet-empty {
  padding: 18px;
}

.wallet-login button {
  margin-top: 10px;
}

@media (max-width: 700px) {
  .wallet-toolbar,
  .wallet-tabs {
    align-items: stretch;
  }
  .wallet-tabs button {
    flex: 1 1 30%;
  }
  .wallet-profile-meta,
  .wallet-detail-grid {
    grid-template-columns: 1fr;
  }
  .wallet-track-box,
  .wallet-summary-grid-compact,
  .wallet-profile-row,
  .wallet-activity-row {
    grid-template-columns: 1fr;
  }
  .wallet-profile-top,
  .wallet-watch-row,
  .wallet-alert-row,
  .wallet-activity-row,
  .wallet-section-head,
  .wallet-detail-head {
    display: grid;
  }
}

/* Coins page */
.coins-page {
  --coins-bg: #050505;
  --coins-panel: #101010;
  --coins-panel-2: #171717;
  --coins-panel-3: #202020;
  --coins-line: rgba(255,255,255,.095);
  background: var(--coins-bg);
  color: var(--text);
  overflow-x: hidden;
}

.coins-page *,
.coins-page *::before,
.coins-page *::after {
  box-sizing: border-box;
}

.coins-shell {
  width: 100%;
  max-width: 1560px;
  margin: 0 auto;
  padding: 30px 22px 56px;
  box-sizing: border-box;
}

.coins-hero {
  display: flex;
  justify-content: space-between;
  gap: 22px;
  align-items: flex-start;
  margin-bottom: 18px;
}

.coins-title {
  margin: 0 0 7px;
  color: var(--text);
  font-size: clamp(30px, 3vw, 42px);
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: 0;
}

.coins-sub {
  max-width: 680px;
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.5;
}

.coins-mood-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}

.coins-market-read {
  border: 1px solid var(--coins-line);
  border-radius: 14px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--coins-panel-2) 94%, var(--accent) 3%), var(--coins-panel));
  box-shadow: 0 18px 45px rgba(0,0,0,.28);
  margin-bottom: 16px;
  overflow: hidden;
}

.coins-read-main {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 18px;
  align-items: center;
  padding: 16px 18px;
  border-bottom: 1px solid var(--coins-line);
}

.coins-read-main span,
.coins-read-drivers em {
  display: block;
  color: var(--muted);
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .07em;
  text-transform: uppercase;
  font-style: normal;
}

.coins-read-main strong {
  display: block;
  margin-top: 5px;
  color: var(--text);
  font-size: 24px;
  font-weight: 950;
}

.coins-read-main p {
  max-width: 920px;
  margin: 5px 0 0;
  color: color-mix(in srgb, var(--text) 80%, var(--muted) 20%);
  font-size: 14px;
  line-height: 1.45;
}

.coins-fng-wheel {
  position: relative;
  width: 82px;
  height: 82px;
  border-radius: 50%;
  color: #f7b731;
  background: conic-gradient(currentColor calc(var(--fng) * 1%), rgba(255,255,255,.08) 0);
  box-shadow: inset 0 0 0 1px var(--coins-line);
  flex: 0 0 auto;
}

.coins-fng-wheel.fear { color: #ef5350; }
.coins-fng-wheel.greed { color: #00bb7f; }

.coins-fng-wheel::before {
  content: "";
  position: absolute;
  inset: 8px;
  border-radius: 50%;
  background: var(--coins-panel);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.04);
}

.coins-fng-wheel > div {
  position: relative;
  z-index: 1;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.coins-fng-wheel b {
  color: var(--text);
  font-size: 20px;
  font-weight: 950;
  line-height: 1;
}

.coins-fng-wheel span {
  margin-top: 4px;
  color: var(--muted);
  font-size: 9px;
  font-weight: 950;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.coins-read-drivers {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 8px;
  padding: 12px 18px;
  border-bottom: 1px solid var(--coins-line);
}

.coins-read-drivers span {
  min-width: 0;
  border: 1px solid var(--coins-line);
  border-radius: 10px;
  background: rgba(255,255,255,.025);
  padding: 10px;
}

.coins-read-drivers b {
  display: block;
  margin-top: 4px;
  color: var(--text);
  font-size: 13px;
  font-weight: 950;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.coins-read-questions {
  display: grid;
  gap: 8px;
  padding: 12px 18px 14px;
  background: color-mix(in srgb, var(--coins-panel-2) 84%, var(--accent) 5%);
}

.coins-read-questions-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.coins-read-questions-head span {
  color: var(--accent);
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.coins-read-questions-head em {
  color: var(--muted);
  font-size: 11px;
  font-style: normal;
  font-weight: 700;
}

.coins-read-question-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.coins-read-questions button,
.coins-ask-pills button {
  border: 1px solid var(--coins-line);
  border-radius: 999px;
  background: color-mix(in srgb, var(--coins-panel-3) 86%, var(--accent) 8%);
  color: var(--accent);
  padding: 8px 13px;
  font-size: 12.5px;
  font-weight: 850;
  cursor: pointer;
  transition: background .15s ease, border-color .15s ease, color .15s ease, transform .15s ease;
}

.coins-read-questions button:hover,
.coins-ask-pills button:hover {
  border-color: color-mix(in srgb, var(--accent) 45%, var(--coins-line));
  background: color-mix(in srgb, var(--accent) 14%, var(--coins-panel-3));
  color: var(--accent);
  transform: translateY(-1px);
}

.coins-mood-card,
.coins-main-card {
  border: 1px solid var(--coins-line);
  background: linear-gradient(180deg, var(--coins-panel-2), var(--coins-panel));
  box-shadow: 0 18px 45px rgba(0,0,0,.34);
}

.coins-mood-card {
  position: relative;
  overflow: hidden;
  border-radius: 12px;
  padding: 14px;
}

.coins-mood-card span {
  display: block;
  color: var(--muted);
  font-size: 10.5px;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.coins-mood-card b {
  display: block;
  margin-top: 6px;
  color: var(--text);
  font-size: 21px;
  font-weight: 950;
  letter-spacing: 0;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.coins-mood-card em {
  display: block;
  margin-top: 3px;
  color: var(--muted);
  font-size: 12px;
  font-style: normal;
}

.coins-mini-spark {
  position: absolute;
  right: 12px;
  bottom: 12px;
  width: 46px;
  height: 18px;
  opacity: .75;
  background:
    linear-gradient(135deg, transparent 0 17%, currentColor 18% 21%, transparent 22% 39%, currentColor 40% 43%, transparent 44% 61%, currentColor 62% 65%, transparent 66%),
    linear-gradient(90deg, transparent, currentColor, transparent);
  color: #00bb7f;
  mask: linear-gradient(#000, #000);
}

.coins-mini-spark.down { color: #ef5350; transform: scaleY(-1); }
.coins-mini-spark.btc { color: #f7931a; }

.coins-etf-card.inflow {
  border-color: color-mix(in srgb, #00bb7f 26%, var(--coins-line));
}

.coins-etf-card.outflow {
  border-color: color-mix(in srgb, #ef5350 26%, var(--coins-line));
}

.coins-etf-card.inflow b { color: #00bb7f; }
.coins-etf-card.outflow b { color: #ef5350; }

.coins-fng-card::before {
  content: '';
  position: absolute;
  inset: auto -24px -42px auto;
  width: 112px;
  height: 112px;
  border-radius: 50%;
  background: radial-gradient(circle, color-mix(in srgb, currentColor 22%, transparent), transparent 66%);
  color: var(--muted);
}

.coins-fng-card.fear,
.coins-fng-card.fear-hot { color: #ef5350; }
.coins-fng-card.neutral { color: #f0b35a; }
.coins-fng-card.greed,
.coins-fng-card.greed-hot { color: #00bb7f; }

.coins-fng-card b {
  color: currentColor;
}

.coins-fng-gauge {
  position: relative;
  height: 7px;
  margin-top: 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  overflow: hidden;
}

.coins-fng-gauge span {
  display: block;
  height: 100%;
  min-width: 8px;
  border-radius: inherit;
  background: currentColor;
  box-shadow: 0 0 18px color-mix(in srgb, currentColor 45%, transparent);
}

.coins-main-card {
  border-radius: 14px;
}

.coins-main-card {
  min-width: 0;
  overflow: hidden;
}

.coins-toolbar {
  position: sticky;
  top: 0;
  z-index: 12;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 18px;
  border-bottom: 1px solid var(--coins-line);
  background: color-mix(in srgb, var(--coins-panel) 94%, #050505 6%);
  box-shadow: 0 12px 26px rgba(0,0,0,.22);
}

.coins-section-title,
.coins-intel-title {
  color: var(--text);
  font-size: 22px;
  font-weight: 950;
  letter-spacing: 0;
}

.coins-stable-badge {
  display: inline-flex;
  align-items: center;
  margin-left: 8px;
  height: 22px;
  border: 1px solid var(--coins-line);
  border-radius: 999px;
  background: var(--coins-panel-3);
  color: var(--muted);
  padding: 0 8px;
  font-size: 10.5px;
  font-weight: 850;
  vertical-align: middle;
}

.coins-section-sub {
  margin-top: 3px;
  color: var(--muted);
  font-size: 12.5px;
}

.coins-controls {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.coins-search {
  display: flex;
  align-items: center;
  gap: 7px;
  height: 34px;
  border: 1px solid var(--coins-line);
  border-radius: 9px;
  background: var(--coins-panel-3);
  padding: 0 10px;
}

.coins-search svg {
  width: 14px;
  height: 14px;
  color: var(--muted);
}

.coins-search input {
  width: 160px;
  border: 0;
  outline: 0;
  background: transparent;
  color: var(--text);
  font: inherit;
  font-size: 12.5px;
}

.coins-filter-pills {
  display: flex;
  gap: 6px;
  align-items: center;
  scrollbar-width: none;
}

.coins-timeframes {
  display: flex;
  gap: 4px;
  height: 34px;
  padding: 3px;
  border: 1px solid var(--coins-line);
  border-radius: 999px;
  background: var(--coins-panel-3);
}

.coins-timeframes button {
  min-width: 40px;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: var(--muted);
  padding: 0 9px;
  font-size: 11px;
  font-weight: 900;
}

.coins-timeframes button.active {
  background: var(--text);
  color: var(--bg);
}

.coins-filter-pills::-webkit-scrollbar {
  display: none;
}

.coins-filter-pills button,
.coins-watchlist-filter button {
  height: 34px;
  border: 1px solid var(--coins-line);
  border-radius: 999px;
  background: var(--coins-panel-3);
  color: var(--muted);
  padding: 0 11px;
  font-size: 12px;
  font-weight: 800;
}

.coins-filter-pills button.active,
.coins-watchlist-filter button.active {
  background: var(--text);
  color: var(--bg);
  border-color: var(--text);
}

.coins-watchlist-filter {
  display: flex;
  justify-content: flex-end;
}

.coins-stable-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 34px;
  border: 1px solid var(--coins-line);
  border-radius: 999px;
  background: var(--coins-panel-3);
  color: var(--muted);
  padding: 0 11px;
  font-size: 12px;
  font-weight: 800;
  white-space: nowrap;
}

.coins-stable-toggle input {
  accent-color: var(--accent);
}

.coins-stable-hidden-note {
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  white-space: nowrap;
}

.coins-sector-select {
  height: 34px;
  border: 1px solid var(--coins-line);
  border-radius: 999px;
  background-color: var(--coins-panel-3);
  background-image: linear-gradient(45deg, transparent 50%, var(--muted) 50%), linear-gradient(135deg, var(--muted) 50%, transparent 50%);
  background-position: calc(100% - 17px) 14px, calc(100% - 12px) 14px;
  background-size: 5px 5px, 5px 5px;
  background-repeat: no-repeat;
  color: var(--text);
  padding: 0 30px 0 12px;
  font: inherit;
  font-size: 12px;
  font-weight: 850;
  outline: 0;
  appearance: none;
  color-scheme: dark;
}

.coins-sector-select.active {
  border-color: rgba(240,179,90,.62);
  background-color: color-mix(in srgb, var(--coins-panel-3) 72%, #f0b35a 28%);
}

.coins-sector-select option {
  background: #171717;
  color: #f4f4f4;
}

.coins-movers {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  padding: 14px 18px;
  border-bottom: 1px solid var(--coins-line);
}

.coins-movers > div {
  border: 1px solid var(--coins-line);
  border-radius: 11px;
  background: var(--coins-panel-2);
  padding: 12px;
}

.coins-movers strong {
  display: block;
  color: var(--text);
  font-size: 12px;
  margin-bottom: 8px;
}

.coins-movers button {
  display: flex;
  width: 100%;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  border: 0;
  background: transparent;
  color: var(--text);
  padding: 5px 0;
  font-size: 12.5px;
}

.coins-movers button span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
  font-weight: 800;
}

.coins-movers button img,
.coins-movers .coins-logo-fallback {
  width: 20px;
  height: 20px;
  border-radius: 50%;
}

.coins-movers button img {
  background: #f2f3f5;
}

.coins-logo-fallback {
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  justify-content: center;
  border: 1px solid color-mix(in srgb, var(--coins-line) 75%, var(--accent) 18%);
  background:
    radial-gradient(circle at 30% 25%, rgba(255,255,255,.16), transparent 42%),
    linear-gradient(135deg, rgba(255,122,42,.28), rgba(0,187,127,.18));
  color: var(--text);
  font-size: 8px;
  font-weight: 950;
  letter-spacing: 0;
}

.coins-movers b.vol {
  color: #f0b35a;
}

.coins-sector-summary b {
  display: block;
  color: var(--text);
  font-size: 20px;
  font-weight: 950;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0;
}

.coins-sector-summary span {
  display: block;
  margin-top: 3px;
  color: var(--muted);
  font-size: 11.5px;
}

.coins-table-wrap {
  overflow-x: auto;
  scrollbar-color: color-mix(in srgb, var(--accent) 36%, var(--coins-line)) transparent;
}

.coins-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 16px;
  padding: 12px 0 2px;
}

.coins-pagination-actions {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  flex-wrap: wrap;
}

.coins-page-btn {
  border: 1px solid var(--coins-line);
  background: transparent;
  color: var(--muted);
  border-radius: 7px;
  width: 34px;
  height: 32px;
  padding: 0;
  font-size: 12px;
  font-weight: 800;
  cursor: pointer;
  transition: border-color .16s ease, background .16s ease, color .16s ease;
}

.coins-page-btn:hover:not(:disabled) {
  border-color: color-mix(in srgb, var(--accent) 42%, var(--coins-line));
  color: var(--text);
}

.coins-page-btn.active {
  background: var(--text);
  border-color: color-mix(in srgb, var(--accent) 58%, var(--coins-line));
  color: var(--bg);
}

.coins-page-btn:disabled {
  opacity: .45;
  cursor: not-allowed;
}

.coins-table {
  width: 100%;
  min-width: 1230px;
  table-layout: fixed;
  border-collapse: collapse;
  font-variant-numeric: tabular-nums;
}

@media (min-width: 981px) {
  .coins-toolbar {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 14px;
  }

  .coins-controls {
    display: grid;
    grid-template-columns: minmax(220px, 1fr) auto;
    align-items: center;
    justify-content: stretch;
    width: 100%;
  }

  .coins-search {
    min-width: 220px;
  }

  .coins-search input {
    width: 100%;
  }

  .coins-timeframes {
    justify-self: end;
  }

  .coins-filter-pills {
    grid-column: 1;
    grid-row: 2;
    flex-wrap: wrap;
    align-content: flex-start;
  }

  .coins-watchlist-filter {
    grid-column: 2;
    grid-row: 2;
    align-self: start;
    justify-self: end;
  }
}

.coins-table th {
  padding: 12px 10px;
  color: var(--muted);
  background: color-mix(in srgb, var(--coins-panel-2) 92%, #050505 8%);
  border-bottom: 1px solid var(--coins-line);
  box-shadow: 0 1px 0 var(--coins-line);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .05em;
  text-align: left;
  text-transform: uppercase;
  white-space: nowrap;
  cursor: pointer;
}

.coins-table td {
  padding: 13px 10px;
  border-bottom: 1px solid var(--coins-line);
  color: var(--text);
  font-size: 13px;
  vertical-align: middle;
}

.coins-table tbody tr {
  cursor: pointer;
  transition: background .12s;
}

.coins-table tbody tr:hover {
  background: var(--coins-panel-2);
}

.coins-table .num {
  text-align: right;
}

.coins-rank {
  width: 46px;
  color: var(--muted) !important;
}

.coins-table th:nth-child(1),
.coins-table td:nth-child(1) {
  width: 46px;
}

.coins-table th:nth-child(2),
.coins-table td:nth-child(2) {
  width: 84px;
  text-align: center;
}

.coins-table th:nth-child(3),
.coins-table td:nth-child(3) {
  width: 216px;
}

.coins-table th:nth-child(3) {
  padding-left: 42px;
}

.coins-table th.coins-watch-head {
  text-align: center;
}

.coins-table th:nth-child(4),
.coins-table td:nth-child(4),
.coins-table th:nth-child(5),
.coins-table td:nth-child(5),
.coins-table th:nth-child(6),
.coins-table td:nth-child(6),
.coins-table th:nth-child(7),
.coins-table td:nth-child(7),
.coins-table th:nth-child(8),
.coins-table td:nth-child(8) {
  width: 76px;
}

.coins-table th:nth-child(9),
.coins-table td:nth-child(9),
.coins-table th:nth-child(10),
.coins-table td:nth-child(10),
.coins-table th:nth-child(11),
.coins-table td:nth-child(11) {
  width: 126px;
}

.coins-table th:nth-child(12),
.coins-table td:nth-child(12) {
  width: 128px;
  min-width: 128px;
  border-left: 1px solid color-mix(in srgb, var(--coins-line) 78%, var(--accent) 10%);
}

.coins-wallet-intel-cell {
  min-width: 0;
}

.wallet-intel-mini {
  display: flex;
  align-items: center;
  gap: 5px;
  min-width: 0;
  flex-wrap: wrap;
}

.wallet-intel-mini > span:not(.wallet-risk-badge) {
  display: inline-flex;
  align-items: center;
  height: 21px;
  border: 1px solid var(--coins-line);
  border-radius: 999px;
  background: rgba(255,255,255,.035);
  color: var(--muted);
  padding: 0 7px;
  font-size: 10px;
  font-weight: 850;
}

.wallet-risk-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  height: 23px;
  border: 1px solid var(--coins-line);
  border-radius: 999px;
  padding: 0 8px;
  color: var(--text);
  background: var(--coins-panel-3);
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .02em;
  white-space: nowrap;
}

.wallet-risk-badge b {
  color: currentColor;
  font-size: 10px;
  font-weight: 950;
}

.wallet-risk-badge.high {
  border-color: rgba(239,83,80,.4);
  background: rgba(239,83,80,.13);
  color: #ff7b78;
}

.wallet-risk-badge.medium {
  border-color: rgba(240,179,90,.42);
  background: rgba(240,179,90,.13);
  color: #f0b35a;
}

.wallet-risk-badge.low {
  border-color: rgba(0,187,127,.34);
  background: rgba(0,187,127,.11);
  color: #00bb7f;
}

.wallet-intel-empty {
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.token-intel-page {
  background: var(--coins-bg, #050505);
}

.token-intel-controls {
  justify-content: flex-end;
}

@media (min-width: 981px) {
  .token-intel-card .coins-controls {
    display: grid;
    grid-template-columns: minmax(260px, 1fr) repeat(3, minmax(150px, 180px));
    gap: 8px;
    align-items: center;
  }

  .token-intel-card .coins-search,
  .token-intel-card .coins-sector-select {
    width: 100%;
  }
}

.token-intel-summary {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  padding: 14px 18px;
  border-bottom: 1px solid var(--coins-line);
}

.token-intel-summary > div {
  border: 1px solid var(--coins-line);
  border-radius: 10px;
  background: var(--coins-panel-2);
  padding: 12px;
  min-width: 0;
}

.token-intel-summary span {
  display: block;
  color: var(--muted);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.token-intel-summary b {
  display: block;
  margin-top: 5px;
  color: var(--text);
  font-size: 18px;
  font-weight: 950;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.token-intel-table {
  min-width: 1380px;
  table-layout: fixed;
}

.token-intel-table th:nth-child(1),
.token-intel-table td:nth-child(1) {
  width: 220px !important;
}

.token-intel-table th:nth-child(2),
.token-intel-table td:nth-child(2) {
  width: 82px !important;
}

.token-intel-table th:nth-child(3),
.token-intel-table td:nth-child(3) {
  width: 146px !important;
}

.token-intel-table th:nth-child(4),
.token-intel-table td:nth-child(4),
.token-intel-table th:nth-child(5),
.token-intel-table td:nth-child(5),
.token-intel-table th:nth-child(6),
.token-intel-table td:nth-child(6),
.token-intel-table th:nth-child(7),
.token-intel-table td:nth-child(7) {
  width: 112px !important;
}

.token-intel-table th:nth-child(8),
.token-intel-table td:nth-child(8) {
  width: 78px !important;
}

.token-intel-table th:nth-child(9),
.token-intel-table td:nth-child(9) {
  width: 86px !important;
}

.token-intel-table th:nth-child(10),
.token-intel-table td:nth-child(10) {
  width: 112px !important;
}

.token-intel-table th:nth-child(11),
.token-intel-table td:nth-child(11) {
  width: 120px !important;
}

.token-intel-table td {
  padding-top: 11px;
  padding-bottom: 11px;
}

.token-intel-table tbody tr:not(.token-intel-detail-row) {
  cursor: pointer;
}

.token-intel-table .coins-asset {
  gap: 10px;
}

.token-intel-table .coins-asset > div {
  min-width: 0;
}

.token-intel-table .coins-asset strong,
.token-intel-table .coins-asset span,
.token-intel-table .token-intel-address {
  max-width: 150px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.token-copy-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 22px;
  border: 1px solid var(--coins-line);
  border-radius: 999px;
  background: rgba(255,255,255,.045);
  color: var(--muted);
  padding: 0 8px;
  margin-left: 6px;
  font-size: 10px;
  font-weight: 900;
  white-space: nowrap;
}

.token-copy-btn:hover {
  color: var(--text);
  border-color: color-mix(in srgb, var(--accent) 45%, var(--coins-line));
}

.token-chain-pill {
  display: inline-flex;
  align-items: center;
  height: 23px;
  border: 1px solid var(--coins-line);
  border-radius: 999px;
  background: rgba(255,255,255,.035);
  color: var(--text);
  padding: 0 8px;
  font-size: 10px;
  font-weight: 950;
  text-transform: uppercase;
}

.token-intel-detail-row td {
  padding: 0 !important;
  background: color-mix(in srgb, var(--coins-panel-2) 72%, #050505 28%);
}

.token-intel-detail {
  display: grid;
  gap: 10px;
  padding: 14px 16px 16px 68px;
  border-bottom: 1px solid var(--coins-line);
}

.token-intel-detail-address {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
  color: var(--muted);
  font-family: ui-monospace, "JetBrains Mono", monospace;
  font-size: 11px;
}

.token-intel-detail-address span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.token-intel-detail-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 8px;
}

.token-intel-detail-grid span {
  min-width: 0;
  border: 1px solid var(--coins-line);
  border-radius: 8px;
  background: rgba(255,255,255,.025);
  padding: 8px;
}

.token-intel-detail-grid em,
.token-intel-detail-grid b {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.token-intel-detail-grid em {
  color: var(--muted);
  font-size: 9px;
  font-style: normal;
  font-weight: 900;
  text-transform: uppercase;
}

.token-intel-detail-grid b {
  margin-top: 3px;
  color: var(--text);
  font-size: 12px;
  font-weight: 950;
}

.token-intel-detail-notes {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.token-intel-detail-notes em {
  border: 1px solid var(--coins-line);
  border-radius: 999px;
  background: rgba(255,255,255,.035);
  color: var(--muted);
  padding: 5px 8px;
  font-size: 10px;
  font-style: normal;
  font-weight: 800;
}

.token-intel-address {
  display: block;
  margin-top: 2px;
  color: var(--muted);
  font-family: ui-monospace, "JetBrains Mono", monospace;
  font-size: 10px;
}

.token-intel-mobile-list {
  display: none;
}

.token-intel-mobile-card {
  border: 1px solid var(--coins-line);
  border-radius: 10px;
  background: var(--coins-panel-2);
  padding: 11px;
  color: var(--text);
}

.token-intel-mobile-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

.token-intel-mobile-asset {
  display: flex;
  align-items: center;
  gap: 9px;
  min-width: 0;
}

.token-intel-mobile-asset img,
.token-intel-mobile-asset .coins-logo-fallback {
  width: 28px;
  height: 28px;
  border-radius: 50%;
}

.token-intel-mobile-asset > div {
  min-width: 0;
}

.token-intel-mobile-asset strong,
.token-intel-mobile-asset span,
.token-intel-mobile-asset small {
  display: block;
  max-width: 220px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.token-intel-mobile-asset strong {
  color: var(--text);
  font-size: 14px;
  font-weight: 950;
}

.token-intel-mobile-asset span,
.token-intel-mobile-asset small,
.token-intel-mobile-source {
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
}

.token-intel-mobile-asset small {
  font-family: ui-monospace, "JetBrains Mono", monospace;
  margin-top: 2px;
}

.token-intel-mobile-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
  margin-top: 10px;
}

.token-intel-mobile-metrics span {
  border: 1px solid var(--coins-line);
  border-radius: 8px;
  background: rgba(255,255,255,.025);
  padding: 7px;
  min-width: 0;
}

.token-intel-mobile-metrics em,
.token-intel-mobile-metrics b {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.token-intel-mobile-metrics em {
  color: var(--muted);
  font-size: 8.5px;
  font-style: normal;
  font-weight: 900;
  text-transform: uppercase;
}

.token-intel-mobile-metrics b {
  margin-top: 3px;
  color: var(--text);
  font-size: 11px;
  font-weight: 950;
}

  .token-intel-mobile-source {
    margin-top: 9px;
  }
  .token-intel-mobile-card .token-intel-detail {
    padding: 10px 0 0;
    border-bottom: 0;
  }
  .token-intel-detail-address {
    font-size: 10px;
  }
  .token-intel-detail-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

.token-copy-mobile {
  margin: 9px 0 0;
}

.coins-watch-btn,
.coins-row-ask {
  border: 1px solid var(--coins-line);
  border-radius: 999px;
  background: var(--coins-panel-3);
  color: var(--muted);
  font: inherit;
  font-size: 12px;
  font-weight: 900;
}

.coins-watch-btn {
  width: 28px;
  height: 28px;
  padding: 0;
}

.coins-watch-btn.active {
  border-color: color-mix(in srgb, #f0b35a 50%, var(--coins-line));
  color: #f0b35a;
}

.coins-row-ask {
  min-width: 66px;
  height: 28px;
  padding: 0 10px;
  color: var(--text);
}

.coins-row-ask:hover,
.coins-watch-btn:hover {
  border-color: color-mix(in srgb, var(--accent) 45%, var(--coins-line));
  background: color-mix(in srgb, var(--accent) 12%, var(--coins-panel-3));
}

.coins-supply-cell {
  color: var(--muted) !important;
  font-size: 12px !important;
}

.coins-asset {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.coins-asset img,
.coins-asset .coins-logo-fallback {
  width: 28px;
  height: 28px;
  border-radius: 50%;
}

.coins-asset img {
  background: transparent;
  object-fit: contain;
}

.coins-asset > div {
  min-width: 0;
}

.coins-asset strong {
  display: block;
  overflow: hidden;
  color: var(--text);
  font-weight: 900;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.coins-asset span {
  display: block;
  overflow: hidden;
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  text-overflow: ellipsis;
  text-transform: uppercase;
  white-space: nowrap;
}

.coins-asset .coins-logo-fallback,
.coins-movers .coins-logo-fallback {
  display: inline-flex;
  overflow: visible;
  align-items: center;
  justify-content: center;
  color: var(--text);
  font-size: 8px;
  font-weight: 950;
  text-overflow: clip;
  text-transform: uppercase;
  white-space: nowrap;
}

.coins-tags {
  display: flex !important;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 4px;
  font-size: 0 !important;
  text-transform: none !important;
}

.coins-tags em {
  display: inline-flex;
  align-items: center;
  height: 18px;
  border: 1px solid color-mix(in srgb, var(--coins-line) 78%, var(--accent) 12%);
  border-radius: 999px;
  background: rgba(255,255,255,.035);
  color: var(--muted);
  padding: 0 6px;
  font-size: 9.5px;
  font-style: normal;
  font-weight: 850;
  letter-spacing: 0;
  text-transform: none;
}

.coins-table td:nth-child(3) .coins-asset > div {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  column-gap: 8px;
  width: 100%;
}

.coins-table td:nth-child(3) .coins-asset strong {
  grid-column: 1;
  grid-row: 1;
  font-size: 14px;
  line-height: 1.15;
}

.coins-table td:nth-child(3) .coins-asset span {
  grid-column: 1;
  grid-row: 2;
  line-height: 1.15;
}

.coins-table td:nth-child(3) .coins-tags {
  grid-column: 2;
  grid-row: 1 / 3;
  align-self: center;
  justify-self: end;
  flex-wrap: nowrap;
  margin-top: 0;
  max-width: 78px;
}

.coins-spark-cell {
  width: 104px;
  text-align: center;
}

.coins-table th:last-child {
  text-align: center;
}

.coins-spark {
  display: block;
  width: 92px;
  height: 54px;
  margin: 0 auto;
}

.coins-spark-wrap {
  position: relative;
  display: inline-block;
}

.coins-spark-wrap::after {
  content: attr(data-spark-tip);
  position: absolute;
  right: 0;
  bottom: calc(100% + 8px);
  z-index: 20;
  width: max-content;
  max-width: 280px;
  padding: 7px 9px;
  border: 1px solid var(--coins-line);
  border-radius: 8px;
  background: #111;
  color: var(--text);
  box-shadow: 0 14px 28px rgba(0,0,0,.42);
  font-size: 11px;
  font-weight: 750;
  line-height: 1.25;
  opacity: 0;
  pointer-events: none;
  transform: translateY(4px);
  transition: opacity .12s, transform .12s;
}

.coins-spark-wrap:hover::after,
.coins-spark-wrap:focus-visible::after {
  opacity: 1;
  transform: translateY(0);
}

.coins-density-compact .coins-table th {
  padding-top: 9px;
  padding-bottom: 9px;
}

.coins-density-compact .coins-table td {
  padding-top: 6px;
  padding-bottom: 6px;
}

.coins-density-compact .coins-asset img,
.coins-density-compact .coins-asset .coins-logo-fallback {
  width: 24px;
  height: 24px;
}

.coins-density-compact .coins-asset {
  gap: 8px;
}

.coins-density-compact .coins-tags {
  display: flex !important;
  gap: 3px;
  margin-top: 0;
}

.coins-density-compact .coins-tags em {
  height: 15px;
  padding: 0 5px;
  font-size: 8.5px;
  font-weight: 900;
}

.coins-density-compact .coins-spark {
  height: 42px;
}

.coins-spark-empty {
  display: block;
  width: 76px;
  height: 32px;
  margin: 0 auto;
  border-radius: 999px;
  background:
    linear-gradient(135deg, transparent 0 20%, rgba(255,255,255,.12) 21% 24%, transparent 25% 45%, rgba(255,255,255,.16) 46% 49%, transparent 50% 70%, rgba(255,255,255,.1) 71% 74%, transparent 75%),
    linear-gradient(90deg, rgba(255,255,255,.035), rgba(255,255,255,.095), rgba(255,255,255,.035));
  background-size: 100% 100%, 220% 100%;
  animation: shimmer 1.25s linear infinite;
  color: var(--muted);
  font-size: 12px;
  text-align: right;
}

.coins-row-open {
  background: color-mix(in srgb, var(--coins-panel-2) 84%, var(--accent) 8%);
}

.coins-detail-row td {
  padding: 0 !important;
  background: var(--coins-panel);
  border-top: 0;
}

.coins-detail-panel {
  padding: 14px 18px;
  border-bottom: 1px solid var(--coins-line);
}

.coins-detail-row .coins-detail-panel {
  border-top: 1px solid var(--coins-line);
  width: 100%;
  max-width: none;
}

.coins-detail-panel[hidden] {
  display: none;
}

.coins-detail-status .coins-loading {
  padding: 10px 0;
}

.coins-detail-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
}

.coins-detail-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.coins-ask-pills {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.coins-ask-pills span {
  color: var(--accent);
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.coins-ask-pills button {
  height: 30px;
  cursor: pointer;
}

.coins-range-pills {
  display: flex;
  gap: 5px;
  padding: 3px;
  border: 1px solid var(--coins-line);
  border-radius: 999px;
  background: var(--coins-panel-3);
}

.coins-range-pills button {
  height: 28px;
  min-width: 40px;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
}

.coins-range-pills button.active {
  background: var(--text);
  color: var(--bg);
}

.coins-back-btn,
.coins-ask-btn {
  height: 34px;
  border: 1px solid var(--coins-line);
  border-radius: 999px;
  background: var(--coins-panel-3);
  color: var(--text);
  padding: 0 13px;
  font-size: 12px;
  font-weight: 900;
}

.coins-ask-btn {
  background: var(--text);
  color: var(--bg);
  border-color: var(--text);
}

.coins-detail-grid {
  display: grid;
  grid-template-columns: minmax(280px, .68fr) minmax(420px, 1.32fr);
  gap: 12px;
  align-items: stretch;
}

.coins-detail-main,
.coins-detail-chart,
.coins-detail-stats {
  border: 1px solid var(--coins-line);
  border-radius: 12px;
  background: var(--coins-panel-2);
  padding: 14px;
}

.coins-detail-price {
  margin-top: 14px;
  color: var(--text);
  font-size: 28px;
  font-weight: 950;
  font-variant-numeric: tabular-nums;
}

.coins-detail-price span {
  margin-left: 8px;
  font-size: 14px;
}

.coins-detail-main p {
  margin: 10px 0 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.5;
}

.coins-thesis-panel {
  margin-top: 14px;
  border: 1px solid var(--coins-line);
  border-radius: 12px;
  background: color-mix(in srgb, var(--coins-panel) 84%, var(--accent) 5%);
  padding: 12px;
}

.coins-thesis-head span {
  display: block;
  color: var(--muted);
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .07em;
  text-transform: uppercase;
}

.coins-thesis-head b {
  display: block;
  margin-top: 5px;
  color: var(--text);
  font-size: 15px;
  font-weight: 950;
  line-height: 1.25;
}

.coins-thesis-panel p {
  color: color-mix(in srgb, var(--text) 82%, var(--muted) 18%);
}

.coins-thesis-tags,
.coins-thesis-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin-top: 10px;
}

.coins-thesis-tags em {
  border: 1px solid var(--coins-line);
  border-radius: 999px;
  background: rgba(255,255,255,.035);
  color: var(--muted);
  padding: 5px 8px;
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
}

.coins-thesis-grid {
  display: grid;
  gap: 8px;
  margin-top: 11px;
}

.coins-thesis-grid span {
  border: 1px solid var(--coins-line);
  border-radius: 9px;
  background: rgba(255,255,255,.025);
  padding: 9px;
  min-width: 0;
}

.coins-thesis-grid em,
.coins-thesis-grid b {
  display: block;
}

.coins-thesis-grid em {
  color: var(--muted);
  font-size: 9px;
  font-style: normal;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .05em;
}

.coins-thesis-grid b {
  margin-top: 3px;
  color: var(--text);
  font-size: 12px;
  line-height: 1.35;
  font-weight: 850;
}

.coins-ai-answer {
  margin-top: 14px;
  border: 1px solid var(--coins-line);
  border-radius: 10px;
  background: color-mix(in srgb, var(--coins-panel) 82%, var(--accent) 6%);
  padding: 12px;
}

.coins-ai-answer strong {
  display: block;
  color: var(--text);
  font-size: 13px;
  font-weight: 950;
  margin-bottom: 6px;
}

.coins-ai-answer p {
  margin: 0;
  color: color-mix(in srgb, var(--text) 82%, var(--muted) 18%);
  font-size: 13px;
  line-height: 1.62;
}

.coins-ai-answer.muted {
  color: var(--muted);
  font-size: 12px;
}

.coins-detail-chart {
  min-height: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.coins-full-chart {
  width: 100%;
  height: auto;
  min-height: 0;
  aspect-ratio: 560 / 300;
}

.coins-full-chart .coins-chart-bg {
  fill: color-mix(in srgb, var(--coins-panel-2) 82%, #0b1118 18%);
  stroke: color-mix(in srgb, var(--coins-line) 84%, transparent);
  stroke-width: 1;
}

.coins-full-chart text {
  fill: var(--muted);
  font-size: 11px;
  font-weight: 800;
}

.coins-full-chart .coins-chart-kicker,
.coins-full-chart .coins-chart-volume-label,
.coins-full-chart .coins-chart-ma-label,
.coins-full-chart .coins-chart-range {
  fill: var(--text);
  opacity: .75;
}

.coins-full-chart .coins-chart-range.pos { fill: #00bb7f; opacity: .95; }
.coins-full-chart .coins-chart-range.neg { fill: #ef5350; opacity: .95; }

.coins-full-chart .coins-chart-y {
  font-size: 10px;
}

.coins-chart-grid line {
  stroke: color-mix(in srgb, var(--line) 58%, transparent);
  stroke-width: 1;
}

.coins-chart-price-line {
  stroke-width: 3.2;
  stroke-linecap: round;
  stroke-linejoin: round;
  filter: drop-shadow(0 0 7px color-mix(in srgb, currentColor 28%, transparent));
}

.coins-chart-ma {
  stroke: rgba(240,179,90,.78);
  stroke-width: 1.7;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-dasharray: 5 5;
}

.coins-chart-last {
  stroke: rgba(255,255,255,.25);
  stroke-width: 1;
  stroke-dasharray: 4 5;
}

.coins-chart-dot {
  stroke: var(--coins-panel-2);
  stroke-width: 2;
}

.coins-chart-empty {
  display: flex;
  width: 100%;
  min-height: 220px;
  align-items: center;
  justify-content: center;
  color: var(--muted);
  font-size: 13px;
}

.coins-chart-loading {
  display: grid;
  gap: 10px;
  align-content: center;
  border: 1px solid color-mix(in srgb, var(--coins-line) 70%, transparent);
  border-radius: 14px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.04), transparent),
    repeating-linear-gradient(0deg, transparent 0 42px, rgba(255,255,255,.045) 43px),
    repeating-linear-gradient(90deg, transparent 0 70px, rgba(255,255,255,.035) 71px);
}

.coins-chart-loading span {
  display: block;
  width: min(72%, 380px);
  height: 74px;
  margin: 0 auto;
  border-bottom: 3px solid rgba(240,179,90,.45);
  border-radius: 50% 30% 0 0;
  opacity: .75;
}

.coins-chart-loading b {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.coins-detail-stats {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(8, minmax(0, 1fr));
  gap: 10px;
}

.coins-detail-stats span {
  display: grid;
  gap: 4px;
  color: var(--muted);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.coins-detail-stats b {
  color: var(--text);
  font-size: 14px;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0;
  text-transform: none;
}

.coins-detail-extra {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.coins-detail-extra section {
  min-width: 0;
  border: 1px solid var(--coins-line);
  border-radius: 12px;
  background: var(--coins-panel-2);
  padding: 14px;
}

.coins-detail-extra .coins-news-section {
  grid-column: span 2;
  border-color: color-mix(in srgb, var(--coins-line) 70%, #f0b35a 30%);
  background:
    linear-gradient(135deg, rgba(240,179,90,.1), transparent 42%),
    color-mix(in srgb, var(--coins-panel-2) 88%, #121820 12%);
}

.coins-news-row.compact {
  min-height: 54px;
}

.coins-full-profile-page .coins-mood-grid,
.coins-full-profile-page .coins-market-read,
.coins-full-profile-page .coins-movers,
.coins-full-profile-page .coins-toolbar,
.coins-full-profile-page .coins-pagination {
  display: none !important;
}

.coins-full-profile-page .coins-main-card {
  border: 0;
  background: transparent;
  box-shadow: none;
}

.coins-full-profile-page .coins-table-wrap {
  overflow: visible;
}

.coins-full-profile-page .coins-detail-panel {
  border: 0;
  border-radius: 0;
  background: transparent;
  padding: 0;
}

.coins-full-profile-page .coins-detail-head {
  margin-bottom: 14px;
}


.coins-profile-links {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.coins-profile-link {
  display: flex;
  min-width: 0;
  min-height: 38px;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  border: 1px solid color-mix(in srgb, var(--coins-line) 78%, transparent);
  border-radius: 10px;
  background: rgba(255,255,255,.035);
  color: var(--text);
  padding: 8px 9px;
  text-decoration: none;
  transition: background .15s ease, border-color .15s ease, transform .15s ease;
}

.coins-profile-link:hover {
  border-color: rgba(0,187,127,.38);
  background: rgba(0,187,127,.08);
  transform: translateY(-1px);
}

.coins-profile-link span {
  min-width: 0;
  overflow: hidden;
  color: var(--text);
  font-size: 11px;
  font-weight: 900;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.coins-profile-link b {
  display: inline-flex;
  width: 20px;
  height: 20px;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: rgba(0,187,127,.16);
  color: #00bb7f;
  font-size: 10px;
  font-weight: 950;
  flex: 0 0 auto;
}

.coins-profile-link.x b { background: rgba(74,163,255,.18); color: #4aa3ff; }
.coins-profile-link.reddit b { background: rgba(255,69,0,.18); color: #ff6b35; }
.coins-profile-link.whitepaper b,
.coins-profile-link.explorer b { background: rgba(240,179,90,.18); color: #f0b35a; }

.coins-extra-title {
  color: var(--text);
  font-size: 13px;
  font-weight: 950;
  margin-bottom: 4px;
}

.coins-extra-sub {
  color: var(--muted);
  font-size: 11px;
  margin-bottom: 10px;
}

.coins-market-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto 52px;
  gap: 8px;
  align-items: center;
  padding: 8px 0;
  border-top: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
}

.coins-market-row strong,
.coins-news-row strong {
  display: block;
  min-width: 0;
  color: var(--text);
  font-size: 12px;
  font-weight: 900;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.coins-market-row span,
.coins-news-row span {
  color: var(--muted);
  font-size: 11px;
}

.coins-market-row b,
.coins-market-row em {
  color: var(--text);
  font-size: 12px;
  font-style: normal;
  font-weight: 850;
  font-variant-numeric: tabular-nums;
  text-align: right;
}

.coins-market-row em {
  color: var(--muted);
}

.coins-quality-card {
  border: 1px solid color-mix(in srgb, var(--coins-line) 76%, currentColor 14%);
  border-radius: 10px;
  background: color-mix(in srgb, var(--coins-panel) 84%, currentColor 5%);
  color: #f0b35a;
  padding: 10px;
}

.coins-quality-card.strong { color: #00bb7f; }
.coins-quality-card.good { color: #8fd36f; }
.coins-quality-card.watch { color: #f0b35a; }
.coins-quality-card.thin { color: #ef5350; }

.coins-quality-top {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 2px 8px;
  align-items: end;
}

.coins-quality-top span {
  grid-column: 1 / -1;
  color: var(--muted);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .05em;
  text-transform: uppercase;
}

.coins-quality-top b {
  color: currentColor;
  font-size: 22px;
  font-weight: 950;
  letter-spacing: 0;
}

.coins-quality-top i {
  color: var(--text);
  font-size: 18px;
  font-style: normal;
  font-weight: 950;
  font-variant-numeric: tabular-nums;
}

.coins-quality-bar {
  height: 7px;
  margin-top: 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  overflow: hidden;
}

.coins-quality-bar span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: currentColor;
  box-shadow: 0 0 16px color-mix(in srgb, currentColor 45%, transparent);
}

.coins-quality-card p {
  margin: 9px 0 0;
  color: color-mix(in srgb, var(--text) 78%, var(--muted) 22%);
  font-size: 12px;
  line-height: 1.45;
}

.coins-quality-metrics {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 7px;
  margin-top: 10px;
}

.coins-quality-metrics span {
  display: grid;
  gap: 2px;
  min-width: 0;
  color: var(--muted);
  font-size: 9.5px;
  font-weight: 850;
  text-transform: uppercase;
}

.coins-quality-metrics b {
  overflow: hidden;
  color: var(--text);
  font-size: 11.5px;
  font-weight: 950;
  text-overflow: ellipsis;
  text-transform: none;
  white-space: nowrap;
}

.coins-quality-flags {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-top: 10px;
}

.coins-quality-flags em {
  display: inline-flex;
  align-items: center;
  min-height: 18px;
  border: 1px solid color-mix(in srgb, currentColor 38%, transparent);
  border-radius: 999px;
  color: currentColor;
  padding: 0 7px;
  font-size: 9px;
  font-style: normal;
  font-weight: 900;
}

.coins-quality-pop {
  margin-top: 10px;
}

.coins-quality-pop summary {
  cursor: pointer;
  color: currentColor;
  font-size: 11px;
  font-weight: 900;
}

.coins-quality-pop p {
  color: var(--muted);
  font-size: 11.5px;
}

.coins-tokenomics-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.coins-context-grid {
  display: grid;
  gap: 8px;
}

.coins-context-grid span {
  display: grid;
  gap: 3px;
  min-width: 0;
  padding: 9px;
  border: 1px solid color-mix(in srgb, var(--line) 80%, transparent);
  border-radius: 9px;
  background: color-mix(in srgb, var(--coins-panel) 80%, transparent);
  color: var(--muted);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.coins-context-grid b {
  color: var(--text);
  font-size: 13px;
  font-weight: 950;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0;
  text-transform: none;
}

.coins-context-grid em {
  overflow: hidden;
  color: var(--muted);
  font-size: 11px;
  font-style: normal;
  letter-spacing: 0;
  text-overflow: ellipsis;
  text-transform: none;
  white-space: nowrap;
}

.coins-pressure-section {
  grid-column: 1 / -1;
}

.coins-pressure-card {
  border: 1px solid color-mix(in srgb, var(--coins-line) 72%, #ffd700 18%);
  border-radius: 10px;
  background:
    linear-gradient(135deg, rgba(255,215,0,.08), transparent 42%),
    color-mix(in srgb, var(--coins-panel) 86%, #101820 14%);
  padding: 10px;
  min-width: 0;
}

.coins-pressure-card.hot { border-color: rgba(255,92,92,.42); }
.coins-pressure-card.elevated { border-color: rgba(240,179,90,.44); }
.coins-pressure-card.moderate { border-color: rgba(255,215,0,.32); }
.coins-pressure-card.cool { border-color: rgba(0,187,127,.28); }

.coins-pressure-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 8px;
}

.coins-pressure-head span {
  display: grid;
  gap: 2px;
}

.coins-pressure-head b {
  color: var(--text);
  font-size: 17px;
  font-weight: 950;
}

.coins-pressure-head em {
  color: #ffd700;
  font-size: 10.5px;
  font-style: normal;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.coins-pressure-head button {
  height: 28px;
  border: 1px solid rgba(255,215,0,.35);
  border-radius: 999px;
  background: rgba(255,215,0,.12);
  color: var(--text);
  padding: 0 10px;
  font-size: 11px;
  font-weight: 950;
}

.coins-pressure-foot {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-top: 8px;
}

.coins-pressure-foot span {
  display: grid;
  gap: 2px;
  border: 1px solid color-mix(in srgb, var(--line) 78%, transparent);
  border-radius: 8px;
  background: color-mix(in srgb, var(--coins-panel-2) 82%, transparent);
  color: var(--muted);
  padding: 8px;
  font-size: 10px;
  font-weight: 850;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.coins-pressure-foot b {
  color: var(--text);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0;
  text-transform: none;
}

.coins-pressure-preview-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, .8fr);
  gap: 10px;
  min-width: 0;
}

.coins-pressure-preview-grid > div {
  min-width: 0;
}

.coins-pressure-preview-label {
  margin: 0 0 6px;
  color: var(--muted);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .05em;
  text-transform: uppercase;
}

.coins-pressure-preview-pan {
  width: 100%;
  max-width: 100%;
  min-width: 0;
  overflow: hidden;
  border-radius: 12px;
}

.coins-pressure-card .tools-pressure-chart,
.coins-pressure-card .tools-pressure-heatmap {
  min-width: 0;
  margin-top: 0;
}

.coins-pressure-card .tools-pressure-heatmap {
  aspect-ratio: 1080 / 640;
}

.coins-pressure-card .tools-pressure-chart {
  aspect-ratio: 1080 / 560;
}

.coins-pressure-card .tools-pressure-chart text,
.coins-pressure-card .tools-pressure-heatmap text {
  font-size: 13px;
}

.coins-tokenomics-grid span {
  display: grid;
  gap: 4px;
  min-width: 0;
  padding: 9px;
  border: 1px solid color-mix(in srgb, var(--line) 80%, transparent);
  border-radius: 9px;
  color: var(--muted);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.coins-tokenomics-grid b {
  min-width: 0;
  color: var(--text);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: none;
  overflow: hidden;
  text-overflow: ellipsis;
}

.coins-news-row {
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
  min-height: 70px;
  margin-top: 9px;
  padding: 8px;
  border-top: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
  border-radius: 10px;
  background: rgba(255,255,255,.035);
  text-decoration: none;
  transition: background .15s ease, border-color .15s ease, transform .15s ease;
}

.coins-news-row:first-of-type {
  margin-top: 0;
}

.coins-news-row:hover {
  border-color: rgba(240,179,90,.42);
  background: rgba(240,179,90,.08);
  transform: translateY(-1px);
}

.coins-news-thumb {
  display: flex;
  width: 58px;
  height: 54px;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--coins-line) 72%, transparent);
  border-radius: 9px;
  background: linear-gradient(135deg, rgba(240,179,90,.24), rgba(0,187,127,.12));
  color: var(--text);
  flex: 0 0 auto;
}

.coins-news-thumb.coin-logo {
  padding: 11px;
  background:
    radial-gradient(circle at 30% 20%, rgba(255,255,255,.16), transparent 42%),
    linear-gradient(135deg, rgba(240,179,90,.22), rgba(74,163,255,.16));
}

.coins-news-thumb img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.coins-news-thumb.broken::before {
  content: 'AC';
  color: var(--text);
  font-size: 14px;
  font-weight: 950;
}

.coins-news-thumb b {
  color: var(--text);
  font-size: 14px;
  font-weight: 950;
  letter-spacing: .02em;
}

.coins-news-thumb.fallback.x {
  background: linear-gradient(135deg, rgba(74,163,255,.28), rgba(255,255,255,.05));
}

.coins-news-copy {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.coins-news-copy em {
  color: #f0b35a;
  font-size: 10px;
  font-style: normal;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.coins-news-row strong {
  color: color-mix(in srgb, var(--text) 94%, #f0b35a 6%);
  font-size: 13px;
  line-height: 1.28;
  white-space: normal;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.coins-empty-mini {
  color: var(--muted);
  font-size: 12px;
  padding: 12px 0 2px;
}

.coins-mobile-list {
  display: none;
}

.coins-loading {
  padding: 24px;
  color: var(--muted);
  font-size: 13px;
}

.coins-error-state {
  display: grid;
  gap: 6px;
  text-align: center;
}

.coins-error-state strong {
  color: var(--text);
  font-size: 15px;
}

.coins-error-state span {
  color: var(--muted);
  font-size: 13px;
}

.coins-skeleton-list {
  display: grid;
  gap: 0;
}

.coins-skeleton-row {
  display: grid;
  grid-template-columns: 34px 1fr 120px 90px;
  align-items: center;
  gap: 14px;
  padding: 14px 18px;
  border-bottom: 1px solid var(--coins-line);
}

.coins-skeleton-row i,
.coins-skeleton-row span,
.coins-skeleton-row b,
.coins-skeleton-row em,
.coins-mood-card.skeleton span,
.coins-mood-card.skeleton b,
.coins-mood-card.skeleton em,
.coins-mover-skeleton {
  display: block;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(255,255,255,.045), rgba(255,255,255,.105), rgba(255,255,255,.045));
  background-size: 220% 100%;
  animation: shimmer 1.25s linear infinite;
}

.coins-skeleton-row i { width: 28px; height: 28px; border-radius: 50%; }
.coins-skeleton-row span { height: 18px; }
.coins-skeleton-row b { height: 14px; }
.coins-skeleton-row em { height: 32px; }
.coins-mood-card.skeleton span { width: 62px; height: 10px; }
.coins-mood-card.skeleton b { width: 104px; height: 24px; }
.coins-mood-card.skeleton em { width: 132px; height: 12px; }
.coins-mover-skeleton { min-height: 92px; border-radius: 11px; }

.coins-page .pos {
  color: #00bb7f !important;
}

	.coins-page .neg {
	  color: #ef5350 !important;
	}

/* Intel Tools: MarketCap-style visual pass.
   Kept near the MarketCap rules so Intel uses the same dark product surface. */
#toolsPage {
  --tools-bg: var(--bg);
  --tools-panel: color-mix(in srgb, var(--panel) 82%, var(--bg) 18%);
  --tools-panel-2: color-mix(in srgb, var(--panel-2) 88%, var(--bg) 12%);
  --tools-panel-3: color-mix(in srgb, var(--panel-2) 78%, var(--bg) 22%);
  --tools-line: var(--line);
  background: var(--bg) !important;
}

html.light #toolsPage,
body.light #toolsPage,
html.light-mode #toolsPage,
body.light-mode #toolsPage,
html.light-theme #toolsPage,
body.light-theme #toolsPage,
html.theme-light #toolsPage,
body.theme-light #toolsPage,
[data-theme="light"] #toolsPage,
[data-color-scheme="light"] #toolsPage {
  --tools-bg: var(--bg, #f6f7f9);
  --tools-panel: #ffffff;
  --tools-panel-2: #f8fafc;
  --tools-panel-3: #eef2f6;
  --tools-line: rgba(15,23,42,.12);
}

#toolsPage #toolsContent {
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 18px 32px 56px;
  box-sizing: border-box;
}

#toolsPage .disc-header {
  background: var(--bg) !important;
  padding-bottom: 12px !important;
}

#toolsPage .tools-etf-head,
#toolsPage .tools-etf-head > div,
#toolsPage .tools-etf-chart-top > div {
  min-width: 0;
}

#toolsPage .tools-panel {
  background: transparent !important;
}

#toolsPage .tools-tabs {
  display: flex;
  align-items: center;
  gap: 6px;
  width: 100%;
  max-width: 100%;
  margin: 8px 0 18px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  overflow-x: auto;
  scrollbar-width: none;
}

#toolsPage .tools-tabs::-webkit-scrollbar {
  display: none;
}

#toolsPage .tools-tabs .disc-pill {
  border-color: var(--tools-line) !important;
  background: transparent !important;
  color: var(--muted) !important;
  flex: 0 0 auto;
}

#toolsPage .tools-tabs .disc-pill.active {
  background: var(--text) !important;
  border-color: var(--text) !important;
  color: var(--bg) !important;
}

#toolsPage {
  --tools-bg: #050607;
  --tools-panel: #090c10;
  --tools-panel-2: #0d1117;
  --tools-panel-3: #111722;
  --tools-line: rgba(255,255,255,.125);
}

#toolsPage .tools-tabs {
  position: sticky;
  top: 0;
  z-index: 12;
  background: transparent !important;
  backdrop-filter: none;
}

#toolsPage .tools-stat,
#toolsPage .tools-alt-meter,
#toolsPage .tools-command-center,
#toolsPage .tools-intel-card,
#toolsPage .tools-preview-card,
#toolsPage .tools-pm-card,
#toolsPage .tools-etf-loading,
#toolsPage .tools-etf-summary-card,
#toolsPage .tools-etf-contrib-card,
#toolsPage .tools-etf-chart-card,
#toolsPage .tools-etf-table-card,
#toolsPage .tools-treasury-card,
#toolsPage .tools-ms-grid > *,
#toolsPage .tools-cq-card,
#toolsPage .tools-deriv-card,
#toolsPage .tools-liq-card,
#toolsPage .tools-macro-country-row,
#toolsPage .tools-econ-mobile-card {
  background: linear-gradient(180deg, var(--tools-panel-2), var(--tools-panel)) !important;
  border-color: var(--tools-line) !important;
  box-shadow: 0 18px 45px rgba(0,0,0,.28);
}

#toolsPage .tools-macro-country-row.is-selected {
  border-color: rgba(240,179,90,.78) !important;
  background:
    radial-gradient(circle at 9% 50%, rgba(240,179,90,.28), transparent 42%),
    linear-gradient(90deg, rgba(240,179,90,.22), rgba(255,229,170,.10) 58%, transparent),
    linear-gradient(180deg, color-mix(in srgb, var(--tools-panel-2) 76%, #f0b35a 24%), var(--tools-panel)) !important;
  box-shadow: inset 3px 0 0 #f0b35a, 0 18px 45px rgba(0,0,0,.30), 0 0 0 1px rgba(240,179,90,.20) !important;
}

#toolsPage .tools-intel-read,
#toolsPage .tools-macro-pill,
#toolsPage .tools-alt-stat,
#toolsPage .tools-pm-stat,
#toolsPage .tools-pm-row,
#toolsPage .tools-preview-mini,
#toolsPage .tools-ms-mini-stat,
#toolsPage .tools-deriv-source-row,
#toolsPage .tools-liq-asset-row,
#toolsPage .tools-liq-event-row,
#toolsPage .tools-treasury-adapters span,
#toolsPage .tools-treasury-mstr-stats span,
#toolsPage .tools-treasury-update-row,
#toolsPage .tools-treasury-buy-item,
#toolsPage .tools-etf-meta span,
#toolsPage .tools-etf-read-stats span {
  background: var(--tools-panel-3) !important;
  border-color: var(--tools-line) !important;
}

#toolsPage .tools-etf-assets,
#toolsPage .tools-treasury-segment,
#toolsPage .tools-etf-range,
#toolsPage .tools-etf-share-btn,
#toolsPage .tools-treasury-toggle,
#toolsPage .tools-treasury-buy-filter select {
  background: var(--tools-panel-3) !important;
  border-color: var(--tools-line) !important;
}

#toolsPage .tools-primary-share {
  background: rgba(232,87,42,.22) !important;
  border-color: rgba(232,87,42,.58) !important;
  color: #fff !important;
}

#toolsPage .tools-command-center {
  background:
    radial-gradient(circle at 16% 0%, rgba(232,87,42,.16), transparent 35%),
    linear-gradient(180deg, #101620, #07090c) !important;
  border-color: rgba(255,255,255,.14) !important;
}

#toolsPage .tools-etf-asset.active,
#toolsPage .tools-treasury-segment button.active,
#toolsPage .tools-etf-range.active {
  background: var(--text) !important;
  border-color: var(--text) !important;
  color: var(--bg) !important;
}

#toolsPage .tools-etf-chart,
#toolsPage .tools-treasury-mstr-chart,
#toolsPage .tools-treasury-adds-chart,
#toolsPage .tools-ms-chart {
  background: var(--tools-panel) !important;
  border-color: var(--tools-line) !important;
}

#toolsPage .tools-etf-table th {
  background: var(--tools-panel-2) !important;
}

#toolsPage .tools-etf-table th,
#toolsPage .tools-etf-table td {
  border-bottom-color: var(--tools-line) !important;
}

#toolsPage .tools-cq-card.ok {
  border-left-color: var(--cq-accent, #00bb7f) !important;
}

#toolsPage .tools-intel-title,
#toolsPage .tools-section-title,
#toolsPage .tools-etf-title,
#toolsPage .tools-alt-title,
#toolsPage .tools-pm-title,
#toolsPage .tools-stat-value,
#toolsPage .tools-etf-value,
#toolsPage .tools-ms-big {
  color: var(--text) !important;
  font-weight: 900;
  letter-spacing: 0;
}

#toolsPage .tools-intel-copy,
#toolsPage .tools-section-sub,
#toolsPage .tools-etf-copy,
#toolsPage .tools-alt-sub,
#toolsPage .tools-pm-copy,
#toolsPage .tools-etf-sub,
#toolsPage .tools-pm-row-meta,
#toolsPage .tools-treasury-name {
  color: color-mix(in srgb, var(--muted) 90%, var(--text) 10%) !important;
}

#toolsPage .tools-etf-table tbody tr:hover,
#toolsPage .tools-pm-row:hover,
#toolsPage .tools-preview-card:hover {
  background: var(--tools-panel-2) !important;
  border-color: color-mix(in srgb, var(--tools-line) 70%, var(--accent) 30%) !important;
}

#toolsPage .tools-ai-read {
  margin: 0 0 14px;
  border-color: rgba(240,179,90,.34) !important;
  background:
    linear-gradient(135deg, rgba(240,179,90,.10), transparent 42%),
    linear-gradient(180deg, var(--tools-panel-2), var(--tools-panel)) !important;
  box-shadow: 0 0 0 1px rgba(240,179,90,.045), 0 18px 45px rgba(0,0,0,.24);
}

#toolsPage .tools-ai-read .tools-etf-read-title {
  color: #ffd700;
  font-size: 14px;
  font-weight: 950;
  letter-spacing: .02em;
}

#toolsPage .tools-ai-read .tools-etf-copy b {
  color: var(--text);
}

#toolsPage .tools-ai-read-leverage {
  border-color: rgba(126,188,255,.32) !important;
  background:
    linear-gradient(135deg, rgba(126,188,255,.10), transparent 42%),
    linear-gradient(180deg, var(--tools-panel-2), var(--tools-panel)) !important;
}

#toolsPage .tools-ai-read-liquidations {
  border-color: rgba(255,122,87,.34) !important;
  background:
    linear-gradient(135deg, rgba(255,122,87,.11), transparent 44%),
    linear-gradient(180deg, var(--tools-panel-2), var(--tools-panel)) !important;
}

#toolsPage .tools-ai-read-market {
  border-color: rgba(0,187,127,.28) !important;
  background:
    linear-gradient(135deg, rgba(0,187,127,.10), transparent 44%),
    linear-gradient(180deg, var(--tools-panel-2), var(--tools-panel)) !important;
}

.tools-econ-calendar-wrap {
  display: grid;
  gap: 14px;
  min-width: 0;
}

.tools-econ-summary {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.tools-econ-summary .tools-etf-summary-card:nth-child(1) {
  border-color: rgba(83, 166, 255, .28);
  background: linear-gradient(135deg, rgba(83, 166, 255, .14), var(--tools-card, var(--panel)));
}

.tools-econ-summary .tools-etf-summary-card:nth-child(2) {
  border-color: rgba(255, 122, 87, .3);
  background: linear-gradient(135deg, rgba(255, 122, 87, .13), var(--tools-card, var(--panel)));
}

.tools-econ-summary .tools-etf-summary-card:nth-child(3) {
  border-color: rgba(102, 217, 169, .26);
  background: linear-gradient(135deg, rgba(102, 217, 169, .12), var(--tools-card, var(--panel)));
}

.tools-econ-summary .tools-etf-summary-card:nth-child(4) {
  border-color: rgba(240, 179, 90, .28);
  background: linear-gradient(135deg, rgba(240, 179, 90, .12), var(--tools-card, var(--panel)));
}

.tools-econ-read {
  align-items: center;
}

.tools-econ-ai-read {
  border-color: rgba(255, 215, 0, .46);
  background: var(--tools-card, var(--panel));
  box-shadow: 0 0 0 1px rgba(255, 215, 0, .08), 0 12px 32px rgba(255, 215, 0, .06);
}

.tools-econ-ai-read .tools-etf-read-title {
  color: #ffd700;
  font-size: 14px;
  font-weight: 950;
  letter-spacing: .04em;
}

.tools-econ-ai-read .tools-etf-copy {
  color: var(--text);
  font-size: 15px;
  line-height: 1.55;
  max-width: 820px;
}

.tools-econ-ai-read .tools-etf-read-stats span {
  border-color: rgba(255, 215, 0, .26);
}

.tools-econ-date,
.tools-econ-event {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.tools-econ-date b,
.tools-econ-event b {
  color: var(--text);
  font-weight: 900;
  letter-spacing: 0;
}

.tools-econ-event b {
  display: block;
  font-size: 15px;
  line-height: 1.25;
}

.tools-econ-date span,
.tools-econ-event span {
  color: var(--muted);
  font-size: 11px;
  line-height: 1.35;
}

.tools-econ-row td:first-child {
  position: relative;
}

.tools-econ-row td:first-child::before,
.tools-econ-mobile-card::before {
  content: '';
  position: absolute;
  width: 3px;
  border-radius: 999px;
  background: var(--econ-cat, #7ebcff);
}

.tools-econ-row td:first-child::before {
  left: 0;
  top: 9px;
  bottom: 9px;
}

.tools-econ-mobile-card {
  position: relative;
}

.tools-econ-mobile-card::before {
  left: 0;
  top: 14px;
  bottom: 14px;
}

.tools-econ-cat-inflation { --econ-cat: #ff7a57; }
.tools-econ-cat-labor { --econ-cat: #66d9a9; }
.tools-econ-cat-fed { --econ-cat: #b993ff; }
.tools-econ-cat-growth { --econ-cat: #7ebcff; }
.tools-econ-cat-liquidity { --econ-cat: #f0b35a; }
.tools-econ-cat-sentiment { --econ-cat: #ff8fc7; }
.tools-econ-cat-rates { --econ-cat: #64d2ff; }
.tools-econ-cat-credit { --econ-cat: #ffd166; }
.tools-econ-cat-macro { --econ-cat: #9aa4b2; }

.tools-econ-impact {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 58px;
  padding: 5px 8px;
  border-radius: 999px;
  border: 1px solid var(--tools-line, var(--line));
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .04em;
}

.tools-econ-impact.high {
  color: #ff7a57;
  background: rgba(232,87,42,.15);
  border-color: rgba(232,87,42,.38);
}

.tools-econ-impact.medium {
  color: #f0b35a;
  background: rgba(240,179,90,.13);
  border-color: rgba(240,179,90,.32);
}

.tools-econ-impact.low {
  color: var(--muted);
  background: var(--tools-panel-3, var(--panel-2));
}

.tools-econ-series {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-top: 6px;
}

.tools-econ-series span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  max-width: 100%;
  padding: 4px 7px;
  border: 1px solid var(--tools-line, var(--line));
  border-radius: 999px;
  background: var(--tools-panel-3, var(--panel-2));
  color: var(--muted);
  overflow-wrap: anywhere;
}

.tools-econ-series b {
  color: var(--text);
  font-size: 11px;
}

.tools-econ-table th:first-child,
.tools-econ-table td:first-child {
  width: 120px;
}

.tools-econ-mobile-list {
  display: none;
}

.tools-econ-mobile-card {
  display: grid;
  gap: 10px;
  padding: 14px;
  border-bottom: 1px solid var(--tools-line, var(--line));
}

.tools-econ-mobile-cat {
  margin-top: -6px;
  color: var(--econ-cat, var(--muted));
  font-size: 11px;
  font-weight: 850;
  letter-spacing: .02em;
}

.tools-econ-mobile-top,
.tools-econ-mobile-metrics {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.tools-econ-mobile-top span,
.tools-econ-mobile-metrics span {
  display: grid;
  gap: 2px;
}

.tools-econ-mobile-top b,
.tools-econ-mobile-metrics b {
  color: var(--text);
  font-weight: 850;
}

.tools-econ-mobile-top em,
.tools-econ-mobile-metrics em {
  color: var(--muted);
  font-size: 10px;
  font-style: normal;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.tools-econ-mobile-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.tools-stock-symbol {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  min-width: 0;
}

.tools-stock-symbol b {
  color: var(--text);
  font-size: 14px;
  font-weight: 900;
}

.tools-stock-logo,
.tools-stock-logo-fallback {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  flex: 0 0 26px;
}

.tools-stock-logo {
  display: block;
  object-fit: contain;
  background: #fff;
  border: 1px solid var(--tools-line, var(--line));
}

.tools-stock-logo-fallback {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--tools-panel-3, var(--panel-2));
  border: 1px solid var(--tools-line, var(--line));
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
}

@media (max-width: 600px) {
  #toolsPage #toolsContent {
    width: 100%;
    max-width: 100%;
    padding: 12px 14px calc(var(--mobile-bottom-nav-h, 64px) + 78px) !important;
    overflow-x: hidden;
  }

  #toolsPage .disc-header {
    padding: 14px 14px 10px !important;
  }

  #toolsPage .tools-strip {
    grid-template-columns: 1fr !important;
    gap: 10px;
    width: 100%;
    max-width: 100%;
  }

  #toolsPage .tools-stat {
    min-width: 0;
    padding: 13px 14px;
  }

  #toolsPage .tools-stat-value,
  #toolsPage .tools-etf-value,
  #toolsPage .tools-intel-value {
    white-space: normal;
    overflow: visible;
    text-overflow: clip;
  }

      #toolsPage .tools-alt-meter {
        padding: 15px;
        overflow: hidden;
      }

      #toolsPage .tools-command-center {
        grid-template-columns: 1fr;
        gap: 12px;
        padding: 14px;
        border-radius: 12px;
      }

      #toolsPage .tools-command-title {
        font-size: 21px;
        line-height: 1.12;
      }

      #toolsPage .tools-command-drivers {
        grid-template-columns: 1fr;
        gap: 7px;
      }

      #toolsPage .tools-command-side {
        border-left: 0;
        border-top: 1px solid rgba(255,255,255,.12);
        padding-left: 0;
        padding-top: 12px;
      }

      #toolsPage .tools-command-score {
        font-size: 34px;
      }

  #toolsPage .tools-alt-top {
    display: grid;
    gap: 10px;
  }

  #toolsPage .tools-alt-badge {
    width: max-content;
  }

  #toolsPage .tools-alt-grid,
  #toolsPage .tools-intel-grid,
  #toolsPage .tools-preview-grid,
  #toolsPage .tools-pm-grid {
    grid-template-columns: 1fr !important;
  }

      #toolsPage .tools-intel-card,
      #toolsPage .tools-etf-summary-card,
  #toolsPage .tools-etf-contrib-card,
  #toolsPage .tools-etf-chart-card,
  #toolsPage .tools-etf-table-card,
  #toolsPage .tools-treasury-card,
  #toolsPage .tools-pm-card {
    min-width: 0;
  }

  .tools-econ-summary {
    grid-template-columns: 1fr;
  }

  .tools-econ-table {
    display: none;
  }

  .tools-econ-table-card .tools-etf-table-scroll {
    display: none;
  }

  .tools-econ-mobile-list {
    display: grid;
  }

  .tools-econ-table-card .tools-etf-copy {
    white-space: normal;
    overflow-wrap: anywhere;
  }

  .tools-econ-read {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .tools-econ-read .tools-etf-copy {
    white-space: normal;
    overflow-wrap: anywhere;
  }

  .tools-econ-read .tools-etf-read-stats {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: flex-start;
  }

  .tools-econ-mobile-card {
    padding: 14px 12px;
    overflow: hidden;
  }

  .tools-econ-mobile-top {
    display: grid;
    grid-template-columns: minmax(0, 1fr) max-content;
  }

  .tools-econ-mobile-card .tools-econ-impact {
    display: none;
  }

  .tools-econ-mobile-card .tools-etf-title {
    font-size: 17px;
    line-height: 1.22;
  }

  .econ-cal-controls .tools-etf-assets,
  .econ-cal-controls .tools-etf-ranges {
    width: 100%;
  }
}

@media (min-width: 981px) and (max-width: 1700px) {
  .coins-shell {
    padding-left: 14px;
    padding-right: 14px;
  }
  .coins-table {
    min-width: 100%;
    table-layout: fixed;
  }
  .coins-table th:nth-child(1),
  .coins-table td:nth-child(1) {
    width: 44px;
  }
  .coins-table th:nth-child(2),
  .coins-table td:nth-child(2) {
    width: 76px;
  }
  .coins-table th:nth-child(3),
  .coins-table td:nth-child(3) {
    width: 204px;
  }
  .coins-table th:nth-child(3) {
    padding-left: 39px;
  }
  .coins-table th:nth-child(4),
  .coins-table td:nth-child(4),
  .coins-table th:nth-child(5),
  .coins-table td:nth-child(5),
  .coins-table th:nth-child(6),
  .coins-table td:nth-child(6),
  .coins-table th:nth-child(7),
  .coins-table td:nth-child(7),
  .coins-table th:nth-child(8),
  .coins-table td:nth-child(8) {
    width: 70px;
  }
  .coins-table th:nth-child(9),
  .coins-table td:nth-child(9),
  .coins-table th:nth-child(10),
  .coins-table td:nth-child(10),
  .coins-table th:nth-child(11),
  .coins-table td:nth-child(11) {
    width: 116px;
    min-width: 0;
  }
  .coins-table th:nth-child(12),
  .coins-table td:nth-child(12) {
    width: 104px;
    min-width: 0;
  }
  .coins-detail-extra {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 981px) and (max-width: 1200px) {
  .coins-table th,
  .coins-table td {
    padding-left: 7px;
    padding-right: 7px;
    font-size: 12px;
  }
  .coins-table th {
    font-size: 10px;
  }
  .coins-table th:nth-child(8),
  .coins-table td:nth-child(8),
  .coins-table th:nth-child(10),
  .coins-table td:nth-child(10) {
    display: none;
  }
  .coins-table th:nth-child(1),
  .coins-table td:nth-child(1) {
    width: 34px;
  }
  .coins-table th:nth-child(2),
  .coins-table td:nth-child(2) {
    width: 68px;
  }
  .coins-table th:nth-child(3),
  .coins-table td:nth-child(3) {
    width: 174px;
  }
  .coins-table th:nth-child(3) {
    padding-left: 38px;
  }
  .coins-table th:nth-child(4),
  .coins-table td:nth-child(4),
  .coins-table th:nth-child(5),
  .coins-table td:nth-child(5),
  .coins-table th:nth-child(6),
  .coins-table td:nth-child(6),
  .coins-table th:nth-child(7),
  .coins-table td:nth-child(7) {
    width: 66px;
  }
  .coins-table th:nth-child(9),
  .coins-table td:nth-child(9) {
    width: 96px;
  }
  .coins-table th:nth-child(12),
  .coins-table td:nth-child(12) {
    width: 104px;
  }
  .coins-spark {
    width: 82px;
    height: 38px;
  }
  .coins-row-ask {
    min-width: 0;
  }
  .coins-asset {
    gap: 7px;
  }
}

@media (max-width: 980px) {
  .coins-shell {
    padding: 24px 16px calc(var(--mobile-bottom-nav-h, 64px) + 28px);
    max-width: 100%;
  }
  .coins-hero,
  .coins-toolbar {
    flex-direction: column;
  }
  .coins-mood-grid,
  .coins-movers {
    grid-template-columns: 1fr;
  }
  .coins-read-main {
    grid-template-columns: 1fr;
    align-items: flex-start;
  }
  .coins-fng-wheel {
    justify-self: flex-start;
  }
  .coins-read-drivers {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .coins-controls,
  .coins-search,
  .coins-search input,
  .coins-timeframes {
    width: 100%;
  }
  .coins-timeframes button {
    flex: 1;
  }
  .coins-filter-pills {
    width: 100%;
    overflow-x: visible;
    flex-wrap: wrap;
  }
  .coins-watchlist-filter {
    width: 100%;
    justify-content: flex-end;
  }
  .coins-filter-pills button {
    flex: 1 0 auto;
  }
  .coins-sector-select {
    flex: 1 0 132px;
    min-width: 132px;
  }
  .coins-title {
    font-size: 32px;
  }
  .coins-sub {
    max-width: 100%;
    overflow-wrap: normal;
  }
}

@media (max-width: 600px) {
  .coins-shell {
    padding-top: 22px;
    padding-bottom: calc(var(--mobile-bottom-nav-h, 64px) + 96px);
    width: calc(100vw - 32px);
    max-width: 100%;
    margin: 0 auto;
    padding-left: 0;
    padding-right: 0;
    overflow-x: hidden;
  }
  .coins-hero,
  .coins-sub,
  .coins-main-card {
    width: 100%;
    max-width: 100%;
  }
  .coins-hero {
    margin-bottom: 16px;
  }
  .coins-mood-grid {
    width: 100%;
    max-width: 100%;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    overflow: visible;
    padding-bottom: 0;
  }
  .coins-mood-card {
    width: 100%;
    min-width: 0;
    padding: 12px;
  }
  .coins-mood-card b {
    font-size: 19px;
    white-space: normal;
  }
  .coins-market-read {
    width: 100%;
    max-width: 100%;
  }
  .coins-read-main,
  .coins-read-drivers,
  .coins-read-questions {
    padding-left: 10px;
    padding-right: 10px;
  }
  .coins-read-main strong {
    font-size: 20px;
  }
  .coins-read-drivers {
    grid-template-columns: 1fr;
  }
  .coins-read-question-row,
  .coins-read-questions button,
  .coins-ask-pills button {
    width: 100%;
  }
  .coins-read-questions-head {
    align-items: flex-start;
    flex-direction: column;
    gap: 2px;
  }
  .coins-read-questions button,
  .coins-ask-pills button {
    border-radius: 9px;
    text-align: left;
  }
  .coins-sub,
  .coins-mood-card em {
    overflow-wrap: anywhere;
  }
  .tools-macro-map-layout,
  .tools-macro-map-summary {
    grid-template-columns: 1fr;
  }
  .tools-macro-map-svg {
    min-height: 0;
  }
  .tools-macro-country-list {
    max-height: none;
  }
  .tools-macro-country-row {
    grid-template-columns: 24px minmax(0, 1fr) minmax(80px, auto);
  }
  .tools-macro-bar {
    display: none;
  }
  .coins-main-card {
    width: 100%;
  }
  .coins-movers {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 8px;
    padding: 8px 12px;
    overflow: visible;
    border-bottom: 1px solid var(--line);
  }
  .coins-movers > div {
    display: flex;
    align-items: center;
    gap: 8px;
    width: 100%;
    min-width: 0;
    padding: 8px 10px;
    border-radius: 9px;
  }
  .coins-movers strong {
    flex: 0 0 auto;
    margin: 0;
    font-size: 11px;
  }
  .coins-movers > div > div {
    display: flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
  }
  .coins-movers button {
    width: auto;
    gap: 5px;
    padding: 0;
    font-size: 11px;
  }
  .coins-movers button:nth-child(n+3) {
    display: none;
  }
  .coins-movers button img,
  .coins-movers .coins-logo-fallback {
    width: 18px;
    height: 18px;
  }
  .coins-movers button span {
    gap: 5px;
  }
  .coins-timeframes {
    order: 3;
    min-width: 0;
    overflow-x: auto;
    scrollbar-width: none;
  }
  .coins-controls {
    min-width: 0;
    max-width: 100%;
    overflow: hidden;
  }
  .coins-timeframes::-webkit-scrollbar {
    display: none;
  }
  .coins-filter-pills {
    order: 5;
    display: flex;
    flex-wrap: wrap;
    overflow: visible;
    padding-bottom: 1px;
  }
  .coins-watchlist-filter {
    order: 4;
  }
  .coins-filter-pills button {
    flex: 1 1 calc(50% - 6px);
  }
  .coins-sector-select {
    flex: 1 1 100%;
    width: 100%;
  }
  .coins-tags {
    display: none !important;
  }
  .coins-mobile-tags {
    display: flex !important;
    gap: 3px;
    margin-top: 3px;
  }
  .coins-mobile-tags em {
    height: 15px;
    padding: 0 5px;
    font-size: 8.5px;
  }
  .coins-skeleton-row {
    grid-template-columns: 28px 1fr 78px;
    padding: 12px;
  }
  .coins-skeleton-row em {
    display: none;
  }
  .coins-table {
    display: none;
  }
  .token-intel-table {
    display: none;
  }
  .token-intel-mobile-list {
    display: grid;
    gap: 8px;
    padding: 10px;
  }
  .token-intel-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    padding: 10px;
  }
  .token-intel-controls {
    justify-content: stretch;
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
  }
  .token-intel-card .coins-search,
  .token-intel-card .coins-sector-select {
    width: 100%;
  }
  .coins-table-wrap {
    overflow-x: hidden;
  }
  .token-intel-page .coins-table-wrap {
    overflow-x: hidden;
  }
  .coins-mobile-list {
    display: grid;
    gap: 8px;
    padding: 8px 10px 14px;
  }
  .coins-mobile-card {
    display: block;
    width: 100%;
    border: 1px solid var(--line);
    border-radius: 10px;
    background: color-mix(in srgb, var(--panel-2) 70%, #050505 30%);
    color: var(--text);
    padding: 9px 10px;
    text-align: left;
    min-height: 0;
  }
  .coins-mobile-top {
    display: grid;
    grid-template-columns: 24px minmax(0, 1fr) auto;
    align-items: center;
    gap: 8px;
    min-width: 0;
  }
  .coins-mobile-rank {
    color: var(--muted);
    font-size: 11px;
    font-weight: 800;
    text-align: right;
    font-variant-numeric: tabular-nums;
  }
  .coins-mobile-top .coins-asset {
    min-width: 0;
    gap: 8px;
  }
  .coins-mobile-top .coins-asset img,
  .coins-mobile-top .coins-asset .coins-logo-fallback {
    width: 24px;
    height: 24px;
  }
  .coins-mobile-top .coins-asset > div {
    min-width: 0;
  }
  .coins-mobile-top .coins-asset strong,
  .coins-mobile-top .coins-asset span {
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .coins-mobile-top .coins-asset strong {
    font-size: 13px;
  }
  .coins-mobile-top .coins-asset span {
    font-size: 10px;
    text-transform: none;
  }
  .coins-mobile-price {
    display: grid;
    gap: 1px;
    text-align: right;
    min-width: 0;
    max-width: 104px;
    overflow: hidden;
  }
  .coins-mobile-price strong {
    color: var(--text);
    font-size: 12.5px;
    font-weight: 900;
    font-variant-numeric: tabular-nums;
  }
  .coins-mobile-price span {
    font-size: 10.5px;
    font-weight: 900;
    font-variant-numeric: tabular-nums;
  }
  .coins-mobile-bottom {
    display: none;
    align-items: center;
    justify-content: flex-start;
    gap: 10px;
    min-width: 0;
    padding-left: 30px;
    color: var(--muted);
    font-size: 10px;
    font-weight: 800;
    font-variant-numeric: tabular-nums;
  }
  .coins-mobile-bottom span {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .coins-mobile-bottom span:first-child {
    color: var(--text);
  }
  .coins-mobile-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 6px;
    margin-top: 8px;
    color: var(--muted);
    font-size: 9px;
    text-align: left;
    font-weight: 850;
    text-transform: uppercase;
    letter-spacing: .02em;
  }
  .coins-mobile-metrics span {
    min-width: 0;
    text-align: left;
    overflow: hidden;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(255,255,255,.025);
    padding: 6px 7px;
  }
  .coins-mobile-metrics em {
    display: block;
    color: var(--muted);
    font-style: normal;
    font-size: 8.5px;
    line-height: 1.05;
  }
  .coins-mobile-metrics b {
    display: block;
    margin-top: 3px;
    color: var(--text);
    font-size: 11px;
    line-height: 1.08;
    font-variant-numeric: tabular-nums;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .coins-mobile-bottom .coins-spark {
    display: none;
  }
  .coins-mobile-card.coins-row-open {
    border-color: var(--line);
    background: color-mix(in srgb, var(--panel-2) 90%, var(--accent) 5%);
  }
  .coins-detail-panel {
    padding: 10px;
    border: 1px solid var(--coins-line);
    border-radius: 12px;
    background: var(--coins-panel);
    margin: 8px 8px 10px;
    width: auto;
    max-width: none;
  }
  .coins-detail-head,
  .coins-detail-grid,
  .coins-detail-stats,
  .coins-detail-extra {
    grid-template-columns: 1fr;
  }
  .coins-detail-head {
    flex-direction: column;
    align-items: stretch;
  }
  .coins-detail-actions {
    justify-content: stretch;
  }
  .coins-ask-pills {
    width: 100%;
  }
  .coins-ask-pills span {
    width: 100%;
  }
  .coins-ask-pills button {
    flex: 1;
  }
  .coins-range-pills {
    width: 100%;
  }
  .coins-range-pills button {
    flex: 1;
  }
  .coins-back-btn,
  .coins-ask-btn {
    width: 100%;
  }
  .coins-detail-price {
    font-size: 24px;
  }
  .coins-detail-chart {
    min-height: 202px;
    padding: 8px;
  }
  .coins-full-chart {
    min-height: 190px;
  }
  .coins-detail-main,
  .coins-detail-chart,
  .coins-detail-stats,
  .coins-detail-extra section {
    padding: 10px;
  }
  .coins-detail-main,
  .coins-detail-chart,
  .coins-detail-stats,
  .coins-detail-extra section,
  .coins-quality-card {
    position: relative;
    z-index: 0;
    overflow: hidden;
    contain: layout paint;
  }
  .coins-thesis-panel {
    margin-top: 10px;
    padding: 10px;
    border-radius: 10px;
  }
  .coins-thesis-head b {
    font-size: 13px;
  }
  .coins-thesis-panel p {
    display: none;
  }
  .coins-thesis-tags {
    margin-top: 8px;
  }
  .coins-thesis-grid {
    gap: 6px;
    margin-top: 8px;
  }
  .coins-thesis-grid span {
    padding: 7px;
  }
  .coins-thesis-grid b {
    font-size: 11px;
    line-height: 1.25;
  }
  .coins-detail-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 6px;
  }
  .coins-detail-stats span {
    gap: 2px;
    font-size: 9.5px;
  }
  .coins-detail-stats b {
    font-size: 12px;
  }
  .coins-detail-stats span:nth-child(n+7) {
    display: none;
  }
  .coins-detail-extra {
    display: flex;
    flex-direction: column;
    gap: 7px;
  }
  .coins-detail-extra section {
    border-radius: 10px;
  }
  .coins-extra-title {
    font-size: 12px;
    margin-bottom: 0;
  }
  .coins-extra-sub {
    display: none;
  }
  .coins-market-row {
    grid-template-columns: minmax(0, 1fr) auto;
    padding: 7px 0;
  }
  .coins-market-row em {
    display: none;
  }
  .coins-market-row strong,
  .coins-news-row strong {
    font-size: 11.5px;
  }
  .coins-market-row b {
    font-size: 11px;
  }
  .coins-quality-card {
    margin-top: 8px;
    padding: 9px;
    border-radius: 9px;
  }
  .coins-quality-top b {
    font-size: 17px;
  }
  .coins-quality-top i {
    font-size: 15px;
  }
  .coins-quality-bar {
    height: 5px;
    margin-top: 6px;
  }
  .coins-quality-card p,
  .coins-quality-flags,
  .coins-quality-pop {
    display: none;
  }
  .coins-quality-metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 6px;
    margin-top: 8px;
  }
  .coins-quality-metrics span {
    font-size: 8.5px;
  }
  .coins-quality-metrics b {
    font-size: 10.5px;
  }
  .coins-quality-metrics span:nth-child(n+5) {
    display: none;
  }
  .coins-tokenomics-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 6px;
  }
  .coins-tokenomics-grid span {
    padding: 8px;
  }
  .coins-tokenomics-grid span:nth-child(n+7) {
    display: none;
  }
  .coins-profile-links {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 6px;
  }
  .coins-profile-link {
    min-height: 34px;
    padding: 6px 8px;
  }
  .coins-news-row {
    min-height: 48px;
    padding: 7px;
  }
  .coins-news-thumb {
    width: 34px;
    height: 34px;
  }
  .coins-pressure-preview-grid {
    grid-template-columns: 1fr;
  }
}

/* Cross-page polish: pull secondary surfaces closer to the homepage system. */
.answers-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.answers-grid .disc-item {
  border-radius: 16px;
  background: color-mix(in srgb, var(--panel) 88%, var(--accent) 4%);
}

.answers-photo {
  aspect-ratio: 1 / .54;
  border-radius: 12px;
}

.answers-read {
  font-size: 12px;
  letter-spacing: .01em;
}

.portfolio-page.pf-logged-out .pf-empty {
  max-width: 760px;
  margin: 0 auto;
  padding-top: 72px;
}

.portfolio-page.pf-logged-out .pf-empty-icon {
  width: 66px;
  height: 66px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 20px;
  margin-bottom: 18px;
  background: linear-gradient(145deg, rgba(232,87,42,.22), rgba(255,255,255,.045));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.1), 0 18px 42px rgba(0,0,0,.2);
}

.portfolio-page.pf-logged-out .pf-empty-actions {
  margin-top: 20px;
}

.portfolio-page.pf-logged-out .pf-empty-preview-card {
  background: color-mix(in srgb, var(--panel) 90%, var(--accent) 4%);
  border-radius: 16px;
  padding: 14px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.045);
}

.portfolio-page.pf-logged-out .pf-empty-preview-top {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 7px;
}

.portfolio-page.pf-logged-out .pf-empty-preview-top span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 999px;
  color: var(--accent);
  background: rgba(232,87,42,.12);
  font-size: 10px;
  font-weight: 850;
  letter-spacing: .02em;
}

.portfolio-page.pf-logged-out .pf-empty-preview-top b {
  color: var(--text);
  font-size: 12px;
  font-weight: 850;
  letter-spacing: .01em;
}

#toolsPredictionMarkets.tools-pm-card {
  background: linear-gradient(145deg, color-mix(in srgb, var(--panel) 88%, var(--accent) 7%), var(--panel));
  border-radius: 16px;
}

.tools-pm-title {
  font-size: 20px;
}

.tools-strip {
  opacity: .92;
}

@media (max-width: 900px) {
  .answers-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .pm-top-picks-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 600px) {
  .answers-grid {
    grid-template-columns: 1fr;
  }

  .answers-featured-row {
    grid-template-columns: 1fr;
    padding-left: 16px;
    padding-right: 16px;
  }

  .answers-photo {
    aspect-ratio: 1 / .45;
  }

  .pm-top-picks {
    padding: 11px;
  }

  .portfolio-page.pf-logged-out .pf-empty {
    padding-top: 46px;
    width: 100%;
    max-width: 100%;
    margin-left: 0;
    margin-right: 0;
    box-sizing: border-box;
    overflow: hidden;
    transform: none;
  }

  .portfolio-page.pf-logged-out .pf-empty-product {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 auto !important;
  }

  .portfolio-page.pf-logged-out .pf-empty-copy {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 auto !important;
  }

  .portfolio-page.pf-logged-out .pf-empty-title,
  .portfolio-page.pf-logged-out .pf-empty-text {
    max-width: min(320px, calc(100vw - 48px));
  }

  .portfolio-page.pf-logged-out .pf-empty-preview {
    width: 100%;
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
  }
}

/* Final mobile pass for secondary navs, Intel charts, and wide data surfaces. */
@media (max-width: 600px) {
  #toolsPage,
  #toolsPage *,
  #toolsPage *::before,
  #toolsPage *::after {
    max-width: 100%;
    box-sizing: border-box;
  }

  #toolsPage {
    overflow-x: clip !important;
  }

  #toolsPage .tools-panel.active,
  #toolsPage .tools-section,
  #toolsPage .tools-market-structure-wrap,
  #toolsPage .tools-econ-calendar-wrap,
  #toolsPage .tools-etf-wrap,
  #toolsPage .tools-treasury-wrap,
  #toolsPage .tools-cq-section,
  #toolsPage .tools-pm-card {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow: visible !important;
  }

  #toolsPage .tools-etf-head,
  #toolsPage .tools-etf-controls,
  #toolsPage .tools-etf-chart-top,
  #toolsPage .tools-ms-asset-head,
  #toolsPage .tools-pm-head,
  #toolsPage .tools-section-head {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    align-items: start !important;
    gap: 10px !important;
  }

  #toolsPage .tools-section-title,
  #toolsPage .tools-etf-title,
  #toolsPage .tools-pm-title,
  #toolsPage .tools-command-title,
  #toolsPage .tools-cq-title,
  #toolsPage .tools-stock-symbol b {
    white-space: normal !important;
    overflow-wrap: anywhere !important;
    text-overflow: clip !important;
  }

  #toolsPage .tools-etf-read-card,
  #toolsPage .tools-ai-read,
  #toolsPage .tools-cq-read {
    width: 100% !important;
    max-width: 100% !important;
    overflow: hidden !important;
  }

  #toolsPage .tools-etf-read-card {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 12px !important;
  }

  #toolsPage .tools-etf-read-card > div,
  #toolsPage .tools-etf-read-card .tools-etf-copy {
    min-width: 0 !important;
    max-width: 100% !important;
  }

  #toolsPage .tools-etf-read-stats {
    width: 100% !important;
    min-width: 0 !important;
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: flex-start !important;
  }

  #toolsPage .tools-etf-read-stats span {
    min-width: 0 !important;
    white-space: nowrap !important;
  }

  #toolsPage .tools-pressure-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  #toolsPage #toolsLeveragePressureAssets {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    width: 100% !important;
    max-width: 100% !important;
    overflow: hidden !important;
  }

  #toolsPage [data-tools-panel="leverage-pressure"],
  #toolsPage #toolsLeveragePressureContent,
  #toolsPage #toolsLeveragePressureContent > *,
  #toolsPage .tools-pressure-layout,
  #toolsPage .tools-ai-read-pressure {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow-x: visible !important;
  }

  #toolsPage [data-tools-panel="leverage-pressure"] .tools-pressure-summary {
    grid-template-columns: 1fr !important;
  }

  #toolsPage [data-tools-panel="leverage-pressure"] .tools-section-sub,
  #toolsPage [data-tools-panel="leverage-pressure"] .tools-etf-copy {
    width: auto !important;
    max-width: 100% !important;
    white-space: normal !important;
    overflow: visible !important;
    overflow-wrap: anywhere !important;
  }

  #toolsPage [data-tools-panel="leverage-pressure"] .tools-pressure-heatmap-wrap {
    width: 100% !important;
    max-width: 100% !important;
    overflow: visible !important;
  }

  #toolsPage [data-tools-panel="leverage-pressure"] .tools-pressure-pan {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
  }

  #toolsPage [data-tools-panel="leverage-pressure"] .tools-pressure-chart,
  #toolsPage [data-tools-panel="leverage-pressure"] .tools-pressure-heatmap {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
  }

  #toolsPage [data-tools-panel="leverage-pressure"] .tools-liq-event-list {
    grid-template-columns: 1fr !important;
  }

  #toolsPage [data-tools-panel="leverage-pressure"] .tools-liq-event-row {
    grid-template-columns: minmax(0, 1fr) auto !important;
    align-items: start !important;
    gap: 6px 10px !important;
    padding: 11px 12px 11px 14px !important;
  }

  #toolsPage [data-tools-panel="leverage-pressure"] .tools-liq-event-row span {
    display: grid !important;
    grid-template-columns: auto auto !important;
    justify-content: start !important;
  }

  #toolsPage [data-tools-panel="leverage-pressure"] .tools-liq-event-row small {
    overflow-wrap: anywhere !important;
  }

  #toolsPage [data-tools-panel="leverage-pressure"] .tools-pressure-action-read {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    overflow: visible !important;
    min-height: 0 !important;
  }

  #toolsPage [data-tools-panel="leverage-pressure"] .tools-pressure-action-read b,
  #toolsPage [data-tools-panel="leverage-pressure"] .tools-pressure-action-read span {
    display: block !important;
    width: calc(100vw - 86px) !important;
    inline-size: calc(100vw - 86px) !important;
    max-width: calc(100vw - 86px) !important;
    white-space: normal !important;
    overflow: visible !important;
    text-overflow: clip !important;
    overflow-wrap: break-word !important;
    word-break: normal !important;
  }

  #toolsPage [data-tools-panel="leverage-pressure"] .tools-etf-head .tools-section-sub {
    display: none !important;
  }

  #toolsPage [data-tools-panel="leverage-pressure"] .tools-pressure-action-read b {
    margin-bottom: 5px !important;
  }

  #toolsPage [data-tools-panel="leverage-pressure"] {
    padding-bottom: 156px !important;
    width: calc(100vw - 28px) !important;
    max-width: calc(100vw - 28px) !important;
    overflow-x: hidden !important;
  }

  #toolsPage [data-tools-panel="leverage-pressure"] .tools-etf-head,
  #toolsPage [data-tools-panel="leverage-pressure"] .tools-section-head {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 10px !important;
  }

  #toolsPage [data-tools-panel="leverage-pressure"] .tools-etf-head .tools-etf-share-btn,
  #toolsPage [data-tools-panel="leverage-pressure"] .tools-section-head .tools-etf-share-btn {
    width: 100% !important;
    justify-content: center !important;
  }

  #toolsPage [data-tools-panel="leverage-pressure"] .tools-etf-head > .tools-etf-share-btn {
    display: none !important;
  }

  #toolsPage [data-tools-panel="leverage-pressure"] .tools-section-sub,
  #toolsPage [data-tools-panel="leverage-pressure"] .tools-etf-copy {
    width: calc(100vw - 56px) !important;
    inline-size: calc(100vw - 56px) !important;
    max-width: calc(100vw - 56px) !important;
    min-width: 0 !important;
    overflow-wrap: break-word !important;
    word-break: normal !important;
  }

  #toolsPage [data-tools-panel="leverage-pressure"] .tools-etf-controls,
  #toolsPage [data-tools-panel="leverage-pressure"] #toolsLeveragePressureContent,
  #toolsPage [data-tools-panel="leverage-pressure"] .tools-pressure-layout,
  #toolsPage [data-tools-panel="leverage-pressure"] .tools-etf-summary,
  #toolsPage [data-tools-panel="leverage-pressure"] .tools-pressure-chart-card,
  #toolsPage [data-tools-panel="leverage-pressure"] .tools-etf-table-card {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }

  #toolsPage [data-tools-panel="leverage-pressure"] .tools-etf-meta {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 6px !important;
  }

  #toolsPage [data-tools-panel="leverage-pressure"] .tools-etf-meta span {
    padding: 7px 9px !important;
    width: 100% !important;
    white-space: normal !important;
    line-height: 1.2 !important;
  }

  #toolsPage [data-tools-panel="leverage-pressure"] .tools-pressure-chart-card .tools-etf-chart-actions {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 7px !important;
    width: 100% !important;
  }

  #toolsPage [data-tools-panel="leverage-pressure"] .tools-pressure-window {
    grid-column: 1 / -1 !important;
  }

  #toolsPage [data-tools-panel="leverage-pressure"] .tools-pressure-pan {
    overflow-x: hidden !important;
  }

  #toolsPage [data-tools-panel="leverage-pressure"] .tools-pressure-heatmap-wrap,
  #toolsPage [data-tools-panel="leverage-pressure"] .tools-pressure-pan {
    max-width: 100% !important;
    min-width: 0 !important;
  }

  #toolsPage [data-tools-panel="leverage-pressure"] .tools-pressure-pan {
    overflow-x: hidden !important;
    overflow-y: hidden !important;
  }

  #toolsPage [data-tools-panel="leverage-pressure"] .tools-pressure-canvas-map {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    min-height: 0 !important;
    height: auto !important;
    aspect-ratio: 1080 / 580 !important;
    grid-template-columns: 28px minmax(0, 1fr) !important;
    gap: 5px !important;
    padding: 6px !important;
  }

  #toolsPage [data-tools-panel="leverage-pressure"] .tools-pressure-canvas-stage {
    grid-template-rows: minmax(0, 1fr) 24px !important;
    gap: 4px !important;
  }

  #toolsPage [data-tools-panel="leverage-pressure"] .tools-pressure-canvas-scale {
    font-size: 8px !important;
    gap: 4px !important;
  }

  #toolsPage [data-tools-panel="leverage-pressure"] .tools-pressure-canvas-scale canvas {
    width: 14px !important;
  }

  #toolsPage [data-tools-panel="leverage-pressure"] .tools-pressure-canvas-stage canvas[data-pressure-heatmap-mini] {
    height: 24px !important;
  }

  #toolsPage [data-tools-panel="leverage-pressure"] .tools-pressure-mini-map .tools-pressure-chart {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }

  :root {
    --mobile-bottom-nav-h: calc(62px + env(safe-area-inset-bottom, 0px));
    --mobile-secondary-nav-h: 54px;
  }

  body,
  .app,
  .main-content,
  .content {
    max-width: 100vw;
    overflow-x: hidden;
  }

  .disc-sub,
  .tools-section-sub,
  .tools-etf-copy,
  .tools-intel-copy,
  .answer-text,
  .answer-card,
  .disc-mag-headline,
  .disc-mag-excerpt {
    max-width: 100%;
    overflow-wrap: anywhere;
    word-break: normal;
  }

  #toolsPage .disc-header-top,
  #toolsPage .disc-header-top > div,
  #toolsPage .tools-etf-head > div,
  #toolsPage .tools-section-head > div {
    min-width: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  #answersPage .disc-sub,
  #toolsPage .disc-sub,
  .discovery-page .disc-sub,
  #toolsPage .tools-section-sub,
  #toolsPage .tools-etf-copy,
  #toolsPage .tools-intel-copy,
  #toolsPage .tools-cq-read {
    display: block !important;
    flex: 0 0 100% !important;
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    white-space: normal !important;
    overflow: visible !important;
    text-overflow: clip !important;
    overflow-wrap: anywhere !important;
    word-break: normal !important;
  }

  #toolsPage .tools-panel.active,
  #toolsPage .tools-etf-head,
  #toolsPage .tools-etf-head > div,
  #toolsPage .tools-exflow-card,
  #toolsPage .tools-exflow-grid > *,
  #toolsPage .tools-exflow-read,
  #toolsPage .tools-etf-read-card,
  #toolsPage .tools-chain-layout,
  #toolsPage .tools-chain-card,
  #toolsPage .tools-etf-table-card {
    width: 100% !important;
    max-width: calc(100vw - 28px) !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  #toolsPage .tools-chain-card .tools-etf-chart-top {
    grid-template-columns: minmax(0, 1fr) auto !important;
    align-items: start !important;
  }

  #toolsPage .tools-chain-card .tools-etf-share-btn {
    width: auto !important;
    min-width: 64px;
    justify-self: end;
  }

  #toolsPage .tools-etf-head .tools-etf-copy,
  #toolsPage .tools-etf-head .tools-section-sub,
  #toolsPage .tools-exflow-read,
  #toolsPage .tools-etf-read-card .tools-etf-copy,
  #toolsPage .tools-chain-card .tools-etf-copy {
    width: min(300px, calc(100vw - 72px)) !important;
    max-width: min(300px, calc(100vw - 72px)) !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
  }

  #toolsPage .tools-etf-head .tools-etf-copy,
  #toolsPage .tools-etf-head .tools-section-sub {
    width: min(260px, calc(100vw - 96px)) !important;
    max-width: min(260px, calc(100vw - 96px)) !important;
  }

  #toolsPage [data-tools-panel="chain-tvl"] .tools-section-sub {
    width: min(260px, calc(100vw - 96px)) !important;
    max-width: min(260px, calc(100vw - 96px)) !important;
  }

  #toolsContent {
    width: calc(100vw - 28px) !important;
    max-width: calc(100vw - 28px) !important;
    box-sizing: border-box !important;
    padding-left: 14px !important;
    padding-right: 14px !important;
    padding-bottom: calc(var(--mobile-bottom-nav-h) + var(--mobile-secondary-nav-h) + 58px) !important;
    overflow-x: hidden !important;
  }

  #toolsPage .disc-header,
  #answersPage .disc-header,
  .discovery-page .disc-header {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    overflow-x: hidden;
  }

  #toolsPage .disc-header > *,
  #answersPage .disc-header > *,
  .discovery-page .disc-header > * {
    max-width: 100%;
    min-width: 0;
  }

  .discovery-page.visible .disc-feed,
  .discovery-page.visible .disc-mag,
  .discovery-page.visible .lane-mag {
    padding-bottom: calc(var(--mobile-bottom-nav-h) + var(--mobile-secondary-nav-h) + 58px) !important;
  }

  #toolsPage.visible .tools-tabs,
  .discovery-page.visible .disc-categories-wrap {
    left: 10px !important;
    right: 10px !important;
    top: auto !important;
    bottom: var(--mobile-bottom-nav-h) !important;
    position: fixed !important;
    height: var(--mobile-secondary-nav-h) !important;
    min-height: var(--mobile-secondary-nav-h) !important;
    box-sizing: border-box !important;
    align-items: center !important;
    gap: 6px !important;
    padding: 7px !important;
    border-radius: 18px !important;
    background: color-mix(in srgb, var(--bg) 92%, transparent) !important;
    border: 1px solid color-mix(in srgb, var(--line) 80%, transparent) !important;
    box-shadow: 0 12px 34px rgba(0,0,0,.34) !important;
    backdrop-filter: blur(16px) !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    scrollbar-width: none !important;
  }

  #toolsPage.visible .tools-tabs::before,
  .discovery-page.visible .disc-categories-wrap::before,
  #toolsPage.visible .tools-tabs::after,
  .discovery-page.visible .disc-categories-wrap::after {
    content: none !important;
    display: none !important;
  }

  #toolsPage.visible .tools-tabs .disc-pill,
  .discovery-page.visible .disc-category-tab {
    min-height: 34px !important;
    height: 34px !important;
    flex: 0 0 auto !important;
    border-radius: 999px !important;
    box-sizing: border-box !important;
  }

  #toolsPage.visible .tools-tabs .disc-pill {
    padding: 7px 11px !important;
    font-size: 10.5px !important;
    opacity: .88;
    background: color-mix(in srgb, var(--tools-panel-3) 78%, #fff 6%) !important;
    border-color: color-mix(in srgb, var(--tools-line) 85%, #fff 10%) !important;
    color: color-mix(in srgb, var(--text) 78%, var(--muted) 22%) !important;
  }

  #toolsPage.visible .tools-tabs .disc-pill.active {
    opacity: 1;
    background: linear-gradient(180deg, #ffcf6a, #f0b35a) !important;
    border-color: #ffe5aa !important;
    color: #fff !important;
    text-shadow: 0 1px 2px rgba(62,36,0,.42) !important;
    box-shadow: 0 8px 18px rgba(240,179,90,.24) !important;
  }

  #toolsPage.visible .tools-tabs {
    background: color-mix(in srgb, var(--bg) 94%, var(--panel-2) 6%) !important;
    border: 1px solid color-mix(in srgb, var(--line) 86%, transparent) !important;
    box-shadow: 0 -10px 26px rgba(0,0,0,.32) !important;
    backdrop-filter: blur(16px) !important;
    -webkit-backdrop-filter: blur(16px) !important;
  }

  .tools-etf-assets {
    display: flex !important;
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }

  #toolsMacroMapMetrics,
  #toolsMacroMapGroups {
    overflow-x: auto !important;
    overflow-y: hidden !important;
    scrollbar-width: none !important;
    flex-wrap: nowrap !important;
  }

  #toolsMacroMapMetrics::-webkit-scrollbar,
  #toolsMacroMapGroups::-webkit-scrollbar {
    display: none !important;
  }

  #toolsMacroMapMetrics .tools-etf-asset,
  #toolsMacroMapGroups .tools-etf-range {
    flex: 0 0 auto !important;
    white-space: nowrap !important;
  }

  .tools-etf-asset {
    flex: 1 1 33.333% !important;
    width: auto !important;
    max-width: 33.333% !important;
    min-width: 0 !important;
    text-align: center !important;
    white-space: nowrap;
  }

  #toolsPage [data-tools-panel="etf-flows"] .tools-etf-assets,
  #toolsPage [data-tools-panel="etf-flows"] .tools-etf-ranges {
    display: flex !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    gap: 5px !important;
    scrollbar-width: none !important;
  }

  #toolsPage [data-tools-panel="etf-flows"] .tools-etf-assets::-webkit-scrollbar,
  #toolsPage [data-tools-panel="etf-flows"] .tools-etf-ranges::-webkit-scrollbar {
    display: none !important;
  }

  #toolsPage [data-tools-panel="etf-flows"] .tools-etf-asset,
  #toolsPage [data-tools-panel="etf-flows"] .tools-etf-range {
    flex: 0 0 auto !important;
    width: auto !important;
    max-width: none !important;
    min-width: 42px !important;
    min-height: 30px !important;
    padding: 6px 8px !important;
    font-size: 11px !important;
    line-height: 1 !important;
  }

  #toolsPage [data-tools-panel="treasury"] .tools-etf-assets {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 6px !important;
  }

  #toolsPage [data-tools-panel="treasury"] .tools-etf-asset {
    flex: 0 0 auto !important;
    width: auto !important;
    max-width: none !important;
    min-width: 48px !important;
    min-height: 30px !important;
    padding: 6px 10px !important;
    font-size: 11px !important;
    line-height: 1 !important;
  }

  .tools-etf-chart-card,
  .tools-etf-table-card,
  .tools-treasury-card {
    padding: 13px !important;
    border-radius: 12px !important;
  }

  .tools-treasury-visual-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }

  .tools-treasury-donut-layout {
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    align-items: stretch !important;
  }

  .tools-treasury-pie {
    height: 218px !important;
    max-height: 218px !important;
    margin: 0 auto !important;
  }

  .tools-treasury-legend {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 7px !important;
  }

  .tools-treasury-legend-row {
    min-width: 0;
    border: 1px solid var(--line);
    border-radius: 9px;
    background: var(--panel-2);
    padding: 7px 8px;
    gap: 8px !important;
  }

  .tools-treasury-legend-row span {
    min-width: 0;
  }

  .tools-treasury-mstr-stats {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 7px !important;
  }

  .tools-treasury-mstr-stats span {
    border-radius: 10px !important;
    padding: 8px !important;
    white-space: normal !important;
  }

  .tools-treasury-mstr-controls {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }

  .tools-treasury-segment {
    width: 100% !important;
    box-sizing: border-box !important;
    justify-content: space-between !important;
    border-radius: 12px !important;
  }

  .tools-treasury-segment button {
    flex: 1 1 0 !important;
    text-align: center !important;
    padding-left: 6px !important;
    padding-right: 6px !important;
  }

  .tools-treasury-buy-filter {
    justify-content: space-between !important;
    width: 100% !important;
  }

  .tools-treasury-buy-filter select {
    width: auto !important;
    max-width: 68% !important;
  }

  .tools-treasury-mstr-chart {
    height: 300px !important;
  }

  .tools-heatmap {
    height: 240px !important;
    min-height: 240px !important;
    padding: 0 !important;
    overflow: hidden !important;
    box-shadow: none !important;
  }

  .tools-bubbles-wrap {
    height: 260px !important;
    min-height: 260px !important;
  }

  .btc-mr-wrap {
    position: relative;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
  }

  .btc-mr-wrap::after {
    content: '';
    position: sticky;
    right: 0;
    display: block;
    width: 34px;
    height: 1px;
    margin-top: -1px;
    pointer-events: none;
    box-shadow: -22px 0 24px rgba(0,0,0,.34);
  }

  .btc-mr-table {
    min-width: 700px !important;
    font-size: 11px !important;
  }

  .btc-mr-table th:first-child,
  .btc-mr-table td:first-child {
    position: sticky;
    left: 0;
    z-index: 2;
    background: var(--panel);
  }

  .btc-mr-table th,
  .btc-mr-table td {
    min-width: 46px !important;
    padding: 7px 5px !important;
  }

  .tools-liq-split {
    height: 13px !important;
    margin: 9px 0 7px !important;
  }

  .tools-liq-asset-split small {
    white-space: normal !important;
    line-height: 1.25;
  }
}

/* Sitewide mobile polish: last-mile overflow and fixed-nav safety. */
@media (max-width: 600px) {
  .portfolio-page.visible {
    bottom: var(--mobile-bottom-nav-h, 64px) !important;
    padding-bottom: 18px !important;
  }
  body.portfolio-mobile-active .portfolio-page.visible {
    bottom: var(--mobile-bottom-nav-h, 64px) !important;
  }

  .app,
  .main,
  .main-content,
  .discovery-page.visible,
  .answers-page.visible,
  .tools-page.visible,
  .portfolio-page.visible,
  .predictions-page.visible,
  .coins-page {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  .main-content:not(.has-chat) {
    align-items: stretch !important;
    padding-left: 12px !important;
    padding-right: 12px !important;
    justify-content: flex-start !important;
    padding-top: max(24vh, calc(env(safe-area-inset-top, 0px) + 136px)) !important;
  }

  .main-content:not(.has-chat) .welcome,
  .main-content:not(.has-chat) .composer,
  .main-content:not(.has-chat) .disc-preview-pane,
  .main-content:not(.has-chat) .home-v3,
  .main-content:not(.has-chat) .home-v3-section,
  .main-content:not(.has-chat) .home-v3-twin,
  .main-content:not(.has-chat) .home-module-grid {
    width: min(100%, calc(100vw - 24px)) !important;
    max-width: calc(100vw - 24px) !important;
    min-width: 0 !important;
    margin-left: auto !important;
    margin-right: auto !important;
    box-sizing: border-box !important;
  }

  .welcome-title {
    white-space: normal !important;
    overflow-wrap: anywhere;
    font-size: clamp(26px, 7.2vw, 28px) !important;
    max-width: 100% !important;
  }

  .welcome-subtitle {
    width: 100%;
    max-width: 100%;
    overflow-wrap: anywhere;
  }

  .main-content:not(.has-chat) .welcome {
    margin-top: 0 !important;
    margin-bottom: 16px !important;
  }

  .main-content:not(.has-chat) .composer {
    overflow: hidden !important;
    width: min(348px, calc(100dvw - 32px)) !important;
    max-width: min(348px, calc(100dvw - 32px)) !important;
    min-height: 132px;
    padding: 10px 12px 9px !important;
    display: flex !important;
    flex-direction: column;
    justify-content: center;
    margin-top: 18px !important;
    box-shadow: 0 22px 54px -30px rgba(232,87,42,.55), 0 0 0 1px rgba(255,255,255,.025) inset;
  }

  .main-content:not(.has-chat) .home-today-strip {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    width: min(348px, calc(100dvw - 32px)) !important;
    max-width: min(348px, calc(100dvw - 32px)) !important;
    margin: 10px auto 0 !important;
    padding: 0 2px 4px;
    overflow-x: auto;
    scrollbar-width: none;
    white-space: nowrap;
    color: var(--home-mute);
    font-size: 12px;
    line-height: 1;
  }
  .main-content:not(.has-chat) .home-today-strip::-webkit-scrollbar { display: none; }
  .main-content:not(.has-chat) .home-today-strip span {
    flex: 0 0 auto;
    color: var(--home-dim);
    font-weight: 600;
  }
  .main-content:not(.has-chat) .home-today-strip button {
    flex: 0 0 auto;
    appearance: none;
    border: 0;
    background: transparent;
    color: var(--home-dim);
    font: inherit;
    font-weight: 600;
    padding: 6px 0;
    cursor: pointer;
  }
  .main-content:not(.has-chat) .home-today-strip button + button::before {
    content: "·";
    color: var(--home-mute);
    margin: 0 6px 0 0;
    font-weight: 600;
  }
  .main-content:not(.has-chat) .home-today-strip button:active,
  .main-content:not(.has-chat) .home-today-strip button:hover {
    color: var(--home-text);
  }

  .main-content:not(.has-chat) #discPreviewPane,
  .main-content:not(.has-chat) .disc-preview-pane {
    display: none !important;
    visibility: hidden !important;
    width: 0 !important;
    max-width: 0 !important;
    height: 0 !important;
    min-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
  }

  html[data-theme="light"] .main-content:not(.has-chat) .composer {
    box-shadow: 0 22px 54px -30px rgba(0,0,0,.16), 0 0 0 1px rgba(255,255,255,.70) inset !important;
  }

  .main-content:not(.has-chat) .input-container textarea {
    width: 100% !important;
    max-width: 100% !important;
    min-height: 50px !important;
    padding: 10px 66px 0 4px !important;
    box-sizing: border-box !important;
  }

  #submit,
  .main-content:not(.has-chat) #submit,
  .main-content.has-chat #submit {
    width: 40px !important;
    height: 40px !important;
    min-width: 40px !important;
    max-width: 40px !important;
    aspect-ratio: 1 / 1 !important;
    border-radius: 50% !important;
    padding: 0 !important;
    font-size: 0 !important;
    line-height: 1 !important;
    overflow: hidden !important;
    white-space: nowrap !important;
  }

  .main-content:not(.has-chat) #submit {
    right: 12px !important;
    top: 16px !important;
  }

  .main-content.has-chat .input-container textarea {
    padding-right: 76px !important;
  }

  .home-intel-visual,
  .home-intel-tools,
  .home-watchlist-grid,
  .home-agents-grid,
  .home-trends-grid,
  .home-module-grid {
    width: 100%;
    max-width: 100%;
    min-width: 0;
  }

  .home-intel-tools {
    grid-template-columns: 1fr !important;
  }

  .home-intel-card,
  .home-for-you-card,
  .home-briefing,
  .home-watchlist,
  .home-module-card {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  .home-briefing-title,
  .home-for-you-title,
  .home-intel-title,
  .home-watchlist-title {
    font-size: clamp(20px, 6vw, 24px) !important;
    max-width: 100% !important;
  }

  .home-briefing-copy,
  .home-for-you-copy,
  .home-intel-copy,
  .home-watchlist-copy {
    max-width: 100% !important;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 4;
    overflow: hidden;
  }

  .home-briefing-foot span {
    max-width: 100%;
    white-space: normal;
    overflow-wrap: anywhere;
  }

  .discovery-page.visible,
  .answers-page.visible,
  .tools-page.visible,
  .portfolio-page.visible,
  .predictions-page.visible {
    padding-bottom: calc(var(--mobile-bottom-nav-h, 64px) + 28px) !important;
  }

  .disc-feed,
  .answers-grid,
  .disc-mag,
  .lane-mag,
  .disc-mag-cover,
  .disc-mag-grid,
  .lane-mag-grid,
  .pm-events-grid {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow-x: hidden !important;
    box-sizing: border-box !important;
  }

  .disc-mag-lead,
  .lane-mag-hero,
  .disc-mag-card,
  .disc-mag-rail-item,
  .answers-card,
  .pm-event-card,
  .pf-empty-card {
    width: min(100%, calc(100vw - 28px)) !important;
    max-width: calc(100vw - 28px) !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  .disc-mag-headline,
  .disc-mag-card-title,
  .lane-mag-headline,
  .disc-item-title,
  .pm-event-title {
    max-width: calc(100vw - 62px) !important;
    overflow-wrap: anywhere !important;
    word-break: normal !important;
  }

  .disc-mag-visual img,
  .lane-mag-visual img,
  .disc-mag-thumb img,
  .answers-photo svg {
    max-width: 100% !important;
  }

  .portfolio-page.pf-logged-out .pf-empty-preview {
    display: grid !important;
    grid-template-columns: 1fr !important;
    width: 100% !important;
    max-width: min(100%, calc(100vw - 96px), 330px) !important;
    margin: 14px auto 0 !important;
  }

  .portfolio-page.pf-logged-out .pf-empty-preview-card {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }

  .portfolio-page.pf-logged-out .pf-empty-card {
    border-radius: 12px !important;
  }

  .predictions-page.visible .pm-search-card,
  .predictions-page.visible .pm-record-card,
  .predictions-page.visible .pm-header,
  .predictions-page.visible .pm-filters {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  .pm-search-box,
  .pm-search-chips,
  .pm-filters {
    max-width: 100%;
    overflow-x: auto;
  }

  .coins-page {
    padding-bottom: var(--mobile-bottom-nav-h, 64px);
  }

  #toolsPage .tools-panel.active,
  #toolsPage .tools-section,
  #toolsPage .tools-market-structure-wrap,
  #toolsPage .tools-econ-calendar-wrap,
  #toolsPage .tools-etf-wrap,
  #toolsPage .tools-treasury-wrap,
  #toolsPage .tools-cq-section,
  #toolsPage .tools-pm-card {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow: visible !important;
  }

  #toolsPage .tools-etf-assets,
  #toolsPage .tools-etf-ranges,
  #toolsPage .tools-tf-pills,
  #toolsPage .tools-treasury-segment {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }

  #toolsPage .tools-etf-read-card,
  #toolsPage .tools-ai-read,
  #toolsPage .tools-cq-read {
    max-width: 100% !important;
    overflow: hidden !important;
  }

  #toolsPage .tools-etf-read-card {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 12px !important;
  }
}

/* Mobile Pro Chart compact mode. */
@media (max-width: 600px) {
  .topbar-brand {
    display: none !important;
  }

  .disc-back-btn,
  .pm-back-btn,
  .notif-back-btn {
    display: none !important;
  }

  .disc-sub,
  .discovery-page .disc-sub,
  .coins-sub,
  .pm-search-sub {
    display: none !important;
  }

  .disc-header,
  .pm-header,
  .notif-topbar {
    padding-top: 10px !important;
    padding-bottom: 10px !important;
  }

  .disc-title,
  .pm-header-title,
  .notif-top-title,
  .coins-title {
    font-size: 22px !important;
    line-height: 1.12 !important;
  }

  .notif-summary-grid {
    display: none !important;
  }

  .notif-hero {
    margin-bottom: 10px !important;
  }

  .notif-tabs {
    overflow-x: auto !important;
    flex-wrap: nowrap !important;
    padding-bottom: 8px !important;
  }

  .notif-tab {
    flex: 0 0 auto !important;
    white-space: nowrap !important;
  }

  .settings-modal {
    display: grid !important;
    grid-template-rows: auto 1fr !important;
  }

  .settings-tabs {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
    overflow: visible !important;
  }

  .settings-tab {
    width: 100% !important;
    justify-content: center !important;
  }

  .coins-shell {
    display: flex !important;
    flex-direction: column !important;
  }

  .coins-hero {
    order: 1 !important;
    margin-bottom: 10px !important;
  }

  .coins-mood-grid {
    order: 2 !important;
  }

  .coins-main-card {
    order: 3 !important;
  }

  .coins-market-read {
    order: 4 !important;
  }

  .coins-section-title {
    display: none !important;
  }

  .coins-toolbar {
    padding: 12px !important;
  }

  .coins-controls {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }

  .coins-filter-pills {
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    width: 100% !important;
    padding-bottom: 3px !important;
    scrollbar-width: none !important;
  }

  .coins-filter-pills button,
  .coins-sector-select,
  .coins-stable-toggle {
    flex: 0 0 auto !important;
    width: auto !important;
    min-width: max-content !important;
  }

  .coins-read-drivers,
  .coins-read-questions {
    display: none !important;
  }

  .coins-market-read {
    margin-top: 12px !important;
  }

  .coins-read-main {
    padding: 12px !important;
  }

  .pf-hero-top {
    flex-direction: row !important;
    align-items: flex-start !important;
  }

  .pf-hero {
    padding-top: 50px !important;
  }

  .pf-hero-actions {
    display: grid !important;
    grid-template-columns: minmax(126px, 1fr) 36px !important;
    width: auto !important;
    min-width: 174px !important;
    max-width: 210px !important;
    gap: 6px !important;
  }

  .pf-hero-actions > button {
    width: auto !important;
  }

  .pf-more-btn {
    display: inline-flex !important;
  }

  .pf-back-btn {
    display: none !important;
  }

  .portfolio-page.visible {
    bottom: var(--mobile-bottom-nav-h, 64px) !important;
  }

  body.portfolio-mobile-active .mobile-bottom-nav {
    display: grid !important;
  }

  .pro-chart-modal,
  .pro-chart-shell {
    width: 100dvw !important;
    max-width: 100dvw !important;
    overflow: hidden !important;
  }

  .pro-chart-shell {
    height: 100dvh !important;
  }

  .mode-description:not([hidden]) {
    display: block !important;
  }

  .pro-chart-head {
    display: block !important;
    padding: 8px 48px 7px 10px !important;
    overflow: visible !important;
  }

  .pro-chart-symbol-row {
    display: grid !important;
    grid-template-columns: auto minmax(0, 1fr) !important;
    gap: 6px !important;
  }

  .pro-chart-exit {
    height: 34px !important;
    padding: 0 10px !important;
  }

  .pro-chart-search {
    min-width: 0 !important;
    height: 34px !important;
  }

  .pro-chart-watch-add {
    display: none !important;
  }

  .pro-chart-search button {
    width: 42px !important;
    padding: 0 !important;
  }

  .pro-chart-quick {
    display: none !important;
  }

  .pro-chart-title {
    display: none !important;
    font-size: 16px !important;
    margin-top: 2px;
  }

  .pro-chart-sub {
    display: none !important;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .pro-chart-close {
    left: auto !important;
    right: 8px !important;
    top: 8px !important;
  }

  .pro-chart-mainbar,
  .pro-chart-toolbar,
  .pro-chart-scalebar,
  .pro-chart-actions {
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    max-width: 100dvw !important;
    scrollbar-width: none !important;
  }

  .pro-chart-mainbar {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    justify-content: stretch !important;
    gap: 8px !important;
    padding: 7px 10px !important;
  }

  .pro-chart-mainbar .pro-chart-actions {
    grid-column: 1 / -1 !important;
    justify-content: flex-start !important;
  }

  .pro-chart-control-group,
  .pro-chart-controls,
  .pro-chart-compare,
  .pro-chart-compare-chips {
    flex: 0 0 auto !important;
    min-width: 0 !important;
  }

  .pro-chart-control-label {
    display: none !important;
  }

  .pro-chart-controls {
    width: 100% !important;
  }

  .pro-chart-mobile-select {
    display: block !important;
    width: 100% !important;
    min-height: 34px !important;
    border: 1px solid #2a2e39 !important;
    border-radius: 8px !important;
    background: #151b24 !important;
    color: #f2f5f8 !important;
    padding: 0 10px !important;
    font: inherit !important;
    font-size: 12px !important;
    font-weight: 850 !important;
  }

  .pro-chart-mainbar .pro-chart-chip,
  .pro-chart-toolbar .pro-chart-control-btn,
  .pro-chart-toolbar .pro-chart-toolbar-label,
  .pro-chart-toolbar > span:not(.pro-chart-toolbar-label),
  .pro-chart-toolbar > span[style] {
    display: none !important;
  }

  .pro-chart-toolbar {
    padding: 7px 10px !important;
    display: block !important;
  }

  .pro-chart-scalebar {
    padding: 6px 10px !important;
  }

  .pro-chart-chip,
  .pro-chart-control-btn,
  .pro-chart-scale-btn,
  .pro-chart-action-btn,
  .pro-chart-compare button {
    min-height: 28px !important;
    padding-left: 8px !important;
    padding-right: 8px !important;
    font-size: 10.5px !important;
  }

  .pro-chart-actionbar {
    overflow: visible !important;
    padding: 6px 10px !important;
    justify-content: flex-start !important;
  }

  .pro-chart-narrative {
    display: none !important;
  }

  .pro-chart-compare input {
    width: 96px !important;
  }

  .pro-chart-body {
    min-width: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  .pro-chart-workspace-main {
    display: flex !important;
    flex-direction: column !important;
    min-height: 0 !important;
    flex: 1 1 auto !important;
  }

  .pro-chart-side {
    display: none !important;
  }

  .pro-chart-canvas,
  .pro-chart-indicator-pane {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }

  .pro-chart-canvas {
    flex: 1 1 auto !important;
    min-height: 280px !important;
  }

  .pro-chart-main-legend {
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    min-width: 0 !important;
    max-width: none !important;
    width: 100% !important;
    border-radius: 0 !important;
    border-left: 0 !important;
    border-right: 0 !important;
    padding: 4px 7px !important;
    background: rgba(8,11,15,.78) !important;
    box-shadow: 0 6px 18px rgba(0,0,0,.2) !important;
    white-space: nowrap !important;
    overflow: hidden !important;
  }

  .pro-chart-main-legend .legend-date,
  .pro-chart-main-legend .legend-ohlc {
    display: none !important;
  }

  .pro-chart-main-legend .legend-row {
    display: inline-flex !important;
    align-items: baseline !important;
    gap: 4px !important;
    min-height: 0 !important;
    margin-right: 10px !important;
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace !important;
  }

  .pro-chart-main-legend .legend-label {
    font-size: 10px !important;
  }

  .pro-chart-main-legend .legend-value,
  .pro-chart-main-legend .legend-price .legend-value {
    font-size: 12px !important;
    max-width: 96px !important;
  }

  #proChartCanvas-rsi,
  #proChartCanvas-macd,
  #proChartCanvas-stochrsi {
    height: 74px !important;
    flex-basis: 74px !important;
  }

  #proChartCanvas-vwrsi {
    height: 82px !important;
    flex-basis: 82px !important;
  }
}

@media (min-width: 769px) {
  #toolsPage.visible .tools-tabs {
    display: none !important;
  }
}

html[data-theme="light"] #toolsPage {
  --tools-bg: #faf9f7 !important;
  --tools-panel: #ffffff !important;
  --tools-panel-2: #f5f2ee !important;
  --tools-panel-3: #ebe7e1 !important;
  --tools-line: rgba(49,39,31,.14) !important;
  --macro-map-ocean-a: #f8fbff;
  --macro-map-ocean-b: #edf4fb;
  --macro-map-ocean-c: #f6f0e7;
  background: var(--bg) !important;
}

html[data-theme="light"] #toolsPage .disc-header,
html[data-theme="light"] #toolsPage .tools-panel {
  background: var(--bg) !important;
}

html[data-theme="light"] #toolsPage .tools-stat,
html[data-theme="light"] #toolsPage .tools-alt-meter,
html[data-theme="light"] #toolsPage .tools-command-center,
html[data-theme="light"] #toolsPage .tools-intel-card,
html[data-theme="light"] #toolsPage .tools-preview-card,
html[data-theme="light"] #toolsPage .tools-pm-card,
html[data-theme="light"] #toolsPage .tools-etf-loading,
html[data-theme="light"] #toolsPage .tools-etf-summary-card,
html[data-theme="light"] #toolsPage .tools-etf-contrib-card,
html[data-theme="light"] #toolsPage .tools-etf-chart-card,
html[data-theme="light"] #toolsPage .tools-etf-table-card,
html[data-theme="light"] #toolsPage .tools-treasury-card,
html[data-theme="light"] #toolsPage .tools-ms-grid > *,
html[data-theme="light"] #toolsPage .tools-cq-card,
html[data-theme="light"] #toolsPage .tools-deriv-card,
html[data-theme="light"] #toolsPage .tools-liq-card,
html[data-theme="light"] #toolsPage .tools-macro-country-row,
html[data-theme="light"] #toolsPage .tools-econ-mobile-card {
  background: linear-gradient(180deg, var(--tools-panel-2), var(--tools-panel)) !important;
  border-color: var(--tools-line) !important;
  box-shadow: 0 14px 34px rgba(62,45,30,.08) !important;
}

html[data-theme="light"] #toolsPage .tools-intel-read,
html[data-theme="light"] #toolsPage .tools-macro-pill,
html[data-theme="light"] #toolsPage .tools-alt-stat,
html[data-theme="light"] #toolsPage .tools-pm-stat,
html[data-theme="light"] #toolsPage .tools-pm-row,
html[data-theme="light"] #toolsPage .tools-preview-mini,
html[data-theme="light"] #toolsPage .tools-ms-mini-stat,
html[data-theme="light"] #toolsPage .tools-deriv-source-row,
html[data-theme="light"] #toolsPage .tools-liq-asset-row,
html[data-theme="light"] #toolsPage .tools-liq-event-row,
html[data-theme="light"] #toolsPage .tools-treasury-adapters span,
html[data-theme="light"] #toolsPage .tools-treasury-mstr-stats span,
html[data-theme="light"] #toolsPage .tools-treasury-update-row,
html[data-theme="light"] #toolsPage .tools-treasury-buy-item,
html[data-theme="light"] #toolsPage .tools-etf-meta span,
html[data-theme="light"] #toolsPage .tools-etf-read-stats span {
  background: var(--tools-panel-3) !important;
  border-color: var(--tools-line) !important;
}

html[data-theme="light"] #toolsPage .tools-heatmap,
html[data-theme="light"] #toolsPage .tools-bubbles-wrap {
  background: var(--tools-panel) !important;
  border-color: var(--tools-line) !important;
  box-shadow: inset 0 0 42px rgba(62,45,30,.06) !important;
}

html[data-theme="light"] #toolsPage .tools-command-center {
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(250,247,242,.98)) !important;
  border-color: rgba(49,39,31,.14) !important;
  box-shadow: 0 14px 34px rgba(62,45,30,.08) !important;
}

html[data-theme="light"] #toolsPage .tools-command-kicker {
  color: var(--accent) !important;
}

html[data-theme="light"] #toolsPage .tools-command-title {
  color: var(--text) !important;
}

html[data-theme="light"] #toolsPage .tools-command-copy,
html[data-theme="light"] #toolsPage .tools-command-label {
  color: var(--muted) !important;
}

html[data-theme="light"] #toolsPage .tools-command-driver {
  background: rgba(255,255,255,.72) !important;
  border-color: rgba(49,39,31,.12) !important;
}

html[data-theme="light"] #toolsPage .tools-command-driver span {
  color: var(--muted) !important;
}

html[data-theme="light"] #toolsPage .tools-command-driver b {
  color: var(--text) !important;
}

html[data-theme="light"] #toolsPage .tools-command-side {
  border-left-color: rgba(49,39,31,.12) !important;
}

html[data-theme="light"] #toolsPage .tools-macro-map-svg {
  background: #f3f7fb !important;
  border-color: rgba(49,39,31,.14) !important;
}

html[data-theme="light"] #toolsPage .tools-macro-map-svg text {
  fill: rgba(31,37,45,.82);
}

html[data-theme="light"] #toolsPage .tools-macro-map-country {
  fill: rgba(42,54,68,.08);
  stroke: rgba(42,54,68,.12);
}

html[data-theme="light"] #toolsPage .tools-macro-map-country.is-active {
  stroke: rgba(42,54,68,.22);
}

html[data-theme="light"] #toolsPage .tools-pressure-chart text,
html[data-theme="light"] #toolsPage .tools-pressure-heatmap text {
  fill: rgba(49,39,31,.72);
}

html[data-theme="light"] #toolsPage .tools-pressure-chart .tools-pressure-watermark {
  fill: rgba(49,39,31,.055);
}

html[data-theme="light"] #toolsPage .tools-pressure-chart .tools-pressure-current,
html[data-theme="light"] #toolsPage .tools-pressure-heatmap .tools-pressure-current {
  fill: #a06b00;
}

html[data-theme="light"] #toolsPage .tools-pressure-chart .tools-pressure-axis-label,
html[data-theme="light"] #toolsPage .tools-pressure-heatmap .tools-pressure-axis-label {
  fill: rgba(49,39,31,.62);
}

html[data-theme="light"] #toolsPage .tools-pressure-chart-card {
  background: linear-gradient(180deg, #fffaf2, #ffffff) !important;
  border-color: rgba(49,39,31,.14) !important;
}

html[data-theme="light"] #toolsPage .tools-pressure-action-read {
  border-color: rgba(183,124,0,.26);
  background: linear-gradient(135deg, rgba(255,210,88,.22), rgba(35,164,146,.08) 58%, rgba(255,255,255,.72));
}

html[data-theme="light"] #toolsPage .tools-pressure-action-read b {
  color: #9a6500;
}

html[data-theme="light"] #toolsPage .tools-pressure-action-read span,
html[data-theme="light"] #toolsPage .tools-pressure-zone-row span {
  color: rgba(49,39,31,.66);
}

html[data-theme="light"] #toolsPage .tools-pressure-window {
  border-color: rgba(49,39,31,.14);
  background: rgba(49,39,31,.045);
}

html[data-theme="light"] #toolsPage .tools-pressure-window button {
  color: rgba(49,39,31,.68);
}

html[data-theme="light"] #toolsPage .tools-pressure-window button.active {
  color: #21170a;
  background: #ffd700;
  box-shadow: 0 0 0 1px rgba(49,39,31,.08), 0 8px 18px rgba(183,124,0,.16);
}

html[data-theme="light"] #toolsPage .tools-pressure-canvas-map {
  border-color: rgba(49,39,31,.16);
  background: #202020;
  box-shadow: none;
}

html[data-theme="light"] #toolsPage .tools-pressure-canvas-scale {
  color: rgba(255,255,255,.82);
}

html[data-theme="light"] #toolsPage .tools-pressure-canvas-scale canvas,
html[data-theme="light"] #toolsPage .tools-pressure-canvas-stage canvas[data-pressure-heatmap-mini] {
  border-color: transparent;
  background: #202020;
}

html[data-theme="light"] #toolsPage .tools-pressure-canvas-stage canvas[data-pressure-heatmap-main] {
  border-color: transparent;
  background: #171717;
}

html[data-theme="light"] #toolsPage .tools-pressure-chart,
html[data-theme="light"] #toolsPage .tools-pressure-heatmap {
  border-color: rgba(49,39,31,.16);
  background: #f7efe3;
}

html[data-theme="light"] #toolsPage .tools-pressure-zone-map {
  background: #fffaf2;
}

html[data-theme="light"] #toolsPage .tools-pressure-zone-map > rect:first-of-type {
  fill: #fffaf2;
}

html[data-theme="light"] #toolsPage .tools-pressure-zone-map > rect[rx="12"] {
  fill: rgba(49,39,31,.035);
}

html[data-theme="light"] #toolsPage .tools-pressure-zone-map line {
  stroke: rgba(49,39,31,.11);
}

html[data-theme="light"] #toolsPage .tools-pressure-zone-map line[stroke="#ffd700"] {
  stroke: #b77700;
}

html[data-theme="light"] #toolsPage .tools-pressure-zone-map path[fill="rgba(255,65,88,.16)"] {
  fill: rgba(213,65,76,.14);
}

html[data-theme="light"] #toolsPage .tools-pressure-zone-map path[fill="rgba(52,209,189,.15)"] {
  fill: rgba(18,154,133,.13);
}

html[data-theme="light"] #toolsPage .tools-pressure-zone-map .tools-pressure-legend text {
  fill: rgba(49,39,31,.68);
}

html[data-theme="light"] #toolsPage .tools-pressure-mini-map {
  border-top-color: rgba(49,39,31,.12);
}

html[data-theme="light"] #toolsPage .tools-pressure-zone-row {
  background: #fffaf2;
  border-color: rgba(49,39,31,.14);
}

html[data-theme="light"] #toolsPage .tools-pressure-zone-row.is-above {
  border-color: rgba(18,154,133,.38);
  background: linear-gradient(90deg, rgba(18,154,133,.10), #fffaf2 28%);
}

html[data-theme="light"] #toolsPage .tools-pressure-zone-row.is-below {
  border-color: rgba(213,65,76,.34);
  background: linear-gradient(90deg, rgba(213,65,76,.10), #fffaf2 28%);
}

html[data-theme="light"] #toolsPage .tools-pressure-zone-row b,
html[data-theme="light"] #toolsPage .tools-pressure-zone-row strong {
  color: rgba(35,28,22,.92);
}

html[data-theme="light"] #toolsPage .tools-pressure-zone-row b i {
  color: rgba(35,28,22,.88);
  background: rgba(49,39,31,.08);
  border-color: rgba(49,39,31,.14);
}

html[data-theme="light"] #toolsPage .tools-pressure-zone-row strong.pos {
  color: #d5414c;
}

html[data-theme="light"] #toolsPage .tools-pressure-zone-row strong.neg {
  color: #b77700;
}

html[data-theme="light"] #toolsPage .tools-pressure-zone-row.is-hovered,
html[data-theme="light"] #toolsPage .tools-pressure-zone-row:focus-visible {
  border-color: rgba(183,124,0,.44);
  background: #fff4cf;
  box-shadow: 0 0 0 1px rgba(183,124,0,.12), 0 12px 26px rgba(62,45,30,.12);
}

html[data-theme="light"] #toolsPage .tools-pressure-meaning {
  border-color: rgba(183,124,0,.24) !important;
  background: linear-gradient(135deg, rgba(255,210,88,.20), transparent 48%), #fffaf2 !important;
}

html[data-theme="light"] #toolsPage .tools-pressure-method {
  border-color: rgba(49,39,31,.14);
}

html[data-theme="light"] #toolsPage .tools-pressure-empty {
  border-color: rgba(49,39,31,.18);
  background: rgba(49,39,31,.035);
  color: rgba(49,39,31,.62);
}

html[data-theme="light"] .tools-pressure-modal {
  background: #fffaf2;
  border-color: rgba(49,39,31,.16);
}

html[data-theme="light"] .coins-page {
  --coins-bg: var(--bg);
  --coins-panel: #ffffff;
  --coins-panel-2: #f5f2ee;
  --coins-panel-3: #ebe7e1;
  --coins-line: rgba(49,39,31,.14);
  background: var(--bg) !important;
}

html[data-theme="light"] .coins-card,
html[data-theme="light"] .coins-mood-card,
html[data-theme="light"] .coins-market-card,
html[data-theme="light"] .coins-detail-card,
html[data-theme="light"] .coins-pressure-card {
  background: linear-gradient(180deg, var(--coins-panel-2), var(--coins-panel)) !important;
  border-color: var(--coins-line) !important;
  box-shadow: 0 14px 34px rgba(62,45,30,.08) !important;
}

@media (min-width: 769px) {
  #toolsPage .tools-macro-map-layout,
  #macroPage .tools-macro-map-layout {
    grid-template-columns: minmax(0, 1.6fr) minmax(320px, .52fr);
    gap: 12px;
  }

  #toolsPage .tools-macro-map-svg,
  #macroPage .tools-macro-map-svg {
    height: clamp(538px, 49vw, 638px);
    width: 100%;
  }

  #toolsPage .tools-macro-country-list,
  #macroPage .tools-macro-country-list {
    max-height: 563px;
  }
}

#macroPage {
  --macro-panel: var(--tools-panel, var(--panel));
  --macro-line: var(--tools-line, var(--line));
}

.macro-command-center {
  margin-bottom: 18px;
  position: relative;
  overflow: hidden;
  border-color: rgba(255,255,255,.10);
}

.macro-command-center::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 5px;
  background: #f0b35a;
}

.macro-command-center::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(115deg, rgba(240,179,90,.12), transparent 42%);
}

.macro-command-center.macro-tone-on::before { background: #00bb7f; }
.macro-command-center.macro-tone-off::before { background: #ef5350; }
.macro-command-center.macro-tone-mixed::before { background: #f0b35a; }
.macro-command-center.macro-tone-on::after { background: linear-gradient(115deg, rgba(0,187,127,.14), transparent 44%); }
.macro-command-center.macro-tone-off::after { background: linear-gradient(115deg, rgba(239,83,80,.14), transparent 44%); }

#macroPage .tools-command-main,
#macroPage .tools-command-side {
  position: relative;
  z-index: 1;
}

#macroPage .tools-command-drivers span.pos {
  color: #00bb7f;
  border-color: rgba(0,187,127,.26);
  background: rgba(0,187,127,.08);
}

#macroPage .tools-command-drivers span.neg {
  color: #ef5350;
  border-color: rgba(239,83,80,.26);
  background: rgba(239,83,80,.08);
}

.macro-risk-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.macro-risk-card,
.macro-catalyst-card {
  background: linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.025));
  border: 1px solid var(--tools-line, var(--line));
  border-radius: 8px;
  padding: 12px;
  min-width: 0;
  position: relative;
  overflow: hidden;
}

.macro-risk-card::before,
.macro-catalyst-card::before,
.macro-index-section::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 3px;
  background: rgba(240,179,90,.72);
}

.macro-risk-card.pos::before { background: #00bb7f; }
.macro-risk-card.neg::before { background: #ef5350; }
.macro-risk-card.zero::before { background: #8a93a4; }

.macro-risk-card.pos { box-shadow: inset 0 0 0 1px rgba(0,187,127,.08), 0 16px 32px rgba(0,0,0,.12); }
.macro-risk-card.neg { box-shadow: inset 0 0 0 1px rgba(239,83,80,.08), 0 16px 32px rgba(0,0,0,.12); }

.macro-risk-card-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
}

.macro-risk-card-top i {
  color: var(--muted);
  font-size: 10px;
  font-style: normal;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .04em;
  opacity: .62;
}

.macro-risk-card span,
.macro-catalyst-card span,
.macro-catalyst-card em {
  display: block;
  color: var(--muted);
  font-size: 12px;
  font-style: normal;
}

.macro-risk-card b {
  display: block;
  color: var(--text);
  font-size: 18px;
  line-height: 1.2;
  margin-top: 4px;
}

.macro-risk-card em {
  display: block;
  margin-top: 5px;
  font-size: 13px;
  font-style: normal;
  font-weight: 750;
}

.macro-risk-card em.pos,
.macro-indices-table .pos {
  color: #00bb7f;
}

.macro-risk-card em.neg,
.macro-indices-table .neg {
  color: #ef5350;
}

.macro-risk-card em.zero {
  color: var(--muted);
}

.macro-backdrop-card {
  padding: 16px;
  border-color: rgba(240,179,90,.16);
  background: linear-gradient(180deg, rgba(240,179,90,.055), rgba(255,255,255,.026));
}

.macro-catalyst-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.macro-catalyst-grid > div {
  display: grid;
  gap: 8px;
}

.macro-catalyst-card b {
  display: block;
  color: var(--text);
  font-size: 14px;
  line-height: 1.25;
  margin: 5px 0 3px;
}

.macro-index-section {
  margin-top: 12px;
  position: relative;
  overflow: hidden;
}

.macro-index-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
}

.macro-index-section-head span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 750;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 999px;
  padding: 4px 8px;
  white-space: nowrap;
}

.macro-index-meta {
  margin-bottom: 4px;
}

.macro-indices-table tr {
  transition: background .15s ease;
}

.macro-indices-table tbody tr:hover {
  background: rgba(255,255,255,.035);
}

.macro-index-name b,
.macro-index-name span {
  display: block;
}

.macro-index-name span {
  color: var(--muted);
  font-size: 12px;
  margin-top: 2px;
}

.macro-rating {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 0 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.09);
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
  white-space: nowrap;
}

#macroPage .tools-section {
  animation: macroFadeIn .22s ease both;
}

@keyframes macroFadeIn {
  from { opacity: .72; transform: translateY(4px); }
  to { opacity: 1; transform: translateY(0); }
}

/* MarketCap mobile density pass: closer to CMC/CoinGecko scan rows. */
@media (max-width: 600px) {
  .coins-page .coins-shell {
    width: 100% !important;
    padding: 8px 8px calc(var(--mobile-bottom-nav-h, 64px) + 76px) !important;
  }

  .coins-page .coins-hero {
    margin: 0 0 8px !important;
    padding: 0 6px !important;
  }

  .coins-page .coins-title {
    font-size: 21px !important;
  }

  .coins-page .coins-mood-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 7px !important;
    margin: 0 0 8px !important;
    padding: 0 0 2px !important;
    overflow-x: visible !important;
    overflow-y: hidden !important;
    scrollbar-width: none !important;
  }

  .coins-page .coins-mood-grid::-webkit-scrollbar {
    display: none;
  }

  .coins-page .coins-mood-card {
    min-width: 0 !important;
    min-height: 50px !important;
    padding: 8px 7px !important;
    border-radius: 9px !important;
    box-shadow: none !important;
  }

  .coins-page .coins-mood-card:nth-child(4),
  .coins-page .coins-fng-card {
    display: none !important;
  }

  .coins-page .coins-mood-card span {
    font-size: 8.5px !important;
    line-height: 1.05 !important;
    letter-spacing: .045em !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  .coins-page .coins-mood-card b {
    margin-top: 4px !important;
    font-size: 15px !important;
    line-height: 1 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  .coins-page .coins-mood-card em,
  .coins-page .coins-mini-spark,
  .coins-page .coins-fng-gauge,
  .coins-page .coins-fng-card::before {
    display: none !important;
  }

  .coins-page .coins-main-card {
    border-radius: 10px !important;
    box-shadow: none !important;
  }

  .coins-page .coins-toolbar {
    position: sticky !important;
    top: 0 !important;
    z-index: 30 !important;
    padding: 8px !important;
    gap: 7px !important;
    border-radius: 10px 10px 0 0 !important;
  }

  .coins-page .coins-controls {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    gap: 7px !important;
    overflow: visible !important;
  }

  .coins-page .coins-search {
    grid-column: 1 / -1 !important;
    height: 32px !important;
    border-radius: 8px !important;
    padding: 0 9px !important;
  }

  .coins-page .coins-search input {
    font-size: 12px !important;
  }

  .coins-page .coins-timeframes {
    order: 2 !important;
    grid-column: 1 !important;
    width: auto !important;
    height: 30px !important;
    padding: 2px !important;
  }

  .coins-page .coins-timeframes button {
    min-width: 34px !important;
    padding: 0 7px !important;
    font-size: 10px !important;
  }

  .coins-page .coins-watchlist-filter {
    order: 3 !important;
    grid-column: 2 !important;
    width: auto !important;
    align-self: center !important;
  }

  .coins-page .coins-watchlist-filter button {
    height: 30px !important;
    padding: 0 9px !important;
    font-size: 10px !important;
  }

  .coins-page .coins-filter-pills {
    order: 4 !important;
    grid-column: 1 / -1 !important;
    gap: 5px !important;
    height: 31px !important;
    padding: 0 0 1px !important;
  }

  .coins-page .coins-filter-pills button,
  .coins-page .coins-sector-select,
  .coins-page .coins-stable-toggle {
    height: 28px !important;
    min-height: 28px !important;
    padding: 0 9px !important;
    font-size: 10px !important;
    border-radius: 999px !important;
  }

  .coins-page .coins-stable-toggle input {
    width: 12px !important;
    height: 12px !important;
  }

  .coins-page .coins-movers {
    display: none !important;
  }

  .coins-page .coins-mobile-list {
    gap: 0 !important;
    padding: 0 !important;
  }

  .coins-page .coins-mobile-card {
    min-height: 54px !important;
    padding: 7px 8px !important;
    border-width: 0 0 1px !important;
    border-color: var(--line) !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
  }

  .coins-page .coins-mobile-top {
    grid-template-columns: 24px minmax(66px, 1fr) minmax(82px, auto) minmax(54px, auto) !important;
    gap: 8px !important;
  }

  .coins-page .coins-mobile-rank {
    font-size: 10px !important;
    text-align: center !important;
  }

  .coins-page .coins-mobile-top .coins-asset {
    gap: 7px !important;
  }

  .coins-page .coins-mobile-top .coins-asset img,
  .coins-page .coins-mobile-top .coins-asset .coins-logo-fallback {
    width: 24px !important;
    height: 24px !important;
  }

  .coins-page .coins-mobile-top .coins-asset strong {
    font-size: 15px !important;
    line-height: 1.1 !important;
    font-weight: 950 !important;
    letter-spacing: .01em !important;
  }

  .coins-page .coins-mobile-top .coins-asset span {
    margin-top: 1px !important;
    font-size: 9.5px !important;
    line-height: 1.1 !important;
  }

  .coins-page .coins-mobile-tags {
    display: none !important;
  }

  .coins-page .coins-mobile-price {
    display: contents !important;
  }

  .coins-page .coins-mobile-price strong {
    justify-self: start !important;
    color: var(--text) !important;
    font-size: 14px !important;
    line-height: 1.1 !important;
    font-weight: 950 !important;
    font-variant-numeric: tabular-nums !important;
    white-space: nowrap !important;
  }

  .coins-page .coins-mobile-price span {
    justify-self: end !important;
    margin-top: 0 !important;
    font-size: 12.5px !important;
    line-height: 1.1 !important;
    font-weight: 950 !important;
    font-variant-numeric: tabular-nums !important;
    white-space: nowrap !important;
  }

  .coins-page .coins-mobile-price em {
    display: none !important;
    margin-top: 2px !important;
    color: var(--muted) !important;
    font-size: 9px !important;
    line-height: 1.05 !important;
    font-style: normal !important;
    font-weight: 750 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  .coins-page .coins-mobile-metrics {
    display: none !important;
  }

  .coins-page .coins-pagination {
    margin-top: 8px !important;
    padding: 8px 0 2px !important;
  }

  .coins-page .coins-page-btn {
    width: 30px !important;
    height: 28px !important;
    font-size: 11px !important;
  }
}

html[data-theme="light"] .macro-risk-card,
html[data-theme="light"] .macro-catalyst-card,
html[data-theme="light"] .macro-backdrop-card {
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(247,244,239,.96)) !important;
  border-color: rgba(49,39,31,.13) !important;
  box-shadow: 0 14px 34px rgba(62,45,30,.08) !important;
}

html[data-theme="light"] .macro-command-center {
  border-color: rgba(49,39,31,.12) !important;
}

@media (max-width: 900px) {
  .macro-risk-grid,
  .macro-catalyst-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 620px) {
  #macroContent {
    padding: 0 14px 22px !important;
  }

  #macroPage .macro-command-center {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }

  #macroPage .tools-command-title {
    font-size: 25px !important;
    line-height: 1.15 !important;
    max-width: 100% !important;
  }

  #macroPage .tools-command-copy {
    max-width: 100% !important;
  }

  #macroPage .tools-command-drivers {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 6px !important;
    margin-top: 12px !important;
  }

  #macroPage .tools-command-drivers span {
    flex: 0 1 auto !important;
    min-width: 0 !important;
    max-width: 100% !important;
    white-space: normal !important;
    line-height: 1.25 !important;
  }

  #macroPage .tools-command-side {
    border-left: 0 !important;
    border-top: 1px solid rgba(255,255,255,.12) !important;
    padding-left: 0 !important;
    padding-top: 12px !important;
    justify-items: start !important;
  }

  .macro-risk-grid,
  .macro-catalyst-grid {
    grid-template-columns: 1fr;
  }

  .macro-index-section-head {
    align-items: flex-start;
    flex-direction: column;
  }

  .macro-indices-table th,
  .macro-indices-table td {
    padding-left: 9px;
    padding-right: 9px;
    font-size: 12px;
  }

  .macro-index-name span {
    max-width: 170px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
}

/* Intel Tools mobile overview: compact first-screen dashboard. */
@media (max-width: 600px) {
  #toolsPage .disc-header {
    padding: 9px 12px 6px !important;
  }

  #toolsPage .disc-header-top {
    gap: 8px !important;
  }

  #toolsPage .disc-title {
    font-size: 22px !important;
    line-height: 1.05 !important;
  }

  #toolsPage .disc-sub {
    display: none !important;
  }

  #toolsPage #toolsContent {
    width: 100% !important;
    max-width: 100% !important;
    padding: 8px 8px calc(var(--mobile-bottom-nav-h, 64px) + var(--mobile-secondary-nav-h, 54px) + 24px) !important;
  }

  #toolsPage [data-tools-panel="overview"].active {
    display: grid !important;
    gap: 8px !important;
  }

  #toolsPage #toolsCommandCenter {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    grid-template-areas:
      "kicker score"
      "title score"
      "copy copy"
      "drivers drivers" !important;
    gap: 7px 10px !important;
    margin: 0 !important;
    padding: 11px !important;
    border-radius: 12px !important;
    box-shadow: none !important;
  }

  #toolsPage #toolsCommandCenter .tools-command-main,
  #toolsPage #toolsCommandCenter .tools-command-side {
    display: contents !important;
  }

  #toolsPage #toolsCommandCenter .tools-command-kicker {
    grid-area: kicker !important;
    align-self: end !important;
    font-size: 9px !important;
    letter-spacing: .07em !important;
  }

  #toolsPage #toolsCommandCenter .tools-command-title {
    grid-area: title !important;
    margin: 0 !important;
    font-size: 19px !important;
    line-height: 1.12 !important;
  }

  #toolsPage #toolsCommandCenter .tools-command-copy {
    grid-area: copy !important;
    display: -webkit-box !important;
    -webkit-box-orient: vertical !important;
    -webkit-line-clamp: 2 !important;
    margin: 0 !important;
    overflow: hidden !important;
    color: rgba(255,255,255,.68) !important;
    font-size: 11.5px !important;
    line-height: 1.32 !important;
  }

  #toolsPage #toolsCommandCenter .tools-command-drivers {
    grid-area: drivers !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 6px !important;
    margin-top: 1px !important;
  }

  #toolsPage #toolsCommandCenter .tools-command-driver {
    min-height: 44px !important;
    padding: 7px !important;
    border-radius: 9px !important;
  }

  #toolsPage #toolsCommandCenter .tools-command-driver span {
    margin-bottom: 3px !important;
    font-size: 8px !important;
    letter-spacing: .045em !important;
  }

  #toolsPage #toolsCommandCenter .tools-command-driver b {
    font-size: 10px !important;
    line-height: 1.15 !important;
    white-space: normal !important;
    display: -webkit-box !important;
    -webkit-box-orient: vertical !important;
    -webkit-line-clamp: 2 !important;
  }

  #toolsPage #toolsCommandCenter .tools-command-score {
    grid-area: score !important;
    align-self: center !important;
    justify-self: end !important;
    min-width: 56px !important;
    border: 1px solid rgba(255,255,255,.12) !important;
    border-radius: 12px !important;
    background: rgba(255,255,255,.055) !important;
    padding: 8px 9px !important;
    font-size: 31px !important;
    text-align: center !important;
  }

  #toolsPage #toolsCommandCenter .tools-command-label,
  #toolsPage #toolsOverviewShareBtn {
    display: none !important;
  }

  #toolsPage #toolsGlobalStrip {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 6px !important;
    margin: 0 !important;
  }

  #toolsPage #toolsGlobalStrip .tools-stat {
    min-height: 52px !important;
    padding: 8px 7px !important;
    border-radius: 10px !important;
    box-shadow: none !important;
  }

  #toolsPage #toolsGlobalStrip .tools-stat:nth-child(n+4) {
    display: none !important;
  }

  #toolsPage #toolsGlobalStrip .tools-stat-label {
    margin-bottom: 3px !important;
    font-size: 8px !important;
    letter-spacing: .035em !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  #toolsPage #toolsGlobalStrip .tools-stat-value {
    font-size: 14px !important;
    line-height: 1.05 !important;
    white-space: nowrap !important;
  }

  #toolsPage #toolsGlobalStrip .tools-stat-sub {
    font-size: 9px !important;
    line-height: 1.05 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  #toolsPage #toolsAltSeason {
    margin: 0 !important;
    padding: 10px !important;
    border-radius: 11px !important;
    box-shadow: none !important;
  }

  #toolsPage #toolsAltSeason .tools-alt-top {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    gap: 8px !important;
    align-items: center !important;
    margin-bottom: 8px !important;
  }

  #toolsPage #toolsAltSeason .tools-alt-title {
    margin: 0 !important;
    font-size: 13px !important;
    line-height: 1.12 !important;
  }

  #toolsPage #toolsAltSeason .tools-alt-sub {
    display: none !important;
  }

  #toolsPage #toolsAltSeason .tools-alt-badge {
    max-width: 108px !important;
    padding: 5px 8px !important;
    font-size: 10px !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
  }

  #toolsPage #toolsAltSeason .tools-alt-track {
    height: 6px !important;
    margin-bottom: 8px !important;
  }

  #toolsPage #toolsAltSeason .tools-alt-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 6px !important;
  }

  #toolsPage #toolsAltSeason .tools-alt-stat {
    padding: 7px !important;
    border-radius: 8px !important;
  }

  #toolsPage #toolsAltSeason .tools-alt-stat-label {
    margin-bottom: 2px !important;
    font-size: 8px !important;
  }

  #toolsPage #toolsAltSeason .tools-alt-stat-value {
    font-size: 11px !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  #toolsPage [data-tools-panel="overview"] .tools-section {
    margin: 0 !important;
  }

  #toolsPage [data-tools-panel="overview"] .tools-section-head {
    display: none !important;
  }

  #toolsPage [data-tools-panel="overview"] .tools-intel-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 7px !important;
    margin: 0 !important;
  }

  #toolsPage [data-tools-panel="overview"] .tools-intel-card {
    min-height: 0 !important;
    padding: 10px !important;
    border-radius: 10px !important;
    box-shadow: none !important;
  }

  #toolsPage [data-tools-panel="overview"] .tools-intel-kicker {
    margin-bottom: 4px !important;
    font-size: 9px !important;
  }

  #toolsPage [data-tools-panel="overview"] .tools-intel-title {
    margin-bottom: 0 !important;
    font-size: 13px !important;
    line-height: 1.15 !important;
  }

  #toolsPage [data-tools-panel="overview"] .tools-intel-card > .tools-intel-copy,
  #toolsPage [data-tools-panel="overview"] .tools-mini-bars,
  #toolsPage [data-tools-panel="overview"] .tools-theme-list {
    display: none !important;
  }

  #toolsPage [data-tools-panel="overview"] .tools-intel-read {
    margin-top: 7px !important;
    padding: 7px !important;
    border-radius: 8px !important;
  }

  #toolsPage [data-tools-panel="overview"] .tools-intel-label {
    display: none !important;
  }

  #toolsPage [data-tools-panel="overview"] .tools-intel-read .tools-intel-copy {
    margin: 0 !important;
    font-size: 10.5px !important;
    line-height: 1.25 !important;
    display: -webkit-box !important;
    -webkit-box-orient: vertical !important;
    -webkit-line-clamp: 2 !important;
    overflow: hidden !important;
  }

  #toolsPage [data-tools-panel="overview"] .tools-intel-value {
    font-size: 12px !important;
  }
}

/* Final mobile portfolio correction: remove the top dead space and keep content above bottom nav. */
@media (max-width: 600px) {
  body.portfolio-mobile-active .main {
    overflow: hidden !important;
  }

  body.portfolio-mobile-active .portfolio-page.visible {
    position: absolute !important;
    inset: 0 0 var(--mobile-bottom-nav-h, 64px) 0 !important;
    height: auto !important;
    min-height: 0 !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
    padding-top: 0 !important;
    padding-bottom: 12px !important;
  }

  body.portfolio-mobile-active .portfolio-page.visible .pf-hero {
    top: 0 !important;
    padding-top: 10px !important;
    padding-bottom: 8px !important;
  }

  body.portfolio-mobile-active .portfolio-page.visible .pf-page-inner {
    gap: 12px !important;
    padding-bottom: 24px !important;
  }

  body.portfolio-mobile-active .portfolio-page.visible .pf-charts-row {
    min-height: 0 !important;
  }
}
