: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}}
