:root{--bg-space: #000000;--bg-panel: rgba(15, 15, 20, .95);--bg-header: rgba(10, 10, 15, .98);--planet-healthy: #22c55e;--planet-warning: #fbbf24;--planet-critical: #ef4444;--planet-dead: #4b5563;--accent-primary: #00d4ff;--accent-secondary: #8b5cf6;--text-primary: #ffffff;--text-secondary: #9ca3af;--text-muted: #6b7280;--header-height: 56px;--playback-height: 56px;--panel-width: 320px}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,sans-serif;background:var(--bg-space);color:var(--text-primary)}.app-container{display:flex;flex-direction:column;height:100vh;width:100vw;overflow:hidden}.header-bar{height:var(--header-height);background:var(--bg-header);border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:space-between;padding:0 16px;flex-shrink:0;z-index:100}.header-left{display:flex;align-items:center;gap:16px}.header-logo{font-weight:700;font-size:16px;letter-spacing:.5px;color:var(--accent-primary)}.header-simid{font-family:SF Mono,Monaco,Courier New,monospace;font-size:12px;color:var(--text-secondary);background:#ffffff0d;padding:4px 8px;border-radius:4px}.header-mode{font-size:11px;font-weight:700;padding:4px 10px;border-radius:4px;letter-spacing:.5px}.header-tick{font-family:SF Mono,Monaco,Courier New,monospace;font-size:13px;color:var(--text-secondary)}.header-right{display:flex;align-items:center;gap:20px}.header-planet-dots{display:flex;gap:4px;align-items:center}.planet-dot{width:8px;height:8px;border-radius:50%}.planet-dot.healthy{background:var(--planet-healthy)}.planet-dot.warning{background:var(--planet-warning)}.planet-dot.critical{background:var(--planet-critical);animation:pulse 1.5s infinite}.planet-dot.dead{background:var(--planet-dead)}.header-planet-counts{display:flex;gap:12px;align-items:center}.planet-count{display:flex;align-items:center;gap:4px;font-size:13px;font-weight:500}.planet-count .count-dot{width:10px;height:10px;border-radius:50%}.planet-count.healthy .count-dot{background:var(--planet-healthy)}.planet-count.healthy{color:var(--planet-healthy)}.planet-count.warning .count-dot{background:var(--planet-warning)}.planet-count.warning{color:var(--planet-warning)}.planet-count.critical .count-dot{background:var(--planet-critical)}.planet-count.critical{color:var(--planet-critical)}.planet-count.dead .count-dot{background:var(--planet-dead)}.planet-count.dead{color:var(--planet-dead)}.header-agents{font-size:13px;color:var(--text-secondary)}.header-mode-controls{display:flex;align-items:center;gap:2px;background:#0000004d;border-radius:6px;padding:2px}.header-mode-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;background:transparent;border:none;border-radius:4px;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.header-mode-btn:hover:not(:disabled){background:#ffffff1a;color:var(--text-primary)}.header-mode-btn:disabled{opacity:.35;cursor:not-allowed}.header-mode-btn.live .mode-indicator{width:6px;height:6px;border-radius:50%;background:var(--planet-critical);animation:pulse 1.5s infinite}.header-mode-btn.history{color:var(--text-secondary)}.server-indicator{font-size:13px;padding:6px 8px;color:var(--text-muted)}.server-indicator.online{color:var(--planet-healthy)}.server-indicator.offline{color:var(--text-muted)}.header-history-wrapper{position:relative}.header-history-dropdown{position:absolute;top:100%;left:0;margin-top:4px;min-width:280px;max-height:300px;overflow-y:auto;background:var(--bg-panel);border:1px solid rgba(255,255,255,.15);border-radius:8px;box-shadow:0 8px 24px #0006;z-index:200}.dropdown-loading,.dropdown-empty{padding:16px;text-align:center;font-size:13px;color:var(--text-muted)}.dropdown-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 14px;background:none;border:none;border-bottom:1px solid rgba(255,255,255,.05);cursor:pointer;transition:all .15s;text-align:left;color:var(--text-primary)}.dropdown-item:last-child{border-bottom:none}.dropdown-item:hover{background:#ffffff14}.dropdown-item-id{font-family:SF Mono,Monaco,monospace;font-size:12px;flex:1}.dropdown-item-status{font-size:9px;font-weight:600;text-transform:uppercase;padding:2px 6px;border-radius:3px}.dropdown-item-status.completed{background:#22c55e33;color:#22c55e}.dropdown-item-status.running{background:#fbbf2433;color:#fbbf24}.dropdown-item-status.error{background:#ef444433;color:#ef4444}.dropdown-item-ticks{font-size:11px;color:var(--text-muted)}.main-content{flex:1;position:relative;overflow:hidden}.galaxy-map{display:block}.detail-panel{position:absolute;top:var(--header-height);right:0;width:var(--panel-width);height:calc(100vh - var(--header-height));background:var(--bg-panel);border-left:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;z-index:50;animation:slide-in .2s ease-out}@keyframes slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.detail-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid rgba(255,255,255,.1);font-weight:600;font-size:14px}.detail-close{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:16px;padding:4px 8px;border-radius:4px;transition:all .15s}.detail-close:hover{background:#ffffff1a;color:var(--text-primary)}.detail-content{flex:1;overflow-y:auto;padding:16px}.detail-placeholder{color:var(--text-muted);font-size:13px;text-align:center;padding:40px 0}.playback-bar{height:var(--playback-height);background:var(--bg-header);border-top:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;padding:0 16px;flex-shrink:0;color:var(--text-muted);font-size:13px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#0003}::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff40}button{font-family:inherit;cursor:pointer;transition:all .15s}button:focus{outline:2px solid var(--accent-primary);outline-offset:2px}.filter-controls{position:absolute;bottom:24px;left:50%;transform:translate(-50%);background:#1e2028e6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:16px;padding:12px 20px;display:flex;gap:24px;border:1px solid rgba(255,255,255,.1);box-shadow:0 8px 32px #0006;z-index:40}.filter-toggle{display:flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none}.filter-label{font-size:13px;font-weight:500;color:var(--text-secondary);white-space:nowrap}.toggle-switch{width:44px;height:24px;background:#ffffff1a;border-radius:12px;position:relative;transition:all .2s ease;cursor:pointer}.toggle-switch.on{background:#22c55e}.toggle-knob{width:20px;height:20px;background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;transition:all .2s ease;box-shadow:0 2px 4px #0003}.toggle-switch.on .toggle-knob{left:22px}.map-controls{position:absolute;bottom:24px;right:24px;display:flex;flex-direction:column;gap:8px;z-index:40}.map-btn{width:40px;height:40px;border-radius:10px;background:#1e2028e6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);color:var(--text-primary);font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}.map-btn:hover{background:#32343ce6;border-color:#fff3}.detail-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.detail-body{flex:1;overflow-y:auto;padding:16px}.detail-planet-header{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:12px}.detail-planet-name{font-size:18px;font-weight:600;color:var(--text-primary)}.detail-planet-id{font-size:12px;color:var(--text-muted);font-family:SF Mono,Monaco,monospace}.detail-health-badge{font-size:10px;font-weight:600;padding:3px 8px;border-radius:4px;color:#000;text-transform:uppercase;letter-spacing:.3px}.detail-role-badge{font-size:10px;font-weight:600;padding:3px 8px;border-radius:4px;background:#8b5cf640;color:#a78bfa;text-transform:uppercase;letter-spacing:.3px}.detail-tag{font-size:11px;padding:4px 10px;border-radius:4px;background:#fbbf2433;color:#fbbf24;margin-bottom:16px;display:inline-block}.detail-economy-summary{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:12px}.detail-tag.producing{background:#22c55e33;color:#4ade80}.detail-tag.consuming{background:#fbbf2433;color:#fbbf24}.detail-tag.refining{background:#14b8a633;color:#2dd4bf}.detail-llm-agent{font-weight:400;color:#a78bfa}.detail-strategy-reasoning{font-size:11px;font-style:italic;color:#9ca3af;padding:4px 0}.detail-stock-item{margin-bottom:4px}.detail-resource-tags{display:flex;gap:6px;margin:2px 0 4px;min-height:0}.resource-tag{font-size:9px;font-weight:600;padding:1px 6px;border-radius:3px;letter-spacing:.2px}.resource-tag.producing{background:#22c55e33;color:#4ade80}.resource-tag.consuming{background:#fbbf2433;color:#fbbf24}.resource-tag.refining{background:#14b8a633;color:#2dd4bf}.resource-tag.inactive{background:#6b728026;color:#4b5563}.detail-agent-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.detail-agent-name{font-size:18px;font-weight:600;color:var(--text-primary)}.detail-state-badge{font-size:10px;font-weight:600;padding:3px 8px;border-radius:4px;text-transform:uppercase;letter-spacing:.3px}.detail-state-badge.docked{background:#22d3ee33;color:#22d3ee}.detail-state-badge.in_transit{background:#a855f733;color:#a855f7}.detail-section{margin-bottom:20px}.detail-section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid rgba(255,255,255,.08)}.detail-row{display:flex;align-items:center;gap:12px;margin-bottom:8px}.detail-label{font-size:13px;color:var(--text-secondary);min-width:80px;text-transform:capitalize}.detail-value{font-size:13px;font-weight:500;color:var(--text-primary);font-family:SF Mono,Monaco,monospace;min-width:50px;text-align:right}.detail-bar-container{flex:1;min-width:60px}.progress-bar{height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden}.progress-fill{height:100%;border-radius:3px;transition:width .3s ease}.detail-agent-list{display:flex;flex-direction:column;gap:6px}.detail-agent-item{display:flex;align-items:center;gap:12px;padding:8px 12px;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:8px;cursor:pointer;transition:all .15s;width:100%;text-align:left}.detail-agent-item:hover{background:#ffffff14;border-color:#ffffff26}.detail-agent-item .agent-id{font-weight:600;color:var(--accent-primary);font-size:13px}.detail-agent-item .agent-wealth{font-size:12px;color:var(--text-secondary);font-family:SF Mono,Monaco,monospace}.detail-agent-item .agent-fuel{font-size:12px;color:var(--text-muted);margin-left:auto}.detail-agent-item.departing{opacity:.35;pointer-events:none}.detail-agent-item .agent-departing-label{font-size:10px;color:#6b7280;margin-left:auto;font-style:italic}.detail-empty{font-size:13px;color:var(--text-muted);font-style:italic;padding:8px 0}.detail-location-link{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:8px;cursor:pointer;transition:all .15s;width:100%;text-align:left;color:var(--text-primary);font-size:14px}.detail-location-link:hover{background:#ffffff14;border-color:var(--accent-primary)}.detail-location-link.small{padding:6px 10px;font-size:13px}.detail-location-link .location-icon{font-size:14px}.detail-location-link .location-id{font-size:11px;color:var(--text-muted);font-family:SF Mono,Monaco,monospace;margin-left:auto}.detail-transit{display:flex;align-items:center;gap:12px}.transit-from,.transit-to{flex:1;display:flex;flex-direction:column;gap:4px}.transit-label{font-size:10px;text-transform:uppercase;color:var(--text-muted);letter-spacing:.3px}.transit-arrow{font-size:18px;color:var(--text-muted)}.detail-wealth{font-size:24px;font-weight:600;color:#22c55e;font-family:SF Mono,Monaco,monospace}.mode-selector-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:1000}.mode-selector{background:var(--bg-panel);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:32px;width:420px;max-width:90vw;box-shadow:0 20px 60px #00000080}.mode-selector-header{text-align:center;margin-bottom:24px}.mode-selector-header h2{font-size:24px;font-weight:600;color:var(--text-primary);margin-bottom:12px}.server-status{display:flex;align-items:center;justify-content:center;gap:8px;font-size:13px;color:var(--text-secondary)}.status-dot{width:8px;height:8px;border-radius:50%}.status-dot.green{background:var(--planet-healthy);box-shadow:0 0 8px var(--planet-healthy)}.status-dot.red{background:var(--planet-critical)}.status-dot.pulse{animation:pulse 1.5s infinite}.live-status{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;margin-bottom:20px;font-size:13px;color:var(--text-secondary)}.live-status strong{color:var(--text-primary);font-family:SF Mono,Monaco,monospace}.mode-selector-actions{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.mode-btn{display:flex;align-items:center;gap:16px;padding:16px 20px;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:12px;cursor:pointer;transition:all .2s ease;text-align:left;width:100%}.mode-btn:hover:not(:disabled){background:#ffffff14;border-color:#fff3}.mode-btn:disabled{opacity:.4;cursor:not-allowed}.mode-btn.live:hover:not(:disabled){border-color:var(--planet-critical);background:#ef44441a}.mode-btn.replay:hover:not(:disabled){border-color:var(--accent-secondary);background:#8b5cf61a}.mode-btn-icon{font-size:20px;width:32px;text-align:center}.mode-btn.live .mode-btn-icon{color:var(--planet-critical)}.mode-btn.replay .mode-btn-icon{color:var(--accent-secondary)}.mode-btn-label{font-size:16px;font-weight:600;color:var(--text-primary)}.mode-btn-desc{font-size:12px;color:var(--text-muted);margin-left:auto}.history-panel{background:#0000004d;border:1px solid rgba(255,255,255,.08);border-radius:10px;margin-bottom:20px;overflow:hidden}.history-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.08);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.refresh-btn{background:none;border:none;color:var(--accent-primary);font-size:11px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .15s}.refresh-btn:hover{background:#00d4ff1a}.history-loading,.history-error,.history-empty{padding:24px;text-align:center;font-size:13px;color:var(--text-muted)}.history-error{color:var(--planet-critical)}.history-list{max-height:200px;overflow-y:auto}.history-item{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;background:none;border:none;border-bottom:1px solid rgba(255,255,255,.05);cursor:pointer;transition:all .15s;text-align:left}.history-item:last-child{border-bottom:none}.history-item:hover{background:#ffffff0d}.history-item-id{font-family:SF Mono,Monaco,monospace;font-size:13px;color:var(--text-primary);flex:1}.history-item-status{font-size:10px;font-weight:600;text-transform:uppercase;padding:3px 8px;border-radius:4px}.history-item-status.completed{background:#22c55e33;color:#22c55e}.history-item-status.running{background:#fbbf2433;color:#fbbf24}.history-item-status.error{background:#ef444433;color:#ef4444}.history-item-ticks{font-size:12px;color:var(--text-muted);min-width:60px;text-align:right}.mode-selector-footer{text-align:center;padding-top:12px;border-top:1px solid rgba(255,255,255,.08)}.server-url{font-family:SF Mono,Monaco,monospace;font-size:11px;color:var(--text-muted)}.waiting-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:900}.waiting-content{text-align:center;padding:40px}.waiting-spinner{width:48px;height:48px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 20px}@keyframes spin{to{transform:rotate(360deg)}}.waiting-content h3{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.waiting-content p{font-size:14px;color:var(--text-secondary);margin-bottom:20px}.waiting-cancel{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:var(--text-primary);padding:10px 24px;border-radius:8px;font-size:14px;cursor:pointer;transition:all .15s}.waiting-cancel:hover{background:#ffffff26}.connection-badge{display:flex;align-items:center;gap:6px;font-size:11px;padding:4px 10px;border-radius:4px;font-weight:500}.connection-badge.connected{background:#22c55e33;color:#22c55e}.connection-badge.connecting{background:#fbbf2433;color:#fbbf24}.connection-badge.disconnected{background:#6b728033;color:#9ca3af}.connection-badge.error{background:#ef444433;color:#ef4444}.header-disconnect{background:#ef444433;border:1px solid rgba(239,68,68,.3);color:#ef4444;width:28px;height:28px;border-radius:6px;font-size:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}.header-disconnect:hover{background:#ef44444d;border-color:#ef444480}.error-toast{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background:#ef4444f2;color:#fff;padding:12px 24px;border-radius:8px;font-size:14px;z-index:1100;animation:toast-in .3s ease-out}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.app-container.signal-lost .main-content{filter:grayscale(1) brightness(.4);pointer-events:none}.app-container.signal-lost .filter-controls{opacity:.3;pointer-events:none}.signal-lost-overlay{position:fixed;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;z-index:800;pointer-events:none}.signal-lost-content{text-align:center;pointer-events:auto}.signal-lost-icon{font-size:64px;color:var(--planet-critical);margin-bottom:16px;animation:signal-pulse 2s ease-in-out infinite;text-shadow:0 0 40px var(--planet-critical)}.signal-lost-text{font-size:48px;font-weight:700;letter-spacing:12px;color:var(--planet-critical);text-shadow:0 0 20px var(--planet-critical),0 0 40px rgba(239,68,68,.5),0 0 60px rgba(239,68,68,.3);animation:signal-flicker 3s ease-in-out infinite;margin-bottom:12px}.signal-lost-subtext{font-size:14px;color:var(--text-muted);letter-spacing:2px;text-transform:uppercase;margin-bottom:32px}.signal-lost-btn{background:#ef444433;border:1px solid rgba(239,68,68,.4);color:var(--planet-critical);padding:12px 32px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;letter-spacing:1px}.signal-lost-btn:hover{background:#ef44444d;border-color:#ef444499;box-shadow:0 0 20px #ef44444d}@keyframes signal-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.95)}}@keyframes signal-flicker{0%,to{opacity:1}10%{opacity:.8}20%{opacity:1}30%{opacity:.9}40%{opacity:1}50%{opacity:.7}60%{opacity:1}70%{opacity:.85}80%{opacity:1}90%{opacity:.75}}.stream-ended-overlay{position:fixed;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;z-index:800;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.stream-ended-content{text-align:center;padding:48px}.stream-ended-icon{font-size:64px;color:#10b981;margin-bottom:16px;text-shadow:0 0 40px rgba(16,185,129,.5)}.stream-ended-text{font-size:42px;font-weight:700;letter-spacing:8px;color:#10b981;text-shadow:0 0 20px rgba(16,185,129,.5),0 0 40px rgba(16,185,129,.3);margin-bottom:12px}.stream-ended-subtext{font-size:14px;color:var(--text-secondary);letter-spacing:1px;margin-bottom:32px}.stream-ended-btn{background:#10b98133;border:1px solid rgba(16,185,129,.4);color:#10b981;padding:12px 32px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;letter-spacing:1px}.stream-ended-btn:hover{background:#10b9814d;border-color:#10b98199;box-shadow:0 0 20px #10b9814d}.playback-bar{position:fixed;bottom:0;left:0;right:0;height:56px;background:linear-gradient(to top,#0a0c10fa,#0a0c10f2);border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:16px;padding:0 20px;z-index:500;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.playback-controls{display:flex;align-items:center;gap:4px}.playback-btn{width:36px;height:36px;border:none;background:#ffffff0f;border-radius:8px;color:var(--text-secondary);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.playback-btn:hover:not(:disabled){background:#ffffff1f;color:var(--text-primary)}.playback-btn:disabled{opacity:.3;cursor:not-allowed}.playback-btn-main{width:44px;height:44px;background:var(--accent-primary);color:#fff;font-size:16px;border-radius:50%}.playback-btn-main:hover:not(:disabled){background:var(--accent-primary);filter:brightness(1.1);box-shadow:0 0 20px #60a5fa66}.playback-scrubber{flex:1;height:32px;display:flex;align-items:center;cursor:pointer}.playback-track{position:relative;width:100%;height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden}.playback-progress{position:absolute;top:0;left:0;height:100%;background:var(--accent-primary);border-radius:3px;pointer-events:none}.playback-slider{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer;margin:0}.playback-time{display:flex;align-items:baseline;gap:4px;font-family:SF Mono,Monaco,monospace;font-size:13px;min-width:140px}.playback-current{color:var(--text-primary);font-weight:500}.playback-separator{color:var(--text-muted)}.playback-total{color:var(--text-secondary)}.playback-speed{display:flex;align-items:center;gap:2px}.playback-speed-btn{padding:6px 10px;border:none;background:transparent;color:var(--text-muted);font-size:12px;font-weight:500;cursor:pointer;border-radius:4px;transition:all .15s}.playback-speed-btn:hover{background:#ffffff14;color:var(--text-secondary)}.playback-speed-btn.active{background:#60a5fa33;color:var(--accent-primary)}.app-footer{position:fixed;bottom:0;left:0;right:0;height:24px;background:#000c;border-top:1px solid rgba(255,255,255,.05);display:flex;align-items:center;justify-content:space-between;padding:0 16px;font-size:10px;color:var(--text-muted);z-index:50;pointer-events:none}.footer-copyright{opacity:.7}.footer-version{font-family:SF Mono,Monaco,monospace;opacity:.7}.header-view-toggle{display:flex;align-items:center;gap:2px;background:#0000004d;border-radius:6px;padding:2px}.view-toggle-btn{display:flex;align-items:center;justify-content:center;width:36px;height:32px;background:transparent;border:none;border-radius:4px;color:var(--text-muted);cursor:pointer;transition:all .15s}.view-toggle-btn:hover{background:#ffffff1a;color:var(--text-secondary)}.view-toggle-btn.active{background:#ffffff1f;color:var(--accent-primary)}.system-table-container{width:100%;height:100%;overflow:auto;background:#020617;padding:16px 20px}.col-sector{width:44px}.sector-name-cell{background:#ffffff08;border-right:2px solid rgba(255,255,255,.08)!important;vertical-align:middle;text-align:center;padding:8px 4px!important}.sector-label-text{writing-mode:vertical-lr;transform:rotate(180deg);font-size:12px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--text-secondary);white-space:nowrap;-webkit-user-select:none;user-select:none}.sector-spacer td{height:24px;background:#020617;border:none!important;padding:0!important}.col-system{width:100px}.col-node{width:120px}.col-role{width:80px}.col-stock{width:58px}.col-price,.col-rate{width:48px}.col-agents{width:50px}.col-strategy{width:100px}.system-name-cell{font-size:12px;font-weight:700;color:var(--text-primary);letter-spacing:.3px;vertical-align:top;padding-top:8px!important;border-right:1px solid rgba(255,255,255,.06)}.system-first-row td{border-top:1px solid rgba(255,255,255,.08)}.system-table tbody tr:first-child td{border-top:none}.system-table{width:100%;border-collapse:collapse;font-family:SF Mono,Monaco,Courier New,monospace;font-size:12px;table-layout:fixed}.system-table th{color:var(--text-muted);font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:6px 10px;text-align:left;border-bottom:1px solid rgba(255,255,255,.08);white-space:nowrap;background:#0a0a0f;overflow:hidden;position:sticky;top:0;z-index:10}.system-table th.th-center{text-align:center}.system-table th.th-right{text-align:right}.system-table th.th-group{text-align:center;font-size:10px;letter-spacing:1px;border-bottom:1px solid rgba(255,255,255,.12);background:#0f0f14}.system-table th.th-sub{font-size:9px;color:var(--text-secondary);padding:4px 10px;top:29px;background:#0a0a0f}.system-table td{padding:6px 10px;border-bottom:1px solid rgba(255,255,255,.03);vertical-align:middle;overflow:hidden;text-overflow:ellipsis}.system-table tbody tr:last-child td{border-bottom:none}.system-table-row{cursor:pointer;transition:background .1s}.system-table-row:nth-child(2n){background:#ffffff05}.system-table-row:hover{background:#ffffff0f}.system-table-row.hub-row{background:#fbbf240a}.system-table-row.hub-row:hover{background:#fbbf2417}.node-name-cell{border-left:3px solid transparent;display:flex;align-items:center;gap:6px}.node-name{color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hub-badge{font-size:8px;font-weight:700;padding:1px 4px;border-radius:2px;background:#fbbf2440;color:#fbbf24;letter-spacing:.5px;flex-shrink:0}.refinery-indicator{font-size:9px;font-weight:700;width:14px;height:14px;display:inline-flex;align-items:center;justify-content:center;border-radius:2px;background:#22d3ee33;color:#22d3ee;flex-shrink:0}.role-cell{white-space:nowrap;overflow:hidden}.role-badge-table{font-size:10px;font-weight:500;padding:2px 6px;border-radius:3px;background:#94a3b826;color:#94a3b8;display:inline-block}.role-badge-table.hub{background:#fbbf2426;color:#fbbf24}.role-badge-table.refinery{background:#22d3ee26;color:#22d3ee}.role-badge-table.consumer{background:#f8717126;color:#f87171}.role-badge-table.producer{background:#4ade8026;color:#4ade80}.role-badge-table.mixed{background:#94a3b826;color:#94a3b8}.role-badge-table.outpost{background:#64748b26;color:#64748b}.stock-cell{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}.stock-cell.stock-warning{background:#fbbf2414}.stock-cell.stock-critical{background:#f43f5e1f}.rate-cell{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap;font-size:11px}.rate-none{color:var(--text-muted);opacity:.3}.price-cell{text-align:right;color:var(--text-secondary);font-variant-numeric:tabular-nums;white-space:nowrap}.agents-cell{text-align:center}.agent-count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:18px;padding:0 5px;border-radius:9px;background:#4ade8033;color:#4ade80;font-size:11px;font-weight:600}.agent-count-zero{color:var(--text-muted);opacity:.4}.strategy-cell{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.strategy-label{font-size:10px;color:#a78bfa;cursor:help}.strategy-none{color:var(--text-muted);opacity:.3}.mobile-notice,.detail-drawer-handle{display:none}@media (max-width: 768px){:root{--header-height: 48px;--panel-width: 100%}.mobile-notice{display:block;text-align:center;padding:6px 16px;font-size:11px;color:var(--text-secondary);background:#ffffff0f;border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0}.header-bar{padding:0 12px}.header-left{gap:8px}.header-logo{font-size:14px}.header-simid{font-size:11px;padding:2px 6px}.header-right{gap:10px}.header-planet-dots{display:none}.header-planet-counts{gap:6px}.planet-count,.header-agents{font-size:11px}.header-view-toggle{gap:1px}.view-toggle-btn{width:32px;height:28px}.detail-panel{top:auto;right:0;bottom:0;left:0;width:100%;height:50vh;max-height:60vh;border-left:none;border-top:1px solid rgba(255,255,255,.1);border-radius:16px 16px 0 0;animation:slide-up .25s ease-out}@keyframes slide-up{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.detail-drawer-handle{display:block;width:36px;height:4px;background:#ffffff4d;border-radius:2px;margin:8px auto 0;flex-shrink:0}.detail-close{font-size:20px;padding:8px 12px;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.galaxy-inline-detail{display:none!important}.galaxy-legend{top:8px!important;left:8px!important;gap:2px!important}.galaxy-zoom-controls{bottom:24px!important;right:8px!important}.filter-controls{gap:12px;padding:8px 14px;bottom:16px}.filter-label{font-size:11px}.toggle-switch{width:36px;height:20px}.toggle-knob{width:16px;height:16px}.toggle-switch.on .toggle-knob{left:18px}.playback-bar{display:none!important}.system-table-container{padding:8px 12px;-webkit-overflow-scrolling:touch}.system-table{min-width:700px}}@media (max-width: 480px){:root{--header-height: 44px}.header-bar{padding:0 8px}.header-left{gap:6px;flex:1;min-width:0}.header-logo{font-size:12px;letter-spacing:0}.header-simid{display:none}.header-mode-controls{gap:1px;padding:1px}.header-mode-btn{padding:4px 8px;font-size:11px;gap:4px}.header-mode{font-size:10px;padding:3px 6px}.header-tick{font-size:11px}.header-view-toggle{display:none}.header-right{gap:6px}.header-planet-counts,.header-agents{display:none}.server-indicator{font-size:11px;padding:4px 6px}.connection-badge{font-size:10px;padding:3px 6px}.galaxy-legend{display:none!important}.galaxy-zoom-controls{bottom:16px!important;right:6px!important}.header-disconnect{width:36px;height:36px;font-size:14px}.detail-panel{height:55vh;max-height:70vh}.detail-body{padding:12px}.detail-planet-name,.detail-agent-name{font-size:16px}.filter-controls{gap:8px;padding:6px 10px;border-radius:12px;bottom:12px}.filter-toggle{gap:6px}.filter-label{font-size:10px}.toggle-switch{width:32px;height:18px}.toggle-knob{width:14px;height:14px}.toggle-switch.on .toggle-knob{left:16px}.system-table-container{padding:4px 8px}.system-table{min-width:600px;font-size:11px}.system-table .sector-name-cell{position:sticky;left:0;z-index:5;background:#0a0a0f}.mode-selector{width:100%;max-width:100vw;border-radius:0;padding:24px 16px}.signal-lost-text,.stream-ended-text{font-size:28px;letter-spacing:4px}.signal-lost-icon,.stream-ended-icon{font-size:48px}.error-toast{left:12px;right:12px;transform:none;text-align:center}}
