:root{color-scheme:dark;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#101318;color:#f7f1df;--bg: #101318;--surface: #1c222b;--surface-2: #232b35;--line: rgba(247, 241, 223, .1);--text: #f7f1df;--muted: #aeb7bd;--dim: #77838c;--amber: #f5b84b;--teal: #43d8bd;--rose: #f0647f;--green: #91e46c;--shadow: 0 20px 60px rgba(0, 0, 0, .28)}*{box-sizing:border-box}body{min-width:320px;margin:0;background:radial-gradient(circle at 22% 12%,rgba(245,184,75,.1),transparent 28rem),radial-gradient(circle at 88% 18%,rgba(67,216,189,.08),transparent 24rem),linear-gradient(145deg,#101318,#111820,#0d1116)}button,select,input{font:inherit}button{color:inherit}h1,h2,p{margin:0}.icon{width:18px;height:18px;fill:currentColor;flex:0 0 auto}.app-shell{min-height:100vh;padding:18px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;max-width:760px;margin:0 auto 18px}.brand{display:inline-flex;align-items:center;gap:12px;padding:6px 10px 6px 6px;border:1px solid var(--line);border-radius:10px;background:#1c222b9e;cursor:pointer;text-align:left}.brand-mark{display:grid;width:40px;height:40px;place-items:center;border-radius:50%;background:radial-gradient(circle,#f7f1df 0 23%,transparent 24%),conic-gradient(from 320deg,var(--amber),var(--teal),var(--rose),var(--amber));color:#101318;font-size:13px;font-weight:900}.brand strong{display:block;font-size:18px;line-height:1.05}.brand small{display:block;margin-top:2px;color:var(--muted);font-size:12px;text-transform:capitalize}.nav-tabs{display:flex;gap:6px;padding:4px;border:1px solid var(--line);border-radius:10px;background:#10131894}.nav-tab{display:inline-flex;align-items:center;gap:7px;min-height:40px;padding:0 12px;border:1px solid transparent;border-radius:8px;background:transparent;color:var(--muted);font-size:13px;font-weight:700;cursor:pointer}.nav-tab.active{background:#f7f1df;color:#111820}.workspace{max-width:760px;margin:0 auto}.panel{padding:24px;border:1px solid var(--line);border-radius:12px;background:#1c222bc7;box-shadow:var(--shadow)}.panel-heading{margin-bottom:20px}h1{color:var(--text);font-size:clamp(26px,5vw,40px);line-height:1.02}.panel-heading p,.small-note{margin-top:8px;color:var(--muted);font-size:15px;line-height:1.5}.focus-row,.action-row{display:flex;flex-wrap:wrap;gap:10px}.focus-row{margin-bottom:20px}.segmented{min-height:42px;padding:0 16px;border:1px solid var(--line);border-radius:8px;background:#151a21;color:var(--muted);font-size:13px;font-weight:850;text-transform:capitalize;cursor:pointer}.segmented.selected{background:#43d8bd29;border-color:#43d8bd75;color:var(--teal)}.timeline-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:20px 0}.timeline-row{display:grid;grid-template-columns:34px minmax(0,1fr);align-items:center;gap:12px;padding:12px;border:1px solid var(--line);border-radius:8px;background:#1013186b}.timeline-dot{display:grid;width:34px;height:34px;place-items:center;border-radius:50%;background:#f5b84b1f;color:var(--amber);font-weight:900}.timeline-row strong{display:block;font-size:15px}.timeline-row small{display:block;margin-top:3px;color:var(--dim);font-size:12px}.primary-action,.secondary-action,.danger-action{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:50px;padding:0 18px;border:1px solid transparent;border-radius:9px;font-size:14px;font-weight:850;cursor:pointer}.primary-action{background:var(--amber);color:#15110a}.secondary-action{background:#151a21;border-color:var(--line);color:var(--text)}.danger-action{background:#f0647f21;border-color:#f0647f66;color:#ff9dad}.score-rings{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin:24px 0}.score-ring{display:grid;width:min(100%,180px);aspect-ratio:1;margin:0 auto;place-items:center;border-radius:50%;background:conic-gradient(var(--teal) var(--score),#27313b 0);box-shadow:inset 0 0 0 14px #101318eb}.score-ring strong{font-size:clamp(26px,7vw,40px);font-variant-numeric:tabular-nums}.score-ring span{color:var(--muted);font-size:12px;font-weight:850}.summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin:20px 0}.summary-grid div{padding:12px;border:1px solid var(--line);border-radius:8px;background:#1013187a}.summary-grid span{display:block;margin-bottom:6px;color:var(--dim);font-size:11px;font-weight:800;text-transform:uppercase}.summary-grid strong{font-size:20px;font-variant-numeric:tabular-nums}.history-bars{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));align-items:end;gap:10px;min-height:320px}.history-day{display:grid;grid-template-rows:22px repeat(3,1fr);gap:6px;height:300px}.history-day span{color:var(--muted);font-size:12px;text-align:center}.history-day div{position:relative;overflow:hidden;border-radius:7px;background:#151a21}.history-day i{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(180deg,var(--amber),var(--teal))}.settings-panel{display:grid;gap:18px}.settings-panel label{display:grid;gap:8px;color:var(--muted);font-size:13px;font-weight:800}.settings-panel select,.settings-panel input[type=range]{width:min(100%,420px)}.settings-panel select{min-height:44px;padding:0 12px;border:1px solid var(--line);border-radius:8px;background:#151a21;color:var(--text)}.practice-active{height:100vh;height:100dvh;min-height:0;padding:0;overflow:hidden}.task-frame{height:100%;max-width:560px;margin:0 auto;display:grid;grid-template-rows:auto auto auto minmax(0,1fr) auto auto;padding:max(8px,env(safe-area-inset-top)) 14px max(10px,env(safe-area-inset-bottom));overflow:hidden}.tf-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:6px 0}.tf-exit{display:inline-flex;align-items:center;gap:2px;min-height:34px;padding:0 8px 0 4px;border:1px solid var(--line);border-radius:8px;background:#10131899;color:var(--muted);font-size:13px;font-weight:700;cursor:pointer}.tf-step{color:var(--muted);font-size:13px;font-weight:850}.tf-time{color:var(--amber);font-size:15px;font-weight:850;font-variant-numeric:tabular-nums}.tf-progress{height:4px;margin:2px 0 8px;overflow:hidden;border-radius:999px;background:#2a333d}.tf-progress i{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--amber),var(--teal));transition:width .4s linear}.tf-title{padding-bottom:8px}.tf-title h1{font-size:clamp(22px,6vw,30px);line-height:1.05}.tf-title p{margin-top:4px;color:var(--muted);font-size:14px;line-height:1.35}.tf-body{min-height:0;display:flex;flex-direction:column;overflow:hidden}.tf-feedback{display:flex;align-items:center;min-height:40px;padding:6px 2px;color:var(--text);font-size:14px;font-weight:700;line-height:1.3}.tf-actions{display:grid;grid-template-columns:auto 1fr;gap:10px;padding-top:8px}.tf-actions:only-child,.task-frame .tf-actions>.tf-primary:only-child{grid-column:1 / -1}.tf-secondary,.tf-primary{min-height:54px;border:1px solid transparent;border-radius:10px;font-size:15px;font-weight:850;cursor:pointer}.tf-secondary{padding:0 16px;background:#151a21;border-color:var(--line);color:var(--text)}.tf-primary{padding:0 20px;background:var(--amber);color:#15110a}.tf-primary:disabled{opacity:.5;cursor:default}.tf-secondary:disabled{opacity:.5;cursor:default}.intro-card{flex:1 1 auto;min-height:0;display:flex;flex-direction:column;justify-content:center;gap:12px;padding:8px 2px}.intro-flag{align-self:flex-start;padding:3px 10px;border-radius:999px;background:#43d8bd29;color:var(--teal);font-size:11px;font-weight:900;letter-spacing:.06em;text-transform:uppercase}.intro-control{color:var(--amber);font-size:15px;font-weight:800}.intro-blurb{color:var(--text);font-size:17px;line-height:1.5}.intro-strip{margin-top:6px}.tap-body{flex:1 1 auto;min-height:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px}.tap-pad{position:relative;display:grid;flex:0 1 auto;aspect-ratio:1;width:auto;height:auto;max-width:min(78vw,300px);max-height:min(42vh,300px);min-height:120px;place-items:center;overflow:hidden;border:1px solid rgba(245,184,75,.24);border-radius:50%;background:radial-gradient(circle,rgba(245,184,75,.18),transparent 39%),radial-gradient(circle,rgba(67,216,189,.09),transparent 66%),#141920;color:var(--text);box-shadow:inset 0 0 0 12px #f7f1df06,0 18px 40px #0000004d;cursor:pointer}.tap-pad.tone-listen{border-color:#43d8bd4d;background:radial-gradient(circle,rgba(67,216,189,.14),transparent 44%),#141920}.tap-pad:active{transform:scale(.99)}.tap-pad strong{position:relative;z-index:2;font-size:clamp(26px,8vw,46px);line-height:.95}.tap-pad small{position:relative;z-index:2;max-width:80%;margin-top:4px;color:var(--muted);font-size:13px;line-height:1.3;text-align:center}.disabled-pad{cursor:default;opacity:.78}.disabled-pad:active{transform:none}.tap-flash{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;border-radius:50%;pointer-events:none;animation:tap-flash .36s ease-out forwards}.tap-flash.tight{box-shadow:inset 0 0 0 5px var(--green),inset 0 0 36px #91e46c8c}.tap-flash.close{box-shadow:inset 0 0 0 5px var(--amber),inset 0 0 36px #f5b84b80}.tap-flash.off{box-shadow:inset 0 0 0 5px var(--rose),inset 0 0 36px #f0647f80}@keyframes tap-flash{0%{opacity:.95;transform:scale(.97)}to{opacity:0;transform:scale(1.03)}}.last-tap{color:var(--muted);font-size:13px;text-align:center}.count-in{display:grid;place-items:center;gap:8px}.count-in span{color:var(--teal);font-size:12px;font-weight:900;letter-spacing:.14em;text-transform:uppercase}.count-in strong{font-size:clamp(72px,26vw,130px);line-height:.9;color:var(--amber);font-variant-numeric:tabular-nums}.beat-strip{display:grid;grid-auto-flow:column;grid-auto-columns:1fr;gap:4px;width:100%;max-width:460px}.beat-strip i{aspect-ratio:1;max-height:26px;border:1px solid var(--line);border-radius:5px;background:#151a21}.beat-strip i.accent{border-color:#f5b84b47}.beat-strip.show-dropout i.audible{border-color:#f5b84b66;background:#f5b84b29}.beat-strip.show-dropout i.silent{border-style:dashed;border-color:#f7f1df38;background:transparent;opacity:.55}.beat-strip i.lit{border-color:transparent;background:var(--amber);opacity:1;box-shadow:0 0 18px #f5b84b99}.sub-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;width:100%;max-width:460px}.sub-beat{display:grid;gap:6px}.sub-beat-no{color:var(--dim);font-size:12px;font-weight:800;text-align:left}.sub-dots{position:relative;height:18px;border-left:2px solid rgba(245,184,75,.5)}.sub-dots i{position:absolute;top:50%;width:10px;height:10px;margin-left:-5px;border-radius:50%;transform:translateY(-50%)}.sub-dots i.on-beat{background:var(--amber)}.sub-dots i.on-sub{background:var(--teal)}.sub-next{grid-column:1 / -1;margin-top:2px;color:var(--dim);font-size:12px}.groove-lane{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;width:100%;max-width:460px}.groove-zone{padding:14px 8px;border:1px solid var(--line);border-radius:10px;background:#151a21;color:var(--muted);font-size:13px;font-weight:850;text-align:center}.groove-zone.target{border-color:var(--amber);background:#f5b84b29;color:var(--amber);box-shadow:0 0 22px #f5b84b40}.ear-body{flex:1 1 auto;min-height:0;display:flex;flex-direction:column;justify-content:center;gap:12px}.ear-play{display:grid;grid-template-columns:1fr 1fr;gap:10px}.ear-btn.span2{grid-column:1 / -1}.ear-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:50px;border:1px solid rgba(67,216,189,.4);border-radius:10px;background:#43d8bd1a;color:var(--teal);font-size:14px;font-weight:850;cursor:pointer}.ear-key{color:var(--dim);font-size:12px;text-align:center}.role-tiles{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.role-tile{display:grid;gap:2px;min-height:56px;padding:8px 10px;border:1px solid var(--line);border-radius:10px;background:#151a21;color:var(--text);text-align:left;cursor:pointer}.role-tile strong{font-size:18px}.role-tile span{color:var(--muted);font-size:12px;font-weight:700}.role-tile.idk{align-items:center;justify-content:center;color:var(--muted)}.role-tile.correct{border-color:var(--green);background:#91e46c29}.role-tile.wrong{border-color:var(--rose);background:#f0647f29}.role-tile:disabled{cursor:default}.ear-reveal{color:var(--text);font-size:14px;line-height:1.4}.response-body{flex:1 1 auto;min-height:0;display:flex;flex-direction:column;justify-content:center;gap:12px}.timeline{display:grid;grid-template-columns:70px minmax(0,1fr);align-items:center;gap:10px}.timeline-label{color:var(--dim);font-size:12px;font-weight:800}.timeline-track{position:relative;height:30px;border:1px solid var(--line);border-radius:8px;background:#10131899}.timeline-empty{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:var(--dim);font-size:11px}.dot{position:absolute;top:50%;width:14px;height:14px;margin-left:-7px;border-radius:50%;transform:translateY(-50%)}.dot.prompt{background:var(--amber)}.dot.try.pending{background:var(--muted)}.dot.try.hit{background:var(--green)}.dot.try.early,.dot.try.late{background:var(--amber)}.dot.try.missed{background:var(--rose)}.response-body .tap-pad{align-self:center;max-height:min(30vh,220px);max-width:min(60vw,220px);min-height:96px}.transfer-body{flex:1 1 auto;min-height:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px}.transfer-step{color:var(--muted);font-size:14px;font-weight:700;text-align:center}.transfer-body .tap-pad{max-height:min(34vh,240px);max-width:min(66vw,240px)}.feel-tiles{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%}.feel-tile{display:grid;gap:4px;min-height:56px;padding:10px 12px;border:1px solid var(--line);border-radius:10px;background:#151a21;color:var(--text);text-align:left;cursor:pointer}.feel-tile strong{font-size:16px}.feel-tile span{color:var(--muted);font-size:11px;font-weight:600;line-height:1.3}.feel-tile.chosen{border-color:var(--teal);background:#43d8bd1f}.feel-tile.correct{border-color:var(--green);background:#91e46c29}.feel-tile.wrong{border-color:var(--rose);background:#f0647f29}.feel-tile:disabled{cursor:default}@media(min-width:760px){.task-frame{margin:24px auto;height:calc(100dvh - 48px);border:1px solid var(--line);border-radius:18px;background:#1c222b8c;box-shadow:var(--shadow);padding:16px 22px 22px}}@media(max-height:700px){.tf-title p{font-size:13px}.last-tap,.sub-next,.ear-key{display:none}.tap-pad{max-height:min(38vh,240px)}.tf-secondary,.tf-primary{min-height:48px}}@media(max-width:520px){.timeline-list{grid-template-columns:1fr}.nav-tab span{display:none}.summary-grid{grid-template-columns:repeat(2,1fr)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}
