.app-container,.connect-screen{display:flex;flex-direction:column;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.connect-screen{align-items:center;justify-content:center;gap:20px;color:white;text-align:center;padding:20px}.connect-screen h1{font-size:2.5rem;margin-bottom:10px;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.connect-screen p{font-size:1.1rem;opacity:.9;margin-bottom:20px}.requirements{background:rgba(255,255,255,.1);border-radius:12px;padding:20px;margin:20px 0;text-align:left;max-width:400px}.requirements p{margin-bottom:10px;font-weight:600}.requirements ul{list-style:none;padding:0;margin:0}.requirements li{opacity:.9;position:relative;padding:5px 0 5px 20px}.requirements li:before{content:"✓";position:absolute;left:0;color:#10b981;font-weight:700}.connect-screen button{padding:15px 30px;font-size:18px;background:#16A34A;color:white;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px rgba(22,163,74,.3)}.connect-screen button:hover{background:#15803D;transform:translateY(-2px);box-shadow:0 6px 20px rgba(22,163,74,.4)}.connect-screen button:disabled{opacity:.6;cursor:not-allowed;transform:none}.session-info-bar{background:#1e293b;color:white;padding:10px 20px;border-radius:8px;margin-bottom:10px;display:flex;justify-content:space-between;align-items:center;font-size:.9rem}.session-info{color:#94a3b8;font-size:.9rem;margin-top:10px}.assistant-container{max-width:1000px;padding:20px;background:white;border-radius:20px;box-shadow:0 10px 30px rgba(0,0,0,.2);margin:20px auto}.status-bar{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;background:#f8fafc;border-radius:12px;margin-bottom:20px;border:1px solid #e2e8f0}.status{font-weight:600;font-size:1.1rem}.status.connected{color:#16A34A}.status.disconnected{color:#dc2626}.visualizer{background:linear-gradient(135deg,#1f2937,#374151);border-radius:16px;padding:40px;margin:20px 0;text-align:center;box-shadow:inset 0 2px 10px rgba(0,0,0,.3)}.agent-state{color:white;font-size:20px;margin-top:20px;font-weight:500}.audio-debug{background:#f0f9ff;border:1px solid #0ea5e9;border-radius:12px;padding:20px;margin:20px 0}.audio-debug h3{color:#0369a1;margin-bottom:15px;font-size:1.3rem}.debug-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px}.debug-stats p{margin:5px 0;font-size:1rem;color:#0c4a6e}.audio-track-container{background:#dcfce7;border:1px solid #16a34a;border-radius:8px;padding:15px;margin:15px 0;text-align:center}.audio-track-container p{color:#166534;font-weight:500;margin:10px 0 0}.audio-controls{background:#fef3c7;border:1px solid #f59e0b;border-radius:12px;padding:20px;margin:20px 0}.audio-controls h3{color:#92400e;margin-bottom:15px;font-size:1.3rem}.controls{display:flex;gap:15px;justify-content:center;margin-top:20px;flex-wrap:wrap}.controls button{padding:12px 24px;font-size:16px;border-radius:8px;cursor:pointer;border:none;transition:all .3s ease;font-weight:500}.controls button:first-child{background:#3b82f6;color:white}.controls button:first-child:hover{background:#2563eb;transform:translateY(-2px)}.controls button:last-child{background:#dc2626;color:white}.controls button:last-child:hover{background:#b91c1c;transform:translateY(-2px)}.error-container{text-align:center;padding:40px;background:white;border-radius:20px;box-shadow:0 10px 30px rgba(0,0,0,.2);margin:20px}.error-container h2{color:#dc2626;margin-bottom:20px;font-size:1.8rem}.error-container p{color:#6b7280;margin-bottom:30px;font-size:1.1rem}.error-actions{display:flex;gap:15px;justify-content:center;margin-bottom:25px;flex-wrap:wrap}.error-actions button{background:#3b82f6;color:white;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;font-size:16px;min-width:120px}.error-actions button:hover{background:#2563eb}.error-actions button:last-child{background:#10b981}.error-actions button:last-child:hover{background:#059669}.error-tips{background:#f9fafb;border-radius:8px;padding:20px;text-align:left;max-width:400px;margin:0 auto}.error-tips h4{color:#374151;margin-bottom:10px;text-align:center}.error-tips ul{color:#6b7280;margin:0;padding-left:20px}.error-tips li{margin-bottom:5px}.connecting-container{text-align:center;padding:40px;background:white;border-radius:20px;box-shadow:0 10px 30px rgba(0,0,0,.2);margin:20px}.connecting-container h2{color:#3b82f6;margin-bottom:20px;font-size:1.8rem}.connecting-container p{color:#6b7280;margin-bottom:30px;font-size:1.1rem}.spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.live-camera-feed{background:#f0fdf4;border:1px solid #22c55e;border-radius:12px;padding:20px;margin:20px 0}.live-camera-feed h3{color:#166534;margin-bottom:15px;font-size:1.3rem}.camera-container{text-align:center;margin-bottom:15px}.camera-video{border:2px solid #22c55e;box-shadow:0 4px 12px rgba(34,197,94,.2)}.camera-status{text-align:center;margin-bottom:15px}.status-success{color:#166534;font-weight:500;margin:0}.status-error{color:#dc2626;font-weight:500;margin:0}.status-waiting{color:#6b7280;font-weight:500;margin:0}.captured-image{background:#f9fafb;border:1px solid #d1d5db;border-radius:12px;padding:20px;margin:20px 0;text-align:center}.captured-image h3{color:#374151;margin-bottom:15px;font-size:1.2rem}.vision-status{background:#f0f9ff;border:1px solid #0ea5e9;border-radius:12px;padding:20px;margin:20px 0}.vision-status h3{color:#0369a1;margin-bottom:15px;font-size:1.3rem}.vision-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px}.vision-info p{margin:5px 0;font-size:1rem;color:#0c4a6e}.vision-result{background:#fef3c7;border:1px solid #f59e0b;border-radius:12px;padding:20px;margin:20px 0}.vision-result h3{color:#92400e;margin-bottom:15px;font-size:1.3rem}.vision-content p{color:#92400e;line-height:1.5;margin:10px 0}.tools-section{background:white;border-radius:12px;padding:20px;margin:20px 0;box-shadow:0 4px 6px rgba(0,0,0,.1)}.tools-section h3{margin:0 0 15px;color:#333;font-size:1.3rem;font-weight:600}.tools-list{display:flex;flex-direction:column;gap:10px;margin-bottom:15px}.tool-item{display:flex;align-items:center;padding:10px;border:1px solid #e0e0e0;border-radius:8px;background:#f9f9f9;transition:all .2s ease}.tool-item:hover{background:#f0f0f0;border-color:#667eea}.tool-item label{display:flex;align-items:center;gap:10px;cursor:pointer;width:100%}.tool-item input[type=checkbox]{margin:0;transform:scale(1.2);cursor:pointer}.tool-name{font-weight:600;color:#333;min-width:150px;font-size:.95rem}.tool-description{color:#666;font-size:.9rem;flex:1}.tools-status{padding:10px;background:#f0f8ff;border-radius:6px;border-left:4px solid #667eea}.tools-status p{margin:0;font-weight:500;color:#333}.assistant-container-clean{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:space-between;background:#f8f8f8;padding:40px 20px;position:relative}.status-dots{display:flex;gap:8px;justify-content:center;align-items:center;padding:20px}.status-dots .dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.3);transition:all .3s ease}.status-dots .dot.connected{background:#10b981;box-shadow:0 0 15px #10b981;animation:pulse 2s infinite}.status-dots .dot.disconnected{background:#ef4444;box-shadow:0 0 15px #ef4444}.main-content-wrapper{flex:1;display:flex;align-items:center;justify-content:center;position:relative;width:100%;max-width:1200px}.camera-feed-corner{position:absolute;bottom:30px;left:30px;z-index:10;background:#000;backdrop-filter:blur(10px);border-radius:50%;padding:0;box-shadow:0 8px 32px rgba(0,0,0,.15);border:3px solid #000;overflow:hidden;width:150px;height:150px}.camera-feed-corner .live-camera-feed{background:transparent;border:none;padding:0;margin:0;width:100%;height:100%;position:relative}.camera-feed-corner .live-camera-feed h3{display:none}.camera-feed-corner .camera-container{width:100%;height:100%;margin:0;padding:0;text-align:center;position:relative}.camera-feed-corner .camera-video{border-radius:50%;width:100%;height:100%;-o-object-fit:cover;object-fit:cover;box-shadow:none;position:absolute;top:0;left:0}.camera-feed-corner .camera-status{display:none}.center-visualizer{flex-direction:column;gap:40px}.blob-visualizer-container,.center-visualizer{display:flex;align-items:center;justify-content:center}.blob-visualizer-container{position:relative;width:400px;height:400px;border-radius:50%;overflow:hidden}.blob-visualizer-container canvas{display:block;width:100%;height:100%}.state-text-clean{font-size:32px;font-weight:600;color:#374151;text-shadow:none;letter-spacing:1px}.bottom-controls{gap:20px;padding:20px}.bottom-controls,.control-btn{display:flex;align-items:center;justify-content:center}.control-btn{width:60px;height:60px;border-radius:50%;border:none;font-size:24px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px rgba(0,0,0,.2)}.reconnect-btn{background:#10b981;color:white}.reconnect-btn:hover{background:#059669;transform:scale(1.1) rotate(180deg);box-shadow:0 6px 20px rgba(16,185,129,.5)}.disconnect-btn{background:#ef4444;color:white;font-size:28px}.disconnect-btn:hover{background:#dc2626;transform:scale(1.1);box-shadow:0 6px 20px rgba(239,68,68,.5)}.disconnect-btn svg,.reconnect-btn svg{width:24px;height:24px}.mic-btn{background:#1f2937;color:white}.mic-btn:hover{background:#111827;transform:scale(1.1);box-shadow:0 6px 20px rgba(0,0,0,.5)}.mic-btn.muted{background:#1f2937;opacity:.7}.mic-btn.muted:hover{background:#111827;transform:scale(1.1);box-shadow:0 6px 20px rgba(0,0,0,.5);opacity:.9}.control-btn svg{display:block;pointer-events:none}.mic-btn{font-size:24px}.assistant-container-minimal{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.minimal-header{display:flex;align-items:center;justify-content:space-between;padding:15px 25px;background:rgba(255,255,255,.15);backdrop-filter:blur(10px);border-radius:20px;margin-bottom:20px}.connection-dot{width:12px;height:12px;border-radius:50%;margin-right:10px;display:inline-block}.connection-dot.connected{background:#10b981;box-shadow:0 0 10px #10b981;animation:pulse 2s infinite}.connection-dot.disconnected{background:#ef4444;box-shadow:0 0 10px #ef4444}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.connection-text{color:white;font-size:16px;font-weight:500}.header-actions{display:flex;gap:10px}.icon-button{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.2);border-radius:50%;cursor:pointer;transition:all .3s ease;font-size:20px;border:none}.icon-button:hover{background:rgba(255,255,255,.3);transform:scale(1.1)}.icon-button.reconnect{background:rgba(59,130,246,.3)}.icon-button.reconnect:hover{background:rgba(59,130,246,.5);animation:spin 1s linear}.icon-button.disconnect{background:rgba(239,68,68,.3)}.icon-button.disconnect:hover{background:rgba(239,68,68,.5)}.minimal-content{display:grid;grid-template-columns:1fr 1fr;gap:20px;flex:1;align-items:center;padding:20px}.polygon-visualizer{padding:40px 20px}.camera-feed-minimal,.polygon-visualizer{display:flex;flex-direction:column;align-items:center;justify-content:center}.camera-feed-minimal{background:rgba(255,255,255,.1);backdrop-filter:blur(10px);border-radius:20px;padding:20px;box-shadow:0 10px 30px rgba(0,0,0,.2)}.camera-feed-minimal .live-camera-feed{background:transparent;border:none;padding:0;margin:0}.camera-feed-minimal .camera-video{border-radius:12px;max-width:100%;box-shadow:0 4px 15px rgba(0,0,0,.3)}.polygon-svg{width:300px;height:300px;max-width:90vw;max-height:50vh;filter:drop-shadow(0 10px 30px rgba(0,0,0,.3))}.polygon{fill:rgba(255,255,255,.9);stroke:white;stroke-width:3;transition:all .3s ease;transform-origin:center}.polygon-listening{animation:listening-pulse 2s ease-in-out infinite}@keyframes listening-pulse{0%,to{fill:rgba(59,130,246,.7);transform:scale(1)}50%{fill:rgba(59,130,246,.9);transform:scale(1.05)}}.polygon-thinking{fill:rgba(251,191,36,.8);animation:thinking-rotate 3s linear infinite}@keyframes thinking-rotate{0%{transform:rotate(0deg);fill:rgba(251,191,36,.7)}50%{fill:rgba(251,191,36,1)}to{transform:rotate(1turn);fill:rgba(251,191,36,.7)}}.polygon-speaking{animation:speaking-pulse .6s ease-in-out infinite}@keyframes speaking-pulse{0%,to{fill:rgba(34,197,94,.7);transform:scale(1)}50%{fill:rgba(34,197,94,1);transform:scale(1.1)}}.state-text{font-size:50px;fill:rgba(255,255,255,.95);filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.state-label{margin-top:30px;font-size:28px;font-weight:600;color:white;text-shadow:0 2px 10px rgba(0,0,0,.3);letter-spacing:1px}@media (max-width:768px){.assistant-container{margin:10px;padding:15px}.assistant-container-minimal{padding:15px}.assistant-container-clean{padding:30px 15px}.minimal-header{padding:12px 18px;flex-wrap:wrap;gap:10px}.minimal-content{grid-template-columns:1fr;gap:20px}.main-content-wrapper{padding:0 10px}.camera-feed-corner{bottom:100px;left:15px;width:120px;height:120px}.blob-visualizer-container{width:280px;height:280px}.state-text-clean{font-size:26px}.control-btn{width:55px;height:55px}.control-btn,.state-label{font-size:22px}.connect-screen h1{font-size:2rem}.controls{flex-direction:column;align-items:center}.controls button{width:100%;max-width:200px}.status-bar{gap:10px}.session-info-bar,.status-bar{flex-direction:column;text-align:center}.session-info-bar{gap:5px}}