:root{--bg-0: #f7f4ef;--bg-1: #fff8ee;--surface: #ffffff;--surface-2: #fbf7f0;--line: #e6ddcf;--violet: #3bbfbf;--violet-2: #2a9999;--coral: #ef6c57;--sunshine: #ffd166;--forest: #1b3a2d;--text: #1b3a2d;--muted: #6b7d72;--radius: 18px;--shadow: 0 8px 24px rgba(27, 58, 45, .12);--font: "Nunito", ui-rounded, "SF Pro Rounded", "Segoe UI", system-ui, sans-serif}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--font);color:var(--text);background:linear-gradient(180deg,#fff8ee,#f7f4ef);-webkit-font-smoothing:antialiased;overflow:hidden}.app{display:flex;flex-direction:column;height:100%}.card-tactile{background:#fff;border-radius:20px;box-shadow:0 8px 24px #1b3a2d1f;transition:transform .12s ease}.card-tactile:active{transform:scale(.97)}.btn-pressable{font-family:inherit;font-weight:800;border-radius:14px;border:none;cursor:pointer;transition:transform .08s ease,box-shadow .08s ease,filter .12s ease}.btn-pressable:active{transform:translateY(2px);box-shadow:inset 0 2px 6px #1b3a2d33}.btn-teal{background:var(--violet);color:#fff;box-shadow:0 4px 0 var(--violet-2)}.btn-coral{background:var(--coral);color:#fff;box-shadow:0 4px #c5503f}.btn-teal:active,.btn-coral:active{box-shadow:inset 0 2px 6px #1b3a2d40}.tile-wood{background:linear-gradient(180deg,#fff8ee,#f0dcc0);box-shadow:inset 0 2px #fffc,0 6px #c4a574,0 10px 20px #1b3a2d26}.app-header{display:flex;align-items:center;gap:24px;padding:12px 22px;background:#ffffffd9;border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--text)}.brand-mark{font-size:38px;filter:drop-shadow(0 2px 6px rgba(59,191,191,.6))}.brand h1{margin:0;font-size:22px;letter-spacing:.2px}.brand p{margin:0;font-size:12px;color:var(--muted)}.level-box{margin-left:auto;display:flex;align-items:center;gap:10px;min-width:200px}.level-badge{background:linear-gradient(135deg,var(--violet),var(--violet-2));color:#fff;font-weight:700;font-size:13px;padding:6px 12px;border-radius:999px;white-space:nowrap}.xp-bar{flex:1;height:12px;background:var(--surface-2);border-radius:999px;overflow:hidden;border:1px solid var(--line)}.xp-fill{height:100%;background:linear-gradient(90deg,#5FD0D0,var(--violet));transition:width .5s ease}.tabs{display:flex;gap:8px}.tab{font-family:inherit;font-size:14px;font-weight:600;color:var(--muted);background:var(--surface-2);border:1px solid var(--line);border-radius:999px;padding:9px 16px;cursor:pointer;transition:all .15s ease}.tab:hover{color:var(--text)}.tab--active{color:#fff;background:linear-gradient(135deg,var(--violet),var(--violet-2));border-color:transparent}.app-main{flex:1;min-height:0;overflow:auto;padding:18px 22px}.coach{height:100%;display:grid;grid-template-columns:250px minmax(0,1fr) 290px;grid-template-rows:1fr auto;grid-template-areas:"left center right" "footer footer footer";gap:18px}.coach-left{grid-area:left;display:flex;flex-direction:column;align-items:center;gap:12px}.coach-center{grid-area:center;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;position:relative}.coach-right{grid-area:right;display:flex;flex-direction:column;align-items:center;gap:14px}.coach-footer{grid-area:footer}.coach--start{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;text-align:center}.start-btn{font-family:inherit;font-size:24px;font-weight:800;color:#fff;background:linear-gradient(135deg,var(--violet),var(--violet-2));border:none;border-radius:999px;padding:18px 44px;cursor:pointer;box-shadow:var(--shadow);transition:transform .1s ease}.start-btn:hover{transform:translateY(-2px)}.start-btn:disabled{opacity:.6;cursor:default}.start-hint{color:var(--muted);max-width:360px;font-size:14px}.prompt{text-align:center}.prompt-word{font-size:30px;font-weight:800;color:var(--text);letter-spacing:.5px}.word-target{color:#7fd8d8;text-decoration:underline;text-decoration-color:#3bbfbf;text-underline-offset:4px}.prompt-sub{font-size:15px;color:var(--muted);margin-top:2px}.prompt-sub strong{color:#2a9999}.talk-btn{font-family:inherit;font-size:22px;font-weight:800;color:#fff;background:linear-gradient(135deg,#ef6c57,#3bbfbf);border:none;border-radius:999px;padding:18px 40px;cursor:pointer;box-shadow:var(--shadow);touch-action:none;-webkit-user-select:none;user-select:none;transition:transform .08s ease}.talk-btn:active,.talk-btn--active{transform:scale(.97);background:linear-gradient(135deg,#fb7185,#5fd0d0);box-shadow:0 0 0 8px #3bbfbf40,var(--shadow);animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 0 0 6px #3bbfbf40,var(--shadow)}50%{box-shadow:0 0 0 14px #3bbfbf14,var(--shadow)}}.mic-orb{position:relative;width:168px;height:168px;border-radius:50%;border:none;cursor:pointer;background:radial-gradient(circle at 50% 40%,#5fd0d0,#2a9999 70%);color:#fff;font-family:inherit;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;box-shadow:var(--shadow);-webkit-user-select:none;user-select:none;transition:transform .1s ease}.mic-orb:active{transform:scale(.97)}.mic-orb-ring{position:absolute;top:-6px;right:-6px;bottom:-6px;left:-6px;border-radius:50%;border:4px solid rgba(59,191,191,.55);transform:scale(calc(1 + var(--vol, 0) * .55));opacity:calc(.25 + var(--vol, 0) * .75);transition:transform .06s linear,opacity .06s linear;pointer-events:none}.mic-orb--listening{background:radial-gradient(circle at 50% 40%,#7fd8d8,#3bbfbf 70%);animation:pulse 1.4s ease-in-out infinite}.mic-orb-face{font-size:52px;line-height:1}.mic-orb-label{font-size:15px;font-weight:700}.interim{font-size:15px;color:#2a9999;font-style:italic}.speech-error{font-size:13px;color:#fca5a5;max-width:280px;text-align:center}.heard-chip{background:var(--surface-2);border:2px solid var(--violet);border-radius:14px;padding:10px 16px;font-size:16px;font-weight:600;text-align:center}.coach-tip{color:var(--muted);font-size:14px;text-align:center;max-width:200px}.fallback-banner{background:var(--surface-2);border:1px solid var(--line);color:#fcd34d;font-size:13px;padding:10px 16px;border-radius:12px;margin-bottom:14px;text-align:center}.word-picker{display:flex;gap:10px;overflow-x:auto;padding:4px 2px 8px;justify-content:center}.word-card{flex:0 0 auto;font-family:inherit;width:96px;background:var(--surface);border:2px solid var(--line);border-radius:16px;padding:10px 8px;cursor:pointer;position:relative;display:flex;flex-direction:column;align-items:center;gap:2px;transition:all .15s ease}.word-card:hover{border-color:var(--violet-2)}.word-card--active{border-color:var(--violet);background:var(--surface-2);box-shadow:0 0 0 4px #3bbfbf2e}.xp-float{position:absolute;bottom:28%;font-size:22px;font-weight:800;color:#ffd166;text-shadow:0 2px 8px rgba(0,0,0,.5);animation:rise 1.1s ease-out forwards;pointer-events:none}@keyframes rise{0%{opacity:0;transform:translateY(10px) scale(.8)}20%{opacity:1}to{opacity:0;transform:translateY(-50px) scale(1.1)}}.mouth-diagram{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}.mouth-face{fill:#fff3e6;stroke:var(--line);stroke-width:1.5}.mouth-palate,.mouth-pharynx{fill:none;stroke:#c4a574;stroke-width:3;stroke-linecap:round}.mouth-teeth{fill:#fff;opacity:.9}.tongue-goal{fill:none;stroke:#2a9999;stroke-width:2.5;stroke-dasharray:6 5;opacity:.7}.lip-goal{fill:none;stroke:#2a9999;stroke-width:2.5;stroke-dasharray:5 4;opacity:.6}.tongue-live{opacity:.92;transition:fill .2s ease}.lip-live{opacity:.95}.mouth-label{fill:#2a9999;font-size:18px;font-weight:800;text-anchor:middle}.score-meter svg{width:150px;height:150px}.meter-track{fill:none;stroke:var(--surface-2);stroke-width:12}.meter-fill{fill:none;stroke-width:12;stroke-linecap:round;transition:stroke-dasharray .15s ease,stroke .2s ease}.meter-best{fill:none;stroke:#ffd166;stroke-width:12;stroke-linecap:round}.meter-text{font-size:34px;font-weight:800;text-anchor:middle}.meter-unit{fill:var(--muted);font-size:11px;text-anchor:middle}.vowel-space{width:100%;max-width:260px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:4px}.vs-frame{fill:#3bbfbf0a;stroke:var(--line);stroke-width:1.5}.vs-grid{stroke:var(--line);stroke-width:1;stroke-dasharray:3 4}.vs-axis{fill:var(--muted);font-size:10px}.vs-target{fill:var(--surface-2);stroke:#9bb0a5;stroke-width:1.5}.vs-target--active{fill:#d8b4fe40;stroke:#2a9999;stroke-width:2.5}.vs-target-label{fill:var(--text);font-size:9px;font-weight:700}.vs-live{stroke:#fff;stroke-width:2;animation:blip .9s ease-in-out infinite}@keyframes blip{0%,to{r:9}50%{r:11}}.brightness{width:100%;max-width:260px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:14px}.brightness-label{font-size:12px;color:var(--muted);margin-bottom:10px}.brightness-track{position:relative;height:16px;background:linear-gradient(90deg,#e6ddcf,#2a9999,#7fd8d8);border-radius:999px}.brightness-goal{position:absolute;top:-5px;width:4px;height:26px;background:#ffd166;border-radius:2px;transform:translate(-50%)}.brightness-live{position:absolute;top:50%;width:16px;height:16px;border-radius:50%;border:2px solid white;transform:translate(-50%,-50%);transition:left .1s linear}.brightness-ends{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);margin-top:8px}.hint-chip{background:var(--surface-2);border:2px solid var(--violet);border-radius:14px;padding:10px 14px;font-size:15px;font-weight:600;text-align:center;max-width:260px}.dragon{display:flex;flex-direction:column;align-items:center;width:100%}.speech-bubble{background:#fff;color:#1b3a2d;font-weight:600;font-size:14px;border-radius:16px;padding:12px 16px;margin-bottom:8px;position:relative;box-shadow:var(--shadow);text-align:center;min-height:20px}.speech-bubble:after{content:"";position:absolute;bottom:-9px;left:50%;transform:translate(-50%);border:10px solid transparent;border-top-color:#fff;border-bottom:0}.dragon-svg{width:170px;height:170px}.dragon-body{fill:#2a9999}.dragon-belly{fill:#7fd8d8}.dragon-snout{fill:#2a9999}.dragon-wing{fill:#1b3a2d}.dragon-horn,.dragon-eye{fill:#fff}.dragon-pupil{fill:#1b3a2d;transition:cx .2s ease,cy .2s ease}.dragon-nostril{fill:#1b3a2d}.dragon-mouth{fill:#1b3a2d;transition:height .08s linear}.dragon-name{margin-top:2px;font-weight:800;color:#2a9999;letter-spacing:1px}.dragon-sparkles text{font-size:20px;animation:twinkle .8s ease-in-out infinite alternate}@keyframes twinkle{0%{opacity:.3}to{opacity:1}}.dragon--happy .dragon-svg{animation:bounce .5s ease}@keyframes bounce{0%,to{transform:translateY(0)}30%{transform:translateY(-14px) scale(1.04)}}.dragon--sad .dragon-svg{animation:wobble .6s ease}@keyframes wobble{0%,to{transform:rotate(0)}25%{transform:rotate(-5deg)}75%{transform:rotate(5deg)}}.demo-badge{background:var(--surface-2);border:1px solid var(--line);color:var(--muted);font-size:12px;padding:5px 12px;border-radius:999px}.sound-picker{display:flex;gap:10px;overflow-x:auto;padding:4px 2px 8px}.sound-card{flex:0 0 auto;font-family:inherit;width:92px;background:var(--surface);border:2px solid var(--line);border-radius:16px;padding:10px 8px;cursor:pointer;position:relative;display:flex;flex-direction:column;align-items:center;gap:2px;transition:all .15s ease}.sound-card:hover{border-color:var(--violet-2)}.sound-card--active{border-color:var(--violet);background:var(--surface-2);box-shadow:0 0 0 4px #3bbfbf2e}.sound-emoji{font-size:28px}.sound-label{font-weight:800;color:var(--text)}.sound-word{font-size:11px;color:var(--muted)}.sound-mastery{position:absolute;top:8px;right:8px;width:12px;height:12px;border-radius:50%;border:2px solid var(--surface)}.dashboard{max-width:900px;margin:0 auto;display:flex;flex-direction:column;gap:16px}.dash-title{margin:0;font-size:22px}.outcome-card{background:linear-gradient(135deg,var(--surface-2),var(--surface));border:1px solid var(--line);border-radius:var(--radius);padding:20px;text-align:center;box-shadow:var(--shadow)}.outcome-big{font-size:54px;font-weight:900;line-height:1}.outcome-sub{color:var(--muted);font-size:14px;margin-top:6px}.stat-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.stat{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:14px;text-align:center}.stat-value{font-size:26px;font-weight:800;color:#2a9999}.stat-label{font-size:12px;color:var(--muted)}.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px}.panel h3{margin:0 0 12px;font-size:16px}.chart-wrap{width:100%}.panel-note{font-size:12px;color:var(--muted);margin:10px 2px 0}.ba-list{display:flex;flex-direction:column;gap:8px}.ba-row{display:grid;grid-template-columns:1fr 56px 24px 56px 70px;align-items:center;gap:8px;background:var(--surface-2);border-radius:10px;padding:8px 12px}.ba-sound{font-weight:700}.ba-before{color:var(--muted)}.ba-arrow{color:var(--muted);text-align:center}.ba-after{font-weight:800}.ba-delta{font-weight:700;text-align:right}.ba-delta.up{color:#4ade80}.ba-delta.down{color:#f87171}.focus-list{display:flex;flex-wrap:wrap;gap:10px}.focus-chip{display:flex;align-items:center;gap:8px;background:var(--surface-2);border:1px solid var(--line);border-radius:999px;padding:8px 14px;font-size:14px}.focus-dot{width:10px;height:10px;border-radius:50%}.dash-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.export-btn{font-family:inherit;font-size:13px;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--violet),var(--violet-2));border:none;border-radius:999px;padding:9px 20px;cursor:pointer}.export-btn:hover{filter:brightness(1.1)}.reset-btn{font-family:inherit;font-size:13px;color:var(--muted);background:transparent;border:1px solid var(--line);border-radius:999px;padding:8px 18px;cursor:pointer}.reset-btn:hover{color:var(--text);border-color:var(--violet-2)}.wave-canvas{width:100%;max-width:340px;height:92px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius)}.graph-slot{width:100%;max-width:340px;display:flex;justify-content:center}.howto-card{width:100%;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:10px 12px 12px;display:flex;flex-direction:column;align-items:center;gap:6px}.howto-head{font-weight:800;color:#7fd8d8;font-size:15px}.howto-cue{font-size:14px;font-weight:600;color:var(--text);text-align:center}.artic-face{width:200px;height:142px}.artic-skin{fill:#ffe3c9}.artic-lip{fill:#e2728f}.artic-lip-rim{fill:none;stroke:#f4a6bb;stroke-width:3}.artic-mouth{fill:#5d2e2e}.artic-teeth{fill:#fdf2f8}.howto-toggle{font-family:inherit;font-size:13px;font-weight:700;color:var(--text);background:var(--surface-2);border:1px solid var(--line);border-radius:999px;padding:7px 16px;cursor:pointer}.howto-toggle:hover{border-color:var(--violet-2)}.phoneme-matrix{display:flex;gap:8px}.phoneme-cell{min-width:46px;padding:8px 12px;border-radius:12px;font-weight:800;font-size:18px;text-align:center;background:var(--surface-2);border:2px solid var(--line);color:var(--text);transition:all .2s ease}.phoneme-cell--success{background:#4ade802e;border-color:#4ade80;color:#bbf7d0;animation:cell-bounce .5s ease}.phoneme-cell--error{background:#fb71852e;border-color:#fb7185;color:#fecdd3;animation:cell-wobble .5s ease}@keyframes cell-bounce{0%,to{transform:translateY(0)}35%{transform:translateY(-10px) scale(1.08)}}@keyframes cell-wobble{0%,to{transform:rotate(0)}20%{transform:rotate(-7deg)}60%{transform:rotate(7deg)}}.coach-right{overflow-y:auto}.replay-panel-head{display:flex;align-items:center;justify-content:space-between;width:100%;font-weight:700;color:var(--text)}.cam-toggle{font-family:inherit;font-size:12px;color:var(--muted);background:var(--surface-2);border:1px solid var(--line);border-radius:999px;padding:5px 10px;cursor:pointer}.cam-toggle--on{color:#fff;background:linear-gradient(135deg,var(--violet),var(--violet-2));border-color:transparent}.replay-card{width:100%;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:12px;display:flex;flex-direction:column;gap:8px}.replay-head{display:flex;justify-content:space-between;font-weight:700;font-size:14px}.replay-score{font-weight:800}.replay-video{width:100%;border-radius:10px;background:#000;max-height:150px}.replay-wave{width:100%;height:28px}.replay-heard{font-size:13px;color:var(--muted);text-align:center}.replay-controls{display:flex;align-items:center;justify-content:space-between;gap:8px}.replay-play{font-family:inherit;font-size:13px;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--violet),var(--violet-2));border:none;border-radius:999px;padding:7px 14px;cursor:pointer}.replay-speeds{display:flex;gap:4px}.replay-speed{font-family:inherit;font-size:12px;color:var(--muted);background:var(--surface-2);border:1px solid var(--line);border-radius:8px;padding:5px 8px;cursor:pointer}.replay-speed--active{color:#fff;background:var(--violet-2);border-color:transparent}.privacy-note{font-size:11px;color:var(--muted);text-align:center}.slp-card{border-left:3px solid var(--violet)}.slp-table{width:100%;border-collapse:collapse;font-size:14px}.slp-table th{text-align:left;color:var(--muted);font-size:12px;font-weight:600;padding:4px 8px;border-bottom:1px solid var(--line)}.slp-table td{padding:7px 8px;border-bottom:1px solid var(--surface-2)}.slp-ipa{color:var(--muted);font-size:12px}.slp-acc{font-weight:800}.word-card--add{border-style:dashed;color:var(--muted);justify-content:center}.word-card--add:hover{color:var(--text);border-color:var(--violet)}.word-card--custom{border-color:#9bb0a5}.add-word-form{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:center;margin-bottom:12px}.add-word-input{font-family:inherit;font-size:15px;color:var(--text);background:var(--surface);border:2px solid var(--violet);border-radius:999px;padding:9px 16px;width:240px;outline:none}.add-word-input::placeholder{color:var(--muted)}.add-word-go{font-family:inherit;font-size:14px;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--violet),var(--violet-2));border:none;border-radius:999px;padding:9px 16px;cursor:pointer}.add-word-cancel{font-family:inherit;font-size:14px;color:var(--muted);background:var(--surface-2);border:1px solid var(--line);border-radius:50%;width:34px;height:34px;cursor:pointer}.add-word-error{color:#fca5a5;font-size:13px;width:100%;text-align:center}@media (max-width: 880px){body{overflow:auto}.coach{height:auto;grid-template-columns:minmax(0,1fr);grid-template-rows:repeat(4,auto);grid-template-areas:"left" "center" "right" "footer"}.stat-strip{grid-template-columns:repeat(2,1fr)}}.app-main--immersive{padding:0}.blaze{display:inline-flex;animation:blaze-pop .3s ease}.blaze-svg{width:100%;height:100%;display:block}.blaze--sm{width:80px;height:80px}.blaze--md{width:112px;height:112px}.blaze--lg{width:160px;height:160px}.blaze--xl{width:208px;height:208px}.blaze--idle .blaze-svg{animation:blaze-bob 2.6s ease-in-out infinite}.blaze--demonstrating .blaze-svg{animation:blaze-bob 1.6s ease-in-out infinite}.blaze--waving .blaze-svg{animation:blaze-bob 2s ease-in-out infinite}.blaze--listening .blaze-svg{animation:blaze-pulse 1.2s ease-in-out infinite}.blaze--celebrating .blaze-svg{animation:blaze-celebrate .8s ease-in-out infinite}.blaze--confused .blaze-svg{animation:blaze-confused .6s ease-in-out}.blaze-wing{transform-box:fill-box;transform-origin:0% 50%}.blaze-wing--wave{animation:blaze-wing-wave 1.2s ease-in-out infinite}.blaze-sparkles{animation:blaze-sparkle .8s ease-in-out infinite}@keyframes blaze-pop{0%{opacity:.6;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes blaze-bob{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}@keyframes blaze-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.04) translateY(-2px)}}@keyframes blaze-celebrate{0%{transform:translateY(0) rotate(0)}25%{transform:translateY(-12px) rotate(-3deg)}50%{transform:translateY(0) rotate(3deg)}75%{transform:translateY(-8px) rotate(-2deg)}to{transform:translateY(0) rotate(0)}}@keyframes blaze-confused{0%,to{transform:rotate(0)}20%{transform:rotate(-8deg)}40%{transform:rotate(8deg)}60%{transform:rotate(-4deg)}80%{transform:rotate(4deg)}}@keyframes blaze-wing-wave{0%,to{transform:rotate(0)}25%{transform:rotate(18deg)}60%{transform:rotate(-6deg)}}@keyframes blaze-sparkle{0%,to{opacity:.5}50%{opacity:1}}.confetti-canvas{position:fixed;top:0;right:0;bottom:0;left:0;width:100vw;height:100vh;pointer-events:none;z-index:60}.star-rating{display:flex;align-items:center;justify-content:center;gap:10px}.star{font-size:40px;transform:scale(0);animation:star-pop .4s cubic-bezier(.34,1.56,.64,1) forwards}.star--filled{filter:drop-shadow(0 3px 6px rgba(255,209,102,.6))}@keyframes star-pop{0%{transform:scale(0) rotate(-30deg)}to{transform:scale(1) rotate(0)}}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:6px}.field-label{font-size:13px;font-weight:700;color:var(--muted)}.field-input{font-family:inherit;font-size:17px;font-weight:700;color:var(--text);background:#fff;border:2px solid var(--line);border-radius:14px;padding:13px 15px;transition:border-color .15s ease}.field-input:focus{outline:none;border-color:var(--violet)}.field-input--pin{letter-spacing:12px;text-align:center;max-width:180px}.chip-row{display:flex;gap:8px}.chip-row--wrap{flex-wrap:wrap}.chip{font-family:inherit;font-size:15px;font-weight:800;color:var(--text);background:var(--surface-2);border:2px solid var(--line);border-radius:12px;padding:10px 16px;cursor:pointer;transition:all .12s ease}.chip--active{color:#fff;background:var(--violet);border-color:var(--violet)}.toggle-row{display:flex;align-items:center;gap:10px;font-weight:700;color:var(--text);cursor:pointer}.toggle-row input{width:20px;height:20px;accent-color:var(--violet)}.btn-ghost{font-family:inherit;font-weight:800;color:var(--text);background:#fff;border:2px solid var(--line);border-radius:14px;padding:14px 20px;cursor:pointer}.onb{max-width:460px;margin:0 auto;min-height:100%;display:flex;flex-direction:column;padding:24px 20px 28px}.onb-dots{display:flex;justify-content:center;gap:8px;margin-bottom:22px}.onb-dot{width:8px;height:8px;border-radius:999px;background:#1b3a2d2e;transition:all .2s ease}.onb-dot--active{width:30px;background:var(--violet)}.onb-dot--done{background:#3bbfbf8c}.onb-body{flex:1;display:flex;flex-direction:column;animation:onb-slide .25s ease}@keyframes onb-slide{0%{opacity:0;transform:translate(14px)}to{opacity:1;transform:translate(0)}}.onb-center{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:14px}.onb-h1{margin:6px 0 0;font-size:28px;color:var(--text)}.onb-h2{margin:0;font-size:22px;color:var(--text)}.onb-lead{margin:0;font-size:16px;line-height:1.5;color:var(--muted);max-width:380px}.onb-form{display:flex;flex-direction:column;gap:16px}.onb-head{display:flex;align-items:center;gap:14px}.onb-sub{margin:2px 0 0;font-size:14px;color:var(--muted);font-weight:600}.onb-note{margin:0;font-size:14px;line-height:1.5;color:var(--muted)}.onb-ready{padding:16px 18px}.onb-ready-title{margin:0 0 4px;font-weight:800;color:var(--text)}.onb-ready-sub{margin:0;font-size:14px;line-height:1.5;color:var(--muted)}.onb-actions{display:flex;gap:12px;margin-top:22px}.onb-next{flex:1;padding:16px;font-size:17px}.onb-next:disabled{opacity:.45;cursor:default;box-shadow:none}.onb-actions .btn-ghost{flex:0 0 auto}.onb-skip{margin:14px auto 0;background:none;border:none;color:var(--muted);font-family:inherit;font-size:14px;font-weight:700;cursor:pointer;text-decoration:underline}.home{max-width:920px;margin:0 auto;display:flex;flex-direction:column;gap:18px}.home-hero{display:flex;align-items:center;gap:20px;padding:20px 24px}.home-greeting{margin:0;font-size:28px;color:var(--text)}.home-tagline{margin:6px 0 0;font-size:16px;color:var(--muted)}.home-banner{display:flex;align-items:center;gap:16px;text-decoration:none;color:var(--text);background:linear-gradient(135deg,#fff3da,#ffe7c2);border:2px solid var(--sunshine);border-radius:18px;padding:16px 20px;font-size:15px;line-height:1.45}.home-banner-emoji{font-size:34px}.home-banner-go{margin-left:auto;font-size:26px;font-weight:900;color:var(--coral)}.home-doors{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.door{display:flex;flex-direction:column;align-items:flex-start;gap:4px;text-align:left;text-decoration:none;color:var(--text);border:none;border-radius:18px;padding:20px;cursor:pointer;min-height:132px;box-shadow:0 6px #1b3a2d1f,0 12px 24px #1b3a2d1a}.door--teal{background:linear-gradient(160deg,#e4faf8,#c3f1ee)}.door--coral{background:linear-gradient(160deg,#ffe6e0,#ffd2c8)}.door--cream{background:linear-gradient(160deg,#fff8ee,#f3e7d2)}.door-emoji{font-size:36px}.door-title{font-size:18px;font-weight:900;margin-top:auto}.door-sub{font-size:13px;color:var(--muted);font-weight:600}.home-rail-title{margin:4px 0 12px;font-size:18px;color:var(--text)}.home-rail-track{display:flex;gap:12px;overflow-x:auto;padding:4px 2px 14px}.rail-word{position:relative;flex:0 0 auto;width:104px;display:flex;flex-direction:column;align-items:center;gap:2px;border:none;border-radius:16px;padding:14px 8px;cursor:pointer;color:var(--text)}.rail-word-emoji{font-size:32px}.rail-word-label{font-weight:900;font-size:16px}.rail-word-sound{font-size:12px;color:var(--muted);font-weight:700}.rail-word--priority{outline:3px solid var(--coral);outline-offset:-1px}.rail-word-flag{position:absolute;top:-8px;right:-6px;background:var(--coral);color:#fff;font-size:10px;font-weight:800;padding:2px 7px;border-radius:999px}.intro{position:relative;max-width:480px;margin:0 auto;min-height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:16px;padding:32px 22px}.intro-glow{position:absolute;top:34%;left:50%;transform:translate(-50%,-50%);width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(255,209,102,.38),transparent 68%);z-index:0;pointer-events:none;animation:glow-pulse 3s ease-in-out infinite}@keyframes glow-pulse{0%,to{opacity:.6}50%{opacity:1}}.intro>*{position:relative;z-index:1}.intro-title{margin:6px 0 0;font-size:28px;color:var(--text)}.intro-lead{margin:0;font-size:16px;line-height:1.55;color:var(--muted);max-width:400px}.intro-steps{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}.intro-step{display:flex;align-items:center;gap:7px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:8px 14px;font-size:13px;font-weight:700;color:var(--text)}.intro-step-emoji{font-size:18px}.intro-start{padding:16px 30px;font-size:18px;margin-top:6px}.intro-fine{margin:0;font-size:13px;color:var(--muted);font-weight:600}.intro-warn{padding:18px 20px;max-width:400px;display:flex;flex-direction:column;gap:12px;font-size:14px;line-height:1.5;color:var(--text)}.intro-warn .btn-teal{padding:12px;text-decoration:none;text-align:center}.intro-skip{background:none;border:none;color:var(--muted);font-family:inherit;font-size:14px;font-weight:700;cursor:pointer;text-decoration:underline}.diag{max-width:480px;margin:0 auto;min-height:100%;display:flex;flex-direction:column;align-items:center;gap:14px;padding:16px 20px 24px}.diag-top{width:100%;display:flex;align-items:center;gap:12px}.diag-quit{width:38px;height:38px;border-radius:50%;border:none;background:#fff;box-shadow:var(--shadow);font-size:16px;cursor:pointer;color:var(--muted)}.diag-progress{margin:0 auto;font-size:14px;font-weight:800;color:var(--muted)}.diag-finish{background:none;border:2px solid var(--violet);color:var(--violet);border-radius:999px;padding:7px 14px;font-family:inherit;font-weight:800;font-size:13px;cursor:pointer}.diag-blaze{display:flex;flex-direction:column;align-items:center;gap:10px}.energy{width:240px}.energy-label{font-size:13px;font-weight:800;color:var(--text);text-align:center;margin-bottom:5px}.energy-track{height:16px;background:var(--surface-2);border:1px solid var(--line);border-radius:999px;overflow:hidden}.energy-fill{height:100%;background:linear-gradient(90deg,var(--sunshine),var(--coral));border-radius:999px;transition:width .5s cubic-bezier(.34,1.4,.64,1)}.diag-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:22px 40px}.diag-emoji{font-size:72px;line-height:1}.diag-word{font-size:40px;font-weight:900;letter-spacing:2px;color:var(--text);text-transform:lowercase}.diag-wave{height:92px;display:flex;align-items:center}.diag-flash{min-height:22px;font-size:15px;font-weight:700;color:var(--violet-2);text-align:center}.diag-done{max-width:480px;margin:0 auto;min-height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:16px;padding:32px 22px}.diag-done-title{margin:6px 0 0;font-size:30px;color:var(--text)}.diag-done-sub{margin:0;font-size:16px;line-height:1.55;color:var(--muted);max-width:400px}.diag-done-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}.diag-done-actions button{padding:14px 22px;font-size:16px}.gate{min-height:100%;display:flex;align-items:center;justify-content:center;padding:24px}.gate-card{max-width:360px;width:100%;padding:28px 26px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px}.gate-emoji{font-size:44px}.gate-title{margin:0;font-size:22px;color:var(--text)}.gate-sub{margin:0;font-size:14px;color:var(--muted);line-height:1.5}.gate-error{color:var(--coral);font-weight:800;font-size:14px}.gate-continue{padding:14px 22px;width:100%}.gate-link{color:var(--violet-2);font-weight:800;font-size:14px;text-decoration:none}.pin-dots{display:flex;gap:14px}.pin-dots--error{animation:pin-shake .4s ease}@keyframes pin-shake{0%,to{transform:translate(0)}25%{transform:translate(-8px)}75%{transform:translate(8px)}}.pin-dot{width:16px;height:16px;border-radius:50%;border:2px solid var(--line)}.pin-dot--filled{background:var(--violet);border-color:var(--violet)}.pin-pad{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;width:100%;max-width:240px}.pin-key{font-size:22px;font-weight:800;padding:14px;background:#fff;color:var(--text);box-shadow:0 3px 0 var(--line)}.pin-key--ghost{background:transparent;box-shadow:none;color:var(--muted)}.report{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:16px}.report-head{display:flex;align-items:flex-start}.report-title{margin:0;font-size:26px;color:var(--text)}.report-meta{margin:4px 0 0;color:var(--muted);font-weight:700}.report-home{margin-left:auto;width:36px;height:36px;border-radius:50%;background:#fff;box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center;text-decoration:none;color:var(--muted);font-size:16px}.report-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.rs-stat{background:#fff;border:1px solid var(--line);border-radius:16px;padding:16px;text-align:center}.rs-num{display:block;font-size:30px;font-weight:900;color:var(--text)}.rs-label{font-size:12px;font-weight:700;color:var(--muted)}.rs-stat--clear{background:#e7f8f6;border-color:#a9e6df}.rs-stat--practice{background:#ffeee9;border-color:#f6c3b7}.rec-list{display:flex;flex-direction:column;gap:10px}.rec{display:flex;gap:14px;align-items:center}.rec-badge{flex:0 0 auto;width:56px;height:56px;border-radius:14px;background:var(--coral);color:#fff;font-weight:900;font-size:18px;display:flex;align-items:center;justify-content:center}.rec-cue{font-weight:700;color:var(--text)}.rec-example{font-size:13px;color:var(--muted);margin-top:2px}.diag-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(78px,1fr));gap:8px}.diag-cell{border-radius:12px;padding:10px 6px;text-align:center;border:2px solid transparent}.diag-cell-label{display:block;font-size:17px;font-weight:900;color:var(--text)}.diag-cell-state{font-size:11px;font-weight:700}.diag-cell--clear{background:#e7f8f6;border-color:#7dd8cf}.diag-cell--clear .diag-cell-state{color:var(--violet-2)}.diag-cell--unclear{background:#ffeee9;border-color:#f0a999}.diag-cell--unclear .diag-cell-state{color:var(--coral)}.diag-cell--untested{background:var(--surface-2);border-color:var(--line)}.diag-cell--untested .diag-cell-state{color:var(--muted)}.diag-legend{display:flex;gap:16px;margin-top:12px;font-size:13px;font-weight:700;color:var(--muted)}.diag-legend span{display:flex;align-items:center;gap:6px}.lg{width:14px;height:14px;border-radius:4px;display:inline-block}.lg--clear{background:#7dd8cf}.lg--unclear{background:#f0a999}.lg--untested{background:var(--line)}.report-disclaimer{font-size:13px;line-height:1.6;color:var(--muted);background:var(--surface-2);border:1px solid var(--line);border-radius:14px;padding:14px 16px}.report-actions{display:flex;gap:10px;flex-wrap:wrap}.report-actions button{padding:12px 16px;font-size:14px}.report-empty{max-width:420px;margin:40px auto;text-align:center;display:flex;flex-direction:column;gap:12px;align-items:center}.report-empty .btn-coral{text-decoration:none;padding:12px 20px}.settings{max-width:560px;margin:0 auto;display:flex;flex-direction:column;gap:16px}.settings-title{margin:0;font-size:26px;color:var(--text)}.settings-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.settings-flash{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:var(--forest);color:#fff;font-weight:800;padding:12px 20px;border-radius:999px;box-shadow:var(--shadow);z-index:50}@media print{.app-header,.report-actions,.report-home{display:none!important}body{overflow:visible}.app-main{overflow:visible;padding:0}}@media (max-width: 720px){.home-doors,.report-summary{grid-template-columns:1fr}}.score-card{display:flex;align-items:center;gap:14px;padding:10px 16px;border-radius:16px;max-width:340px;animation:score-pop .25s ease}@keyframes score-pop{0%{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}.score-num{font-size:34px;font-weight:900;line-height:1;display:flex;align-items:baseline}.score-pct{font-size:16px;margin-left:2px}.score-info{display:flex;flex-direction:column}.score-label{font-weight:800;color:var(--text);font-size:14px}.score-heard{font-size:13px;color:var(--muted)}.score-method{margin-left:auto;font-size:10px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;color:var(--muted);background:var(--surface-2);border:1px solid var(--line);border-radius:999px;padding:4px 9px;cursor:help}.home-hero-text{flex:1}.goal-ring{width:84px;height:84px;flex:0 0 auto}.goal-ring-track{fill:none;stroke:var(--surface-2);stroke-width:8}.goal-ring-fill{fill:none;stroke-width:8;stroke-linecap:round;transition:stroke-dasharray .5s ease}.goal-ring-num{text-anchor:middle;font-weight:900;font-size:15px;fill:var(--text);font-family:var(--font)}.goal-ring-cap{text-anchor:middle;font-size:9px;font-weight:700;fill:var(--muted);font-family:var(--font)}.rail-tabs{display:flex;gap:8px;margin-bottom:12px}.rail-tab{font-family:inherit;font-weight:800;font-size:14px;color:var(--muted);background:var(--surface-2);border:1px solid var(--line);border-radius:999px;padding:8px 16px;cursor:pointer;transition:all .12s ease}.rail-tab--active{color:#fff;background:var(--violet);border-color:var(--violet)}.rail-note{margin-top:8px}.rail-word-flag--custom{background:var(--violet)}.panel-tag{font-size:12px;font-weight:700;color:var(--muted);background:var(--surface-2);border:1px solid var(--line);border-radius:999px;padding:2px 10px;margin-left:8px;vertical-align:middle}.dash-empty{display:flex;align-items:center;gap:16px}.dash-empty-emoji{font-size:36px}.wordinfo{max-width:380px;padding:10px 14px;text-align:left;font-size:13px}.wordinfo--loading{color:var(--muted);font-size:13px;padding:6px}.wordinfo-head{display:flex;align-items:center;gap:8px;margin-bottom:4px}.wordinfo-icon{font-size:15px}.wordinfo-ipa{font-family:ui-monospace,SF Mono,monospace;color:var(--violet-2);font-weight:700;font-size:13px}.wordinfo-audio{border:none;background:var(--surface-2);border-radius:999px;width:26px;height:26px;cursor:pointer;font-size:13px;line-height:1}.wordinfo-audio:hover{background:#eef7f6}.wordinfo-pos{font-size:11px;font-weight:700;color:var(--muted);background:var(--surface-2);border-radius:999px;padding:2px 8px}.wordinfo-pry{margin-left:auto;color:var(--line);font-weight:900;letter-spacing:1px;-webkit-user-select:none;user-select:none}.wordinfo-def{color:var(--text);line-height:1.4}.wordinfo-ex{color:var(--muted);font-style:italic;margin-top:3px}.wordinfo-obscure{margin-top:8px;padding-top:8px;border-top:1px dashed var(--line);color:var(--muted);line-height:1.4;animation:score-pop .25s ease}.wordinfo-obscure-tag{display:inline-block;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:var(--coral);margin-right:6px}@media (max-width: 560px){body{overflow:auto}.app-header{flex-wrap:wrap;gap:8px 12px;padding:max(8px,env(safe-area-inset-top)) 14px 8px;position:sticky;top:0;z-index:30}.brand-mark{font-size:28px}.brand h1{font-size:18px}.brand p{display:none}.level-box{min-width:0;flex:1 1 110px;gap:8px}.level-badge{font-size:12px;padding:5px 10px}.tabs{flex-basis:100%;justify-content:space-between;gap:6px}.tab{flex:1;padding:9px 4px;font-size:13px;text-align:center}.app-main{padding:12px 12px max(14px,env(safe-area-inset-bottom))}.coach,.coach-center{gap:12px}.prompt-word{font-size:26px}.mic-orb{width:144px;height:144px}.mic-orb-face{font-size:44px}.wave-canvas{width:100%;max-width:320px;height:auto}.wordinfo,.score-card{max-width:100%}.word-picker{justify-content:flex-start}.word-card{width:84px}.home-hero{flex-direction:column;text-align:center;gap:12px;padding:18px}.home-greeting{font-size:24px}.home-banner{font-size:14px;padding:14px 16px}.dash-title,.settings-title,.report-title{font-size:22px}.stat-strip{grid-template-columns:repeat(2,1fr)}.outcome-big{font-size:40px}.slp-table{font-size:13px}.slp-table th,.slp-table td{padding:6px 5px}.report-actions button{flex:1 1 auto}.onb,.intro,.diag,.diag-done{padding-left:18px;padding-right:18px}.diag-emoji{font-size:60px}.diag-word{font-size:34px}}
