/* ============================================================
   StockInsight Pro — Commercial Financial Analysis Platform
   Design System v3.1 (16:9 Widescreen Optimized)
   ============================================================ */

:root {
  --primary-50:#eff6ff;--primary-100:#dbeafe;--primary-200:#bfdbfe;--primary-300:#93c5fd;--primary-400:#60a5fa;--primary-500:#3b82f6;--primary-600:#2563eb;--primary-700:#1d4ed8;--primary-800:#1e40af;--primary-900:#1e3a8a;
  --emerald-50:#ecfdf5;--emerald-100:#d1fae5;--emerald-500:#10b981;--emerald-600:#059669;--emerald-700:#047857;
  --amber-50:#fffbeb;--amber-100:#fef3c7;--amber-500:#f59e0b;--amber-600:#d97706;--amber-700:#b45309;
  --rose-50:#fff1f2;--rose-100:#ffe4e6;--rose-500:#f43f5e;--rose-600:#e11d48;--rose-700:#be123c;
  --slate-0:#fff;--slate-50:#f8fafc;--slate-100:#f1f5f9;--slate-200:#e2e8f0;--slate-300:#cbd5e1;--slate-400:#94a3b8;--slate-500:#64748b;--slate-600:#475569;--slate-700:#334155;--slate-800:#1e293b;--slate-900:#0f172a;
  --bg-body:var(--slate-50);--bg-card:var(--slate-0);--bg-elevated:var(--slate-0);--bg-subtle:var(--slate-100);--bg-hover:#f8fafc;
  --text-primary:var(--slate-900);--text-secondary:var(--slate-600);--text-tertiary:var(--slate-400);--text-inverse:var(--slate-0);
  --border-subtle:var(--slate-200);--border-default:var(--slate-300);--border-strong:var(--slate-400);
  --shadow-xs:0 1px 2px 0 rgb(0 0 0 / 0.04);--shadow-sm:0 1px 2px 0 rgb(0 0 0 / 0.04),0 1px 3px 0 rgb(0 0 0 / 0.06);--shadow-md:0 4px 6px -1px rgb(0 0 0 / 0.06),0 2px 4px -2px rgb(0 0 0 / 0.04);--shadow-lg:0 10px 15px -3px rgb(0 0 0 / 0.06),0 4px 6px -4px rgb(0 0 0 / 0.04);--shadow-xl:0 20px 25px -5px rgb(0 0 0 / 0.06),0 8px 10px -6px rgb(0 0 0 / 0.04);
  --space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;
  --font-sans:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Noto Sans SC','PingFang SC','Microsoft YaHei',sans-serif;
  --font-mono:'SF Mono',Menlo,Monaco,Consolas,monospace;
  --text-xs:12px;--text-sm:13px;--text-base:14px;--text-lg:16px;--text-xl:18px;--text-2xl:20px;--text-3xl:24px;--text-4xl:30px;
  --leading-tight:1.25;--leading-snug:1.375;--leading-normal:1.5;--leading-relaxed:1.625;
  --radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-full:9999px;
  --transition-fast:150ms cubic-bezier(0.4,0,0.2,1);--transition-base:200ms cubic-bezier(0.4,0,0.2,1);--transition-slow:300ms cubic-bezier(0.4,0,0.2,1);
  --max-width:1440px;--navbar-height:60px;--sidebar-width:260px;--navbar-bg:rgba(255,255,255,0.92);
}
[data-theme="dark"] {
  --primary-50:#0f172a;--primary-100:#1e293b;--primary-200:#334155;--primary-300:#475569;--primary-400:#60a5fa;--primary-500:#3b82f6;--primary-600:#2563eb;--primary-700:#1d4ed8;--primary-800:#1e40af;--primary-900:#172554;
  --emerald-50:#064e3b;--emerald-100:#065f46;--emerald-500:#10b981;--emerald-600:#34d399;--emerald-700:#6ee7b7;
  --amber-50:#78350f;--amber-100:#92400e;--amber-500:#f59e0b;--amber-600:#fbbf24;--amber-700:#fcd34d;
  --rose-50:#881337;--rose-100:#9f1239;--rose-500:#f43f5e;--rose-600:#fb7185;--rose-700:#fda4af;
  --slate-0:#0b0f19;--slate-50:#111827;--slate-100:#1f2937;--slate-200:#374151;--slate-300:#4b5563;--slate-400:#6b7280;--slate-500:#9ca3af;--slate-600:#d1d5db;--slate-700:#e5e7eb;--slate-800:#f3f4f6;--slate-900:#f9fafb;
  --bg-body:#0b0f19;--bg-card:#111827;--bg-elevated:#1f2937;--bg-subtle:#1f2937;--bg-hover:#374151;
  --text-primary:#f9fafb;--text-secondary:#9ca3af;--text-tertiary:#6b7280;--text-inverse:#111827;
  --border-subtle:#374151;--border-default:#4b5563;--border-strong:#6b7280;
  --shadow-xs:0 1px 2px 0 rgb(0 0 0 / 0.3);--shadow-sm:0 1px 2px 0 rgb(0 0 0 / 0.3),0 1px 3px 0 rgb(0 0 0 / 0.4);--shadow-md:0 4px 6px -1px rgb(0 0 0 / 0.4),0 2px 4px -2px rgb(0 0 0 / 0.3);--shadow-lg:0 10px 15px -3px rgb(0 0 0 / 0.5),0 4px 6px -4px rgb(0 0 0 / 0.4);--shadow-xl:0 20px 25px -5px rgb(0 0 0 / 0.5),0 8px 10px -6px rgb(0 0 0 / 0.4);
  --navbar-bg:rgba(17,24,39,0.85);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth}
body{font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--text-primary);background:var(--bg-body);min-height:100vh}

/* Layout - 16:9 Widescreen Optimized */
.container{max-width:var(--max-width);margin:0 auto;padding:var(--space-6)}
@media(min-width:1440px){.container{max-width:1600px;padding:var(--space-8)}}
@media(min-width:1920px){.container{max-width:1800px;padding:var(--space-10)}}
@media(max-width:768px){.container{padding:var(--space-4)}}
.page-wrapper{display:flex;gap:var(--space-6)}
.main-content{flex:1;min-width:0}

/* Navbar */
.navbar{position:sticky;top:0;z-index:50;height:var(--navbar-height);background:var(--navbar-bg);backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid var(--border-subtle)}

/* Theme Toggle */
.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:transparent;border-radius:var(--radius-md);cursor:pointer;color:var(--text-secondary);padding:0;transition:color var(--transition-fast),background var(--transition-fast)}
.theme-toggle:hover{background:var(--bg-subtle);color:var(--text-primary)}
.theme-toggle svg{width:20px;height:20px}
.navbar-inner{max-width:var(--max-width);margin:0 auto;padding:0 var(--space-6);height:100%;display:flex;align-items:center;justify-content:space-between}
.logo{display:flex;align-items:center;gap:var(--space-3);font-size:var(--text-lg);font-weight:700;color:var(--text-primary);text-decoration:none;letter-spacing:-0.02em}
.logo svg{width:26px;height:26px;color:var(--primary-600);flex-shrink:0}
.nav-links{display:flex;align-items:center;gap:var(--space-1)}
.nav-links a{padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);text-decoration:none;transition:all var(--transition-fast)}
.nav-links a:hover{color:var(--text-primary);background:var(--bg-subtle)}
.nav-links a.active{color:var(--primary-600);background:var(--primary-50);font-weight:600}
@media(max-width:640px){.navbar-inner{padding:0 var(--space-4)}.nav-links a{padding:var(--space-2) var(--space-3);font-size:var(--text-xs)}}
@media (min-width: 1025px) {
  .nav-links a { padding: var(--space-2) var(--space-3); font-size: var(--text-xs); }
}

/* Sidebar - 16:9 Optimized */
.sidebar{width:var(--sidebar-width);flex-shrink:0;display:flex;flex-direction:column;gap:var(--space-2)}
.sidebar-section{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-subtle);overflow:hidden}
.sidebar-header{padding:var(--space-4) var(--space-5);font-size:var(--text-xs);font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:0.08em;border-bottom:1px solid var(--border-subtle)}
.sidebar-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);font-size:var(--text-sm);color:var(--text-secondary);text-decoration:none;transition:all var(--transition-fast);border-left:3px solid transparent}
.sidebar-item:hover{color:var(--text-primary);background:var(--bg-hover)}
.sidebar-item.active{color:var(--primary-600);background:var(--primary-50);font-weight:600;border-left-color:var(--primary-500)}
.sidebar-icon{width:18px;height:18px;opacity:0.7}
.sidebar-item.active .sidebar-icon{opacity:1;color:var(--primary-600)}
@media(min-width:1440px){.sidebar{width:280px}}

/* Cards */
.card{background:var(--bg-card);border-radius:var(--radius-xl);border:1px solid var(--border-subtle);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-base)}
.card:hover{box-shadow:var(--shadow-md)}
.card-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-subtle)}
.card-body{padding:var(--space-6)}
.card-title{font-size:var(--text-base);font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:var(--space-2)}
.card-subtitle{font-size:var(--text-sm);color:var(--text-tertiary);margin-top:var(--space-1)}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:600;border:none;cursor:pointer;transition:all var(--transition-fast);text-decoration:none;line-height:var(--leading-tight);white-space:nowrap}
.btn:disabled{opacity:0.5;cursor:not-allowed}
.btn-primary{background:var(--primary-600);color:#fff;box-shadow:0 1px 2px rgb(37 99 235 / 0.15)}
.btn-primary:hover:not(:disabled){background:var(--primary-700);transform:translateY(-1px);box-shadow:0 4px 12px rgb(37 99 235 / 0.25)}
.btn-success{background:var(--emerald-600);color:#fff}
.btn-success:hover:not(:disabled){background:var(--emerald-700);transform:translateY(-1px)}
.btn-outline{background:transparent;border:1px solid var(--border-default);color:var(--text-secondary)}
.btn-outline:hover:not(:disabled){border-color:var(--slate-400);color:var(--text-primary);background:var(--bg-subtle)}
.btn-ghost{background:rgba(255,255,255,0.1);color:#fff;border:1px solid rgba(255,255,255,0.2)}
.btn-ghost:hover:not(:disabled){background:rgba(255,255,255,0.2)}
.btn-sm{padding:var(--space-2) var(--space-3);font-size:var(--text-xs);border-radius:var(--radius-md)}
.btn-lg{padding:var(--space-4) var(--space-6);font-size:var(--text-base)}
.btn-block{width:100%}

/* Forms */
input,select,textarea{width:100%;padding:var(--space-3) var(--space-4);border:1px solid var(--border-default);border-radius:var(--radius-lg);font-size:var(--text-sm);font-family:var(--font-sans);color:var(--text-primary);background:var(--bg-card);transition:all var(--transition-fast);outline:none}
input::placeholder,textarea::placeholder{color:var(--text-tertiary)}
input:hover,select:hover,textarea:hover{border-color:var(--border-strong)}
input:focus,select:focus,textarea:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-100)}
select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748B' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:40px}
.form-group{margin-bottom:var(--space-5)}.form-group:last-child{margin-bottom:0}
.form-group label{display:block;font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-2)}
.form-row{display:flex;gap:var(--space-4);align-items:flex-end}.form-row .form-group{flex:1;margin-bottom:0}
.checkbox-group{display:flex;gap:var(--space-6);flex-wrap:wrap}.checkbox-group label{display:flex;align-items:center;gap:var(--space-2);font-weight:400;color:var(--text-secondary);cursor:pointer;margin-bottom:0}.checkbox-group input[type="checkbox"]{width:18px;height:18px;accent-color:var(--primary-600)}

/* Search */
.search-box{position:relative;display:flex;gap:var(--space-3);align-items:stretch}.search-box input{flex:1;font-size:var(--text-base);padding:var(--space-4) var(--space-5)}
.search-box .btn{padding:var(--space-4) var(--space-6)}

/* Autocomplete */
.autocomplete-wrapper{position:relative}
.autocomplete-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:100;background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);border:1px solid var(--border-subtle);overflow:hidden;animation:dropdownSlide 0.2s cubic-bezier(0.16,1,0.3,1);max-height:320px;overflow-y:auto}
@keyframes dropdownSlide{from{opacity:0;transform:translateY(-4px) scale(0.98)}to{opacity:1;transform:translateY(0) scale(1)}}
.autocomplete-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);font-size:var(--text-sm);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);border-bottom:1px solid var(--border-subtle)}
.autocomplete-item:last-child{border-bottom:none}
.autocomplete-item:hover,.autocomplete-item.active{background:var(--primary-50)}
.autocomplete-item .symbol{font-weight:600;font-variant-numeric:tabular-nums;min-width:90px;flex-shrink:0;color:var(--primary-700);font-family:var(--font-mono);font-size:var(--text-xs)}
.autocomplete-item .name{color:var(--text-secondary);flex:1}
.autocomplete-empty{padding:var(--space-6) var(--space-4);text-align:center;color:var(--text-tertiary);font-size:var(--text-sm)}

/* Stats - 16:9 Optimized */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}
.stat-card{background:var(--bg-card);border-radius:var(--radius-xl);border:1px solid var(--border-subtle);padding:var(--space-6);transition:all var(--transition-base)}
.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.stat-value{font-size:var(--text-3xl);font-weight:700;line-height:var(--leading-tight);letter-spacing:-0.02em;color:var(--primary-600)}
.stat-label{font-size:var(--text-sm);color:var(--text-tertiary);margin-top:var(--space-2);font-weight:500}
@media(min-width:1440px){.stats-grid{grid-template-columns:repeat(4,1fr)}.stat-card{padding:var(--space-8)}}
@media(max-width:1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.stats-grid{grid-template-columns:1fr}}

/* Metrics */
.metric-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0}
.metric-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-subtle)}
.metric-item:nth-child(odd){border-right:1px solid var(--border-subtle)}
.metric-item:last-child,.metric-item:nth-last-child(2):nth-child(odd){border-bottom:none}
.metric-name{font-size:var(--text-sm);color:var(--text-secondary);font-weight:500}
.metric-value{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:var(--space-2)}
.metric-summary{padding:var(--space-5);background:var(--bg-subtle);border-radius:var(--radius-lg);font-size:var(--text-sm);line-height:var(--leading-relaxed);color:var(--text-secondary);margin-top:var(--space-4)}
@media(max-width:640px){.metric-grid{grid-template-columns:1fr}.metric-item:nth-child(odd){border-right:none}}

/* Signal Badge */
.signal-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:600;line-height:1}
.signal-badge::before{content:'';width:8px;height:8px;border-radius:50%;flex-shrink:0}
.signal-badge.buy{background:var(--emerald-50);color:var(--emerald-700)}.signal-badge.buy::before{background:var(--emerald-500)}
.signal-badge.sell{background:var(--rose-50);color:var(--rose-700)}.signal-badge.sell::before{background:var(--rose-500)}
.signal-badge.hold{background:var(--amber-50);color:var(--amber-700)}.signal-badge.hold::before{background:var(--amber-500)}
.signal-badge.neutral{background:var(--slate-100);color:var(--slate-600)}.signal-badge.neutral::before{background:var(--slate-400)}
.signal-strength{display:flex;align-items:center;gap:var(--space-3);font-size:var(--text-sm);color:var(--text-tertiary)}
.signal-strength-bar{width:80px;height:6px;background:var(--slate-200);border-radius:var(--radius-full);overflow:hidden}
.signal-strength-fill{height:100%;border-radius:var(--radius-full);transition:width var(--transition-slow)}
.signal-strength-fill.buy{background:var(--emerald-500)}.signal-strength-fill.sell{background:var(--rose-500)}.signal-strength-fill.hold{background:var(--amber-500)}

/* Tags */
.tag{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;line-height:1}
.tag-green{background:var(--emerald-50);color:var(--emerald-700)}.tag-red{background:var(--rose-50);color:var(--rose-700)}.tag-yellow{background:var(--amber-50);color:var(--amber-700)}.tag-blue{background:var(--primary-50);color:var(--primary-700)}.tag-gray{background:var(--slate-100);color:var(--slate-600)}.tag-purple{background:#f3e8ff;color:#7c3aed}

/* Tables - 16:9 Optimized */
.table-container{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border-subtle)}
.table-container table{width:100%;border-collapse:separate;border-spacing:0;font-size:var(--text-sm)}
.table-container thead{background:var(--bg-subtle)}
.table-container th{padding:var(--space-3) var(--space-4);text-align:left;font-weight:600;color:var(--text-secondary);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:0.05em;border-bottom:1px solid var(--border-subtle);white-space:nowrap}
.table-container td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-subtle);color:var(--text-primary);vertical-align:middle}
.table-container td.truncate{max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.table-container tbody tr{transition:background var(--transition-fast)}.table-container tbody tr:hover{background:var(--primary-50)}.table-container tbody tr:last-child td{border-bottom:none}
@media(min-width:1440px){.table-container td{padding:var(--space-4) var(--space-5)}.table-container th{padding:var(--space-4) var(--space-5)}}

/* Tabs */
.tabs{display:flex;gap:var(--space-1);padding:var(--space-1);background:var(--bg-subtle);border-radius:var(--radius-lg);width:fit-content;margin-bottom:var(--space-6)}
.tab{padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);border:none;background:transparent;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.tab:hover{color:var(--text-primary)}.tab.active{background:var(--bg-card);color:var(--primary-600);font-weight:600;box-shadow:var(--shadow-sm)}

/* Feature Cards */
.feature-card{background:var(--bg-card);border-radius:var(--radius-xl);border:1px solid var(--border-subtle);padding:var(--space-8);transition:all var(--transition-base);cursor:pointer}
.feature-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);border-color:var(--primary-200)}
.feature-icon{width:48px;height:48px;border-radius:var(--radius-lg);background:var(--primary-50);color:var(--primary-600);display:flex;align-items:center;justify-content:center;font-size:var(--text-2xl);margin-bottom:var(--space-4)}
.feature-title{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-2)}
.feature-desc{font-size:var(--text-sm);color:var(--text-tertiary);line-height:var(--leading-relaxed)}

/* Report Cards */
.report-card{display:block;padding:var(--space-4) var(--space-5);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:all var(--transition-fast);text-decoration:none}
.report-card:hover{border-color:var(--primary-300);box-shadow:var(--shadow-md)}
.report-card-title{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-1)}
.report-card-meta{font-size:var(--text-xs);color:var(--text-tertiary)}

/* Section Title */
.section-title{font-size:var(--text-xs);font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:var(--space-4);padding-bottom:var(--space-3);border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;gap:var(--space-2)}

/* Dashboard Widgets - 16:9 Optimized */
.widget-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6)}
.widget-lg{grid-column:span 2}
@media(min-width:1440px){.widget-grid{grid-template-columns:repeat(3,1fr)}.widget-lg{grid-column:span 2}}
@media(max-width:1024px){.widget-grid{grid-template-columns:1fr}.widget-lg{grid-column:span 1}}

/* Market Overview */
.market-ticker{display:flex;gap:var(--space-6);padding:var(--space-4) 0;overflow-x:auto}
.ticker-item{display:flex;flex-direction:column;gap:var(--space-1);min-width:120px}
.ticker-name{font-size:var(--text-xs);font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:0.05em}
.ticker-value{font-size:var(--text-xl);font-weight:700;color:var(--text-primary);font-family:var(--font-mono)}
.ticker-change{font-size:var(--text-xs);font-weight:600;font-family:var(--font-mono)}
.ticker-change.up{color:var(--rose-500)}.ticker-change.down{color:var(--emerald-500)}

/* Quick Actions */
.quick-actions{display:flex;gap:var(--space-3);flex-wrap:wrap}
.quick-action{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);text-decoration:none;color:var(--text-secondary);font-size:var(--text-sm);font-weight:500;transition:all var(--transition-fast)}
.quick-action:hover{border-color:var(--primary-300);color:var(--primary-600);box-shadow:var(--shadow-sm)}
.quick-action-icon{width:36px;height:36px;border-radius:var(--radius-md);background:var(--primary-50);color:var(--primary-600);display:flex;align-items:center;justify-content:center;font-size:var(--text-lg)}

/* Activity Feed */
.activity-item{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) 0;border-bottom:1px solid var(--border-subtle)}
.activity-item:last-child{border-bottom:none}
.activity-icon{width:32px;height:32px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);flex-shrink:0}
.activity-content{flex:1}.activity-title{font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}
.activity-meta{font-size:var(--text-xs);color:var(--text-tertiary);margin-top:var(--space-1)}

/* Empty State */
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12);text-align:center}
.empty-state-icon{font-size:var(--text-4xl);margin-bottom:var(--space-4);opacity:0.5}
.empty-state-title{font-size:var(--text-lg);font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-2)}
.empty-state-desc{font-size:var(--text-sm);color:var(--text-tertiary);max-width:360px}

/* Hero */
.hero{background:linear-gradient(135deg,var(--primary-800) 0%,var(--primary-700) 50%,var(--primary-600) 100%);border-radius:var(--radius-xl);padding:var(--space-10) var(--space-8);color:#fff;position:relative;overflow:hidden;margin-bottom:var(--space-6)}
.hero::before{content:'';position:absolute;top:-50%;right:-20%;width:600px;height:600px;background:radial-gradient(circle,rgba(255,255,255,0.08) 0%,transparent 70%);pointer-events:none}
.hero-content{position:relative;z-index:1}
.hero-title{font-size:var(--text-3xl);font-weight:700;letter-spacing:-0.02em;line-height:var(--leading-tight);margin-bottom:var(--space-3)}
.hero-subtitle{font-size:var(--text-base);opacity:0.85;line-height:var(--leading-relaxed);max-width:560px}
.hero-actions{display:flex;gap:var(--space-3);margin-top:var(--space-6)}

/* Grid */
.grid{display:grid;gap:var(--space-6)}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}
@media(min-width:1440px){.grid-4{grid-template-columns:repeat(4,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}}
@media(max-width:1024px){.grid-4{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

/* Toast */
.toast-container{position:fixed;bottom:var(--space-6);right:var(--space-6);z-index:100;display:flex;flex-direction:column;gap:var(--space-3)}
@keyframes toastEnter{from{opacity:0;transform:translateX(20px) scale(0.95)}to{opacity:1;transform:translateX(0) scale(1)}}
.toast{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);border:1px solid var(--border-subtle);border-left:4px solid var(--primary-500);animation:toastEnter 0.3s cubic-bezier(0.16,1,0.3,1);max-width:420px;font-size:var(--text-sm)}
.toast.success{border-left-color:var(--emerald-500)}.toast.error{border-left-color:var(--rose-500)}.toast.warning{border-left-color:var(--amber-500)}

/* Footer */
.footer{text-align:center;padding:var(--space-8) var(--space-6);color:var(--text-tertiary);font-size:var(--text-xs);border-top:1px solid var(--border-subtle);margin-top:var(--space-12)}

/* Utils */
.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--text-tertiary)}.text-primary{color:var(--primary-600)}.text-success{color:var(--emerald-600)}.text-danger{color:var(--rose-600)}.text-warning{color:var(--amber-600)}
.font-mono{font-family:var(--font-mono)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}
.mt-0{margin-top:0}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}
.mb-0{margin-bottom:0}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}
.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}
.hidden{display:none!important}
/* Modal */
.modal { display:none; position:fixed; inset:0; z-index:100; align-items:center; justify-content:center; }
.modal.active { display:flex; }
.modal-backdrop { position:absolute; inset:0; background:rgba(0,0,0,0.5); }
.modal-content { position:relative; background:var(--bg-card); border-radius:var(--radius-lg); width:90%; max-width:600px; max-height:90vh; overflow:auto; box-shadow:var(--shadow-xl); }
.modal-header { display:flex; align-items:center; justify-content:space-between; padding:var(--space-4) var(--space-6); border-bottom:1px solid var(--border-subtle); }
.modal-header h3 { font-size:var(--text-lg); font-weight:600; margin:0; }
.modal-header button { background:none; border:none; font-size:var(--text-2xl); color:var(--text-tertiary); cursor:pointer; line-height:1; }
.modal-body { padding:var(--space-6); }
.compare-grid { display:grid; grid-template-columns:1fr 1fr; gap:var(--space-6); }
@media(max-width:768px){ .compare-grid { grid-template-columns:1fr; } }
.template-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:var(--space-4); }
@media(max-width:768px){ .template-grid { grid-template-columns:1fr; } }
.schedule-list { margin-top:var(--space-4); }
.schedule-item { display:flex; align-items:center; justify-content:space-between; padding:var(--space-3) var(--space-4); background:var(--bg-subtle); border-radius:var(--radius-md); margin-bottom:var(--space-2); }
/* ============================================================
   Dark Mode Component Overrides
   ============================================================ */
body, .card, .navbar, .sidebar, input, select, button, .table-container, .sidebar-drawer, .footer, .toast, .autocomplete-dropdown { transition: background-color var(--transition-base), color var(--transition-base), border-color var(--transition-base); }
[data-theme="dark"] .nav-links a.active { color: var(--primary-400); background: var(--primary-900); }
[data-theme="dark"] .sidebar-item.active { color: var(--primary-400); background: var(--primary-900); border-left-color: var(--primary-400); }
[data-theme="dark"] .sidebar-item.active .sidebar-icon { color: var(--primary-400); }
[data-theme="dark"] .autocomplete-item:hover, [data-theme="dark"] .autocomplete-item.active { background: var(--primary-900); }
[data-theme="dark"] .table-container tbody tr:hover { background: var(--primary-900); }
[data-theme="dark"] input:focus, [data-theme="dark"] select:focus, [data-theme="dark"] textarea:focus { box-shadow: 0 0 0 3px rgba(37,99,235,0.25); }
[data-theme="dark"] .btn-outline:hover:not(:disabled) { border-color: var(--slate-500); }
[data-theme="dark"] .feature-card:hover { border-color: var(--primary-700); }
[data-theme="dark"] .quick-action:hover { border-color: var(--primary-700); }
[data-theme="dark"] .report-card:hover { border-color: var(--primary-700); }
[data-theme="dark"] .signal-strength-bar { background: var(--slate-700); }
[data-theme="dark"] .tag-purple { background: #3b0764; color: #c084fc; }
[data-theme="dark"] select { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%239CA3AF' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E"); }
[data-theme="dark"] .nav-mobile-drawer { background: var(--bg-card); }
[data-theme="dark"] .sidebar-drawer { background: var(--bg-card); }
[data-theme="dark"] .sidebar-overlay { background: rgba(0,0,0,0.6); }

@media(max-width:1024px){.page-wrapper{flex-direction:column}.sidebar{width:100%;flex-direction:row;overflow-x:auto}}

/* =================================================================
   Mobile Responsive
   ================================================================= */

/* Mobile Navigation */
.nav-toggle {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--space-2);
  color: var(--text-primary);
}
.nav-toggle svg {
  width: 24px;
  height: 24px;
}

.nav-mobile-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.4);
  z-index: 40;
}
.nav-mobile-overlay.open {
  display: block;
}

.nav-mobile-drawer {
  display: none;
  position: fixed;
  top: var(--navbar-height);
  left: 0;
  right: 0;
  background: var(--bg-card);
  border-bottom: 1px solid var(--border-subtle);
  box-shadow: var(--shadow-lg);
  z-index: 45;
  padding: var(--space-2);
  flex-direction: column;
  gap: var(--space-1);
}
.nav-mobile-drawer.open {
  display: flex;
}
.nav-mobile-drawer a {
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  font-size: var(--text-base);
  font-weight: 500;
  color: var(--text-secondary);
  text-decoration: none;
}
.nav-mobile-drawer a.active {
  color: var(--primary-600);
  background: var(--primary-50);
  font-weight: 600;
}

/* Mobile Sidebar Drawer */
.sidebar-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.35);
  z-index: 55;
}
.sidebar-overlay.open {
  display: block;
}
.sidebar-drawer {
  display: none;
}

@media (max-width: 1024px) {
  .nav-toggle {
    display: block;
  }
  .nav-links {
    display: none;
  }
  .sidebar {
    display: none;
  }
  .sidebar-drawer {
    display: flex;
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    width: 280px;
    max-width: 80vw;
    background: var(--bg-card);
    z-index: 60;
    flex-direction: column;
    gap: var(--space-2);
    padding: var(--space-4);
    box-shadow: var(--shadow-xl);
    transform: translateX(-100%);
    transition: transform var(--transition-slow);
    overflow-y: auto;
  }
  .sidebar-drawer.open {
    transform: translateX(0);
  }
  .sidebar-drawer-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-bottom: var(--space-4);
    border-bottom: 1px solid var(--border-subtle);
    margin-bottom: var(--space-2);
  }
  .sidebar-drawer-close {
    background: none;
    border: none;
    cursor: pointer;
    padding: var(--space-2);
    color: var(--text-secondary);
  }
  .sidebar-drawer-close svg {
    width: 20px;
    height: 20px;
  }
  .sidebar-drawer .sidebar-section {
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-lg);
    overflow: hidden;
  }
}

@media (max-width: 768px) {
  .container {
    padding: var(--space-4);
  }
  .page-wrapper {
    flex-direction: column;
    gap: var(--space-4);
  }
  .hero {
    padding: var(--space-8) var(--space-5);
    border-radius: var(--radius-lg);
  }
  .hero-title {
    font-size: var(--text-2xl);
  }
  .hero-subtitle {
    font-size: var(--text-sm);
  }
  .hero-actions {
    flex-direction: column;
    gap: var(--space-2);
  }
  .hero-actions .btn {
    width: 100%;
  }
  .search-box {
    flex-direction: column;
    gap: var(--space-3);
  }
  .search-box .btn {
    width: 100%;
    padding: var(--space-4);
  }
  .stats-grid {
    grid-template-columns: 1fr;
    gap: var(--space-3);
  }
  .stat-card {
    padding: var(--space-5);
  }
  .stat-value {
    font-size: var(--text-2xl);
  }
  .quick-actions {
    flex-direction: column;
    gap: var(--space-3);
  }
  .quick-action {
    width: 100%;
    justify-content: flex-start;
  }
  .market-ticker {
    gap: var(--space-4);
    padding: var(--space-3) 0;
  }
  .ticker-value {
    font-size: var(--text-lg);
  }
  .grid-3 {
    grid-template-columns: 1fr;
  }
  .feature-card {
    padding: var(--space-6);
  }
  .form-row {
    flex-direction: column;
    gap: var(--space-3);
    align-items: stretch;
  }
  .form-row .form-group {
    width: 100%;
    max-width: none !important;
  }
  .tabs {
    width: 100%;
    overflow-x: auto;
    flex-wrap: nowrap;
    -webkit-overflow-scrolling: touch;
  }
  .tab {
    white-space: nowrap;
    flex-shrink: 0;
  }
  .metric-grid {
    grid-template-columns: 1fr;
  }
  .metric-item:nth-child(odd) {
    border-right: none;
  }
  .widget-grid {
    grid-template-columns: 1fr;
  }
  .widget-lg {
    grid-column: span 1;
  }
  .grid-2,
  .grid-4 {
    grid-template-columns: 1fr;
  }
  .table-container {
    margin: 0 calc(-1 * var(--space-4));
    border-radius: 0;
    border-left: none;
    border-right: none;
  }
  .card-header {
    padding: var(--space-4) var(--space-5);
  }
  .card-body {
    padding: var(--space-4) var(--space-5);
  }
  .checkbox-group {
    flex-direction: column;
    gap: var(--space-3);
  }
  .toast-container {
    left: var(--space-4);
    right: var(--space-4);
    bottom: var(--space-4);
  }
  .toast {
    max-width: 100%;
  }
  .btn,
  input,
  select,
  textarea,
  .sidebar-item,
  .autocomplete-item,
  .tab,
  .nav-mobile-drawer a {
    min-height: 44px;
  }
  .footer {
    padding: var(--space-6) var(--space-4);
    margin-top: var(--space-8);
  }
}

@media (min-width: 769px) and (max-width: 1024px) {
  .stats-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .grid-4 {
    grid-template-columns: repeat(2, 1fr);
  }
  .grid-3 {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ============================================================
   Analyze Page Enhancements
   ============================================================ */

/* Score Ring */
.score-ring { position: relative; width: 72px; height: 72px; }
.score-ring svg { transform: rotate(-90deg); width: 100%; height: 100%; }
.score-ring-fill { transition: stroke-dasharray 0.6s ease-out, stroke 0.3s ease; }
.score-ring-text { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; font-size: 14px; font-weight: 700; color: var(--text-primary); }

/* Metric Cards */
.metric-card-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-4); }
.metric-card { background: var(--bg-card); border-radius: var(--radius-lg); border: 1px solid var(--border-subtle); padding: var(--space-4); box-shadow: var(--shadow-sm); transition: transform var(--transition-base), box-shadow var(--transition-base); }
.metric-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-lg); }
@media (min-width: 1440px) { .metric-card-grid { grid-template-columns: repeat(4, 1fr); } .metric-card { padding: var(--space-5); } }
@media (max-width: 1024px) { .metric-card-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .metric-card-grid { grid-template-columns: 1fr; } }

/* Trend Arrows (A-share: up=red, down=green) */
.trend-up { color: #f43f5e; font-size: var(--text-xs); }
.trend-down { color: #10b981; font-size: var(--text-xs); }

/* Animations */
@keyframes fadeInUp { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }
.animate-fade-in { animation: fadeInUp 0.4s ease-out both; }

/* Spinner */
.spinner {
  display: inline-block;
  width: 18px;
  height: 18px;
  border: 2px solid var(--border-default);
  border-top-color: var(--primary-500);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
