:root {
    --bg: #07111f;
    --bg2: #0d1728;
    --bg3: #162235;
    --bg4: #1e2d45;
    --border: rgba(148, 163, 184, 0.14);
    --border2: rgba(148, 163, 184, 0.22);
    --cyan: #60a5fa;
    --cyan-dim: rgba(96, 165, 250, 0.16);
    --green: #34d399;
    --green-dim: rgba(52, 211, 153, 0.14);
    --red: #f87171;
    --red-dim: rgba(248, 113, 113, 0.14);
    --amber: #fbbf24;
    --amber-dim: rgba(251, 191, 36, 0.14);
    --text: #f8fbff;
    --text2: #b8c6db;
    --text3: #7f93b2;
    --font: 'Manrope', system-ui, sans-serif;
    --sans: 'Manrope', system-ui, sans-serif;
    --mono: 'IBM Plex Mono', monospace;
    --radius: 20px;
    --radius-sm: 12px;
    --shadow-sm: 0 8px 24px rgba(2, 6, 23, 0.22);
    --shadow-md: 0 18px 40px rgba(2, 6, 23, 0.3), inset 0 1px 0 rgba(255,255,255,0.04);
    --shadow-lg: 0 28px 72px rgba(2, 6, 23, 0.38), inset 0 1px 0 rgba(255,255,255,0.04);
    --target-label-bg: linear-gradient(180deg, rgba(39,39,42,0.96), rgba(24,24,27,0.92));
    --target-label-border: rgba(255,255,255,0.08);
    --target-label-shadow: 0 8px 20px rgba(0,0,0,0.18);
    --chart-chip-bg: linear-gradient(180deg, rgba(30,45,69,0.92), rgba(13,23,40,0.88));
    --chart-chip-border: rgba(148,163,184,0.16);
    --chart-chip-shadow: 0 8px 18px rgba(2,6,23,0.18);
    --transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
  }
  *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
  body { 
    font-family: var(--font);
    background:
      radial-gradient(circle at top left, rgba(96,165,250,0.14), transparent 28%),
      radial-gradient(circle at top right, rgba(52,211,153,0.09), transparent 24%),
      linear-gradient(180deg, #08111e 0%, #07111f 48%, #091628 100%);
    color: var(--text);
    height: 100vh; /* Fallback */
    height: 100dvh; /* Dynamic viewport height for mobile */
    display: flex;
    flex-direction: column;
    overflow: hidden;
    position: relative;
    letter-spacing: -0.01em;
  }
  body::before {
    content: '';
    position: fixed;
    inset: 0;
    background-image:
      linear-gradient(rgba(148,163,184,0.04) 1px, transparent 1px),
      linear-gradient(90deg, rgba(148,163,184,0.04) 1px, transparent 1px);
    background-size: 72px 72px;
    mask-image: linear-gradient(180deg, rgba(0,0,0,0.38), transparent 75%);
    pointer-events: none;
    opacity: 0.42;
  }

  /* ── Top bar ── */
  header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    padding: 18px 24px;
    border-bottom: 1px solid var(--border);
    background: rgba(7,17,31,0.82);
    backdrop-filter: blur(18px);
    flex-shrink: 0;
    position: relative;
    z-index: 10;
    box-shadow: var(--shadow-sm);
  }
  .brand-block {
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 0;
  }
  .logo { display: flex; align-items: center; gap: 10px; }
  .logo-copy {
    display: flex;
    flex-direction: column;
    gap: 2px;
  }
  .logo-icon { 
    width: 34px; height: 34px; background: linear-gradient(135deg, #93c5fd 0%, #38bdf8 100%); border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    box-shadow: 0 10px 28px rgba(56,189,248,0.26);
    transition: var(--transition);
  }
  .logo-icon:hover { 
    box-shadow: 0 12px 30px rgba(56,189,248,0.32);
    transform: translateY(-2px);
  }
  .logo-icon svg { width: 18px; height: 18px; fill: #07111f; }
  .logo-text { 
    font-size: 20px; font-weight: 800; letter-spacing: -0.05em;
    background: linear-gradient(135deg, #ffffff 0%, #cbd5e1 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    line-height: 1;
  }
  .logo-text span { color: var(--cyan); }
  .logo-caption {
    font-size: 11px;
    font-family: var(--mono);
    color: var(--text3);
    text-transform: uppercase;
    letter-spacing: 0.14em;
  }
  .brand-summary {
    max-width: 560px;
    font-size: 13px;
    line-height: 1.5;
    color: var(--text2);
  }
  .header-right {
    display: flex;
    align-items: center;
    gap: 14px;
    justify-content: flex-end;
    flex-wrap: wrap;
  }
  .header-status-group,
  .header-actions-group {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    justify-content: flex-end;
  }
  .llm-switcher {
    display: flex; align-items: center; gap: 8px;
    padding: 8px 12px; border-radius: 999px; border: 1px solid var(--border2);
    background: linear-gradient(180deg, rgba(22,34,53,0.96), rgba(13,23,40,0.92));
    box-shadow: var(--shadow-sm);
    transition: var(--transition);
  }
  .llm-switcher:hover {
    border-color: rgba(96,165,250,0.38);
    background: linear-gradient(180deg, rgba(22,34,53,0.98), rgba(13,23,40,0.95));
  }
  .llm-switcher-label {
    font-size: 10px; font-family: var(--mono); color: var(--text3); text-transform: uppercase; letter-spacing: 0.08em;
  }
  .llm-provider-select, .llm-model-input {
    height: 32px; border-radius: 999px; border: 1px solid var(--border);
    background: var(--bg3); background-clip: padding-box; color: var(--text); font-size: 11px;
    font-family: var(--mono); outline: none; transition: var(--transition);
  }
  .llm-provider-select {
    padding: 0 10px; min-width: 92px; cursor: pointer;
  }
  .llm-model-input {
    width: 156px; padding: 0 12px;
  }
  .llm-provider-select:hover, .llm-model-input:hover {
    border-color: rgba(59,130,246,0.2);
    background: rgba(39,39,42,0.5);
  }
  .llm-provider-select:focus, .llm-model-input:focus {
    border-color: var(--cyan); 
    box-shadow: inset 0 0 0 1px rgba(59,130,246,0.2), 0 0 0 3px rgba(59,130,246,0.12);
    background: rgba(39,39,42,0.6);
  }
  .llm-status {
    min-width: 126px; font-size: 10px; font-family: var(--mono); color: #93c5fd;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  }
  .auth-controls {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 8px;
    border-radius: 999px;
    border: 1px solid var(--border2);
    background: linear-gradient(180deg, rgba(22,34,53,0.96), rgba(13,23,40,0.92));
    box-shadow: var(--shadow-sm);
  }
  .auth-user {
    max-width: 140px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 11px;
    font-family: var(--mono);
    color: var(--text2);
  }
  .auth-btn {
    height: 30px;
    padding: 0 12px;
    border-radius: 999px;
    border: 1px solid var(--border);
    background: var(--bg3);
    color: var(--text);
    font-size: 11px;
    font-family: var(--mono);
    cursor: pointer;
    transition: var(--transition);
  }
  .auth-btn:hover {
    border-color: rgba(59,130,246,0.4);
    color: var(--cyan);
  }
  .auth-modal {
    position: fixed;
    inset: 0;
    display: none;
    align-items: center;
    justify-content: center;
    background: rgba(3, 7, 18, 0.7);
    backdrop-filter: blur(4px);
    z-index: 10000;
    padding: 16px;
  }
  .auth-modal.open {
    display: flex;
  }
  .auth-modal-card {
    width: 100%;
    max-width: 400px;
    border: 1px solid var(--border2);
    border-radius: 14px;
    background: linear-gradient(180deg, rgba(39,39,42,0.98), rgba(24,24,27,0.98));
    box-shadow: var(--shadow-lg);
    padding: 18px;
  }
  .auth-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
  }
  .auth-modal-header h3 {
    margin: 0;
    font-size: 18px;
    color: var(--text);
  }
  .auth-modal-close {
    border: none;
    background: transparent;
    color: var(--text2);
    font-size: 24px;
    line-height: 1;
    cursor: pointer;
  }
  .auth-modal-subtitle {
    margin: 8px 0 14px;
    color: var(--text3);
    font-size: 12px;
    line-height: 1.5;
  }
  .auth-form {
    display: flex;
    flex-direction: column;
    gap: 8px;
  }
  .auth-label {
    color: var(--text2);
    font-family: var(--mono);
    font-size: 11px;
  }
  .auth-input {
    height: 38px;
    border-radius: 10px;
    border: 1px solid var(--border);
    background: var(--bg3);
    color: var(--text);
    padding: 0 12px;
    font-size: 13px;
    outline: none;
    transition: var(--transition);
  }
  .auth-input:focus {
    border-color: var(--cyan);
    box-shadow: inset 0 0 0 1px rgba(59,130,246,0.2), 0 0 0 3px rgba(59,130,246,0.12);
  }
  .auth-error {
    min-height: 18px;
    color: #fca5a5;
    font-size: 12px;
  }
  .auth-submit {
    margin-top: 2px;
    height: 38px;
    border-radius: 10px;
    border: 1px solid rgba(59,130,246,0.35);
    background: linear-gradient(180deg, rgba(59,130,246,0.22), rgba(59,130,246,0.1));
    color: var(--text);
    font-family: var(--mono);
    font-size: 12px;
    cursor: pointer;
    transition: var(--transition);
  }
  .auth-submit:hover {
    border-color: var(--cyan);
    color: #dbeafe;
  }
  .auth-submit:disabled {
    opacity: 0.6;
    cursor: not-allowed;
  }
  .skill-pills { display: flex; gap: 6px; }
  .skill-pill {
    font-size: 10px; font-weight: 500; font-family: var(--mono);
    padding: 6px 10px; border-radius: 999px;
    border: 1px solid var(--border); color: var(--text2);
    background: rgba(13,23,40,0.82); background-clip: padding-box; transition: var(--transition);
    text-transform: uppercase;
    letter-spacing: 0.06em;
  }
  .skill-pill.active { 
    border-color: var(--cyan); color: var(--cyan); background: var(--cyan-dim);
    box-shadow: 0 0 12px rgba(59,130,246,0.15);
  }
  .skill-pill.done { 
    border-color: var(--green); color: var(--green); background: var(--green-dim);
    box-shadow: 0 0 12px rgba(16,185,129,0.15);
  }
  .export-menu { position: relative; }
  .export-btn {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 8px 12px; border-radius: 999px; border: 1px solid var(--border2);
    background: linear-gradient(180deg, rgba(96,165,250,0.14), rgba(96,165,250,0.06));
    color: var(--text); font-family: var(--mono); font-size: 11px; cursor: pointer;
    transition: var(--transition);
    box-shadow: var(--shadow-sm);
  }
  .export-btn:hover { 
    border-color: var(--cyan); 
    background: rgba(59,130,246,0.16);
    transform: translateY(-3px) scale(1.01);
    box-shadow: 0 4px 14px rgba(59,130,246,0.15);
  }
  .export-btn:active {
    transform: translateY(0);
  }
  .export-btn .caret { color: var(--cyan); font-size: 10px; }
  .export-dropdown {
    position: absolute; top: calc(100% + 10px); right: 0; min-width: 180px;
    padding: 8px; border-radius: var(--radius-sm); border: 1px solid var(--border2);
    background: rgba(24,24,27,0.98); backdrop-filter: blur(16px); 
    box-shadow: var(--shadow-lg);
    display: none; z-index: 20;
  }
  .export-dropdown.open { display: block; }
  .reports-menu-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
    min-width: 320px;
    max-width: 360px;
    max-height: 380px;
    overflow-y: auto;
  }
  .reports-menu-empty {
    padding: 12px;
    font-size: 12px;
    color: var(--text3);
    line-height: 1.6;
    text-align: center;
  }
  .report-menu-item {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 10px;
    padding: 10px 12px;
    border-radius: 10px;
    border: 1px solid var(--border);
    background: var(--bg2);
    transition: var(--transition);
  }
  .report-menu-item:hover {
    border-color: var(--cyan);
  }
  .report-menu-meta {
    flex: 1;
    min-width: 0;
  }
  .report-menu-ticker {
    font-size: 12px;
    font-weight: 600;
    color: var(--cyan);
    font-family: var(--mono);
  }
  .report-menu-label {
    margin-top: 3px;
    font-size: 11px;
    color: var(--text2);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .report-menu-date {
    margin-top: 5px;
    font-size: 10px;
    color: var(--text3);
    font-family: var(--mono);
  }
  .report-menu-actions {
    display: flex;
    flex-direction: column;
    gap: 5px;
    flex-shrink: 0;
  }
  .report-menu-action {
    padding: 4px 8px;
    border-radius: 6px;
    font-size: 10px;
    font-family: var(--mono);
    cursor: pointer;
    white-space: nowrap;
    transition: var(--transition);
  }
  .report-menu-action.load {
    background: var(--cyan-dim);
    border: 1px solid rgba(59,130,246,0.3);
    color: var(--cyan);
  }
  .report-menu-action.load:hover {
    background: rgba(59,130,246,0.2);
  }
  .report-menu-action.delete {
    background: var(--red-dim);
    border: 1px solid rgba(239,68,68,0.25);
    color: var(--red);
  }
  .report-menu-action.delete:hover {
    background: rgba(239,68,68,0.18);
  }
  .export-option {
    width: 100%; display: flex; align-items: center; justify-content: space-between;
    gap: 10px; padding: 10px 12px; border: none; background: transparent;
    border-radius: 10px; color: var(--text); font-family: var(--font); font-size: 12px; text-align: left; cursor: pointer;
    transition: var(--transition);
  }
  .export-option:hover { 
    background: rgba(59,130,246,0.12); 
    color: var(--cyan);
    transform: translateX(4px);
  }
  .export-option span { font-family: var(--mono); font-size: 10px; color: var(--text3); }

  /* ── Main layout ── */
  .main {
    display: flex;
    flex: 1;
    overflow: hidden;
    gap: 20px;
    padding: 20px;
    position: relative;
    z-index: 1;
  }

  /* ── Chat panel ── */
  .chat-panel {
    width: 408px;
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    border: 1px solid var(--border);
    border-radius: 28px;
    background: linear-gradient(180deg, rgba(10,19,34,0.9), rgba(13,23,40,0.98));
    box-shadow: var(--shadow-md);
    overflow: hidden;
  }
  .chat-panel-top {
    padding: 18px 18px 0;
  }
  .workspace-card {
    border: 1px solid rgba(96,165,250,0.18);
    border-radius: 18px;
    padding: 10px 12px;
    background:
      radial-gradient(circle at top right, rgba(96,165,250,0.18), transparent 34%),
      linear-gradient(180deg, rgba(17,28,47,0.98), rgba(11,20,36,0.96));
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
  }
  .workspace-kicker {
    font-size: 10px;
    font-family: var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #93c5fd;
  }
  .workspace-title-row {
    display: flex;
    gap: 8px;
    justify-content: space-between;
    align-items: flex-start;
    margin-top: 6px;
  }
  .workspace-title {
    flex: 1;
    min-width: 0;
    font-size: 16px;
    line-height: 1.2;
    letter-spacing: -0.03em;
    max-width: 300px;
  }
  .workspace-live-indicator {
    flex-shrink: 0;
    font-size: 9px;
    font-family: var(--mono);
    color: var(--green);
    padding: 3px 6px;
    border-radius: 999px;
    border: 1px solid rgba(52,211,153,0.22);
    background: rgba(52,211,153,0.08);
  }
  .workspace-description {
    margin-top: 6px;
    font-size: 12px;
    line-height: 1.4;
    color: var(--text2);
  }
  .workspace-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 6px;
    margin-top: 8px;
  }
  .workspace-metric {
    padding: 6px 8px;
    border-radius: 10px;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(148,163,184,0.12);
    min-width: 0;
  }
  .workspace-metric-label {
    display: block;
    font-size: 9px;
    color: var(--text3);
    font-family: var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 5px;
  }
  .workspace-metric strong {
    display: block;
    font-size: 12px;
    line-height: 1.45;
    color: var(--text);
    font-weight: 700;
    letter-spacing: -0.01em;
    overflow-wrap: anywhere;
  }
  .chat-messages {
    flex: 1;
    overflow-y: auto;
    padding: 16px 18px;
    display: flex;
    flex-direction: column;
    gap: 12px;
  }
  .chat-messages::-webkit-scrollbar { width: 4px; }
  .chat-messages::-webkit-scrollbar-thumb { background: var(--border2); border-radius: 2px; }

  .msg { max-width: 85%; display: flex; flex-direction: column; gap: 4px; }
  .msg.user { align-self: flex-end; align-items: flex-end; }
  .msg.bot { align-self: flex-start; align-items: flex-start; }
  .msg-bubble {
    padding: 12px 15px; border-radius: 18px; font-size: 13.5px; line-height: 1.65;
  }
  .msg.user .msg-bubble { 
    background: linear-gradient(135deg, #60a5fa 0%, #38bdf8 100%); color: #07111f; font-weight: 700; border-radius: 18px 18px 6px 18px;
    box-shadow: 0 10px 24px rgba(56,189,248,0.22);
  }
  .msg.bot .msg-bubble { 
    background: linear-gradient(180deg, rgba(22,34,53,0.94), rgba(13,23,40,0.92)); background-clip: padding-box; border: 1px solid var(--border); border-radius: 6px 18px 18px 18px;
    box-shadow: var(--shadow-sm);
  }
  .msg-time { font-size: 10px; color: var(--text3); font-family: var(--mono); }

  .skill-badge {
    display: inline-flex; align-items: center; gap: 5px;
    font-size: 10px; font-family: var(--mono); padding: 2px 8px;
    border-radius: 4px; margin-bottom: 4px;
    transition: var(--transition);
  }
  .skill-badge.s1 { 
    background: rgba(59,130,246,0.1); color: var(--cyan); 
    border: 1px solid rgba(59,130,246,0.2);
    box-shadow: 0 0 8px rgba(59,130,246,0.1);
  }
  .skill-badge.s2 { 
    background: rgba(16,185,129,0.1); color: var(--green);
    border: 1px solid rgba(16,185,129,0.2);
    box-shadow: 0 0 8px rgba(16,185,129,0.1);
  }
  .skill-badge.s3 { 
    background: rgba(245,158,11,0.1); color: var(--amber);
    border: 1px solid rgba(245,158,11,0.2);
    box-shadow: 0 0 8px rgba(245,158,11,0.1);
  }
  .skill-badge.s4 { 
    background: rgba(59,130,246,0.08); color: var(--cyan);
    border: 1px solid rgba(59,130,246,0.18);
    box-shadow: 0 0 8px rgba(59,130,246,0.08);
  }

  .chat-input-area {
    padding: 14px 18px 18px;
    border-top: 1px solid var(--border);
    background: linear-gradient(180deg, rgba(7,17,31,0.65), rgba(7,17,31,0.98));
  }
  .composer-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 10px;
  }
  .composer-title {
    font-size: 13px;
    font-weight: 700;
    color: var(--text);
  }
  .composer-subtitle {
    margin-top: 2px;
    font-size: 11px;
    color: var(--text3);
  }
  .chat-input-row { display: flex; gap: 8px; }
  .chat-input {
    flex: 1; background: rgba(22,34,53,0.88); background-clip: padding-box; border: 1px solid var(--border);
    border-radius: 16px; padding: 12px 14px; color: var(--text);
    font-family: var(--font); font-size: 13px; outline: none; resize: none;
    transition: var(--transition);
    min-height: 48px;
  }
  .chat-input:hover {
    border-color: rgba(59,130,246,0.18);
    background: rgba(39,39,42,0.6);
  }
  .chat-input:focus { 
    border-color: var(--cyan);
    box-shadow: inset 0 0 0 1px rgba(59,130,246,0.2), 0 0 0 3px rgba(59,130,246,0.12);
    background: rgba(39,39,42,0.7);
  }
  .chat-input::placeholder { color: var(--text3); }
  .chat-input:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    background: rgba(22,34,53,0.5);
    border-color: var(--border);
  }
  .send-btn {
    background: var(--cyan); border: none; border-radius: var(--radius-sm);
    width: 40px; height: 40px; cursor: pointer; display: flex; align-items: center;
    justify-content: center; transition: var(--transition); flex-shrink: 0;
    box-shadow: 0 4px 12px rgba(59,130,246,0.24);
  }
  .send-btn:hover { 
    opacity: 0.9;
    transform: translateY(-3px) scale(1.01);
    box-shadow: 0 6px 16px rgba(59,130,246,0.32);
  }
  .send-btn:active {
    transform: translateY(0);
  }
  .send-btn:disabled { 
    opacity: 0.35; cursor: not-allowed;
  }
  .send-btn svg { width: 16px; height: 16px; fill: var(--bg); }
  .stop-btn {
    background: var(--bg3); background-clip: padding-box;
    border: 1px solid var(--border);
    box-shadow: var(--shadow-sm);
  }
  .stop-btn svg { fill: var(--text2); }
  .stop-btn:not(:disabled):hover { 
    border-color: var(--amber);
    background: rgba(245,158,11,0.12);
    box-shadow: 0 4px 12px rgba(245,158,11,0.15);
  }
  .stop-btn:not(:disabled):hover svg { fill: var(--amber); }
  .quick-btns { display: flex; flex-wrap: wrap; gap: 5px; margin-bottom: 8px; }
  .quick-btn {
    font-size: 10px; font-family: var(--mono); padding: 7px 11px;
    background: rgba(13,23,40,0.88); background-clip: padding-box; border: 1px solid var(--border);
    border-radius: 999px; color: var(--text2); cursor: pointer; transition: var(--transition);
    letter-spacing: 0.04em;
  }
  .quick-btn:hover { 
    border-color: var(--cyan); color: var(--cyan); 
    background: var(--cyan-dim);
    box-shadow: 0 0 12px rgba(59,130,246,0.15);
    transform: translateY(-2px);
  }
  .quick-btn:disabled {
    opacity: 0.4;
    cursor: not-allowed;
    pointer-events: none;
    transform: none;
  }

  /* ── Analysis panel ── */
  .analysis-panel {
    flex: 1;
    overflow-y: auto;
    padding: 22px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    position: relative;
    border: 1px solid var(--border);
    border-radius: 30px;
    background: linear-gradient(180deg, rgba(10,19,34,0.76), rgba(10,19,34,0.92));
    box-shadow: var(--shadow-md);
  }
  .analysis-panel::-webkit-scrollbar { width: 4px; }
  .analysis-panel::-webkit-scrollbar-thumb { background: var(--border2); border-radius: 2px; }

  .welcome-state {
    flex: 1;
    display: flex;
    align-items: stretch;
    justify-content: center;
    padding: 6px;
  }
  .welcome-shell {
    width: 100%;
    max-width: 1120px;
    display: grid;
    grid-template-columns: 1.3fr 1fr;
    gap: 18px;
    align-self: center;
  }
  .welcome-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
  }
  .welcome-card {
    border: 1px solid var(--border);
    border-radius: 24px;
    padding: 22px;
    background: linear-gradient(180deg, rgba(16,27,45,0.96), rgba(11,20,36,0.9));
    box-shadow: var(--shadow-sm);
  }
  .welcome-card-primary {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 20px;
    background:
      radial-gradient(circle at top right, rgba(96,165,250,0.16), transparent 30%),
      linear-gradient(180deg, rgba(16,27,45,0.98), rgba(11,20,36,0.94));
  }
  .welcome-badge,
  .welcome-card-kicker {
    display: inline-flex;
    align-self: flex-start;
    padding: 6px 10px;
    border-radius: 999px;
    border: 1px solid rgba(96,165,250,0.24);
    background: rgba(96,165,250,0.08);
    color: #bfdbfe;
    font-size: 10px;
    font-family: var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.12em;
  }
  .welcome-copy h2 {
    margin-top: 16px;
    font-size: 36px;
    line-height: 1.05;
    letter-spacing: -0.06em;
    max-width: 620px;
  }
  .welcome-copy p {
    margin-top: 14px;
    font-size: 15px;
    line-height: 1.75;
    color: var(--text2);
    max-width: 720px;
  }
  .welcome-highlights {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
  }
  .welcome-highlight {
    padding: 14px;
    border-radius: 16px;
    border: 1px solid rgba(148,163,184,0.12);
    background: rgba(255,255,255,0.03);
  }
  .welcome-highlight-label {
    display: block;
    margin-bottom: 6px;
    font-size: 10px;
    color: var(--text3);
    font-family: var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.08em;
  }
  .welcome-highlight strong {
    font-size: 13px;
    line-height: 1.5;
    color: var(--text);
  }
  .welcome-card h3 {
    margin-top: 16px;
    font-size: 20px;
    line-height: 1.15;
    letter-spacing: -0.04em;
  }
  .welcome-card p {
    margin-top: 10px;
    font-size: 13px;
    line-height: 1.65;
    color: var(--text2);
  }

  /* ── Cards ── */
  .card { 
    background: var(--bg2); background-clip: padding-box; border: 1px solid var(--border); 
    border-radius: var(--radius); padding: 16px;
    box-shadow: var(--shadow-sm);
    transition: var(--transition);
  }
  .card:hover {
    border-color: rgba(59,130,246,0.18);
    box-shadow: var(--shadow-md);
    transform: translateY(-3px) scale(1.01);
  }
  .card-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
  .card-title { 
    font-size: 12px; font-family: var(--mono); 
    color: var(--text2); letter-spacing: 0.08em; text-transform: uppercase;
    font-weight: 500;
  }
  .card-skill { font-size: 10px; font-family: var(--mono); padding: 2px 7px; border-radius: 4px; }

  /* ── Ticker header ── */
  .ticker-header { 
    background: var(--bg2); background-clip: padding-box; border: 1px solid var(--border); 
    border-radius: var(--radius); padding: 16px 20px;
    box-shadow: var(--shadow-md);
    transition: var(--transition);
  }
  .ticker-main { display: flex; align-items: flex-start; justify-content: space-between; }
  .ticker-left { display: flex; flex-direction: column; gap: 2px; }
  .ticker-symbol { 
    font-size: 28px; font-weight: 600; letter-spacing: -1px; color: var(--cyan); 
    font-family: var(--mono);
    text-shadow: 0 0 20px rgba(59,130,246,0.15);
  }
  .ticker-name { font-size: 13px; color: var(--text2); }
  .ticker-sector { font-size: 11px; color: var(--text3); margin-top: 2px; }
  .ticker-right { text-align: right; }
  .ticker-price { font-size: 26px; font-weight: 600; font-family: var(--mono); }
  .ticker-change { font-size: 13px; font-family: var(--mono); margin-top: 2px; }
  .ticker-change.up { color: var(--green); }
  .ticker-change.down { color: var(--red); }
  .ticker-stats {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    grid-template-rows: auto auto;
    column-gap: 10px;
    row-gap: 6px;
    margin-top: 14px;
    padding-top: 14px;
    border-top: 1px solid var(--border);
  }
  .stat-label { font-size: 10px; color: var(--text3); font-family: var(--mono); white-space: nowrap; }
  .stat-value { font-size: 13px; font-weight: 500; font-family: var(--mono); white-space: nowrap; }

  /* ── Intelligence cards ── */
  .intel-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
  .intel-card { 
    background: var(--bg3); background-clip: padding-box; border: 1px solid var(--border); 
    border-radius: var(--radius-sm); padding: 12px;
    box-shadow: var(--shadow-sm);
    transition: var(--transition);
  }
  .intel-card:hover {
    border-color: rgba(59,130,246,0.18);
    box-shadow: var(--shadow-md);
  }
  .intel-label { font-size: 10px; color: var(--text3); font-family: var(--mono); margin-bottom: 6px; text-transform: uppercase; }
  .intel-value { font-size: 14px; font-weight: 500; }

  .trend-badge { 
    display: inline-flex; align-items: center; gap: 5px; 
    font-size: 12px; font-weight: 500; padding: 4px 10px; 
    border-radius: 6px;
    transition: var(--transition);
  }
  .trend-badge.bullish { 
    background: var(--green-dim); color: var(--green); 
    border: 1px solid rgba(16,185,129,0.2);
    box-shadow: 0 0 12px rgba(16,185,129,0.12);
  }
  .trend-badge.bearish { 
    background: var(--red-dim); color: var(--red);
    border: 1px solid rgba(239,68,68,0.2);
    box-shadow: 0 0 12px rgba(239,68,68,0.12);
  }
  .trend-badge.neutral { 
    background: var(--amber-dim); color: var(--amber);
    border: 1px solid rgba(245,158,11,0.2);
    box-shadow: 0 0 12px rgba(245,158,11,0.12);
  }

  .sentiment-bar { 
    height: 6px; background: var(--bg); border-radius: 3px; 
    overflow: hidden; margin-top: 6px;
    box-shadow: inset 0 1px 2px rgba(0,0,0,0.3);
  }
  .sentiment-fill { 
    height: 100%; border-radius: 3px; 
    transition: width 0.6s ease;
    background: linear-gradient(90deg, var(--red), var(--amber), var(--green));
  }

  /* ── News list ── */
  .news-item { 
    padding: 10px 0; border-bottom: 1px solid var(--border); 
    display: flex; justify-content: space-between; align-items: flex-start; gap: 8px;
    transition: var(--transition);
  }
  .news-item:hover {
    border-bottom-color: rgba(59,130,246,0.15);
    padding-left: 4px;
    padding-right: -4px;
  }
  .news-item:last-child { border-bottom: none; }
  .news-title { 
    font-size: 12.5px; line-height: 1.45; color: var(--text); flex: 1;
  }
  .news-title a { 
    color: inherit; text-decoration: none;
    transition: var(--transition);
  }
  .news-title a:hover { color: var(--cyan); text-decoration: underline; }
  .news-summary { font-size: 11.5px; line-height: 1.5; color: var(--text2); margin-top: 5px; max-width: 720px; }
  .news-details { margin-top: 5px; }
  .news-toggle { 
    font-size: 10px; font-family: var(--mono); color: var(--cyan); 
    cursor: pointer; user-select: none; list-style: none;
    transition: var(--transition);
  }
  .news-toggle::-webkit-details-marker { display: none; }
  .news-toggle:hover { 
    text-decoration: underline;
    color: #60a5fa;
  }
  .news-meta { display: flex; gap: 6px; align-items: center; margin-top: 4px; }
  .news-source { font-size: 10px; font-family: var(--mono); color: var(--text3); }
  .news-time { font-size: 10px; color: var(--text3); }
  .news-link { font-size: 10px; font-family: var(--mono); color: var(--cyan); text-decoration: none; }
  .news-link:hover { text-decoration: underline; }
  .news-sentiment { 
    flex-shrink: 0; font-size: 11px; font-family: var(--mono); 
    padding: 2px 6px; border-radius: 4px;
    transition: var(--transition);
    box-shadow: 0 1px 4px rgba(0,0,0,0.15);
  }
  .news-sentiment.pos { 
    background: var(--green-dim); color: var(--green);
    border: 1px solid rgba(16,185,129,0.2);
  }
  .news-sentiment.neg { 
    background: var(--red-dim); color: var(--red);
    border: 1px solid rgba(239,68,68,0.2);
  }
  .news-sentiment.neutral { 
    background: var(--amber-dim); color: var(--amber);
    border: 1px solid rgba(245,158,11,0.2);
  }

  /* ── Chart containers ── */
  .chart-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
  .chart-wrap { 
    background: var(--bg2); background-clip: padding-box; border: 1px solid var(--border); 
    border-radius: var(--radius); padding: 14px;
    box-shadow: var(--shadow-sm);
    transition: var(--transition);
  }
  .chart-wrap:hover {
    border-color: rgba(59,130,246,0.18);
    box-shadow: var(--shadow-md);
  }
  .chart-title { font-size: 11px; font-family: var(--mono); color: var(--text2); margin-bottom: 10px; }
  .chart-title-group { display: flex; flex-direction: column; gap: 6px; }
  .chart-legend { display: flex; flex-wrap: wrap; gap: 10px 14px; align-items: center; }
  .chart-legend-item {
    display: inline-flex; align-items: center; gap: 6px; font-size: 10px; font-family: var(--mono); color: var(--text2);
    padding: 5px 8px; border-radius: 999px; border: 1px solid var(--chart-chip-border);
    background: var(--chart-chip-bg); box-shadow: var(--chart-chip-shadow);
  }
  button.chart-legend-item {
    border: 1px solid var(--chart-chip-border);
    background: var(--chart-chip-bg);
    cursor: pointer;
    transition: var(--transition);
  }
  button.chart-legend-item:hover {
    border-color: rgba(59,130,246,0.22);
    color: var(--text);
  }
  button.chart-legend-item.is-off {
    opacity: 0.5;
    border-color: rgba(122,143,184,0.15);
  }
  .chart-legend-swatch { width: 14px; height: 8px; border-radius: 999px; background: var(--text3); flex-shrink: 0; }
  .chart-legend-swatch.candle { background: linear-gradient(90deg, #10b981 0%, #10b981 49%, #ef4444 51%, #ef4444 100%); }
  .chart-legend-swatch.volume { background: rgba(59,130,246,0.5); }
  .chart-legend-swatch.ma10 { height: 0; border-top: 2px dashed #f59e0b; background: transparent; border-radius: 0; }
  .chart-legend-swatch.ma20 { height: 0; border-top: 2px dashed #10b981; background: transparent; border-radius: 0; }
  .chart-legend-values { display: flex; flex-wrap: wrap; gap: 8px 10px; align-items: center; }
  .chart-legend-value {
    display: inline-flex; align-items: center; gap: 6px; font-size: 10px; font-family: var(--mono); color: var(--text3);
    padding: 5px 8px; border-radius: 999px; border: 1px solid var(--chart-chip-border);
    background: var(--chart-chip-bg); box-shadow: var(--chart-chip-shadow);
  }
  .chart-legend-value strong { color: var(--text); font-weight: 500; }
  .chart-legend-date { color: var(--cyan); }
  .chart-canvas-wrap { position: relative; height: 160px; }
  .chart-full { 
    background: var(--bg2); background-clip: padding-box; border: 1px solid var(--border); 
    border-radius: var(--radius); padding: 14px;
    box-shadow: var(--shadow-md);
  }
  .chart-full .chart-canvas-wrap { height: 200px; }
  .news-heatmap-summary { font-size: 10px; font-family: var(--mono); color: var(--text3); margin-bottom: 8px; }
  .news-heatmap-summary strong { color: var(--text); font-weight: 500; }
  .news-heatmap {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(62px, 1fr));
    gap: 6px;
  }
  .news-heatmap-cell {
    border: 1px solid var(--border);
    border-radius: 6px;
    min-height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 6px;
    font-size: 10px;
    font-family: var(--mono);
    color: var(--text);
    cursor: pointer;
    transition: var(--transition);
  }
  .news-heatmap-cell:hover {
    border-color: rgba(59,130,246,0.32);
    transform: translateY(-2px);
  }
  .news-heatmap-hover {
    margin-top: 8px;
    font-size: 11px;
    color: var(--text2);
    min-height: 32px;
    line-height: 1.4;
  }

  /* ── EDA Insights ── */
  .insight-list { display: flex; flex-direction: column; gap: 8px; }
  .insight-item { 
    display: flex; gap: 8px; align-items: flex-start; 
    font-size: 13px; line-height: 1.55;
    transition: var(--transition);
    padding: 4px 0;
  }
  .insight-item:hover {
    padding-left: 4px;
  }
  .insight-dot { 
    width: 6px; height: 6px; border-radius: 50%; 
    background: var(--cyan); margin-top: 6px; flex-shrink: 0;
    box-shadow: 0 0 6px rgba(59,130,246,0.4);
  }
  .risk-flag { 
    display: flex; align-items: center; gap: 8px; font-size: 12px; 
    padding: 8px 10px; background: rgba(239,68,68,0.08); 
    border: 1px solid rgba(239,68,68,0.15); border-radius: var(--radius-sm); 
    color: var(--red);
    box-shadow: 0 0 12px rgba(239,68,68,0.08);
  }

  /* ── Recommendation card ── */
  .rec-card { 
    border-radius: var(--radius); padding: 20px; 
    border: 1px solid var(--border);
    box-shadow: var(--shadow-md);
    background: linear-gradient(135deg, rgba(59,130,246,0.05), rgba(16,185,129,0.03));
    transition: var(--transition);
  }
  .rec-card:hover {
    border-color: rgba(59,130,246,0.2);
    box-shadow: var(--shadow-lg);
  }
  .rec-action { 
    font-size: 36px; font-weight: 700; font-family: var(--mono); 
    letter-spacing: -1px; margin-bottom: 4px;
    text-shadow: 0 2px 8px rgba(0,0,0,0.3);
  }
  .rec-confidence { font-size: 13px; color: var(--text2); margin-bottom: 16px; }
  .confidence-bar-wrap { 
    background: var(--bg); border-radius: 3px; height: 6px; 
    overflow: hidden; margin-top: 6px;
    box-shadow: inset 0 1px 2px rgba(0,0,0,0.3);
  }
  .confidence-bar { 
    height: 100%; border-radius: 3px; 
    transition: width 0.8s cubic-bezier(0.4,0,0.2,1);
    background: linear-gradient(90deg, var(--cyan), var(--green));
  }
  .price-targets { 
    display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px; margin: 16px 0;
  }
  .target-item { 
    background: var(--bg3); background-clip: padding-box; border-radius: var(--radius-sm); 
    padding: 10px;
    box-shadow: var(--shadow-sm);
    transition: var(--transition);
    border: 1px solid var(--border);
  }
  .target-item:hover {
    border-color: rgba(59,130,246,0.18);
    box-shadow: var(--shadow-md);
    transform: translateY(-3px) scale(1.01);
  }
  .target-label { font-size: 10px; color: var(--text3); font-family: var(--mono); margin-bottom: 4px; }
  .target-value { font-size: 16px; font-weight: 600; font-family: var(--mono); }
  .signal-grid { display: flex; flex-direction: column; gap: 6px; margin-top: 14px; }
  .signal-row { 
    display: flex; align-items: center; gap: 8px; font-size: 12px;
    transition: var(--transition);
    padding: 4px 0;
  }
  .signal-row:hover {
    padding-left: 2px;
  }
  .signal-pts { 
    font-family: var(--mono); font-size: 11px; padding: 1px 6px; 
    border-radius: 4px; font-weight: 500;
    transition: var(--transition);
    box-shadow: 0 1px 4px rgba(0,0,0,0.1);
  }
  .signal-pts.pos { 
    background: var(--green-dim); color: var(--green);
    border: 1px solid rgba(16,185,129,0.2);
  }
  .signal-pts.neg { 
    background: var(--red-dim); color: var(--red);
    border: 1px solid rgba(239,68,68,0.2);
  }
  .signal-name { flex: 1; color: var(--text2); }
  .signal-reason { font-size: 11px; color: var(--text3); }
  .signal-detail { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 3px; margin-left: 28px; }
  .detail-chip { 
    font-size: 10px; font-family: var(--mono); padding: 1px 6px; 
    border-radius: 3px; background: var(--bg); border: 1px solid var(--border); 
    color: var(--text2);
    transition: var(--transition);
    box-shadow: 0 1px 3px rgba(0,0,0,0.15);
  }
  .macro-theme-chip {
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-family: var(--mono);
    font-size: 10px;
  }
  .detail-chip span { color: var(--text3); margin-right: 2px; }

  /* ── Historical Patterns card ── */
  .analog-row { 
    display: grid; grid-template-columns: 90px 1fr 1fr 1fr; 
    gap: 8px; align-items: center; font-size: 11px; 
    font-family: var(--mono); padding: 6px 0; border-bottom: 1px solid var(--border);
    transition: var(--transition);
  }
  .analog-row:hover {
    background: rgba(59,130,246,0.04);
    padding-left: 4px;
  }
  .analog-row:last-child { border-bottom: none; }
  .analog-date { color: var(--text3); }
  .analog-ret { text-align: right; }
  .analog-ret.pos { color: var(--green); }
  .analog-ret.neg { color: var(--red); }
  .pattern-stat { 
    background: var(--bg3); background-clip: padding-box; border-radius: var(--radius-sm); 
    padding: 10px 12px; display: flex; flex-direction: column; gap: 3px;
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--border);
    transition: var(--transition);
  }
  .pattern-stat:hover {
    border-color: rgba(59,130,246,0.18);
    box-shadow: var(--shadow-md);
  }
  .pattern-stat-label { font-size: 10px; color: var(--text3); font-family: var(--mono); text-transform: uppercase; }
  .pattern-stat-value { font-size: 16px; font-weight: 600; font-family: var(--mono); }
  .disclaimer { font-size: 10px; color: var(--text3); margin-top: 14px; padding-top: 12px; border-top: 1px solid var(--border); }
  .rr-badge { 
    display: inline-flex; align-items: center; gap: 4px; 
    font-size: 11px; font-family: var(--mono); padding: 3px 8px; 
    border-radius: 4px; margin-top: 8px;
    background: rgba(59,130,246,0.08);
    border: 1px solid rgba(59,130,246,0.15);
    color: var(--cyan);
    transition: var(--transition);
    box-shadow: 0 1px 4px rgba(0,0,0,0.1);
  }
  .rr-badge:hover {
    background: rgba(59,130,246,0.12);
    box-shadow: 0 2px 6px rgba(59,130,246,0.12);
  }

  /* ── Range selector ── */
  .range-selector { display: flex; gap: 4px; flex-wrap: wrap; justify-content: flex-end; }
  .range-btn {
    font-size: 10px; font-family: var(--mono); padding: 3px 8px;
    background: var(--chart-chip-bg); background-clip: padding-box; border: 1px solid var(--chart-chip-border);
    border-radius: 4px; color: var(--text3); cursor: pointer; 
    transition: var(--transition);
    box-shadow: var(--chart-chip-shadow);
  }
  .range-btn:hover { 
    border-color: var(--cyan); color: var(--cyan); 
    background: var(--cyan-dim);
    box-shadow: 0 0 8px rgba(59,130,246,0.12);
  }
  .range-btn.active { 
    border-color: var(--cyan); color: var(--cyan); 
    background: var(--cyan-dim);
    box-shadow: 0 0 12px rgba(59,130,246,0.18);
  }

  /* ── Loading ── */
  .loading-step { 
    display: flex; align-items: center; gap: 10px; 
    padding: 10px 14px; background: var(--bg3); background-clip: padding-box; border: 1px solid var(--border); 
    border-radius: var(--radius-sm); font-size: 13px; color: var(--text2);
    box-shadow: var(--shadow-sm);
  }
  .spin { width: 14px; height: 14px; border: 2px solid var(--border2); border-top-color: var(--cyan); border-radius: 50%; animation: spin 0.7s linear infinite; }
  @keyframes spin { to { transform: rotate(360deg); } }
  .check-icon { color: var(--green); font-size: 14px; }

  /* ── RSI Gauge ── */
  .rsi-gauge { 
    display: flex; flex-direction: column; align-items: center; gap: 8px; 
    padding: 12px; background: var(--bg3); background-clip: padding-box; border-radius: var(--radius-sm);
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--border);
  }
  .rsi-number { font-size: 32px; font-weight: 600; font-family: var(--mono); }
  .rsi-label { font-size: 10px; font-family: var(--mono); padding: 2px 8px; border-radius: 4px; }
  .rsi-bar-track { width: 100%; height: 6px; background: linear-gradient(to right, var(--cyan) 0%, var(--green) 30%, var(--amber) 70%, var(--red) 100%); border-radius: 3px; position: relative; }
  .rsi-marker { position: absolute; top: -4px; width: 14px; height: 14px; background: white; border-radius: 50%; border: 2px solid var(--bg); transform: translateX(-50%); transition: left 0.6s ease; }

  /* ── Analyst target bar ── */
  .target-range { margin-top: 12px; }
  .target-range-bar { 
    height: 8px; background: var(--bg); border-radius: 4px; 
    position: relative; margin: 6px 0;
    box-shadow: inset 0 1px 2px rgba(0,0,0,0.3);
  }
  .target-range-bar-detailed {
    margin-top: 18px;
    margin-bottom: 10px;
  }
  .target-range-fill { 
    position: absolute; top: 0; height: 100%; 
    border-radius: 4px; 
    background: linear-gradient(90deg, var(--red-dim), var(--amber-dim), var(--green-dim));
    box-shadow: 0 0 8px rgba(59,130,246,0.15);
  }
  .target-range-point {
    position: absolute;
    top: 50%;
    width: 10px;
    height: 10px;
    border-radius: 999px;
    transform: translate(-50%, -50%);
    border: 2px solid var(--bg2);
    background: var(--text2);
    z-index: 2;
  }
  .target-range-point-low,
  .target-range-point-high {
    width: 8px;
    height: 18px;
    border-radius: 999px;
    background: rgba(255,255,255,0.7);
  }
  .target-range-point-mean {
    background: var(--amber);
    box-shadow: 0 0 0 3px rgba(245,158,11,0.12);
  }
  .target-range-current { 
    position: absolute; top: -4px; width: 16px; height: 16px; 
    background: var(--cyan); border-radius: 50%; 
    transform: translateX(-50%);
    box-shadow: 0 2px 6px rgba(59,130,246,0.3);
    transition: left 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    z-index: 3;
  }
  .target-range-point-label {
    position: absolute;
    left: 50%;
    bottom: calc(100% + 6px);
    transform: translateX(-50%);
    white-space: nowrap;
    font-size: 9px;
    font-weight: 500;
    letter-spacing: 0.01em;
    font-family: var(--mono);
    color: var(--text2);
    background: var(--target-label-bg);
    border: 1px solid var(--target-label-border);
    border-radius: 8px;
    padding: 4px 7px;
    line-height: 1.2;
    box-shadow: var(--target-label-shadow);
    backdrop-filter: blur(10px);
  }
  .target-range-point-label::after {
    content: '';
    position: absolute;
    left: 50%;
    top: 100%;
    width: 6px;
    height: 6px;
    background: inherit;
    border-right: 1px solid var(--target-label-border);
    border-bottom: 1px solid var(--target-label-border);
    transform: translate(-50%, -55%) rotate(45deg);
  }
  .target-range-point-label-mean {
    color: var(--amber);
    border-color: rgba(245,158,11,0.24);
  }
  .target-range-point-label-current {
    color: var(--cyan);
    border-color: rgba(59,130,246,0.25);
  }
  .target-range-labels { display: flex; justify-content: space-between; font-size: 10px; font-family: var(--mono); color: var(--text3); }

  /* ── Animations ── */
  @keyframes fadeIn { 
    from { opacity: 0; transform: translateY(12px); } 
    to { opacity: 1; transform: translateY(0); } 
  }
  .fade-in { 
    animation: fadeIn 0.4s cubic-bezier(0.4, 0, 0.2, 1) forwards; 
  }

  @keyframes slideInRight {
    from { opacity: 0; transform: translateX(20px); }
    to { opacity: 1; transform: translateX(0); }
  }
  .slide-in-right {
    animation: slideInRight 0.35s cubic-bezier(0.4, 0, 0.2, 1) forwards;
  }

  .section-divider {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 10px 0 6px;
  }
  .section-divider-line { 
    flex: 1;
    height: 1px;
    background: linear-gradient(90deg, rgba(148,163,184,0.05), rgba(148,163,184,0.38), rgba(148,163,184,0.05));
  }
  .section-divider-text { 
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 7px 12px;
    border-radius: 999px;
    border: 1px solid rgba(148,163,184,0.16);
    background: linear-gradient(180deg, rgba(22,34,53,0.98), rgba(13,23,40,0.92));
    box-shadow: 0 10px 24px rgba(2,6,23,0.18), inset 0 1px 0 rgba(255,255,255,0.04);
    font-size: 10px;
    font-family: var(--mono);
    color: var(--text2);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    white-space: nowrap;
  }
  .analysis-back-btn {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    margin-left: 14px;
    padding: 8px 12px;
    border-radius: 999px;
    border: 1px solid rgba(96,165,250,0.18);
    background: linear-gradient(180deg, rgba(96,165,250,0.12), rgba(96,165,250,0.04));
    color: var(--text);
    font-size: 11px;
    font-family: var(--mono);
    line-height: 1;
    cursor: pointer;
    transition: var(--transition);
    box-shadow: 0 10px 24px rgba(2,6,23,0.14);
    white-space: nowrap;
  }
  .analysis-back-btn:hover {
    border-color: rgba(96,165,250,0.36);
    color: #dbeafe;
    transform: translateY(-2px);
    box-shadow: 0 14px 28px rgba(37,99,235,0.18);
  }
  .analysis-back-btn:active {
    transform: translateY(0);
  }
  .analysis-back-btn-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    border-radius: 999px;
    background: rgba(255,255,255,0.1);
    color: var(--cyan);
    font-size: 11px;
    flex-shrink: 0;
  }

  @media (max-width: 1380px) {
    header { height: auto; padding: 12px 16px; align-items: flex-start; gap: 12px; }
    .header-right { flex-wrap: wrap; justify-content: flex-end; }
    .header-status-group,
    .header-actions-group { width: 100%; }
    .llm-switcher { order: -1; }
    .welcome-shell { grid-template-columns: 1fr; }
  }

  @media (max-width: 1120px) {
    .skill-pills { display: none; }
    .main { padding: 16px; gap: 16px; }
    .chat-panel { width: 360px; }
    .analysis-panel { padding: 18px; }
    .workspace-title { max-width: none; font-size: 16px; }
    .welcome-grid { grid-template-columns: 1fr 1fr; }
    .welcome-highlights { grid-template-columns: 1fr; }
  }

  @media (max-width: 980px) {
    .brand-summary { max-width: none; }
    .chat-panel { width: 100%; }
    .main { flex-direction: column; }
    .welcome-copy h2 { font-size: 30px; }
    .welcome-grid { grid-template-columns: 1fr; }
  }

  .mobile-tabs {
    display: none;
  }

  /* ── Mobile Layout Logic (JS toggles .is-mobile class) ── */
  body.is-mobile .mobile-tabs {
    display: flex;
    justify-content: space-around;
    background: var(--bg2);
    border-top: 1px solid var(--border);
    padding: 10px 16px;
    padding-bottom: env(safe-area-inset-bottom, 10px);
    z-index: 100;
    box-shadow: 0 -4px 12px rgba(0,0,0,0.2);
    flex-shrink: 0;
  }
  body.is-mobile .mobile-tab {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    background: transparent;
    border: none;
    color: var(--text3);
    font-size: 11px;
    font-weight: 500;
    cursor: pointer;
    transition: var(--transition);
  }
  body.is-mobile .mobile-tab.active {
    color: var(--cyan);
  }

  body.is-mobile .main {
    flex-direction: column;
    padding: 12px;
    gap: 12px;
    min-height: 0;
  }
  body.is-mobile .chat-panel {
    width: 100%;
    display: none;
    min-height: 0;
  }
  body.is-mobile .analysis-panel {
    padding: 14px;
    display: none;
    min-height: 0;
    overflow-x: hidden;
  }
  
  body.is-mobile .chat-panel-top,
  body.is-mobile .composer-header {
    display: none;
  }
  
  body.is-mobile .chat-input-area {
    padding: 10px 12px;
  }
  
  body.is-mobile .quick-btns {
    margin-bottom: 6px;
    gap: 4px;
  }
  
  body.is-mobile .quick-btn {
    padding: 5px 10px;
    font-size: 9px;
  }

  body.is-mobile .chat-input {
    min-height: 40px;
    padding: 8px 12px;
  }

  body.is-mobile.show-chat .chat-panel {
    display: flex;
    flex: 1;
  }
  body.is-mobile.show-analysis .analysis-panel {
    display: flex;
    flex: 1;
  }

  body.is-mobile header {
    padding: 10px 12px;
    gap: 8px;
  }
  body.is-mobile .brand-summary {
    display: none;
  }
  body.is-mobile .export-menu span {
    display: none; /* Hide 'Export' and 'Reports' text, keep icon if any, or just reduce width */
  }
  body.is-mobile .export-btn {
    padding: 6px 8px;
  }
  body.is-mobile .msg-bubble,
  body.is-mobile .insight-item,
  body.is-mobile .news-summary,
  body.is-mobile .target-value,
  body.is-mobile .pattern-stat-value {
    word-break: break-word;
    overflow-wrap: anywhere;
  }
  body.is-mobile .signal-row {
    flex-wrap: wrap;
  }
  body.is-mobile .detail-chip {
    white-space: normal;
    word-break: break-word;
  }

  body.is-mobile .llm-switcher {
    width: 100%;
    flex-wrap: wrap;
    border-radius: var(--radius-sm);
  }
  body.is-mobile .llm-model-input {
    flex: 1;
    width: auto;
    min-width: 180px;
  }
  body.is-mobile .llm-status {
    width: 100%;
    min-width: 0;
  }
  body.is-mobile .workspace-title-row {
    flex-direction: column;
  }
  body.is-mobile .workspace-metrics,
  body.is-mobile .welcome-highlights,
  body.is-mobile .welcome-grid {
    grid-template-columns: 1fr;
  }
  body.is-mobile .welcome-state {
    padding: 2px;
  }
  body.is-mobile .welcome-copy h2 {
    font-size: 28px;
  }

  body.is-mobile .intel-grid, 
  body.is-mobile .chart-grid,
  body.is-mobile .price-targets {
    grid-template-columns: 1fr;
  }
  
  body.is-mobile .ticker-stats {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  
  body.is-mobile .analog-row {
    grid-template-columns: 75px 1fr 1fr 1fr;
    font-size: 10px;
    gap: 4px;
  }

  /* Fallback if JS hasn't run yet */
  @media (max-width: 900px) {
    body:not(.is-mobile) .main { flex-direction: column; }
    body:not(.is-mobile) .chat-panel { width: 100%; }
    body:not(.is-mobile) .analysis-panel { padding: 16px; }
    body:not(.is-mobile) .llm-switcher { width: 100%; flex-wrap: wrap; border-radius: var(--radius-sm); }
    body:not(.is-mobile) .llm-model-input { flex: 1; width: auto; min-width: 180px; }
    body:not(.is-mobile) .llm-status { width: 100%; min-width: 0; }
    body:not(.is-mobile) .workspace-title-row,
    body:not(.is-mobile) .welcome-shell,
    body:not(.is-mobile) .welcome-grid,
    body:not(.is-mobile) .workspace-metrics,
    body:not(.is-mobile) .welcome-highlights {
      grid-template-columns: 1fr;
      flex-direction: column;
    }
  }

  /* ── Light Theme ── */
  [data-theme="light"] {
    --bg: #eff3f8;
    --bg2: #fbfcfe;
    --bg3: #f2f5f9;
    --bg4: #e4eaf2;
    --border: rgba(15,23,42,0.09);
    --border2: rgba(15,23,42,0.15);
    --text: #0f172a;
    --text2: #334155;
    --text3: #6b7280;
    --cyan: #2563eb;
    --cyan-dim: rgba(37, 99, 235, 0.09);
    --green: #059669;
    --green-dim: rgba(5, 150, 105, 0.09);
    --red: #dc2626;
    --red-dim: rgba(220, 38, 38, 0.09);
    --amber: #d97706;
    --amber-dim: rgba(217, 119, 6, 0.09);
    --shadow-sm: 0 1px 2px rgba(15,23,42,0.04);
    --shadow-md: 0 8px 24px rgba(15,23,42,0.06);
    --shadow-lg: 0 18px 40px rgba(15,23,42,0.08);
    --target-label-bg: linear-gradient(180deg, rgba(255,255,255,0.99), rgba(242,245,249,0.97));
    --target-label-border: rgba(148,163,184,0.2);
    --target-label-shadow: 0 8px 18px rgba(15,23,42,0.06);
    --chart-chip-bg: linear-gradient(180deg, rgba(255,255,255,0.99), rgba(242,245,249,0.96));
    --chart-chip-border: rgba(148,163,184,0.18);
    --chart-chip-shadow: 0 6px 14px rgba(15,23,42,0.04);
  }
  [data-theme="light"] {
    background:
      radial-gradient(circle at top left, rgba(148,163,184,0.12), transparent 22%),
      radial-gradient(circle at top right, rgba(37,99,235,0.06), transparent 18%),
      linear-gradient(180deg, #f8fafc 0%, #eff3f8 52%, #e9eef5 100%);
  }
  [data-theme="light"]::before {
    opacity: 0.18;
  }
  [data-theme="light"] .logo-text { background: linear-gradient(135deg, #0f172a 0%, #64748b 100%); -webkit-background-clip: text; background-clip: text; }
  [data-theme="light"] header {
    background: rgba(248,250,252,0.88);
    box-shadow: 0 1px 2px rgba(15,23,42,0.04);
  }
  [data-theme="light"] .brand-summary,
  [data-theme="light"] .logo-caption { color: #5b6b82; }
  [data-theme="light"] .llm-switcher {
    background: linear-gradient(180deg, #ffffff, #f4f7fb);
    border: 1px solid rgba(15,23,42,0.1);
  }
  [data-theme="light"] .llm-switcher:hover {
    background: linear-gradient(180deg, #ffffff, #eef3f8);
  }
  [data-theme="light"] .llm-provider-select,
  [data-theme="light"] .llm-model-input,
  [data-theme="light"] .auth-btn,
  [data-theme="light"] .quick-btn {
    background: #ffffff;
    border-color: rgba(15,23,42,0.12);
    color: #0f172a;
  }
  [data-theme="light"] .llm-provider-select:hover,
  [data-theme="light"] .llm-model-input:hover,
  [data-theme="light"] .quick-btn:hover {
    background: #eff6ff;
    border-color: rgba(37,99,235,0.2);
  }
  [data-theme="light"] .llm-provider-select:focus,
  [data-theme="light"] .llm-model-input:focus,
  [data-theme="light"] .chat-input:hover,
  [data-theme="light"] .chat-input:focus {
    background: #ffffff;
  }
  [data-theme="light"] .auth-controls,
  [data-theme="light"] .skill-pill,
  [data-theme="light"] .theme-toggle-btn {
    background: linear-gradient(180deg, #ffffff, #f5f7fa);
    border-color: rgba(15,23,42,0.12);
  }
  [data-theme="light"] .export-dropdown { background: rgba(255,255,255,0.98); }
  [data-theme="light"] .export-option:hover { background: rgba(59,130,246,0.08); }
  [data-theme="light"] .chat-panel,
  [data-theme="light"] .analysis-panel {
    background: linear-gradient(180deg, rgba(252,253,255,0.94), rgba(243,246,250,0.98));
    box-shadow: 0 18px 36px rgba(15,23,42,0.07);
  }
  [data-theme="light"] .workspace-card,
  [data-theme="light"] .welcome-card,
  [data-theme="light"] .msg.bot .msg-bubble {
    background:
      radial-gradient(circle at top right, rgba(37,99,235,0.06), transparent 30%),
      linear-gradient(180deg, rgba(255,255,255,0.99), rgba(246,248,251,0.98));
    border-color: rgba(15,23,42,0.09);
  }
  [data-theme="light"] .workspace-metric,
  [data-theme="light"] .welcome-highlight {
    background: rgba(250,251,253,0.96);
    border-color: rgba(15,23,42,0.08);
  }
  [data-theme="light"] .workspace-kicker,
  [data-theme="light"] .welcome-badge,
  [data-theme="light"] .welcome-card-kicker {
    color: #1d4ed8;
    border-color: rgba(37,99,235,0.14);
    background: rgba(37,99,235,0.06);
  }
  [data-theme="light"] .workspace-title,
  [data-theme="light"] .workspace-metric strong {
    color: #0f172a;
  }
  [data-theme="light"] .workspace-description,
  [data-theme="light"] .workspace-metric-label {
    color: #5b6b82;
  }
  [data-theme="light"] .section-divider-line {
    background: linear-gradient(90deg, rgba(148,163,184,0.05), rgba(148,163,184,0.45), rgba(148,163,184,0.05));
  }
  [data-theme="light"] .section-divider-text {
    background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(244,248,253,0.98));
    border-color: rgba(15,23,42,0.08);
    box-shadow: 0 10px 20px rgba(15,23,42,0.06);
    color: #475569;
  }
  [data-theme="light"] .analysis-back-btn {
    background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(239,246,255,0.98));
    border-color: rgba(37,99,235,0.16);
    color: #0f172a;
    box-shadow: 0 10px 20px rgba(15,23,42,0.06);
  }
  [data-theme="light"] .analysis-back-btn:hover {
    color: #1d4ed8;
    border-color: rgba(37,99,235,0.28);
    box-shadow: 0 14px 24px rgba(37,99,235,0.12);
  }
  [data-theme="light"] .analysis-back-btn-icon {
    background: rgba(37,99,235,0.08);
    color: #2563eb;
  }
  [data-theme="light"] .workspace-live-indicator {
    color: #047857;
    border-color: rgba(5,150,105,0.18);
    background: rgba(16,185,129,0.08);
  }
  [data-theme="light"] .msg.user .msg-bubble { color: #ffffff; }
  [data-theme="light"] .chat-input-area { background: linear-gradient(180deg, rgba(248,250,252,0.7), rgba(255,255,255,0.98)); }
  [data-theme="light"] .chat-input { background: #f8fafc; border-color: rgba(0,0,0,0.1); }
  [data-theme="light"] .stop-btn { background: #f8fafc; }
  [data-theme="light"] .auth-modal {
    background: rgba(15, 23, 42, 0.25);
  }
  [data-theme="light"] .auth-modal-card {
    background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
    border-color: rgba(15, 23, 42, 0.12);
    box-shadow: 0 16px 40px rgba(15, 23, 42, 0.18);
  }
  [data-theme="light"] .auth-modal-header h3 {
    color: #0f172a;
  }
  [data-theme="light"] .auth-modal-subtitle {
    color: #475569;
  }
  [data-theme="light"] .auth-modal-close {
    color: #475569;
  }
  [data-theme="light"] .auth-modal-close:hover {
    color: #0f172a;
  }
  [data-theme="light"] .auth-label {
    color: #334155;
  }
  [data-theme="light"] .auth-input {
    background: #ffffff;
    border-color: rgba(15, 23, 42, 0.14);
    color: #0f172a;
  }
  [data-theme="light"] .auth-input:focus {
    border-color: #3b82f6;
    box-shadow: inset 0 0 0 1px rgba(59,130,246,0.18), 0 0 0 3px rgba(59,130,246,0.14);
  }
  [data-theme="light"] .auth-error {
    color: #dc2626;
  }
  [data-theme="light"] .auth-submit {
    background: linear-gradient(180deg, #3b82f6 0%, #2563eb 100%);
    border-color: #2563eb;
    color: #ffffff;
  }
  [data-theme="light"] .auth-submit:hover {
    background: linear-gradient(180deg, #2563eb 0%, #1d4ed8 100%);
    border-color: #1d4ed8;
    color: #ffffff;
  }
  
  .theme-toggle-btn {
    display: inline-flex; align-items: center; justify-content: center;
    width: 32px; height: 32px; border-radius: 50%;
    border: 1px solid var(--border2); background: var(--bg2);
    color: var(--text2); cursor: pointer; transition: var(--transition);
  }
  .theme-toggle-btn:hover {
    color: var(--cyan); border-color: var(--cyan); transform: scale(1.05);
  }
  .theme-toggle-btn svg { width: 14px; height: 14px; fill: currentColor; }

  /* Mock/Live switch styling */
  .mode-switch-container {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 10px;
    border-radius: 999px;
    border: 1px solid var(--border2);
    background: linear-gradient(180deg, rgba(22,34,53,0.96), rgba(13,23,40,0.92));
    box-shadow: var(--shadow-sm);
    transition: var(--transition);
  }
  .mode-switch-container:hover {
    border-color: rgba(96,165,250,0.38);
  }
  .mode-switch-label {
    font-size: 10px;
    font-family: var(--mono);
    color: var(--text3);
    text-transform: uppercase;
    letter-spacing: 0.08em;
  }
  .mode-toggle {
    display: flex;
    position: relative;
    width: 90px;
    height: 24px;
    background: var(--bg3);
    border: 1px solid var(--border);
    border-radius: 999px;
    cursor: pointer;
    overflow: hidden;
    user-select: none;
    transition: var(--transition);
  }
  .mode-toggle-option {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 9.5px;
    font-family: var(--mono);
    font-weight: 700;
    color: var(--text3);
    z-index: 2;
    transition: var(--transition);
    text-transform: uppercase;
  }
  .mode-toggle.mock .option-mock {
    color: #07111f;
  }
  .mode-toggle.live .option-live {
    color: #07111f;
  }
  .mode-toggle-slider {
    position: absolute;
    top: 1px;
    left: 1px;
    width: 42px;
    height: 20px;
    background: var(--cyan);
    border-radius: 999px;
    z-index: 1;
    transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1), background-color 0.3s ease;
    box-shadow: 0 2px 6px rgba(96,165,250,0.4);
  }
  .mode-toggle.live .mode-toggle-slider {
    transform: translateX(44px);
    background: var(--green);
    box-shadow: 0 2px 6px rgba(52,211,153,0.4);
  }

  /* Mock mode workspace indicator */
  .workspace-live-indicator.mock-mode {
    color: var(--cyan);
    border-color: rgba(96,165,250,0.24);
    background: rgba(96,165,250,0.08);
  }

  /* Light theme variations */
  [data-theme="light"] .mode-switch-container {
    background: linear-gradient(180deg, #f8fafc, #f1f5f9);
    border-color: rgba(15, 23, 42, 0.08);
  }
  [data-theme="light"] .mode-switch-container:hover {
    border-color: rgba(59,130,246,0.3);
  }
  [data-theme="light"] .mode-toggle {
    background: #e2e8f0;
    border-color: rgba(15, 23, 42, 0.08);
  }
  [data-theme="light"] .mode-toggle-option {
    color: #64748b;
  }
  [data-theme="light"] .mode-toggle.mock .option-mock {
    color: #ffffff;
  }
  [data-theme="light"] .mode-toggle.live .option-live {
    color: #ffffff;
  }

  /* Multi-Agent Toggle Styles */
  .mode-toggle.on .option-on {
    color: #07111f;
  }
  .mode-toggle.on .mode-toggle-slider {
    transform: translateX(44px);
    background: #8b5cf6;
    box-shadow: 0 2px 6px rgba(139,92,246,0.4);
  }
  [data-theme="light"] .mode-toggle.on .option-on {
    color: #ffffff;
  }
  [data-theme="light"] .mode-toggle.on .mode-toggle-slider {
    background: #8b5cf6;
    box-shadow: 0 2px 6px rgba(139,92,246,0.3);
  }
  .mode-toggle.off .option-off {
    color: #07111f;
  }
  [data-theme="light"] .mode-toggle.off .option-off {
    color: #ffffff;
  }

  /* Multi-Agent Debate Arena Layout */
  .debate-arena-header {
    margin-bottom: 14px;
    padding-bottom: 8px;
    border-bottom: 1px dashed var(--border);
  }
  .debate-arena-title {
    font-size: 14px;
    font-weight: 700;
    color: #a78bfa;
    display: flex;
    align-items: center;
    gap: 6px;
  }
  .debate-arena-subtitle {
    font-size: 11px;
    color: var(--text3);
    font-family: var(--mono);
    margin-top: 2px;
  }

  .debate-arena-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    margin-bottom: 14px;
  }
  
  @media (max-width: 768px) {
    .debate-arena-grid {
      grid-template-columns: 1fr;
      gap: 10px;
    }
  }

  .debate-card {
    padding: 12px 14px;
    border-radius: 12px;
    border: 1px solid var(--border);
    transition: var(--transition);
  }
  .debate-card:hover {
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
  }

  .debate-card.bullish {
    background: rgba(16,185,129,0.03);
    border-color: rgba(16,185,129,0.18);
  }
  [data-theme="light"] .debate-card.bullish {
    background: rgba(16,185,129,0.02);
  }

  .debate-card.bearish {
    background: rgba(239,68,68,0.03);
    border-color: rgba(239,68,68,0.18);
  }
  [data-theme="light"] .debate-card.bearish {
    background: rgba(239,68,68,0.02);
  }

  .debate-card.decision {
    background: linear-gradient(135deg, rgba(139,92,246,0.05), rgba(139,92,246,0.01));
    border-color: rgba(139,92,246,0.25);
    box-shadow: 0 4px 12px rgba(139,92,246,0.05);
  }
  [data-theme="light"] .debate-card.decision {
    background: linear-gradient(135deg, rgba(139,92,246,0.03), rgba(139,92,246,0.005));
  }

  .debate-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 8px;
    border-bottom: 1px solid rgba(255,255,255,0.04);
    padding-bottom: 6px;
  }
  [data-theme="light"] .debate-card-header {
    border-bottom-color: rgba(15,23,42,0.04);
  }

  .debate-agent-icon {
    font-size: 14px;
    margin-right: 4px;
  }
  .debate-agent-name {
    font-size: 12.5px;
    font-weight: 600;
    color: var(--text);
  }
  .debate-agent-badge {
    font-size: 9px;
    font-family: var(--mono);
    padding: 1px 6px;
    border-radius: 4px;
    font-weight: 600;
  }
  .debate-agent-badge.pos {
    background: rgba(16,185,129,0.1);
    color: var(--green);
    border: 1px solid rgba(16,185,129,0.2);
  }
  .debate-agent-badge.neg {
    background: rgba(239,68,68,0.1);
    color: var(--red);
    border: 1px solid rgba(239,68,68,0.2);
  }

  .debate-analysis {
    font-size: 12px;
    line-height: 1.55;
    color: var(--text2);
    margin: 0 0 10px 0;
  }

  .debate-bullets {
    display: flex;
    flex-direction: column;
    gap: 6px;
  }
  .debate-bullet {
    display: flex;
    align-items: flex-start;
    gap: 6px;
    font-size: 11.5px;
    color: var(--text2);
    line-height: 1.45;
  }
  .debate-bullet .bullet-icon {
    font-size: 10px;
    flex-shrink: 0;
    margin-top: 2px;
  }
  .debate-bullet .bullet-icon {
    color: var(--text3);
  }
  .debate-card.bullish .bullet-icon {
    color: var(--green);
  }
  .debate-card.bearish .bullet-icon {
    color: var(--red);
  }

  .debate-flow-divider {
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 16px 0;
  }
  .debate-flow-line {
    flex: 1;
    height: 1px;
    background: linear-gradient(90deg, rgba(139,92,246,0.01), rgba(139,92,246,0.3), rgba(139,92,246,0.01));
  }
  .debate-flow-badge {
    font-size: 10px;
    font-family: var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 4px 10px;
    border-radius: 20px;
    background: rgba(139,92,246,0.08);
    border: 1px solid rgba(139,92,246,0.15);
    color: #a78bfa;
  }

  /* Multi-Round Debate Additions */
  .debate-round-header {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 14px 0 10px 0;
  }
  .debate-round-number {
    font-size: 9px;
    font-family: var(--mono);
    font-weight: 700;
    color: #a78bfa;
    background: rgba(139,92,246,0.09);
    border: 1px solid rgba(139,92,246,0.22);
    padding: 2px 6px;
    border-radius: 4px;
    letter-spacing: 0.05em;
  }
  .debate-round-title {
    font-size: 11px;
    font-family: var(--mono);
    color: var(--text2);
    text-transform: uppercase;
    letter-spacing: 0.05em;
  }
  .rebuttal-card {
    border-style: dashed !important;
    background: transparent !important;
  }
  .rebuttal-card .debate-analysis {
    margin-bottom: 0;
  }

  /* ── Multi-Agent Advisory Card ── */
  .multi-agent-advisory {
    grid-column: 1 / span 2;
    border: 1px solid rgba(245,158,11,0.22) !important;
    background: radial-gradient(circle at top right, rgba(245,158,11,0.08), transparent 35%), linear-gradient(180deg, rgba(24,18,12,0.98), rgba(16,11,8,0.94));
    display: flex;
    flex-direction: column;
    gap: 10px;
  }
  .advisory-badge {
    display: inline-flex;
    align-self: flex-start;
    padding: 4px 10px;
    border-radius: 999px;
    border: 1px solid rgba(245,158,11,0.3);
    background: rgba(245,158,11,0.1);
    color: #fef08a;
    font-size: 10px;
    font-family: var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.12em;
  }
  .advisory-title {
    margin-top: 6px;
    font-size: 16px;
    color: var(--amber);
    letter-spacing: -0.02em;
  }
  .advisory-desc {
    margin-top: 2px;
    font-size: 13.5px;
    line-height: 1.6;
    color: var(--text2);
  }
  .advisory-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
    margin-top: 10px;
  }
  .advisory-item {
    padding: 10px;
    border-radius: 10px;
    border: 1px solid rgba(255,255,255,0.05);
    background: rgba(255,255,255,0.02);
  }
  .advisory-item-label {
    display: block;
    font-size: 9px;
    font-family: var(--mono);
    text-transform: uppercase;
    color: var(--amber);
    margin-bottom: 4px;
  }
  .advisory-item-desc {
    font-size: 11px;
    color: var(--text2);
    line-height: 1.4;
    display: block;
  }

  /* Light theme overrides for Advisory card */
  [data-theme="light"] .multi-agent-advisory {
    background: radial-gradient(circle at top right, rgba(217,119,6,0.06), transparent 35%), linear-gradient(180deg, #fefefe, #f1f5f9);
    border-color: rgba(217,119,6,0.3) !important;
  }
  [data-theme="light"] .advisory-badge {
    border-color: rgba(217,119,6,0.3);
    background: rgba(217,119,6,0.1);
    color: #b45309;
  }
  [data-theme="light"] .advisory-item {
    border-color: rgba(15,23,42,0.06);
    background: rgba(15,23,42,0.02);
  }
  [data-theme="light"] .advisory-item-desc {
    color: var(--text2);
  }
  [data-theme="light"] .advisory-desc {
    color: var(--text2);
  }
  [data-theme="light"] .advisory-title {
    color: var(--amber);
  }
