.voice-consult-container{position:fixed;bottom:120px;right:30px;z-index:9999;display:flex;align-items:center;gap:10px}.voice-consult-button{display:flex;align-items:center;gap:8px;padding:16px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:50px;font-size:16px;font-weight:700;cursor:pointer;box-shadow:0 4px 15px #667eea66;transition:all .3s ease;user-select:none;-webkit-user-select:none}.voice-consult-button.no-permission{background:linear-gradient(135deg,#999,#666);cursor:not-allowed}.voice-consult-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea99}.voice-consult-button:active:not(:disabled){transform:translateY(0)}.voice-consult-button:disabled{opacity:.5;cursor:not-allowed}.voice-consult-button.recording{background:linear-gradient(135deg,#f093fb,#f5576c);animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 4px 15px #f5576c66}50%{box-shadow:0 4px 25px #f5576ccc}}.recording-icon{font-size:18px;animation:blink 1s ease-in-out infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.mic-icon{font-size:20px}.button-text{font-size:16px;font-weight:600}.transcript-preview-overlay{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10000;pointer-events:none}.transcript-preview-content{background:#667eeaf2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:3px solid white;border-radius:16px;padding:20px 30px;max-width:500px;box-shadow:0 8px 32px #0000004d;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.transcript-label{font-size:16px;color:#fff;font-weight:700;margin-right:12px;display:block;margin-bottom:8px}.transcript-text{font-size:20px;color:#fff;line-height:1.6;font-weight:600;display:block}.device-selector-toggle{width:48px;height:48px;border-radius:50%;background:#667eeae6;color:#fff;border:none;font-size:20px;cursor:pointer;box-shadow:0 4px 15px #667eea66;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.device-selector-toggle:hover:not(:disabled){transform:scale(1.1);background:#667eea}.device-selector-toggle:disabled{opacity:.5;cursor:not-allowed}.device-selector-dropdown{position:fixed;bottom:180px;right:30px;z-index:10000;background:#fff;border-radius:12px;box-shadow:0 8px 32px #0003;min-width:250px;max-width:350px;overflow:hidden;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.device-selector-header{padding:12px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:700;font-size:14px}.device-option{width:100%;padding:12px 16px;border:none;background:#fff;text-align:left;cursor:pointer;transition:background .2s ease;font-size:14px;color:#333;border-bottom:1px solid #f0f0f0}.device-option:hover{background:#f5f5f5}.device-option.selected{background:#e8eeff;color:#667eea;font-weight:600}.device-option:last-child{border-bottom:none}@media(max-width:768px){.voice-consult-container{bottom:80px;right:20px}.voice-consult-button{padding:14px 20px;font-size:14px}.device-selector-toggle{width:40px;height:40px;font-size:18px}.device-selector-dropdown{bottom:140px;right:20px;min-width:200px}.transcript-preview{max-width:250px;font-size:13px}}.speech-bubble{position:fixed;max-width:400px;min-width:200px;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;padding:16px 20px;box-shadow:0 4px 20px #00000026;z-index:1000;animation:bubbleSlideIn .3s ease-out;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.speech-bubble-top-left{top:20px;left:20px}.speech-bubble-top-right{top:20px;right:20px}.speech-bubble-bottom-left{bottom:100px;left:20px}.speech-bubble-bottom-right{bottom:100px;right:20px}.speech-bubble-center{top:50%;left:50%;transform:translate(-50%,-50%)}@media(max-width:768px){.speech-bubble{max-width:calc(100vw - 40px);min-width:250px}.speech-bubble-top-left,.speech-bubble-top-right{top:10px;left:10px;right:10px}.speech-bubble-bottom-left,.speech-bubble-bottom-right{bottom:80px;left:10px;right:10px}}.speech-bubble-assistant{background:linear-gradient(135deg,#93c5fdf2,#bfdbfef2);border:2px solid rgba(59,130,246,.3)}.speech-bubble-user{background:#f3f4f6f2;border:2px solid rgba(156,163,175,.3)}.speech-bubble-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid rgba(0,0,0,.1)}.speech-bubble-character{font-weight:600;font-size:14px;color:#000c}.speech-bubble-streaming-indicator{display:flex;align-items:center;gap:4px}.speech-bubble-streaming-indicator .dot{width:6px;height:6px;background:#3b82f6cc;border-radius:50%;animation:dotPulse 1.4s infinite ease-in-out}.speech-bubble-streaming-indicator .dot:nth-child(1){animation-delay:0s}.speech-bubble-streaming-indicator .dot:nth-child(2){animation-delay:.2s}.speech-bubble-streaming-indicator .dot:nth-child(3){animation-delay:.4s}@keyframes dotPulse{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1.2);opacity:1}}.speech-bubble-content{font-size:15px;line-height:1.6;color:#000000e6;word-wrap:break-word;white-space:pre-wrap}.speech-bubble-cursor{display:inline-block;margin-left:2px;color:#3b82f6cc;animation:cursorBlink 1s infinite}@keyframes cursorBlink{0%,49%{opacity:1}50%,to{opacity:0}}@keyframes bubbleSlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.speech-bubble-bottom-left,.speech-bubble-bottom-right{animation:bubbleSlideInBottom .3s ease-out}@keyframes bubbleSlideInBottom{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.speech-bubble-center{animation:bubbleSlideInCenter .3s ease-out}@keyframes bubbleSlideInCenter{0%{opacity:0;transform:translate(-50%,-50%) scale(.9)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.speech-bubble:hover{box-shadow:0 6px 25px #0003}@media(prefers-color-scheme:dark){.speech-bubble{background:#1f2937f2}.speech-bubble-assistant{background:linear-gradient(135deg,#1e3a8af2,#3b82f6f2);border-color:#60a5fa4d}.speech-bubble-user{background:#374151f2;border-color:#6b72804d}.speech-bubble-character,.speech-bubble-content{color:#ffffffe6}.speech-bubble-header{border-bottom-color:#ffffff1a}}html,body,#root{width:100vw;height:100dvh;min-height:100dvh;margin:0;padding:0;overflow:hidden!important;position:static!important;box-sizing:border-box}body{background:none!important}.ui-button-group{display:flex;flex-direction:row;align-items:center;gap:12px}@media(max-width:768px){.panel-mobile{position:fixed;top:calc(76px + env(safe-area-inset-top,0px));bottom:100px;left:10px;right:10px;background:#fffffff2;border-radius:16px;padding:0;box-shadow:0 8px 32px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);z-index:10500;overflow:hidden;display:flex;flex-direction:column}.header-bar{padding:8px;flex-wrap:nowrap}.panel-mobile .info-panel{height:100%;margin-top:0!important;display:flex;flex-direction:column}.header-bar>div:first-child{display:flex;flex-wrap:nowrap;gap:2px;overflow-x:auto;padding-bottom:2px;scrollbar-width:none;-ms-overflow-style:none}.header-bar>div:first-child::-webkit-scrollbar{display:none}.header-button-group{gap:1px;min-width:50px}.header-button{width:32px;height:32px;padding:4px;font-size:12px}.button-label{font-size:8px}.panel-toggle-overlay{top:70px;right:10px;left:auto;flex-direction:column;gap:8px;z-index:30000}.panel-open-btn{margin:0;min-width:120px;padding:10px 12px;font-size:13px}}@media(max-width:480px){.panel-toggle-overlay{top:60px;right:8px;left:8px;gap:6px}.panel-open-btn{padding:8px 10px;font-size:12px;min-height:40px}}@media(max-width:360px){.panel-toggle-overlay{flex-direction:column;gap:4px;right:5px;left:5px}.panel-open-btn{min-width:100px}}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes slideInUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.panel-mobile,.panel-pc{animation:slideInUp .3s ease-out}@media(max-width:768px){.chat-panel{width:calc(100vw - 40px)!important;height:350px!important;bottom:90px!important;right:20px!important;left:20px!important}.chat-toggle-btn{bottom:30px!important;right:30px!important;width:50px!important;height:50px!important;font-size:20px!important}.streaming-overlay{position:fixed!important;top:60px!important;left:10px!important;right:10px!important;width:auto!important;max-width:calc(100vw - 20px)!important;min-width:auto!important;margin:0!important;padding:12px!important;z-index:15000!important}}.header-button-group{display:flex;flex-direction:column;align-items:center;gap:4px}.header-button{background:#fff3;border:1px solid rgba(255,255,255,.3);border-radius:8px;padding:8px;cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:16px}.header-button:hover{background:#ffffff4d;transform:translateY(-1px)}.header-button.active{background:#667eeacc;border-color:#667eea;color:#fff}.header-button.active-focus{background:#ff6b6bcc;border-color:#ff6b6b;color:#fff}.button-label{font-size:10px;color:#ffffffe6;font-weight:500;text-align:center;white-space:nowrap;text-shadow:0 1px 2px rgba(0,0,0,.3)}
