@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0a0c10;--bg-2:#0d0f14;--surface:#131720;--surface-2:#181d28;--border:#1e2533;--border-2:#252d3d;--text:#e4eaf5;--text-2:#7e8fa8;--text-3:#475569;--green:#22d46e;--green-dim:#0d3323;--amber:#f59e0b;--amber-dim:#3d2503;--red:#f04747;--red-dim:#3d0f0f;--blue:#3d8ef0;--blue-dim:#0d2347;--purple:#9b59f5;--purple-dim:#1d0d3d;--radius:10px;--radius-lg:16px;--font:"Inter", system-ui, sans-serif;--mono:"JetBrains Mono", monospace;--sidebar-w:220px;--transition:.15s ease}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);font-family:var(--font);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.6}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:3px}.app-layout{height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}.sidebar-logo{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:20px 18px;display:flex}.sidebar-logo-icon{background:linear-gradient(135deg,#1d4ed8,#7c3aed);border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:16px;display:flex}.sidebar-logo-text{letter-spacing:-.02em;font-size:15px;font-weight:700}.sidebar-logo-sub{color:var(--text-3);letter-spacing:.04em;text-transform:uppercase;font-size:10px}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:12px 10px;display:flex;overflow-y:auto}.nav-item{color:var(--text-2);cursor:pointer;transition:var(--transition);border:1px solid #0000;border-radius:8px;align-items:center;gap:10px;padding:9px 10px;font-size:13px;font-weight:500;text-decoration:none;display:flex}.nav-item:hover{background:var(--surface-2);color:var(--text)}.nav-item.active{background:var(--blue-dim);color:var(--blue);border-color:#3d8ef033}.nav-icon{text-align:center;flex-shrink:0;width:20px;font-size:16px}.sidebar-footer{border-top:1px solid var(--border);padding:12px}.user-chip{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;align-items:center;gap:8px;padding:8px 10px;display:flex}.user-avatar{color:#fff;background:linear-gradient(135deg,#1d4ed8,#7c3aed);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;font-weight:600;display:flex}.user-email{color:var(--text-2);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:11px;overflow:hidden}.logout-btn{color:var(--text-3);cursor:pointer;transition:color var(--transition);background:0 0;border:none;padding:2px;font-size:14px}.logout-btn:hover{color:var(--red)}.main-content{flex-direction:column;flex:1;display:flex;overflow-y:auto}.page-header{border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:12px;padding:24px 28px 16px;display:flex}.page-title{letter-spacing:-.03em;font-size:22px;font-weight:700}.page-sub{color:var(--text-2);margin-top:3px;font-size:13px}.page-body{flex:1;padding:24px 28px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:14px;overflow:hidden}.card-header{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:13px 16px;display:flex}.card-title{flex:1;font-size:13px;font-weight:600}.card-body{padding:16px}.metrics{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:16px;display:grid}.metric{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.metric-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px;font-size:10px}.metric-value{font-size:26px;font-weight:700;font-family:var(--mono);line-height:1}.metric-sub{color:var(--text-2);margin-top:5px;font-size:11px}.c-green{color:var(--green)}.c-amber{color:var(--amber)}.c-red{color:var(--red)}.c-blue{color:var(--blue)}.c-purple{color:var(--purple)}.badge{border-radius:20px;align-items:center;padding:2px 9px;font-size:11px;font-weight:600;display:inline-flex}.badge-green{background:var(--green-dim);color:var(--green)}.badge-red{background:var(--red-dim);color:var(--red)}.badge-amber{background:var(--amber-dim);color:var(--amber)}.badge-blue{background:var(--blue-dim);color:var(--blue)}.badge-purple{background:var(--purple-dim);color:var(--purple)}.badge-muted{background:var(--surface-2);color:var(--text-3)}.btn{cursor:pointer;transition:opacity var(--transition), transform .1s;border:none;border-radius:8px;align-items:center;gap:7px;padding:8px 16px;font-size:13px;font-weight:600;display:inline-flex}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{color:#fff;background:linear-gradient(135deg,#1d4ed8,#3d8ef0)}.btn-primary:hover:not(:disabled){opacity:.88}.btn-success{color:#fff;background:linear-gradient(135deg,#15803d,#22d46e)}.btn-success:hover:not(:disabled){opacity:.88}.btn-danger{background:var(--red-dim);color:var(--red);border:1px solid var(--red-dim)}.btn-danger:hover:not(:disabled){opacity:.8}.btn-ghost{border:1px solid var(--border);color:var(--text-2);background:0 0}.btn-ghost:hover:not(:disabled){color:var(--text);border-color:var(--border-2)}.btn-sm{padding:5px 11px;font-size:12px}.btn-icon{padding:7px}.form-group{margin-bottom:16px}.form-label{color:var(--text-2);text-transform:uppercase;letter-spacing:.06em;margin-bottom:7px;font-size:11px;font-weight:600;display:block}.form-input,.form-select,.form-textarea{background:var(--bg-2);border:1px solid var(--border);width:100%;color:var(--text);font-family:var(--font);transition:border-color var(--transition);border-radius:8px;outline:none;padding:10px 12px;font-size:13px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--blue)}.form-select{appearance:none;cursor:pointer}.form-textarea{resize:vertical;min-height:80px}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:12px}th{text-align:left;color:var(--text-3);border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.07em;padding:8px 12px;font-size:10px;font-weight:600}td{border-bottom:1px solid var(--border);color:var(--text-2);padding:10px 12px}tr:last-child td{border-bottom:none}tr:hover td{background:var(--surface-2)}td.strong{color:var(--text);font-weight:500}.signal-card{background:var(--bg-2);transition:border-color var(--transition);border:1px solid #0000;border-radius:9px;align-items:flex-start;gap:12px;margin-bottom:8px;padding:12px;display:flex}.signal-card:hover{border-color:var(--border)}.signal-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px;margin-top:5px}.dot-buy{background:var(--green);box-shadow:0 0 8px var(--green)}.dot-watch{background:var(--amber)}.dot-sell{background:var(--red)}.signal-body{flex:1;min-width:0}.signal-asset{font-size:13px;font-weight:600}.signal-meta{color:var(--text-3);margin-top:2px;font-size:11px}.signal-catalyst{color:var(--text-2);margin-top:4px;font-size:12px;line-height:1.4}.signal-actions{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:6px;display:flex}.signal-upside{font-size:14px;font-weight:700;font-family:var(--mono);white-space:nowrap}.sector-row{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:8px 0;display:flex}.sector-row:last-child{border-bottom:none}.sector-name{color:var(--text-2);min-width:180px;font-size:12px}.sector-bar-wrap{background:var(--border);border-radius:3px;flex:1;height:6px;overflow:hidden}.sector-bar{border-radius:3px;height:100%;transition:width .8s}.sector-val{font-size:12px;font-weight:600;font-family:var(--mono);text-align:right;min-width:38px}.toggle{width:38px;height:21px;display:inline-block;position:relative}.toggle input{opacity:0;width:0;height:0}.toggle-slider{background:var(--border-2);cursor:pointer;border-radius:21px;transition:all .2s;position:absolute;inset:0}.toggle-slider:before{content:"";background:#fff;border-radius:50%;width:15px;height:15px;transition:all .2s;position:absolute;bottom:3px;left:3px}.toggle input:checked+.toggle-slider{background:var(--blue)}.toggle input:checked+.toggle-slider:before{transform:translate(17px)}.modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:200;background:#000000b3;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--radius-lg);width:480px;max-width:95vw;max-height:90vh;padding:28px;animation:.15s slideUp;overflow-y:auto}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.modal-title{margin-bottom:6px;font-size:17px;font-weight:700}.modal-sub{color:var(--text-2);margin-bottom:20px;font-size:12px}.modal-footer{justify-content:flex-end;gap:8px;margin-top:20px;display:flex}.empty{color:var(--text-3);text-align:center;padding:3rem 1rem;font-size:13px;font-style:italic}.spinner{border:2px solid var(--border);border-top-color:var(--blue);border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.loader-center{justify-content:center;align-items:center;padding:4rem;display:flex}.alert{border-radius:8px;margin-bottom:14px;padding:10px 14px;font-size:12px}.alert-success{background:var(--green-dim);color:var(--green)}.alert-error{background:var(--red-dim);color:var(--red)}.alert-info{background:var(--blue-dim);color:var(--blue)}.login-page{background:radial-gradient(ellipse at 50% 0%, #3d8ef01f 0%, transparent 60%), var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:380px;max-width:95vw;padding:40px}.login-logo{text-align:center;margin-bottom:28px}.login-logo-icon{background:linear-gradient(135deg,#1d4ed8,#7c3aed);border-radius:14px;justify-content:center;align-items:center;width:54px;height:54px;margin:0 auto 12px;font-size:26px;display:flex}.login-logo-title{letter-spacing:-.03em;font-size:22px;font-weight:700}.login-logo-sub{color:var(--text-2);margin-top:4px;font-size:12px}.source-row{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:10px 0;display:flex}.source-row:last-child{border-bottom:none}.source-info{flex:1;min-width:0}.source-name{font-size:13px;font-weight:500}.source-meta{color:var(--text-3);margin-top:2px;font-size:11px}.source-region{background:var(--surface-2);color:var(--text-2);white-space:nowrap;border-radius:20px;padding:2px 7px;font-size:10px}.pnl-positive{color:var(--green)}.pnl-negative{color:var(--red)}.pnl-neutral{color:var(--text-2)}@media (width<=768px){.sidebar{display:none}.page-body{padding:16px}.page-header{padding:16px 16px 12px}.metrics{grid-template-columns:1fr 1fr}}.tag-select{flex-wrap:wrap;gap:6px;display:flex}.tag{background:var(--surface-2);border:1px solid var(--border);color:var(--text-2);cursor:pointer;transition:all var(--transition);-webkit-user-select:none;user-select:none;border-radius:20px;align-items:center;gap:5px;padding:4px 10px;font-size:11px;display:inline-flex}.tag.selected{background:var(--blue-dim);color:var(--blue);border-color:#3d8ef066}
