*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f1117;--panel:#1a1d27;--border:#2d3044;--text:#d4d8e8;--text-dim:#6b7280;--text-head:#f0f2ff;--accent:#e8ff00;--accent-dim:#e8ff001f;--speed:#00d4ff;--brake:#f44;--green:#22c55e;--radius:8px;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;font:14px/1.5 system-ui,Segoe UI,sans-serif}body{min-height:100vh}#root{display:contents}.app{flex-direction:column;min-height:100vh;display:flex}.app-header{border-bottom:1px solid var(--border);background:var(--panel);align-items:center;gap:10px;padding:14px 24px;display:flex}.app-logo-img{width:auto;height:26px;image-rendering:crisp-edges;flex-shrink:0;display:block}.header-right{align-items:center;margin-left:auto;display:flex}.track-selector-wrapper{align-items:center;display:flex;position:relative}.track-selector{appearance:none;border:1px solid var(--border);color:var(--text-dim);letter-spacing:.12em;text-transform:uppercase;cursor:pointer;background:0 0;border-radius:20px;outline:none;padding:4px 28px 4px 12px;font-family:inherit;font-size:12px;transition:border-color .15s,color .15s}.track-selector:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.track-selector:disabled{opacity:.4;cursor:not-allowed}.track-selector option{background:var(--panel);color:var(--text);text-transform:none;letter-spacing:0}.track-selector-arrow{color:var(--text-dim);pointer-events:none;font-size:10px;position:absolute;right:10px}.app-body{flex:1;grid-template-columns:260px 1fr;display:grid;overflow:hidden}.setup-panel{background:var(--panel);border-right:1px solid var(--border);flex-direction:column;gap:20px;padding:20px 16px;display:flex;overflow-y:auto}.panel-title{letter-spacing:.14em;text-transform:uppercase;color:var(--text-dim);border-bottom:1px solid var(--border);padding-bottom:12px;font-size:11px;font-weight:600}.slider-row{flex-direction:column;gap:6px;display:flex}.slider-header{justify-content:space-between;align-items:baseline;display:flex}.slider-label{color:var(--text);font-size:13px;font-weight:500}.slider-value{color:var(--accent);font-variant-numeric:tabular-nums;font-size:13px;font-weight:700}.slider-bounds{color:var(--text-dim);justify-content:space-between;font-size:10px;display:flex}input[type=range]{appearance:none;background:var(--border);cursor:pointer;border-radius:2px;outline:none;width:100%;height:4px}input[type=range]::-webkit-slider-thumb{appearance:none;background:var(--accent);border:2px solid var(--panel);width:14px;height:14px;box-shadow:0 0 0 1px var(--accent);cursor:grab;border-radius:50%}input[type=range]::-webkit-slider-thumb:active{cursor:grabbing}input[type=range]::-moz-range-thumb{background:var(--accent);border:2px solid var(--panel);cursor:grab;border-radius:50%;width:14px;height:14px}.fixed-params{border-top:1px solid var(--border);flex-direction:column;gap:8px;padding-top:8px;display:flex}.fixed-param{color:var(--text-dim);justify-content:space-between;font-size:12px;display:flex}.fixed-param span:last-child{color:var(--text);font-variant-numeric:tabular-nums}.run-btn{background:var(--accent);color:#0f1117;border-radius:var(--radius);letter-spacing:.05em;text-transform:uppercase;cursor:pointer;border:none;width:100%;margin-top:auto;padding:11px 0;font-size:13px;font-weight:700;transition:opacity .15s}.run-btn:hover:not(:disabled){opacity:.88}.run-btn:disabled{opacity:.45;cursor:not-allowed}.run-btn.loading{background:var(--border);color:var(--text-dim)}.dashboard{flex-direction:column;gap:20px;padding:20px 24px;display:flex;overflow-y:auto}.dashboard-placeholder{color:var(--text-dim);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:40px;font-size:14px;display:flex}.dashboard-placeholder strong{color:var(--text)}.dashboard-placeholder.error{color:#ff6b6b}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:28px;height:28px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.metrics-row{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.metric-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:4px;padding:14px 16px;display:flex}.metric-label{letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);font-size:10px}.metric-value{letter-spacing:-.5px;color:var(--text-head);font-variant-numeric:tabular-nums;font-size:26px;font-weight:700}.metric-sub{color:var(--text-dim);font-size:11px}.sector-row{gap:10px;display:flex}.sector-badge{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:8px;padding:8px 14px;display:flex}.sector-label{letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);font-size:10px}.sector-time{font-variant-numeric:tabular-nums;color:var(--accent);font-size:14px;font-weight:600}.chart-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:10px;padding:16px 16px 12px;display:flex}.chart-title{letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);align-items:center;gap:10px;font-size:11px;font-weight:600;display:flex}.chart-unit{color:var(--text-dim);font-weight:400}.chart-legend{letter-spacing:.04em;text-transform:none;gap:14px;font-size:11px;font-weight:400;display:flex}.baseline-btn{color:var(--text-dim);border:1px solid var(--border);border-radius:var(--radius);letter-spacing:.05em;text-transform:uppercase;cursor:pointer;background:0 0;width:100%;padding:9px 0;font-size:12px;font-weight:600;transition:border-color .15s,color .15s}.baseline-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.baseline-btn:disabled{opacity:.3;cursor:not-allowed}.cmp-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.cmp-header{border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:8px;padding:14px 16px 12px;display:flex}.cmp-title{letter-spacing:.14em;text-transform:uppercase;color:var(--text-dim);font-size:11px;font-weight:600}.cmp-baseline-tag{color:var(--text-dim);font-variant-numeric:tabular-nums;border:1px solid var(--border);border-radius:20px;padding:2px 10px;font-size:11px}.cmp-table{border-collapse:collapse;font-variant-numeric:tabular-nums;width:100%;font-size:13px}.cmp-th{text-align:left;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);border-bottom:1px solid var(--border);background:#ffffff05;padding:8px 16px;font-size:10px;font-weight:600}.cmp-th-metric{width:38%}.cmp-row:not(:last-child) td{border-bottom:1px solid #2d304499}.cmp-label{color:var(--text);padding:10px 16px;font-weight:500}.cmp-cell{padding:10px 16px}.cmp-baseline{color:var(--text-dim)}.cmp-current{color:var(--text-head);font-weight:600}.delta-badge{letter-spacing:.02em;border-radius:4px;align-items:center;padding:2px 8px;font-size:12px;font-weight:700;display:inline-flex}.delta-good{color:#22c55e;background:#22c55e26}.delta-bad{color:#ef4444;background:#ef444426}.delta-neutral{color:var(--text-dim);background:#6b72801f}.cmp-empty{background:var(--panel);border:1px dashed var(--border);border-radius:var(--radius);color:var(--text-dim);align-items:center;gap:12px;padding:18px 20px;font-size:13px;display:flex}.cmp-empty-icon{opacity:.4;flex-shrink:0;font-size:18px}.cmp-empty strong{color:var(--text)}.track-map-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:8px;padding:10px 10px 8px;display:flex}.track-map-header{letter-spacing:.14em;text-transform:uppercase;color:var(--text-dim);font-size:10px;font-weight:600}.track-map-svg-wrapper{width:100%;line-height:0}.track-classification{letter-spacing:.1em;text-transform:uppercase;color:var(--accent);text-align:center;opacity:.85;font-size:10px;font-weight:600}.playback-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:8px;padding:10px 10px 8px;display:flex}.playback-header{letter-spacing:.14em;text-transform:uppercase;color:var(--text-dim);font-size:10px;font-weight:600}.playback-progress-bar{background:var(--border);border-radius:2px;width:100%;height:3px;overflow:hidden}.playback-progress-fill{background:var(--accent);border-radius:2px;height:100%;transition:width 40ms linear}.playback-controls-row{align-items:center;gap:6px;display:flex}.playback-transport{gap:4px;display:flex}.playback-btn{border:1px solid var(--border);width:28px;height:28px;color:var(--text-dim);cursor:pointer;background:0 0;border-radius:6px;justify-content:center;align-items:center;font-size:13px;transition:border-color .15s,color .15s,background .15s;display:flex}.playback-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.playback-btn:disabled{opacity:.28;cursor:not-allowed}.playback-btn.active{background:var(--accent);border-color:var(--accent);color:#0f1117}.playback-speed-group{gap:3px;margin-left:auto;display:flex}.speed-btn{border:1px solid var(--border);color:var(--text-dim);letter-spacing:.04em;cursor:pointer;background:0 0;border-radius:4px;padding:3px 5px;font-size:10px;font-weight:700;transition:border-color .15s,color .15s,background .15s}.speed-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.speed-btn:disabled{opacity:.28;cursor:not-allowed}.speed-btn.active{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.live-strip{border-radius:var(--radius);background:#e8ff000a;border:1px solid #e8ff002e;flex-direction:column;gap:10px;padding:10px 14px;display:flex}.live-strip-top{justify-content:space-between;align-items:center;display:flex}.live-indicator{letter-spacing:.14em;text-transform:uppercase;color:var(--accent);align-items:center;gap:6px;font-size:10px;font-weight:700;display:flex}.live-dot{background:var(--accent);border-radius:50%;width:6px;height:6px;animation:1s ease-in-out infinite live-pulse}@keyframes live-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.7)}}.live-time{font-variant-numeric:tabular-nums;color:var(--text-dim);font-size:11px;font-weight:600}.live-grid{grid-template-columns:repeat(3,1fr);gap:10px 8px;display:grid}.live-cell{flex-direction:column;gap:1px;display:flex}.live-label{letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);font-size:9px;font-weight:600}.live-value{font-variant-numeric:tabular-nums;color:var(--text-head);letter-spacing:-.3px;font-size:15px;font-weight:700}.live-value-hi{color:var(--accent)}.live-unit{color:var(--text-dim);letter-spacing:0;font-size:9px;font-weight:400}
