*{margin:0;padding:0;box-sizing:border-box}:root{font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-height:100vh}#root{min-height:100vh}*{margin:0;padding:0;box-sizing:border-box;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}:root{--bg-primary: #0f0f23;--bg-secondary: #1a1a2e;--bg-card: #16213e;--accent-primary: #6366f1;--accent-secondary: #8b5cf6;--accent-tertiary: #ec4899;--text-primary: #f8fafc;--text-secondary: #cbd5e1;--text-muted: #64748b;--border-color: rgba(148, 163, 184, .1);--shadow-sm: 0 4px 6px -1px rgba(0, 0, 0, .3);--shadow-md: 0 10px 25px -5px rgba(0, 0, 0, .4);--shadow-lg: 0 20px 50px -12px rgba(0, 0, 0, .5);--shadow-glow: 0 0 30px rgba(99, 102, 241, .3)}.app{min-height:100vh;background:var(--bg-primary);background-image:radial-gradient(circle at 20% 30%,rgba(99,102,241,.15) 0%,transparent 50%),radial-gradient(circle at 80% 70%,rgba(139,92,246,.15) 0%,transparent 50%);display:flex;align-items:center;justify-content:center;padding:1.5rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.container{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:32px;padding:3rem 2.5rem;max-width:680px;width:100%;box-shadow:var(--shadow-lg)}.header{text-align:center;margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid var(--border-color)}.logo{display:inline-flex;align-items:center;justify-content:center;margin-bottom:1.5rem;animation:float 3s ease-in-out infinite;filter:drop-shadow(var(--shadow-glow))}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}h1{font-size:2.75rem;font-weight:700;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 50%,var(--accent-tertiary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.75rem;letter-spacing:-.025em}.subtitle{color:var(--text-secondary);font-size:1.0625rem;font-weight:400;letter-spacing:.01em}.mode-toggle-container{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid var(--border-color)}.mode-toggle{display:flex;gap:.75rem;margin-bottom:1rem}.mode-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.625rem;padding:1rem 1.5rem;background:var(--bg-card);color:var(--text-secondary);border:2px solid var(--border-color);border-radius:16px;font-weight:600;font-size:.9375rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);font-family:inherit;box-shadow:var(--shadow-sm)}.mode-btn svg{transition:all .3s ease}.mode-btn:hover:not(:disabled){border-color:#6366f166;transform:translateY(-2px);box-shadow:var(--shadow-md)}.mode-btn.active{background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);color:var(--text-primary);border-color:#6366f180;box-shadow:var(--shadow-md),var(--shadow-glow)}.mode-btn:disabled{opacity:.5;cursor:not-allowed}.mode-info{text-align:center;color:var(--text-muted);font-size:.875rem;margin:0;padding:.75rem 1rem;background:#6366f10d;border-radius:12px;border:1px solid rgba(99,102,241,.1)}.model-info-button{display:flex;align-items:center;justify-content:center;width:100%;text-align:center;color:var(--text-muted);font-size:.875rem;margin:0;padding:.75rem 1rem;background:#6366f10d;border-radius:12px;border:1px solid rgba(99,102,241,.1);font-family:inherit;cursor:pointer;transition:all .2s ease}.model-info-button:hover:not(:disabled){background:#6366f11a;border-color:#6366f133;transform:translateY(-1px)}.model-info-button:disabled{opacity:.5;cursor:not-allowed}.model-selector{margin-top:1rem}.model-selector-label{display:block;color:var(--text-secondary);font-size:.875rem;font-weight:600;margin-bottom:.75rem;text-align:center}.model-options{display:grid;grid-template-columns:repeat(2,1fr);gap:.625rem;margin-bottom:.75rem}.model-options.mobile{grid-template-columns:1fr}.model-option{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.875rem .75rem;background:var(--bg-card);color:var(--text-secondary);border:2px solid var(--border-color);border-radius:12px;font-family:inherit;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-sm)}.model-option:hover:not(:disabled){border-color:#6366f166;transform:translateY(-2px);box-shadow:var(--shadow-md)}.model-option.active{background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);color:var(--text-primary);border-color:#6366f180;box-shadow:var(--shadow-md),0 0 20px #6366f133}.model-option:disabled{opacity:.5;cursor:not-allowed;transform:none}.model-option.warning{border-color:#fbbf244d}.model-option.warning:hover:not(:disabled){border-color:#fbbf2480}.model-option.warning.active{border-color:#fbbf2499}.model-name{font-size:.9375rem;font-weight:600;letter-spacing:.01em}.model-size{font-size:.75rem;opacity:.85;font-weight:500}.model-warning{font-size:.6875rem;color:#fbbf24;font-weight:600;margin-top:.125rem;text-align:center}.model-desc{text-align:center;color:var(--text-muted);font-size:.8125rem;line-height:1.4;margin:0;padding:.5rem .75rem;background:#6366f10d;border-radius:8px;border:1px solid rgba(99,102,241,.08)}.visualizer{background:var(--bg-card);border:1px solid var(--border-color);border-radius:24px;padding:3rem 2rem;margin-bottom:2.5rem;min-height:180px;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden;box-shadow:var(--shadow-md)}.visualizer:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at center,rgba(99,102,241,.05) 0%,transparent 70%);pointer-events:none}.waveform{display:flex;align-items:center;justify-content:center;gap:5px;height:100px;position:relative;z-index:1}.bar{width:3px;background:linear-gradient(180deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);border-radius:3px;transition:height .15s ease-out;animation:wave 1.5s ease-in-out infinite;box-shadow:0 0 8px #6366f180}@keyframes wave{0%,to{opacity:.3;filter:blur(0px)}50%{opacity:1;filter:blur(.5px)}}.recording-indicator{display:flex;align-items:center;gap:.875rem;margin-top:2rem;padding:.875rem 1.75rem;background:#0f0f2399;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(239,68,68,.2);border-radius:40px;box-shadow:0 8px 24px #ef444426;position:relative;z-index:2}.pulse-dot{width:10px;height:10px;background:#ef4444;border-radius:50%;animation:pulse 1.5s ease-in-out infinite;box-shadow:0 0 12px #ef4444cc}@keyframes pulse{0%,to{opacity:1;transform:scale(1);box-shadow:0 0 12px #ef4444cc}50%{opacity:.7;transform:scale(1.3);box-shadow:0 0 20px #ef4444}}.recording-text{font-weight:600;color:#fca5a5;font-size:.8125rem;letter-spacing:.08em;text-transform:uppercase}.timer{font-weight:600;color:var(--text-primary);font-size:1.0625rem;font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}.controls{display:flex;gap:1rem;justify-content:center;margin-bottom:2.5rem}.control-btn{display:flex;flex-direction:column;align-items:center;gap:.625rem;padding:1.375rem 1.25rem;border:1px solid var(--border-color);border-radius:20px;background:var(--bg-card);cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);min-width:110px;font-family:inherit;position:relative;overflow:hidden}.control-btn:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent 0%,rgba(255,255,255,.03) 100%);opacity:0;transition:opacity .25s ease}.control-btn:hover:not(:disabled):before{opacity:1}.control-btn:hover:not(:disabled){transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:#94a3b833}.control-btn:active:not(:disabled){transform:translateY(-1px)}.control-btn:disabled{opacity:.35;cursor:not-allowed}.control-btn svg{transition:all .25s cubic-bezier(.4,0,.2,1)}.control-btn span{font-size:.875rem;font-weight:600;color:var(--text-secondary);transition:color .25s ease}.record-btn svg{color:#ef4444;filter:drop-shadow(0 0 8px rgba(239,68,68,.4))}.record-btn.active{background:linear-gradient(135deg,#ef444426,#dc262626);border-color:#ef44444d;box-shadow:0 0 30px #ef444433}.record-btn.active span{color:#fca5a5}.pause-btn svg{color:#f59e0b;filter:drop-shadow(0 0 8px rgba(245,158,11,.4))}.pause-btn.active{background:linear-gradient(135deg,#f59e0b26,#d9770626);border-color:#f59e0b4d;box-shadow:0 0 30px #f59e0b33}.pause-btn.active span{color:#fcd34d}.stop-btn svg{color:var(--text-muted);filter:drop-shadow(0 0 6px rgba(100,116,139,.3))}.stop-btn:hover:not(:disabled) svg{color:var(--text-secondary)}.loading-container{margin-top:0;padding-top:3rem;padding-bottom:1rem;border-top:1px solid var(--border-color);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;min-height:240px}.loading-spinner{position:relative;width:80px;height:80px;display:flex;align-items:center;justify-content:center}.spinner-ring{position:absolute;width:100%;height:100%;border-radius:50%;border:3px solid transparent;animation:spin-ring 2s cubic-bezier(.5,0,.5,1) infinite}.spinner-ring:nth-child(1){border-top-color:var(--accent-primary);animation-delay:-.45s;width:100%;height:100%}.spinner-ring:nth-child(2){border-top-color:var(--accent-secondary);animation-delay:-.3s;width:75%;height:75%}.spinner-ring:nth-child(3){border-top-color:var(--accent-tertiary);animation-delay:-.15s;width:50%;height:50%}@keyframes spin-ring{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-text{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0;animation:pulse-text 1.5s ease-in-out infinite}.loading-subtext{font-size:.9375rem;color:var(--text-muted);margin:0;animation:pulse-text 1.5s ease-in-out infinite;animation-delay:.2s}.loading-note{font-size:.8125rem;color:var(--text-muted);margin:0;font-style:italic}@keyframes pulse-text{0%,to{opacity:1}50%{opacity:.6}}.transcription-container{margin-top:0;padding-top:2.5rem;border-top:1px solid var(--border-color)}.transcription-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.transcription-header h2{font-size:1.125rem;font-weight:600;color:var(--text-primary);letter-spacing:-.01em}.spinner{width:18px;height:18px;border:2.5px solid rgba(148,163,184,.2);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.transcription-box{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:1.75rem;min-height:140px;color:var(--text-secondary);font-size:1rem;line-height:1.75;white-space:pre-wrap;word-wrap:break-word;user-select:text;-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;box-shadow:var(--shadow-sm);transition:all .3s ease}.transcription-box:hover{border-color:#94a3b826}.action-buttons-wrapper{display:flex;justify-content:center;gap:.75rem;margin-top:1.25rem;flex-wrap:wrap}.action-btn{display:flex;align-items:center;justify-content:center;gap:.625rem;padding:1.0625rem 2.25rem;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);color:var(--text-primary);border:1px solid rgba(99,102,241,.3);border-radius:14px;font-weight:600;font-size:.9375rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);font-family:inherit;min-width:160px;box-shadow:var(--shadow-md),var(--shadow-glow);position:relative;overflow:hidden}.action-btn:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.1) 0%,transparent 100%);opacity:0;transition:opacity .3s ease}.action-btn:hover:before{opacity:1}.action-btn:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 12px 32px #6366f166,var(--shadow-glow)}.action-btn:active:not(:disabled){transform:translateY(-1px)}.action-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.speak-btn.speaking{background:linear-gradient(135deg,#f59e0b,#d97706);border-color:#f59e0b4d;box-shadow:0 12px 32px #f59e0b4d,0 0 30px #f59e0b4d;animation:pulse-speak 1.5s ease-in-out infinite}@keyframes pulse-speak{0%,to{opacity:1}50%{opacity:.85}}.stop-speak-btn{background:linear-gradient(135deg,#ef4444,#dc2626);border-color:#ef44444d;box-shadow:0 12px 32px #ef44444d,0 0 30px #ef44444d}.stop-speak-btn:hover{box-shadow:0 12px 32px #ef444480,0 0 30px #ef444480}.copy-btn.copied{background:linear-gradient(135deg,#10b981,#059669);border-color:#10b9814d;box-shadow:0 12px 32px #10b9814d,0 0 30px #10b9814d;animation:copySuccess .3s cubic-bezier(.34,1.56,.64,1)}@keyframes copySuccess{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.copy-btn.copied svg{animation:checkmark .4s cubic-bezier(.34,1.56,.64,1)}@keyframes checkmark{0%{transform:scale(0) rotate(-45deg);opacity:0}50%{opacity:1}to{transform:scale(1) rotate(0);opacity:1}}@media(max-width:640px){.app{padding:1rem}.container{padding:2rem 1.5rem}.header{margin-bottom:2rem;padding-bottom:1.5rem}h1{font-size:2rem}.subtitle{font-size:.9375rem}.visualizer{padding:2rem 1.5rem;min-height:160px}.waveform{gap:4px;height:80px}.bar{width:2.5px}.controls{flex-wrap:wrap;gap:.875rem}.control-btn{min-width:calc(50% - .4375rem);flex:1}.action-buttons-wrapper{flex-direction:column}.action-btn{width:100%;min-width:unset}.mode-toggle{flex-direction:column;gap:.625rem}.mode-btn span{font-size:.875rem}.mode-info{font-size:.8125rem}}.modal-overlay{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1.5rem;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:24px;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg),0 0 60px #6366f133;animation:slideUp .3s cubic-bezier(.4,0,.2,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 2rem;border-bottom:1px solid var(--border-color)}.modal-header h3{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.modal-close{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s ease}.modal-close:hover{background:#ffffff0d;color:var(--text-primary)}.modal-body{padding:2rem}.modal-body .model-options{margin-bottom:1.5rem}.modal-body .model-desc{margin-top:1.5rem}.language-selector-container{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid var(--border-color)}.language-button{display:flex;align-items:center;justify-content:center;width:100%;padding:1rem 1.5rem;background:#6366f10d;border-radius:12px;border:1px solid rgba(99,102,241,.1);font-family:inherit;font-size:.9375rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.language-button:hover:not(:disabled){background:#6366f11a;border-color:#6366f133;transform:translateY(-1px)}.language-button:disabled{opacity:.5;cursor:not-allowed}.language-modal{max-width:600px}.language-section{margin-bottom:2rem}.language-section:last-child{margin-bottom:0}.language-section h4{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-color)}.language-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.language-option{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.375rem;padding:1rem .75rem;background:var(--bg-card);color:var(--text-secondary);border:2px solid var(--border-color);border-radius:12px;font-family:inherit;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-sm);min-height:80px}.language-option:hover{border-color:#6366f166;transform:translateY(-2px);box-shadow:var(--shadow-md)}.language-option.active{background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);color:var(--text-primary);border-color:#6366f180;box-shadow:var(--shadow-md),0 0 20px #6366f133}.language-flag{font-size:1.75rem;line-height:1}.language-name{font-size:.8125rem;font-weight:600;text-align:center;line-height:1.2}.cancel-btn svg{color:#f87171;filter:drop-shadow(0 0 8px rgba(248,113,113,.4))}.cancel-btn:hover:not(:disabled) svg{color:#ef4444;filter:drop-shadow(0 0 12px rgba(239,68,68,.6))}.cancel-btn:hover:not(:disabled) span{color:#fca5a5}@media(max-width:640px){.language-grid{grid-template-columns:repeat(2,1fr);gap:.625rem}.language-option{padding:.875rem .625rem;min-height:75px}.language-flag{font-size:1.5rem}.language-name{font-size:.75rem}.language-button{font-size:.875rem;padding:.875rem 1.25rem}}.install-prompt{position:fixed;bottom:0;left:0;right:0;z-index:1000;padding:1rem;animation:slideUpPrompt .3s ease-out}.install-prompt-content{background:linear-gradient(135deg,#6366f1f2,#8b5cf6f2);border-radius:16px;padding:1rem 1.25rem;display:flex;align-items:center;gap:1rem;box-shadow:0 8px 32px #0000004d,0 0 0 1px #ffffff1a inset;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);max-width:600px;margin:0 auto}.install-prompt-icon{font-size:2rem;line-height:1;flex-shrink:0}.install-prompt-text{flex:1;min-width:0}.install-prompt-text h3{margin:0 0 .25rem;font-size:.9375rem;font-weight:600;color:#fff}.install-prompt-text p{margin:0;font-size:.8125rem;color:#ffffffd9;line-height:1.3}.install-prompt-actions{display:flex;gap:.5rem;align-items:center;flex-shrink:0}.install-prompt-btn{border:none;cursor:pointer;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-weight:600;transition:all .2s ease;border-radius:8px}.install-prompt-btn.install{background:#fffffff2;color:#6366f1;padding:.625rem 1.25rem;font-size:.875rem}.install-prompt-btn.install:hover{background:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.install-prompt-btn.install:active{transform:translateY(0)}.install-prompt-btn.dismiss{background:#ffffff26;color:#ffffffe6;padding:.5rem;font-size:1rem;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.install-prompt-btn.dismiss:hover{background:#ffffff40}@keyframes slideUpPrompt{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@media(max-width:640px){.install-prompt{padding:.75rem}.install-prompt-content{padding:.875rem 1rem;gap:.75rem}.install-prompt-icon{font-size:1.75rem}.install-prompt-text h3{font-size:.875rem}.install-prompt-text p{font-size:.75rem}.install-prompt-btn.install{padding:.5rem 1rem;font-size:.8125rem}}
