.voice-settings-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeInOverlay .3s ease-out}@keyframes fadeInOverlay{0%{opacity:0;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px)}to{opacity:1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}}.voice-settings-modal{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:600px;max-height:80vh;overflow:hidden;animation:slideInModal .4s ease-out;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}@keyframes slideInModal{0%{opacity:0;transform:translateY(-50px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.voice-settings-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px;display:flex;justify-content:space-between;align-items:center}.voice-settings-header h3{margin:0;font-size:1.5rem;font-weight:600}.close-voice-settings{background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:5px;border-radius:50%;width:35px;height:35px;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.close-voice-settings:hover{background:#fff3;transform:scale(1.1)}.voice-settings-content{padding:20px;max-height:60vh;overflow-y:auto;display:flex;flex-direction:column;gap:24px}.setting-group{background:#f8f9fa;border-radius:12px;padding:20px;border:1px solid #e9ecef;transition:all .3s ease}.setting-group:hover{border-color:#667eea;box-shadow:0 2px 10px #667eea1a}.setting-label{display:block;font-size:1.1rem;font-weight:600;color:#495057;margin-bottom:12px}.setting-description{font-size:.9rem;color:#6c757d;margin-top:8px;line-height:1.4}.setting-select{width:100%;padding:12px 16px;border:2px solid #e9ecef;border-radius:8px;font-size:1rem;background:#fff;cursor:pointer;transition:all .3s ease}.setting-select:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.setting-select option{padding:10px}.setting-range{width:100%;height:6px;border-radius:3px;background:#e9ecef;outline:none;cursor:pointer;margin:12px 0;-webkit-appearance:none}.setting-range::-webkit-slider-thumb{-webkit-appearance:none;width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);cursor:pointer;box-shadow:0 2px 8px #667eea4d;transition:all .3s ease}.setting-range::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 4px 12px #667eea80}.setting-range::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);cursor:pointer;border:none;box-shadow:0 2px 8px #667eea4d}.range-labels{display:flex;justify-content:space-between;font-size:.85rem;color:#6c757d;margin-top:-8px}.setting-checkboxes{display:flex;flex-direction:column;gap:16px;margin-top:12px}.checkbox-item{display:flex;flex-direction:column;gap:8px;cursor:pointer;padding:16px;background:#fff;border:2px solid #e9ecef;border-radius:8px;transition:all .3s ease;position:relative}.checkbox-item:hover{border-color:#667eea;box-shadow:0 2px 8px #667eea1a}.checkbox-item input[type=checkbox]{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.checkbox-label{font-weight:500;color:#495057;font-size:1rem;padding-left:35px;position:relative;display:flex;align-items:center;justify-content:space-between}.checkbox-label:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:20px;height:20px;border:2px solid #e9ecef;border-radius:4px;background:#fff;transition:all .3s ease}.checkbox-item input[type=checkbox]:checked+.checkbox-label:before{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea}.checkbox-label:after{content:"✓";position:absolute;left:5px;top:50%;transform:translateY(-50%);color:#fff;font-weight:700;font-size:12px;opacity:0;transition:all .3s ease}.checkbox-item input[type=checkbox]:checked+.checkbox-label:after{opacity:1}.checkbox-description{font-size:.85rem;color:#6c757d;line-height:1.4;padding-left:35px}.test-haptic-btn{background:linear-gradient(135deg,#28a745,#20c997);color:#fff;border:none;padding:6px 12px;border-radius:6px;font-size:.8rem;cursor:pointer;transition:all .3s ease;margin-left:auto}.test-haptic-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 2px 8px #28a7454d}.test-haptic-btn:disabled{background:#e9ecef;color:#6c757d;cursor:not-allowed}.voice-settings-footer{background:#f8f9fa;padding:20px;display:flex;justify-content:space-between;align-items:center;border-top:1px solid #e9ecef}.reset-settings-btn{background:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:.9rem;cursor:pointer;transition:all .3s ease}.reset-settings-btn:hover{background:#5a6268;transform:translateY(-1px)}.settings-actions{display:flex;gap:12px}.cancel-settings-btn,.save-settings-btn{padding:10px 20px;border-radius:8px;font-size:.9rem;cursor:pointer;transition:all .3s ease;font-weight:500}.cancel-settings-btn{background:transparent;color:#6c757d;border:2px solid #e9ecef}.cancel-settings-btn:hover{background:#f8f9fa;border-color:#dee2e6}.save-settings-btn{background:linear-gradient(135deg,#28a745,#20c997);color:#fff;border:none}.save-settings-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #28a7454d}@media (max-width: 768px){.voice-settings-overlay{padding:15px}.voice-settings-modal{max-width:95%;max-height:85vh}.voice-settings-header{padding:16px}.voice-settings-header h3{font-size:1.3rem}.voice-settings-content{padding:16px;gap:20px}.setting-group{padding:16px}.voice-settings-footer{padding:16px;flex-direction:column;gap:15px}.settings-actions{width:100%;justify-content:space-between}.cancel-settings-btn,.save-settings-btn{flex:1}}@media (max-width: 480px){.voice-settings-overlay{padding:10px}.voice-settings-modal{max-width:100%;max-height:90vh;border-radius:12px}.voice-settings-header{padding:12px 16px}.voice-settings-header h3{font-size:1.2rem}.voice-settings-content{padding:12px;gap:16px}.setting-group{padding:12px}.setting-label{font-size:1rem}.setting-description{font-size:.85rem}.checkbox-label{font-size:.9rem}.checkbox-description{font-size:.8rem}.voice-settings-footer{padding:12px}}.voice-settings-content::-webkit-scrollbar{width:6px}.voice-settings-content::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.voice-settings-content::-webkit-scrollbar-thumb{background:#667eea;border-radius:3px}.voice-settings-content::-webkit-scrollbar-thumb:hover{background:#5a6fd8}.demo-mode-container{width:100%;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;position:fixed;top:0;left:0;right:0;bottom:0;z-index:1000;overflow-y:auto}.demo-subtitle{color:#ffffffe6;margin:0;font-size:1rem;font-weight:300}.demo-main-area{flex:1;display:flex;align-items:center;justify-content:center;padding:20px;position:relative;min-height:400px}.demo-loading{text-align:center;color:#fff;padding:20px}.loading-spinner{width:60px;height:60px;border:4px solid rgba(255,255,255,.3);border-top:4px solid white;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 20px}.demo-loading h2{font-size:1.5rem;margin:0 0 10px;font-weight:600}.demo-loading p{font-size:1rem;opacity:.8;margin:0}.demo-layout{width:100%;max-width:1400px;height:100%;display:flex;flex-direction:column;gap:20px;padding:20px}.demo-avatar-area{flex:1;display:flex;align-items:center;justify-content:center;min-height:400px;position:relative}.demo-avatar-container{position:relative;width:100%;max-width:700px;height:450px;background:#ffffff1a;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border-radius:20px;border:2px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0003;overflow:hidden;transition:all .3s ease}.demo-avatar-container:hover{transform:translateY(-3px);box-shadow:0 12px 40px #0000004d}.demo-avatar-container .avatar-display{width:100%;height:100%;border-radius:18px;background:transparent;box-shadow:none;padding:0}.demo-avatar-container .avatar-video-container{width:100%;height:100%;border-radius:18px;overflow:hidden;position:relative;background:transparent}.demo-avatar-container .avatar-video{width:100%;height:100%;object-fit:cover;border-radius:18px;opacity:0;visibility:visible;position:relative;z-index:1;background-color:transparent}.demo-avatar-container .avatar-background-image{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0;border-radius:18px;background-size:cover;background-position:center}.demo-avatar-container .chroma-key-processor{position:absolute;top:0;left:0;width:100%;height:100%;border-radius:18px;z-index:2;pointer-events:none;opacity:1;mix-blend-mode:normal;display:block!important;visibility:visible!important}.demo-avatar-container .avatar-display .chroma-key-processor{opacity:1!important;transition:opacity .5s ease-in}.demo-avatar-container .avatar-controls,.demo-avatar-container .avatar-status,.demo-avatar-container .avatar-actions,.demo-avatar-container .avatar-info,.demo-avatar-container .avatar-button{display:none!important}.demo-avatar-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000c);padding:20px 15px 15px;border-radius:0 0 18px 18px}.avatar-info{text-align:center;color:#fff}.avatar-info h3{font-size:1.3rem;margin:0 0 6px;font-weight:600;text-shadow:0 2px 4px rgba(0,0,0,.5)}.avatar-status{font-size:.95rem;margin:0;font-weight:500;padding:6px 14px;border-radius:20px;display:inline-block;text-shadow:0 1px 2px rgba(0,0,0,.5);transition:all .3s ease}.avatar-status.status-ready{background:#4caf50cc;color:#fff}.avatar-status.status-disconnected{background:#616161cc;color:#fff;animation:disconnected-pulse 2s infinite}.avatar-status.status-connecting{background:#ffc107cc;color:#fff;animation:pulse-glow 2s infinite}.avatar-status.status-speaking{background:#2196f3cc;color:#fff;animation:speaking-pulse 1s infinite}.avatar-status.status-listening{background:#e91e63cc;color:#fff;animation:listening-pulse 1.5s infinite}.avatar-status.status-processing{background:#9c27b0cc;color:#fff;animation:processing-pulse 1s infinite}.avatar-status.status-error{background:#f44336cc;color:#fff}.avatar-status.status-loading{background:#9e9e9ecc;color:#fff}.interim-transcript{font-size:.9rem;font-style:italic;color:#fffc;margin-top:8px;padding:6px 12px;background:#0000004d;border-radius:15px;border-left:3px solid rgba(233,30,99,.8)}@keyframes disconnected-pulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.02)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 20px #ffc1074d;transform:scale(1)}50%{box-shadow:0 0 30px #ffc10799;transform:scale(1.05)}}@keyframes speaking-pulse{0%,to{box-shadow:0 0 20px #2196f366}50%{box-shadow:0 0 35px #2196f3cc}}@keyframes listening-pulse{0%,to{box-shadow:0 0 25px #e91e6366;transform:scale(1)}50%{box-shadow:0 0 40px #e91e63cc;transform:scale(1.03)}}@keyframes processing-pulse{0%,to{box-shadow:0 0 25px #9c27b066;transform:rotate(0)}50%{box-shadow:0 0 35px #9c27b0cc;transform:rotate(180deg)}}.avatar-placeholder{text-align:center;background:#ffffff26;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border-radius:20px;padding:60px 40px;border:2px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0003;transition:all .3s ease}.avatar-placeholder:hover{transform:translateY(-5px);box-shadow:0 12px 40px #0000004d}.avatar-icon{font-size:4rem;margin-bottom:20px;display:block}.avatar-placeholder h3{color:#fff;font-size:1.8rem;margin:0 0 15px;font-weight:600}.demo-controls{display:flex;flex-direction:column;align-items:center;gap:15px;padding:0 20px;margin-top:-10px}.demo-voice-container{display:flex;justify-content:center;width:100%;order:2}.demo-avatar-controls{display:flex;justify-content:center;width:100%;order:1}.demo-connect-btn,.demo-disconnect-btn{color:#fff;border:none;padding:14px 28px;border-radius:50px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:8px;min-width:180px;justify-content:center}.demo-connect-btn{background:linear-gradient(45deg,#2196f3,#1976d2);box-shadow:0 4px 20px #2196f366}.demo-disconnect-btn{background:linear-gradient(45deg,#f44336,#d32f2f);box-shadow:0 4px 20px #f4433666}.demo-connect-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 25px #2196f380;background:linear-gradient(45deg,#1976d2,#2196f3)}.demo-disconnect-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 25px #f4433680;background:linear-gradient(45deg,#d32f2f,#f44336)}.demo-connect-btn:disabled,.demo-disconnect-btn:disabled{background:#fff3;cursor:not-allowed;transform:none;box-shadow:none}.demo-secondary-controls{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;order:3;margin-top:5px}.demo-info-btn,.demo-voice-settings-btn{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:10px 16px;border-radius:25px;font-size:.9rem;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.demo-info-btn:hover:not(:disabled),.demo-voice-settings-btn:hover:not(:disabled){background:#ffffff4d;transform:translateY(-1px)}.demo-info-btn:disabled,.demo-voice-settings-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.demo-voice-settings-btn{background:linear-gradient(45deg,#667eea,#764ba2);border:1px solid rgba(102,126,234,.3);min-width:50px;display:flex;align-items:center;justify-content:center;gap:3px}.demo-voice-settings-btn:hover:not(:disabled){background:linear-gradient(45deg,#5a6fd8,#6c42a0);box-shadow:0 3px 12px #667eea4d}.demo-footer{text-align:center;padding:12px 15px;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid rgba(255,255,255,.2);display:flex;flex-direction:column;align-items:center;gap:6px;margin-top:10px}.demo-footer p{color:#fffc;margin:0;font-size:.9rem}.demo-status-indicator{display:flex;align-items:center;gap:8px;font-size:.85rem;color:#ffffffb3}.status-dot{width:8px;height:8px;border-radius:50%;background:#4caf50;animation:status-blink 2s infinite}.status-dot.connected{background:#4caf50}.status-dot.disconnected{background:#757575;animation:disconnected-blink 2s infinite}@keyframes disconnected-blink{0%,to{opacity:.4}50%{opacity:1}}@keyframes status-blink{0%,to{opacity:1}50%{opacity:.5}}@media (max-width: 768px){.demo-subtitle{font-size:.9rem}.demo-main-area{padding:12px}.demo-layout{gap:15px;padding:15px}.demo-avatar-area{min-height:350px}.demo-avatar-container{height:380px;max-width:90%}.avatar-info h3{font-size:1.2rem}.avatar-status{font-size:.85rem;padding:5px 12px}.demo-controls{gap:12px;margin-top:-15px}.demo-connect-btn,.demo-disconnect-btn{min-width:160px;padding:12px 24px;font-size:.95rem}.demo-secondary-controls{gap:10px;margin-top:8px}.demo-info-btn,.demo-voice-settings-btn{padding:8px 14px;font-size:.85rem}.voice-config-info{font-size:.7rem;padding:3px 8px}}@media (max-width: 480px){.demo-subtitle{font-size:.8rem}.demo-main-area{padding:8px}.demo-layout{gap:12px;padding:10px}.demo-avatar-area{min-height:300px}.demo-avatar-container{height:320px;max-width:95%;margin:0 auto}.demo-avatar-overlay{padding:15px 12px 12px}.avatar-info h3{font-size:1.1rem;margin-bottom:4px}.avatar-status{font-size:.8rem;padding:4px 10px}.demo-controls{gap:10px;margin-top:-20px;padding:0 10px}.demo-connect-btn,.demo-disconnect-btn{min-width:140px;padding:10px 20px;font-size:.9rem}.demo-secondary-controls{gap:8px;margin-top:10px;flex-direction:row;justify-content:center}.demo-info-btn,.demo-voice-settings-btn{padding:6px 12px;font-size:.8rem;flex:1;max-width:120px}.demo-voice-settings-btn{min-width:40px}.demo-footer{padding:8px 10px;margin-top:5px}.demo-footer p{font-size:.75rem}.demo-status-indicator{font-size:.7rem}.voice-config-info{font-size:.65rem;padding:2px 6px;margin-top:4px}}.demo-avatar-container,.demo-controls,.demo-connect-btn,.demo-disconnect-btn,.demo-info-btn,.demo-voice-settings-btn{transition:all .3s cubic-bezier(.4,0,.2,1)}@media (max-width: 768px) and (orientation: landscape){.demo-layout{flex-direction:row;gap:15px}.demo-avatar-area{flex:0 0 60%;min-height:250px}.demo-avatar-container{height:300px;max-width:100%}.demo-controls{flex:0 0 35%;justify-content:center;margin-top:0;gap:15px}.demo-footer{position:fixed;bottom:0;left:0;right:0;padding:6px 10px;margin-top:0}}.demo-layout{animation:fadeIn .6s ease-out}.demo-avatar-container{animation:fadeIn .8s ease-out .2s both}.demo-controls{animation:fadeIn .8s ease-out .4s both}.voice-config-info{font-size:.75rem;color:#ffffffe6;background:#0006;padding:4px 10px;border-radius:12px;margin-top:6px;display:inline-block;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border:1px solid rgba(255,255,255,.2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.demo-voice-container{display:flex;justify-content:center;width:100%}.demo-voice-container .voice-input-button{background:none!important;border:none!important;padding:0!important;margin:0!important;box-shadow:none!important;min-height:auto!important;display:flex!important;align-items:center!important;justify-content:center!important}.demo-voice-container .voice-button-container{background:none!important;padding:0!important;margin:0!important;display:flex!important;align-items:center!important;justify-content:center!important;flex-direction:row!important;gap:0!important}.demo-voice-container .voice-button{background:linear-gradient(45deg,#4caf50,#45a049)!important;color:#fff!important;border:none!important;padding:18px 40px!important;border-radius:50px!important;font-size:1.2rem!important;font-weight:600!important;cursor:pointer!important;transition:all .3s ease!important;display:flex!important;align-items:center!important;gap:12px!important;box-shadow:0 4px 20px #4caf5066!important;min-width:250px!important;justify-content:center!important;margin:0!important;width:auto!important;height:auto!important}.demo-voice-container .voice-button:hover:not(:disabled){transform:translateY(-3px)!important;box-shadow:0 6px 25px #4caf5080!important;background:linear-gradient(45deg,#45a049,#4caf50)!important}.demo-voice-container .voice-button:disabled{background:#fff3!important;cursor:not-allowed!important;transform:none!important;box-shadow:none!important}.demo-voice-container .voice-button.listening{background:linear-gradient(45deg,#e91e63,#c2185b)!important;animation:voice-pulse 1.5s infinite!important}.demo-voice-container .button-icon{font-size:1.3rem!important;margin:0!important}.demo-voice-container .button-text{font-weight:600!important;margin:0!important}.demo-voice-container .duration-indicator,.demo-voice-container .voice-controls,.demo-voice-container .transcription-preview,.demo-voice-container .progress-container,.demo-voice-container .voice-error,.demo-voice-container .voice-info,.demo-voice-container .final-transcript,.demo-voice-container .interim-transcript,.demo-voice-container .listening-hint,.demo-voice-container .progress-bar,.demo-voice-container .progress-text,.demo-voice-container .error-dismiss,.demo-voice-container .control-button{display:none!important;visibility:hidden!important;opacity:0!important;height:0!important;margin:0!important;padding:0!important;overflow:hidden!important}@keyframes voice-pulse{0%,to{box-shadow:0 0 25px #e91e6366;transform:scale(1)}50%{box-shadow:0 0 40px #e91e63cc;transform:scale(1.05)}}.connection-buttons,.disconnection-buttons{display:flex;flex-direction:column;align-items:center;gap:12px}.demo-simulate-btn{background:linear-gradient(45deg,#ff9800,#f57c00);color:#fff;border:none;padding:12px 24px;border-radius:50px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:8px;min-width:160px;justify-content:center;box-shadow:0 4px 20px #ff980066;border:2px dashed rgba(255,255,255,.3)}.demo-simulate-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 25px #ff980080;background:linear-gradient(45deg,#f57c00,#ff9800)}.demo-simulate-btn:disabled{background:#fff3;cursor:not-allowed;transform:none;box-shadow:none}.simulation-indicator{background:#ff9800cc;color:#fff;padding:4px 12px;border-radius:15px;font-size:.8rem;font-weight:500;text-align:center;border:1px dashed rgba(255,255,255,.4);animation:simulation-pulse 2s infinite}@keyframes simulation-pulse{0%,to{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.02)}}.demo-voice-simulate-btn{background:linear-gradient(45deg,#9c27b0,#673ab7);color:#fff;border:none;padding:18px 40px;border-radius:50px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:12px;box-shadow:0 4px 20px #9c27b066;min-width:250px;justify-content:center;border:2px dashed rgba(255,255,255,.3)}.demo-voice-simulate-btn:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 6px 25px #9c27b080;background:linear-gradient(45deg,#673ab7,#9c27b0)}.demo-voice-simulate-btn:disabled{background:#fff3;cursor:not-allowed;transform:none;box-shadow:none}.demo-simulate-action-btn{background:linear-gradient(45deg,#795548,#5d4037);color:#fff;border:1px dashed rgba(255,255,255,.3);padding:10px 16px;border-radius:25px;font-size:.9rem;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.demo-simulate-action-btn:hover:not(:disabled){background:linear-gradient(45deg,#5d4037,#795548);transform:translateY(-1px);box-shadow:0 3px 12px #7955484d}.demo-simulate-action-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.development-banner{background:linear-gradient(45deg,#ff9800,#f57c00);color:#fff;padding:8px 16px;border-radius:20px;font-size:.85rem;font-weight:500;text-align:center;margin-top:8px;border:2px dashed rgba(255,255,255,.4);animation:dev-banner-pulse 3s infinite}@keyframes dev-banner-pulse{0%,to{opacity:.9;box-shadow:0 2px 10px #ff980033}50%{opacity:1;box-shadow:0 4px 20px #ff980066}}@media (max-width: 768px){.connection-buttons,.disconnection-buttons{gap:10px}.demo-simulate-btn{min-width:140px;padding:10px 20px;font-size:.85rem}.demo-voice-simulate-btn{min-width:200px;padding:14px 32px;font-size:1rem}.simulation-indicator{font-size:.75rem;padding:3px 10px}.development-banner{font-size:.8rem;padding:6px 12px}}@media (max-width: 480px){.demo-simulate-btn{min-width:120px;padding:8px 16px;font-size:.8rem}.demo-voice-simulate-btn{min-width:180px;padding:12px 28px;font-size:.95rem}.demo-simulate-action-btn{padding:8px 12px;font-size:.8rem}.simulation-indicator{font-size:.7rem;padding:2px 8px}.development-banner{font-size:.75rem;padding:5px 10px}}body:has(.demo-mode-container) .nav-buttons,body:has(.demo-mode-container) .app-nav .nav-button,body:has(.demo-mode-container) .header-nav,body:has(.demo-mode-container) .top-navigation{display:none!important;visibility:hidden!important}@media (min-width: 768px) and (max-width: 1024px){.demo-avatar-area{flex:1;display:flex;align-items:flex-end;justify-content:flex-start;min-height:60vh;position:relative;padding-left:40px;padding-bottom:40px}.demo-avatar-container{position:relative;width:100%;max-width:600px;height:400px;background:#ffffff1a;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border-radius:20px;border:2px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0003;overflow:hidden;transition:all .3s ease;align-self:flex-end;margin-left:0;margin-right:auto}.demo-controls{display:flex;flex-direction:column;align-items:center;gap:15px;padding:0 40px;margin-top:-120px;position:relative;z-index:10}.demo-footer{text-align:center;padding:15px 20px;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid rgba(255,255,255,.2);display:flex;flex-direction:column;align-items:center;gap:8px;margin-top:20px;flex-shrink:0;position:relative;z-index:10;min-height:80px}.demo-layout{width:100%;max-width:1024px;height:100%;display:flex;flex-direction:column;gap:20px;padding:20px;min-height:calc(100vh - 40px)}.demo-main-area{flex:1;display:flex;align-items:stretch;justify-content:center;padding:20px;position:relative;min-height:calc(100vh - 140px)}}@media (min-width: 768px) and (max-width: 1024px) and (orientation: landscape){.demo-layout{flex-direction:row;gap:30px;align-items:stretch}.demo-avatar-area{flex:0 0 65%;align-items:center;justify-content:center;padding-left:20px;padding-bottom:20px}.demo-controls{flex:0 0 30%;margin-top:0;justify-content:center;gap:20px}.demo-footer{position:fixed;bottom:0;left:0;right:0;margin-top:0;z-index:1100}}@viewport{width:device-width;zoom:1}:root{touch-action:manipulation}.app-container{display:flex;flex-direction:column;height:100vh;width:100%;margin:0;background-color:var(--color-bg);position:fixed;top:0;left:0;right:0;bottom:0;overflow:hidden}.app-header{padding:12px 16px;background-color:var(--color-brand-bg);border-bottom:1px solid rgba(0,0,0,.1);box-shadow:0 2px 4px #0000000d;position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:center;min-height:60px}.app-header h1{font-size:24px;margin:0;color:#333}.back-to-pos{position:absolute;left:16px;display:flex;align-items:center;background-color:transparent;color:var(--color-text);padding:8px;border-radius:var(--border-radius);text-decoration:none;font-size:0;transition:all .2s ease}.back-to-pos svg{width:24px;height:24px}.app-main{flex:1;overflow:hidden;display:flex;flex-direction:column;padding:0;position:relative;height:calc(100vh - 60px)}.chat-container{display:flex;flex-direction:column;height:100%;background-color:var(--color-bg)}.message-history{flex:1;overflow-y:auto;padding:16px;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column;gap:8px}.chat-input-container{padding:12px 16px;padding-bottom:calc(12px + env(safe-area-inset-bottom));border-top:1px solid rgba(0,0,0,.1);background-color:var(--color-brand-bg);position:sticky;bottom:0;width:100%;z-index:100;display:flex;flex-direction:column;gap:8px}.message-input-wrapper{display:flex;flex-direction:column;gap:8px;width:100%}.message-input{width:100%;font-size:16px;padding:12px 16px;min-height:48px;max-height:120px;border-radius:12px;border:1px solid rgba(0,0,0,.1);background-color:var(--color-input-bg);resize:none;margin:0;line-height:1.4;color:#333}.actions-container{display:flex;align-items:center;gap:8px;padding:0 4px;position:relative;z-index:101}.image-upload-container,.upload-options{display:flex;gap:8px}.upload-button,.camera-button{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background-color:var(--color-input-bg);border-radius:8px;border:1px solid rgba(0,0,0,.1);cursor:pointer;padding:0;color:var(--color-text);transition:all .2s ease}.upload-button:hover,.camera-button:hover{background-color:#0000000d}.send-button{width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:#fff;background-color:var(--color-accent);border-radius:8px;border:none;padding:0;cursor:pointer;transition:all .2s ease;margin-left:auto}.send-button:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.send-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.send-button svg{width:20px;height:20px}.message{padding:12px 16px;border-radius:20px;max-width:85%;word-break:break-word;animation:fadeIn .3s ease;box-shadow:0 1px 2px #0000001a;position:relative;margin:0;color:#333}.message.user{align-self:flex-end;background-color:var(--color-user-message);color:#fff;margin-left:auto;border-bottom-right-radius:4px}.message.assistant{align-self:flex-start;background-color:var(--color-assistant-message);color:var(--color-text);margin-right:auto;border-bottom-left-radius:4px}.message-content{display:flex;flex-direction:column;gap:8px}.message-image{max-width:300px;border-radius:4px;overflow:hidden}.message-image img{width:100%;height:auto;object-fit:contain}.message-timestamp{font-size:11px;margin-top:4px;opacity:.7;text-align:right}.loader{width:18px;height:18px;border:2px solid transparent;border-top-color:var(--color-text);border-radius:50%;animation:spin 1s linear infinite}.image-input{display:none}.image-preview-container{display:flex;align-items:center;gap:8px}.input-image-preview-container{display:flex;align-items:center;gap:8px;margin-top:8px}.input-image-preview{position:relative;width:50px;height:50px;border-radius:8px;overflow:hidden;border:2px solid var(--color-accent);cursor:pointer;transition:all .2s ease}.input-image-preview:hover{transform:scale(1.05);box-shadow:0 4px 12px #00000026}.input-image-preview img{width:100%;height:100%;object-fit:cover}.image-preview{position:relative;width:36px;height:36px;border-radius:4px;overflow:hidden}.image-preview img{width:100%;height:100%;object-fit:cover}.remove-image{position:absolute;top:-6px;right:-6px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;background-color:#ff6b6be6;color:#fff;border-radius:50%;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s ease;border:2px solid white;z-index:10}.remove-image:hover{background-color:#ff6b6b;transform:scale(1.1)}.image-name{font-size:12px;max-width:120px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--color-text);opacity:.8}.error-message{margin-top:8px;color:#ff6b6b;font-size:14px}.structured-data{background-color:#ffffff0d;border-radius:var(--border-radius);padding:16px;margin-top:8px;border-left:3px solid var(--color-accent)}.data-title{font-size:18px;font-weight:600;margin:0 0 12px;color:var(--color-accent)}.data-message{margin-bottom:12px}.data-details{margin:12px 0;padding-left:20px}.data-details li{margin-bottom:8px}.data-note{font-style:italic;margin-top:12px;opacity:.9;border-top:1px solid rgba(255,255,255,.1);padding-top:12px}.data-instruction{font-weight:500;margin-top:12px;color:var(--color-accent)}.empty-state-hint{font-size:14px;opacity:.7;margin-top:8px}.camera-container{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000e6;z-index:1000;display:flex;flex-direction:column;align-items:center;justify-content:center}.camera-preview{max-width:100%;max-height:80vh;border-radius:8px}.capture-button{margin-top:16px;width:64px;height:64px;border-radius:50%;background-color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer}.capture-icon{width:56px;height:56px;border-radius:50%;border:2px solid #444}.close-camera{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;background-color:#00000080;color:#fff;font-size:24px;display:flex;align-items:center;justify-content:center;cursor:pointer}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.speak-button{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background-color:var(--color-accent);color:var(--color-text);border-radius:50%;margin-left:auto;opacity:.7;transition:opacity .2s;align-self:flex-end;margin-top:4px}.speak-button:hover{opacity:1}.speak-button svg{width:14px;height:14px}.message-content{position:relative}.tiempos-entrega{margin-top:16px;background-color:#10a37f1a;padding:12px;border-radius:var(--border-radius);border-left:3px solid var(--color-accent)}.tiempos-entrega h4{margin:0 0 8px;font-size:16px;color:var(--color-accent)}.entrega-details{margin:0;padding-left:20px}.entrega-details li{margin-bottom:4px}.entrega-details strong{font-weight:500}.formatted-response{display:flex;flex-direction:column;gap:0px}.formatted-response p{color:#333}.section-header{font-weight:600;margin-top:12px;margin-bottom:4px;color:var(--color-accent)}.prescription-line{font-family:monospace;background-color:#ffffff0d;padding:4px 8px;border-radius:4px;margin:2px 0}.treatment-option{margin-top:10px;padding-top:8px;border-top:1px solid rgba(255,255,255,.1)}.treatment-option p{font-weight:600;color:var(--color-accent)}.price-line{margin-left:12px;margin-bottom:0;opacity:.9}.message-text{width:100%}.json-editor{width:100%;max-width:900px;margin:0 auto;padding:20px}.editor-instructions{margin-bottom:15px;color:#666}.json-textarea{width:100%;min-height:500px;font-family:Courier New,monospace;font-size:14px;padding:12px;border:1px solid #ccc;border-radius:4px;background-color:#f5f5f5;resize:vertical;white-space:pre;-moz-tab-size:2;tab-size:2}.editor-toolbar{margin-bottom:10px}.format-button{background-color:#f0f0f0;border:1px solid #ccc;padding:8px 12px;border-radius:4px;cursor:pointer}.editor-actions{margin-top:15px;display:flex;align-items:center;gap:15px}.save-button{background-color:var(--color-accent);color:#fff;border:none;padding:10px 20px;border-radius:4px;cursor:pointer;font-weight:500}.save-button:disabled{opacity:.7;cursor:not-allowed}.error-message{color:#e53935;margin-top:10px;padding:10px;background-color:#e539351a;border-radius:4px}.success-message{color:#43a047;padding:10px;background-color:#43a0471a;border-radius:4px}@media (max-width: 768px){.app-header h1{font-size:20px}.message-history{padding:12px 12px 80px}.message{max-width:90%;font-size:15px;padding:10px 14px}.chat-input-container{padding:8px 12px;padding-bottom:calc(80px + env(safe-area-inset-bottom))}.message-input{padding:10px 14px;min-height:44px}.upload-button,.camera-button,.send-button{width:32px;height:32px}.send-button svg{width:18px;height:18px}.disclaimer{margin:8px;font-size:13px}}*{-webkit-tap-highlight-color:transparent}input,textarea{font-size:16px!important}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;opacity:.7;text-align:center}.disclaimer{background-color:#ffc1071a;border-left:3px solid #ffc107;padding:12px 16px;margin:8px;border-radius:var(--border-radius);font-size:14px;color:var(--color-text);display:flex;align-items:center;gap:8px}.disclaimer svg{flex-shrink:0;width:20px;height:20px;color:#ffc107}.image-preview-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000c;z-index:1000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.image-preview-container{position:relative;max-width:90%;max-height:90%;background-color:#fff;border-radius:12px;overflow:hidden;box-shadow:0 20px 60px #0006;animation:scaleIn .2s ease}.image-preview{width:100%;height:auto;max-width:100%;max-height:80vh;object-fit:contain;display:block}.image-preview-close{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:50%;background-color:#000000b3;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:10}.image-preview-close:hover{background-color:#000000e6;transform:scale(1.1)}.image-preview-label{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000c);color:#fff;padding:20px 16px 16px;font-size:14px;font-weight:500;text-align:center}.serie-highlight{background-color:var(--color-accent)!important;color:#fff!important;font-weight:600;padding:6px 12px!important;border-radius:8px!important;margin:4px 0!important}.treatment-name{font-weight:600!important;color:var(--color-accent)!important;font-size:16px;margin:0}.delivery-line{margin-left:12px;color:#10a37f;font-weight:500;background-color:#10a37f1a;padding:4px 8px;border-radius:4px;border-left:3px solid #10A37F}.message.incomplete-response{border-left:4px solid #ff6b6b;background-color:#ff6b6b0d}.incomplete-indicator{display:flex;align-items:center;gap:8px;margin-top:12px;padding:8px 12px;background-color:#ff6b6b1a;border-radius:6px;color:#ff6b6b;font-size:13px;border:1px solid rgba(255,107,107,.2)}.incomplete-indicator svg{flex-shrink:0;width:16px;height:16px}.image-label{background-color:#10a37fe6;color:#fff;font-size:12px;padding:6px 10px;border-radius:6px;position:absolute;bottom:8px;left:8px;font-weight:500;box-shadow:0 2px 8px #0000004d;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:0;transform:translateY(4px);transition:all .2s ease;pointer-events:none}.message-image:hover .image-label{opacity:1;transform:translateY(0)}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@media (max-width: 768px){.image-preview-container{max-width:95%;max-height:95%;margin:16px}.image-preview{max-height:75vh}.image-preview-close{width:40px;height:40px;top:8px;right:8px}.image-preview-label{font-size:13px;padding:16px 12px 12px}}.auto-generated-message svg{flex-shrink:0;width:16px;height:16px;opacity:.6}@media (max-width: 768px){.image-preview-container{max-width:95%;max-height:95%;margin:16px}.image-preview{max-height:75vh}.image-preview-close{width:40px;height:40px;top:8px;right:8px}.image-preview-label{font-size:13px;padding:16px 12px 12px}.auto-generated-message{font-size:12px;padding:6px 10px}}.treatment-detected{background-color:#4a90e21a;border-left:3px solid #4a90e2;padding:8px 12px;margin:8px 0;border-radius:4px;font-weight:500;color:#4a90e2}.auto-generated-message{display:flex;align-items:center;gap:8px;padding:8px 12px;background-color:#4a90e21a;border-radius:6px;color:#4a90e2cc;font-size:13px;font-style:italic;border:1px solid rgba(74,144,226,.2)}.interface-navigation{position:absolute;right:16px;display:flex;gap:8px;align-items:center}.nav-link{padding:8px 16px;border-radius:8px;text-decoration:none;color:var(--color-text);font-size:14px;font-weight:500;transition:all .2s ease;background-color:#ffffff1a;border:1px solid rgba(0,0,0,.1);white-space:nowrap}.nav-link:hover{background-color:#fff3;transform:translateY(-1px)}.nav-link.active{background-color:var(--color-accent);color:#fff;box-shadow:0 2px 4px #0003}.nav-link.active:hover{background-color:var(--color-accent);opacity:.9}@media (max-width: 768px){.interface-navigation{position:static;justify-content:center;margin-top:8px;width:100%}.app-header{flex-direction:column;gap:8px;min-height:auto;padding:12px 16px 16px}.back-to-pos{position:absolute;top:12px;left:16px}.nav-link{font-size:13px;padding:6px 12px}}.virtual-assistant-content{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:30px}.avatar-container{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 10px #0000001a;min-height:400px;display:flex;align-items:center;justify-content:center}.avatar-placeholder{text-align:center;padding:40px;border:2px dashed #bdc3c7;border-radius:8px;background:#ecf0f1;width:100%}.avatar-placeholder h3{color:#34495e;margin-bottom:10px}.avatar-placeholder p{color:#7f8c8d;margin-bottom:15px}.avatar-status{font-weight:700;color:#27ae60;padding:8px 16px;background:#d5f4e6;border-radius:20px;display:inline-block}.voice-input-container{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 10px #0000001a;text-align:center;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:20px}.record-button{background:#3498db;color:#fff;border:none;padding:20px 40px;border-radius:50px;font-size:18px;cursor:pointer;transition:all .3s ease;min-width:200px;box-shadow:0 4px 15px #3498db4d}.record-button:hover{background:#2980b9;transform:translateY(-2px);box-shadow:0 6px 20px #3498db66}.record-button.recording{background:#e74c3c;animation:pulse 1s infinite}.record-button.recording:hover{background:#c0392b}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.recording-status{font-size:16px;color:#7f8c8d;font-weight:500}.transcription-container{grid-column:1 / -1;background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 10px #0000001a;transition:all .3s ease}.transcription-container.avatar-speaking{opacity:.7;transform:scale(.98);pointer-events:none}.transcription-container.avatar-speaking .messages-container{filter:blur(1px)}.transcription-container h4{color:#2c3e50;margin-bottom:15px;border-bottom:2px solid #ecf0f1;padding-bottom:10px}.transcription-area{max-height:300px;overflow-y:auto;padding:15px;background:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.user-message,.assistant-message{margin-bottom:15px;padding:12px;border-radius:8px;line-height:1.5}.user-message{background:#e3f2fd;border-left:4px solid #2196f3}.assistant-message{background:#f3e5f5;border-left:4px solid #9c27b0}.placeholder{text-align:center;color:#95a5a6;font-style:italic;padding:40px}.test-controls{background:#fff3cd;border:1px solid #ffeaa7;border-radius:8px;padding:20px;margin-top:20px}.test-controls h4{color:#856404;margin-bottom:15px}.test-controls button{background:#ffc107;color:#212529;border:none;padding:8px 16px;margin:5px;border-radius:5px;cursor:pointer;font-size:14px;transition:background .3s ease}.test-controls button:hover{background:#e0a800}@media (max-width: 768px){.virtual-assistant-content{grid-template-columns:1fr}.avatar-container{min-height:250px}.record-button{padding:15px 30px;font-size:16px;min-width:150px}}.service-tester{max-width:1200px;margin:0 auto;padding:20px;background:var(--background-color, #f8f9fa)}.test-section{background:#fff;border-radius:12px;padding:24px;margin-bottom:24px;box-shadow:0 2px 10px #0000001a}.test-section h3{color:#2c3e50;margin-bottom:20px;border-bottom:2px solid #ecf0f1;padding-bottom:10px}.status-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:20px;padding:16px;background:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.status-item strong{color:#495057;font-size:14px}.status-item span{font-weight:600;font-size:14px}.test-controls{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:20px}.test-button{padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:8px;min-width:140px;justify-content:center}.test-button:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.test-button.primary{background:#007bff;color:#fff}.test-button.primary:hover:not(:disabled){background:#0056b3;transform:translateY(-2px)}.test-button.secondary{background:#6c757d;color:#fff}.test-button.secondary:hover:not(:disabled){background:#545b62;transform:translateY(-2px)}.test-button.success{background:#28a745;color:#fff}.test-button.success:hover:not(:disabled){background:#1e7e34;transform:translateY(-2px)}.test-button.warning{background:#ffc107;color:#212529}.test-button.warning:hover:not(:disabled){background:#e0a800;transform:translateY(-2px)}.test-button.danger{background:#dc3545;color:#fff}.test-button.danger:hover:not(:disabled){background:#c82333;transform:translateY(-2px)}.test-results{margin-top:20px}.result-box{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:16px;margin-bottom:12px}.result-box strong{color:#495057;display:block;margin-bottom:8px}.transcript-box{background:#fff;border:1px solid #dee2e6;border-radius:6px;padding:12px;min-height:60px;font-family:Courier New,monospace;font-size:14px;color:#495057;white-space:pre-wrap;word-break:break-word}.error-box{background:#f8d7da;border:1px solid #f5c6cb;border-radius:8px;padding:12px;color:#721c24}.error-box strong{display:block;margin-bottom:4px}.avatar-video-container{position:relative;width:100%;height:100%;flex:1;display:flex;align-items:center;justify-content:center;background:#000;border-radius:12px;overflow:hidden;margin-bottom:15px;min-height:300px}.avatar-video{width:auto!important;height:100%!important;object-fit:contain!important;border-radius:12px;background:transparent;position:relative;z-index:1;display:block;margin:0 auto}.avatar-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;min-height:50px;padding:12px;background:#f8f9fa;border-radius:8px;flex-wrap:nowrap;gap:12px;overflow-x:auto;overflow-y:hidden}.avatar-status{display:flex;gap:15px;align-items:center;flex-shrink:0}.avatar-actions{display:flex!important;flex-direction:row!important;gap:8px;align-items:center;flex-shrink:0}.video-placeholder{position:absolute;color:#fff;font-size:18px;text-align:center;background:#000000b3;padding:20px;border-radius:8px;pointer-events:none}.instructions-section{background:#e7f3ff;border:1px solid #b8daff;border-radius:8px;padding:20px;margin-top:24px}.instructions-section h4{color:#004085;margin-bottom:12px}.instructions-section ol{color:#004085;margin:0;padding-left:20px}.instructions-section li{margin-bottom:8px;line-height:1.5}.instructions-section strong{font-weight:600}@media (max-width: 768px){.service-tester{padding:12px}.test-section{padding:16px;margin-bottom:16px}.status-info{grid-template-columns:1fr;gap:8px}.test-controls{flex-direction:column}.test-button{width:100%;min-width:auto}.avatar-video{height:200px}.instructions-section{padding:16px}}.avatar-display{background:#fff;border-radius:12px;padding:20px;min-height:400px;height:calc(100% - 300px);display:flex;flex-direction:column;position:relative;padding-bottom:0!important;background:transparent!important;width:100%}.avatar-video-hidden{display:none!important}.avatar-canvas{width:100%;height:300px;border-radius:8px;background:#000;object-fit:cover;margin-bottom:15px}.avatar-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;min-height:50px;padding:12px;background:#f8f9fa;border-radius:8px}.avatar-status{display:flex;gap:15px;align-items:center}.status-indicator{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;flex-shrink:0}.status-indicator.connected{color:#28a745}.status-indicator.disconnected{color:#6c757d}.speaking-indicator{color:#17a2b8;font-size:14px;animation:pulse 1.5s infinite ease-in-out;flex-shrink:0}.avatar-button{padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:6px;white-space:nowrap;flex-shrink:0}.avatar-button.connect{background:#28a745;color:#fff}.avatar-button.connect:hover:not(:disabled){background:#218838;transform:translateY(-1px)}.avatar-button.disconnect{background:#dc3545;color:#fff}.avatar-button.disconnect:hover{background:#c82333;transform:translateY(-1px)}.avatar-button:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.avatar-info{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#e9ecef;border-radius:6px;font-size:13px;color:#495057}.avatar-name{font-weight:600}.avatar-error{margin-top:10px;padding:10px;background:#f8d7da;border:1px solid #f5c6cb;border-radius:6px;color:#721c24;font-size:14px}.voice-input-button{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 10px #0000001a;min-height:300px;display:flex;flex-direction:column;gap:15px}.voice-button-container{display:flex;flex-direction:column;align-items:center;gap:10px}.voice-button{width:120px;height:120px;border-radius:50%;border:none;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;font-size:14px;font-weight:600;color:#fff;box-shadow:0 4px 20px #0003;position:relative;overflow:hidden}.voice-button:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 8px 25px #0000004d}.voice-button.listening{animation:voice-pulse 1.5s infinite}.voice-button:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.button-icon{font-size:32px}.button-text{font-size:12px;text-align:center;line-height:1.2}.duration-indicator{font-size:14px;font-weight:500;color:#495057;background:#ffffffe6;padding:4px 12px;border-radius:20px;box-shadow:0 2px 8px #0000001a}.voice-controls{display:flex;justify-content:center;gap:10px}.control-button{padding:8px 16px;border:none;border-radius:20px;font-size:13px;font-weight:500;cursor:pointer;transition:all .3s ease}.control-button.abort{background:#dc3545;color:#fff}.control-button.abort:hover{background:#c82333;transform:translateY(-1px)}.transcription-preview{flex:1;min-height:100px}.final-transcript,.interim-transcript{margin-bottom:12px;padding:12px;border-radius:8px;border-left:4px solid}.final-transcript{background:#d4edda;border-left-color:#28a745}.interim-transcript{background:#fff3cd;border-left-color:#ffc107}.transcript-text{margin-top:8px;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:15px;line-height:1.4}.transcript-text.final{color:#155724;font-weight:500}.transcript-text.interim{color:#856404;font-style:italic}.listening-hint{text-align:center;color:#6c757d;font-style:italic;padding:20px;background:#f8f9fa;border-radius:8px;border:2px dashed #dee2e6}.progress-container{position:relative;background:#e9ecef;border-radius:10px;height:20px;overflow:hidden}.progress-bar{height:100%;transition:width .3s ease;border-radius:10px}.progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:12px;font-weight:600;color:#495057}.voice-error{background:#f8d7da;border:1px solid #f5c6cb;border-radius:8px;padding:12px;color:#721c24;display:flex;justify-content:space-between;align-items:center}.error-dismiss{background:none;border:none;color:#721c24;cursor:pointer;font-size:18px;padding:0;margin-left:10px}.voice-info{background:#d1ecf1;border:1px solid #bee5eb;border-radius:8px;padding:12px;color:#0c5460}.voice-info p{margin:4px 0 0;font-size:13px}@keyframes voice-pulse{0%{transform:scale(1);box-shadow:0 4px 20px #e74c3c4d}50%{transform:scale(1.05);box-shadow:0 8px 30px #e74c3c80}to{transform:scale(1);box-shadow:0 4px 20px #e74c3c4d}}.transcription-display{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;display:flex;flex-direction:column;height:500px;overflow:hidden}.transcription-header{padding:16px 20px;border-bottom:1px solid #e9ecef;background:#f8f9fa;border-radius:12px 12px 0 0}.transcription-header h3{margin:0 0 8px;color:#2c3e50;font-size:18px}.conversation-status{font-size:14px}.status-speaking{color:#17a2b8;font-weight:500}.status-listening{color:#ffc107;font-weight:500}.messages-container{flex:1;overflow-y:auto;padding:16px 20px;scroll-behavior:smooth}.empty-conversation{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;padding-top:100px;color:#6c757d}.empty-icon{font-size:48px;margin-bottom:16px}.empty-conversation h4{color:#495057;margin-bottom:8px}.empty-conversation p{margin-bottom:20px;max-width:300px}.conversation-tips{background:#f8f9fa;padding:16px;border-radius:8px;border:1px solid #e9ecef;text-align:left;max-width:280px}.conversation-tips ul{margin:8px 0 0;padding-left:20px}.conversation-tips li{margin-bottom:4px;font-size:14px}.message{display:flex;gap:12px;margin-bottom:16px;animation:messageSlideIn .3s ease}.message-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.user-message .message-avatar{background:#007bff;color:#fff}.assistant-message .message-avatar{background:#28a745;color:#fff}.message-content{flex:1;min-width:0}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.message-sender{font-weight:600;font-size:14px;color:#495057}.message-timestamp{font-size:12px;color:#6c757d}.message-body{background:#f8f9fa;padding:12px;border-radius:8px;border:1px solid #e9ecef}.user-message .message-body{background:#e3f2fd;border-color:#bbdefb}.assistant-message .message-body{background:#f3e5f5;border-color:#e1bee7}.structured-message .message-title{color:#495057;font-size:16px;margin:0 0 8px}.structured-message .message-text{margin:0 0 12px;line-height:1.5}.message-details{margin:8px 0;padding-left:20px}.message-details li{margin-bottom:4px;line-height:1.4}.message-note{margin:12px 0 0;color:#6c757d;font-size:14px;border-top:1px solid #dee2e6;padding-top:8px}.plain-message{line-height:1.5;word-wrap:break-word}.current-input .message-body{background:#fff3cd;border-color:#ffeaa7}.interim-input{color:#856404;font-style:italic}.typing-cursor{animation:blink 1s infinite;font-weight:700}.speaking .message-body{background:#d1ecf1;border-color:#bee5eb}.typing-indicator{display:flex;align-items:center;gap:8px}.typing-indicator span:not(.typing-text){width:8px;height:8px;border-radius:50%;background:#17a2b8;animation:typingDots 1.4s infinite ease-in-out}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}.typing-text{color:#17a2b8;font-style:italic;margin-left:4px}.scroll-to-bottom{position:absolute;bottom:80px;right:20px;background:#007bff;color:#fff;border:none;border-radius:20px;padding:8px 16px;font-size:14px;cursor:pointer;box-shadow:0 2px 10px #0003;transition:all .3s ease;z-index:10}.scroll-to-bottom:hover{background:#0056b3;transform:translateY(-2px)}.transcription-footer{padding:12px 20px;border-top:1px solid #e9ecef;background:#f8f9fa;border-radius:0 0 12px 12px}.message-count{font-size:12px;color:#6c757d;text-align:center}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}@keyframes typingDots{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-10px)}}@media (max-width: 768px){.avatar-canvas{height:200px}.avatar-controls{flex-direction:column;gap:10px;align-items:stretch;max-width:93vw;overflow-x:scroll}.voice-button{width:100px;height:100px}.button-icon{font-size:28px}.button-text{font-size:11px}.transcription-display{height:400px}.message{gap:8px}.message-avatar{width:28px;height:28px;font-size:14px}}.assistant-controls{background:#fff;color:#222;border-radius:14px;box-shadow:0 2px 10px #00000012;padding:18px 12px;margin-top:18px}.control-section{margin-bottom:20px}.control-section h4{color:#1765c1;margin-bottom:12px;border-bottom:2px solid #ecf0f1;padding-bottom:8px}.control-buttons{display:flex;gap:10px;flex-wrap:wrap}.control-btn{padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:6px}.control-btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.control-btn.clear{background:#dc3545;color:#fff}.control-btn.clear:hover:not(:disabled){background:#c82333;transform:translateY(-1px)}.control-btn.demo{background:#17a2b8;color:#fff}.control-btn.demo:hover:not(:disabled){background:#138496;transform:translateY(-1px)}.control-btn.speak{background:#28a745;color:#fff}.control-btn.speak:hover:not(:disabled){background:#218838;transform:translateY(-1px)}.system-status{background:#fff;color:#222;border-radius:10px;box-shadow:0 1px 6px #0000000d;padding:12px 8px;margin-bottom:12px}.status-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#fff;border-radius:6px;box-shadow:0 1px 3px #0000001a}.status-label{font-weight:600;color:#222;font-size:14px}.status-value{font-weight:500;font-size:14px}.status-value.connected{color:#28a745}.usage-info{background:#e7f3ff;border:1px solid #b8daff;border-radius:8px;padding:16px}.usage-info h5{color:#1765c1;margin:0 0 12px;font-size:16px}.usage-info ol{color:#004085;margin:0;padding-left:20px}.usage-info li{margin-bottom:6px;line-height:1.4}.virtual-assistant-content{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.transcription-container{grid-column:1 / -1}@media (max-width: 768px){.control-buttons{flex-direction:column}.control-btn{width:100%;justify-content:center}.system-status{grid-template-columns:1fr;gap:8px}.usage-info{padding:12px}.virtual-assistant-content{grid-template-columns:1fr}}.flow-status{margin-top:12px;padding:10px;background:#007bff1a;border:1px solid rgba(0,123,255,.3);border-radius:6px;font-size:14px;line-height:1.4}.flow-status strong{color:#0056b3}.status-value{font-weight:500;font-size:14px;transition:all .3s ease}.status-value.connected{color:#28a745;text-shadow:0 0 4px rgba(40,167,69,.3)}.status-value.disconnected{color:#6c757d}.control-btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important;position:relative}.control-btn.demo:disabled:after,.control-btn.speak:disabled:after{content:"";position:absolute;top:50%;left:50%;width:16px;height:16px;margin:-8px 0 0 -8px;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.usage-info h5{color:#1765c1;margin:0 0 12px;font-size:16px;display:flex;align-items:center;gap:8px}.usage-info ol li{margin-bottom:8px;line-height:1.5;position:relative;padding-left:4px}.usage-info ol li strong{color:#0056b3}.system-status{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;padding:16px;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:8px;border:1px solid #e9ecef;margin-bottom:20px;position:relative}.system-status:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#28a745,#17a2b8,#ffc107);border-radius:8px 8px 0 0}.status-item{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:#fff;border-radius:6px;box-shadow:0 1px 3px #0000001a;transition:all .3s ease}.status-item:hover{transform:translateY(-1px);box-shadow:0 2px 6px #00000026}.avatar-canvas{width:100%;height:300px;border-radius:8px;background:#000;object-fit:cover;margin-bottom:15px;border:2px solid #e9ecef;transition:border-color .3s ease}.avatar-display:has(.status-indicator.connected) .avatar-canvas{border-color:#28a745;box-shadow:0 0 12px #28a7454d}.avatar-display:has(.speaking-indicator) .avatar-canvas{border-color:#17a2b8;box-shadow:0 0 12px #17a2b866}.voice-button.listening{animation:voice-pulse 1.5s infinite;box-shadow:0 8px 25px #e74c3c66}.voice-button:not(:disabled):hover{transform:translateY(-3px) scale(1.02);box-shadow:0 12px 30px #0000004d}.conversation-status{font-size:14px;display:flex;align-items:center;gap:8px}.status-speaking{color:#17a2b8;font-weight:500;animation:pulse 1.5s infinite}.status-listening{color:#ffc107;font-weight:500;animation:pulse 2s infinite}.status-idle{color:#6c757d}.message{display:flex;gap:12px;margin-bottom:16px;animation:messageSlideIn .4s ease-out}.message.current-input{animation:messageSlideIn .2s ease-out}.message.speaking{animation:messageSlideIn .3s ease-out,speakingPulse 2s infinite .3s}@keyframes speakingPulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.empty-conversation{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;color:#6c757d;animation:fadeIn .5s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.empty-icon{font-size:48px;margin-bottom:16px;animation:bounce 2s infinite}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}@media (max-width: 768px){.flow-status{font-size:13px;padding:8px}.system-status{grid-template-columns:1fr}.status-item{padding:8px 12px}.conversation-status{flex-direction:column;align-items:flex-start;gap:4px}}.flow-diagnostic{max-width:1200px;margin:0 auto;padding:20px;background:var(--background-color, #f8f9fa)}.diagnostic-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding:20px;background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a}.diagnostic-header h3{color:#2c3e50;margin:0}.diagnostic-actions{display:flex;gap:10px}.diagnostic-btn{padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:6px}.diagnostic-btn.test{background:#17a2b8;color:#fff}.diagnostic-btn.test:hover:not(:disabled){background:#138496;transform:translateY(-1px)}.diagnostic-btn.refresh{background:#6c757d;color:#fff}.diagnostic-btn.refresh:hover{background:#545b62;transform:translateY(-1px)}.diagnostic-btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.diagnostic-section{background:#fff;border-radius:12px;padding:20px;margin-bottom:20px;box-shadow:0 2px 10px #0000001a}.diagnostic-section h4{color:#2c3e50;margin:0 0 16px;border-bottom:2px solid #ecf0f1;padding-bottom:8px}.diagnostic-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:12px}.diagnostic-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background:#f8f9fa;border-radius:6px;border:1px solid #e9ecef}.diagnostic-item strong{color:#495057;font-size:14px}.diagnostic-item span{font-size:14px;font-weight:500}.diagnostic-details{background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;padding:12px;font-family:Courier New,monospace;font-size:13px;max-height:300px;overflow-y:auto}.diagnostic-details pre{margin:0;white-space:pre-wrap;word-wrap:break-word}.diagnostic-details>div{margin-bottom:8px;line-height:1.4}.test-results{display:flex;flex-direction:column;gap:12px}.test-result{border:1px solid #e9ecef;border-radius:6px;padding:12px;background:#f8f9fa}.test-result strong{color:#495057;display:block;margin-bottom:8px}.test-details{background:#fff;border:1px solid #dee2e6;border-radius:4px;padding:8px}.test-details pre{margin:0;font-size:12px;max-height:200px;overflow-y:auto}.diagnostic-footer{text-align:center;padding:12px;background:#e9ecef;border-radius:6px;margin-top:20px}.diagnostic-footer small{color:#6c757d;font-size:12px}.diagnostic-link{margin-top:12px;text-align:center}.diagnostic-link-btn{background:linear-gradient(135deg,#ffc107,#fd7e14);color:#212529;border:none;padding:10px 20px;border-radius:20px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #ffc1074d}.diagnostic-link-btn:hover{background:linear-gradient(135deg,#e0a800,#dc6502);transform:translateY(-2px);box-shadow:0 4px 12px #ffc10766}@media (max-width: 768px){.flow-diagnostic{padding:12px}.diagnostic-header{flex-direction:column;gap:12px;text-align:center}.diagnostic-actions{width:100%;justify-content:center}.diagnostic-grid{grid-template-columns:1fr}.diagnostic-item{flex-direction:column;gap:8px;text-align:center}.toggle-button{min-width:auto;flex:1}.view-toggle{gap:4px}}.mic-btn{background:transparent;border:1px solid transparent;width:44px;height:44px;border-radius:50%;color:#5f6368;font-size:22px;padding:0}.mic-btn:hover:not(:disabled){background-color:#0000000d}.chat-controls-bar .chat-input{flex:1;border:none;outline:none;font-size:1rem;margin-bottom:0;height:40px!important;border-radius:24px;background:var(--color-input-bg, #ffffff);color:var(--color-text, #212529);box-shadow:0 1px 2px #0000000d inset;border:1px solid #dadce0}.chat-input:focus{border-color:var(--color-accent, #4a90e2);box-shadow:0 0 0 2px rgba(var(--color-accent),.2)}.send-btn{width:44px;height:44px;border-radius:50%;background:transparent;color:var(--color-accent, #4a90e2);border:none;font-size:22px;padding:0}.send-btn:hover:not(:disabled){background-color:rgba(var(--color-accent),.1)}@media (max-width: 768px){.controls-area{padding-bottom:80px}.chat-controls-bar{position:fixed;left:0;right:0;bottom:0;margin:0;border-radius:0;box-shadow:0 -2px 5px #00000014;padding:8px 10px;background:#fff;z-index:1100}.chat-history-panel{padding-bottom:70px}.mic-btn,.send-btn{width:40px;height:40px;font-size:20px}.chat-input{font-size:.95rem;padding:8px 12px}}.controls-area{width:100%;min-width:0;display:flex;flex-direction:column;gap:0}@media (max-width: 900px){.assistant-layout{grid-template-columns:1fr;gap:0}.controls-area,.avatar-area{width:100%}}.virtual-assistant-container{width:100%;max-width:100vw;margin:0 auto;padding:0;min-height:100vh;background:var(--color-bg, #f8f9fa);display:flex;flex-direction:column;overflow:hidden}.virtual-assistant-header{text-align:center;padding:12px 20px;background:var(--color-brand-bg, #ffffff);border-bottom:1px solid #dadce0;box-shadow:0 1px 3px #0000000a;position:sticky;top:0;z-index:1000;transition:all .3s ease;cursor:pointer}.virtual-assistant-header.collapsed{padding:8px 20px}.virtual-assistant-header.collapsed h2{margin:0;font-size:1.1rem}.virtual-assistant-header.collapsed p,.virtual-assistant-header.collapsed .view-toggle{display:none}.virtual-assistant-header h2{color:var(--color-text, #212529);margin-bottom:4px;font-size:1.25rem;transition:all .3s ease}.virtual-assistant-header p{color:#5f6368;margin:0 0 8px;font-size:.875rem;transition:all .3s ease}.view-toggle{display:flex;gap:8px;justify-content:center;margin-top:8px;flex-wrap:wrap}.toggle-button{padding:6px 12px;border:1px solid #dadce0;border-radius:var(--border-radius, 12px);background:var(--color-brand-bg, #ffffff);color:var(--color-accent, #4a90e2);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease-in-out}.toggle-button:hover{background:#f1f3f5;border-color:#c6c9cc}.toggle-button.active{background:var(--color-accent, #4a90e2);color:var(--color-brand-white, #ffffff);border-color:var(--color-accent, #4a90e2);box-shadow:0 1px 2px #0000001a}.toggle-button.active:hover{opacity:.9}.assistant-layout{display:grid;grid-template-columns:auto;gap:0;width:100%;flex-grow:1;overflow:hidden;height:calc(100vh - 100px)}.avatar-area{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#fff;position:relative;min-height:300px}.avatar-display .avatar-video{width:100%;flex-grow:1;object-fit:contain;border-radius:0;background-color:#000}.avatar-display .avatar-controls{display:flex;flex-direction:row;flex-wrap:nowrap!important;overflow-x:auto;overflow-y:hidden;align-items:stretch;gap:8px;min-width:0}.avatar-display .avatar-controls::-webkit-scrollbar{height:6px;background:#f0f0f0;border-radius:6px}.avatar-display .avatar-controls::-webkit-scrollbar-thumb{background:#b3b3b3;border-radius:6px}@media (max-width: 768px){.avatar-display .avatar-controls{flex-direction:row;gap:6px;padding:3px 8px;border-radius:10px 10px 0 0;font-size:.85rem}}.avatar-display .avatar-button{flex:0 0 auto}.avatar-display .avatar-button.connect{background:linear-gradient(90deg,#28a745,#4a90e2)}.avatar-display .avatar-button.disconnect{background:linear-gradient(90deg,#ffb3b3,#fdd);color:#b71c1c}.avatar-display .avatar-button.interrupt{background:linear-gradient(90deg,#fff3cd,#ffe082);color:#b8860b}@media (max-width: 768px){.avatar-display .avatar-button{min-width:80px;font-size:.95rem;padding:6px 12px}}.avatar-display .avatar-status{position:absolute;top:12px;left:12px;z-index:10;backdrop-filter:blur(8px);background:#fff3;-webkit-backdrop-filter:blur(8px);box-shadow:0 2px 8px #50e3c20a;color:#222;border:none;border-radius:18px;padding:6px 16px;font-size:1rem;font-weight:600;display:flex;align-items:center;gap:8px;min-height:32px;min-width:80px;white-space:nowrap}@media (max-width: 768px){.avatar-display .avatar-status{font-size:.85rem!important;padding:4px 10px;top:6px;left:6px;min-height:24px;min-width:60px}}.avatar-display .avatar-error{position:absolute;bottom:60px;left:10px;right:10px;background-color:#dc3545cc;color:#fff;padding:8px;border-radius:var(--border-radius);z-index:10;font-size:.8rem;text-align:center}.controls-area{background:var(--color-sidebar, #ffffff);color:var(--color-text, #212529);padding:0;display:flex!important;flex-direction:column;height:100%;max-height:72vh;border-left:1px solid #dadce0;box-shadow:-2px 0 5px #0000000d;overflow:hidden;min-height:300px}.chat-history-panel{flex-grow:1;overflow-y:auto;padding:16px;background:var(--color-sidebar, #ffffff);min-height:200px}.chat-controls-bar{background:#f1f3f5!important;padding:10px 16px;border-top:1px solid #dadce0;display:flex!important;align-items:center;gap:10px;min-height:56px!important;max-height:56px;flex-shrink:0;width:100%;box-sizing:border-box;position:relative}.chat-controls-bar .voice-input-button{display:inline-flex!important;padding:0!important;min-height:auto!important;max-height:40px!important;width:auto!important;background:none!important;border-radius:0!important;box-shadow:none!important}.chat-controls-bar .voice-input-button .voice-button-container{display:flex!important;flex-direction:row!important;align-items:center!important;gap:0!important}.chat-controls-bar .mic-btn .voice-button,.chat-controls-bar .voice-input-button .voice-button{width:40px!important;height:40px!important;padding:0!important;background-color:#fff!important;border:1px solid #dadce0!important;box-shadow:0 1px 1px #0000000a!important;color:#5f6368!important;border-radius:50%!important;margin:0!important;display:flex!important;align-items:center!important;justify-content:center!important}.chat-controls-bar .mic-btn .voice-button:hover:not(:disabled),.chat-controls-bar .voice-input-button .voice-button:hover:not(:disabled){background-color:#f8f9fa!important;border-color:#c6c9cc!important}.chat-controls-bar .mic-btn .voice-button.listening,.chat-controls-bar .voice-input-button .voice-button.listening{background-color:#ea4335!important;color:#fff!important;border-color:#ea4335!important}.chat-controls-bar .mic-btn .voice-button .button-icon,.chat-controls-bar .voice-input-button .voice-button .button-icon{font-size:20px!important;margin:0!important}.chat-controls-bar .mic-btn .voice-button .button-text,.chat-controls-bar .voice-input-button .voice-button .button-text,.chat-controls-bar .mic-btn .duration-indicator,.chat-controls-bar .mic-btn .voice-controls,.chat-controls-bar .mic-btn .transcription-preview,.chat-controls-bar .mic-btn .progress-container,.chat-controls-bar .mic-btn .voice-error,.chat-controls-bar .mic-btn .voice-info,.chat-controls-bar .voice-input-button .duration-indicator,.chat-controls-bar .voice-input-button .voice-controls,.chat-controls-bar .voice-input-button .transcription-preview,.chat-controls-bar .voice-input-button .progress-container,.chat-controls-bar .voice-input-button .voice-error,.chat-controls-bar .voice-input-button .voice-info,.chat-controls-bar .voice-input-button .final-transcript,.chat-controls-bar .voice-input-button .interim-transcript,.chat-controls-bar .voice-input-button .listening-hint{display:none!important}.chat-input{flex:1;border:none;outline:none;font-size:.95rem;padding:10px 16px;border-radius:20px;background:var(--color-input-bg, #ffffff);color:var(--color-text, #212529);border:1px solid #dadce0;height:40px;box-sizing:border-box;display:block!important}.chat-input:focus{border-color:var(--color-accent, #4a90e2);box-shadow:0 0 0 1px var(--color-accent, #4a90e2)}.chat-input:disabled{background:#e9ecef;cursor:not-allowed}.send-btn{width:40px;height:40px;border-radius:50%;background:transparent;color:var(--color-accent, #4a90e2);border:none;font-size:20px;padding:0;display:flex!important;align-items:center;justify-content:center;flex-shrink:0}.send-btn:hover:not(:disabled){background-color:#4a90e21a}.send-btn:disabled{color:#bdc1c6;cursor:not-allowed}.help-btn{width:40px;height:40px;border-radius:50%;background:transparent;color:#5f6368;border:none;font-size:22px;padding:0;display:flex!important;align-items:center;justify-content:center;flex-shrink:0}.help-btn:hover{background-color:#0000000d}.help-modal-overlay{background-color:#0009;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.help-modal{background:var(--color-sidebar, #ffffff);border-radius:var(--border-radius, 12px);box-shadow:0 4px 20px #00000026;max-width:500px;padding:24px}.close-help-modal{background:#e9ecef;border-radius:50%;width:32px;height:32px;color:#5f6368}.close-help-modal:hover{background:#dadce0}@media (min-width: 769px){.assistant-layout{grid-template-columns:1fr 380px;height:calc(100vh - 70px)}.controls-area{border-left:1px solid #dadce0}.chat-controls-bar{position:static;box-shadow:none;border-top:1px solid #dadce0}.chat-history-panel{padding-bottom:0}}@media (max-width: 768px){.virtual-assistant-header{display:none}.assistant-layout{height:100vh;display:flex!important;flex-direction:column!important}.avatar-area{flex:1 1 50vh!important;min-height:0!important;max-height:50vh!important;overflow:hidden;padding:10px}.controls-area{flex:1 1 50vh!important;min-height:0!important;max-height:50vh!important;overflow:auto;border-left:none;box-shadow:none;display:flex!important;flex-direction:column!important}.avatar-video-container{min-height:200px;max-width:93vw;height:auto;flex:none;margin:auto;aspect-ratio:16/9}.avatar-display{height:100%;width:100%;display:flex;flex-direction:column;padding:0}.avatar-controls{flex-direction:row!important;gap:6px;padding:8px;border-radius:8px;font-size:.85rem;overflow-x:auto;overflow-y:hidden;flex-wrap:nowrap;justify-content:flex-start;margin-bottom:10px}.avatar-status{gap:8px;flex-shrink:0}.avatar-actions{display:flex!important;flex-direction:row!important;gap:6px;align-items:center;flex-shrink:0}.avatar-button,.status-indicator{height:34px;min-height:34px;font-size:.9rem;padding:0 10px;min-width:80px;flex-shrink:0;white-space:nowrap}.chat-history-panel{padding:10px 10px 70px;flex-grow:1;min-height:150px}.transcription-display .message{max-width:95%;font-size:.9rem}.chat-controls-bar{position:fixed!important;left:0;right:0;bottom:0;border-radius:0;box-shadow:0 -2px 5px #00000014;padding:8px 10px;background:#fff;z-index:1100;min-height:56px;display:flex!important;border-top:1px solid #dadce0}.mic-btn .voice-button,.send-btn,.help-btn{width:38px;height:38px;font-size:18px}.chat-controls-bar .mic-btn .voice-button .button-icon{font-size:18px!important}.chat-input{font-size:.9rem;padding:8px 12px}.transcription-header{display:none!important;visibility:hidden!important;height:0!important;min-height:0!important;max-height:0!important;padding:0!important;border:none!important;position:absolute!important}}.service-tester,.flow-diagnostic{padding:16px;background-color:var(--color-bg);height:100%;overflow-y:auto}.test-section,.diagnostic-section{background:var(--color-sidebar, #ffffff);border-radius:var(--border-radius, 12px);padding:20px;margin-bottom:20px;box-shadow:0 2px 8px #00000014}.test-section h3,.diagnostic-header h3,.diagnostic-section h4{color:var(--color-text, #212529);margin-top:0;margin-bottom:16px;border-bottom:1px solid #e0e0e0;padding-bottom:8px}.diagnostic-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding:16px 20px;background:#fff;border-radius:var(--border-radius, 12px);box-shadow:0 2px 10px #0000001a}.diagnostic-header .diagnostic-actions{display:flex;gap:8px}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.03)}to{transform:scale(1)}}.speaking-indicator,.transcription-display .status-speaking,.transcription-display .status-listening{animation:pulse 1.5s infinite ease-in-out}.transcription-display .typing-indicator span:not(.typing-text){width:6px;height:6px;animation-delay:.1s}.virtual-assistant-content,.avatar-container,.voice-input-container{display:none}.transcription-display.listening-mode .messages-container:before{content:"";display:block;position:sticky;top:0;background:#fff3cde6;border:1px solid #ffeaa7;border-radius:8px;padding:12px;margin-bottom:12px;z-index:10}.transcription-display.listening-mode .listening-indicator{position:sticky;top:0;background:#fff3cdf2;border:1px solid #ffeaa7;border-radius:8px;padding:12px;margin-bottom:12px;z-index:10;display:flex;align-items:center;gap:8px;font-weight:500;color:#856404;animation:pulse 1.5s infinite ease-in-out}.transcription-display.listening-mode .listening-indicator:before{content:"🎤";font-size:18px}.transcription-display.listening-mode .interim-preview{position:sticky;top:60px;background:#d4eddaf2;border:1px solid #c3e6cb;border-radius:8px;padding:12px;margin-bottom:12px;z-index:9;font-style:italic;color:#155724;min-height:20px}.transcription-display.listening-mode .interim-preview:empty:before{content:"Escuchando...";color:#6c757d}.chat-controls-bar .voice-input-button,.chat-controls-bar .mic-btn{display:inline-flex!important;width:40px!important;height:40px!important;background:#28a745!important;border-radius:50%!important;border:none!important;color:#fff!important;align-items:center!important;justify-content:center!important;font-size:20px!important;cursor:pointer!important;border:2px solid blue!important}.voice-input-button{display:inline-flex!important;background:none!important;padding:0!important;border:none!important;border-radius:0!important}.voice-input-button .voice-button-container{display:flex!important}.voice-input-button .voice-button{display:flex!important;align-items:center!important;justify-content:center!important}.chat-history-panel .transcription-display{height:100%;display:flex;flex-direction:column}.chat-history-panel .transcription-display .messages-container{padding-bottom:100px;flex-grow:1;overflow-y:auto}.chat-history-panel .transcription-display .message{max-width:90%;border-radius:18px;padding:8px 12px;margin-bottom:8px}.chat-history-panel .transcription-display .message-content{display:flex;flex-direction:column;width:100%}.chat-history-panel .transcription-display .message-body{padding:10px 12px;border-radius:8px;width:100%;box-sizing:border-box}.chat-history-panel .transcription-display .user-message{background-color:var(--color-accent, #4a90e2);color:var(--color-brand-white, #ffffff);align-self:flex-end;border-bottom-right-radius:6px}.chat-history-panel .transcription-display .user-message .message-body{background-color:var(--color-accent, #4a90e2);color:var(--color-brand-white, #ffffff);border:none}.chat-history-panel .transcription-display .assistant-message{background-color:var(--color-assistant-message, #f1f3f5);color:var(--color-text, #212529);align-self:flex-start;border:1px solid #e0e0e0;border-bottom-left-radius:6px}.chat-history-panel .transcription-display .assistant-message .message-body{background-color:var(--color-assistant-message, #f1f3f5);color:var(--color-text, #212529);border:none}.chat-history-panel .transcription-display .message-avatar{width:28px;height:28px;font-size:14px}.chat-history-panel .transcription-display .transcription-header{flex-shrink:0;padding:12px 0}.chat-history-panel .transcription-display .transcription-footer{flex-shrink:0;padding:8px 0}.avatar-display .avatar-status,.avatar-display .avatar-button{height:40px;min-height:40px;display:flex;align-items:center;margin:0 2px;padding:0 18px;border-radius:22px;font-size:1rem;font-weight:600;box-sizing:border-box;white-space:nowrap}.avatar-display .avatar-status{color:#222;border:none;box-shadow:0 2px 8px #50e3c20a;gap:8px;justify-content:center}.avatar-display .avatar-button{background:linear-gradient(90deg,#4a90e2,#b3d8fd);color:#fff;border:none;box-shadow:0 2px 8px #50e3c214;transition:background .2s,box-shadow .2s,transform .1s;cursor:pointer;outline:none}.avatar-display .avatar-button.connect{background:linear-gradient(90deg,#4a90e2,#8ec9f7)}.avatar-display .avatar-button.disconnect{background:linear-gradient(90deg,#4a90e2,#b3d8fd)}.avatar-display .avatar-button.interrupt{background:linear-gradient(90deg,#4a90e2,#d6eaff)}.avatar-display .avatar-button:hover:not(:disabled){filter:brightness(1.08) saturate(1.2);box-shadow:0 4px 16px #50e3c22e;transform:translateY(-2px) scale(1.03)}.avatar-display .avatar-button:disabled{opacity:.6;cursor:not-allowed;filter:grayscale(.2)}.avatar-display .status-indicator{display:flex;align-items:center;gap:8px;font-size:1rem;font-weight:600;color:#6c757d}.avatar-display .status-indicator.connected{color:#28a745}.avatar-display .status-indicator.disconnected,.avatar-display .status-indicator.status-idle{color:#6c757d}@media (max-width: 768px){.avatar-display .avatar-button,.avatar-display .avatar-status{height:34px;min-height:34px;font-size:.95rem;padding:0 10px}}.avatar-display .avatar-controls{overflow-x:auto;overflow-y:hidden}@media (max-width: 768px){.avatar-display .avatar-button,.avatar-display .avatar-status{height:34px;min-height:34px;font-size:.95rem;padding:0 10px}.transcription-header{display:none!important;visibility:hidden!important;height:0!important;min-height:0!important;max-height:0!important;padding:0!important;border:none!important;position:absolute!important}}.avatar-video-container{aspect-ratio:16/9;width:100%;max-width:700px;min-width:280px;min-height:180px;height:auto;display:flex;align-items:center;justify-content:center;position:relative;background:#000;border-radius:12px;overflow:hidden;margin-bottom:20px}.avatar-video{width:100%!important;height:100%!important;max-height:100%;object-fit:contain!important;border-radius:12px;background:transparent;position:relative;z-index:1}@media (max-width: 768px){.avatar-video-container{aspect-ratio:16/9;min-height:120px;max-width:93vw}.avatar-display .avatar-button,.avatar-display .avatar-status{min-width:90px;font-size:.95rem;padding:0 10px}.transcription-header{display:none!important;visibility:hidden!important;height:0!important;min-height:0!important;max-height:0!important;padding:0!important;border:none!important;position:absolute!important}}.avatar-display{padding-bottom:0!important;background:transparent!important}@media (max-width: 768px){.avatar-display .avatar-actions{display:flex!important;flex-direction:row!important;gap:6px;width:auto;justify-content:flex-start;align-items:center}}.avatar-display .avatar-button.disconnect,.avatar-display .avatar-button.interrupt{color:#fff!important}@media (max-width: 768px){.assistant-layout{display:flex!important;flex-direction:column!important;height:100vh!important}.avatar-area{flex:1 1 50vh!important;min-height:0!important;max-height:50vh!important;overflow:hidden}.controls-area{flex:1 1 50vh!important;min-height:0!important;max-height:50vh!important;overflow:auto}.avatar-display .status-indicator{font-size:.85rem!important;flex-wrap:wrap!important;white-space:normal!important;line-height:1.1;max-width:100%;word-break:break-word}}@media (min-width: 769px){.assistant-layout{grid-template-columns:1fr 380px;height:calc(100vh - 70px)}.avatar-area{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#fff;position:relative;padding:20px}.avatar-video-container{height:calc(100vh - 250px);max-height:calc(100vh - 250px);min-height:400px;width:100%;max-width:800px;flex:1;margin:0 auto}.avatar-video{width:auto!important;height:100%!important;max-width:100%;object-fit:contain!important;display:block;margin:0 auto}.avatar-display{height:100%;width:100%;display:flex;flex-direction:column;padding:0;background:transparent;align-items:center}.avatar-controls{flex-wrap:nowrap;overflow-x:visible;justify-content:space-between;align-items:center;flex-shrink:0;margin-bottom:0;width:100%;max-width:800px}.avatar-actions{display:flex!important;flex-direction:row!important;gap:12px;flex-shrink:0}.avatar-button{white-space:nowrap;min-width:auto;padding:8px 16px;font-size:14px}.avatar-status{flex-shrink:0}.avatar-info{flex-shrink:0;margin-top:10px;width:100%;max-width:800px}.controls-area{border-left:1px solid #dadce0}.chat-controls-bar{position:static;box-shadow:none;border-top:1px solid #dadce0}.chat-history-panel{padding-bottom:0}}.chroma-key-processor{transform:translate(-20%);height:100%;width:auto;object-fit:contain;display:block;margin:0 auto}@media (max-width: 768px){.chroma-key-processor{transform:none;width:100%;height:auto}}:root{--color-bg: #f8f9fa;--color-sidebar: #ffffff;--color-text: #212529;--color-input-bg: #ffffff;--color-user-message: #4a90e2;--color-assistant-message: #f1f3f5;--color-accent: #4a90e2;--color-brand-bg: #ffffff;--color-brand-white: #212529;--border-radius: 12px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,sans-serif;color:var(--color-text);background-color:var(--color-bg);line-height:1.6}button{cursor:pointer;border:none;outline:none;background:none}textarea{font-family:Inter,sans-serif;resize:none}
