.app{--app-pad-x: clamp(16px, 6vw, 80px);--app-pad-y: clamp(18px, 4vw, 40px);min-height:100svh;min-height:var(--app-height, 100dvh);height:var(--app-height, 100dvh);width:100%;display:flex;flex-direction:column;align-items:center;gap:clamp(12px,3vw,24px);padding:calc(var(--app-pad-y) + env(safe-area-inset-top,0px)) var(--app-pad-x) calc(var(--app-pad-y) + env(safe-area-inset-bottom,0px));position:relative;overflow:hidden;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.app.mode-listen.listen-focused{--app-pad-y: clamp(12px, 3vw, 28px);gap:clamp(8px,2vw,16px);padding:calc(clamp(12px,3vw,28px) + env(safe-area-inset-top,0px)) var(--app-pad-x) calc(clamp(12px,3vw,28px) + env(safe-area-inset-bottom,0px))}.app.mode-listen.listen-focused .stage{gap:clamp(8px,2vw,14px)}.app.mode-listen.listen-focused .letter{font-size:clamp(64px,18vw,160px)}.top-bar{width:min(960px,100%);display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:start;gap:clamp(8px,2vw,16px);z-index:2}.logo{display:flex;align-items:center;justify-self:start}.logo-button{padding:0;border:0;background:transparent;cursor:pointer;display:flex;align-items:center}.logo-button:focus-visible{outline:3px solid var(--color-text-primary-70);outline-offset:6px;border-radius:16px}.logo img{width:clamp(44px,6vw,72px);height:auto;display:block;opacity:.5;transition:opacity var(--timing-snap) var(--ease-out),transform var(--timing-morph) var(--ease-out)}.logo-button:hover img{opacity:1;transform:rotate(15deg)}.legal-page{width:100%;height:100%;min-height:100%;display:flex;flex-direction:column;align-items:center;gap:clamp(18px,4vw,32px);padding:clamp(20px,5vw,48px) clamp(18px,6vw,80px) clamp(28px,6vw,64px);overflow-y:auto;overflow-x:hidden;position:relative;-webkit-user-select:text;user-select:text;-webkit-touch-callout:default}.legal-header{width:min(900px,100%);display:grid;gap:clamp(12px,3vw,20px)}.legal-top{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px}.legal-back{font-size:.7rem;text-transform:uppercase;letter-spacing:.2em;color:var(--color-text-primary-60);text-decoration:none;border-bottom:1px solid transparent;transition:color var(--timing-snap) var(--ease-out),border-color var(--timing-snap) var(--ease-out)}.legal-back:hover{color:var(--color-text-primary-90);border-color:var(--color-border-hover)}.legal-back:focus-visible{outline:2px solid var(--color-text-primary-70);outline-offset:4px}.legal-nav{display:flex;gap:16px;font-size:.7rem;text-transform:uppercase;letter-spacing:.2em}.legal-nav a{color:var(--color-text-primary-60);text-decoration:none;border-bottom:1px solid transparent;transition:color var(--timing-snap) var(--ease-out),border-color var(--timing-snap) var(--ease-out)}.legal-nav a:hover{color:var(--color-text-primary-90);border-color:var(--color-border-hover)}.legal-nav a[aria-current=page]{color:var(--color-accent-wave);border-color:var(--color-accent-wave)}.legal-hero{display:grid;gap:10px}.legal-eyebrow{margin:0;font-size:.75rem;text-transform:uppercase;letter-spacing:.4em;color:var(--color-text-primary-60)}.legal-title{margin:0;font-family:inherit;font-size:clamp(1.8rem,3vw,2.4rem);letter-spacing:.02em}.legal-intro{margin:0;color:var(--color-text-primary-80);max-width:60ch}.legal-updated{margin:0;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-primary-40)}.legal-overlay{position:absolute;inset:0;display:grid;place-items:center;padding:clamp(16px,4vw,40px);background:var(--color-surface-backdrop);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:4;animation:legalFade var(--timing-standard) var(--ease-out)}.legal-card{width:min(900px,100%);padding:clamp(20px,4vw,32px);border-radius:24px;border:1px solid var(--color-border-subtle);background:var(--color-surface-panel-strong);backdrop-filter:blur(14px) saturate(160%);-webkit-backdrop-filter:blur(14px) saturate(160%);display:grid;gap:24px;animation:aboutPop var(--timing-standard) var(--ease-out)}.legal-card a{color:var(--accent)}.legal-section{display:grid;gap:12px}.legal-section h2{margin:0;font-size:.9rem;letter-spacing:.18em;text-transform:uppercase;color:var(--color-text-primary-70)}.legal-section p{margin:0;color:var(--color-text-primary-80)}.legal-section ul{margin:0;padding-left:18px;color:var(--color-text-primary-80);display:grid;gap:8px}.legal-footer{width:min(900px,100%);display:flex;justify-content:center;font-size:.65rem;letter-spacing:.24em;text-transform:uppercase;color:var(--color-text-primary-40)}.about-overlay{position:absolute;inset:0;display:grid;place-items:center;padding:clamp(16px,4vw,40px);background:var(--color-surface-backdrop-soft);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:4;animation:aboutFade var(--timing-standard) var(--ease-out)}.about-card{width:min(420px,100%);padding:clamp(18px,4vw,28px);border-radius:20px;border:1px solid var(--color-border-subtle);background:var(--color-surface-panel-strong);backdrop-filter:blur(12px) saturate(140%);-webkit-backdrop-filter:blur(12px) saturate(140%);text-align:center;display:flex;flex-direction:column;gap:14px;animation:aboutPop var(--timing-standard) var(--ease-out);position:relative;overflow:hidden}.about-title{margin:0;font-size:.9rem;letter-spacing:.4em;text-transform:uppercase;color:var(--text)}.about-instruction{margin:0;font-size:.9rem;line-height:1.5;letter-spacing:.01em;text-align:left;color:var(--color-text-primary-90)}.about-instruction-secondary{font-size:.85rem;line-height:1.5;letter-spacing:.01em;color:var(--color-text-primary-70)}.about-links{display:flex;justify-content:center;gap:14px;padding-top:20px;margin-top:14px;border-top:1px solid rgba(255,255,255,.1);font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--color-text-primary-40)}.about-links a{color:inherit;text-decoration:none;border-bottom:1px solid transparent;transition:color var(--timing-snap) var(--ease-out),border-color var(--timing-snap) var(--ease-out)}.about-links a:hover{color:var(--color-text-primary-80);border-color:var(--color-border-hover)}.about-links a:focus-visible{outline:2px solid var(--color-text-primary-70);outline-offset:3px}.about-close{align-self:center;border-radius:999px;border:1px solid rgba(255,255,255,.2);background:#ffffff0f;color:var(--color-text-primary-80);text-transform:uppercase;font-size:.65rem;letter-spacing:.2em;padding:10px 18px;cursor:pointer;transition:all var(--timing-snap) var(--ease-out)}.about-close:hover{color:var(--text);border-color:var(--color-border-hover);background:#ffffff1f}.about-close:focus-visible{outline:2px solid var(--color-text-primary-70);outline-offset:3px}@keyframes aboutFade{0%{opacity:0}to{opacity:1}}@keyframes aboutPop{0%{transform:translateY(6px) scale(.98)}to{transform:translateY(0) scale(1)}}.settings{position:relative;display:flex;flex-direction:column;align-items:flex-end;gap:10px;justify-self:end;z-index:3}.auth{display:flex;align-items:center;justify-content:flex-start;gap:10px;flex-wrap:wrap;padding-top:16px;border-top:1px solid var(--color-border-subtle)}.auth-avatar{width:28px;height:28px;border-radius:999px;border:1px solid var(--color-border-hover);background:var(--color-surface-panel-strong);display:grid;place-items:center;color:var(--text);font-size:.65rem;letter-spacing:.08em;text-transform:uppercase;object-fit:cover}.auth-name{font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text);max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.auth-button{border-radius:12px;padding:10px 16px;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;font-weight:500;border:1px solid var(--color-border-subtle);background:var(--color-surface-input);-webkit-backdrop-filter:blur(10px) saturate(180%);backdrop-filter:blur(10px) saturate(180%);color:var(--color-text-primary-80);cursor:pointer;width:100%;transition:all var(--timing-snap) var(--ease-out)}.auth-button:hover{color:var(--text);border-color:var(--color-border-hover);background:var(--color-surface-input-pressed);transform:translateY(-1px)}.auth-button:not(:disabled):active{transform:scale(.97)}.auth-button:focus-visible{outline:2px solid var(--color-text-primary-70);outline-offset:3px}.auth-button:disabled{cursor:not-allowed;opacity:.6}.mode-select,.panel-select{appearance:none;border-radius:999px;border:1px solid var(--color-border-subtle);background:var(--color-surface-input);-webkit-backdrop-filter:blur(10px) saturate(180%);backdrop-filter:blur(10px) saturate(180%);color:var(--text);letter-spacing:.12em;text-transform:uppercase;cursor:pointer;background-image:linear-gradient(45deg,transparent 50%,rgba(255,255,255,.6) 50%),linear-gradient(135deg,rgba(255,255,255,.6) 50%,transparent 50%);background-position:calc(100% - 14px) 55%,calc(100% - 9px) 55%;background-size:5px 5px;background-repeat:no-repeat}.mode-select{justify-self:center;padding:8px 26px 8px 12px;font-size:.72rem}.panel-select{padding:8px 30px 8px 14px;font-size:.72rem;font-weight:500;transition:border var(--timing-snap) var(--ease-out),background var(--timing-snap) var(--ease-out)}.panel-select:hover{border-color:var(--color-border-hover);background:var(--color-surface-input-pressed)}:is(.mode-select,.settings-button):focus-visible{outline:3px solid var(--color-text-primary-70);outline-offset:3px}.settings-button{width:40px;height:40px;border-radius:999px;border:1px solid var(--color-border-subtle);background:var(--color-surface-panel);-webkit-backdrop-filter:blur(10px) saturate(150%);backdrop-filter:blur(10px) saturate(150%);display:grid;place-items:center;color:var(--text);box-shadow:0 8px 18px #0000004d,inset 0 1px #ffffff1a;transition:transform var(--timing-exit) var(--ease-out),border var(--timing-standard) var(--ease-out),filter var(--timing-standard) var(--ease-out),box-shadow var(--timing-standard) var(--ease-out)}.settings-button:hover{filter:brightness(1.2)}.settings-button:hover svg{animation:settingsGearSpin var(--timing-morph) var(--ease-in-out)}.settings-button[aria-expanded=true]{border-color:var(--color-border-hover)}.settings-button:active{transform:scale(.95)}@keyframes settingsGearSpin{0%{transform:rotate(0)}to{transform:rotate(90deg)}}.settings-button svg{width:18px;height:18px}.settings-panel{position:absolute;top:calc(100% + 10px);right:0;min-width:240px;padding:20px 18px;border-radius:16px;border:1px solid var(--color-border-subtle);background:var(--color-surface-panel-strong);-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);display:flex;flex-direction:column;gap:18px;animation:panelSlideIn var(--timing-standard) var(--ease-out)}@keyframes panelSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.panel-group{display:flex;flex-direction:column;gap:12px;padding-top:14px;border-top:1px solid var(--color-border-subtle)}.panel-hint{font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-primary-40);font-style:italic}:is(.panel-button,.modal-close,.hint-button){border-radius:12px;color:var(--muted);text-transform:uppercase;cursor:pointer;transition:border var(--timing-snap) var(--ease-out),color var(--timing-snap) var(--ease-out),background var(--timing-snap) var(--ease-out),transform var(--timing-press) var(--ease-out)}.panel-button,.modal-close{padding:10px 16px;font-size:.68rem;letter-spacing:.18em;font-weight:500}.panel-button,.hint-button{border:1px solid var(--color-border-subtle);background:var(--color-surface-input);-webkit-backdrop-filter:blur(10px) saturate(180%);backdrop-filter:blur(10px) saturate(180%)}.panel-button{width:100%;text-align:center}:is(.panel-button,.modal-close,.hint-button):hover{color:var(--text);border-color:var(--color-border-hover);background:var(--color-surface-input-pressed);box-shadow:0 8px 20px #0000004d,inset 0 1px #ffffff26;transform:translateY(-1px)}:is(.panel-button,.modal-close,.hint-button):active{transform:scale(.97)}:is(.panel-select,.panel-button,.modal-close,.hint-button):focus-visible{outline:2px solid var(--color-text-primary-70);outline-offset:3px}.panel-button-row{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%}.panel-button-label{font-weight:500}.panel-button-value{color:var(--color-text-muted, rgba(255, 255, 255, .6));font-size:.9em}.panel-button-chevron{margin-left:4px;opacity:.6}.toggle{display:flex;align-items:center;justify-content:space-between;gap:20px;font-size:.85rem;color:var(--text)}.toggle-label{text-transform:uppercase;letter-spacing:.14em;font-size:.75rem;font-weight:500;color:var(--color-text-primary-80)}.toggle-input{appearance:none;width:48px;height:26px;border-radius:999px;border:1px solid var(--color-border-subtle);background:var(--color-controls-switch-track-off);position:relative;cursor:pointer;transition:background var(--timing-standard) var(--ease-out),border var(--timing-standard) var(--ease-out),box-shadow var(--timing-standard) var(--ease-out)}.toggle-input:hover{border-color:var(--color-border-hover)}.toggle-input:after{content:"";width:20px;height:20px;border-radius:999px;background:var(--color-text-primary-90);position:absolute;top:2px;left:2px;transition:transform var(--timing-standard) var(--ease-in-out),background var(--timing-standard) var(--ease-out);box-shadow:0 2px 4px #0000004d}.toggle-input:checked{background:var(--color-accent-wave);border-color:var(--color-accent-wave)}.toggle-input:checked:after{transform:translate(22px);background:var(--color-controls-switch-thumb-on)}.toggle-input:focus-visible{outline:2px solid var(--color-text-primary-70);outline-offset:3px}.stage{flex:1;align-self:stretch;width:100%;min-height:0;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:clamp(12px,2vw,18px);z-index:1}.letter{font-family:inherit;font-size:clamp(96px,24vw,200px);line-height:.9;letter-spacing:.12em;font-weight:500;text-transform:uppercase;color:var(--text);text-shadow:0 20px 60px rgba(0,0,0,.55);animation:letterRise var(--timing-morph) var(--ease-out);transition:color var(--timing-wash) var(--ease-out)}.word-display{font-family:inherit;font-size:clamp(52px,14vw,160px);line-height:.95;letter-spacing:.12em;font-weight:500;text-transform:uppercase;color:var(--text);text-shadow:0 20px 60px rgba(0,0,0,.55);display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(4px,1.2vw,12px);animation:letterRise var(--timing-morph) var(--ease-out)}.word-letter{opacity:.28;transition:color var(--timing-snap) var(--ease-out),opacity var(--timing-snap) var(--ease-out),transform var(--timing-snap) var(--ease-out)}.word-letter.done{opacity:.6;color:var(--color-accent-wave)}.word-letter.active{opacity:1;color:var(--color-accent-wave);transform:translateY(-4px)}.status-success .word-letter.active{color:var(--color-feedback-success)}.status-error .word-letter.active{color:var(--color-feedback-error)}.letter-placeholder{min-height:.9em;opacity:.2}.progress{display:flex;align-items:center;gap:12px;min-height:22px}.pip{display:inline-block;border-radius:999px;background:var(--color-accent-wave);box-shadow:0 0 16px #4cc9ff4d;transition:transform var(--timing-exit) var(--ease-out),background var(--timing-standard) var(--ease-out),opacity var(--timing-standard) var(--ease-out)}.pip.dot{width:12px;height:12px}.pip.dah{width:34px;height:12px}.pip.expected{opacity:.3;filter:saturate(.6)}.pip.hit{opacity:1;transform:translateY(-1px)}.progress-hidden{opacity:0}.status-text{margin:0;font-size:.9rem;line-height:1.2;min-height:1.2em;letter-spacing:.12em;color:var(--muted);transition:color var(--timing-wash) var(--ease-out)}.wpm-text{margin:0;font-size:.75rem;line-height:1.2;min-height:1.2em;letter-spacing:.2em;color:var(--muted);text-transform:uppercase}.status-success .status-text{color:var(--color-feedback-success)}.status-error .status-text{color:var(--color-feedback-error)}.status-success .letter{color:var(--color-feedback-success)}.status-error .letter{color:var(--color-feedback-error);animation:letterShake var(--timing-medium) var(--ease-out)}.status-success .pip{background:var(--color-feedback-success)}.status-error .pip{background:var(--color-feedback-error)}.controls{width:min(560px,100%);display:flex;flex-direction:column;align-items:center;gap:24px;z-index:1}.settings{position:relative}.intro-hint{position:relative;display:grid;gap:8px;padding:12px 14px;border-radius:14px;border:1px solid var(--color-border-subtle);background:var(--color-surface-panel-strong);text-align:center;color:var(--text)}.intro-hint p{margin:0;font-size:.82rem;line-height:1.3;letter-spacing:.08em}.intro-hint-morse{width:min(340px,100%);margin-bottom:8px}.intro-hint-settings{position:absolute;right:0;top:calc(100% + 12px);width:200px;z-index:4}.intro-hint-settings .intro-hint-arrow{top:-6px;left:75%;bottom:auto;border-bottom:none;border-right:none;border-top:1px solid var(--color-border-subtle);border-left:1px solid var(--color-border-subtle);transform:translate(-50%) rotate(45deg)}.intro-hint-arrow{position:absolute;width:10px;height:10px;background:var(--color-surface-panel-strong);border-right:1px solid var(--color-border-subtle);border-bottom:1px solid var(--color-border-subtle);bottom:-6px;left:50%;transform:translate(-50%) rotate(45deg)}.intro-hint-dismiss{justify-self:center;padding:6px 12px;border-radius:12px;border:1px solid var(--color-border-subtle);background:var(--color-surface-input);color:var(--text);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;cursor:pointer;transition:transform var(--timing-exit) var(--ease-out),background var(--timing-exit) var(--ease-out),border var(--timing-exit) var(--ease-out)}.intro-hint-dismiss:hover{transform:translateY(-1px);background:var(--color-surface-input-pressed);border-color:var(--color-border-hover)}.intro-hint-dismiss:focus-visible{outline:2px solid var(--color-text-primary-70);outline-offset:2px}.listen-controls{width:min(560px,100%);display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:12px}.listen-controls-custom{width:min(640px,100%);flex-direction:column;flex-wrap:nowrap;gap:14px}.keyboard-key{font-family:inherit;text-transform:uppercase}.listen-keyboard{width:min(640px,100%);display:flex;flex-direction:column;gap:clamp(6px,1.6vw,10px)}.keyboard-row{display:flex;justify-content:center;gap:clamp(4px,1.2vw,8px)}.keyboard-key{flex:1 1 0;max-width:56px;height:clamp(36px,9vw,48px);border-radius:12px;border:1px solid var(--color-border-subtle);background:var(--color-surface-input);-webkit-backdrop-filter:blur(10px) saturate(180%);backdrop-filter:blur(10px) saturate(180%);color:var(--text);font-size:clamp(.75rem,2.8vw,.95rem);letter-spacing:.12em;cursor:pointer;transition:all var(--timing-press) var(--ease-out);touch-action:manipulation}.keyboard-key:active{transform:translateY(1px) scale(.98);background:var(--color-surface-input-pressed);border-color:var(--color-border-hover)}.keyboard-key:disabled{opacity:.5;cursor:default}.modal-overlay{position:fixed;inset:0;background:var(--color-surface-backdrop);display:grid;place-items:center;padding:clamp(16px,4vw,40px);z-index:5;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.modal{width:min(720px,100%);max-height:min(82vh,680px);background:var(--color-surface-panel-strong);border-radius:20px;border:1px solid var(--color-border-subtle);-webkit-backdrop-filter:blur(24px) saturate(180%);backdrop-filter:blur(24px) saturate(180%);display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 20px 12px;border-bottom:1px solid var(--color-border-subtle)}.modal-actions{display:flex;align-items:center;gap:8px}.modal-title{font-size:.75rem;letter-spacing:.28em;text-transform:uppercase;color:var(--text)}.modal-close{border:1px solid var(--color-border-subtle);background:var(--color-surface-input);-webkit-backdrop-filter:blur(10px) saturate(180%);backdrop-filter:blur(10px) saturate(180%)}.modal-close.modal-reset{color:var(--error);border-color:var(--color-border-error)}.modal-close.modal-reset:hover{color:var(--error);border-color:var(--color-border-error-strong)}.reference-grid,.reference-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(78px,1fr));gap:12px}.reference-grid{padding:0}.reference-scroll{display:flex;flex-direction:column;gap:14px;padding:16px 20px 20px;overflow:auto}.reference-hero{display:flex;align-items:baseline;justify-content:space-between;gap:12px;padding:14px 18px;border-radius:14px;background:var(--color-surface-input);border:1px solid var(--color-border-subtle)}.reference-hero-value{font-size:1.8rem;font-weight:600;color:var(--text);letter-spacing:.02em}.reference-hero-value-muted{color:var(--color-text-primary-40);font-weight:400}.reference-hero-label{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--color-text-primary-60)}.reference-streak{display:flex;flex-direction:column;gap:8px;padding:12px 16px;border-radius:14px;background:var(--color-surface-input);border:1px solid var(--color-border-subtle)}.reference-streak-header{display:flex;align-items:baseline;justify-content:space-between;gap:12px}.reference-streak-text{font-size:.95rem;color:var(--text);font-weight:500}.reference-streak-detail{font-size:.75rem;color:var(--color-text-primary-60)}.reference-streak-track{position:relative;height:6px;border-radius:3px;background:#ffffff14;overflow:hidden}.reference-streak-fill{position:absolute;inset:0 auto 0 0;background:var(--color-accent-wave);transition:width var(--timing-standard) var(--ease-out)}.reference-course-banner{display:flex;flex-direction:column;gap:4px;padding:10px 14px;border-radius:12px;background:var(--color-surface-card);border:1px solid var(--color-border-subtle)}.reference-course-banner-title{font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-primary-70)}.reference-course-banner-letters{font-size:.95rem;color:var(--text);letter-spacing:.08em}.reference-card-mastered{box-shadow:inset 0 0 0 1px var(--color-feedback-success)}.reference-row{grid-column:1 / -1;margin-top:6px}.reference-card{padding:12px 10px;border-radius:12px;background:linear-gradient(0deg,rgba(var(--score-tint, 0, 0, 0),var(--score-alpha, 0)),rgba(var(--score-tint, 0, 0, 0),var(--score-alpha, 0))),var(--color-surface-card);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--color-border-subtle);display:flex;flex-direction:column;align-items:center;gap:6px}.reference-head{position:relative;width:100%;min-height:1.4rem;display:grid;place-items:center}.reference-letter,.reference-score{position:absolute;inset:0;display:grid;place-items:center;transition:opacity var(--timing-snap) var(--ease-out);font-family:inherit;text-transform:uppercase;color:var(--text)}.reference-letter{font-size:1.2rem;letter-spacing:.18em;opacity:1}.reference-score{font-size:1rem;letter-spacing:.16em;opacity:0}.reference-score.score-positive{color:var(--color-feedback-success)}.reference-score.score-negative{color:var(--color-feedback-error)}.reference-card:hover .reference-letter{opacity:0}.reference-card:hover .reference-score{opacity:1}.reference-code{display:flex;gap:4px;font-size:.9rem;letter-spacing:.16em;color:var(--muted)}.reference-symbol{font-weight:600}.hint-button{padding:8px 16px;font-size:.65rem;letter-spacing:.18em}.hint-button:disabled{opacity:.6;cursor:default}.freestyle-status{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}.button-content{position:relative;display:flex;align-items:center;gap:16px;z-index:1}.signal{display:inline-block;background:#0000004d;border:none;box-shadow:none}.signal.dot{width:14px;height:14px;border-radius:999px}.signal.dah{width:40px;height:14px;border-radius:999px}@keyframes letterRise{0%{opacity:.4;transform:translateY(14px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes letterShake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}@media(max-width:600px){.status-text{font-size:.8rem;letter-spacing:.1em}.settings-button{width:36px;height:36px}.auth-name{display:none}.letter{letter-spacing:.08em}.button-content{gap:12px}.signal.dah{width:32px}}.phase-modal-overlay{position:fixed;inset:0;background:var(--color-surface-backdrop);display:grid;place-items:center;padding:clamp(16px,4vw,40px);z-index:6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:phase-modal-fade var(--timing-standard) var(--ease-out)}.phase-modal-card{width:min(420px,100%);background:var(--color-surface-panel-strong);border-radius:20px;border:1px solid var(--color-border-subtle);-webkit-backdrop-filter:blur(24px) saturate(180%);backdrop-filter:blur(24px) saturate(180%);padding:32px 24px;display:flex;flex-direction:column;align-items:center;gap:16px;animation:phase-modal-scale var(--timing-standard) var(--ease-out)}.phase-modal-title{font-size:1.1rem;font-weight:600;letter-spacing:.02em;color:var(--text);text-align:center;margin:0}.phase-modal-subtitle{font-size:.9rem;line-height:1.4;color:var(--color-text-primary-70);text-align:center;margin:0}.phase-modal-letters{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.phase-modal-chip{width:36px;height:36px;border-radius:10px;background:var(--color-surface-input);border:1px solid var(--color-border-subtle);display:grid;place-items:center;font-size:1rem;font-weight:600;letter-spacing:.1em;color:var(--text)}.phase-modal-button{margin-top:8px;padding:12px 28px;border-radius:24px;border:1px solid var(--color-border-subtle);background:var(--color-surface-input);color:var(--text);font-size:.9rem;font-weight:500;cursor:pointer;transition:background var(--timing-press) var(--ease-out),transform var(--timing-press) var(--ease-out)}.phase-modal-button:hover{background:var(--color-surface-input-pressed)}.phase-modal-button:active{transform:scale(.97)}.phase-modal-button:focus-visible{outline:2px solid var(--color-text-primary-70);outline-offset:2px}@keyframes phase-modal-fade{0%{opacity:0}to{opacity:1}}@keyframes phase-modal-scale{0%{opacity:0;transform:scale(.96) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}.return-to-lesson-button{margin-bottom:12px;padding:10px 16px;border-radius:24px;border:1px solid var(--color-border-subtle);background:var(--color-surface-input);color:var(--text);font-size:.85rem;cursor:pointer;transition:background var(--timing-press) var(--ease-out)}.return-to-lesson-button:hover{background:var(--color-surface-input-pressed)}.nux-overlay{position:fixed;inset:0;z-index:80;background:var(--color-surface-solid-backdrop);display:flex;align-items:center;justify-content:center;padding:24px;animation:phase-modal-fade var(--timing-standard) var(--ease-out)}.nux-overlay-welcome{background:var(--color-surface-solid-backdrop)}.nux-content{width:min(480px,100%);max-height:calc(100vh - 48px);overflow-y:auto;background:var(--color-surface-panel-strong);border:1px solid var(--color-border-subtle);border-radius:28px;padding:28px 24px 24px;display:flex;flex-direction:column;gap:20px;box-shadow:0 24px 80px #0000008c;color:var(--color-text-primary);animation:phase-modal-scale var(--timing-standard) var(--ease-out)}.nux-progress{display:flex;justify-content:center;gap:6px}.nux-dot{width:7px;height:7px;border-radius:4px;background:#fff3;transition:background var(--timing-standard) var(--ease-in-out),width var(--timing-standard) var(--ease-out)}.nux-dot.active{width:20px;background:var(--color-text-primary)}.nux-dot.past{background:#6ee7b7}.nux-body{display:flex;flex-direction:column;gap:20px;align-items:stretch;transition:opacity var(--timing-exit) var(--ease-out)}.nux-body>*{animation:nux-step-in var(--timing-standard) var(--ease-out) both}.nux-body>*:nth-child(1){animation-delay:0ms}.nux-body>*:nth-child(2){animation-delay:50ms}.nux-body>*:nth-child(3){animation-delay:.1s}.nux-body>*:nth-child(4){animation-delay:.15s}.nux-body>*:nth-child(5){animation-delay:.2s}.nux-body[data-exiting]{opacity:0;pointer-events:none}.nux-body[data-exiting]>*{animation:none}@starting-style{.nux-body{opacity:0}}@keyframes nux-step-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.nux-copy{display:flex;flex-direction:column;gap:6px;text-align:center}.nux-headline{margin:0;font-size:22px;font-weight:600;letter-spacing:-.01em}.nux-subtext{margin:0;color:var(--color-text-primary-70);font-size:15px;line-height:1.45}.nux-option-column{display:flex;flex-direction:column;gap:12px}.nux-option-card{text-align:left;border:1px solid var(--color-border-subtle);background:var(--color-surface-input);border-radius:18px;padding:16px 18px;color:inherit;font:inherit;cursor:pointer;transition:background var(--timing-exit) var(--ease-out),border-color var(--timing-exit) var(--ease-out),transform var(--timing-exit) var(--ease-out)}.nux-option-card:hover{background:var(--color-surface-input-pressed)}.nux-option-card:active{transform:scale(.97)}.nux-option-card.selected{border-color:var(--color-border-hover);background:var(--color-surface-input-pressed);transform:scale(1.02)}.nux-option-title{margin:0 0 4px;font-size:16px;font-weight:600}.nux-option-body{margin:0;color:var(--color-text-primary-70);font-size:14px}.nux-sound-button{position:relative;align-self:center;width:160px;height:160px;border-radius:50%;border:1px solid var(--color-border-subtle);background:var(--color-surface-input);color:var(--color-text-primary);font-size:15px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform var(--timing-exit) var(--ease-out),border-color var(--timing-exit) var(--ease-out),background var(--timing-exit) var(--ease-out)}.nux-sound-label{position:relative;z-index:1}.nux-sound-button:hover{background:var(--color-surface-input-pressed)}.nux-sound-button:active{transform:scale(.97)}.nux-sound-button.complete{border-color:var(--color-feedback-success);color:var(--color-feedback-success)}.nux-sound-choice{border:1px solid var(--color-border-subtle);background:var(--color-surface-input);color:inherit;font:inherit;font-size:15px;font-weight:500;padding:12px 14px;border-radius:14px;cursor:pointer;transition:background var(--timing-exit) var(--ease-out),border-color var(--timing-exit) var(--ease-out),transform var(--timing-exit) var(--ease-out)}.nux-sound-choice:hover{background:var(--color-surface-input-pressed)}.nux-sound-choice.selected{border-color:var(--color-border-hover);background:var(--color-surface-input-pressed)}.nux-sound-help{border:1px solid var(--color-border-subtle);background:var(--color-surface-input);border-radius:14px;padding:14px 16px;text-align:left}.nux-sound-help-title{margin:0 0 8px;font-size:13px;font-weight:600;letter-spacing:.02em;text-transform:uppercase;color:var(--color-text-primary-60)}.nux-sound-help-list{margin:0;padding-left:18px;color:var(--color-text-primary-80);font-size:14px;line-height:1.5;display:flex;flex-direction:column;gap:4px}.nux-sound-help-emph{color:var(--color-text-primary);font-weight:600}.nux-sound-confirm{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%}.nux-sound-choice{border:1px solid rgba(255,255,255,.12);background:#ffffff0a;color:inherit;font:inherit;font-size:15px;font-weight:500;padding:12px 14px;border-radius:14px;cursor:pointer;transition:background .14s ease,border-color .14s ease,transform .14s ease}.nux-sound-choice:hover{background:#ffffff14}.nux-sound-choice:active{transform:scale(.98)}.nux-sound-choice.selected{border-color:#fff6;background:#ffffff1a}.nux-sound-help{border:1px solid rgba(255,255,255,.08);background:#ffffff08;border-radius:14px;padding:14px 16px;text-align:left}.nux-sound-help-title{margin:0 0 8px;font-size:13px;font-weight:600;letter-spacing:.02em;text-transform:uppercase;color:#f8fafc8c}.nux-sound-help-list{margin:0;padding-left:18px;color:#f8fafcc7;font-size:14px;line-height:1.5;display:flex;flex-direction:column;gap:4px}.nux-sound-help-emph{color:#f8fafc;font-weight:600}.nux-tutorial-block{display:flex;flex-direction:column;gap:12px}.nux-tutorial-row{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--color-surface-input);border:1px solid var(--color-border-subtle);border-radius:14px}.nux-tutorial-label{font-size:15px;font-weight:500}.nux-tutorial-hint{color:var(--color-text-primary-60);font-weight:400}.nux-tutorial-pips{display:flex;gap:6px}.nux-tutorial-pip{width:10px;height:10px;border-radius:999px;background:#ffffff2e;border:1px solid rgba(255,255,255,.22);transition:background var(--timing-snap) var(--ease-out),border-color var(--timing-snap) var(--ease-out)}.nux-tutorial-pip.filled{background:var(--color-feedback-success);border-color:var(--color-feedback-success);animation:nux-pip-pop var(--timing-standard) var(--ease-out)}@keyframes nux-pip-pop{0%{transform:scale(.4)}60%{transform:scale(1.15)}to{transform:scale(1)}}.nux-tutorial-button-slot{display:flex;justify-content:center;margin-top:4px}.nux-card{background:var(--color-surface-input);border:1px solid var(--color-border-subtle);border-radius:16px;padding:14px 18px;margin:0}.nux-bullet-list{list-style:none;padding:14px 18px;display:flex;flex-direction:column;gap:8px;color:var(--color-text-primary-80);font-size:15px}.nux-bullet-list li{display:flex;gap:8px}.nux-bullet-list li:before{content:"•";color:var(--color-text-primary-40)}.nux-stages{display:flex;flex-direction:column;gap:10px}.nux-stage-row{display:flex;align-items:center;gap:14px;padding:12px 14px;border:1px solid var(--color-border-subtle);border-radius:14px;background:var(--color-surface-input);animation:nux-step-in var(--timing-standard) var(--ease-out) both}.nux-stage-row:nth-child(1){animation-delay:.12s}.nux-stage-row:nth-child(2){animation-delay:.26s}.nux-stage-row:nth-child(3){animation-delay:.4s}.nux-stage-number{width:28px;height:28px;border-radius:999px;background:#ffffff1a;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;animation:nux-pip-pop var(--timing-standard) var(--ease-out) both}.nux-stage-row:nth-child(1) .nux-stage-number{animation-delay:.2s}.nux-stage-row:nth-child(2) .nux-stage-number{animation-delay:.34s}.nux-stage-row:nth-child(3) .nux-stage-number{animation-delay:.48s}.nux-stage-body{display:flex;flex-direction:column;gap:2px;min-width:0}.nux-stage-title{margin:0;font-size:15px;font-weight:600}.nux-stage-desc{margin:0;font-size:13px;color:var(--color-text-primary-60)}.nux-pack-preview{display:flex;flex-direction:column;gap:12px;align-items:center}.nux-pack-label{margin:0;color:var(--color-text-primary-60);font-size:13px;text-transform:uppercase;letter-spacing:.08em}.nux-pack-chips{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;perspective:600px}.nux-pack-chip{min-width:52px;padding:10px 16px;border-radius:14px;background:var(--color-surface-input);border:1px solid var(--color-border-subtle);font-size:20px;font-weight:600;letter-spacing:.05em;text-align:center;transform-origin:center;animation:nux-chip-deal-in var(--timing-morph) var(--ease-out) both}.nux-pack-chip:nth-child(1){animation-delay:.2s}.nux-pack-chip:nth-child(2){animation-delay:.32s}.nux-pack-chip:nth-child(3){animation-delay:.44s}.nux-pack-chip:nth-child(4){animation-delay:.56s}@keyframes nux-chip-deal-in{0%{opacity:0;transform:rotateY(90deg) scale(.7)}60%{opacity:1}to{opacity:1;transform:rotateY(0) scale(1)}}.nux-reminder-form{display:flex;flex-direction:column;gap:12px;align-items:stretch}.nux-reminder-label{display:flex;flex-direction:column;gap:6px;font-size:14px;color:var(--color-text-primary-70)}.nux-reminder-input{padding:10px 12px;font-size:18px;font-family:inherit;color:inherit;border-radius:12px;border:1px solid var(--color-border-subtle);background:var(--color-surface-input)}.nux-cta-slot{display:flex;justify-content:center;min-height:48px}.nux-cta{min-width:200px;padding:14px 22px;border-radius:999px;border:0;background:var(--color-text-primary);color:var(--color-controls-switch-thumb-on);font-size:15px;font-weight:600;cursor:pointer;transition:transform var(--timing-exit) var(--ease-out),opacity var(--timing-exit) var(--ease-out)}.nux-cta:disabled{opacity:.35;cursor:default}.nux-cta:not(:disabled):hover{transform:translateY(-1px)}.nux-cta:not(:disabled):active{transform:scale(.97)}.nux-skip{align-self:center;margin-top:4px;padding:10px 18px;border:0;background:transparent;color:var(--color-text-primary-60);font-size:14px;cursor:pointer}.nux-skip:hover{color:var(--color-text-primary-90)}.nux-skip:active{transform:scale(.97)}.nux-welcome{display:flex;flex-direction:column;align-items:center;gap:18px;animation:phase-modal-scale var(--timing-morph) var(--ease-out)}.nux-welcome-logo{width:108px;height:108px;opacity:0;animation:nux-welcome-logo-in var(--timing-morph) var(--ease-out) var(--timing-press) forwards,nux-welcome-logo-breath var(--timing-breath) var(--ease-in-out) calc(var(--timing-press) + var(--timing-morph)) infinite}.nux-welcome-title{margin:0;font-size:34px;font-weight:700;letter-spacing:-.02em;opacity:0;animation:nux-welcome-text-in var(--timing-circle-draw) var(--ease-out) .4s forwards}.nux-welcome-sub{margin:0;color:var(--color-text-primary-70);font-size:16px;opacity:0;animation:nux-welcome-text-in var(--timing-circle-draw) var(--ease-out) .6s forwards}@keyframes nux-welcome-logo-in{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes nux-welcome-logo-breath{0%,to{transform:scale(1)}50%{transform:scale(1.015)}}@keyframes nux-welcome-text-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.app.nux-active>.top-bar,.app.nux-active>.stage,.app.nux-active>.controls{visibility:hidden}.app.nux-tour-active>.top-bar{visibility:visible}.listen-visual{position:relative;align-self:stretch;width:calc(100% + 2 * var(--app-pad-x));margin-left:calc(-1 * var(--app-pad-x));margin-right:calc(-1 * var(--app-pad-x));margin-top:12px;margin-bottom:8px;height:180px;display:flex;align-items:center;justify-content:center}.listen-wave{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;transition:filter var(--timing-standard) var(--ease-out)}.listen-wave.tint-success{filter:drop-shadow(0 0 12px hsla(154,88%,58%,.45))}.listen-wave.tint-error{filter:drop-shadow(0 0 12px hsla(0,100%,71%,.45))}.listen-overlay-letter{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:1;pointer-events:none;animation:listen-letter-in var(--timing-snap) var(--ease-out)}@keyframes listen-letter-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.status-text.listen-status-success{color:var(--color-feedback-success)}.status-text.listen-status-error{color:var(--color-feedback-error)}.listen-ttr{font-variant-numeric:tabular-nums;animation:listen-ttr-in var(--timing-snap) var(--ease-out)}@keyframes listen-ttr-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.learning-sheet{width:min(560px,100%)}.learning-segments{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:12px 20px 4px}.learning-segment{appearance:none;border:1px solid var(--color-border-subtle);background:var(--color-surface-input);color:var(--text);border-radius:12px;padding:10px 12px;font:inherit;cursor:pointer;transition:background .12s ease,border-color .12s ease}.learning-segment:hover{background:var(--color-surface-input-hover, rgba(255, 255, 255, .06))}.learning-segment.is-active{background:var(--color-surface-panel-strong);border-color:var(--color-border-strong, rgba(255, 255, 255, .18))}.learning-body{flex:1;overflow:auto;padding:16px 20px 20px}.learning-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.learning-row{appearance:none;width:100%;background:var(--color-surface-input);border:1px solid var(--color-border-subtle);color:var(--text);border-radius:14px;padding:12px 14px;text-align:left;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:12px;transition:background .12s ease,border-color .12s ease}.learning-row:hover{background:var(--color-surface-input-hover, rgba(255, 255, 255, .06))}.learning-row.is-selected{border-color:var(--color-border-strong, rgba(255, 255, 255, .22))}.learning-row-text{display:flex;flex-direction:column;gap:2px}.learning-row-title{font-weight:500}.learning-row-subtitle{color:var(--color-text-muted, rgba(255, 255, 255, .6));font-size:.85em}.learning-row-check,.learning-row-chevron{opacity:.7}.learning-row.is-current{border-color:var(--color-border-strong, rgba(255, 255, 255, .32))}.learning-row.is-completed .learning-row-title{opacity:.7}.learning-custom{display:flex;flex-direction:column;gap:14px}.learning-custom-header{display:flex;align-items:center;justify-content:space-between}.learning-custom-back{appearance:none;background:transparent;border:none;color:var(--text);font:inherit;cursor:pointer;padding:4px 8px;border-radius:8px}.learning-custom-back:hover{background:var(--color-surface-input-hover, rgba(255, 255, 255, .06))}.learning-custom-count{color:var(--color-text-muted, rgba(255, 255, 255, .6));font-size:.85em}.learning-custom-grid{display:grid;grid-template-columns:repeat(6,minmax(40px,1fr));gap:8px}.learning-chip{appearance:none;background:var(--color-surface-input);border:1px solid var(--color-border-subtle);color:var(--text);font-family:inherit;font-size:1rem;height:44px;border-radius:12px;cursor:pointer;transition:background .12s ease,border-color .12s ease}.learning-chip:hover{background:var(--color-surface-input-hover, rgba(255, 255, 255, .06))}.learning-chip.is-on{background:var(--color-surface-panel-strong);border-color:var(--color-border-strong, rgba(255, 255, 255, .32))}.learning-custom-apply{align-self:stretch}.learning-custom-apply:disabled{opacity:.5;cursor:not-allowed}.sign-in-sheet{width:min(420px,100%)}.sign-in-body{padding:16px 20px 20px;display:flex;flex-direction:column;gap:14px}.sign-in-providers{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.sign-in-provider{appearance:none;width:100%;background:var(--color-surface-input);border:1px solid var(--color-border-subtle);color:var(--text);font:inherit;border-radius:12px;padding:12px 14px;text-align:left;cursor:pointer;transition:background .12s ease,border-color .12s ease}.sign-in-provider:hover:not(:disabled){background:var(--color-surface-input-hover, rgba(255, 255, 255, .06))}.sign-in-provider:disabled{opacity:.5;cursor:not-allowed}.sign-in-form{display:flex;flex-direction:column;gap:12px}.sign-in-field{display:flex;flex-direction:column;gap:4px}.sign-in-field span{font-size:.85em;color:var(--color-text-muted, rgba(255, 255, 255, .6))}.sign-in-field input{appearance:none;background:var(--color-surface-input);border:1px solid var(--color-border-subtle);color:var(--text);border-radius:10px;padding:10px 12px;font:inherit}.sign-in-error{color:var(--error, #ff5a60);font-size:.9em}.sign-in-secondary{appearance:none;background:transparent;border:none;color:var(--color-text-muted, rgba(255, 255, 255, .7));font:inherit;cursor:pointer;text-decoration:underline;align-self:center;padding:4px 8px}.sign-in-secondary:disabled{opacity:.5;cursor:not-allowed;text-decoration:none}.sign-in-back{appearance:none;background:transparent;border:none;color:var(--text);font:inherit;font-size:1.1rem;cursor:pointer;padding:0 8px}.auth-button-destructive{color:var(--error, #ff5a60);border-color:var(--color-border-error, rgba(255, 90, 96, .4))}.auth-button-destructive:hover:not(:disabled){border-color:var(--color-border-error-strong, rgba(255, 90, 96, .7))}.reference-streak.is-at-risk{border:1px solid var(--color-border-error, rgba(255, 90, 96, .4));background:#ff5a600f}.reference-card-button{appearance:none;font:inherit;text-align:left;cursor:pointer;touch-action:manipulation}.reference-card-button:hover{background:linear-gradient(0deg,rgba(var(--score-tint, 0, 0, 0),var(--score-alpha, 0)),rgba(var(--score-tint, 0, 0, 0),var(--score-alpha, 0))),var(--color-surface-input-hover, rgba(255, 255, 255, .08))}.reference-card-button:focus-visible{outline:2px solid var(--color-border-strong, rgba(255, 255, 255, .5));outline-offset:2px}.welcome-options{position:absolute;bottom:72px;left:0;right:0;display:flex;flex-direction:column;align-items:center;gap:14px;opacity:0;pointer-events:none;transition:opacity .6s ease}.welcome-options.is-visible{opacity:1;pointer-events:auto}.welcome-option-button{appearance:none;background:transparent;border:0;font:inherit;letter-spacing:.2px;padding:6px 12px;cursor:pointer;transition:opacity .12s ease}.welcome-option-primary{color:#e6f0fff2;font-size:15px;font-weight:500}.welcome-option-secondary{color:#c8d2dc80;font-size:13px;font-weight:400}.welcome-option-button:hover,.welcome-option-button:focus-visible{opacity:.8}.welcome-option-secondary:hover,.welcome-option-secondary:focus-visible{opacity:1;color:#c8d2dcbf}.tour-overlay{position:fixed;inset:0;background:transparent;z-index:30;cursor:pointer}.tour-spotlight{position:fixed;border-radius:14px;background:transparent;pointer-events:none;box-shadow:0 0 0 2px var(--color-accent-wave, hsl(154, 88%, 58%)),0 0 0 6px #36f2a040,0 8px 24px #00000059;transition:top .2s ease,left .2s ease,width .2s ease,height .2s ease}.tour-callout{position:fixed;background:var(--color-surface-panel-strong);border:1px solid var(--color-border-subtle);border-radius:16px;padding:16px 18px;color:var(--text);pointer-events:none;box-shadow:0 12px 32px #00000073;max-width:calc(100vw - 32px)}.tour-callout-title{font-size:1rem;font-weight:600;margin-bottom:6px}.tour-callout-body{font-size:.9rem;line-height:1.4;color:var(--color-text-muted, rgba(255, 255, 255, .8));margin-bottom:12px}.tour-callout-meta{display:flex;align-items:center;justify-content:space-between}.tour-dots{display:flex;gap:6px}.tour-dot{width:6px;height:6px;border-radius:50%;background:#ffffff40}.tour-dot.is-active{background:#ffffffd9}.tour-callout-cta{font-size:.85em;color:var(--color-text-muted, rgba(255, 255, 255, .7))}.app-footer{width:100%;display:flex;flex-direction:row;justify-content:center;align-items:center;gap:14px;padding:clamp(16px,4vw,24px);font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:#ffffff73;margin-top:auto}.app-footer a{color:inherit;text-decoration:none;border-bottom:1px solid transparent;transition:color var(--timing-snap) var(--ease-out),border-color var(--timing-snap) var(--ease-out)}.app-footer a:hover{color:#ffffffbf;border-color:#ffffff59}.app-footer a:focus-visible{outline:2px solid rgba(255,255,255,.6);outline-offset:3px}.morse-button-wrap{width:min(480px,100%);display:grid;place-items:center}.morse-button{position:relative;width:100%;height:clamp(64px,14vw,96px);border-radius:999px;border:none;background:transparent;display:grid;place-items:center;cursor:pointer;isolation:isolate;transform:translateZ(0);overflow:visible;transition:transform .2s cubic-bezier(.4,0,.2,1),box-shadow .3s ease;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;touch-action:none;-webkit-tap-highlight-color:transparent;z-index:1}.morse-button:before{content:"";position:absolute;inset:0;border-radius:999px;padding:2px;opacity:.5;mix-blend-mode:hard-light;background:conic-gradient(from 125deg,#000000bf,#00000080 25deg,#00000059 45deg,#0000,#fff0 135deg,#fffffff2 180deg 200deg,#fff0 225deg,#0000,#00000073 315deg,#00000080 350deg,#000000bf 360deg);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;z-index:10}.fluid-container{position:absolute;inset:0;border-radius:999px;overflow:hidden;z-index:-2}.fluid-paint{position:absolute;inset:-20px;background:linear-gradient(125deg,transparent 20%,rgba(200,220,255,.85) 25%,transparent 30%),linear-gradient(65deg,transparent 35%,rgba(160,200,255,.9) 40%,transparent 50%),linear-gradient(170deg,transparent 10%,rgba(255,180,200,.85) 20%,transparent 35%),linear-gradient(95deg,transparent 50%,rgba(180,170,240,.85) 60%,transparent 70%),linear-gradient(140deg,transparent 60%,rgba(150,200,255,.9) 70%,transparent 80%),linear-gradient(45deg,transparent 15%,rgba(255,190,210,.8) 25%,transparent 40%),linear-gradient(200deg,transparent 40%,rgba(190,180,240,.85) 55%,transparent 65%),linear-gradient(135deg,#a8d0ff,#d0c0f0,#ffccd8,#b8d8ff,#f0d0e8);background-size:200% 200%;filter:url(#fluid) saturate(1.15) contrast(1.02);transition:background-size .6s cubic-bezier(.34,1.26,.64,1),filter .3s ease;animation:liquidSwirl 16s ease-in-out infinite}.morse-button.pressing .fluid-paint{background-size:120% 170%;filter:url(#fluidActive) saturate(2) contrast(1.15) brightness(1.05)}@keyframes liquidSwirl{0%,to{background-position:80% 20%;transform:scale(1.03) rotate(2deg)}14%{background-position:30% 10%;transform:scale(1.02) rotate(-2deg)}28%{background-position:10% 50%;transform:scale(1.04) rotate(1deg)}42%{background-position:25% 85%;transform:scale(1.02) rotate(-1deg)}57%{background-position:70% 90%;transform:scale(1.03) rotate(2deg)}71%{background-position:95% 60%;transform:scale(1.02) rotate(-2deg)}85%{background-position:90% 30%;transform:scale(1.04) rotate(1deg)}}.fluid-glow{position:absolute;inset:-2px;border-radius:999px;z-index:-3;pointer-events:none;background:radial-gradient(120% 140% at 15% 70%,rgba(147,197,253,.5),transparent 60%),radial-gradient(110% 120% at 85% 30%,rgba(252,165,202,.45),transparent 65%),radial-gradient(140% 140% at 55% 55%,rgba(196,181,253,.4),transparent 60%);filter:blur(8px);opacity:.55;transition:opacity .3s ease}.fluid-glass{position:absolute;inset:0;border-radius:999px;z-index:1;pointer-events:none;background:linear-gradient(160deg,rgba(255,255,255,.2) 0%,rgba(255,255,255,.08) 20%,transparent 50%,rgba(0,0,0,.05) 80%,rgba(0,0,0,.1) 100%);box-shadow:inset 0 2px 3px #ffffff40,inset 0 -2px 3px #00000026,inset 2px 0 3px #ffffff14,inset -2px 0 3px #00000014}.fluid-glass:before{content:"";position:absolute;inset:2px;border-radius:999px;border:1px solid rgba(255,255,255,.08);pointer-events:none}.fluid-glass:after{content:"";position:absolute;top:4px;left:10%;right:10%;height:30%;border-radius:999px;background:linear-gradient(180deg,rgba(255,255,255,.12),transparent);filter:blur(2px);pointer-events:none}.morse-button:hover .fluid-glow{opacity:.8}.morse-button.pressing{transform:scale(.98);box-shadow:inset 0 2px 4px #0003,inset 0 -1px 1px #ffffff1a,0 0 0 1px #0000004d,0 2px 8px #0003}.morse-button.pressing .fluid-glow{opacity:1}.morse-button,.morse-button *,.morse-button *:before,.morse-button *:after{-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.morse-button:focus-visible{outline:2px solid rgba(255,255,255,.4);outline-offset:4px}@media(prefers-reduced-motion:reduce){.fluid-paint{filter:url(#fluid) saturate(1.15) contrast(1.02)!important;animation:none!important}}@media(max-width:600px){.morse-button-wrap{margin-bottom:clamp(8px,3vw,14px)}}.page-404-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--color-surface-solid-backdrop);color:var(--color-text-primary);font-family:inherit;position:relative;overflow:hidden;padding:clamp(20px,5vw,48px)}.page-404-content{max-width:600px;text-align:center;position:relative;z-index:2;flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center}.page-404-title{margin-bottom:2rem;opacity:0}.morse-404{font-size:clamp(1.5rem,4vw,2rem);font-family:inherit;letter-spacing:.3em;color:var(--color-accent-wave);text-shadow:0 0 20px hsla(24,100%,65%,.3);display:block;margin-bottom:.5rem;animation:pulse var(--timing-breath) var(--ease-in-out) infinite}.morse-404 .space{margin:0 .5em}.error-code{font-size:clamp(5rem,15vw,8rem);font-weight:700;font-family:inherit;margin:0;text-shadow:0 0 40px hsla(24,100%,65%,.3);background:linear-gradient(135deg,var(--color-accent-wave),var(--color-feedback-success));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:glitch var(--timing-breath) var(--ease-in-out) infinite}.page-404-message{margin-bottom:3rem;opacity:0}.page-404-message h2{font-size:clamp(1.5rem,4vw,2rem);margin-bottom:1rem;font-family:inherit;font-weight:400;letter-spacing:.02em}.page-404-message p{font-size:clamp(1rem,3vw,1.2rem);margin-bottom:.5rem;color:#ffffffe0;min-height:1.5em;line-height:1.5}.page-404-message .subtitle{font-size:clamp(.9rem,2.5vw,1rem);color:var(--color-text-primary-60)}.home-button{background:#ffffff0f;border:1px solid rgba(255,255,255,.2);color:#ffffffbf;padding:clamp(12px,2.5vw,16px) clamp(24px,5vw,32px);font-size:.75rem;border-radius:999px;cursor:pointer;transition:all var(--timing-snap) var(--ease-out);display:inline-flex;align-items:center;gap:clamp(.8rem,2vw,1rem);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);opacity:0;font-weight:500;letter-spacing:.15em;text-transform:uppercase}.home-button:hover{background:#ffffff1f;border-color:#ffffff59;color:var(--color-text-primary);transform:translateY(-2px)}.home-button:active{transform:translateY(0)}.home-button:focus-visible{outline:2px solid rgba(255,255,255,.6);outline-offset:4px}.button-text{font-weight:600;letter-spacing:.15em}@keyframes fade-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fade-in var(--timing-connector) var(--ease-out) forwards}.fade-in-delayed{animation:fade-in var(--timing-connector) var(--ease-out) var(--timing-medium) forwards}.fade-in-more-delayed{animation:fade-in var(--timing-connector) var(--ease-out) var(--timing-connector) forwards}.fade-in-last{animation:fade-in var(--timing-connector) var(--ease-out) var(--timing-ripple) forwards}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes glitch{0%,90%,to{transform:translate(0)}92%{transform:translate(-2px,2px)}94%{transform:translate(2px,-2px)}96%{transform:translate(-2px,-2px)}98%{transform:translate(2px,2px)}}@media(max-width:768px){.page-404-content{padding:clamp(20px,5vw,32px)}.error-code{font-size:clamp(4rem,12vw,5rem)}.morse-404{font-size:clamp(1.2rem,3.5vw,1.5rem)}.page-404-message h2{font-size:clamp(1.5rem,4vw,2rem)}.page-404-message p{font-size:clamp(.9rem,2.5vw,1rem)}.home-button{padding:10px 20px;font-size:.7rem;flex-wrap:wrap;justify-content:center}}:root{--hue-primary: 24;--hue-liquid: 207;--hue-success: 154;--hue-error: 0;--color-text-primary: hsl(24, 29%, 97%);--color-text-primary-90: hsla(24, 29%, 97%, .9);--color-text-primary-80: hsla(24, 29%, 97%, .8);--color-text-primary-70: hsla(24, 29%, 97%, .7);--color-text-primary-60: hsla(24, 29%, 97%, .6);--color-text-primary-40: hsla(24, 29%, 97%, .4);--color-text-primary-20: hsla(24, 29%, 97%, .2);--color-accent-wave: hsl(24, 100%, 65%);--color-border-subtle: hsla(0, 0%, 100%, .12);--color-border-hover: hsla(0, 0%, 100%, .25);--color-border-error: hsla(0, 100%, 71%, .4);--color-border-error-strong: hsla(0, 100%, 71%, .6);--color-surface-solid-backdrop: hsla(207, 40%, 4%, 1);--color-surface-backdrop: hsla(207, 40%, 4%, .72);--color-surface-backdrop-soft: hsla(207, 40%, 4%, .35);--color-surface-panel: hsla(0, 0%, 0%, .4);--color-surface-panel-strong: hsla(207, 33%, 7%, .92);--color-surface-input: hsla(0, 0%, 100%, .06);--color-surface-input-pressed: hsla(0, 0%, 100%, .12);--color-surface-card: hsla(209, 34%, 12%, .45);--color-surface-header-gradient: linear-gradient( 0deg, transparent, hsla(0, 0%, 0%, .26), hsla(0, 0%, 0%, .9), hsla(0, 0%, 0%, .9) );--color-feedback-success: hsl(154, 88%, 58%);--color-feedback-error: hsl(0, 100%, 71%);--color-shadow-base: hsl(0, 0%, 0%);--color-shadow-text: hsla(0, 0%, 0%, .55);--color-controls-switch-track-off: hsla(0, 0%, 100%, .15);--color-controls-switch-thumb-on: hsl(24, 29%, 7%);--color-controls-picker-tint: hsla(0, 0%, 0%, .1);--space-xs: 4px;--space-sm: 8px;--space-md: 12px;--space-lg: 16px;--space-xl: 24px;--radius-sm: 10px;--radius-md: 14px;--radius-lg: 20px;--radius-pill: 999px;--radius-icon-circle: 36px;--timing-press: .12s;--timing-snap: .16s;--timing-standard: .24s;--timing-medium: .32s;--timing-exit: .14s;--timing-morph: .52s;--timing-wash: .32s;--timing-breath: 3s;--timing-ripple: 1.2s;--timing-circle-draw: .5s;--timing-connector: .7s;--ease-out: cubic-bezier(.23, 1, .32, 1);--ease-in-out: cubic-bezier(.77, 0, .175, 1);--ease-drawer: cubic-bezier(.32, .72, 0, 1)}html{height:var(--app-height, 100dvh);overflow:hidden;overscroll-behavior:none}:root{font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,SF Pro Display,system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--text: var(--color-text-primary);--muted: var(--color-text-primary-60);--accent: var(--color-accent-wave);--error: var(--color-feedback-error)}*,*:before,*:after{box-sizing:border-box}body{margin:0;position:fixed;inset:0;width:100%;height:var(--app-height, 100dvh);overflow:hidden;overscroll-behavior:none;background:var(--color-surface-solid-backdrop);color:var(--text);-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}#root{height:100%;width:100%;overflow:hidden;position:relative}button{font-family:inherit;color:inherit;border:none;background:none;padding:0}
