body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--transition-theme:all 1.2s cubic-bezier(0.25,0.46,0.45,0.94)}html{background:#000;border:none!important;box-sizing:border-box;height:100%;margin:0!important;outline:none!important;overflow:hidden;padding:0!important;width:100%}body{animation:pageLoad 1.2s ease-out;background:#000;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;height:100vh;line-height:1.4;width:100vw}#root,body{border:none!important;box-sizing:border-box;margin:0!important;outline:none!important;overflow:hidden;padding:0!important;transition:all 1.2s cubic-bezier(.25,.46,.45,.94);transition:var(--transition-theme)}#root{background:var(--bg-primary);height:100vh!important;width:100vw!important}:root[data-theme=dark]{--bg-primary:#000;--bg-glass:#0006;--bg-glass-strong:#000000e6;--text-secondary:#ffffffb3;--text-muted:#ffffff80;--accent-primary:#0f8;--accent-secondary:#0fa;--accent-tertiary:#0fc;--border-color:#fff3;--shadow-color:#0006;--subtitle-bg:#0000004d}:root[data-theme=light]{--bg-primary:#fff;--bg-secondary:#f8f9fa;--bg-glass:#fffc;--bg-glass-strong:#fffffff2;--text-primary:#1a1a1a;--text-secondary:#1a1a1acc;--text-muted:#1a1a1a99;--accent-primary:#00cc6a;--accent-secondary:#00b85f;--accent-tertiary:#00a354;--border-color:#1a1a1a26;--shadow-color:#0000001a;--subtitle-bg:#ffffffe6}.language-button{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--bg-glass);border:1px solid var(--border-color);border-radius:12px;cursor:pointer;display:flex;gap:8px;min-width:80px;padding:8px 12px;transition:all 1.2s cubic-bezier(.25,.46,.45,.94);transition:var(--transition-theme)}.language-button:hover{background:var(--bg-glass-strong);box-shadow:0 4px 20px var(--shadow-color);transform:translateY(-1px)}.language-icon{font-size:16px}.language-display{color:var(--text-primary);font-size:14px;font-weight:500}.language-selector-overlay{align-items:center;animation:overlayFadeIn .3s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.language-selector-modal{animation:modalSlideIn .3s cubic-bezier(.34,1.56,.64,1);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:20px;box-shadow:0 20px 60px var(--shadow-color);max-height:80vh;max-width:600px;overflow-y:auto;width:90%}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.language-modal-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:20px 24px}.language-modal-header h2{color:var(--text-primary);font-size:24px;font-weight:600;margin:0}.close-button{background:none;border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;font-size:24px;padding:4px;transition:all 1.2s cubic-bezier(.25,.46,.45,.94);transition:var(--transition-theme)}.close-button:hover{background:var(--bg-glass);color:var(--text-primary)}.language-modal-content{padding:24px}.language-section{margin-bottom:32px}.language-section:last-child{margin-bottom:0}.language-section h3{color:var(--text-primary);font-size:18px;font-weight:600;margin:0 0 16px}.popular-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.popular-combo{background:var(--bg-glass);border:1px solid var(--border-color);border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:8px;padding:16px;transition:all 1.2s cubic-bezier(.25,.46,.45,.94);transition:var(--transition-theme)}.popular-combo:hover{background:var(--bg-glass-strong);box-shadow:0 4px 20px var(--shadow-color);transform:translateY(-2px)}.popular-combo.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#000}.combo-name{font-size:14px;font-weight:600}.combo-description{color:var(--text-secondary);font-size:12px;line-height:1.4}.popular-combo.active .combo-description{color:#000000b3}.language-group{margin-bottom:20px}.language-group label{display:block;font-weight:500;margin-bottom:8px}.language-group label,.language-select{color:var(--text-primary);font-size:14px}.language-select{background:var(--bg-glass);border:1px solid var(--border-color);border-radius:12px;cursor:pointer;padding:12px 16px;transition:all 1.2s cubic-bezier(.25,.46,.45,.94);transition:var(--transition-theme);width:100%}.language-select:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #00ff881a;outline:none}.language-select option{background:var(--bg-primary);color:var(--text-primary);padding:8px}.config-summary{background:var(--bg-glass);border:1px solid var(--border-color);border-radius:12px;padding:16px}.config-item{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:8px 0}.config-item:last-child{border-bottom:none}.config-label{color:var(--text-secondary);font-size:14px;font-weight:500}.config-value{color:var(--text-primary);font-size:14px;font-weight:600;text-align:right}@media (max-width:768px){.language-selector-modal{max-height:85vh;width:95%}.language-modal-header{padding:16px 20px}.language-modal-content{padding:20px}.popular-grid{grid-template-columns:1fr}.language-button{min-width:60px}.language-display{font-size:12px}}.theme-animation-icon{align-items:center;animation:cinematicFly 1.2s cubic-bezier(.25,.46,.45,.94) forwards;display:flex;filter:drop-shadow(0 0 20px rgba(255,255,255,.8));font-size:24px;height:40px;justify-content:center;left:0;pointer-events:none;position:fixed;top:0;transform:translate(var(--start-x),var(--start-y)) translate(-50%,-50%);width:40px;z-index:9999}@keyframes cinematicFly{0%{filter:drop-shadow(0 0 10px rgba(255,255,255,.6)) brightness(1);opacity:1;transform:translate(var(--start-x),var(--start-y)) translate(-50%,-50%) scale(1)}20%{filter:drop-shadow(0 0 60px rgba(255,255,255,1)) brightness(1.5);opacity:1;transform:translate(50vw,50vh) translate(-50%,-50%) scale(4)}35%{filter:drop-shadow(0 0 100px rgba(255,255,255,1)) brightness(2);opacity:1;transform:translate(50vw,50vh) translate(-50%,-50%) scale(6)}50%{filter:drop-shadow(0 0 150px rgba(255,255,255,1)) brightness(2.5);opacity:1;transform:translate(50vw,50vh) translate(-50%,-50%) scale(8)}65%{filter:drop-shadow(0 0 200px rgba(255,255,255,1)) brightness(3);opacity:1;transform:translate(50vw,50vh) translate(-50%,-50%) scale(10)}80%{filter:drop-shadow(0 0 250px rgba(255,255,255,.8)) brightness(3.5);opacity:.8;transform:translate(50vw,50vh) translate(-50%,-50%) scale(12)}90%{filter:drop-shadow(0 0 300px rgba(255,255,255,.4)) brightness(4);opacity:.4;transform:translate(50vw,50vh) translate(-50%,-50%) scale(15)}to{filter:drop-shadow(0 0 400px rgba(255,255,255,0)) brightness(5);opacity:0;transform:translate(50vw,50vh) translate(-50%,-50%) scale(20)}}.app.theme-animating{overflow:hidden;position:relative;transition:all 1.2s cubic-bezier(.25,.46,.45,.94);transition:var(--transition-theme)}.app.theme-animating:before{animation:themeRadialGlow 1.2s ease-out;background:radial-gradient(circle at 50% 50%,#ffffff1a 0,#0000 70%);bottom:0;content:"";left:0;pointer-events:none;position:fixed;right:0;top:0;z-index:999}@keyframes themeRadialGlow{0%{background:radial-gradient(circle at 50% 50%,#fff0 0,#0000 0);opacity:0}20%{background:radial-gradient(circle at 50% 50%,#ffffff1a 0,#0000 30%);opacity:.6}40%{background:radial-gradient(circle at 50% 50%,#fff3 0,#0000 50%);opacity:.8}60%{background:radial-gradient(circle at 50% 50%,#ffffff4d 0,#0000 70%);opacity:1}80%{background:radial-gradient(circle at 50% 50%,#fff6 0,#0000 80%);opacity:1}90%{background:radial-gradient(circle at 50% 50%,#fff3 0,#0000 90%);opacity:.6}to{background:radial-gradient(circle at 50% 50%,#fff0 0,#0000 100%);opacity:0}}*{margin:0;padding:0}*,.app.subtitle-mode{box-sizing:border-box}.app.subtitle-mode{animation:appFadeIn 1.5s ease-out;background:linear-gradient(135deg,var(--bg-primary) 0,var(--bg-secondary) 100%);border:none!important;display:flex;flex-direction:column;height:100vh!important;margin:0!important;outline:none!important;overflow:hidden;padding:0!important;transition:all 1.2s cubic-bezier(.25,.46,.45,.94);transition:var(--transition-theme);width:100vw!important}@keyframes pageLoad{0%{opacity:0}50%{opacity:.5}to{opacity:1}}@keyframes appFadeIn{0%{opacity:0;transform:scale(.95) translateY(20px)}50%{opacity:.7;transform:scale(.98) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.header.minimal{align-items:center;animation:headerSlideIn 1.8s ease-out .3s both;display:flex;justify-content:space-between;left:20px;pointer-events:none;position:absolute;right:20px;top:20px;z-index:100}.header-controls{align-items:center;display:flex;gap:16px;pointer-events:auto}@keyframes headerSlideIn{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}.header.minimal h1{animation:textGlow 4s ease-in-out 2s infinite;color:var(--text-secondary);font-size:16px;font-weight:500;margin:0}.header.minimal h1,.theme-toggle{pointer-events:auto;transition:all 1.2s cubic-bezier(.25,.46,.45,.94);transition:var(--transition-theme)}.theme-toggle{cursor:pointer;padding:4px;position:relative}.theme-toggle:hover{transform:scale(1.05)}.theme-toggle:active{transform:scale(.95)}.toggle-track{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:var(--bg-glass);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 4px 16px var(--shadow-color),inset 0 1px 0 #ffffff1a;height:24px;position:relative;transition:all 1.2s cubic-bezier(.25,.46,.45,.94);transition:var(--transition-theme);width:48px}.toggle-track.light{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-color:var(--accent-primary);box-shadow:0 4px 16px #00cc6a33,inset 0 1px 0 #ffffff4d}.toggle-track.dark{background:linear-gradient(135deg,#1e293b,#334155);border-color:var(--accent-primary);box-shadow:0 4px 16px #0f83,inset 0 1px 0 #ffffff1a}.toggle-thumb{align-items:center;background:var(--text-primary);border-radius:9px;box-shadow:0 2px 8px var(--shadow-color),0 1px 3px #0000001a;display:flex;height:18px;justify-content:center;position:absolute;top:2px;transition:all .3s cubic-bezier(.4,0,.2,1);width:18px}.toggle-thumb.dark{background:linear-gradient(135deg,#64748b,#475569);border:1px solid var(--accent-primary);box-shadow:0 2px 8px #00ff884d,0 1px 3px #0003;left:2px}.toggle-thumb.light{background:linear-gradient(135deg,#fbbf24,#f59e0b);border:1px solid #f59e0b;box-shadow:0 2px 8px #f59e0b66,0 1px 3px #0000001a;left:26px}.toggle-icon{font-size:10px;line-height:1}.status,.toggle-icon{transition:all 1.2s cubic-bezier(.25,.46,.45,.94);transition:var(--transition-theme)}.status{color:var(--text-muted);font-family:monospace;font-size:12px}.status.connected{animation:statusPulse 2s ease-in-out infinite;color:var(--accent-primary)}.status.disconnected{animation:statusError 1s ease-in-out infinite;color:#f44}@keyframes statusPulse{0%,to{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}@keyframes statusError{0%,to{opacity:.6}50%{opacity:1}}.subtitle-container{align-items:center;animation:containerSlideUp 2s ease-out .6s both;display:flex;flex:1 1;flex-direction:column;justify-content:center;max-height:calc(100vh - 200px);overflow-y:auto;padding:80px 40px 120px;position:relative;text-align:center}@keyframes containerSlideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.subtitle-line{align-items:center;animation:fadeInUp .6s ease-out;display:flex;flex-direction:column;margin:8px 0;max-width:1000px;width:100%}.subtitle-line.continuous{align-items:center;animation:subtitleAppear .8s ease-out;display:flex;justify-content:center;margin:20px 0;min-height:200px}@keyframes subtitleAppear{0%{opacity:0;transform:translateY(30px) scale(.95)}50%{opacity:.7;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.subtitle-text{word-wrap:break-word;color:var(--text-primary);font-size:32px;font-weight:600;-webkit-hyphens:auto;hyphens:auto;letter-spacing:.5px;line-height:1.4;margin-bottom:8px;text-shadow:2px 2px 4px var(--shadow-color),0 0 8px var(--shadow-color);transition:all 1.2s cubic-bezier(.25,.46,.45,.94);transition:var(--transition-theme)}.subtitle-text.translation-text{animation:translationGlow 3s ease-in-out infinite;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:var(--bg-glass);border-left:3px solid var(--accent-secondary);border-radius:12px;color:var(--text-secondary);font-size:28px;font-style:italic;font-weight:500;margin-top:16px;opacity:.85;padding:20px 28px}@keyframes translationGlow{0%,to{box-shadow:0 4px 20px var(--shadow-color)}50%{box-shadow:0 6px 25px var(--accent-secondary-alpha)}}.subtitle-text.flowing{align-items:center;animation:textGlow 4s ease-in-out infinite;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:var(--subtitle-bg);border-left:4px solid var(--accent-primary);border-radius:16px;box-shadow:0 8px 32px var(--shadow-color),inset 0 1px 0 #ffffff1a;color:var(--text-primary);display:flex;line-height:1.5;margin:0;max-width:100%;min-height:80px;overflow:hidden;padding:28px 36px;position:relative;text-align:left;transition:all 1.2s cubic-bezier(.25,.46,.45,.94);transition:var(--transition-theme);white-space:pre-wrap;word-break:break-word}.subtitle-text.flowing:before{animation:textShimmer 3s ease-in-out infinite;background:linear-gradient(90deg,#0000,var(--bg-glass),#0000);content:"";height:100%;left:-100%;position:absolute;top:0;width:100%}@keyframes textShimmer{0%{left:-100%}50%{left:100%}to{left:100%}}.subtitle-text.flowing:hover{border-left-color:var(--accent-secondary);box-shadow:0 12px 40px var(--shadow-color),inset 0 1px 0 #fff3;transform:translateY(-2px)}.subtitle-text.updating{animation:textUpdate .3s ease-out}@keyframes textUpdate{0%{border-left-color:var(--accent-primary);transform:scale(1)}50%{border-left-color:var(--accent-tertiary);transform:scale(1.02)}to{border-left-color:var(--accent-primary);transform:scale(1)}}.subtitle-translation{animation:fadeIn .5s ease-out .2s both;color:var(--text-secondary);font-style:italic;font-weight:400;margin-top:8px;text-shadow:1px 1px 2px var(--shadow-color)}.subtitle-empty,.subtitle-translation{font-size:24px;transition:all 1.2s cubic-bezier(.25,.46,.45,.94);transition:var(--transition-theme)}.subtitle-empty{animation:breathe 3s ease-in-out infinite;color:var(--text-muted);font-weight:300;text-align:center}.controls.floating{animation:controlsSlideUp 2.2s ease-out .8s both;bottom:40px;display:flex;gap:20px;left:50%;position:fixed;transform:translateX(-50%);z-index:200}@keyframes controlsSlideUp{0%{opacity:0;transform:translateX(-50%) translateY(80px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.mic-container{align-items:center;display:flex;justify-content:center;position:relative}.circular-waveform{animation:waveformRotate 20s linear infinite;filter:drop-shadow(0 0 8px var(--accent-primary-alpha));left:50%;opacity:.9;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);z-index:1}@keyframes waveformRotate{0%{transform:translate(-50%,-50%) rotate(0deg)}to{transform:translate(-50%,-50%) rotate(1turn)}}.voice-activity-ring{animation:voicePulse 1.5s ease-in-out infinite;border:3px solid var(--accent-primary);border-radius:50%;height:100px;left:50%;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);width:100px;z-index:0}@keyframes voicePulse{0%,to{opacity:.8;transform:translate(-50%,-50%) scale(1)}50%{opacity:.4;transform:translate(-50%,-50%) scale(1.1)}}.audio-meters{align-items:center;animation:metersSlideDown .5s ease-out;display:flex;gap:30px;left:50%;position:fixed;top:60px;transform:translateX(-50%);z-index:100}@keyframes metersSlideDown{0%{opacity:0;transform:translateX(-50%) translateY(-40px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.vu-meter{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:var(--bg-glass);border:1px solid var(--border-color);border-radius:12px;min-width:200px;padding:15px 20px;text-align:center}.vu-label{color:var(--text-secondary);font-size:14px;font-weight:500;margin-bottom:8px}.vu-bar{background:var(--bg-secondary);height:8px;margin-bottom:6px;overflow:hidden;position:relative}.vu-bar,.vu-fill{border-radius:4px}.vu-fill{box-shadow:0 0 8px currentColor;height:100%;transition:width .1s ease-out,background-color .3s ease}.vu-peak{background:#fff;border-radius:1px;box-shadow:0 0 4px #fff;height:100%;position:absolute;top:0;transition:left .1s ease-out;width:2px}.vu-scale{color:var(--text-muted);display:flex;font-size:10px;justify-content:space-between;margin-top:4px}.voice-indicator{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:var(--bg-glass);border:1px solid var(--border-color);border-radius:12px;padding:15px 20px;text-align:center;transition:all .3s ease}.voice-indicator.active{background:var(--accent-primary-alpha);border-color:var(--accent-primary);box-shadow:0 0 20px var(--accent-primary-alpha)}.voice-icon{font-size:24px;margin-bottom:5px;transition:transform .3s ease}.voice-indicator.active .voice-icon{animation:voiceIconBounce .6s ease-in-out infinite alternate;transform:scale(1.2)}@keyframes voiceIconBounce{0%{transform:scale(1.2)}to{transform:scale(1.3)}}.voice-status{color:var(--text-secondary);font-size:12px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.voice-indicator.active .voice-status{color:var(--accent-primary)}.mic-button{align-items:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:var(--bg-glass);border:none;border:2px solid var(--border-color);border-radius:50%;box-shadow:0 8px 32px var(--shadow-color),inset 0 1px 0 #fff3;color:var(--text-primary);cursor:pointer;display:flex;font-size:32px;height:80px;justify-content:center;overflow:hidden;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1);width:80px;z-index:2}.mic-button:before{background:var(--bg-glass);border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:all .3s ease;width:0}.mic-button:hover:not(:disabled){background:var(--bg-glass-strong);border-color:var(--accent-primary);box-shadow:0 16px 48px var(--shadow-color),inset 0 1px 0 #ffffff4d;transform:scale(1.1) translateY(-4px)}.mic-button:hover:not(:disabled):before{height:100%;width:100%}.mic-button:active{transform:scale(.95) translateY(-2px)}.mic-button.recording{animation:recordingPulse 1.5s infinite;background:linear-gradient(135deg,#f44,#f66);border-color:#f88;box-shadow:0 8px 32px #ff444480,inset 0 1px 0 #fff3,0 0 0 0 #f449;color:#fff}.mic-button.voice-active{animation:voiceActivePulse 1s ease-in-out infinite;border-color:var(--accent-primary);box-shadow:0 0 40px var(--accent-primary-alpha)}@keyframes voiceActivePulse{0%,to{box-shadow:0 0 40px var(--accent-primary-alpha);transform:scale(1)}50%{box-shadow:0 0 50px var(--accent-primary-alpha);transform:scale(1.05)}}.mic-button:disabled{cursor:not-allowed;opacity:.3;transform:none}.clear-button{align-items:center;align-self:flex-end;animation:buttonBounceIn .6s ease-out 1s both;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:var(--bg-glass);border:none;border:2px solid var(--border-color);border-radius:50%;color:var(--text-secondary);cursor:pointer;display:flex;font-size:20px;height:60px;justify-content:center;transition:all .4s cubic-bezier(.4,0,.2,1);width:60px}@keyframes buttonBounceIn{0%{opacity:0;transform:scale(0)}50%{opacity:.8;transform:scale(1.2)}to{opacity:1;transform:scale(1)}}.clear-button:hover{background:#f443;border-color:#ff44444d;box-shadow:0 8px 24px #ff44444d;color:#f44;transform:scale(1.1) translateY(-2px)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes textGlow{0%,to{border-left-color:var(--accent-primary);box-shadow:inset 4px 0 8px #00ff884d,0 8px 32px var(--shadow-color),inset 0 1px 0 #ffffff1a}33%{border-left-color:var(--accent-secondary);box-shadow:inset 4px 0 12px #00ff8880,0 12px 40px var(--shadow-color),inset 0 1px 0 #ffffff26}66%{border-left-color:var(--accent-tertiary);box-shadow:inset 4px 0 16px #0f86,0 10px 36px var(--shadow-color),inset 0 1px 0 #ffffff1f}}@keyframes recordingPulse{0%,to{box-shadow:0 8px 32px #ff444480,0 0 0 0 #f449;transform:scale(1)}50%{box-shadow:0 12px 40px #ff4444b3,0 0 0 15px #f440;transform:scale(1.05)}}@keyframes breathe{0%,to{opacity:.5;transform:scale(1)}50%{opacity:.8;transform:scale(1.02)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width:768px){.subtitle-container{padding:60px 20px 100px}.subtitle-text{font-size:24px}.subtitle-text.flowing{border-radius:12px;font-size:26px;line-height:1.4;padding:20px 24px}.subtitle-translation{font-size:18px}.mic-button{font-size:28px;height:70px;width:70px}.clear-button{font-size:18px;height:50px;width:50px}.header.minimal h1{font-size:14px}.toggle-track{height:20px;width:42px}.toggle-thumb{height:16px;width:16px}.toggle-thumb.light{left:22px}.theme-animation-icon{font-size:18px;height:30px;width:30px}}@media (max-width:480px){.subtitle-text{font-size:20px}.subtitle-text.flowing{border-radius:10px;font-size:22px;line-height:1.3;padding:16px 20px}.subtitle-translation{font-size:16px}.controls.floating{bottom:30px}.theme-animation-icon{font-size:16px;height:25px;width:25px}}@media (prefers-contrast:high){.subtitle-text{text-shadow:3px 3px 0 var(--bg-primary),-1px -1px 0 var(--bg-primary),1px -1px 0 var(--bg-primary),-1px 1px 0 var(--bg-primary)}.subtitle-text.flowing{background:var(--bg-glass-strong);border:2px solid var(--accent-primary)}}.stt-provider-selector{align-items:center;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:var(--bg-glass);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;min-width:140px;padding:8px 16px;transition:all .3s ease}.stt-provider-selector:hover{background:var(--accent-primary-alpha);border-color:var(--accent-primary);transform:translateY(-1px)}.stt-icon{font-size:16px}.stt-display{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stt-selector-overlay{align-items:center;animation:modalFadeIn .3s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.stt-selector-modal{animation:modalSlideIn .3s ease-out;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:var(--bg-glass-strong);border:1px solid var(--border-color);border-radius:16px;box-shadow:0 20px 40px #0000004d;max-height:80vh;max-width:600px;overflow:hidden;padding:0;width:90%}.stt-modal-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:24px 32px 16px}.stt-modal-header h2{color:var(--text-primary);font-size:24px;font-weight:600;margin:0}.stt-modal-content{max-height:60vh;overflow-y:auto;padding:24px 32px 32px}.stt-providers-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.stt-provider-card{background:var(--bg-glass);border:2px solid var(--border-color);border-radius:12px;cursor:pointer;padding:20px;text-align:center;transition:all .3s ease}.stt-provider-card:hover{box-shadow:0 8px 25px var(--accent-primary-alpha);transform:translateY(-2px)}.stt-provider-card.active,.stt-provider-card:hover{background:var(--accent-primary-alpha);border-color:var(--accent-primary)}.stt-provider-card.active{box-shadow:0 4px 20px var(--accent-primary-alpha)}.stt-provider-icon{font-size:32px;margin-bottom:12px}.stt-provider-name{color:var(--text-primary);font-size:18px;font-weight:600;margin-bottom:8px}.stt-provider-description{color:var(--text-secondary);font-size:14px;line-height:1.4;margin-bottom:16px}.stt-provider-features{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:12px}.stt-provider-features .feature{background:var(--bg-secondary);border-radius:6px;color:var(--text-secondary);font-size:12px;font-weight:500;padding:4px 8px}.stt-provider-languages{color:var(--text-muted);font-size:12px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.punctuation-selector{align-items:center;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:var(--bg-glass);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;min-width:120px;padding:8px 16px;transition:all .3s ease}.punctuation-selector:hover{background:var(--accent-primary-alpha);border-color:var(--accent-primary);transform:translateY(-1px)}.punctuation-icon{font-size:16px}.punctuation-display{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.punctuation-selector-overlay{align-items:center;animation:modalFadeIn .3s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.punctuation-selector-modal{animation:modalSlideIn .3s ease-out;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:var(--bg-glass-strong);border:1px solid var(--border-color);border-radius:16px;box-shadow:0 20px 40px #0000004d;max-height:80vh;max-width:650px;overflow:hidden;padding:0;width:90%}.punctuation-modal-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:24px 32px 16px}.punctuation-modal-header h2{color:var(--text-primary);font-size:24px;font-weight:600;margin:0}.punctuation-modal-content{max-height:60vh;overflow-y:auto;padding:24px 32px 32px}.punctuation-toggle-section{margin-bottom:32px}.punctuation-enable-toggle h3{color:var(--text-primary);font-size:18px;font-weight:600;margin:0 0 8px}.punctuation-enable-toggle p{color:var(--text-secondary);font-size:14px;line-height:1.5;margin:0 0 16px}.toggle-button{align-items:center;background:var(--bg-glass);border:2px solid var(--border-color);border-radius:12px;color:var(--text-primary);display:flex;font-size:16px;font-weight:500;gap:12px;padding:12px 20px;transition:all .3s ease;width:fit-content}.toggle-button:hover{background:var(--accent-primary-alpha);border-color:var(--accent-primary);transform:translateY(-1px)}.toggle-button.enabled{background:var(--accent-secondary-alpha);border-color:var(--accent-secondary);color:var(--accent-secondary)}.toggle-button.disabled{background:var(--bg-secondary);border-color:var(--text-muted);color:var(--text-muted)}.toggle-icon{font-size:20px}.toggle-text{font-weight:600}.punctuation-styles-section h3{color:var(--text-primary);font-size:18px;font-weight:600;margin:0 0 8px}.punctuation-styles-section p{color:var(--text-secondary);font-size:14px;line-height:1.5;margin:0 0 20px}.punctuation-styles-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.punctuation-style-card{background:var(--bg-glass);border:2px solid var(--border-color);border-radius:12px;cursor:pointer;padding:20px;position:relative;text-align:center;transition:all .3s ease}.punctuation-style-card:hover{background:var(--accent-primary-alpha);border-color:var(--accent-primary);box-shadow:0 8px 25px var(--accent-primary-alpha);transform:translateY(-2px)}.punctuation-style-card.active{background:var(--accent-secondary-alpha);border-color:var(--accent-secondary);box-shadow:0 4px 20px var(--accent-secondary-alpha)}.punctuation-style-icon{font-size:32px;margin-bottom:12px}.punctuation-style-name{color:var(--text-primary);font-size:18px;font-weight:600;margin-bottom:8px}.punctuation-style-description{color:var(--text-secondary);font-size:14px;line-height:1.4;margin-bottom:16px}.punctuation-style-features{align-items:center;display:flex;flex-direction:column;gap:6px}.punctuation-style-features .feature{background:var(--bg-secondary);border-radius:6px;color:var(--text-secondary);font-size:12px;font-weight:500;padding:4px 8px;width:fit-content}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.theme-animation-icon{display:none}}.loading-screen{align-items:center;background:var(--bg-primary);display:flex;height:100vh;justify-content:center;left:0;position:fixed;top:0;width:100vw;z-index:9999}.loading-content{color:var(--text-primary);text-align:center}.loading-logo{animation:loadingPulse 2s ease-in-out infinite;border-radius:16px;box-shadow:0 8px 32px #3b82f64d;height:80px;margin-bottom:20px;width:80px}.loading-content .loading-spinner{animation:spin 1s linear infinite;border:3px solid #3b82f64d;border-radius:50%;border-top:3px solid var(--accent-primary);height:40px;margin:0 auto 15px;width:40px}.loading-content p{color:var(--text-secondary);font-size:1.1rem;font-weight:500;margin:0}@keyframes loadingPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}.header-logout-button{align-items:center;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border:none;border-radius:25px;box-shadow:0 2px 8px #0000001a;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:600;gap:8px;padding:10px 16px;transition:all .3s ease}.header-logout-button:hover{box-shadow:0 4px 16px #3b82f64d;transform:translateY(-2px)}.header-logout-button:active{transform:translateY(0)}.logout-icon{font-size:1rem}.logout-text{font-size:.85rem}@media (max-width:768px){.header-logout-button{font-size:.8rem;padding:8px 12px}.logout-text{display:none}.logout-icon{font-size:1.1rem}}.app.authenticated{animation:appAuthenticated .6s ease-out}@keyframes appAuthenticated{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}body.login-active{margin:0;overflow:hidden;padding:0}.login-page{align-items:center;background:#0f0f0f;background:var(--bg-primary);display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;justify-content:center;min-height:100vh;padding:20px;transition:background-color .3s ease}.login-container{animation:loginFadeIn .6s ease-out;background:#1a1a1a;background:var(--bg-secondary);border:1px solid #333;border:1px solid var(--border-color);border-radius:20px;box-shadow:0 20px 40px #0000001a;max-width:500px;padding:40px;width:100%}.login-header{margin-bottom:40px;text-align:center}.logo-container{align-items:center;display:flex;gap:15px;justify-content:center;margin-bottom:15px}.login-logo{border-radius:12px;box-shadow:0 4px 12px #00000026;height:50px;width:50px}.app-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#6366f1);background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;background-clip:text;font-size:2.2rem;font-weight:700;margin:0}.app-subtitle{color:#a0a0a0;color:var(--text-secondary);font-size:1rem;margin:0;opacity:.8}.form-header{margin-bottom:30px;text-align:center}.form-header h2{color:#fff;color:var(--text-primary);font-size:1.8rem;font-weight:600;margin:0 0 8px}.form-header p{color:#a0a0a0;color:var(--text-secondary);font-size:.95rem;margin:0}.login-form{margin-bottom:25px}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:.9rem;font-weight:600;margin-bottom:8px}.form-group input,.form-group label{color:#fff;color:var(--text-primary)}.form-group input{background:#0f0f0f;background:var(--bg-primary);border:2px solid #333;border:2px solid var(--border-color);border-radius:12px;box-sizing:border-box;font-size:1rem;padding:14px 16px;transition:all .3s ease;width:100%}.form-group input:focus{border-color:#3b82f6;border-color:var(--accent-primary);box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-group input.error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.form-group input:disabled{cursor:not-allowed;opacity:.6}.form-group input::placeholder{color:#a0a0a0;color:var(--text-secondary);opacity:.7}.error-message{color:#ef4444;display:block;font-size:.85rem;font-weight:500;margin-top:6px}.general-error{background:#ef44441a;border:1px solid #ef44444d;border-radius:8px;margin:20px 0;padding:12px;text-align:center}.submit-button{align-items:center;background:linear-gradient(135deg,#3b82f6,#6366f1);background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border:none;border-radius:12px;color:#fff;cursor:pointer;display:flex;font-size:1.05rem;font-weight:600;gap:10px;justify-content:center;margin-top:10px;padding:16px;transition:all .3s ease;width:100%}.submit-button:hover:not(:disabled){box-shadow:0 8px 25px #3b82f64d;transform:translateY(-2px)}.submit-button:active:not(:disabled){transform:translateY(-1px)}.submit-button:disabled{cursor:not-allowed;opacity:.7;transform:none}.submit-button.loading{pointer-events:none}.loading-spinner{animation:spin 1s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:20px;width:20px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.form-footer{border-top:1px solid #333;border-top:1px solid var(--border-color);padding-top:20px;text-align:center}.form-footer p{color:#a0a0a0;color:var(--text-secondary);font-size:.95rem;margin:0}.toggle-button{background:none;border:none;color:#3b82f6;color:var(--accent-primary);cursor:pointer;font-size:.95rem;font-weight:600;text-decoration:underline;transition:color .3s ease}.toggle-button:hover{color:#6366f1;color:var(--accent-secondary)}.features-preview{border-top:1px solid #333;border-top:1px solid var(--border-color);margin-top:30px;padding-top:25px}.feature{align-items:center;color:#a0a0a0;color:var(--text-secondary);display:flex;font-size:.9rem;gap:12px;margin-bottom:15px}.feature:last-child{margin-bottom:0}.feature-icon{font-size:1.2rem;text-align:center;width:24px}@keyframes loginFadeIn{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.login-page{padding:15px}.login-container{border-radius:16px;padding:30px 25px}.app-title{font-size:1.8rem}.form-header h2{font-size:1.5rem}.logo-container{gap:12px}.login-logo{height:40px;width:40px}}@media (max-width:480px){.login-container{padding:25px 20px}.form-group input{padding:12px 14px}.submit-button{font-size:1rem;padding:14px}}:root[data-theme=dark]{--bg-primary:#0f0f0f;--bg-secondary:#1a1a1a;--text-primary:#fff;--text-secondary:#a0a0a0;--border-color:#333;--accent-primary:#3b82f6;--accent-secondary:#6366f1}:root[data-theme=light]{--bg-primary:#f8fafc;--bg-secondary:#fff;--text-primary:#1e293b;--text-secondary:#64748b;--border-color:#e2e8f0;--accent-primary:#3b82f6;--accent-secondary:#6366f1}:root{--bg-primary:#0f0f0f;--bg-secondary:#1a1a1a;--text-primary:#fff;--text-secondary:#a0a0a0;--border-color:#333;--accent-primary:#3b82f6;--accent-secondary:#6366f1}
/*# sourceMappingURL=main.6da4a603.css.map*/