@import"https://fonts.googleapis.com/css2?family=Hanken+Grotesk:wght@400;500;600;700&family=Instrument+Serif:ital@0;1&family=JetBrains+Mono:wght@400;500;700&display=swap";:root{--bg: #070710;--panel: rgba(14, 14, 24, .66);--panel-solid: rgba(14, 14, 24, .92);--border: rgba(255, 255, 255, .09);--border-strong: rgba(255, 255, 255, .18);--text: #f4f1ea;--muted: #9897ad;--faint: #5d5d72;--amber: #ffb454;--cyan: #49d6ff;--green: #5dffab;--red: #ff5470;--gold: #ffd27a;--serif: "Instrument Serif", "Iowan Old Style", Georgia, serif;--ui: "Hanken Grotesk", system-ui, -apple-system, sans-serif;--mono: "JetBrains Mono", "SFMono-Regular", Menlo, monospace;color-scheme:dark}*{box-sizing:border-box}html,body,#root{margin:0;height:100%;width:100%;overflow:hidden;background:var(--bg);color:var(--text);font-family:var(--ui)}button{font-family:var(--ui);cursor:pointer;color:var(--text);border:none;background:none}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;height:4px;border-radius:4px;background:#ffffff24;outline:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:15px;height:15px;border-radius:50%;background:var(--amber);cursor:pointer;box-shadow:0 0 10px #ffb454b3}input[type=range]::-moz-range-thumb{width:15px;height:15px;border:none;border-radius:50%;background:var(--amber);cursor:pointer}.app{position:relative;height:100vh;width:100vw;overflow:hidden}.scene-layer{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0}.hud{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;pointer-events:none;display:grid;grid-template-columns:320px 1fr 300px;grid-template-rows:auto 1fr auto;gap:18px;padding:18px}.hud>*{pointer-events:auto}.panel{background:var(--panel);backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%);border:1px solid var(--border);border-radius:16px;box-shadow:0 20px 60px #00000080}.topbar{grid-column:1 / -1;grid-row:1;display:flex;align-items:center;justify-content:space-between;padding:14px 22px}.brand{display:flex;align-items:baseline;gap:14px}.brand h1{font-family:var(--serif);font-weight:400;font-size:30px;margin:0;letter-spacing:.5px;line-height:1}.brand .accent{font-style:italic;color:var(--amber)}.brand .tag{font-family:var(--mono);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--faint)}.topbar-right{display:flex;align-items:center;gap:10px}.now-playing{text-align:right}.now-playing .cat{font-family:var(--mono);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--amber)}.now-playing .name{font-family:var(--serif);font-size:20px;line-height:1.1}.pill{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:11px;letter-spacing:.5px;padding:7px 12px;border-radius:999px;border:1px solid var(--border);background:#0000004d;color:var(--muted)}.pill .dot{width:8px;height:8px;border-radius:50%;background:var(--faint)}.pill.on .dot{background:var(--green);box-shadow:0 0 8px var(--green)}.pill.warn .dot{background:var(--red)}.pill button{font-family:var(--mono);font-size:11px;color:var(--cyan)}.left-panel{grid-column:1;grid-row:2;display:flex;flex-direction:column;padding:16px;overflow:hidden}.section-title{font-family:var(--mono);font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--faint);margin:6px 2px 10px}.exercise-list{overflow-y:auto;flex:1;margin:-4px;padding:4px}.exercise-list::-webkit-scrollbar{width:6px}.exercise-list::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:6px}.cat-group{margin-bottom:14px}.cat-label{font-family:var(--mono);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--amber);opacity:.8;margin:0 2px 6px}.lesson-label{font-family:var(--mono);font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:var(--cyan);opacity:.75;margin:0 2px 5px 8px}.ex-item{width:100%;text-align:left;padding:10px 12px;border-radius:10px;border:1px solid transparent;background:#ffffff05;margin-bottom:6px;transition:all .15s ease}.ex-item:hover{background:#ffffff0f;border-color:var(--border)}.ex-item.active{background:linear-gradient(100deg,#ffb4542e,#49d6ff1a);border-color:#ffb45480}.ex-item .ex-name{font-size:14px;font-weight:600}.ex-item .ex-meta{font-family:var(--mono);font-size:10px;color:var(--muted);margin-top:2px}.import-row{margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:9px 14px;border-radius:10px;border:1px solid var(--border-strong);background:#ffffff0a;font-size:13px;font-weight:600;transition:all .15s ease}.btn:hover{background:#ffffff1a}.btn.full{width:100%}.import-error{color:var(--red);font-size:11px;margin-top:8px;font-family:var(--mono)}.score-hud{grid-column:3;grid-row:2;display:flex;flex-direction:column;padding:18px;gap:14px;align-self:start}.score-top{display:flex;align-items:center;justify-content:space-between}.grade{font-family:var(--serif);font-size:64px;line-height:.9;font-style:italic;background:linear-gradient(180deg,var(--gold),var(--amber));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.score-num{text-align:right}.score-num .val{font-family:var(--mono);font-size:38px;font-weight:700}.score-num .lbl{font-family:var(--mono);font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--faint)}.combo{font-family:var(--mono);font-size:13px;color:var(--cyan);letter-spacing:1px}.combo b{font-size:18px;color:var(--text)}.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px}.stat{background:#00000047;border:1px solid var(--border);border-radius:10px;padding:9px 11px}.stat .k{font-family:var(--mono);font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:var(--faint)}.stat .v{font-family:var(--mono);font-size:20px;font-weight:600;margin-top:2px}.stat .v.good{color:var(--green)}.stat .v.bad{color:var(--red)}.stat .v.warn{color:var(--amber)}.timing-meter{margin-top:4px}.timing-bar{position:relative;height:8px;border-radius:6px;background:linear-gradient(90deg,var(--cyan),rgba(255,255,255,.25),var(--amber));margin:8px 0 4px}.timing-needle{position:absolute;top:-3px;width:3px;height:14px;background:#fff;border-radius:3px;box-shadow:0 0 8px #fff;transform:translate(-50%);transition:left .15s ease}.timing-legend{display:flex;justify-content:space-between;font-family:var(--mono);font-size:9px;color:var(--faint);letter-spacing:1px}.progress-wrap{margin-top:auto}.transport{grid-column:1 / -1;grid-row:3;display:flex;align-items:center;gap:22px;padding:14px 22px;flex-wrap:wrap}.transport-group{display:flex;align-items:center;gap:12px}.transport-divider{width:1px;align-self:stretch;background:var(--border)}.icon-btn{width:44px;height:44px;border-radius:12px;border:1px solid var(--border-strong);background:#ffffff0a;display:grid;place-items:center;transition:all .15s ease}.icon-btn:hover{background:#ffffff1f}.icon-btn.primary{width:56px;height:56px;background:linear-gradient(150deg,var(--amber),#ff8a4c);border:none;box-shadow:0 0 24px #ff8a4c80}.icon-btn.primary svg{fill:#1a0e02}.icon-btn svg{fill:var(--text)}.icon-btn:disabled{opacity:.35;cursor:not-allowed}.tempo-display{text-align:center;min-width:92px}.tempo-display .bpm{font-family:var(--mono);font-size:30px;font-weight:700;line-height:1}.tempo-display .bpm small{font-size:12px;color:var(--muted);margin-left:4px}.tempo-display .pct{font-family:var(--mono);font-size:10px;letter-spacing:1.5px;color:var(--amber)}.speed-btns{display:flex;gap:5px}.chip{font-family:var(--mono);font-size:11px;padding:5px 9px;border-radius:8px;border:1px solid var(--border);background:#ffffff08;color:var(--muted)}.chip:hover{color:var(--text)}.chip.active{color:#1a0e02;background:var(--amber);border-color:var(--amber)}.toggle{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-family:var(--mono);letter-spacing:.5px;color:var(--muted)}.switch{width:40px;height:22px;border-radius:999px;background:#ffffff1f;position:relative;transition:background .2s ease;border:1px solid var(--border)}.switch.on{background:var(--green)}.switch .knob{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:left .2s ease}.switch.on .knob{left:20px}.slider-group{display:flex;align-items:center;gap:9px;font-family:var(--mono);font-size:11px;color:var(--muted)}.slider-group input{width:90px}.mode-switch{display:flex;border:1px solid var(--border);border-radius:10px;overflow:hidden}.mode-switch button{font-family:var(--mono);font-size:11px;letter-spacing:1px;text-transform:uppercase;padding:8px 14px;color:var(--muted)}.mode-switch button.active{background:#49d6ff2e;color:var(--cyan)}.center-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:3;pointer-events:none;display:flex;align-items:center;justify-content:center}.countin{font-family:var(--serif);font-size:180px;font-style:italic;color:var(--text);text-shadow:0 0 60px rgba(255,180,84,.6);animation:countpulse 1s ease-out}@keyframes countpulse{0%{transform:scale(1.6);opacity:0}30%{opacity:1}to{transform:scale(1);opacity:.9}}.rating-pop{position:absolute;font-family:var(--serif);font-style:italic;font-size:40px;font-weight:400;pointer-events:none;animation:ratingfloat .8s ease-out forwards;text-shadow:0 2px 20px rgba(0,0,0,.6)}@keyframes ratingfloat{0%{transform:translateY(0) scale(.8);opacity:0}20%{transform:translateY(-10px) scale(1.1);opacity:1}to{transform:translateY(-70px) scale(1);opacity:0}}.start-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:10;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;background:radial-gradient(circle at 50% 40%,#141424d9,#070710f7);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);text-align:center}.start-overlay h1{font-family:var(--serif);font-size:84px;font-weight:400;margin:0;line-height:.95}.start-overlay h1 .accent{font-style:italic;color:var(--amber)}.start-overlay p{color:var(--muted);max-width:540px;font-size:15px;line-height:1.6;margin:0 20px}.start-btn{font-family:var(--mono);font-size:15px;letter-spacing:2px;text-transform:uppercase;padding:18px 46px;border-radius:14px;background:linear-gradient(150deg,var(--amber),#ff8a4c);color:#1a0e02;font-weight:700;box-shadow:0 0 40px #ff8a4c80;transition:transform .15s ease}.start-btn:hover{transform:translateY(-2px) scale(1.02)}.start-btn:disabled{opacity:.6;cursor:wait}.start-hint{font-family:var(--mono);font-size:11px;color:var(--faint);letter-spacing:1px}.modal-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;z-index:20;display:flex;align-items:center;justify-content:center;background:#04040ab3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.modal{width:520px;max-width:92vw;padding:32px;text-align:center}.modal .big-grade{font-family:var(--serif);font-style:italic;font-size:130px;line-height:.9;background:linear-gradient(180deg,var(--gold),var(--amber));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.modal h2{font-family:var(--serif);font-weight:400;font-size:28px;margin:0 0 4px}.modal .sub{color:var(--muted);font-family:var(--mono);font-size:12px;letter-spacing:1px;margin-bottom:22px}.modal .result-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px}.modal .result-grid .stat .v{font-size:24px}.modal-actions{display:flex;gap:12px;justify-content:center}.help-tip{font-family:var(--mono);font-size:10px;color:var(--faint);letter-spacing:.5px;margin-top:10px;line-height:1.5}.kbd{display:inline-block;padding:1px 6px;border-radius:5px;border:1px solid var(--border-strong);background:#ffffff0f;font-family:var(--mono);font-size:10px;color:var(--text)}.progress-track{height:6px;border-radius:6px;background:#ffffff1a;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--cyan),var(--amber));border-radius:6px;transition:width .1s linear}@media (max-width: 1100px){.hud{grid-template-columns:280px 1fr}.score-hud{grid-column:2;grid-row:2;justify-self:end;width:280px}}
