*,*:before,*:after{box-sizing:border-box}:root{--bg: #0d1014;--surface: #161a20;--surface-2: #1d222a;--border: #262c36;--text: #f4f4f6;--text-muted: #a1a8b3;--text-faint: #7d8694;--accent: #d4a574;--accent-hi: #e8b87f;--accent-bg: rgba(212, 165, 116, .12);--on-accent: #1a1108;--success: #4ade80;--danger: #f87171;--warning: #fbbf24;--scrim: rgba(0, 0, 0, .85);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-pill: 9999px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 24px;--space-6: 32px;--space-7: 48px;--space-8: 64px;--shadow-md: 0 4px 12px rgba(0, 0, 0, .25);--ring: 0 0 0 2px var(--accent), 0 0 0 4px var(--bg);--font-sans: "Inter Variable", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, sans-serif;--font-mono: "JetBrains Mono Variable", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace}[data-theme=light]{--bg: #faf8f5;--surface: #ffffff;--surface-2: #f1eee9;--border: #d8d1c5;--text: #1a1a1f;--text-muted: #4a5361;--text-faint: #6b7280;--accent: #8f5f2e;--accent-hi: #9c6a34;--accent-bg: rgba(143, 95, 46, .12);--on-accent: #ffffff;--success: #15803d;--danger: #dc2626;--warning: #b45309;--shadow-md: 0 4px 12px rgba(60, 50, 40, .15);--scrim: rgba(250, 248, 245, .92)}@media(prefers-color-scheme:light){:root:not([data-theme]){--bg: #faf8f5;--surface: #ffffff;--surface-2: #f1eee9;--border: #d8d1c5;--text: #1a1a1f;--text-muted: #4a5361;--text-faint: #6b7280;--accent: #8f5f2e;--accent-hi: #9c6a34;--accent-bg: rgba(143, 95, 46, .12);--on-accent: #ffffff;--success: #15803d;--danger: #dc2626;--warning: #b45309;--shadow-md: 0 4px 12px rgba(60, 50, 40, .15);--scrim: rgba(250, 248, 245, .92)}}:root{font-family:var(--font-sans);line-height:1.5;font-weight:400;color:var(--text);background-color:var(--bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:var(--accent);text-decoration:inherit}a:hover{color:var(--accent-hi)}html{overflow-x:hidden}body{margin:0;min-width:320px;min-height:100vh;overflow-x:hidden}button{font-family:inherit;cursor:pointer}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;transition:none!important}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.inline-icon{width:1.1em;height:1.1em;flex:none;vertical-align:-.15em}.piano-container{width:100%;display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-4);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);position:relative;z-index:1}.audio-notice{text-align:center;padding:var(--space-5);background:var(--accent-bg);border:1px solid var(--accent);border-radius:var(--radius-md);margin-bottom:var(--space-4)}.audio-notice p{margin:0 0 var(--space-4) 0;color:var(--accent);font-size:1.1rem;font-weight:600}.start-audio-btn{padding:var(--space-4) var(--space-6);font-size:1.2rem;font-weight:600;color:var(--on-accent);background:var(--accent);border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow-md)}.start-audio-btn:hover{background:var(--accent-hi);transform:translateY(-2px)}.start-audio-btn:active{transform:translateY(0)}.audio-status{color:var(--accent);font-weight:600;animation:fadeIn .5s ease}.octave-nav{display:flex;align-items:center;justify-content:center;gap:var(--space-3)}.octave-btn{min-width:44px;min-height:44px;padding:0 var(--space-3);border-radius:var(--radius-md);border:1px solid var(--accent);background:var(--accent-bg);color:var(--accent);font-size:1.6rem;line-height:1;font-weight:700;cursor:pointer;transition:background .2s,color .2s,opacity .2s;display:flex;align-items:center;justify-content:center}.octave-btn:hover:not(:disabled){background:var(--accent);color:var(--on-accent)}.octave-btn:disabled{opacity:.35;cursor:not-allowed}.octave-label{min-width:5.5em;text-align:center;font-family:var(--font-mono);font-weight:700;font-size:1rem;color:var(--text)}.piano-scroll{overflow-x:auto;overflow-y:hidden;padding:var(--space-5) var(--space-3);background:var(--bg);border-radius:var(--radius-md);box-shadow:inset 0 4px 12px #00000080;touch-action:pan-x}.piano-scroll.is-windowed{display:flex;justify-content:center;touch-action:none}.piano-scroll::-webkit-scrollbar{height:8px}.piano-scroll::-webkit-scrollbar-track{background:var(--surface-2);border-radius:var(--radius-sm)}.piano-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-sm)}.piano-scroll::-webkit-scrollbar-thumb:hover{background:var(--text-faint)}.piano-keyboard{display:flex;position:relative;height:200px;min-width:fit-content;padding:0 var(--space-3)}.piano-key{position:relative;cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .05s ease;border:1px solid #000;touch-action:none}.piano-key:active{transform:scale(.98)}.piano-key:focus-visible{outline:2px solid var(--accent);outline-offset:-2px;z-index:3}.piano-key.disabled{cursor:not-allowed;opacity:.5}.white-key{width:50px;height:200px;background:linear-gradient(to bottom,#fff,#f5f5f5);border-radius:0 0 5px 5px;box-shadow:0 4px 8px #0003,inset 0 -4px 8px #0000001a;z-index:1;margin-right:-1px}.white-key:hover:not(.disabled){background:linear-gradient(to bottom,#f0f0f0,#e0e0e0)}.white-key.pressed,.white-key.highlighted.pressed{background:linear-gradient(to bottom,var(--accent-hi) 0%,var(--accent) 100%)!important;box-shadow:0 0 25px color-mix(in srgb,var(--accent) 80%,transparent),inset 0 4px 8px #0000004d!important;transform:translateY(2px)!important;animation:none!important}.white-key.highlighted.priority-1{background:linear-gradient(to bottom,var(--accent-hi) 0%,var(--accent) 100%);box-shadow:0 0 30px color-mix(in srgb,var(--accent) 85%,transparent),inset 0 -4px 8px #0000001a;animation:pulse .6s ease-in-out infinite}.white-key.highlighted.priority-2{background:linear-gradient(to bottom,color-mix(in srgb,var(--accent) 45%,#ffffff),color-mix(in srgb,var(--accent) 60%,#ffffff));box-shadow:0 0 20px color-mix(in srgb,var(--accent) 55%,transparent),inset 0 -4px 8px #00000014}.white-key.highlighted.priority-3,.white-key.highlighted.priority-4,.white-key.highlighted.priority-5{background:linear-gradient(to bottom,color-mix(in srgb,var(--accent) 18%,#ffffff),color-mix(in srgb,var(--accent) 32%,#ffffff));box-shadow:0 0 15px color-mix(in srgb,var(--accent) 35%,transparent),inset 0 -4px 8px #0000000d}.black-key{width:30px;height:120px;background:linear-gradient(to bottom,#000,#1a1a1a);border-radius:0 0 3px 3px;box-shadow:0 4px 8px #00000080,inset 0 -2px 4px #ffffff1a;z-index:2;margin-left:-15px;margin-right:-15px}.black-key:hover:not(.disabled){background:linear-gradient(to bottom,#1a1a1a,#2a2a2a)}.black-key.pressed,.black-key.highlighted.pressed{background:linear-gradient(to bottom,var(--accent-hi) 0%,var(--accent) 100%)!important;box-shadow:0 0 25px color-mix(in srgb,var(--accent) 80%,transparent),inset 0 2px 6px #00000080!important;transform:translateY(2px)!important;animation:none!important}.black-key.highlighted.priority-1{background:linear-gradient(to bottom,var(--warning) 0%,color-mix(in srgb,var(--warning) 80%,#000) 100%);box-shadow:0 0 30px color-mix(in srgb,var(--warning) 85%,transparent),inset 0 -2px 4px #0003;animation:pulse .6s ease-in-out infinite}.black-key.highlighted.priority-2{background:linear-gradient(to bottom,color-mix(in srgb,var(--warning) 70%,#000) 0%,var(--warning) 100%);box-shadow:0 0 20px color-mix(in srgb,var(--warning) 60%,transparent),inset 0 -2px 4px #00000026}.black-key.highlighted.priority-3,.black-key.highlighted.priority-4,.black-key.highlighted.priority-5{background:linear-gradient(to bottom,color-mix(in srgb,var(--warning) 45%,#000),color-mix(in srgb,var(--warning) 65%,#000));box-shadow:0 0 15px color-mix(in srgb,var(--warning) 40%,transparent),inset 0 -2px 4px #0000001a}.key-label{position:absolute;bottom:8px;left:50%;transform:translate(-50%);font-size:11px;font-weight:600;color:#666;pointer-events:none}.black-key .key-label{color:#999;font-size:9px;bottom:6px}.key-feedback{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:inline-flex;align-items:center;gap:3px;padding:2px 6px;border-radius:var(--radius-sm);background:#000000c7;color:#fff;font-size:14px;font-weight:700;text-align:center;pointer-events:none;z-index:10;white-space:nowrap;animation:feedbackPop .3s ease}.black-key .key-feedback{font-size:12px}.key-feedback.perfect{color:#81c784;font-size:16px}.key-feedback.good{color:#64b5f6}.key-feedback.ok{color:#ffb74d}.key-feedback.late,.key-feedback.wrong{color:#ef9a9a}@keyframes feedbackPop{0%{transform:translate(-50%,-50%) scale(.5);opacity:0}50%{transform:translate(-50%,-50%) scale(1.1)}to{transform:translate(-50%,-50%) scale(1);opacity:1}}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.02);opacity:.9}}.piano-info{text-align:center;color:var(--text);padding:var(--space-2)}.piano-info p{margin:var(--space-1) 0;font-size:.95rem}.active-notes{color:var(--accent);font-weight:600;font-family:var(--font-mono)}@media(max-width:768px){.piano-container{padding:var(--space-3);gap:var(--space-3)}.piano-scroll{padding:var(--space-4) var(--space-1)}.piano-keyboard{height:190px;padding:0}.white-key{width:44px;height:190px}.black-key{width:30px;height:118px;margin-left:-15px;margin-right:-15px}.key-label{font-size:10px}.piano-info p{font-size:.85rem}}@media(prefers-reduced-motion:reduce){.audio-status,.key-feedback,.white-key.highlighted.priority-1,.black-key.highlighted.priority-1{animation:none}}.music-staff-container{width:100%;background:var(--surface-2);border-radius:var(--radius-md);padding:var(--space-4);border:1px solid var(--border);position:relative;z-index:1;overflow-x:auto}.music-staff{width:100%;min-height:200px;max-height:600px;overflow-y:auto;background:#fffffff2;border-radius:var(--radius-sm);padding:var(--space-2);box-shadow:inset 0 2px 8px #0000001a;box-sizing:border-box}.staff-info{text-align:center;margin-top:var(--space-2)}.staff-info p{margin:0;color:var(--accent);font-size:.85rem;font-weight:600}.music-staff svg{width:100%!important;height:auto;display:block}.music-staff-container::-webkit-scrollbar{height:6px}.music-staff-container::-webkit-scrollbar-track{background:var(--surface);border-radius:var(--radius-sm)}.music-staff-container::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--accent) 50%,transparent);border-radius:var(--radius-sm)}.music-staff-container::-webkit-scrollbar-thumb:hover{background:color-mix(in srgb,var(--accent) 70%,transparent)}@media(max-width:768px){.music-staff-container{padding:var(--space-3)}.music-staff{min-height:180px}.staff-info p{font-size:.8rem}}.song-player{background:var(--surface);border-radius:var(--radius-md);padding:var(--space-4);border:1px solid var(--border);position:relative;z-index:1}.player-header{text-align:center;margin-bottom:var(--space-3)}.header-top{display:flex;align-items:center;justify-content:center;gap:var(--space-4);margin-bottom:var(--space-2);flex-wrap:wrap}.player-header h2{margin:0;color:var(--accent);font-size:1.3rem}.mode-in-header{display:flex;align-items:center;gap:var(--space-2)}.segmented-control{display:inline-flex;gap:var(--space-1);background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-pill);padding:var(--space-1);width:fit-content}.segment{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);min-height:40px;padding:0 var(--space-4);border:none;border-radius:var(--radius-pill);background:transparent;color:var(--text-muted);font-size:.85rem;font-weight:600;line-height:1;white-space:nowrap;transition:background .12s ease,color .12s ease}.segment:hover{color:var(--text);background:var(--surface)}.segment.active{background:var(--accent);color:var(--on-accent)}.segment svg{width:1.1em;height:1.1em;flex:none}.current-song-info{display:flex;align-items:center;justify-content:center;gap:var(--space-3);flex-wrap:wrap}.current-song-info h2{margin:0;color:var(--text);font-size:1.1rem}.difficulty-badge{padding:var(--space-1) var(--space-2);border-radius:var(--radius-md);font-size:.7rem;font-weight:600;text-transform:uppercase;border:1px solid transparent}.difficulty-badge.beginner{background:color-mix(in srgb,var(--success) 15%,transparent);color:var(--success);border-color:color-mix(in srgb,var(--success) 45%,transparent)}.difficulty-badge.intermediate{background:color-mix(in srgb,var(--warning) 15%,transparent);color:var(--warning);border-color:color-mix(in srgb,var(--warning) 45%,transparent)}.difficulty-badge.advanced{background:color-mix(in srgb,var(--danger) 15%,transparent);color:var(--danger);border-color:color-mix(in srgb,var(--danger) 45%,transparent)}.difficulty-badge.custom{background:var(--accent-bg);color:var(--accent);border-color:color-mix(in srgb,var(--accent) 45%,transparent)}.song-list{text-align:center}.song-list h2,.song-list h3{color:var(--accent);margin-bottom:var(--space-3);font-size:1.1rem}.upload-section{margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--border)}.upload-section h3{color:var(--accent);margin-bottom:var(--space-4);font-size:1.1rem}.upload-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-4) var(--space-6);background:var(--accent);color:var(--on-accent);border-radius:var(--radius-md);cursor:pointer;font-weight:600;font-size:1rem;transition:all .3s ease;box-shadow:var(--shadow-md)}.upload-btn:hover{transform:translateY(-2px)}.upload-btn:focus-within{outline:2px solid var(--accent);outline-offset:2px}.difficulty-group{margin-bottom:var(--space-6)}.difficulty-heading{font-size:1rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:var(--space-3);padding-bottom:var(--space-1);border-bottom:1px solid var(--border)}.songs-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));max-width:700px;margin:0 auto;gap:var(--space-3);margin-top:var(--space-3)}.song-card{background:var(--accent-bg);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-4);cursor:pointer;transition:all .3s ease;text-align:left;color:var(--text)}.song-card:hover:not(:disabled){transform:translateY(-2px);border-color:var(--accent);box-shadow:var(--shadow-md)}.song-card:disabled{opacity:.5;cursor:not-allowed}.song-title{font-size:1rem;font-weight:600;margin-bottom:var(--space-1);color:var(--text)}.song-preview{font-size:.8rem;color:var(--text-muted);margin-bottom:var(--space-2)}.player-controls{display:flex;flex-direction:column;gap:var(--space-1)}.progress-section{width:100%}.progress-bar{width:100%;height:6px;background:var(--surface-2);border-radius:var(--radius-sm);overflow:hidden;margin-bottom:var(--space-1)}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent) 0%,var(--accent-hi) 100%);transition:width .1s linear}.time-display{display:flex;justify-content:space-between;color:var(--text-muted);font-size:.75rem;font-family:var(--font-mono)}.controls-row{display:flex;align-items:center;justify-content:center;gap:var(--space-4);flex-wrap:wrap}.main-controls{display:flex;justify-content:center;align-items:center;gap:var(--space-2)}.ready-message-inline{display:flex;align-items:center;justify-content:center;min-width:140px}.start-hint{color:var(--accent);font-size:.85rem;font-weight:600;white-space:nowrap}.reset-inline{width:44px;height:44px;border-radius:var(--radius-sm);border:none;background:var(--accent-bg);color:var(--accent);font-size:1.2rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.reset-inline:hover{background:var(--accent-bg);transform:translateY(-1px)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.control-btn{width:44px;height:44px;border-radius:var(--radius-sm);border:none;background:var(--accent-bg);color:var(--accent);font-size:1.2rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.control-btn:hover:not(:disabled){background:var(--accent-bg);transform:translateY(-1px)}.control-btn:disabled{opacity:.5;cursor:not-allowed}.control-btn svg,.play-icon-btn svg,.reset-icon-btn svg{width:1.15em;height:1.15em;flex:none}.play-btn{width:44px;height:44px;font-size:1.6rem;background:var(--accent);color:var(--on-accent);border:none;border-radius:var(--radius-md);box-shadow:var(--shadow-md)}.play-btn:hover:not(:disabled){background:var(--accent-hi);transform:translateY(-1px)}.control-group{display:flex;align-items:center;gap:var(--space-1)}.control-group label{color:var(--accent);font-weight:600;font-size:.85rem;white-space:nowrap}.control-select{padding:var(--space-2) var(--space-3);min-height:44px;border-radius:var(--radius-sm);border:1px solid var(--accent);background:var(--accent-bg);color:var(--accent);font-weight:600;font-size:.85rem;cursor:pointer;transition:all .2s ease;min-width:100px}.control-select:hover{background:var(--accent-bg);border-color:var(--accent-hi)}.control-select option{background:var(--surface);color:var(--text);padding:var(--space-2)}.back-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);min-height:44px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-2);color:var(--text);font-weight:600;font-size:.85rem;cursor:pointer;transition:all .3s ease;align-self:center}.back-btn:hover{background:var(--surface-2);border-color:var(--text-faint)}.mode-description{width:100%;text-align:center;margin-top:var(--space-1)}.mode-description p{margin:0;color:var(--text-muted);font-size:.8rem;font-style:italic}.performance-panel{background:var(--accent-bg);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-3);display:flex;flex-direction:column;gap:var(--space-2)}.performance-stats{display:flex;flex-direction:column;gap:var(--space-2)}.stat{display:flex;justify-content:space-between;align-items:center}.stat-label{color:var(--accent);font-weight:600;font-size:.85rem}.stat-value{color:var(--text);font-size:1rem;font-weight:700;font-family:var(--font-mono)}.stat-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--space-1)}.stat-mini{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-1);background:var(--surface-2);padding:var(--space-1);border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;font-family:var(--font-mono)}.stat-mini svg{width:1.1em;height:1.1em;flex:none}.stat-mini.perfect{background:color-mix(in srgb,var(--success) 15%,transparent);color:var(--success)}.stat-mini.good{background:color-mix(in srgb,#2196f3 15%,transparent);color:#2196f3}.stat-mini.ok{background:color-mix(in srgb,var(--warning) 15%,transparent);color:var(--warning)}.stat-mini.missed,.stat-mini.wrong{background:color-mix(in srgb,var(--danger) 15%,transparent);color:var(--danger)}.results-modal{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.results-content{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-6);max-width:500px;width:90%;box-shadow:var(--shadow-md);animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.results-content h2{text-align:center;color:var(--accent);margin-top:0;margin-bottom:var(--space-5);font-size:2rem}.results-summary{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);margin-bottom:var(--space-6)}.accuracy-circle{width:150px;height:150px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;border:5px solid;position:relative}.accuracy-circle.passed{border-color:var(--success);background:var(--accent-bg)}.accuracy-circle.failed{border-color:var(--danger);background:var(--accent-bg)}.accuracy-value{font-size:3rem;font-weight:700;color:var(--text)}.accuracy-label{font-size:1rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}.results-status{text-align:center}.pass-message{color:var(--success);font-size:1.3rem;font-weight:600;margin:0}.fail-message{color:var(--danger);font-size:1.1rem;margin:0}.results-breakdown{background:var(--surface-2);border-radius:var(--radius-lg);padding:var(--space-5);margin-bottom:var(--space-5)}.result-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) 0;border-bottom:1px solid var(--border)}.result-row:last-child{border-bottom:none}.result-label{color:var(--text-muted);font-size:1rem}.result-value{color:var(--text);font-size:1.2rem;font-weight:700;font-family:var(--font-mono)}.results-actions{display:flex;gap:var(--space-4);justify-content:center}.btn-primary,.btn-secondary{padding:var(--space-4) var(--space-6);border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;border:none}.btn-primary{background:var(--accent);color:var(--on-accent);box-shadow:var(--shadow-md)}.btn-primary:hover{background:var(--accent-hi);transform:translateY(-2px)}.btn-secondary{background:var(--surface-2);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--surface-2);border-color:var(--text-faint)}@media(max-width:768px){.song-player{padding:var(--space-4)}.songs-grid{grid-template-columns:1fr}.player-header h2{font-size:1.1rem}.header-top{gap:var(--space-2)}.current-song-info h2{font-size:1rem}.main-controls{gap:var(--space-2)}.control-btn{width:44px;height:44px;font-size:1.3rem}.play-btn{width:52px;height:52px;font-size:1.7rem}.controls-row{gap:var(--space-2)}.control-select{min-width:85px;font-size:.8rem;padding:var(--space-2) var(--space-2);min-height:44px}.control-group label{font-size:.8rem}.segment{padding:0 var(--space-3);font-size:.8rem}.start-hint{font-size:.75rem}.stat-grid{grid-template-columns:repeat(3,1fr)}.results-content{padding:var(--space-5)}.results-content h2{font-size:1.5rem}.accuracy-circle{width:120px;height:120px}.accuracy-value{font-size:2.5rem}.results-actions{flex-direction:column}.btn-primary,.btn-secondary{width:100%}}.count-in-overlay{position:fixed;inset:0;background:var(--scrim);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease;padding:calc(var(--space-4) + env(safe-area-inset-top,0px)) calc(var(--space-4) + env(safe-area-inset-right,0px)) calc(var(--space-4) + env(safe-area-inset-bottom,0px)) calc(var(--space-4) + env(safe-area-inset-left,0px));box-sizing:border-box}.count-in-display{text-align:center;color:var(--text);animation:pulse .5s ease-in-out infinite}.count-in-display h2{font-size:2rem;margin-bottom:var(--space-4);color:var(--accent)}.count-number{font-size:clamp(4.5rem,22vw,8rem);font-weight:700;color:var(--warning);text-shadow:0 0 20px color-mix(in srgb,var(--warning) 50%,transparent);margin:var(--space-4) 0;line-height:1}.count-in-display p{font-size:1.2rem;opacity:.8;margin-top:var(--space-4)}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@media(prefers-reduced-motion:reduce){.results-modal,.results-content,.count-in-overlay,.count-in-display{animation:none}}.metronome-indicator{position:fixed;top:calc(20px + env(safe-area-inset-top,0px));right:calc(20px + env(safe-area-inset-right,0px));display:flex;gap:var(--space-3);background:#000000b3;padding:var(--space-3) var(--space-5);border-radius:var(--radius-pill);z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.beat-dot{width:16px;height:16px;border-radius:50%;background:var(--surface-2);transition:all .1s ease}.beat-dot.downbeat{background:color-mix(in srgb,var(--warning) 40%,transparent)}.beat-dot.active{background:var(--accent);box-shadow:0 0 15px color-mix(in srgb,var(--accent) 80%,transparent);transform:scale(1.3)}.beat-dot.active.downbeat{background:var(--warning);box-shadow:0 0 15px color-mix(in srgb,var(--warning) 80%,transparent)}.count-in-btn{background:var(--accent);color:var(--on-accent);padding:var(--space-3) var(--space-5);font-size:1rem;font-weight:700;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow-md)}.count-in-btn:hover{transform:translateY(-2px);background:var(--accent-hi)}.count-in-btn:active{transform:translateY(0)}.ready-message-inline{display:flex;justify-content:center;align-items:center;gap:var(--space-3)}.start-instructions{text-align:center;padding:var(--space-4);background:var(--accent-bg);border-radius:var(--radius-md);margin:var(--space-3) 0;border:1px solid var(--accent)}.start-instructions p{margin:0;font-size:.95rem;color:var(--text);font-weight:500}.metronome-controls{display:flex;align-items:center;gap:var(--space-3)}.play-icon-btn{background:var(--accent);color:var(--on-accent);border:none;border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;transition:all .2s ease;box-shadow:var(--shadow-md)}.play-icon-btn:hover{transform:scale(1.1);background:var(--accent-hi)}.play-icon-btn:active{transform:scale(.95)}.reset-icon-btn{background:var(--warning);color:var(--bg);border:none;border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;transition:all .2s ease;box-shadow:var(--shadow-md)}.reset-icon-btn:hover{transform:scale(1.1);filter:brightness(1.1)}.reset-icon-btn:active{transform:scale(.95)}.toast-stack{position:fixed;left:50%;transform:translate(-50%);bottom:calc(var(--space-5) + env(safe-area-inset-bottom,0px));display:flex;flex-direction:column;align-items:center;gap:var(--space-2);z-index:10000}.toast{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-2) var(--space-2) var(--space-4);background:var(--surface-2);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-pill);box-shadow:var(--shadow-md);font-size:.85rem;font-weight:600;max-width:min(90vw,420px)}.toast-message{min-width:0}.toast-icon{width:1.15em;height:1.15em;flex:none;color:var(--accent)}.toast-success{border-color:var(--success)}.toast-success .toast-icon{color:var(--success)}.toast-danger{border-color:var(--danger)}.toast-danger .toast-icon{color:var(--danger)}.toast-dismiss{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;flex:none;padding:0;border:none;border-radius:50%;background:transparent;color:var(--text-muted);transition:background .12s ease,color .12s ease}.toast-dismiss:hover{background:var(--surface);color:var(--text)}.toast-dismiss svg{width:1.1em;height:1.1em}@media(prefers-reduced-motion:no-preference){.toast{animation:toastIn .2s ease}@keyframes toastIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}}.app{min-height:100vh;background:var(--bg);color:var(--text);display:flex;flex-direction:column}.app-header{position:relative;text-align:center;padding:var(--space-6) var(--space-4);background:var(--surface);border-bottom:1px solid var(--border)}.theme-toggle-btn{position:absolute;top:var(--space-3);right:calc(var(--space-3) + env(safe-area-inset-right,0px));display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;padding:0;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-muted);transition:background .2s,color .2s}.theme-toggle-btn:hover{background:var(--bg);color:var(--text)}.theme-toggle-btn svg{width:20px;height:20px}.app-title{display:flex;align-items:center;gap:var(--space-2);justify-content:center}.title-icon{width:2rem;height:2rem;flex:none;color:var(--accent)}.icon-success{color:var(--success)}.icon-danger{color:var(--danger)}.app-header h1{margin:0;font-size:2.5rem;background:linear-gradient(90deg,var(--accent) 0%,var(--accent-hi) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.app-header p{margin:var(--space-2) 0 0;font-size:1.1rem;color:var(--text-muted)}.app-main{flex:1;max-width:1100px;width:100%;margin:0 auto;padding:var(--space-6) var(--space-4);display:flex;flex-direction:column;gap:var(--space-5)}.app-stack{display:flex;flex-direction:column;gap:var(--space-5);width:100%}.controls{display:flex;justify-content:center;gap:var(--space-4);flex-wrap:wrap}.test-btn{padding:var(--space-3) var(--space-6);font-size:1rem;font-weight:600;color:var(--on-accent);background:var(--accent);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow-md)}.test-btn:hover{background:var(--accent-hi);transform:translateY(-2px)}.test-btn:active{transform:translateY(0)}.help-toggle-container{margin-top:var(--space-5);text-align:center}.help-toggle-btn{background:var(--surface-2);border:1px solid var(--border);color:var(--text-muted);padding:var(--space-2) var(--space-4);min-height:44px;border-radius:var(--radius-pill);font-size:.85rem;cursor:pointer;transition:background .2s,color .2s}.help-toggle-btn:hover{background:var(--surface);color:var(--text)}.help-content{margin-top:var(--space-4);text-align:left;background:var(--surface);border-radius:var(--radius-lg);padding:var(--space-6);border:1px solid var(--border);position:relative;z-index:1}.help-content h2{margin-top:0;color:var(--accent);font-size:1.5rem}.help-content h3{margin-top:var(--space-5);color:var(--accent-hi);font-size:1.2rem}.help-content ul{list-style:none;padding:0}.help-content li{padding:var(--space-2) 0;padding-left:var(--space-5);position:relative}.help-content li:before{content:"▸";position:absolute;left:0;color:var(--accent);font-weight:700}.tip-box{background:var(--accent-bg);border-left:4px solid var(--accent);border-radius:var(--radius-md);padding:var(--space-4) var(--space-5);margin-top:var(--space-5)}.tip-box h4{margin:0 0 var(--space-2) 0;color:var(--accent-hi);font-size:1.1rem}.tip-box p{margin:0;color:var(--text-muted);line-height:1.6}.app-footer{text-align:center;padding:var(--space-5);background:var(--surface);border-top:1px solid var(--border);color:var(--text-faint);font-size:.9rem}.challenge-code{margin-top:var(--space-4);padding:var(--space-3) var(--space-5);background:var(--accent-bg);border:1px solid var(--accent);border-radius:var(--radius-md);text-align:center}.challenge-code-label{margin:0 0 var(--space-1) 0;font-size:.85rem;color:var(--text-muted);letter-spacing:.05em;text-transform:uppercase}.challenge-code-value{display:inline-block;font-family:var(--font-mono);font-size:1.4rem;font-weight:700;color:var(--accent);letter-spacing:.15em;-webkit-user-select:all;user-select:all}@media(max-width:768px){.app-header{padding-top:calc(var(--space-3) + 44px + var(--space-2))}.app-header h1{font-size:2rem}.title-icon{width:1.6rem;height:1.6rem}.app-header p{font-size:1rem}.app-main{padding:var(--space-4) var(--space-2)}.info-section{padding:var(--space-4)}.info-section h2{font-size:1.3rem}.info-section h3{font-size:1.1rem}}
