@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap";:root{--sidebar-width:200px;--topbar-height:56px;--sidebar-bg:#0a0c10;--sidebar-border:#ffffff0f;--sidebar-text:#9ca3af;--sidebar-text-active:#fff;--sidebar-active-bg:#6366f12e;--sidebar-hover:#ffffff0d;--accent:#6366f1;--accent-hover:#818cf8;--success:#10b981;--danger:#ef4444;--warning:#f59e0b;--info:#3b82f6;--violet:#8b5cf6;--muted:#6b7280;--font-sans:"Inter", -apple-system, sans-serif;--font-mono:"JetBrains Mono", monospace;--radius-sm:6px;--radius:10px;--radius-lg:14px;--transition:all .18s ease}[data-theme=dark]{--bg:#0b0e14;--bg-secondary:#111827;--bg-card:#161c2c;--bg-card-hover:#1a213a;--bg-input:#1e2840;--border:#6366f11f;--border-subtle:#ffffff0f;--text:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#4b5563;--topbar-bg:#0a0c10f2;--scrollbar-thumb:#6366f14d}[data-theme=light]{--bg:#f0f2f7;--bg-secondary:#fff;--bg-card:#fff;--bg-card-hover:#f8fafc;--bg-input:#f1f5f9;--border:#6366f126;--border-subtle:#00000012;--text:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--topbar-bg:#fffffff2;--scrollbar-thumb:#6366f140}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;font-family:var(--font-sans);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-size:14px;overflow:hidden}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:99px}.app-shell{height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);border-right:1px solid var(--sidebar-border);z-index:100;flex-direction:column;height:100vh;display:flex;position:fixed;top:0;left:0;overflow-y:auto;background:var(--sidebar-bg)!important}.sidebar-brand{border-bottom:1px solid var(--sidebar-border);min-height:var(--topbar-height);align-items:center;gap:10px;padding:16px 14px;display:flex}.brand-logo{color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:14px;font-weight:800;display:flex;box-shadow:0 0 12px #6366f166}.brand-info strong{color:#fff;font-size:13px;font-weight:700;line-height:1.2;display:block}.brand-info span{color:var(--sidebar-text);text-transform:uppercase;letter-spacing:.05em;font-size:10px}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:10px 8px;display:flex}.nav-section-label{text-transform:uppercase;letter-spacing:.08em;color:#ffffff40;padding:12px 8px 4px;font-size:10px;font-weight:600}.nav-item{border-radius:var(--radius-sm);cursor:pointer;color:var(--sidebar-text);transition:var(--transition);text-align:left;background:0 0;border:none;align-items:center;gap:9px;width:100%;padding:8px 10px;font-size:13px;font-weight:500;text-decoration:none;display:flex}.nav-item:hover{background:var(--sidebar-hover);color:#e2e8f0}.nav-item.active{background:var(--sidebar-active-bg);color:var(--sidebar-text-active);border-left:2px solid var(--accent);padding-left:8px}.nav-item .nav-icon{opacity:.7;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:15px;display:flex}.nav-item.active .nav-icon{opacity:1}.sidebar-footer{border-top:1px solid var(--sidebar-border);padding:12px 10px}.sidebar-status{align-items:center;gap:6px;margin-bottom:8px;display:flex}.status-dot{background:var(--muted);width:7px;height:7px;transition:var(--transition);border-radius:50%}.status-dot.online{background:var(--success);box-shadow:0 0 6px #10b98180}.sidebar-status span{color:var(--sidebar-text);text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:500}.sidebar-capital{color:var(--sidebar-text);justify-content:space-between;align-items:center;margin-bottom:8px;font-size:11px;display:flex}.sidebar-capital strong{color:var(--success);font-size:12px}.sidebar-logout{border-radius:var(--radius-sm);width:100%;color:var(--sidebar-text);cursor:pointer;transition:var(--transition);font-size:12px;font-family:var(--font-sans);background:#ffffff0d;border:1px solid #ffffff14;padding:7px 10px}.sidebar-logout:hover{color:var(--danger);background:#ef444426;border-color:#ef444440}.main-area{margin-left:var(--sidebar-width);flex-direction:column;flex:1;height:100vh;display:flex;overflow:hidden}.page-content{flex:1;padding:20px 24px;overflow-y:auto}.topbar{height:var(--topbar-height);background:var(--topbar-bg);border-bottom:1px solid var(--border-subtle);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:50;flex-shrink:0;align-items:center;gap:10px;padding:0 20px;display:flex;position:relative}.topbar-page-info{flex:none;min-width:160px}.topbar-page-info h1{color:var(--text);font-size:16px;font-weight:700;line-height:1.1}.topbar-page-info span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:11px}.topbar-controls{flex:none;align-items:center;gap:6px;display:flex}.topbar-divider{background:var(--border-subtle);flex-shrink:0;width:1px;height:24px}.topbar-ticker-wrap{flex:1;min-width:0;position:relative;overflow:hidden}.topbar-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.btn-start{border-radius:var(--radius-sm);background:var(--success);color:#fff;cursor:pointer;transition:var(--transition);text-transform:uppercase;letter-spacing:.05em;border:none;padding:6px 16px;font-size:12px;font-weight:700}.btn-start:hover{background:#059669;box-shadow:0 0 12px #10b98166}.btn-stop{border-radius:var(--radius-sm);background:var(--danger);color:#fff;cursor:pointer;transition:var(--transition);text-transform:uppercase;letter-spacing:.05em;border:none;padding:6px 16px;font-size:12px;font-weight:700}.btn-stop:hover{background:#dc2626;box-shadow:0 0 12px #ef444466}.btn-exit{border-radius:var(--radius-sm);background:var(--warning);color:#1a1a1a;cursor:pointer;transition:var(--transition);text-transform:uppercase;letter-spacing:.05em;border:none;padding:6px 16px;font-size:12px;font-weight:700}.btn-exit:hover{background:#d97706;box-shadow:0 0 12px #f59e0b66}.btn-ghost{border-radius:var(--radius-sm);color:var(--text-secondary);border:1px solid var(--border-subtle);cursor:pointer;transition:var(--transition);font-size:12px;font-weight:500;font-family:var(--font-sans);background:0 0;padding:5px 12px}.btn-ghost:hover{background:var(--bg-card);color:var(--text);border-color:var(--border)}.status-badge{text-transform:uppercase;letter-spacing:.07em;border-radius:99px;padding:3px 10px;font-size:10px;font-weight:700}.status-badge.paper{color:var(--warning);background:#f59e0b26;border:1px solid #f59e0b4d}.status-badge.running{color:var(--success);background:#10b98126;border:1px solid #10b9814d}.status-badge.stopped{color:var(--muted);background:#6b728026;border:1px solid #6b72804d}.btn-start:disabled,.btn-stop:disabled,.btn-exit:disabled{opacity:.5;cursor:not-allowed}.ctrl-msg{color:var(--success);white-space:nowrap;text-overflow:ellipsis;max-width:200px;font-size:11px;overflow:hidden}.ticker-tape{width:100%;position:relative;overflow:hidden}.ticker-inner{gap:0;width:max-content;animation:40s linear infinite ticker-scroll;display:flex}.ticker-inner:hover{animation-play-state:paused}@keyframes ticker-scroll{0%{transform:translate(0)}to{transform:translate(-50%)}}.ticker-item{border-right:1px solid var(--border-subtle);white-space:nowrap;align-items:center;gap:5px;padding:0 16px;display:flex}.ticker-symbol{color:var(--text);font-size:11px;font-weight:700}.ticker-price{font-size:11px;font-weight:600;font-family:var(--font-mono);color:var(--text)}.ticker-change{font-size:10px;font-weight:600;font-family:var(--font-mono)}.ticker-change.pos{color:var(--success)}.ticker-change.neg{color:var(--danger)}.ticker-dot{background:var(--success);border-radius:50%;width:5px;height:5px;animation:2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.status-strip{background:var(--bg);border-bottom:1px solid var(--border-subtle);flex-wrap:wrap;flex-shrink:0;gap:8px;padding:8px 24px;display:flex}.readiness-chip{border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.05em;align-items:center;gap:6px;padding:4px 10px;font-size:10px;font-weight:600;display:flex}.readiness-chip.ok{color:var(--success);background:#10b98114;border:1px solid #10b98133}.readiness-chip.bad{color:var(--danger);background:#ef444414;border:1px solid #ef444433}.readiness-chip .chip-status{font-weight:800}.stats-row{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:20px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius);transition:var(--transition);padding:14px 16px;position:relative;overflow:hidden}.stat-card:hover{border-color:var(--border);transform:translateY(-1px)}.stat-card:before{content:"";height:2px;position:absolute;top:0;left:0;right:0}.stat-card.positive:before{background:var(--success)}.stat-card.negative:before{background:var(--danger)}.stat-card.neutral:before{background:var(--text-muted)}.stat-card.info:before{background:var(--info)}.stat-card.warning:before{background:var(--warning)}.stat-card.violet:before{background:var(--violet)}.stat-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:6px;font-size:10px;font-weight:600;display:block}.stat-value{color:var(--text);font-size:22px;font-weight:800;line-height:1.1;font-family:var(--font-mono);display:block}.stat-hint{color:var(--text-secondary);margin-top:4px;font-size:11px;display:block}.stat-value.positive{color:var(--success)}.stat-value.negative{color:var(--danger)}.panel{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius);margin-bottom:16px;overflow:hidden}.panel-header{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;gap:12px;padding:14px 18px 12px;display:flex}.panel-header h2{color:var(--text);text-transform:uppercase;letter-spacing:.06em;font-size:13px;font-weight:700}.panel-header p{color:var(--text-muted);margin-top:2px;font-size:11px}.panel-header-left{flex:1}.panel-header-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.panel-body{padding:16px 18px}.table-wrap{overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:12.5px}.data-table thead tr{border-bottom:1px solid var(--border-subtle)}.data-table th{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);text-align:left;white-space:nowrap;padding:10px 12px;font-size:10px;font-weight:700}.data-table td{color:var(--text-secondary);border-bottom:1px solid var(--border-subtle);white-space:nowrap;padding:9px 12px}.data-table tbody tr:hover td{color:var(--text);background:#6366f10a}.data-table tbody tr:last-child td{border-bottom:none}.data-table td.positive{color:var(--success);font-weight:600}.data-table td.negative{color:var(--danger);font-weight:600}.pill{text-transform:uppercase;letter-spacing:.07em;border-radius:99px;align-items:center;padding:2px 8px;font-size:10px;font-weight:700;display:inline-flex}.pill.success{color:var(--success);background:#10b98126}.pill.danger{color:var(--danger);background:#ef444426}.pill.warning{color:var(--warning);background:#f59e0b26}.pill.info{color:var(--info);background:#3b82f626}.pill.muted{color:var(--muted);background:#6b72801f}.pill.violet{color:var(--violet);background:#8b5cf626}.toggle-switch{flex-shrink:0;width:36px;height:20px;position:relative}.toggle-switch input{opacity:0;width:0;height:0;position:absolute}.toggle-track{cursor:pointer;transition:var(--transition);background:#6b72804d;border-radius:99px;position:absolute;inset:0}.toggle-track:before{content:"";width:14px;height:14px;transition:var(--transition);background:#fff;border-radius:50%;position:absolute;bottom:3px;left:3px}.toggle-switch input:checked+.toggle-track{background:var(--success);box-shadow:0 0 8px #10b98159}.toggle-switch input:checked+.toggle-track:before{transform:translate(16px)}.instruments-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:8px;max-height:calc(100vh - 280px);padding:16px 18px;display:grid;overflow-y:auto}.instrument-card{border-radius:var(--radius-sm);background:var(--bg-secondary);border:1px solid var(--border-subtle);transition:var(--transition);justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.instrument-card:hover{border-color:var(--border)}.instrument-card.enabled{border-color:#10b98133}.instrument-card-info strong{color:var(--text);font-size:12px;font-weight:700;display:block}.instrument-card-info span{color:var(--text-muted);font-size:10px}.form-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;display:grid}.form-field{flex-direction:column;gap:6px;display:flex}.form-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:600}.form-input{border-radius:var(--radius-sm);background:var(--bg-input);border:1px solid var(--border-subtle);color:var(--text);font-size:13px;font-family:var(--font-sans);transition:var(--transition);outline:none;padding:9px 12px}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #6366f126}.form-input:disabled{opacity:.5;cursor:not-allowed}.btn-primary{border-radius:var(--radius-sm);background:var(--accent);color:#fff;cursor:pointer;transition:var(--transition);font-size:13px;font-weight:600;font-family:var(--font-sans);border:none;padding:9px 20px}.btn-primary:hover{background:var(--accent-hover);box-shadow:0 0 16px #6366f159}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{border-radius:var(--radius-sm);background:var(--bg-input);color:var(--text-secondary);border:1px solid var(--border-subtle);cursor:pointer;transition:var(--transition);font-size:13px;font-weight:600;font-family:var(--font-sans);padding:9px 20px}.btn-secondary:hover{background:var(--bg-card-hover);color:var(--text)}.btn-danger{border-radius:var(--radius-sm);color:var(--danger);cursor:pointer;transition:var(--transition);font-size:12px;font-weight:600;font-family:var(--font-sans);background:#ef44441f;border:1px solid #ef444440;padding:7px 14px}.btn-danger:hover{background:#ef444433}.chart-wrap{padding:16px 18px}.metric-grid{background:var(--border-subtle);gap:1px;display:grid}.metric-grid.cols-2{grid-template-columns:1fr 1fr}.metric-grid.cols-3{grid-template-columns:1fr 1fr 1fr}.metric-grid.cols-4{grid-template-columns:repeat(4,1fr)}.metric-grid.cols-6{grid-template-columns:repeat(6,1fr)}.metric-cell{background:var(--bg-card);padding:14px 16px}.metric-cell span{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:5px;font-size:10px;font-weight:600;display:block}.metric-cell strong{color:var(--text);font-size:15px;font-weight:700;font-family:var(--font-mono);display:block}.metric-cell strong.success{color:var(--success)}.metric-cell strong.danger{color:var(--danger)}.metric-cell strong.warning{color:var(--warning)}.log-console{border-radius:var(--radius-sm);font-family:var(--font-mono);background:#070a0e;flex-direction:column;gap:1px;max-height:calc(100vh - 260px);padding:12px;font-size:11.5px;display:flex;overflow-y:auto}.log-entry{border-radius:3px;grid-template-columns:150px 50px 70px 1fr;gap:10px;padding:4px 6px;line-height:1.5;display:grid}.log-entry:hover{background:#ffffff08}.log-entry .log-ts{color:#4b5563;font-size:10.5px}.log-entry .log-level{font-size:10px;font-weight:700}.log-entry .log-cat{color:#6366f1;font-size:10.5px}.log-entry .log-msg{color:#9ca3af;word-break:break-all;font-size:11px}.log-entry.INFO .log-level{color:#3b82f6}.log-entry.WARN .log-level{color:var(--warning)}.log-entry.ERROR .log-level{color:var(--danger)}.log-entry.TRADE .log-level{color:var(--success)}.log-entry.SIGNAL .log-level{color:var(--violet)}.search-input{border-radius:var(--radius-sm);background:var(--bg-input);border:1px solid var(--border-subtle);color:var(--text);font-size:12px;font-family:var(--font-sans);width:220px;transition:var(--transition);outline:none;padding:7px 12px}.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #6366f11f}.filter-group{gap:4px;display:flex}.filter-btn{border:1px solid var(--border-subtle);color:var(--text-muted);cursor:pointer;transition:var(--transition);font-size:11px;font-weight:600;font-family:var(--font-sans);background:0 0;border-radius:99px;padding:5px 12px}.filter-btn:hover{color:var(--text);border-color:var(--border)}.filter-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.empty-state{flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:48px 24px;display:flex}.empty-state strong{color:var(--text-muted);font-size:14px;font-weight:600}.empty-state span{color:var(--text-muted);text-align:center;opacity:.7;max-width:300px;font-size:12px}.inline-msg{border-radius:var(--radius-sm);color:var(--success);background:#10b9811a;border:1px solid #10b98133;padding:6px 12px;font-size:12px}.inline-msg.error{color:var(--danger);background:#ef44441a;border-color:#ef444433}.login-screen{background-color:#07090f;background-image:radial-gradient(at 20%,#6366f112 0%,#0000 50%),radial-gradient(at 80%,#8b5cf60d 0%,#0000 50%);background-position:0 0;background-repeat:repeat;background-size:auto;background-attachment:scroll;background-origin:padding-box;background-clip:border-box;justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{border-radius:var(--radius-lg);background:#111827;border:1px solid #6366f133;width:100%;max-width:380px;padding:32px;box-shadow:0 25px 60px #00000080,0 0 0 1px #6366f11a}.login-logo{align-items:center;gap:12px;margin-bottom:28px;display:flex}.login-logo-icon{color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:12px;justify-content:center;align-items:center;width:46px;height:46px;font-size:20px;font-weight:800;display:flex;box-shadow:0 0 20px #6366f180}.login-logo-info strong{color:#fff;font-size:18px;font-weight:800;display:block}.login-logo-info span{color:#6b7280;text-transform:uppercase;letter-spacing:.06em;font-size:11px}.login-title{color:#94a3b8;margin-bottom:20px;font-size:14px;font-weight:600}.login-form{flex-direction:column;gap:14px;display:flex}.login-error{border-radius:var(--radius-sm);color:var(--danger);background:#ef44441a;border:1px solid #ef444433;padding:10px 14px;font-size:12.5px}.backtest-form{grid-template-columns:1fr 1fr 1fr auto;align-items:end;gap:12px;display:grid}.two-col{grid-template-columns:1fr 1fr}.three-col{grid-template-columns:1fr 1fr 1fr}.content-grid{gap:16px;display:grid}.content-grid.two-col{grid-template-columns:1fr 1fr}.content-grid.main-side{grid-template-columns:1.5fr 1fr}.content-grid.side-main{grid-template-columns:1fr 1.5fr}.loading-screen{background:#07090f;justify-content:center;align-items:center;min-height:100vh;display:flex}.loading-spinner{border:3px solid #6366f133;border-top-color:var(--accent);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.panel-footer{border-top:1px solid var(--border-subtle);flex-wrap:wrap;align-items:center;gap:10px;padding:12px 18px;display:flex}.panel .table-wrap{padding:0}.reason-badge{text-overflow:ellipsis;white-space:nowrap;border-radius:4px;align-items:center;max-width:200px;padding:2px 7px;font-size:10px;font-weight:600;display:inline-flex;overflow:hidden}.reason-badge.taken{color:var(--success);background:#10b9811a}.reason-badge.skipped{color:var(--warning);background:#f59e0b1a}.reason-badge.failed{color:var(--danger);background:#ef44441a}@media (width<=1200px){.content-grid.two-col,.content-grid.main-side{grid-template-columns:1fr}.metric-grid.cols-6{grid-template-columns:repeat(3,1fr)}.metric-grid.cols-4{grid-template-columns:repeat(2,1fr)}}@media (width<=900px){.sidebar{width:56px}.main-area{margin-left:56px}.brand-info,.nav-item span:not(.nav-icon),.sidebar-status span,.sidebar-capital,.sidebar-logout{display:none}.nav-item{justify-content:center;padding:8px}.backtest-form{grid-template-columns:1fr 1fr}}.position-row td{vertical-align:middle}.price-up{font-weight:700;color:var(--success)!important}.price-dn{font-weight:700;color:var(--danger)!important}.panel-search{align-items:center;gap:8px;display:flex}.indicator-card{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:14px}.indicator-card .ind-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:6px;font-size:10px;font-weight:600;display:block}.indicator-card .ind-value{color:var(--text);font-size:20px;font-weight:800;font-family:var(--font-mono)}.artifact-links{flex-wrap:wrap;gap:8px;padding:12px 18px;display:flex}.artifact-link{border-radius:var(--radius-sm);background:var(--bg-input);border:1px solid var(--border-subtle);color:var(--accent);transition:var(--transition);padding:5px 12px;font-size:12px;text-decoration:none}.artifact-link:hover{border-color:var(--accent);background:#6366f11a}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-warning{color:var(--warning)}.text-muted{color:var(--text-muted)}.fw-700{font-weight:700}.fw-600{font-weight:600}.mono{font-family:var(--font-mono)}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.flex{display:flex}.flex-center{align-items:center;display:flex}.gap-8{gap:8px}.gap-12{gap:12px}
