:root{--bg: #0a0c10;--surface: #14171d;--surface-2: #1a1e26;--border: rgba(255, 255, 255, .08);--border-strong: rgba(255, 255, 255, .16);--text: #e6e8ec;--text-muted: #8b909a;--accent: #3b82f6;--accent-hover: #60a5fa;--accent-weak: rgba(59, 130, 246, .16);--danger: #ef4444;--ok: #22c55e;--radius: 8px;--radius-sm: 6px;--tbar-h: 52px;--panel-w: 280px}*{margin:0;padding:0;box-sizing:border-box}html,body,#app{height:100%}body{font-family:Fira Sans,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);overflow:hidden;-webkit-font-smoothing:antialiased}svg{width:1em;height:1em;display:block}#toolbar{position:fixed;inset:0 0 auto 0;height:var(--tbar-h);display:flex;align-items:center;gap:12px;padding:0 14px;background:var(--surface);border-bottom:1px solid var(--border);z-index:30}.brand{display:flex;align-items:center;gap:8px;font-weight:600;font-size:15px;letter-spacing:.2px}.brand-mark{color:var(--accent);font-size:20px}.tbar-divider{width:1px;height:22px;background:var(--border)}.tbar-spacer{flex:1}.btn{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;border:1px solid transparent;transition:background .16s ease,border-color .16s ease,color .16s ease;-webkit-user-select:none;user-select:none}.btn svg{font-size:16px}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:focus-visible{outline:2px solid var(--accent-hover);outline-offset:2px}.status{font-family:Fira Code,monospace;font-size:12px;color:var(--text-muted);padding:5px 10px;border-radius:999px;border:1px solid var(--border);background:var(--surface-2);max-width:360px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status.loading{color:var(--accent-hover);border-color:var(--accent-weak)}.status.ok{color:var(--ok)}.status.error{color:var(--danger);border-color:#ef44444d}#panel{position:fixed;top:var(--tbar-h);left:0;bottom:0;width:var(--panel-w);background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:20}.panel-head{display:flex;align-items:center;gap:8px;padding:12px 14px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);border-bottom:1px solid var(--border)}.panel-head svg{font-size:15px}.panel-body{flex:1;overflow-y:auto;padding:6px 0}.panel-empty{padding:28px 16px;text-align:center;font-size:12px;line-height:1.6;color:var(--text-muted)}.tree-node{display:flex;align-items:center;gap:7px;padding:5px 10px;font-size:13px;cursor:pointer;white-space:nowrap;overflow:hidden;border-radius:var(--radius-sm);margin:0 6px;transition:background .13s ease}.tree-icon{color:var(--text-muted);font-size:15px;flex-shrink:0}.tree-label{overflow:hidden;text-overflow:ellipsis}.tree-node:hover{background:#ffffff0d}.tree-node.selected{background:var(--accent-weak);color:#fff}.tree-node.selected .tree-icon{color:var(--accent-hover)}#viewport{position:fixed;inset:var(--tbar-h) 0 0 var(--panel-w);background:radial-gradient(circle at 50% 38%,#14171d 0%,var(--bg) 80%)}#viewport canvas{display:block}#viewport.drag-over:after{content:"";position:absolute;top:12px;right:12px;bottom:12px;left:12px;border:2px dashed var(--accent);border-radius:12px;background:var(--accent-weak);pointer-events:none}.empty{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;pointer-events:none;text-align:center}.empty-icon{font-size:56px;color:var(--border-strong)}.empty-title{font-size:17px;font-weight:600}.empty-sub{font-size:13px;color:var(--text-muted)}.panel-body::-webkit-scrollbar{width:10px}.panel-body::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:6px;border:3px solid var(--surface)}.tree-chevron{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;flex-shrink:0;color:var(--text-muted);font-size:14px;cursor:pointer;transform:rotate(90deg);transition:transform .13s ease,color .13s ease}.tree-item.collapsed>.tree-node .tree-chevron{transform:rotate(0)}.tree-chevron:hover{color:var(--text)}.tree-chevron.leaf{visibility:hidden;cursor:default}.tree-item.collapsed>.tree-children{display:none}.loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;align-items:center;justify-content:center;background:#0a0c109e;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.loading-overlay[hidden]{display:none}.loading-card{display:flex;flex-direction:column;align-items:center;gap:12px;padding:28px 36px;min-width:240px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius)}.spinner{width:36px;height:36px;border-radius:50%;border:3px solid var(--border-strong);border-top-color:var(--accent);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-name{font-size:14px;font-weight:600;max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.loading-step{font-family:Fira Code,monospace;font-size:12px;color:var(--accent-hover)}.loading-time{font-family:Fira Code,monospace;font-size:11px;color:var(--text-muted)}.annotation{position:absolute;left:0;top:0;transform:translate(-50%,calc(-100% - 14px));background:#14171eeb;border:1px solid var(--border-strong);border-radius:8px;padding:9px 11px;min-width:150px;font-size:12px;color:var(--text);pointer-events:auto;cursor:move;-webkit-user-select:none;user-select:none;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:0 8px 24px #00000073;white-space:nowrap}.annotation-title{font-weight:600;font-size:13px;margin-bottom:6px;padding-bottom:6px;border-bottom:1px solid var(--border);max-width:240px;overflow:hidden;text-overflow:ellipsis}.annotation-row{display:flex;justify-content:space-between;gap:16px;line-height:1.7}.annotation-key{color:var(--text-muted)}.annotation-val{font-family:Fira Code,monospace}.annotation-row.vec{display:grid;grid-template-columns:36px 1fr;gap:10px;align-items:center}.vec-cells{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.vec-cell{display:flex;align-items:baseline;gap:4px;font-family:Fira Code,monospace}.vec-axis{font-style:normal;font-weight:600;font-size:11px;opacity:.75}.vec-axis.x{color:#ff8a99}.vec-axis.y{color:#92e0a0}.vec-axis.z{color:#9bb8ff}.gizmo{position:absolute;top:12px;right:12px;width:88px;height:88px;z-index:4;pointer-events:auto;cursor:pointer}.upaxis-btn{position:absolute;top:104px;right:12px;z-index:5;width:88px;padding:5px 0;font-family:Fira Code,monospace;font-size:12px;text-align:center;background:var(--surface-2);color:var(--text);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:background .16s ease}.upaxis-btn:hover{background:#232832}.btn-ghost{background:var(--surface-2);color:var(--text);border-color:var(--border)}.btn-ghost:hover{background:#232832}.btn-ghost:focus-visible{outline:2px solid var(--accent-hover);outline-offset:2px}.btn:disabled{opacity:.65;cursor:default}.btn-sm{padding:5px 10px;font-size:12px}.btn.sharing{background:var(--danger);color:#fff;border-color:transparent}.btn.sharing:hover{background:#f87171}.share-bar{position:fixed;bottom:16px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--surface);border:1px solid var(--border-strong);border-radius:10px;z-index:30;box-shadow:0 8px 28px #00000080}.share-bar[hidden]{display:none}.share-label{font-size:12px;color:var(--text-muted)}.share-url{width:320px;padding:6px 10px;background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text);font-family:Fira Code,monospace;font-size:12px}.guest-stage{position:fixed;top:0;right:0;bottom:0;left:0;background:#000;display:flex;align-items:center;justify-content:center}.guest-video{width:100%;height:100%;object-fit:contain;background:#000}.guest-status{position:fixed;bottom:24px;left:50%;transform:translate(-50%);padding:8px 16px;background:#000000b3;border:1px solid var(--border);border-radius:999px;font-size:13px;color:var(--text)}@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}.disconnect-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;background:#0a0c10b8;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.disconnect-card{background:#14171d;border:1px solid var(--border-strong);border-radius:14px;padding:28px 32px;text-align:center;max-width:360px;box-shadow:0 20px 60px #00000080}.disconnect-title{font-size:16px;font-weight:600;color:var(--text);margin-bottom:8px}.disconnect-sub{font-size:13px;color:var(--text-muted);margin-bottom:20px}.disconnect-btn{min-width:120px;justify-content:center}
