*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg-color:#0d0d0e;--surface-color:#161618;--text-primary:#e6e5e8;--text-secondary:#9e99a8;--text-muted:#837b8e;--accent-violet:#5d4e70;--accent-violet-light:#a99bbd;--accent-glow:rgba(93,78,112,.4);--accent-glow-subtle:rgba(93,78,112,.15);--danger:#8f3a3a;--green:#3a8f5c;--font-serif:"Cormorant Garamond",serif;--font-sans:"Inter",-apple-system,BlinkMacSystemFont,sans-serif;--grain-opacity:0.07;--blur-strength:64px;--transition:0.4s cubic-bezier(0.22,1,0.36,1)}body,html{height:100%;background-color:var(--bg-color);color:var(--text-primary);font-family:var(--font-serif);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;-webkit-overflow-scrolling:touch;cursor:default}.noise-overlay{z-index:9999;opacity:var(--grain-opacity);background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E")}.noise-overlay,.vignette{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none}.vignette{background:radial-gradient(circle at center,transparent 30%,rgba(13,13,14,.8) 100%);z-index:5}.ambient-glow{position:fixed;width:120vw;height:120vh;background:radial-gradient(circle at 50% 50%,rgba(46,37,54,.3) 0,transparent 60%);top:50%;left:50%;transform:translate(-50%,-50%);z-index:0;pointer-events:none;filter:blur(var(--blur-strength));animation:ambient-breathe 12s ease-in-out infinite alternate}@keyframes ambient-breathe{0%{opacity:.4;transform:translate(-50%,-50%) scale(.9)}to{opacity:.7;transform:translate(-50%,-50%) scale(1.1)}}.app{min-height:100vh;min-height:100dvh;position:relative;z-index:10}.app,.loading-screen{width:100vw;display:flex;justify-content:center;align-items:center}.loading-screen{height:100vh}.meta-label{font-family:var(--font-sans);font-size:10px;text-transform:uppercase;letter-spacing:2px;color:var(--text-secondary);font-weight:600}.serif-heading{font-family:var(--font-serif);font-weight:300;letter-spacing:-.02em;line-height:1.1;color:#d1d0d4;text-shadow:0 0 20px hsla(0,0%,100%,.1)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-sans);font-size:14px;font-weight:400;border:none;border-radius:12px;cursor:pointer;transition:all var(--transition);padding:12px 28px;min-height:48px;-webkit-tap-highlight-color:transparent}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent-violet);color:#fff}.btn-primary:hover:not(:disabled){background:#6b5a80;box-shadow:0 4px 20px var(--accent-glow);transform:translateY(-1px)}.btn-secondary{background:hsla(0,0%,100%,.04);color:var(--text-primary);border:1px solid hsla(0,0%,100%,.08)}.btn-secondary:hover:not(:disabled){background:hsla(0,0%,100%,.08);border-color:hsla(0,0%,100%,.12)}.btn-link{background:none;color:var(--text-muted);padding:8px;font-size:12px;margin-top:16px;border:none;cursor:pointer;font-family:var(--font-sans);transition:color .3s}.btn-ghost,.btn-link:hover{color:var(--text-secondary)}.btn-ghost{background:none;border:none;font-family:var(--font-sans);font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;cursor:pointer;padding:10px 16px;transition:color .3s ease}.btn-ghost:hover{color:var(--text-primary)}.voice-setup{width:100%;min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:max(32px,env(safe-area-inset-top,32px)) 24px max(40px,env(safe-area-inset-bottom,40px));overflow-y:auto;position:relative;z-index:10}.setup-container{max-width:480px;width:100%;text-align:center}.setup-icon{font-size:48px;margin-bottom:24px;filter:grayscale(.3)}.setup-title{font-family:var(--font-serif);font-size:2.8rem;font-weight:300;letter-spacing:-.02em;margin-bottom:8px;color:#d1d0d4;text-shadow:0 0 20px hsla(0,0%,100%,.1)}.setup-step{margin-top:32px}.setup-description{font-family:var(--font-sans);font-size:15px;line-height:1.7;color:var(--text-secondary);margin-bottom:28px;font-weight:400}.setup-description em{color:var(--text-primary);font-style:italic}.voice-name-input{width:100%;padding:14px 18px;border:1px solid hsla(0,0%,100%,.08);border-radius:12px;background:hsla(0,0%,100%,.04);color:var(--text-primary);font-family:var(--font-sans);font-size:16px;outline:none;transition:border-color var(--transition);margin-bottom:20px}.voice-name-input:focus{border-color:var(--accent-violet);box-shadow:0 0 0 3px var(--accent-glow-subtle)}.voice-name-input::placeholder{color:var(--text-muted)}.record-options{display:flex;flex-direction:column;align-items:center;gap:16px}.divider-text{color:var(--text-muted);font-family:var(--font-sans);font-size:11px;text-transform:uppercase;letter-spacing:2px}.btn-record{background:hsla(0,0%,100%,.04);color:var(--accent-violet-light);border:1px solid hsla(0,0%,100%,.08);padding:14px 32px;font-size:15px;border-radius:12px}.btn-record:hover{border-color:var(--accent-violet);box-shadow:0 0 20px var(--accent-glow-subtle)}.record-dot{width:10px;height:10px;border-radius:50%;background:var(--accent-violet-light)}.btn-stop{background:var(--danger);color:#fff;padding:14px 32px;border-radius:12px}.btn-stop:hover{background:#a04040}.recording-active{display:flex;flex-direction:column;align-items:center;gap:20px}.recording-indicator{display:flex;align-items:center;gap:12px;font-size:24px;font-weight:400;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;font-family:var(--font-sans)}.recording-hint{color:var(--text-muted);font-size:13px;font-family:var(--font-sans)}.recording-done{display:flex;flex-direction:column;align-items:center;gap:20px}.recording-ready{color:var(--green);font-size:14px;font-weight:500;font-family:var(--font-sans)}.recording-actions{display:flex;gap:12px}.read-aloud-script{margin-bottom:24px;border-radius:12px;border:1px solid hsla(0,0%,100%,.06);background:hsla(0,0%,100%,.03);overflow:hidden}.read-aloud-toggle{display:block;padding:14px 18px;font-family:var(--font-sans);font-size:13px;font-weight:500;color:var(--text-secondary);cursor:pointer;list-style:none;text-align:center;transition:color .2s;-webkit-tap-highlight-color:transparent}.read-aloud-toggle::-webkit-details-marker{display:none}.read-aloud-toggle:hover{color:var(--text-primary)}.read-aloud-script[open] .read-aloud-toggle{border-bottom:1px solid hsla(0,0%,100%,.06);color:var(--accent-violet-light)}.read-aloud-text{padding:18px 20px;font-family:var(--font-sans);font-size:15px;line-height:1.8;color:var(--text-primary);font-weight:400;max-height:300px;overflow-y:auto}.read-aloud-text p{margin-bottom:14px}.read-aloud-text p:last-child{margin-bottom:0}.pulse-dot{width:10px;height:10px;min-width:10px;border-radius:50%;background:var(--accent-violet-light);animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}.preview-actions{display:flex;gap:12px;justify-content:center;margin-top:24px}.preview-hint{margin-top:12px;font-size:12px;color:var(--text-muted);animation:fadeIn .3s ease-out}.error-message,.preview-hint{font-family:var(--font-sans);text-align:center}.error-message{margin-top:24px;padding:14px 18px;background:rgba(143,58,58,.1);border:1px solid rgba(143,58,58,.25);border-radius:12px;color:#e8a0a0;font-size:13px}.provider-select{margin:20px 0;text-align:left;width:100%}.provider-select .settings-label{margin-bottom:10px;display:block}.provider-options{display:flex;gap:10px}.provider-option{flex:1 1;padding:14px 12px;border-radius:10px;border:1px solid hsla(0,0%,100%,.06);background:hsla(0,0%,100%,.03);cursor:pointer;transition:all .2s;display:flex;flex-direction:column;gap:4px;text-align:left}.provider-option:hover{border-color:rgba(93,78,112,.3)}.provider-option.active{background:rgba(93,78,112,.25);border-color:var(--accent-violet-light);box-shadow:0 0 20px rgba(93,78,112,.25),inset 0 0 0 1px rgba(169,155,189,.15)}.provider-name{font-family:var(--font-sans);font-size:13px;font-weight:600;color:var(--text-primary)}.provider-option.active .provider-name{color:#c8bbda}.provider-desc{font-family:var(--font-sans);font-size:11px;color:var(--text-muted)}.provider-option.active .provider-desc{color:var(--text-secondary)}.skip-clone{margin-top:24px}.clone-fallback{margin-top:28px;padding:20px;background:rgba(93,78,112,.06);border:1px solid rgba(93,78,112,.15);border-radius:12px}.fallback-text{font-size:13px;color:var(--text-secondary);line-height:1.6;margin-bottom:16px;font-family:var(--font-sans)}.voice-grid{display:flex;flex-direction:column;gap:8px;max-height:280px;overflow-y:auto;padding-right:4px;margin-bottom:20px}.voice-grid::-webkit-scrollbar{width:3px}.voice-grid::-webkit-scrollbar-track{background:transparent}.voice-grid::-webkit-scrollbar-thumb{background:hsla(0,0%,100%,.1);border-radius:2px}.voice-card{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:hsla(0,0%,100%,.03);border:1px solid hsla(0,0%,100%,.06);border-radius:10px;cursor:pointer;transition:all var(--transition);text-align:left;font-family:var(--font-sans);color:var(--text-primary);width:100%}.voice-card:hover{border-color:hsla(0,0%,100%,.1);background:hsla(0,0%,100%,.05)}.voice-card.selected{border-color:var(--accent-violet);background:rgba(93,78,112,.1);box-shadow:0 0 12px var(--accent-glow-subtle)}.voice-card-info{display:flex;flex-direction:column;gap:2px}.voice-name{font-size:13px;font-weight:500}.voice-meta{font-size:11px;color:var(--text-muted);text-transform:capitalize}.voice-preview-btn{width:32px;height:32px;border-radius:50%;border:1px solid hsla(0,0%,100%,.08);background:var(--bg-color);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;transition:all var(--transition);flex-shrink:0}.voice-preview-btn:hover{border-color:var(--accent-violet);color:var(--accent-violet-light)}.pick-actions{margin-top:16px;margin-bottom:8px}.breathing-circle{width:80px;height:80px;border-radius:50%;background:radial-gradient(circle,var(--accent-glow) 0,transparent 70%);animation:breathe-circle 3s ease-in-out infinite;margin:0 auto 24px}@keyframes breathe-circle{0%,to{transform:scale(.85);opacity:.6}50%{transform:scale(1.15);opacity:1}}.loading-state{display:flex;flex-direction:column;align-items:center}.loading-text{font-size:15px;font-weight:400;color:var(--text-primary);font-family:var(--font-sans)}.loading-subtext{font-size:12px;color:var(--text-muted);margin-top:8px;font-family:var(--font-sans)}.mirror-session{max-width:480px;min-height:100vh;min-height:100dvh;flex-direction:column;position:relative;z-index:10;padding:max(40px,env(safe-area-inset-top,40px)) 24px max(32px,env(safe-area-inset-bottom,32px))}.mirror-session,.top-bar{width:100%;display:flex;justify-content:space-between;align-items:center}.top-bar{opacity:0;animation:fadeIn 1.5s ease-out .3s forwards}.session-pill{position:absolute;left:50%;transform:translateX(-50%);background:hsla(0,0%,100%,.06);border:1px solid hsla(0,0%,100%,.05);padding:6px 16px;border-radius:100px;display:flex;align-items:center;gap:8px}.session-indicator{width:6px;height:6px;background-color:var(--accent-violet-light);border-radius:50%;box-shadow:0 0 8px var(--accent-violet-light)}.session-time{font-family:var(--font-sans);font-size:10px;letter-spacing:1px;color:hsla(0,0%,100%,.7);text-transform:uppercase;font-weight:600}.peripheral-text{position:absolute;top:50%;transform:translateY(-50%);width:100%;pointer-events:none;display:flex;justify-content:space-between;padding:0 12px;opacity:.25}.peripheral-text span{writing-mode:vertical-rl;-webkit-text-orientation:mixed;text-orientation:mixed;transform:rotate(180deg)}.stage{flex-grow:1;display:flex;flex-direction:column;justify-content:center;align-items:center;position:relative;width:100%}.prompt-text{font-family:var(--font-serif);font-size:2rem;line-height:1.3;text-align:center;font-weight:300;color:var(--text-primary);opacity:.9;letter-spacing:-.01em;max-width:320px;margin-bottom:2rem;transition:opacity .8s ease}.prompt-subtitle{display:block;font-size:1.1rem;color:var(--text-secondary);margin-top:1rem;font-style:italic}.prompt-card{background:hsla(0,0%,100%,.02);border:1px solid hsla(0,0%,100%,.04);padding:1.5rem 2rem;text-align:center;margin-bottom:2.5rem;border-radius:2px;animation:slideUp 1.5s ease-out forwards}.prompt-card-label{font-family:var(--font-sans);font-size:.6rem;text-transform:uppercase;letter-spacing:.15em;color:var(--text-muted);margin-bottom:8px}.prompt-card-text{font-family:var(--font-serif);font-size:1.3rem;font-style:italic;color:#c0bdc4;line-height:1.4}.visualizer-stage{width:200px;height:200px;position:relative;display:flex;justify-content:center;align-items:center;margin-bottom:2rem;filter:blur(20px) contrast(120%)}.orb{width:120px;height:120px;background:radial-gradient(circle,var(--accent-violet-light) 0,rgba(13,13,14,0) 70%);opacity:.6;transition:all .5s ease-out}.orb,.orb-secondary{border-radius:50%;position:absolute}.orb-secondary{width:80px;height:80px;background:radial-gradient(circle,hsla(0,0%,100%,.15) 0,rgba(13,13,14,0) 70%);opacity:.3}.orb.breathing{animation:orb-breathe 6s ease-in-out infinite}.orb.listening{animation:orb-ripple 2s cubic-bezier(.4,0,.6,1) infinite;background:radial-gradient(circle,#8a7b99 0,rgba(13,13,14,0) 60%)}.orb.speaking{animation:orb-speak .3s ease-out infinite alternate}@keyframes orb-breathe{0%,to{transform:scale(1);opacity:.4}50%{transform:scale(1.4);opacity:.7}}@keyframes orb-ripple{0%{transform:scale(.8);opacity:.8}to{transform:scale(2.5);opacity:0}}@keyframes orb-speak{0%{transform:scale(1);opacity:.6}to{transform:scale(1.3);opacity:.9}}.waveform-rings{position:absolute;width:300px;height:300px;display:flex;justify-content:center;align-items:center;pointer-events:none}.waveform-ring{position:absolute;border-radius:50%;border:1px solid rgba(93,78,112,.1);animation:ring-breathe 8s ease-in-out infinite;opacity:0;transition:opacity .5s,border-color .5s}.waveform-ring:first-child{width:100%;height:100%}.waveform-ring:nth-child(2){width:80%;height:80%;animation-delay:1s}.waveform-ring:nth-child(3){width:60%;height:60%;animation-delay:2s}.waveform-ring.active{border-color:rgba(93,78,112,.3);opacity:1}@keyframes ring-breathe{0%,to{transform:scale(.95);opacity:.1}50%{transform:scale(1.05);opacity:.3}}.waveform-bars{display:flex;align-items:center;justify-content:center;gap:4px;height:60px;margin-bottom:2rem;opacity:0;transition:opacity .5s ease}.waveform-bars.active{opacity:.7}.wave-bar{width:3px;background-color:var(--accent-violet);border-radius:2px;height:4px;transition:height .1s ease;box-shadow:0 0 6px rgba(93,78,112,.2);filter:blur(.3px)}.wave-bar:nth-child(odd){background-color:#58506b}.record-btn-wrapper{position:relative;width:120px;height:120px;display:flex;justify-content:center;align-items:center;cursor:pointer;-webkit-tap-highlight-color:transparent}.record-btn-ring{position:absolute;width:100%;height:100%;border-radius:50%;border:1px solid rgba(93,78,109,.3);transition:all .6s cubic-bezier(.22,1,.36,1)}.record-btn-core{width:80px;height:80px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#2a2533,#0d0d0e);border:1px solid hsla(0,0%,100%,.08);box-shadow:0 0 30px rgba(0,0,0,.5),inset 0 0 20px rgba(0,0,0,.8),0 0 0 1px rgba(93,78,112,.1);position:relative;z-index:20;transition:all .5s ease;display:flex;justify-content:center;align-items:center}.record-btn-dot{width:12px;height:12px;background-color:var(--accent-violet);border-radius:50%;box-shadow:0 0 15px rgba(93,78,112,.3);transition:all .3s ease;opacity:.7}.record-btn-wrapper:hover .record-btn-ring{border-color:rgba(93,78,109,.6);transform:scale(1.05)}.record-btn-wrapper:hover .record-btn-dot{transform:scale(1.2);background-color:#7a698c}.record-btn-wrapper.recording .record-btn-ring{border-color:rgba(93,78,109,.8);animation:pulse-ring 2s infinite}.record-btn-wrapper.recording .record-btn-core{border-color:rgba(93,78,112,.5);box-shadow:0 0 50px var(--accent-glow),inset 0 0 10px rgba(0,0,0,.9)}.record-btn-wrapper.recording .record-btn-dot{border-radius:3px;transform:scale(1.2);background-color:var(--text-primary);box-shadow:0 0 20px rgba(230,225,232,.3);opacity:1}@keyframes pulse-ring{0%{transform:scale(1);opacity:.5;box-shadow:0 0 0 0 rgba(93,78,109,.2)}50%{transform:scale(1.15);opacity:.8;box-shadow:0 0 20px 10px rgba(93,78,109,.1)}to{transform:scale(1);opacity:.5;box-shadow:0 0 0 0 rgba(93,78,109,0)}}.distortion-lens{position:absolute;top:-10px;left:-10px;right:-10px;bottom:-10px;background:radial-gradient(circle,transparent 60%,rgba(13,13,14,.8));z-index:25;pointer-events:none;border-radius:50%}.status-label{margin-top:1.5rem;font-family:var(--font-sans);font-size:.8rem;letter-spacing:.05em;text-transform:lowercase;color:var(--text-secondary);opacity:0;transition:opacity .5s ease;text-align:center;height:20px;font-feature-settings:"smcp";font-variant-caps:small-caps}.status-label.visible{opacity:.7}.recording-info{display:flex;align-items:center;gap:10px;justify-content:center;margin-top:12px;font-size:14px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;color:var(--text-secondary);font-family:var(--font-sans)}.reflection-card{background:hsla(0,0%,100%,.02);border:1px solid hsla(0,0%,100%,.05);border-radius:2px;padding:2rem;text-align:left;width:100%;max-width:420px;animation:slideUp .6s ease-out}.card-label{font-family:var(--font-sans);font-size:.6rem;text-transform:uppercase;letter-spacing:.15em;color:var(--text-muted);margin-bottom:10px;font-weight:600}.transcript-text{font-family:var(--font-sans);font-size:13px;line-height:1.6;color:var(--text-secondary);font-weight:300}.card-divider{height:1px;background:hsla(0,0%,100%,.05);margin:20px 0}.reflection-text{font-family:var(--font-serif);font-size:1.3rem;line-height:1.5;color:var(--text-primary);font-weight:300;font-style:italic}.mirror-speaking .reflection-text{max-width:360px;margin:0 auto;text-align:center;animation:fadeIn .8s ease}.done-actions{display:flex;align-items:center;gap:1.5rem;margin-top:2rem;flex-wrap:wrap;justify-content:center}.inline-speed-controls{display:flex;gap:6px;align-items:center}.inline-speed-btn{padding:6px 12px;border-radius:100px;border:1px solid hsla(0,0%,100%,.08);background:hsla(0,0%,100%,.04);color:var(--text-secondary);font-family:var(--font-sans);font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.inline-speed-btn:hover{border-color:hsla(0,0%,100%,.15);color:var(--text-primary)}.inline-speed-btn.active{background:var(--accent-violet);border-color:var(--accent-violet-light);color:#fff;box-shadow:0 0 12px var(--accent-glow-subtle)}.footer-controls{gap:24px;opacity:0;animation:fadeIn 1.5s ease-out 1s forwards}.control-btn,.footer-controls{display:flex;justify-content:center}.control-btn{width:48px;height:48px;border-radius:50%;background-color:hsla(0,0%,100%,.04);border:none;align-items:center;color:var(--text-secondary);cursor:pointer;transition:background .2s,color .2s}.control-btn:hover{background-color:hsla(0,0%,100%,.08);color:var(--text-primary)}.control-btn svg{width:18px;height:18px;stroke-width:1.5px}.control-btn.active{background-color:rgba(93,78,112,.2);color:var(--accent-violet-light);border:1px solid rgba(93,78,112,.3)}.settings-panel{position:absolute;bottom:100px;left:50%;transform:translateX(-50%);background:rgba(20,18,24,.95);border:1px solid hsla(0,0%,100%,.06);border-radius:12px;padding:20px 24px;width:min(300px,calc(100vw - 48px));-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);animation:slideUp .3s ease-out;z-index:60}.settings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.settings-close{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:14px;padding:4px 8px;transition:color .2s}.settings-close:hover{color:var(--text-primary)}.settings-row{display:flex;flex-direction:column;gap:12px}.settings-label{font-family:var(--font-sans);font-size:12px;color:var(--text-secondary);font-weight:500}.speed-control{display:flex;align-items:center;gap:12px}.speed-slider{flex:1 1;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:4px;background:hsla(0,0%,100%,.08);border-radius:2px;outline:none;cursor:pointer}.speed-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent-violet-light);border:2px solid hsla(0,0%,100%,.15);box-shadow:0 0 10px rgba(93,78,112,.4);cursor:pointer;-webkit-transition:transform .15s ease;transition:transform .15s ease}.speed-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.speed-value{font-family:var(--font-sans);font-size:13px;font-weight:600;color:var(--accent-violet-light);min-width:36px;text-align:right;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.speed-presets{display:flex;gap:8px}.speed-preset{flex:1 1;padding:6px 0;border-radius:6px;border:1px solid hsla(0,0%,100%,.06);background:hsla(0,0%,100%,.03);color:var(--text-secondary);font-family:var(--font-sans);font-size:11px;cursor:pointer;transition:all .2s}.speed-preset:hover{border-color:rgba(93,78,112,.3);color:var(--text-primary)}.speed-preset.active{background:rgba(93,78,112,.2);border-color:rgba(93,78,112,.4);color:var(--accent-violet-light)}.context-indicator{font-size:.75rem;color:hsla(0,0%,100%,.15);font-family:var(--font-serif);font-style:italic;text-align:center;margin-top:1rem}.error-toast{position:fixed;bottom:32px;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:12px;padding:14px 20px;background:var(--surface-color);border:1px solid rgba(143,58,58,.25);border-radius:10px;color:#e8a0a0;font-size:13px;font-family:var(--font-sans);z-index:100;animation:slideUp .3s ease}.error-toast button{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:16px;padding:0 4px}.history-panel{position:absolute;bottom:100px;left:50%;transform:translateX(-50%);background:rgba(20,18,24,.95);border:1px solid hsla(0,0%,100%,.06);border-radius:12px;padding:20px 24px;width:min(340px,calc(100vw - 48px));max-height:300px;overflow-y:auto;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);animation:slideUp .3s ease-out;z-index:60}.history-title{font-family:var(--font-sans);font-size:10px;text-transform:uppercase;letter-spacing:2px;color:var(--text-muted);margin-bottom:12px;font-weight:600}.history-list{display:flex;flex-direction:column;gap:10px}.history-item{padding:12px 16px;background:hsla(0,0%,100%,.02);border:1px solid hsla(0,0%,100%,.04);border-radius:2px}.history-transcript{font-size:12px;color:var(--text-muted);margin-bottom:6px;font-family:var(--font-sans)}.history-reflection{font-size:14px;color:var(--text-secondary);font-style:italic;font-family:var(--font-serif)}.history-time{font-size:10px;display:block;margin-top:6px}.history-time,.reset-button{color:var(--text-muted);font-family:var(--font-sans)}.reset-button{position:fixed;bottom:20px;right:20px;background:hsla(0,0%,100%,.04);border:1px solid hsla(0,0%,100%,.06);font-size:11px;padding:8px 14px;border-radius:6px;cursor:pointer;z-index:50;transition:all var(--transition);text-transform:uppercase;letter-spacing:1px}.reset-button:hover{color:var(--text-secondary);border-color:hsla(0,0%,100%,.1)}@keyframes fadeIn{0%{opacity:0;filter:blur(3px);transform:translateY(5px)}to{opacity:1;filter:blur(0);transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}@media (max-width:480px){.setup-title{font-size:2.2rem}.setup-container{padding:16px 0}.prompt-text{font-size:1.6rem}.prompt-card{padding:1.25rem;margin-bottom:2rem}.prompt-card-text{font-size:1.1rem}.record-btn-core{width:70px;height:70px}.record-btn-wrapper{width:100px;height:100px}.preview-actions{margin:24px auto 0}.preview-actions,.recording-actions{flex-direction:column;align-items:stretch;width:100%;max-width:280px}.reflection-card{padding:1.25rem}.reflection-text{font-size:1.1rem}.mirror-speaking .reflection-text{max-width:100%;font-size:1.1rem}.peripheral-text{display:none}.btn-ghost{padding:12px 20px;min-height:44px}.control-btn{width:52px;height:52px}.error-toast{left:16px;right:16px;bottom:max(16px,env(safe-area-inset-bottom,16px));transform:none;width:auto}.voice-grid{max-height:240px}.waveform-rings{width:220px;height:220px}}