:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}:root{--bg-primary: #0f0f0f;--bg-secondary: #1a1a1a;--bg-tertiary: #252525;--bg-hover: #2a2a2a;--border-color: #333;--text-primary: #fff;--text-secondary: #888;--text-muted: #666;--accent: #3b82f6;--accent-hover: #2563eb;--success: #10b981;--warning: #f59e0b;--error: #ef4444;--profit: #10b981;--loss: #ef4444}*{margin:0;padding:0;box-sizing:border-box}html{overflow-y:scroll}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.5}#root{min-height:100vh}.app-container{min-height:100vh;display:flex;flex-direction:column}.app-header{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:1rem 2rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.header-left{display:flex;align-items:center;gap:1rem;justify-self:start}.app-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);white-space:nowrap}.main-nav{display:flex;gap:.5rem;justify-self:center}.header-right{display:flex;align-items:center;justify-self:end;gap:1rem}.nav-tab{padding:.5rem 1rem;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;font-size:.9rem;border-radius:6px;transition:all .2s}.nav-tab:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-tab.active{background:var(--accent);color:#fff}.connection-status{display:flex;align-items:center;gap:.5rem;padding:.25rem .75rem;background:var(--bg-tertiary);border-radius:999px;font-size:.8rem}.status-dot{width:8px;height:8px;border-radius:50%}.status-label{color:var(--text-secondary)}.app-main{flex:1;padding:1rem;max-width:1400px;margin:0 auto;width:100%}.tab-content{min-height:60vh}.trading-tab{width:100%}.subtab-nav{display:flex;gap:.25rem;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color);overflow-x:auto;-webkit-overflow-scrolling:touch}.subtab-btn{padding:.5rem 1rem;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;font-size:.85rem;border-radius:4px;transition:all .2s}.subtab-btn:hover{color:var(--text-primary)}.subtab-btn.active{background:var(--bg-tertiary);color:var(--text-primary)}.section{margin-bottom:2rem}.section h3{font-size:1rem;font-weight:500;color:var(--text-secondary);margin-bottom:1rem}.hero-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:2rem}.metric-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:1.25rem}.metric-card.hero-card{background:linear-gradient(135deg,var(--bg-secondary),var(--bg-tertiary))}.metric-label{font-size:.8rem;color:var(--text-secondary);margin-bottom:.5rem}.metric-value{font-size:1.5rem;font-weight:600}.metric-subtitle{font-size:.75rem;color:var(--text-muted);margin-top:.25rem}.metric-subtitle.positive{color:var(--profit)}.metric-subtitle.negative{color:var(--loss)}.pnl{font-weight:500}.pnl.positive{color:var(--profit)}.pnl.negative{color:var(--loss)}.status-badge{display:inline-block;padding:.2rem .5rem;font-size:.7rem;font-weight:500;border-radius:4px;text-transform:uppercase}.status-success{background:#10b98133;color:var(--success)}.status-warning{background:#f59e0b33;color:var(--warning)}.status-error{background:#ef444433;color:var(--error)}.status-neutral{background:var(--bg-tertiary);color:var(--text-secondary)}.status-live{background:#10b98133;color:var(--success)}.status-paper{background:#3b82f633;color:var(--accent)}.positions-summary{display:flex;flex-direction:column;gap:1.5rem}.position-group h4{font-size:.85rem;font-weight:500;color:var(--text-secondary);margin-bottom:.75rem}.position-chips{display:flex;flex-wrap:wrap;gap:.5rem}.position-chip{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;font-size:.85rem}.position-chip.profit{border-color:var(--profit)}.position-chip.loss{border-color:var(--loss)}.chip-symbol{font-weight:500}.table-container{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:.85rem}.data-table th,.data-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border-color)}.data-table th{font-weight:500;color:var(--text-secondary);background:var(--bg-secondary)}.data-table tr:hover{background:var(--bg-hover)}.symbol-cell{font-weight:500;color:var(--accent)}.time-cell{color:var(--text-muted);font-size:.8rem}.side-cell.buy{color:var(--profit)}.side-cell.sell{color:var(--loss)}.positive{color:var(--profit)}.negative{color:var(--loss)}.no-data{color:var(--text-muted);font-style:italic;padding:2rem;text-align:center}.placeholder{padding:3rem;text-align:center}.placeholder h2{margin-bottom:.5rem}.placeholder p{color:var(--text-secondary)}.signal-flow-container{padding:0}.flow-stats{display:flex;gap:2rem;margin-bottom:1.5rem;padding:1rem;background:var(--bg-secondary);border-radius:8px}.flow-stat{display:flex;flex-direction:column;align-items:center}.flow-stat .stat-value{font-size:1.5rem;font-weight:600;color:var(--text-primary)}.flow-stat .stat-label{font-size:.75rem;color:var(--text-secondary)}.flow-filters{display:flex;gap:.5rem;margin-bottom:1rem}.flow-filters select{padding:.5rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:.85rem}.flow-timeline{display:flex;flex-direction:column;gap:1rem}.flow-group{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:1rem}.flow-group.live{border-left:3px solid var(--success)}.flow-group.paper{border-left:3px solid var(--warning)}.flow-group-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-color)}.flow-symbol{display:flex;align-items:center;gap:.5rem;font-size:1.1rem;font-weight:600;color:var(--accent)}.mode-badge{font-size:.9rem}.flow-position{display:flex;align-items:center;gap:.75rem}.pos-value{font-weight:500}.pos-flat{color:var(--text-muted)}.flow-timeline-row{display:flex;gap:1.5rem;overflow-x:auto;padding-bottom:.5rem}.flow-item{display:flex;align-items:flex-start;gap:.5rem;flex-shrink:0}.flow-item.latest{opacity:1}.flow-item:not(.latest){opacity:.7}.flow-node{display:flex;flex-direction:column;align-items:center;min-width:80px}.node-icon{width:45px;height:45px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.25rem;margin-bottom:.5rem}.signal-node .node-icon{background:#3b82f633;border:2px solid rgb(59,130,246)}.order-node .node-icon{background:#9ca3af33;border:2px solid rgb(156,163,175)}.order-node.filled .node-icon{background:#22c55e33;border-color:#22c55e}.order-node.failed .node-icon{background:#ef444433;border-color:#ef4444}.position-node .node-icon{background:#a855f733;border:2px solid rgb(168,85,247)}.node-info{text-align:center;font-size:.7rem;color:var(--text-secondary)}.target-pos{font-weight:600;font-size:.85rem}.target-pos.buy{color:var(--profit)}.target-pos.sell{color:var(--loss)}.signal-price{color:var(--text-primary)}.signal-change{font-size:.65rem}.signal-time{font-size:.6rem;color:var(--text-muted)}.order-side{font-weight:600;font-size:.8rem}.order-side.buy{color:var(--profit)}.order-side.sell{color:var(--loss)}.slippage{font-size:.6rem}.slippage.positive{color:var(--loss)}.slippage.negative{color:var(--profit)}.flow-arrow{color:var(--text-muted);font-size:1.25rem;padding-top:.75rem}.no-order{color:var(--text-muted);font-style:italic}.signal-flow-react{display:flex;flex-direction:column;height:calc(100vh - 200px);min-height:500px}.metrics-panel{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:1rem;margin-bottom:1rem}.metrics-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:1rem}.metric-box{text-align:center;padding:.75rem;background:var(--bg-tertiary);border-radius:6px}.metric-title{font-size:.7rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.metric-big{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.metric-big.good{color:var(--success)}.metric-big.warning{color:var(--warning)}.metric-big.bad{color:var(--error)}.live-count{color:var(--success)}.paper-count{color:var(--warning)}.flow-canvas{flex:1;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;overflow:hidden}.react-flow__background{background:var(--bg-primary)!important}.react-flow__controls{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px}.react-flow__controls-button{background:var(--bg-tertiary);border-color:var(--border-color);fill:var(--text-secondary)}.react-flow__controls-button:hover{background:var(--bg-hover)}.react-flow__minimap{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px}.flow-node-card{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:10px;min-width:200px;font-size:.85rem;box-shadow:0 4px 12px #0000004d;transition:transform .2s,box-shadow .2s}.flow-node-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0006}.signal-card{border-color:#3b82f6}.signal-card.live{border-color:var(--success);box-shadow:0 0 20px #10b98133}.signal-card.paper{border-color:var(--warning)}.order-card{border-color:#6b7280}.order-card.filled{border-color:var(--success)}.order-card.pending{border-color:var(--warning);animation:pulse-border 2s infinite}.order-card.failed{border-color:var(--error)}@keyframes pulse-border{0%,to{box-shadow:0 0 #f59e0b66}50%{box-shadow:0 0 0 8px #f59e0b00}}.position-card{border-color:#8b5cf6}.position-card.profit{border-color:var(--success);background:linear-gradient(135deg,var(--bg-secondary),rgba(16,185,129,.1))}.position-card.loss{border-color:var(--error);background:linear-gradient(135deg,var(--bg-secondary),rgba(239,68,68,.1))}.node-header{display:flex;align-items:center;gap:.5rem;padding:.6rem .8rem;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);border-radius:8px 8px 0 0}.node-icon{font-size:1rem}.node-title{font-weight:600;color:var(--text-primary);flex:1}.mode-indicator{font-size:.65rem;font-weight:600;padding:.15rem .4rem;border-radius:3px;text-transform:uppercase}.mode-indicator.live{background:#10b98133;color:var(--success)}.mode-indicator.paper{background:#f59e0b33;color:var(--warning)}.status-badge{font-size:.65rem;font-weight:600;padding:.15rem .4rem;border-radius:3px;color:#fff}.node-body{padding:.8rem}.node-symbol{font-size:1.1rem;font-weight:700;color:var(--accent);margin-bottom:.3rem}.node-target{font-weight:600;margin-bottom:.2rem}.node-target.buy{color:var(--success)}.node-target.sell{color:var(--error)}.node-price{color:var(--text-secondary);font-size:.8rem}.node-time{color:var(--text-muted);font-size:.7rem;margin-top:.3rem}.order-side{font-size:1rem;font-weight:700;margin-bottom:.3rem}.order-side.buy{color:var(--success)}.order-side.sell{color:var(--error)}.fill-price{color:var(--text-secondary);font-size:.8rem;margin-bottom:.5rem}.metrics-section{margin-top:.6rem;padding-top:.6rem;border-top:1px solid var(--border-color)}.metric-row{display:flex;justify-content:space-between;align-items:center;padding:.25rem 0;font-size:.75rem}.metric-label{color:var(--text-secondary)}.metric-value{font-weight:600;font-family:SF Mono,Monaco,monospace}.metric-row.excellent .metric-value{color:var(--success)}.metric-row.good .metric-value{color:#22d3ee}.metric-row.warning .metric-value{color:var(--warning)}.metric-row.bad .metric-value{color:var(--error)}.metric-value.better{color:var(--success)}.metric-value.worse{color:var(--error)}.metric-value.exact{color:var(--text-secondary)}.slippage-detail{display:flex;justify-content:space-between;font-size:.65rem;color:var(--text-muted);margin-top:.3rem}.pnl-display{font-size:1.2rem;font-weight:700;margin-bottom:.3rem}.pnl-display.profit{color:var(--success)}.pnl-display.loss{color:var(--error)}.position-size{color:var(--text-secondary);font-size:.8rem}.node-footer{padding:.4rem .8rem;background:var(--bg-tertiary);border-top:1px solid var(--border-color);border-radius:0 0 8px 8px;font-size:.7rem;color:var(--text-muted);display:flex;justify-content:space-between}.total-latency{font-family:SF Mono,Monaco,monospace}.no-data-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:var(--text-muted);font-size:1.1rem}@media(max-width:1200px){.metrics-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.metrics-grid{grid-template-columns:repeat(2,1fr)}.signal-flow-react{height:calc(100vh - 250px)}}@media(max-width:768px){.app-header{grid-template-columns:1fr;gap:.75rem;padding:.75rem 1rem}.header-left,.main-nav,.header-right{justify-self:center}.app-main{padding:.75rem}.hero-metrics{grid-template-columns:1fr 1fr;gap:.5rem}.metric-card{padding:.75rem}.metric-value{font-size:1.1rem}.flow-stats{flex-wrap:wrap;gap:1rem;padding:.75rem}.flow-group{padding:.75rem}.flow-timeline-row{gap:1rem}.flow-node{min-width:60px}.node-icon{width:35px;height:35px;font-size:1rem}.position-chips{gap:.35rem}.position-chip{padding:.35rem .5rem;font-size:.75rem}.data-table th,.data-table td{padding:.5rem;font-size:.75rem}.subtab-btn{padding:.4rem .75rem;font-size:.8rem;white-space:nowrap}}@media(max-width:480px){.hero-metrics{grid-template-columns:1fr}.app-title{font-size:1rem}.main-nav{width:100%;justify-content:center}}.signal-dashboard{display:flex;flex-direction:column;gap:1.5rem}.perf-summary{background:var(--bg-secondary);border-radius:12px;padding:1rem;border:1px solid var(--border-color)}.perf-row{display:grid;grid-template-columns:repeat(6,1fr);gap:1rem}.perf-row .metric-box{text-align:center;padding:.75rem;background:var(--bg-tertiary);border-radius:8px;border:1px solid transparent;transition:border-color .2s}.perf-row .metric-box.good{border-color:var(--success)}.perf-row .metric-box.warn{border-color:var(--warning)}.perf-row .metric-box.bad{border-color:var(--error)}.perf-row .metric-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.perf-row .metric-box.good .metric-value{color:var(--success)}.perf-row .metric-box.warn .metric-value{color:var(--warning)}.perf-row .metric-box.bad .metric-value{color:var(--error)}.perf-row .metric-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-top:.25rem}.perf-row .metric-subtext{font-size:.7rem;color:var(--text-muted);margin-top:.25rem}.dash-filters{display:flex;gap:.75rem}.dash-filters select{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);padding:.5rem 1rem;border-radius:6px;font-size:.875rem;cursor:pointer}.dash-filters select:hover{border-color:var(--accent)}.signal-cards{display:flex;flex-direction:column;gap:1rem}.signal-cards .no-data{text-align:center;padding:3rem;color:var(--text-muted);font-size:1rem}.signal-card{background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border-color);overflow:hidden;transition:border-color .2s}.signal-card.live{border-left:3px solid var(--success)}.signal-card.paper{border-left:3px solid var(--warning)}.signal-card:hover{border-color:var(--accent)}.card-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;cursor:pointer;background:var(--bg-tertiary)}.card-title{display:flex;align-items:center;gap:.75rem}.mode-dot{width:10px;height:10px;border-radius:50%}.mode-dot.live{background:var(--success);box-shadow:0 0 8px var(--success)}.mode-dot.paper{background:var(--warning)}.card-title .symbol{font-size:1.1rem;font-weight:600}.pos-badge{background:var(--bg-hover);padding:.2rem .5rem;border-radius:4px;font-size:.8rem;color:var(--text-secondary)}.card-pnl .flat{color:var(--text-muted);font-size:.875rem}.card-metrics{display:flex;gap:1.5rem;padding:.75rem 1.25rem;background:#0003;border-bottom:1px solid var(--border-color)}.mini-metric{display:flex;flex-direction:column;gap:.2rem}.mini-metric .label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase}.mini-metric .value{font-size:.9rem;font-weight:600}.mini-metric .value.excellent{color:var(--success)}.mini-metric .value.good{color:#4ade80}.mini-metric .value.warn{color:var(--warning)}.mini-metric .value.bad{color:var(--error)}.pipeline{display:flex;align-items:stretch;padding:1.75rem 1.25rem 1.25rem;gap:0;overflow-x:auto;position:relative}.pipeline-stage{display:flex;align-items:flex-start;gap:.75rem;background:var(--bg-tertiary);padding:1rem;border-radius:8px;min-width:140px;flex-shrink:0}.pipeline-stage.filled{border:1px solid var(--success)}.pipeline-stage.pending{border:1px solid var(--warning)}.pipeline-stage.failed{border:1px solid var(--error)}.stage-icon{font-size:1.5rem}.stage-content{display:flex;flex-direction:column;gap:.25rem}.stage-title{font-size:.7rem;color:var(--text-muted);text-transform:uppercase}.stage-main{font-size:1rem;font-weight:600}.stage-sub{font-size:.8rem;color:var(--text-secondary)}.stage-time{font-size:.75rem;color:var(--text-muted)}.stage-extra{font-size:.8rem;color:var(--text-secondary);margin-top:.25rem;padding-top:.25rem;border-top:1px solid rgba(255,255,255,.1)}.stage-badge{font-size:.6rem;background:var(--accent);color:#fff;padding:.1rem .35rem;border-radius:4px;margin-left:.5rem;vertical-align:middle}.pipeline-arrow{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0 .5rem;min-width:70px}.arrow-line{width:100%;height:2px;background:var(--border-color);position:relative}.arrow-line:after{content:"→";position:absolute;right:-8px;top:-10px;color:var(--text-muted)}.pipeline-arrow.excellent .arrow-line{background:var(--success)}.pipeline-arrow.good .arrow-line{background:#4ade80}.pipeline-arrow.warn .arrow-line{background:var(--warning)}.pipeline-arrow.bad .arrow-line{background:var(--error)}.arrow-label{font-size:.75rem;font-weight:600;margin-top:.5rem}.pipeline-arrow.excellent .arrow-label{color:var(--success)}.pipeline-arrow.good .arrow-label{color:#4ade80}.pipeline-arrow.warn .arrow-label{color:var(--warning)}.pipeline-arrow.bad .arrow-label{color:var(--error)}.slippage-display{font-weight:600}.slippage-display.excellent{color:var(--success)}.slippage-display.good{color:#4ade80}.slippage-display.warn{color:var(--warning)}.slippage-display.bad{color:var(--error)}.slip-usd{font-weight:400;font-size:.85em;opacity:.8}.card-history{padding:1rem 1.25rem;border-top:1px solid var(--border-color)}.history-title{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;margin-bottom:.75rem}.history-table{width:100%;border-collapse:collapse;font-size:.85rem}.history-table th{text-align:left;padding:.5rem;color:var(--text-muted);font-weight:500;border-bottom:1px solid var(--border-color)}.history-table td{padding:.5rem;border-bottom:1px solid rgba(255,255,255,.05)}.history-table tr.latest td{background:#3b82f61a}.history-table tr.clickable-row{cursor:pointer;transition:background .15s ease}.history-table tr.clickable-row:hover{background:var(--bg-hover)}.history-table tr.clickable-row.selected td{background:#3b82f633;border-left:2px solid var(--accent)}.history-table tr.clickable-row.selected:first-child td{border-left:2px solid var(--accent)}.history-hint{font-weight:400;color:var(--text-muted);font-size:.75rem;margin-left:.5rem}.pipeline-label{position:absolute;top:-1.25rem;left:0;font-size:.7rem;color:var(--accent);font-weight:500;background:var(--bg-secondary);padding:.1rem .4rem;border-radius:4px}.history-table .filled{color:var(--success)}.history-table .pending{color:var(--warning)}.history-table .failed{color:var(--error)}.history-table td.excellent{color:var(--success)}.history-table td.good{color:#4ade80}.history-table td.warn{color:var(--warning)}.history-table td.bad{color:var(--error)}.expand-btn{width:100%;padding:.75rem;background:none;border:none;border-top:1px solid var(--border-color);color:var(--text-secondary);font-size:.8rem;cursor:pointer;transition:background .2s,color .2s}.expand-btn:hover{background:var(--bg-hover);color:var(--text-primary)}@media(max-width:1024px){.perf-row{grid-template-columns:repeat(3,1fr)}}@media(max-width:640px){.perf-row{grid-template-columns:repeat(2,1fr)}.card-metrics{flex-wrap:wrap;gap:1rem}.pipeline{flex-direction:column;gap:.5rem}.pipeline-arrow{transform:rotate(90deg);padding:.5rem 0;min-width:auto}}.strategies-tab{width:100%}.strategies-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.settings-toggle-btn{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;padding:.5rem;cursor:pointer;color:var(--text-secondary);transition:all .2s}.settings-toggle-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.settings-toggle-btn .icon{width:20px;height:20px}.active-strategies{display:flex;flex-direction:column;gap:1.5rem}.strategies-loading{display:flex;align-items:center;justify-content:center;gap:1rem;padding:3rem;color:var(--text-muted)}.loading-spinner{width:24px;height:24px;border:3px solid var(--border-color);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.strategies-summary{display:flex;gap:2rem;padding:1rem;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-color)}.summary-stat{display:flex;flex-direction:column;align-items:center;gap:.25rem}.stat-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase}.stat-value{font-size:1.25rem;font-weight:600}.stat-value.live{color:var(--success)}.stat-value.paper{color:var(--warning)}.strategy-zone{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;overflow:hidden;transition:border-color .2s}.strategy-zone.live{border-left:3px solid var(--success)}.strategy-zone.paper{border-left:3px solid var(--warning)}.strategy-zone.drag-over{border-color:var(--accent);box-shadow:0 0 20px #3b82f633}.zone-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.zone-header.live{background:#10b9811a}.zone-header.paper{background:#f59e0b1a}.zone-title{font-weight:600;font-size:.9rem}.zone-count{font-size:.8rem;color:var(--text-muted)}.zone-strategies{overflow-x:auto}.empty-zone{padding:2rem;text-align:center;color:var(--text-muted);border:2px dashed var(--border-color);border-radius:6px;margin:1rem}.strategies-table{width:100%}.strategies-table th{position:sticky;top:0;z-index:1}.strategy-row{transition:background .15s,opacity .15s}.strategy-row.dragging{opacity:.5}.strategy-row.pending{animation:pulse-bg 1.5s infinite}@keyframes pulse-bg{0%,to{background:transparent}50%{background:#3b82f61a}}.strategy-row-overlay{background:var(--bg-secondary);border:2px solid var(--accent);border-radius:8px;box-shadow:0 8px 32px #0006}.drag-handle-cell{width:40px}.drag-handle{background:none;border:none;color:var(--text-muted);cursor:grab;padding:.5rem;border-radius:4px;transition:color .2s}.drag-handle:hover{color:var(--text-primary);background:var(--bg-hover)}.drag-handle:active{cursor:grabbing}.strategy-row .symbol{font-weight:600;color:var(--accent)}.pending-badge{font-size:.65rem;font-weight:600;padding:.1rem .3rem;border-radius:4px;margin-left:.5rem;animation:pulse-badge 1s infinite}.pending-badge.live{background:#10b98133;color:var(--success)}.pending-badge.paper{background:#f59e0b33;color:var(--warning)}@keyframes pulse-badge{0%,to{opacity:1}50%{opacity:.5}}.score-cell .score{font-weight:600;font-family:SF Mono,Monaco,monospace}.score-cell .score.positive{color:var(--success)}.score-cell .score.negative{color:var(--error)}.pnl-stack{display:flex;flex-direction:column;gap:.15rem}.pnl-stack .roi{font-size:.7rem;font-weight:500}.position-cell .position{font-weight:600;font-size:.85rem}.position.long{color:var(--success)}.position.short{color:var(--error)}.position.flat{color:var(--text-muted)}.next-signal-cell .next-signal{font-size:.8rem;color:var(--text-secondary)}.actions-cell{display:flex;gap:.25rem}.action-btn{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;padding:.35rem;cursor:pointer;color:var(--text-secondary);transition:all .2s}.action-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.action-btn.danger:hover{background:#ef444433;border-color:var(--error);color:var(--error)}.icon-sm{width:16px;height:16px}.icon-xs{width:14px;height:14px}.changes-banner{position:sticky;bottom:0;display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:var(--bg-secondary);border:1px solid var(--accent);border-radius:8px;box-shadow:0 -4px 20px #0000004d}.banner-actions{display:flex;gap:.75rem}.btn-cancel{padding:.5rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .2s}.btn-cancel:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-save{padding:.5rem 1rem;background:var(--accent);border:none;border-radius:6px;color:#fff;font-weight:500;cursor:pointer;transition:background .2s}.btn-save:hover{background:var(--accent-hover)}.algo-run-selector{display:flex;flex-direction:column;gap:1rem;padding:1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px}.selector-row{display:flex;gap:1.5rem;align-items:flex-end}.date-filter,.run-select{display:flex;flex-direction:column;gap:.5rem}.filter-label{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--text-secondary)}.date-input{padding:.5rem .75rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:.85rem}.date-input:focus{outline:none;border-color:var(--accent)}.listbox-container{position:relative;min-width:250px}.listbox-button{display:flex;justify-content:space-between;align-items:center;width:100%;padding:.5rem .75rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:.85rem;cursor:pointer;transition:border-color .2s}.listbox-button:hover{border-color:var(--accent)}.listbox-value{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.listbox-options{position:absolute;top:100%;left:0;right:0;margin-top:.25rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;max-height:300px;overflow-y:auto;z-index:100;box-shadow:0 8px 24px #0006}.listbox-loading,.listbox-empty{padding:1rem;text-align:center;color:var(--text-muted);font-size:.85rem}.listbox-option{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;cursor:pointer;transition:background .15s}.listbox-option.active{background:var(--bg-hover)}.listbox-option.selected{background:#3b82f626}.option-content{display:flex;gap:1rem;align-items:center}.option-id{font-weight:600;color:var(--accent)}.option-symbols{font-size:.8rem;color:var(--text-secondary)}.option-date{font-size:.75rem;color:var(--text-muted)}.check-icon{color:var(--accent)}.selected-runs-summary{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.summary-label{font-size:.8rem;color:var(--text-secondary)}.run-chip{padding:.25rem .5rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;font-size:.8rem;font-weight:500;color:var(--accent)}.run-strategies{margin-top:1.5rem}.run-strategies-empty,.run-strategies-loading{display:flex;align-items:center;justify-content:center;gap:1rem;padding:3rem;color:var(--text-muted);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px}.bulk-actions{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:var(--bg-secondary);border:1px solid var(--accent);border-radius:6px;margin-bottom:1rem}.run-strategies-table-wrapper{overflow-x:auto;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px}.run-strategies-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.run-strategies-table th.sortable:hover{background:var(--bg-hover)}.th-content{display:flex;align-items:center;gap:.5rem}.checkbox-cell{width:40px;text-align:center}.checkbox-cell input{width:16px;height:16px;cursor:pointer}tr.selected{background:#3b82f61a}.status-badge.off{background:var(--bg-tertiary);color:var(--text-muted)}.status-badge.paper{background:#f59e0b33;color:var(--warning)}.status-badge.live{background:#10b98133;color:var(--success)}.btn{display:inline-flex;align-items:center;gap:.35rem;padding:.5rem 1rem;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s;border:none}.btn-xs{padding:.25rem .5rem;font-size:.75rem}.btn-sm{padding:.35rem .75rem;font-size:.8rem}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary)}.btn-secondary:hover{background:var(--bg-hover)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.settings-panel{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;margin-bottom:1.5rem}.settings-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color)}.settings-header h3{font-size:1rem;font-weight:600}.close-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;border-radius:4px}.close-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.close-btn .icon{width:20px;height:20px}.settings-body{padding:1.25rem;display:flex;flex-direction:column;gap:1.25rem}.setting-group{display:flex;flex-direction:column;gap:.5rem}.setting-label{font-size:.85rem;font-weight:500;color:var(--text-primary)}.setting-input,.setting-select{padding:.5rem .75rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:.85rem}.setting-input:focus,.setting-select:focus{outline:none;border-color:var(--accent)}.setting-help{font-size:.75rem;color:var(--text-muted)}.input-with-suffix{display:flex;align-items:center;gap:.5rem}.input-with-suffix .setting-input{width:100px}.input-suffix{color:var(--text-muted);font-size:.85rem}.settings-computed{padding:.75rem;background:var(--bg-tertiary);border-radius:6px}.computed-item{display:flex;justify-content:space-between;align-items:center}.computed-label{font-size:.8rem;color:var(--text-secondary)}.computed-value{font-weight:600;color:var(--accent)}.settings-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.25rem;border-top:1px solid var(--border-color)}.dialog-overlay{position:fixed;inset:0;z-index:1000;overflow-y:auto}.dialog-backdrop{position:fixed;inset:0;background:#000000b3}.dialog-container{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:1rem}.dialog-panel{position:relative;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;max-width:420px;width:100%;box-shadow:0 16px 48px #00000080}.dialog-panel.large{max-width:700px}.dialog-icon{display:flex;align-items:center;justify-content:center;width:60px;height:60px;margin:1.5rem auto 1rem;border-radius:50%}.dialog-icon.warning{background:#f59e0b33;color:var(--warning)}.dialog-icon .icon{width:32px;height:32px}.dialog-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color)}.dialog-title{font-size:1.1rem;font-weight:600;text-align:center;padding:0 1.5rem}.dialog-body{padding:1.25rem 1.5rem;text-align:center}.dialog-body p{color:var(--text-secondary);margin-bottom:1rem}.position-info{display:flex;align-items:center;justify-content:center;gap:1rem;padding:1rem;background:var(--bg-tertiary);border-radius:8px;margin-bottom:1rem}.position-badge{font-weight:600;padding:.35rem .75rem;border-radius:6px}.position-badge.long{background:#10b98133;color:var(--success)}.position-badge.short{background:#ef444433;color:var(--error)}.dialog-note{font-size:.85rem;color:var(--text-muted)}.dialog-actions{display:flex;flex-direction:column;gap:.5rem;padding:0 1.5rem 1.5rem}.dialog-actions .btn{justify-content:center;width:100%}.dialog-tabs{display:flex;gap:.25rem;padding:0 1rem;border-bottom:1px solid var(--border-color)}.dialog-tab{padding:.75rem 1rem;background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:.85rem;border-bottom:2px solid transparent;transition:all .2s}.dialog-tab:hover{color:var(--text-primary)}.dialog-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.details-section{padding:1.25rem}.details-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.detail-item{display:flex;flex-direction:column;gap:.25rem}.detail-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase}.section-title{font-size:.85rem;font-weight:600;color:var(--text-secondary);margin:1.5rem 0 .75rem;padding-top:1rem;border-top:1px solid var(--border-color)}.config-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.config-item{display:flex;flex-direction:column;gap:.5rem}.config-label{font-size:.85rem;font-weight:500}.config-input,.config-select{padding:.5rem .75rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:.85rem}.config-help{font-size:.7rem;color:var(--text-muted)}.config-actions{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border-color)}.empty-tab{padding:3rem;text-align:center;color:var(--text-muted)}.data-table.compact th,.data-table.compact td{padding:.5rem .75rem;font-size:.8rem}.algo-runs-tab{display:flex;flex-direction:column;gap:1rem}@media(max-width:768px){.strategies-summary{flex-wrap:wrap;gap:1rem}.selector-row{flex-direction:column;gap:1rem}.listbox-container{min-width:100%}.details-grid{grid-template-columns:repeat(2,1fr)}.config-grid{grid-template-columns:1fr}.dialog-panel{margin:.5rem;max-width:calc(100% - 1rem)}}
