:root{--bg-color: #1a1a2e;--bg-surface: #16213e;--bg-elevated: #1f2937;--accent-primary: #e94560;--accent-secondary: #0f3460;--success-color: #4ade80;--warning-color: #fbbf24;--text-primary: #ffffff;--text-secondary: #94a3b8;--text-muted: #64748b;--border-radius: 12px;--border-radius-sm: 8px;--transition-fast: .15s ease;--transition-normal: .25s ease;--safe-area-top: env(safe-area-inset-top, 0px);--safe-area-bottom: env(safe-area-inset-bottom, 0px)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:16px;line-height:1.5;background-color:var(--bg-color);color:var(--text-primary);overflow:hidden;touch-action:manipulation;-webkit-tap-highlight-color:transparent;-webkit-font-smoothing:antialiased}#app{height:100%;display:flex;flex-direction:column}.screen{display:none;flex-direction:column;height:100%;padding:1rem;padding-top:calc(1rem + var(--safe-area-top));padding-bottom:calc(1rem + var(--safe-area-bottom))}.screen.active{display:flex}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;min-height:48px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border:none;border-radius:var(--border-radius);cursor:pointer;transition:all var(--transition-fast);-webkit-appearance:none;appearance:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent-primary);color:#fff}.btn-primary:hover:not(:disabled){background:#d63d56}.btn-primary:active:not(:disabled){transform:scale(.98)}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--text-muted)}.btn-secondary:hover:not(:disabled){background:var(--bg-surface)}.btn-icon{font-size:.875rem}.welcome-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;max-width:400px;margin:0 auto}@font-face{font-family:Caprasimo;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/caprasimo.woff2) format("woff2")}.logo{font-family:Caprasimo,system-ui,cursive;font-size:3.75rem;font-weight:400;letter-spacing:.01em;line-height:1;background:linear-gradient(135deg,var(--accent-primary),#ff8a80);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.tagline{font-size:1.25rem;color:var(--text-secondary);margin-bottom:2rem}.welcome-description{color:var(--text-secondary);margin-bottom:2rem}.welcome-description p{margin-bottom:.5rem}.welcome-description .small{font-size:.875rem;color:var(--text-muted)}.mic-notice{margin-top:1rem;font-size:.75rem;color:var(--text-muted)}.exercise-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.exercise-title{display:flex;align-items:center;gap:.75rem}.vowel-badge{display:inline-flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;background:var(--accent-secondary);border-radius:var(--border-radius-sm);font-family:Courier New,monospace;font-size:1.25rem;font-weight:700}.exercise-name{font-size:1.125rem;font-weight:600}.pitch-display{display:flex;flex-direction:column;align-items:flex-end}.pitch-label{font-size:.625rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em}.pitch-value{font-family:SF Mono,Courier New,monospace;font-size:1rem;color:var(--text-secondary)}.viz-container{flex:1;position:relative;min-height:200px;margin-bottom:1rem}#viz-canvas{width:100%;height:100%;border-radius:var(--border-radius);background:var(--bg-surface)}.target-zone{position:absolute;top:25%;left:0;right:0;height:15%;background:#4ade801a;border-top:2px dashed rgba(74,222,128,.3);border-bottom:2px dashed rgba(74,222,128,.3);display:flex;align-items:center;justify-content:flex-end;padding-right:1rem;pointer-events:none}.target-label{font-size:.625rem;color:var(--success-color);text-transform:uppercase;letter-spacing:.1em;opacity:.7}.exercise-status{margin-bottom:1rem}.status-message{text-align:center;color:var(--text-secondary);font-size:.875rem;margin-bottom:.5rem;min-height:1.5rem}.progress-bar{height:4px;background:var(--bg-elevated);border-radius:2px;overflow:hidden}.progress-fill{height:100%;width:0%;background:var(--success-color);transition:width var(--transition-fast)}.exercise-controls{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.success-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.success-icon{width:80px;height:80px;background:var(--success-color);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2.5rem;color:#fff;margin-bottom:1.5rem}.success-content h2{font-size:1.5rem;margin-bottom:.5rem}.success-content p{color:var(--text-secondary);margin-bottom:2rem}.error-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem}.error-content h2{font-size:1.25rem;margin-bottom:1rem}.error-content p{color:var(--text-secondary);margin-bottom:2rem}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.status-message.recording{animation:pulse 1.5s ease infinite;color:var(--accent-primary)}@media (min-height: 700px){.viz-container{min-height:300px}}@media (min-width: 600px){.exercise-controls{max-width:400px;margin:0 auto}}.calibration-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;max-width:400px;margin:0 auto;padding:1rem}.calibration-content h2{font-size:1.5rem;margin-bottom:.5rem}.calibration-instruction{color:var(--text-secondary);margin-bottom:2rem;line-height:1.6}.calibration-viz{margin-bottom:2rem}.calibration-circle{width:150px;height:150px;border-radius:50%;background:var(--bg-surface);border:3px solid var(--text-muted);display:flex;align-items:center;justify-content:center;transition:all var(--transition-normal)}.calibration-circle.recording{border-color:var(--accent-primary);box-shadow:0 0 30px #e945604d}.calibration-circle.success{border-color:var(--success-color);box-shadow:0 0 30px #4ade804d}.calibration-pitch{font-family:SF Mono,Courier New,monospace;font-size:1.5rem;color:var(--text-primary)}.calibration-status{color:var(--text-secondary);font-size:.875rem;margin-bottom:1rem;min-height:1.5rem}.calibration-progress{width:100%;height:4px;background:var(--bg-elevated);border-radius:2px;overflow:hidden;margin-bottom:2rem}.viz-container-2d .target-zone{display:none}.staged-results{margin-top:1rem;display:flex;flex-direction:column;gap:.35rem}.staged-rep-row{font-family:SF Mono,Courier New,monospace;font-size:.8rem;color:#ffffffd9;background:#ffffff0d;padding:.4rem .6rem;border-radius:6px}.learn-content{max-width:540px;margin:0 auto;padding:1.5rem 1.25rem 2rem;text-align:left;overflow-y:auto;max-height:100vh}.learn-content h2{text-align:center;margin-bottom:1.25rem}.learn-card{background:#ffffff0d;border-radius:10px;padding:.85rem 1rem;margin-bottom:.85rem}.learn-card h3{margin:0 0 .35rem;font-size:.95rem;color:#4ade80}.learn-card p{margin:0;font-size:.9rem;line-height:1.45;color:#ffffffd9}.safety-note{font-size:.85rem;line-height:1.4;color:#ffdc82e6;background:#ffc86414;border-radius:8px;padding:.7rem .9rem;margin:1rem 0 1.25rem}.stack-actions{display:flex;flex-direction:column;align-items:center;gap:.6rem;margin-top:1.25rem}.stack-actions .btn{width:100%;max-width:420px}.welcome-progress{margin-top:1rem;font-size:.85rem;color:#4ade80}#screen-exercise.active{padding:0;position:relative;overflow:hidden}.trace-canvas{position:absolute;inset:0;width:100%;height:100%;display:block}.trace-status-overlay{position:absolute;top:calc(8px + var(--safe-area-top));left:50%;transform:translate(-50%);z-index:2;pointer-events:none;text-align:center;max-width:90%;font-size:.8rem;color:#ffffffb3}.btn-float{position:absolute;bottom:calc(16px + var(--safe-area-bottom));left:50%;transform:translate(-50%);z-index:3;width:auto;min-width:200px;box-shadow:0 4px 16px #00000073}.btn.hidden,.rotate-hint{display:none}.rotate-icon{font-size:3rem;margin-bottom:.5rem}@media (orientation: portrait) and (max-width: 920px){#screen-exercise.active .trace-canvas,#screen-exercise.active .trace-status-overlay,#screen-exercise.active .btn-float{display:none}#screen-exercise.active .rotate-hint{display:flex;position:absolute;inset:0;align-items:center;justify-content:center;text-align:center;color:#ffffffd9}}#screen-debug.active{padding:.5rem}.debug-stage{flex:1;min-height:0}#debug-canvas{width:100%;height:100%;display:block}.debug-note{font-size:.75rem;color:#ffffff80;text-align:center;padding:.3rem}.summary-content{max-width:540px;margin:0 auto;padding:1.5rem 1.25rem 2rem;overflow-y:auto;width:100%}.summary-content h2{text-align:center;margin-bottom:1rem}.summary-body p{font-size:.95rem;line-height:1.5;margin:.4rem 0;color:#ffffffe6}.summary-next-card{background:#4ade801a;border:1px solid rgba(74,222,128,.3);border-radius:10px;padding:.85rem 1rem;margin:1.1rem 0}.summary-next-card h3{margin:0 0 .35rem;font-size:.9rem;color:#4ade80}.summary-next-card p{margin:0;font-size:.9rem;line-height:1.45}.summary-content .btn{width:100%;margin-top:.6rem}.home-content{max-width:540px;margin:0 auto;padding:1.5rem 1.25rem 2rem;width:100%;overflow-y:auto;text-align:center}.home-progress{display:flex;justify-content:center;gap:1.25rem;margin:1rem 0 1.25rem}.home-stat{display:flex;flex-direction:column;font-size:.75rem;color:#fff9;text-transform:uppercase;letter-spacing:.03em}.home-stat-num{font-size:1.5rem;color:#4ade80;margin-bottom:.1rem}.home-content .btn{width:100%;max-width:420px}.home-h{text-align:left;margin:1.5rem 0 .5rem;font-size:.85rem;color:#fff9}.home-sessions{display:flex;flex-direction:column;gap:.4rem}.home-session{display:flex;justify-content:space-between;align-items:baseline;background:#ffffff0d;border-radius:8px;padding:.55rem .75rem;font-size:.82rem;text-align:left}.hs-when{color:#ffffff8c}.hs-stat{color:#ffffffe6;font-family:SF Mono,monospace;font-size:.78rem}.home-empty{color:#ffffff80}.privacy-note{font-size:.8rem;line-height:1.4;color:#96c8ffd9;background:#5aa9ff14;border-radius:8px;padding:.6rem .85rem;margin:0 0 1.1rem}.home-roadmap{display:flex;flex-direction:column;gap:.4rem;text-align:left}.lvl{display:flex;align-items:center;gap:.7rem;background:#ffffff0d;border-radius:8px;padding:.55rem .75rem}.lvl-badge{flex-shrink:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:.8rem;font-weight:700}.lvl-current{border:1px solid rgba(74,222,128,.4)}.lvl-current .lvl-badge{background:#4ade80;color:#0c1322}.lvl-locked{opacity:.5}.lvl-locked .lvl-badge{background:#ffffff1a}.lvl-text{font-size:.82rem;line-height:1.3;color:#ffffffd9}.logo-lockup{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:.45rem}.logo-mark{width:80px;height:48px;filter:drop-shadow(0 1px 6px rgba(233,69,96,.4))}.logo-mark-sm{width:52px;height:31px}.mode-toggle{display:inline-flex;gap:0;background:#ffffff0f;border-radius:999px;padding:4px;margin:0 auto 1.25rem}.mode-opt{border:none;background:transparent;color:#ffffffa6;font:inherit;font-size:.85rem;padding:.45rem 1.1rem;border-radius:999px;cursor:pointer;display:inline-flex;flex-direction:column;align-items:center;line-height:1.1}.mode-active{background:linear-gradient(135deg,var(--accent-primary),#ff8a80);color:#fff;font-weight:600}.mode-soon{color:#ffffff59;cursor:not-allowed}.mode-soon-tag{font-size:.6rem;text-transform:uppercase;letter-spacing:.04em;opacity:.8;margin-top:1px}
