@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg-primary: #0a0e17;--bg-secondary: #111827;--bg-card: #1a1f2e;--bg-card-hover: #222840;--bg-glass: rgba(17, 24, 39, .7);--accent-cyan: #00e5ff;--accent-cyan-dim: rgba(0, 229, 255, .15);--accent-green: #00c853;--accent-green-dim: rgba(0, 200, 83, .15);--accent-amber: #ffab00;--accent-amber-dim: rgba(255, 171, 0, .15);--accent-red: #ff1744;--accent-red-dim: rgba(255, 23, 68, .15);--accent-purple: #d500f9;--text-primary: #e8eaed;--text-secondary: #9aa0b0;--text-muted: #5f6577;--border-subtle: rgba(255, 255, 255, .06);--border-active: rgba(0, 229, 255, .3);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--shadow-card: 0 4px 24px rgba(0, 0, 0, .4);--shadow-glow-cyan: 0 0 20px rgba(0, 229, 255, .2);--shadow-glow-green: 0 0 20px rgba(0, 200, 83, .2);--shadow-glow-red: 0 0 20px rgba(255, 23, 68, .2);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;overflow:hidden;height:100vh}#root{height:100vh;display:flex;flex-direction:column}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.glass{background:var(--bg-glass);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-subtle)}.card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);transition:border-color var(--transition-normal),box-shadow var(--transition-normal)}.card:hover{border-color:var(--border-active)}.mono{font-family:var(--font-mono)}.text-muted{color:var(--text-secondary)}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;font-size:.7rem;font-weight:600;font-family:var(--font-mono);letter-spacing:.03em}@keyframes pulse-glow{0%,to{opacity:.6}50%{opacity:1}}@keyframes pulse-ring{0%{transform:scale(1);opacity:.4}to{transform:scale(1.8);opacity:0}}@keyframes slide-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes data-flow{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes spin{to{transform:rotate(360deg)}}.animate-pulse-glow{animation:pulse-glow 2s ease-in-out infinite}.animate-slide-up{animation:slide-up .3s ease-out}.app-layout{display:grid;grid-template-rows:56px 1fr auto;height:100vh;gap:0}.header{display:flex;align-items:center;justify-content:space-between;padding:0 24px;background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);z-index:10}.header-title{display:flex;align-items:center;gap:12px}.header-title h1{font-size:1.1rem;font-weight:600;letter-spacing:.02em}.header-title .logo-dot{width:10px;height:10px;border-radius:50%;background:var(--accent-cyan);box-shadow:var(--shadow-glow-cyan)}.header-status{display:flex;align-items:center;gap:16px}.connection-indicator{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--text-secondary)}.connection-dot{width:8px;height:8px;border-radius:50%;transition:background var(--transition-normal)}.connection-dot.connected{background:var(--accent-green);box-shadow:var(--shadow-glow-green)}.connection-dot.disconnected{background:var(--accent-red);box-shadow:var(--shadow-glow-red)}.audio-permission-banner{background:var(--accent-amber-dim);border-bottom:1px solid rgba(255,171,0,.3);padding:8px 24px;animation:slideDown .3s ease-out}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.audio-permission-content{display:flex;align-items:center;gap:10px;font-size:.82rem;color:var(--accent-amber)}.audio-permission-content svg{flex-shrink:0}.audio-permission-content span{flex:1}.audio-permission-btn{background:var(--accent-amber);color:#000;border:none;padding:5px 16px;border-radius:var(--radius-sm);font-size:.78rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:opacity var(--transition-fast)}.audio-permission-btn:hover{opacity:.85}.main-content{display:grid;grid-template-columns:1fr 380px;gap:16px;padding:16px;overflow:hidden}.left-panel{display:flex;flex-direction:column;gap:16px;min-height:0}.camera-stack{position:relative;display:flex;flex:1;min-height:0}.mobile-pipeline-overlay,.mobile-inline-pipeline{display:none}.right-panel{display:flex;flex-direction:column;gap:16px;min-height:0}.desktop-pipeline-wrap,.desktop-bottom-pipeline{display:block}.auth-user{font-size:.75rem;color:var(--text-secondary);padding:4px 8px;border:1px solid var(--border-subtle);border-radius:999px}.logout-btn{border:1px solid var(--border-subtle);background:transparent;color:var(--text-secondary);border-radius:var(--radius-sm);font-size:.75rem;padding:6px 10px;cursor:pointer}.logout-btn:hover{color:var(--text-primary);border-color:var(--accent-red)}.login-screen{min-height:100vh;display:grid;place-items:center;padding:16px;background:radial-gradient(circle at 20% 20%,rgba(0,229,255,.08),transparent 35%),radial-gradient(circle at 80% 80%,rgba(255,23,68,.08),transparent 35%),var(--bg-primary)}.login-card{width:min(420px,100%);padding:24px;display:grid;gap:12px}.login-card h2{font-size:1.3rem;margin-bottom:4px}.login-card p{color:var(--text-secondary);font-size:.9rem;margin-bottom:8px}.login-card label{display:grid;gap:6px;font-size:.85rem;color:var(--text-secondary)}.login-card input{width:100%;background:var(--bg-secondary);border:1px solid var(--border-subtle);color:var(--text-primary);border-radius:var(--radius-sm);padding:10px 12px;outline:none}.login-card input:focus{border-color:var(--accent-cyan)}.login-card button{margin-top:8px;background:var(--accent-cyan);color:#04131a;border:none;border-radius:var(--radius-sm);padding:10px 12px;font-weight:600;cursor:pointer}.login-card button:disabled{opacity:.7;cursor:not-allowed}.login-error{color:var(--accent-red);font-size:.82rem}.login-switch{text-align:center;font-size:.82rem;color:var(--text-muted);margin-top:4px}.link-btn{background:none;border:none;color:var(--accent-cyan);cursor:pointer;font-size:inherit;padding:0;margin:0;font-weight:500;text-decoration:underline;text-underline-offset:2px}.link-btn:hover{opacity:.8}.camera-container{flex:1;min-height:0;position:relative;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-subtle);background:#000}.camera-feed{width:100%;height:100%;object-fit:contain;display:block}.camera-overlay{position:absolute;top:12px;left:12px;display:flex;gap:8px}.camera-overlay .badge{background:#000000a6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:var(--text-primary);border:1px solid var(--border-subtle)}.camera-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:16px;color:var(--text-muted)}.camera-placeholder svg{width:64px;height:64px;opacity:.3}.camera-placeholder p{font-size:.85rem;text-align:center;max-width:32ch}.camera-retry-btn{margin-top:4px;padding:8px 12px;border-radius:10px;border:1px solid var(--border-subtle);background:var(--bg-card);color:var(--text-primary);font-size:.8rem;font-weight:600;cursor:pointer}.camera-retry-btn:hover{border-color:var(--accent-cyan);box-shadow:0 0 0 3px #00e5ff26}.query-container{flex:1;display:flex;flex-direction:column;min-height:0}.query-header{padding:14px 16px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;gap:8px}.query-header h3{font-size:.85rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em}.dialogue-display{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:16px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-muted);text-align:center;padding:32px 16px}.empty-state svg{margin-bottom:16px;opacity:.5}.empty-state p{font-size:.9rem;margin:0}.dialogue-message{display:flex;flex-direction:column;gap:6px;animation:message-slide-in .3s ease-out}.dialogue-message.user{align-items:flex-end}.dialogue-message.ai{align-items:flex-start}.message-header{display:flex;align-items:center;gap:6px;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.dialogue-message.user .message-header{color:var(--accent-cyan)}.dialogue-message.ai .message-header{color:var(--text-muted)}.message-bubble{max-width:75%;padding:12px 16px;border-radius:12px;font-size:.9rem;word-wrap:break-word}.dialogue-message.user .message-bubble{background:#00e5ff26;border:1px solid rgba(0,229,255,.3);color:var(--text-primary);border-radius:12px 12px 4px}.dialogue-message.ai .message-bubble{background:var(--card-bg);border:1px solid var(--border);color:var(--text-primary);border-radius:12px 12px 12px 4px}@keyframes message-slide-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.voice-controls{padding:16px;display:flex;justify-content:center;border-top:1px solid var(--border)}.voice-btn{display:flex;align-items:center;gap:12px;padding:14px 28px;background:linear-gradient(135deg,#00e5ff26,#00e5ff0d);border:1px solid rgba(0,229,255,.3);border-radius:24px;color:var(--accent-cyan);font-size:.95rem;font-weight:500;cursor:pointer;transition:all .3s ease}.voice-btn:hover{background:linear-gradient(135deg,#00e5ff40,#00e5ff1a);border-color:var(--accent-cyan);transform:translateY(-2px);box-shadow:0 4px 12px #00e5ff4d}.voice-btn.recording{background:linear-gradient(135deg,#ff4d4d26,#ff4d4d0d);border-color:#ff4d4d4d;color:#ff4d4d}.voice-btn.recording:hover{background:linear-gradient(135deg,#ff4d4d40,#ff4d4d1a);border-color:#ff4d4d}.recording-indicator{position:relative;display:flex;align-items:center;justify-content:center}.pulse-ring{position:absolute;width:32px;height:32px;border:2px solid #ff4d4d;border-radius:50%;animation:pulse-ring 1.5s ease-out infinite}@keyframes pulse-ring{0%{transform:scale(.8);opacity:1}to{transform:scale(1.5);opacity:0}}.voice-btn.transcribing{background:linear-gradient(135deg,#ffab0026,#ffab000d);border-color:#ffab004d;color:var(--accent-amber);cursor:wait;opacity:.9}.transcribing-indicator{display:flex;align-items:center;justify-content:center}.spin-icon{animation:spin 1.2s linear infinite}.query-input-bar{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--border-subtle)}.query-input{flex:1;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:10px 14px;color:var(--text-primary);font-family:var(--font-sans);font-size:.85rem;outline:none;transition:border-color var(--transition-fast)}.query-input:focus{border-color:var(--accent-cyan)}.query-input::placeholder{color:var(--text-muted)}.query-send-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;border-radius:var(--radius-sm);background:var(--accent-cyan);color:var(--bg-primary);cursor:pointer;transition:opacity var(--transition-fast),transform var(--transition-fast)}.query-send-btn:hover{opacity:.85;transform:scale(1.05)}.query-input-bar.listening{border:2px solid var(--accent-cyan);box-shadow:0 0 20px #00e5ff4d;animation:listening-pulse 2s ease-in-out infinite}.listening-indicator{position:absolute;top:-32px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;padding:6px 14px;background:linear-gradient(135deg,#00e5ff26,#00e5ff0d);border:1px solid rgba(0,229,255,.3);border-radius:20px;color:var(--accent-cyan);font-size:.75rem;font-weight:500;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:slide-in-down .3s ease-out}.stop-listening-btn{padding:4px;background:#ff4d4d1a;border:1px solid rgba(255,77,77,.3);border-radius:4px;color:#ff4d4d;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;margin-left:4px}.stop-listening-btn:hover{background:#ff4d4d33;border-color:#ff4d4d;transform:scale(1.1)}.listening-indicator .pulse-icon{animation:pulse-scale 1.5s ease-in-out infinite}@keyframes listening-pulse{0%,to{box-shadow:0 0 20px #00e5ff4d}50%{box-shadow:0 0 30px #00e5ff80,0 0 40px #00e5ff33}}@keyframes pulse-scale{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.15);opacity:.8}}@keyframes slide-in-down{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.mic-toggle-btn{padding:10px 12px;background:var(--card-bg);border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.mic-toggle-btn:hover{background:#00e5ff1a;border-color:var(--accent-cyan);color:var(--accent-cyan)}.mic-toggle-btn.active{background:#00e5ff26;border-color:var(--accent-cyan);color:var(--accent-cyan);animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,to{box-shadow:0 0 10px #00e5ff4d}50%{box-shadow:0 0 20px #00e5ff80}}.query-send-btn:disabled{opacity:.3;cursor:not-allowed;transform:none}.controls-container{padding:16px;display:flex;gap:10px}.mobile-dock{display:none}.control-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);font-family:var(--font-sans);font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;cursor:pointer;transition:all var(--transition-fast);background:var(--bg-card);color:var(--text-primary)}.control-btn:hover{border-color:var(--border-active)}.control-btn.start{background:var(--accent-green-dim);border-color:#00c8534d;color:var(--accent-green)}.control-btn.start:hover{background:#00c85340;box-shadow:var(--shadow-glow-green)}.control-btn.stop{background:var(--accent-red-dim);border-color:#ff17444d;color:var(--accent-red)}.control-btn.stop:hover{background:#ff174440;box-shadow:var(--shadow-glow-red)}.control-btn.mute-active{background:var(--accent-amber-dim);border-color:#ffab004d;color:var(--accent-amber)}.control-btn.starting{background:var(--accent-cyan-dim);border-color:#00e5ff4d;color:var(--accent-cyan);position:relative;overflow:hidden;cursor:wait}.control-btn.starting:hover{background:#00e5ff33;box-shadow:var(--shadow-glow-cyan)}.control-btn.stopping{background:var(--accent-amber-dim);border-color:#ffab004d;color:var(--accent-amber);position:relative;overflow:hidden;cursor:wait}.control-btn.stopping:hover{background:#ffab0033}.init-progress-bar{position:absolute;bottom:0;left:0;height:3px;width:100%;background:linear-gradient(90deg,transparent,var(--accent-cyan),transparent);background-size:200% 100%;animation:init-shimmer 1.5s ease-in-out infinite;border-radius:0 0 var(--radius-sm) var(--radius-sm)}@keyframes init-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.logo-dot.animate-spin-dot{background:var(--accent-cyan);box-shadow:var(--shadow-glow-cyan);animation:spin-dot 1.2s linear infinite}@keyframes spin-dot{0%{box-shadow:0 0 8px #00e5ff99,0 0 16px #00e5ff4d}50%{box-shadow:0 0 16px #00e5ffe6,0 0 32px #00e5ff80}to{box-shadow:0 0 8px #00e5ff99,0 0 16px #00e5ff4d}}.badge-transitioning{animation:badge-pulse 1.5s ease-in-out infinite}@keyframes badge-pulse{0%,to{opacity:.7}50%{opacity:1}}.pipeline-container{background:var(--bg-secondary);border-top:1px solid var(--border-subtle);padding:14px 24px}.pipeline-container.pipeline-compact{padding:10px 12px;border-top:none;border:1px solid rgba(144,198,255,.2);background:linear-gradient(135deg,#18233ee0,#111729d6);box-shadow:0 16px 42px #00000080,0 0 28px #00e5ff14;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-radius:20px}.pipeline-row{display:flex;align-items:center;justify-content:center;gap:0}.pipeline-row.pipeline-row-compact{justify-content:flex-start;overflow-x:auto;overflow-y:hidden;padding-bottom:2px}.pipeline-row.pipeline-row-compact::-webkit-scrollbar{height:4px}.pipeline-node{display:flex;flex-direction:column;align-items:center;gap:6px;padding:8px 16px;position:relative;min-width:90px}.pipeline-node-icon{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.85rem;border:2px solid var(--border-subtle);background:var(--bg-card);transition:all var(--transition-normal);position:relative}.pipeline-node.active .pipeline-node-icon{border-color:var(--accent-green);background:var(--accent-green-dim);box-shadow:var(--shadow-glow-green)}.pipeline-node.processing .pipeline-node-icon{border-color:var(--accent-cyan);background:var(--accent-cyan-dim);box-shadow:var(--shadow-glow-cyan);animation:pulse-glow 1.5s ease-in-out infinite}.pipeline-node.loading .pipeline-node-icon{border-color:#00e5ff4d;background:var(--accent-cyan-dim);animation:node-loading 1.8s ease-in-out infinite}@keyframes node-loading{0%,to{opacity:.4;border-color:#00e5ff33}50%{opacity:1;border-color:var(--accent-cyan);box-shadow:var(--shadow-glow-cyan)}}.pipeline-node.loading .pipeline-node-label{color:var(--text-muted);animation:badge-pulse 1.5s ease-in-out infinite}.pipeline-node.error .pipeline-node-icon{border-color:var(--accent-red);background:var(--accent-red-dim);box-shadow:var(--shadow-glow-red)}.pipeline-node-label{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);transition:color var(--transition-normal)}.pipeline-node.active .pipeline-node-label,.pipeline-node.processing .pipeline-node-label{color:var(--text-secondary)}.pipeline-node-latency{font-size:.6rem;font-family:var(--font-mono);color:var(--text-muted);min-height:14px}.pipeline-container.pipeline-compact .pipeline-node{min-width:76px;padding:6px 10px;gap:4px}.pipeline-container.pipeline-compact .pipeline-node-icon{width:30px;height:30px;font-size:.72rem}.pipeline-container.pipeline-compact .pipeline-node-label{font-size:.56rem}.pipeline-container.pipeline-compact .pipeline-node-latency{font-size:.52rem;min-height:12px}.pipeline-container.pipeline-compact .pipeline-arrow{width:20px;margin-bottom:22px}.pipeline-container.pipeline-compact .pipeline-init-banner{margin-bottom:6px;padding:5px 10px;font-size:.62rem}.pipeline-arrow{display:flex;align-items:center;width:40px;height:2px;background:var(--border-subtle);position:relative;margin-bottom:28px}.pipeline-arrow.active{background:linear-gradient(90deg,var(--accent-cyan),transparent,var(--accent-cyan));background-size:200% 100%;animation:data-flow 1.5s linear infinite}.pipeline-arrow:after{content:"";position:absolute;right:-4px;top:-3px;width:0;height:0;border-top:4px solid transparent;border-bottom:4px solid transparent;border-left:6px solid var(--border-subtle);transition:border-color var(--transition-normal)}.pipeline-arrow.active:after{border-left-color:var(--accent-cyan)}.pipeline-init-banner{display:flex;align-items:center;justify-content:center;gap:10px;padding:8px 16px;margin-bottom:10px;background:linear-gradient(135deg,#00e5ff14,#00e5ff08);border:1px solid rgba(0,229,255,.2);border-radius:var(--radius-sm);color:var(--accent-cyan);font-size:.78rem;font-weight:500;animation:slide-up .3s ease-out}.scene-description{position:absolute;bottom:0;left:0;right:0;padding:12px 16px;background:linear-gradient(transparent,#000000d9);color:var(--text-primary);font-size:.8rem;line-height:1.4}.scene-description .label{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--accent-cyan);margin-bottom:2px}.help-button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.help-button:hover{border-color:var(--accent-cyan);color:var(--accent-cyan);background:var(--accent-cyan-dim)}.shortcuts-overlay{position:fixed;inset:0;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:slide-up .2s ease-out}.shortcuts-panel{background:var(--bg-secondary);border:1px solid var(--border-active);border-radius:var(--radius-lg);width:90%;max-width:420px;box-shadow:var(--shadow-card),var(--shadow-glow-cyan);animation:slide-up .25s ease-out}.shortcuts-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-subtle)}.shortcuts-header h3{font-size:1rem;font-weight:600;color:var(--text-primary)}.close-btn{width:28px;height:28px;border:none;background:transparent;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.close-btn:hover{background:var(--bg-card-hover);color:var(--text-primary)}.shortcuts-list{padding:20px;display:flex;flex-direction:column;gap:12px}.shortcut-item{display:flex;align-items:center;gap:16px;padding:10px 12px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);transition:border-color var(--transition-fast)}.shortcut-item:hover{border-color:var(--border-active)}.shortcut-item kbd{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;padding:0 10px;background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:6px;font-family:var(--font-mono);font-size:.85rem;font-weight:600;color:var(--accent-cyan);box-shadow:0 2px #0000004d}.query-input-bar{position:relative;display:flex;gap:8px;padding:10px;background:var(--card-bg);border:1px solid var(--border);border-radius:8px;transition:all .3s ease}.shortcut-item span{flex:1;font-size:.85rem;color:var(--text-primary)}.shortcuts-footer{padding:12px 20px;border-top:1px solid var(--border-subtle);text-align:center;font-size:.75rem;color:var(--text-muted)}.shortcuts-footer kbd{display:inline-flex;align-items:center;justify-content:center;padding:2px 6px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:4px;font-family:var(--font-mono);font-size:.7rem;color:var(--text-secondary);margin:0 2px}@media(max-width:820px){body{height:100dvh;overflow:hidden;background:radial-gradient(circle at 0% 0%,rgba(0,229,255,.1),transparent 36%),radial-gradient(circle at 100% 100%,rgba(68,113,255,.15),transparent 40%),linear-gradient(180deg,#0a1224,#090e1a 58%,#080d17)}#root{height:100dvh;overflow:hidden}.app-layout{display:flex;flex-direction:column;height:100dvh;min-height:100dvh;position:relative}.header{height:50px;padding:0 12px;background:linear-gradient(180deg,#141c34f5,#0d1425f0);border-bottom:1px solid rgba(120,158,220,.22);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.header-title{gap:8px}.header-title h1{font-size:1rem}.header-title .badge{font-size:.62rem;padding:2px 6px}.header-status{gap:8px}.auth-user,.logout-btn,.help-button{display:none}.connection-indicator{font-size:.68rem}.audio-permission-banner{padding:8px 10px}.audio-permission-content{gap:8px;font-size:.72rem}.audio-permission-btn{padding:6px 10px;font-size:.7rem}.main-content{flex:1;display:flex;flex-direction:column;gap:10px;padding:10px 10px calc(110px + env(safe-area-inset-bottom));overflow:auto;overscroll-behavior:contain}.left-panel{min-height:0;flex:0 0 auto}.camera-stack{min-height:260px}.camera-container{min-height:260px;border-radius:18px;border-color:#77a0e33d;box-shadow:inset 0 0 0 1px #ffffff0a,0 18px 30px #00000061}.camera-feed{object-fit:cover}.camera-overlay{top:8px;left:8px}.camera-overlay .badge{font-size:.58rem;padding:2px 7px}.mobile-pipeline-overlay{display:none}.right-panel{flex:0 0 auto;min-height:0;gap:8px}.mobile-inline-pipeline{display:block}.mobile-inline-pipeline .pipeline-container{border-radius:16px}.query-container{flex:0 0 auto;height:min(42dvh,360px);border-radius:18px;overflow:hidden;background:linear-gradient(180deg,#10182cf0,#0b1220fa);border-color:#77a0e333}.query-header{padding:10px 12px}.query-header h3{font-size:.75rem}.dialogue-display{padding:12px 12px 72px;gap:12px}.message-bubble{max-width:88%;padding:10px 12px;font-size:.84rem;line-height:1.35}.voice-controls,.controls-container,.desktop-pipeline-wrap,.desktop-bottom-pipeline{display:none}.pipeline-container.pipeline-compact .pipeline-node{min-width:70px;padding:5px 7px}.mobile-dock{position:fixed;left:10px;right:10px;bottom:calc(8px + env(safe-area-inset-bottom));z-index:25;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:10px;padding:9px 10px;border-radius:18px;border:1px solid rgba(130,168,235,.25);background:linear-gradient(135deg,#141c33e6,#0d1425f5);box-shadow:0 20px 38px #00000080,0 0 24px #00e5ff17;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.mobile-dock-btn{height:44px;border-radius:12px;border:1px solid rgba(122,156,217,.28);background:#121b30db;color:var(--text-primary);display:flex;align-items:center;justify-content:center;gap:8px;font-size:.76rem;font-weight:600;letter-spacing:.02em;cursor:pointer}.mobile-dock-btn span{white-space:nowrap}.mobile-dock-side.active{border-color:#ffab0073;color:var(--accent-amber);background:#46341173}.mobile-mic-btn{height:44px;width:44px;border-radius:999px;border:2px solid rgba(0,229,255,.45);background:radial-gradient(circle at 40% 25%,#30ceff73,#205fc642 60%,#121e3ef2);color:#9ef6ff;display:grid;place-items:center;margin-top:0;box-shadow:0 0 0 3px #00e5ff1f,0 0 16px #00e5ff33;cursor:pointer}.mobile-mic-btn.recording{border-color:#ff626299;color:#ffd2d2;background:radial-gradient(circle at 40% 25%,#ff7a7a70,#6a2222e6 70%);box-shadow:0 0 0 4px #ff4d4d24,0 0 26px #ff4d4d52}.mobile-mic-btn.transcribing{border-color:#ffab008c;color:#ffe08a;background:radial-gradient(circle at 40% 25%,#ffcd576b,#4c380feb 70%)}.mobile-mic-btn:disabled{cursor:wait;opacity:.9}.mobile-dock-start.start{border-color:#00c85375;color:#8af9be;background:#0c452bb3}.mobile-dock-start.stop{border-color:#ff526e70;color:#ffb3c2;background:#4d1325b8}.mobile-dock-start.waiting{border-color:#00e5ff66;color:var(--accent-cyan);background:#0a3f4eb3;cursor:wait}.mobile-dock-start:disabled{opacity:.9}.mobile-dock-btn:active,.mobile-mic-btn:active{transform:scale(.98)}}
