@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,.right-panel{display:flex;flex-direction:column;gap:16px;min-height:0}.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}.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}.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-row{display:flex;align-items:center;justify-content:center;gap:0}.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-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:960px){.main-content{grid-template-columns:1fr;grid-template-rows:minmax(300px,1fr) auto}.right-panel{max-height:40vh}}
