:root{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--bg-panel: #1a2332;--border: #334155;--border-light: #475569;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--accent: #3b82f6;--accent-dim: #1e3a5f;--xapp-lb: #2f80ed;--xapp-ad: #eb5757;--xapp-ho: #27ae60;--xapp-bf: #f5a623;--status-green: #22c55e;--status-yellow: #eab308;--status-red: #ef4444;--radius: 8px;--radius-sm: 4px;--shadow: 0 2px 8px rgba(0, 0, 0, .3);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .4);--font-mono: "JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden;background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-sans);font-size:13px;line-height:1.5;-webkit-font-smoothing:antialiased}#app{display:flex;height:100vh;width:100vw}.canvas-area{flex:7;position:relative;min-width:0;background:var(--bg-primary);display:flex;align-items:center;justify-content:center}.canvas-area canvas{display:block;width:100%;height:100%}.canvas-overlay{position:absolute;top:12px;left:12px;display:flex;gap:8px;align-items:center;pointer-events:none}.status-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;background:var(--bg-secondary);border:1px solid var(--border);box-shadow:var(--shadow);pointer-events:auto}.status-badge .dot{width:7px;height:7px;border-radius:50%;background:var(--status-green)}.status-badge.paused .dot{background:var(--status-yellow)}.status-badge.mode{color:var(--accent);border-color:var(--accent-dim)}.sidebar{flex:3;min-width:280px;max-width:420px;background:var(--bg-secondary);border-left:1px solid var(--border);overflow-y:auto;display:flex;flex-direction:column;scrollbar-width:thin;scrollbar-color:var(--bg-tertiary) var(--bg-secondary)}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:var(--bg-secondary)}.sidebar::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:3px}.panel{border-bottom:1px solid var(--border);padding:14px 16px}.panel:last-child{border-bottom:none}.panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.panel-header h2{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-secondary)}.panel-header .panel-badge{font-size:10px;padding:2px 8px;border-radius:10px;background:var(--accent-dim);color:var(--accent);font-weight:600}.title-panel{padding:18px 16px;background:linear-gradient(135deg,var(--bg-secondary) 0%,#162033 100%)}.title-panel h1{font-size:15px;font-weight:800;color:var(--text-primary);margin-bottom:3px}.title-panel .subtitle{font-size:11px;color:var(--text-muted)}.control-group{margin-bottom:10px}.control-group:last-child{margin-bottom:0}.control-label{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:var(--text-secondary);margin-bottom:4px;font-weight:500}.control-label .value{font-family:var(--font-mono);color:var(--text-primary);font-size:11px}.btn-row{display:flex;gap:6px;margin-bottom:10px}.btn{flex:1;padding:7px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-tertiary);color:var(--text-primary);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s ease;font-family:inherit}.btn:hover{background:#3d4f65;border-color:var(--border-light)}.btn:active{transform:scale(.97)}.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn.primary:hover{background:#2563eb}.btn.danger{border-color:#7f1d1d;color:var(--status-red)}.btn.danger:hover{background:#450a0a}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:4px;border-radius:2px;background:var(--bg-tertiary);outline:none;cursor:pointer}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);border:2px solid var(--bg-secondary);cursor:pointer;transition:box-shadow .15s}input[type=range]::-webkit-slider-thumb:hover{box-shadow:0 0 0 4px #3b82f633}input[type=range]::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--accent);border:2px solid var(--bg-secondary);cursor:pointer}select{width:100%;padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);font-size:12px;font-family:inherit;cursor:pointer;outline:none}select:focus{border-color:var(--accent)}.toggle-row{display:flex;gap:4px;background:var(--bg-primary);border-radius:var(--radius-sm);padding:2px;border:1px solid var(--border)}.toggle-btn{flex:1;padding:5px 10px;border:none;border-radius:3px;background:transparent;color:var(--text-muted);font-size:11px;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit}.toggle-btn.active{background:var(--accent);color:#fff}.budget-meter{width:100%;height:20px;background:var(--bg-primary);border-radius:10px;overflow:hidden;border:1px solid var(--border);position:relative;margin:6px 0}.budget-meter-fill{height:100%;border-radius:10px;transition:width .3s ease,background-color .3s ease;background:var(--status-green)}.budget-meter-fill.warning{background:var(--status-yellow)}.budget-meter-fill.danger{background:var(--status-red)}.budget-meter-label{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;font-family:var(--font-mono);color:var(--text-primary);text-shadow:0 1px 2px rgba(0,0,0,.5)}.xapp-card{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px;margin-bottom:8px;transition:border-color .2s}.xapp-card:last-child{margin-bottom:0}.xapp-card:hover{border-color:var(--border-light)}.xapp-card-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.xapp-color-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.xapp-card-header .name{font-size:12px;font-weight:700;flex:1}.xapp-card-header .round-badge{font-size:10px;font-family:var(--font-mono);color:var(--text-muted);background:var(--bg-secondary);padding:2px 6px;border-radius:8px}.xapp-metrics-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.metric-item{display:flex;flex-direction:column}.metric-item .metric-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px}.metric-item .metric-value{font-size:13px;font-weight:700;font-family:var(--font-mono)}.metric-item .metric-value.green{color:var(--status-green)}.metric-item .metric-value.yellow{color:var(--status-yellow)}.metric-item .metric-value.red{color:var(--status-red)}.xapp-progress{width:100%;height:4px;background:var(--bg-secondary);border-radius:2px;margin-top:8px;overflow:hidden}.xapp-progress-fill{height:100%;border-radius:2px;transition:width .3s ease}.sparkline-row{display:flex;gap:8px;margin-top:8px}.sparkline-container{flex:1;display:flex;flex-direction:column;align-items:center}.sparkline-container .sparkline-label{font-size:9px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;margin-bottom:2px}.sparkline-container canvas{width:100%;height:28px;border-radius:3px;background:var(--bg-secondary)}.collapsible-header{display:flex;align-items:center;gap:8px;cursor:pointer;padding:6px 0;-webkit-user-select:none;user-select:none}.collapsible-header .arrow{font-size:10px;color:var(--text-muted);transition:transform .2s}.collapsible-header .arrow.open{transform:rotate(90deg)}.collapsible-body{overflow:hidden;max-height:0;transition:max-height .25s ease}.collapsible-body.open{max-height:300px}.collapsible-body-inner{padding:6px 0 2px 18px}.config-row{display:flex;justify-content:space-between;align-items:center;font-size:11px;padding:2px 0}.config-row .config-key{color:var(--text-muted)}.config-row .config-val{font-family:var(--font-mono);color:var(--text-primary);font-size:11px}.composition-result{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px;margin-top:8px}.composition-result .comp-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;margin-bottom:2px}.composition-result .comp-value{font-size:16px;font-weight:800;font-family:var(--font-mono)}.charts-panel canvas{width:100%;height:120px;border-radius:var(--radius);background:var(--bg-primary);border:1px solid var(--border);margin-top:6px}.chart-title{font-size:11px;color:var(--text-secondary);font-weight:600;margin-top:10px}.chart-title:first-child{margin-top:0}.tick-display{font-family:var(--font-mono);font-size:11px;color:var(--text-muted);text-align:center;padding:4px 0}.overall-accuracy{font-size:20px;font-weight:800;font-family:var(--font-mono);text-align:center;padding:4px 0;color:var(--accent)}@media (max-width: 900px){#app{flex-direction:column}.canvas-area{flex:none;height:50vh}.sidebar{flex:1;max-width:none;min-width:auto;border-left:none;border-top:1px solid var(--border)}}@media (max-width: 600px){.canvas-area{height:40vh}.panel{padding:10px 12px}.xapp-metrics-grid{grid-template-columns:1fr}}
