html,body,#root{height:100%;margin:0;padding:0}:root{--bg:#0f1115;--bg-panel:#1a1d24;--bg-panel-2:#232732;--fg:#e6e8eb;--fg-muted:#8b94a3;--accent:#60a5fa;--accent-fg:#0b1220;--danger:#f87171;--border:#2a2f3a}*{box-sizing:border-box}html,body,#root{background:var(--bg);height:100%;color:var(--fg);margin:0;padding:0;font-family:ui-sans-serif,system-ui,-apple-system,sans-serif}.app-shell{flex-direction:column;gap:12px;max-width:none;height:100vh;padding:12px;display:flex}.app-shell header{flex:none}.app-shell header h1{letter-spacing:.02em;margin:0;font-size:24px}.app-shell header .subtitle{color:var(--fg-muted);margin:4px 0 0;font-size:13px}.layout{grid-template-columns:minmax(var(--viewport-min-width,640px), 1fr) var(--splitter-width,6px) minmax(380px, var(--inspector-width,380px));flex:1 1 0;align-items:stretch;gap:12px;min-height:0;display:grid}.layout-left{flex-direction:column;min-width:0;min-height:0;display:flex}.viewport-surface{flex-direction:column;flex:1 1 0;min-width:0;min-height:0;display:flex;position:relative}.viewport-surface>.viewport{flex:1 1 0;min-height:0}.performance-overlay{z-index:10;border:1px solid var(--border);min-width:220px;max-width:260px;color:var(--fg);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);pointer-events:none;background:#0f1115d1;border-radius:8px;flex-direction:column;gap:8px;padding:10px 12px;font-family:ui-monospace,SFMono-Regular,monospace;font-size:11px;line-height:1.35;display:flex;position:absolute;top:12px;left:12px}.performance-overlay__controls{pointer-events:auto}.performance-overlay__header{justify-content:space-between;align-items:baseline;gap:8px;display:flex}.performance-overlay__title{text-transform:uppercase;letter-spacing:.08em;color:var(--fg-muted);font-size:10px}.performance-overlay__fps{color:var(--accent);font-size:12px}.performance-overlay__summary{grid-template-columns:repeat(4,1fr);gap:4px 6px;display:grid}.performance-overlay__cell{flex-direction:column;gap:1px;display:flex}.performance-overlay__cell-label{text-transform:uppercase;letter-spacing:.08em;color:var(--fg-muted);font-size:9px}.performance-overlay__cell-value{color:var(--fg);font-variant-numeric:tabular-nums;font-size:12px}.performance-overlay__sparkline{width:100%;height:30px;color:var(--accent);display:block}.performance-overlay__systems{border-collapse:collapse;width:100%;font-size:11px}.performance-overlay__systems td{vertical-align:baseline;padding:2px 0}.performance-overlay__sys-name{color:var(--fg-muted);white-space:nowrap;text-overflow:ellipsis;max-width:140px;padding-right:6px;overflow:hidden}.performance-overlay__sys-latest,.performance-overlay__sys-avg{text-align:right;font-variant-numeric:tabular-nums;color:var(--fg)}.performance-overlay__sys-avg{color:var(--fg-muted)}.performance-overlay__empty{color:var(--fg-muted);text-align:center;padding:6px 0}.performance-overlay__footnote{text-transform:uppercase;letter-spacing:.06em;color:var(--fg-muted);opacity:.75;margin:0;font-size:9px}.performance-panel{flex-direction:column;gap:10px;display:flex}.performance-panel-toggle{color:var(--fg);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;font-size:13px;display:flex}.performance-panel-toggle input[type=checkbox]{accent-color:var(--accent);cursor:pointer;width:15px;height:15px}.performance-panel-row{grid-template-columns:1fr 160px;align-items:center;gap:10px;display:grid}.performance-panel-row-label{color:var(--fg-muted);font-size:12px}.performance-panel-select{background:var(--bg-panel-2);color:var(--fg);border:1px solid var(--border);cursor:pointer;appearance:none;border-radius:6px;padding:5px 8px;font-family:ui-monospace,SFMono-Regular,monospace;font-size:12px}.performance-panel-select:disabled{opacity:.45;cursor:not-allowed}.performance-panel-hint{color:var(--fg-muted);opacity:.85;margin:0;font-size:11px}.debug-overlay-panel{flex-direction:column;gap:10px;display:flex}.debug-overlay-panel-toggle{color:var(--fg);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;font-size:13px;display:flex}.debug-overlay-panel-toggle input[type=checkbox]{accent-color:var(--accent);cursor:pointer;width:15px;height:15px}.debug-overlay-panel-row{grid-template-columns:1fr 160px;align-items:center;gap:10px;display:grid}.debug-overlay-panel-row-label{color:var(--fg-muted);font-size:12px}.debug-overlay-panel-select{background:var(--bg-panel-2);color:var(--fg);border:1px solid var(--border);cursor:pointer;appearance:none;border-radius:6px;padding:5px 8px;font-family:ui-monospace,SFMono-Regular,monospace;font-size:12px}.debug-overlay-panel-select:disabled{opacity:.45;cursor:not-allowed}.debug-overlay-panel-hint{color:var(--fg-muted);opacity:.85;margin:0;font-size:11px}.layout-right{flex-direction:column;gap:16px;min-width:0;height:100%;min-height:0;padding-right:4px;display:flex;overflow-y:auto}.layout-title{text-transform:uppercase;letter-spacing:.1em;color:var(--fg-muted);margin:0;font-size:12px}.layout-splitter{cursor:col-resize;z-index:2;touch-action:none;outline:none;justify-content:center;align-items:stretch;height:100%;margin:0 -4px;display:flex;position:relative}.layout-splitter-handle{background:var(--border);border-radius:1px;width:2px;height:100%;transition:background .12s}.layout-splitter:hover .layout-splitter-handle,.layout-splitter:focus-visible .layout-splitter-handle,body.layout-splitter-dragging .layout-splitter-handle{background:var(--accent)}.layout-splitter:focus-visible{outline:1px solid var(--accent);outline-offset:-1px}body.layout-splitter-dragging{cursor:col-resize;-webkit-user-select:none;user-select:none}.viewport{background:#000;height:100%;min-height:0;padding:0;position:relative;overflow:hidden}.viewport-header{z-index:5;pointer-events:none;justify-content:space-between;align-items:center;gap:12px;display:flex;position:absolute;top:12px;left:16px;right:16px}.viewport-header h2{pointer-events:auto;border:1px solid var(--border);text-transform:uppercase;letter-spacing:.08em;color:var(--fg-muted);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0f1115b8;border-radius:6px;margin:0;padding:4px 10px;font-size:12px}.viewport-camera-indicator{pointer-events:auto;border:1px solid var(--border);letter-spacing:.04em;color:var(--fg-muted);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0f1115b8;border-radius:6px;padding:4px 10px;font-family:ui-monospace,SFMono-Regular,monospace;font-size:11px}.viewport-key-hint{opacity:.6;margin-left:6px}.viewport-stage{background:#000;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.viewport-placeholder{color:#6b7280;letter-spacing:.04em;margin:0;font-family:ui-monospace,SFMono-Regular,monospace;font-size:14px}.three-viewport{background:#111118;display:block}.three-viewport>canvas{display:block;width:100%!important;height:100%!important}.phaser-viewport{background:#111118;display:block;overflow:hidden}.phaser-viewport>canvas{display:block;width:100%!important;height:100%!important}.renderer-picker{flex-direction:row;align-items:center;gap:10px;display:flex}.renderer-picker-label{color:var(--text-muted,#aaa);flex:none;font-size:.85rem}.renderer-picker select{background:var(--bg-panel-2);color:var(--fg);border:1px solid var(--border);cursor:pointer;border-radius:6px;flex:auto;padding:6px 10px;font-size:13px}.panel{background:var(--bg-panel);border:1px solid var(--border);border-radius:10px;padding:16px}.panel h2{text-transform:uppercase;letter-spacing:.08em;color:var(--fg-muted);margin:0 0 12px;font-size:14px}.control-buttons{flex-wrap:wrap;gap:8px;display:flex}.control-buttons button{background:var(--bg-panel-2);color:var(--fg);border:1px solid var(--border);cursor:pointer;border-radius:6px;padding:8px 14px;font-size:13px;transition:background .12s}.control-buttons button:hover:not(:disabled){background:var(--accent);color:var(--accent-fg);border-color:var(--accent)}.control-buttons button:disabled{opacity:.45;cursor:not-allowed}.simulation-control-panel{flex-direction:column;gap:12px;display:flex}.simulation-time-row{justify-content:flex-start;align-items:baseline;gap:12px;display:flex}.scenario-picker{flex-direction:column;gap:6px;margin-top:12px;display:flex}.control-panel .scenario-picker{margin-top:0}.scenario-picker-label{letter-spacing:.06em;text-transform:uppercase;color:var(--fg-muted);font-size:11px}.scenario-picker-row{align-items:stretch;gap:8px;display:flex}.scenario-picker-row select{background:var(--bg-panel-2);min-width:0;color:var(--fg);border:1px solid var(--border);cursor:pointer;border-radius:6px;flex:1;padding:7px 10px;font-size:13px}.scenario-picker-row select:disabled{opacity:.45;cursor:not-allowed}.scenario-picker-row button{background:var(--bg-panel-2);color:var(--fg);border:1px solid var(--border);cursor:pointer;border-radius:6px;flex:none;padding:7px 14px;font-size:13px;transition:background .12s}.scenario-picker-row button:hover:not(:disabled){background:var(--accent);color:var(--accent-fg);border-color:var(--accent)}.scenario-picker-row button:disabled{opacity:.45;cursor:not-allowed}.scenario-picker-record-label{color:var(--fg-muted);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:7px;margin-top:8px;font-size:12px;display:flex}.scenario-picker-record-label input[type=checkbox]{accent-color:var(--accent);cursor:pointer;flex-shrink:0;width:13px;height:13px}.scenario-picker-row--upload{margin-top:6px}.scenario-picker-row--upload button{flex:1}.scenario-editor-panel{flex-direction:column;gap:10px;display:flex}.scenario-editor-header{justify-content:space-between;align-items:center;gap:8px;display:flex}.scenario-editor-header h2{margin:0}.scenario-editor-expand-button{background:var(--bg-panel-2);width:26px;height:26px;color:var(--fg-muted);border:1px solid var(--border);cursor:pointer;border-radius:6px;flex:none;justify-content:center;align-items:center;padding:0;font-size:14px;line-height:1;transition:background .12s,color .12s,border-color .12s;display:inline-flex}.scenario-editor-expand-button:hover:not(:disabled),.scenario-editor-expand-button:focus-visible{background:var(--accent);color:var(--accent-fg);border-color:var(--accent);outline:none}.scenario-editor-expand-button:disabled{opacity:.4;cursor:not-allowed}.scenario-editor-empty{color:var(--fg-muted);margin:0;font-size:12px}.scenario-editor-preview-shell{flex-direction:column;height:240px;display:flex}.scenario-editor-preview-shell--hidden{display:none}.scenario-editor-preview-toolbar{background:var(--bg-panel-2);border:1px solid var(--border);border-bottom:0;border-radius:6px 6px 0 0;align-items:center;gap:8px;padding:4px 6px;display:flex}.scenario-editor-preview-file-name{text-overflow:ellipsis;white-space:nowrap;min-width:0;color:var(--fg-muted);flex:auto;font-family:ui-monospace,SFMono-Regular,monospace;font-size:12px;overflow:hidden}.scenario-editor-file-name-editor{flex:auto;align-items:center;gap:0;min-width:0;font-family:ui-monospace,SFMono-Regular,monospace;display:flex}.scenario-editor-file-name-input{background:var(--bg-panel);min-width:0;height:24px;color:var(--fg);border:1px solid var(--border);font:inherit;border-radius:6px 0 0 6px;flex:auto;padding:0 6px;font-size:12px}.scenario-editor-file-name-input:focus{border-color:var(--accent);outline:none}.scenario-editor-file-name-extension{height:24px;color:var(--fg-muted);background:var(--bg-panel);border:1px solid var(--border);border-left:0;border-radius:0 6px 6px 0;flex:none;align-items:center;padding:0 6px;font-size:12px;display:inline-flex}.scenario-editor-download-button,.scenario-editor-file-name-edit-button,.scenario-editor-copy-button{background:var(--bg-panel-2);width:26px;height:26px;color:var(--fg-muted);border:1px solid var(--border);cursor:pointer;border-radius:6px;flex:none;justify-content:center;align-items:center;padding:0;transition:background .12s,color .12s,border-color .12s;display:inline-flex}.scenario-editor-file-name-edit-button{margin-left:auto}.scenario-editor-download-button:disabled{opacity:.45;cursor:not-allowed}.scenario-editor-download-button:hover:not(:disabled),.scenario-editor-download-button:focus-visible:not(:disabled),.scenario-editor-file-name-edit-button:hover,.scenario-editor-file-name-edit-button:focus-visible,.scenario-editor-copy-button:hover{background:var(--accent);color:var(--accent-fg);border-color:var(--accent);outline:none}.scenario-editor-preview-shell .scenario-editor-preview{flex:auto;height:auto;min-height:0}.scenario-editor-preview-shell--with-toolbar .scenario-editor-preview{border-radius:0 0 6px 6px}.scenario-editor-preview,.scenario-editor-textarea{background:var(--bg-panel-2);color:var(--fg);border:1px solid var(--border);border-radius:6px;height:240px;padding:8px 10px;font-family:ui-monospace,SFMono-Regular,monospace;font-size:12px;line-height:1.4;overflow:auto}.scenario-editor-panel--expanded{flex:auto;min-height:0}.scenario-editor-panel--expanded .scenario-editor-preview-shell,.scenario-editor-panel--expanded .scenario-editor-preview,.scenario-editor-panel--expanded .scenario-editor-textarea{flex:auto;height:auto;min-height:0;max-height:none}.scenario-editor-preview{white-space:pre-wrap;overflow-wrap:anywhere;word-break:break-word;margin:0}.scenario-editor-textarea{resize:vertical;width:100%}.scenario-editor-actions{flex-wrap:wrap;gap:8px;display:flex}.scenario-editor-actions button{background:var(--bg-panel-2);color:var(--fg);border:1px solid var(--border);cursor:pointer;border-radius:6px;padding:7px 14px;font-size:13px;transition:background .12s}.scenario-editor-actions button:hover:not(:disabled){background:var(--accent);color:var(--accent-fg);border-color:var(--accent)}.scenario-editor-actions button:disabled{opacity:.45;cursor:not-allowed}.scenario-editor-actions .scenario-editor-copy-button{justify-content:center;align-items:center;width:32px;min-width:32px;height:32px;padding:0}.scenario-editor-hint{color:var(--fg-muted);opacity:.85;margin:0;font-size:11px}.scenario-picker-row--save{flex-wrap:wrap;gap:6px 10px;margin-top:8px}.scenario-picker-save-hint{color:var(--fg-muted);opacity:.85;flex-basis:100%;font-size:11px}.error{color:var(--danger);margin:12px 0 0;font-size:13px}.time-value{margin:0;font-family:ui-monospace,SFMono-Regular,monospace;font-size:26px}.metrics{grid-template-columns:1fr 1fr;gap:12px;margin:0;display:grid}.metrics div{flex-direction:column;display:flex}.metrics dt{text-transform:uppercase;letter-spacing:.08em;color:var(--fg-muted);font-size:11px}.metrics dd{margin:2px 0 0;font-family:ui-monospace,SFMono-Regular,monospace;font-size:16px}.entity-table{border-collapse:collapse;width:100%;font-family:ui-monospace,SFMono-Regular,monospace;font-size:12px}.entity-table th,.entity-table td{text-align:left;border-bottom:1px solid var(--border);padding:6px 8px}.entity-table th{color:var(--fg-muted);text-transform:uppercase;letter-spacing:.06em;font-size:11px;font-weight:500}.entity-table td{color:var(--fg)}.empty{color:var(--fg-muted);margin:0;font-size:13px}.renderer-settings-grid{grid-template-columns:1fr;gap:8px;display:grid}.renderer-settings-row{color:var(--fg);grid-template-columns:1fr 130px;align-items:center;gap:10px;font-size:12px;display:grid}.renderer-settings-row>span{color:var(--fg-muted);align-items:center;gap:8px;display:flex}.renderer-settings-row--checkbox{grid-template-columns:auto 1fr}.renderer-settings-row--checkbox>span{color:var(--fg);order:2;font-size:13px}.renderer-settings-row input[type=number],.renderer-settings-row input[type=range],.renderer-settings-row input[type=text],.renderer-settings-row select{background:var(--bg-panel-2);width:100%;color:var(--fg);border:1px solid var(--border);border-radius:6px;padding:5px 8px;font-family:ui-monospace,SFMono-Regular,monospace;font-size:12px}.renderer-settings-row select{cursor:pointer;appearance:none}.renderer-settings-row input[type=range]{height:26px;padding:0}.renderer-settings-row input[type=color]{background:var(--bg-panel-2);border:1px solid var(--border);cursor:pointer;border-radius:6px;width:100%;height:28px;padding:2px}.renderer-settings-row input[type=checkbox]{accent-color:var(--accent);cursor:pointer;width:16px;height:16px}.renderer-settings-value{color:var(--fg);font-family:ui-monospace,SFMono-Regular,monospace;font-size:11px}.renderer-settings-hint{text-transform:uppercase;letter-spacing:.06em;color:var(--fg-muted);opacity:.7;font-size:10px}.renderer-settings-actions{gap:8px;margin-top:12px;display:flex}.renderer-settings-actions button{background:var(--bg-panel-2);color:var(--fg);border:1px solid var(--border);cursor:pointer;border-radius:6px;padding:7px 14px;font-size:13px;transition:background .12s}.renderer-settings-actions button:hover{background:var(--accent);color:var(--accent-fg);border-color:var(--accent)}.replay-timeline{margin-top:8px;padding:10px 14px}.replay-timeline-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.replay-timeline-btn{background:var(--bg-panel-2);color:var(--fg);border:1px solid var(--border);cursor:pointer;border-radius:6px;padding:6px 12px;font-size:12px;transition:background .12s}.replay-timeline-btn:hover:not(:disabled){background:var(--accent);color:var(--accent-fg);border-color:var(--accent)}.replay-timeline-btn:disabled{opacity:.4;cursor:not-allowed}.replay-timeline-btn--primary{font-weight:600}.replay-timeline-btn--exit{margin-left:auto}.replay-timeline-slider{flex:220px;min-width:180px}.replay-timeline-time,.replay-timeline-frame{font-variant-numeric:tabular-nums;color:var(--fg-muted);font-size:12px}.replay-timeline-speed{align-items:center;gap:6px;display:flex}.replay-timeline-speed-label{text-transform:uppercase;letter-spacing:.06em;color:var(--fg-muted);font-size:11px}.replay-timeline-speed select{background:var(--bg-panel-2);color:var(--fg);border:1px solid var(--border);border-radius:4px;padding:3px 6px;font-size:12px}@media (width<=700px){.app-shell{height:auto;min-height:100vh}.layout{flex-direction:column;flex:none;min-height:0;display:flex}.layout-splitter{display:none}.layout-left{flex:none}.viewport-surface{flex:none;height:60vh;min-height:320px}.viewport{height:100%;min-height:0}.layout-right{height:auto;overflow-y:visible}}.connection-status-panel{flex-direction:column;gap:10px;display:flex}.connection-status-control{grid-template-columns:110px 1fr;align-items:center;gap:10px;display:grid}.connection-status-control-label{color:var(--fg-muted);font-size:12px}.connection-status-select,.connection-status-input{background:var(--bg-panel-2);width:100%;color:var(--fg);border:1px solid var(--border);border-radius:6px;padding:6px 8px;font-family:ui-monospace,SFMono-Regular,monospace;font-size:12px}.connection-status-select{cursor:pointer;appearance:none}.connection-status-select option{padding:4px 1.6em}.connection-status-input::placeholder{color:var(--fg-muted);opacity:.7}.connection-status-input:focus,.connection-status-select:focus{outline:1px solid var(--accent);outline-offset:-1px;border-color:var(--accent)}.connection-status-row{align-items:center;gap:8px;font-size:13px;display:flex}.connection-status-dot{background:var(--fg-muted);border-radius:50%;flex:none;width:10px;height:10px;box-shadow:0 0 0 2px #00000040}.connection-status-dot-disabled{background:#4a5160}.connection-status-dot-disconnected{background:var(--fg-muted)}.connection-status-dot-connecting{background:#fbbf24;animation:1.2s ease-in-out infinite connection-status-pulse}.connection-status-dot-connected{background:#34d399}.connection-status-dot-error{background:var(--danger)}@keyframes connection-status-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.35)}}.connection-status-label{color:var(--fg);font-weight:500}.connection-status-target{color:var(--fg-muted);background:var(--bg-panel-2);text-overflow:ellipsis;white-space:nowrap;border-radius:4px;max-width:100%;margin-left:auto;padding:1px 6px;font-size:11px;overflow:hidden}.connection-status-error{color:var(--danger);word-break:break-word;margin:0;font-size:12px}.connection-status-hint{color:var(--fg-muted);margin:0;font-size:12px;line-height:1.4}.connection-status-hint code{background:var(--bg-panel-2);color:var(--fg);border-radius:4px;padding:1px 5px}.ros2-topics-panel{flex-direction:column;gap:8px;display:flex}.ros2-topics-header{justify-content:space-between;align-items:center;gap:8px;display:flex}.ros2-topics-header h2{margin:0}.ros2-topics-expand-button{background:var(--bg-panel-2);width:26px;height:26px;color:var(--fg-muted);border:1px solid var(--border);cursor:pointer;border-radius:6px;flex:none;justify-content:center;align-items:center;padding:0;font-size:14px;line-height:1;transition:background .12s,color .12s,border-color .12s;display:inline-flex}.ros2-topics-expand-button:hover,.ros2-topics-expand-button:focus-visible{background:var(--accent);color:var(--accent-fg);border-color:var(--accent);outline:none}.ros2-topics-panel--expanded .ros2-topics-list{max-height:50vh}.ros2-topics-summary{align-items:center;gap:8px;display:flex}.ros2-topics-count{color:var(--fg);flex:auto;font-size:13px;font-weight:500}.ros2-topics-refresh{background:var(--bg-panel-2);color:var(--fg);border:1px solid var(--border);cursor:pointer;border-radius:6px;flex:none;padding:4px 10px;font-size:12px}.ros2-topics-refresh:hover:not(:disabled){border-color:var(--accent)}.ros2-topics-refresh:disabled{opacity:.55;cursor:progress}.ros2-topics-meta{color:var(--fg-muted);margin:0;font-size:11px}.ros2-topics-meta span{color:var(--fg);font-family:ui-monospace,SFMono-Regular,monospace}.ros2-topics-error{color:var(--danger);word-break:break-word;margin:0;font-size:12px}.ros2-topics-controls{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.ros2-topics-panel>.ros2-topics-system-toggle{margin-left:2px}.ros2-topics-toggle{color:var(--accent);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:6px;padding:3px 10px;font-size:12px}.ros2-topics-toggle:hover{border-color:var(--accent)}.ros2-topics-system-toggle{color:var(--fg-muted);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:6px;font-size:12px;display:inline-flex}.ros2-topics-system-toggle input{accent-color:var(--accent);cursor:pointer}.ros2-topics-list{background:var(--bg-panel-2);border:1px solid var(--border);border-radius:6px;flex-direction:column;gap:2px;max-height:220px;margin:0;padding:4px;font-family:ui-monospace,SFMono-Regular,monospace;font-size:11px;list-style:none;display:flex;overflow-y:auto}.ros2-topics-empty{text-align:center;color:var(--fg-muted);padding:8px;font-style:italic}.ros2-topics-row{border-radius:4px;grid-template-columns:auto auto minmax(0,1.2fr) minmax(0,1fr) auto;align-items:center;gap:8px;padding:4px 6px;display:grid}.ros2-topics-row:hover{background:#ffffff0a}.ros2-topics-name{color:var(--fg);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.ros2-topics-type{color:var(--fg-muted);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.ros2-topics-twist-vehicle{color:var(--fg);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:4px;max-width:110px;padding:1px 6px;font-size:11px}.ros2-topics-twist-vehicle:disabled{opacity:.55;cursor:not-allowed}.ros2-topics-action{color:var(--fg-muted);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:4px;padding:1px 8px;font-size:11px}.ros2-topics-action:not(:disabled):hover{background:var(--accent);color:var(--accent-fg);border-color:var(--accent)}.ros2-topics-action:disabled{opacity:.55;cursor:not-allowed}.ros2-topics-render-checkbox{cursor:pointer;flex-shrink:0;margin:0}.ros2-topics-render-checkbox:disabled{cursor:not-allowed;opacity:.55}.ros2-topics-chevron{width:20px;height:20px;color:var(--fg-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:10px;display:inline-flex}.ros2-topics-chevron:hover{color:var(--fg);background:#ffffff14}.ros2-topics-chevron--disabled,.ros2-topics-chevron:disabled{opacity:.3;cursor:default}.ros2-topics-settings{flex-direction:column;grid-column:1/-1;align-items:flex-start;gap:2px;padding:2px 6px 2px 24px;display:flex}.ros2-topics-settings--inactive{opacity:.5;pointer-events:none}.ros2-topics-settings-row{align-items:center;gap:6px;display:inline-flex}.ros2-topics-settings-hint{color:var(--fg-muted);margin:0;font-size:11px}.ros2-topics-settings-row>label{color:var(--fg);white-space:nowrap;font-size:11px}.ros2-topics-color-group{align-items:center;gap:6px;display:inline-flex}.ros2-topics-color-picker{border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:3px;width:20px;height:20px;padding:0}.ros2-topics-color-hex{border:1px solid var(--border);background:var(--bg-panel-2);width:72px;color:var(--fg);border-radius:3px;padding:1px 4px;font-family:inherit;font-size:11px}.ros2-topics-color-hex:focus{outline:1px solid var(--accent);border-color:var(--accent)}.ros2-topics-color-hex--invalid{border-color:var(--danger)}.ros2-topics-color-hex--invalid:focus{outline-color:var(--danger);border-color:var(--danger)}.ros2-topics-thickness-group,.ros2-topics-vehicle-group{align-items:center;gap:6px;display:inline-flex}.ros2-topics-thickness-input{border:1px solid var(--border);background:var(--bg-panel-2);width:56px;color:var(--fg);font-variant-numeric:tabular-nums;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;border-radius:3px;padding:1px 4px;font-family:inherit;font-size:11px}.ros2-topics-thickness-input:focus{outline:1px solid var(--accent);border-color:var(--accent)}.echo-card{flex-direction:column;gap:8px;display:flex}.echo-card-header{justify-content:space-between;align-items:center;gap:8px;display:flex}.echo-card-title{color:var(--fg);text-overflow:ellipsis;white-space:nowrap;margin:0;font-family:ui-monospace,SFMono-Regular,monospace;font-size:14px;font-weight:600;overflow:hidden}.echo-card-actions{align-items:center;gap:6px;display:flex}.echo-card-actions button{background:var(--bg-panel-2);color:var(--fg);border:1px solid var(--border);cursor:pointer;border-radius:6px;padding:3px 10px;font-size:12px}.echo-card-actions button:hover:not(:disabled){background:var(--accent);color:var(--accent-fg);border-color:var(--accent)}.echo-card-actions button:disabled{opacity:.55;cursor:not-allowed}.echo-card-close{background:var(--bg-panel-2);width:26px;height:26px;color:var(--fg-muted);border:1px solid var(--border);cursor:pointer;border-radius:6px;flex:none;justify-content:center;align-items:center;padding:0;font-size:16px;line-height:1;transition:background .12s,color .12s,border-color .12s;display:inline-flex}.echo-card-close:hover,.echo-card-close:focus-visible{background:var(--accent);color:var(--accent-fg);border-color:var(--accent);outline:none}.echo-card-meta{grid-template-columns:max-content 1fr;gap:4px 10px;margin:0;font-size:12px;display:grid}.echo-card-meta dt{color:var(--fg-muted)}.echo-card-meta dd{color:var(--fg);text-overflow:ellipsis;white-space:nowrap;margin:0;font-family:ui-monospace,SFMono-Regular,monospace;overflow:hidden}.echo-card-meta dd code{background:var(--bg-panel-2);border-radius:4px;padding:1px 5px}.echo-card-status{text-transform:uppercase;letter-spacing:.04em;font-size:11px;font-weight:600}.echo-card-status-listening{color:#34d399}.echo-card-status-stopped{color:var(--fg-muted)}.echo-card-status-error{color:var(--danger)}.echo-card-error{color:var(--danger);word-break:break-word;margin:0;font-size:12px}.json-tree-view{background:var(--bg-panel-2);border:1px solid var(--border);color:var(--fg);border-radius:6px;max-height:240px;margin:0;font-family:ui-monospace,SFMono-Regular,monospace;font-size:11px;line-height:1.4;overflow:auto}.json-tree-toolbar{z-index:1;background:var(--bg-panel-2);border-bottom:1px solid var(--border);gap:6px;padding:8px 10px;display:flex;position:sticky;top:0}.json-tree-toolbar button{background:var(--bg-panel);color:var(--fg);border:1px solid var(--border);cursor:pointer;border-radius:6px;padding:3px 8px;font-size:11px}.json-tree-toolbar button:hover:not(:disabled){background:var(--accent);color:var(--accent-fg);border-color:var(--accent)}.json-tree-toolbar button:disabled{opacity:.55;cursor:not-allowed}.json-tree-body{min-width:max-content;padding:8px 10px}.json-tree-row{width:100%;min-height:20px;color:var(--fg);grid-template-columns:18px minmax(70px,max-content) max-content;align-items:baseline;gap:8px;display:grid}.json-tree-row-button{appearance:none;font:inherit;text-align:left;cursor:pointer;background:0 0;border:0}.json-tree-row-button:hover,.json-tree-row-button:focus-visible{background:#ffffff0d;outline:none}.json-tree-caret,.json-tree-spacer{width:14px;color:var(--fg-muted);justify-content:center;display:inline-flex}.json-tree-key{color:var(--fg);overflow-wrap:anywhere}.json-tree-value{color:#93c5fd;overflow-wrap:anywhere}.json-tree-summary{color:var(--fg-muted)}.json-tree-bracket{color:var(--fg-muted);grid-template-columns:18px max-content}.echo-card-waiting{background:var(--bg-panel-2);border:1px dashed var(--border);text-align:center;color:var(--fg-muted);border-radius:6px;margin:0;padding:12px 10px;font-size:12px;font-style:italic}
