@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--bg-primary: #0a0e17;--bg-secondary: #111827;--bg-card: rgba(17, 24, 39, .8);--bg-card-hover: rgba(31, 41, 55, .9);--bg-glass: rgba(255, 255, 255, .03);--border-glass: rgba(255, 255, 255, .08);--border-active: rgba(99, 102, 241, .4);--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--accent-primary: #6366f1;--accent-primary-glow: rgba(99, 102, 241, .3);--accent-secondary: #8b5cf6;--gain: #10b981;--gain-bg: rgba(16, 185, 129, .1);--gain-glow: rgba(16, 185, 129, .3);--loss: #ef4444;--loss-bg: rgba(239, 68, 68, .1);--loss-glow: rgba(239, 68, 68, .3);--hold: #f59e0b;--hold-bg: rgba(245, 158, 11, .1);--gradient-primary: linear-gradient(135deg, #6366f1, #8b5cf6);--gradient-gain: linear-gradient(135deg, #10b981, #34d399);--gradient-loss: linear-gradient(135deg, #ef4444, #f87171);--gradient-card: linear-gradient(135deg, rgba(17, 24, 39, .9), rgba(31, 41, 55, .6));--sidebar-width: 260px;--radius: 12px;--radius-lg: 16px;--radius-sm: 8px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased;overflow-x:hidden}body:before{content:"";position:fixed;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 20%,rgba(99,102,241,.08) 0%,transparent 50%),radial-gradient(circle at 70% 80%,rgba(139,92,246,.06) 0%,transparent 50%);z-index:-1;animation:bgShift 20s ease-in-out infinite alternate}@keyframes bgShift{0%{transform:translate(0)}to{transform:translate(-5%,-3%)}}#root{display:flex;min-height:100vh}.app-layout{display:flex;width:100%;min-height:100vh}.main-content{flex:1;margin-left:var(--sidebar-width);padding:28px 32px;min-height:100vh}.sidebar{position:fixed;left:0;top:0;width:var(--sidebar-width);height:100vh;background:var(--bg-secondary);border-right:1px solid var(--border-glass);display:flex;flex-direction:column;z-index:100;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.sidebar-logo{padding:24px 20px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border-glass)}.sidebar-logo .logo-icon{width:40px;height:40px;border-radius:var(--radius);background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;font-size:18px;box-shadow:0 4px 15px var(--accent-primary-glow)}.sidebar-logo h1{font-size:18px;font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.3px}.sidebar-logo span{font-size:11px;color:var(--text-muted);display:block;margin-top:2px}.sidebar-nav{padding:16px 12px;flex:1;display:flex;flex-direction:column;gap:4px}.nav-link{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:var(--radius-sm);color:var(--text-secondary);text-decoration:none;font-size:14px;font-weight:500;transition:all .2s ease;cursor:pointer;border:1px solid transparent}.nav-link:hover{background:var(--bg-glass);color:var(--text-primary)}.nav-link.active{background:var(--accent-primary-glow);color:#fff;border-color:var(--border-active)}.nav-link svg{width:20px;height:20px;flex-shrink:0}.card{background:var(--gradient-card);border:1px solid var(--border-glass);border-radius:var(--radius-lg);padding:24px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);transition:all .3s ease}.card:hover{border-color:var(--border-active);box-shadow:0 8px 32px #0000004d}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.card-title{font-size:15px;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:8px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--gradient-card);border:1px solid var(--border-glass);border-radius:var(--radius-lg);padding:20px 24px;display:flex;flex-direction:column;gap:8px;transition:all .3s ease;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-primary);opacity:0;transition:opacity .3s ease}.stat-card:hover:before{opacity:1}.stat-card:hover{transform:translateY(-2px);box-shadow:0 8px 32px #0003}.stat-label{font-size:12px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:28px;font-weight:700;letter-spacing:-.5px}.stat-change{font-size:13px;font-weight:600;display:flex;align-items:center;gap:4px}.stat-change.positive{color:var(--gain)}.stat-change.negative{color:var(--loss)}.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600;letter-spacing:.3px}.badge-buy{background:var(--gain-bg);color:var(--gain);border:1px solid rgba(16,185,129,.2)}.badge-sell{background:var(--loss-bg);color:var(--loss);border:1px solid rgba(239,68,68,.2)}.badge-hold{background:var(--hold-bg);color:var(--hold);border:1px solid rgba(245,158,11,.2)}.rec-card{background:var(--gradient-card);border:1px solid var(--border-glass);border-radius:var(--radius);padding:16px 20px;display:flex;align-items:center;gap:16px;transition:all .2s ease;cursor:pointer}.rec-card:hover{background:var(--bg-card-hover);transform:translate(4px)}.rec-card .rec-symbol{font-size:16px;font-weight:700;min-width:60px}.rec-card .rec-name{flex:1;font-size:13px;color:var(--text-secondary)}.rec-card .rec-confidence{font-size:14px;font-weight:600}.page-header{margin-bottom:28px}.page-header h2{font-size:26px;font-weight:700;letter-spacing:-.5px;margin-bottom:6px}.page-header p{color:var(--text-secondary);font-size:14px}.data-table{width:100%;border-collapse:separate;border-spacing:0}.data-table thead th{padding:12px 16px;text-align:left;font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-glass)}.data-table tbody tr{transition:background .2s ease}.data-table tbody tr:hover{background:var(--bg-glass)}.data-table tbody td{padding:14px 16px;font-size:14px;border-bottom:1px solid rgba(255,255,255,.03)}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;border:none;cursor:pointer;transition:all .2s ease;font-family:inherit}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:0 4px 15px var(--accent-primary-glow)}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px var(--accent-primary-glow)}.btn-success{background:var(--gradient-gain);color:#fff;box-shadow:0 4px 15px var(--gain-glow)}.btn-danger{background:var(--gradient-loss);color:#fff;box-shadow:0 4px 15px var(--loss-glow)}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border-glass)}.btn-ghost:hover{background:var(--bg-glass);color:var(--text-primary)}.btn-sm{padding:6px 12px;font-size:12px}.input-field{padding:10px 16px;border-radius:var(--radius-sm);border:1px solid var(--border-glass);background:var(--bg-secondary);color:var(--text-primary);font-size:14px;font-family:inherit;transition:all .2s ease;outline:none;width:100%}.input-field:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-glow)}.input-field::placeholder{color:var(--text-muted)}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:13px;font-weight:500;color:var(--text-secondary)}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}select.input-field{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%2394a3b8' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:200;animation:fadeIn .2s ease}.modal{background:var(--bg-secondary);border:1px solid var(--border-glass);border-radius:var(--radius-lg);padding:28px;width:90%;max-width:500px;animation:slideUp .3s ease}.modal h3{font-size:18px;font-weight:700;margin-bottom:20px}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.progress-bar{height:8px;background:var(--bg-primary);border-radius:4px;overflow:hidden}.progress-fill{height:100%;border-radius:4px;transition:width .5s ease}.confidence-meter{display:flex;align-items:center;gap:8px}.confidence-bar{flex:1;height:6px;background:var(--bg-primary);border-radius:3px;overflow:hidden}.confidence-fill{height:100%;border-radius:3px;transition:width .5s ease}.spinner{width:40px;height:40px;border:3px solid var(--border-glass);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-container{display:flex;align-items:center;justify-content:center;min-height:300px;flex-direction:column;gap:16px;color:var(--text-muted)}.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted)}.empty-state svg{margin-bottom:16px;opacity:.3}.empty-state h3{font-size:16px;color:var(--text-secondary);margin-bottom:8px}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-glass);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media (max-width: 1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:1fr}}@media (max-width: 768px){.sidebar{display:none}.main-content{margin-left:0;padding:16px}.stats-grid,.grid-2{grid-template-columns:1fr}}.recharts-cartesian-grid-horizontal line,.recharts-cartesian-grid-vertical line{stroke:var(--border-glass)!important}.recharts-text{fill:var(--text-muted)!important;font-size:11px!important}@keyframes pulseGlow{0%,to{box-shadow:0 0 0 0 var(--accent-primary-glow)}50%{box-shadow:0 0 20px 5px var(--accent-primary-glow)}}.pulse-glow{animation:pulseGlow 2s ease-in-out infinite}
