@font-face{font-family:OpenDyslexic;font-weight:400;font-style:normal;font-display:swap;src:url(/assets/OpenDyslexic-Regular-nUhe5EwG.woff2) format("woff2")}@font-face{font-family:OpenDyslexic;font-weight:700;font-style:normal;font-display:swap;src:url(/assets/OpenDyslexic-Bold-Bnmt45Ln.woff2) format("woff2")}:root{--bg: #000000;--fg: #ffffff;--secondary: #666666;--border: #333333;--panel: #1a1a1a;--orp: #ff3b3b;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-dyslexic: "OpenDyslexic", "Inter", -apple-system, sans-serif}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--fg);font-family:var(--font-sans);font-size:16px;line-height:1.5;height:100%;overscroll-behavior:none;-webkit-text-size-adjust:100%}button,a,input[type=checkbox],input[type=radio],input[type=range],label{touch-action:manipulation;-webkit-tap-highlight-color:transparent}body[data-font=opendyslexic]{font-family:var(--font-dyslexic)}#root{height:100vh;display:flex;flex-direction:column}a{color:var(--fg);text-decoration:none}button{background:transparent;color:var(--fg);border:1px solid var(--border);padding:.5rem 1rem;font-family:inherit;font-size:inherit;cursor:pointer;border-radius:2px}button:hover{opacity:.85}button:disabled{opacity:.4;cursor:not-allowed}button.primary{background:var(--fg);color:var(--bg);border-color:var(--fg);font-weight:600}.panel{background:var(--panel);border:1px solid var(--border);padding:1rem;border-radius:4px}.secondary{color:var(--secondary)}.orp-letter{color:var(--orp)}.topbar{display:flex;align-items:center;justify-content:space-between;padding:max(.75rem,env(safe-area-inset-top)) max(1.25rem,env(safe-area-inset-right)) .75rem max(1.25rem,env(safe-area-inset-left));border-bottom:1px solid var(--border);font-size:.875rem}.topbar a{padding:.25rem .75rem}.topbar a.active{background:var(--panel);border-radius:2px}.topbar nav{display:flex;gap:.25rem}.app-main{flex:1;min-height:0;overflow:hidden;width:100%}.app-main>.dashboard,.app-main>.test-screen,.app-main>.history{padding:2rem;max-width:1200px;margin:0 auto;width:100%;height:100%;overflow-y:auto}.dashboard h2{margin-top:0}.dashboard .today-card{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}.dashboard .stat{font-size:1.5rem;font-weight:600}.dashboard .label{color:var(--secondary);font-size:.875rem}.listen{display:grid;grid-template-columns:1fr 280px;height:100%;min-height:0}.listen .left{display:flex;flex-direction:column;min-height:0;min-width:0}.listen .right{border-left:1px solid var(--border);padding:1rem;overflow-y:auto;background:var(--panel);font-size:.875rem;contain:layout paint style}.listen .text-area{flex:1;display:flex;flex-direction:column;overflow-y:auto;padding:2rem;min-height:0;contain:layout paint style}.listen .text-area>.rsvp,.listen .text-area>.subtitle{margin-top:auto;margin-bottom:auto}.listen .text-area>.block-text{margin-top:0;margin-bottom:0;flex-shrink:0}.listen .transport{padding:1rem max(1rem,env(safe-area-inset-right)) max(1rem,env(safe-area-inset-bottom)) max(1rem,env(safe-area-inset-left));display:flex;align-items:center;flex-wrap:wrap;gap:.75rem;row-gap:.5rem;contain:layout paint style}.listen .transport input[type=range]{max-width:8rem}.rsvp{display:grid;grid-template-columns:1fr auto 1fr;align-items:baseline;font-size:4.5rem;font-weight:600;letter-spacing:-.01em;-webkit-user-select:none;user-select:none;width:100%;font-variant-numeric:tabular-nums}.rsvp>span:nth-child(1){text-align:right;padding-right:.05em}.rsvp>span:nth-child(2){text-align:center}.rsvp>span:nth-child(3){text-align:left;padding-left:.05em}.block-text{max-width:720px;margin:0 auto;padding:1rem 0;font-size:1.25rem;line-height:1.7;text-align:left}.subtitle{font-size:2rem;text-align:center;max-width:900px;margin:0 auto;font-weight:500;line-height:1.5}.subtitle.guide .word.current{border-bottom:3px solid var(--orp);padding-bottom:2px}.subtitle.karaoke .word{transition:opacity .1s}.subtitle.karaoke .word.future{opacity:.4}.subtitle.karaoke .word.current{font-weight:700;font-size:1.08em}.settings-row{margin-bottom:1rem}.settings-row label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.settings-row .group-label{font-weight:600;margin-bottom:.5rem}.test-screen{max-width:800px;margin:0 auto;padding:2rem}.test-screen h2{margin-top:0}.test-screen .question{font-size:1.25rem;margin-bottom:1.5rem;line-height:1.5}.test-screen .options{display:flex;flex-direction:column;gap:.75rem}.test-screen .options label{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem;border:1px solid var(--border);border-radius:2px;cursor:pointer}.test-screen .options label.selected{border-color:var(--fg);background:var(--panel)}.test-screen .options label.correct{border-color:var(--fg)}.test-screen .options label.wrong{border-color:var(--secondary);opacity:.7}.test-screen .footer{display:flex;justify-content:space-between;margin-top:2rem}.score-big{font-size:4rem;font-weight:600;text-align:center;margin:1rem 0}.history table{width:100%;border-collapse:collapse;font-size:.875rem}.history th,.history td{text-align:left;padding:.5rem;border-bottom:1px solid var(--border)}.history th{color:var(--secondary);font-weight:500}.completion-grid{display:grid;grid-template-columns:repeat(auto-fill,28px);gap:4px;margin:1rem 0}.completion-grid .cell{width:28px;height:28px;border:1px solid var(--border);border-radius:2px;font-size:.6875rem;display:flex;align-items:center;justify-content:center}.completion-grid .cell.complete{background:var(--fg);color:var(--bg)}.completion-grid .cell.active{background:var(--panel);border-color:var(--fg)}.completion-grid .cell.overlap{background:var(--panel);border-style:dashed;border-color:var(--fg)}.listen .waveform-container{border-top:1px solid var(--border);background:var(--bg);flex-shrink:0}.waveform{position:relative;width:100%;cursor:pointer;contain:layout paint style;isolation:isolate;-webkit-user-select:none;user-select:none;touch-action:pan-y}.waveform.armed{outline:1px solid var(--fg);outline-offset:-1px}.waveform .wave-mask{position:absolute;top:0;right:0;bottom:0;left:0;-webkit-mask-image:var(--wave-mask);mask-image:var(--wave-mask);-webkit-mask-size:100% 100%;mask-size:100% 100%;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.waveform .wave-bg,.waveform .wave-fg{position:absolute;top:0;right:0;bottom:0;left:0}.waveform .wave-bg{background:var(--secondary)}.waveform .wave-fg{background:var(--fg);transform-origin:left center;transform:scaleX(0);will-change:transform}.waveform .wave-loop{position:absolute;top:0;bottom:0;background:#ffffff24;border-left:1px solid rgba(255,255,255,.55);border-right:1px solid rgba(255,255,255,.55);pointer-events:none;z-index:2}.wave-scroll{width:100%;overflow-x:auto;overflow-y:hidden;scrollbar-width:none}.wave-scroll::-webkit-scrollbar{display:none}.wave-controls{display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem;font-size:.8125rem;border-top:1px solid var(--border)}.wave-controls>.secondary{margin-right:auto}.wave-controls button{padding:.25rem .625rem;font-size:.8125rem}.wave-controls .wave-zoom{margin-left:auto;display:flex;align-items:center;gap:.5rem}.wave-controls .wave-zoom input[type=range]{width:110px}.settings-toggle{display:none;margin-left:.5rem;padding:.5rem;align-items:center;justify-content:center}.drawer-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:9}@media (max-width: 960px){.listen{grid-template-columns:1fr 240px}.listen .right{padding:.875rem;font-size:.8125rem}.listen .text-area{padding:1.5rem}.app-main>.dashboard,.app-main>.test-screen,.app-main>.history{padding:1.5rem}}@media (max-width: 640px){.listen{grid-template-columns:1fr}.listen .right{position:fixed;bottom:0;left:0;right:0;max-height:70vh;transform:translateY(100%);transition:transform .2s ease;z-index:10;border-left:none;border-top:1px solid var(--border);padding:1rem 1rem max(1rem,env(safe-area-inset-bottom)) 1rem}.listen .right.drawer-open{transform:translateY(0)}.drawer-backdrop.drawer-open{display:block}.settings-toggle{display:inline-flex}.listen .text-area{padding:1rem}.listen .transport{padding:.625rem .75rem;gap:.5rem;flex-wrap:wrap;row-gap:.5rem}.listen .transport button{min-width:2.75rem;min-height:2.75rem;padding:.5rem}.listen .transport input[type=range]{max-width:7rem}.rsvp{font-size:clamp(2rem,11vw,4.5rem);max-width:100%}.block-text{font-size:clamp(1rem,4.5vw,1.25rem)}.subtitle{font-size:clamp(1.25rem,6vw,2rem);padding:0 .5rem}.topbar{padding:.5rem .875rem}.topbar a{padding:.25rem .5rem}.dashboard .today-card{grid-template-columns:1fr}.app-main>.dashboard,.app-main>.test-screen,.app-main>.history{padding:1rem}.test-screen .question{font-size:1.125rem}.score-big{font-size:clamp(2.5rem,12vw,4rem)}}
