@import "https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,400;0,14..32,500;0,14..32,600;0,14..32,700;0,14..32,800;1,14..32,400&display=swap";:root{--ink:#111827;--muted:#6b7280;--line:#e5e7eb;--paper:#f9f8f6;--card:#fff;--surface:#f4f5fb;--accent:#4361ee;--accent-dark:#3451d1;--accent-faint:#eef0fd;--green:#059669;--amber:#d97706;--red:#dc2626;--shadow-xs:0 1px 2px #0000000d;--shadow-sm:0 1px 3px #0000000a, 0 4px 12px #00000012;--shadow-md:0 2px 6px #0000000a, 0 10px 28px #00000017;--shadow-accent:0 4px 18px #4361ee59;--radius:14px;--radius-sm:8px;--radius-lg:20px;font-feature-settings:"cv02", "cv03", "cv04", "cv11";color:var(--ink);background-color:var(--paper);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,Segoe UI,system-ui,-apple-system,sans-serif}*{box-sizing:border-box}body{background:radial-gradient(ellipse 90% 55% at 8% -5%, #4361ee17 0%, transparent 58%), radial-gradient(ellipse 65% 45% at 96% 105%, #4361ee0f 0%, transparent 55%), var(--paper);min-height:100vh;margin:0}h1,h2,h3{letter-spacing:-.025em;font-weight:700;line-height:1.2}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{font:inherit}.page{z-index:1;max-width:1080px;margin:0 auto;padding:20px 24px 96px;position:relative}.page-loading{text-align:center;color:var(--muted);padding:72px 0}.error-text{color:var(--red)}.muted{color:var(--muted)}.site-header{z-index:100;pointer-events:none;padding:10px 16px 8px;position:sticky;top:0}.site-header>*{pointer-events:auto}.navbar{-webkit-backdrop-filter:blur(20px);background:#f9f8f6eb;border:1px solid #e5e7ebcc;border-radius:16px;align-items:center;gap:20px;max-width:1080px;height:52px;margin:0 auto;padding:0 18px;display:flex;box-shadow:0 4px 24px #00000012,0 1px 3px #0000000d}.navbar-brand{color:var(--ink);flex-shrink:0;align-items:center;line-height:1;display:flex}.navbar-brand:hover{opacity:.85;text-decoration:none}.navbar-brand svg{display:block}.navbar-sections{flex:1;gap:4px;display:flex}.section-pill{color:var(--muted);letter-spacing:-.01em;border-radius:20px;padding:6px 14px;font-size:.88rem;font-weight:600;transition:color .15s,background .15s}.section-pill:hover{color:var(--ink);background:#0000000d;text-decoration:none}.section-pill-active{background:var(--accent);box-shadow:0 2px 8px #4361ee47;color:#fff!important}.section-pill-active:hover{background:var(--accent-dark);color:#fff}.navbar-user{flex-shrink:0;align-items:center;gap:8px;display:flex}.navbar-user a{color:var(--muted);border-radius:var(--radius-sm);padding:6px 10px;font-size:.88rem;font-weight:500;transition:color .15s,background .15s}.navbar-user a:hover{color:var(--ink);background:#0000000a;text-decoration:none}.navbar-user .link-button{font-size:.88rem}.navbar-username{color:var(--ink);padding:0 4px;font-size:.88rem;font-weight:600;text-decoration:none;transition:color .15s}.navbar-username:hover{color:var(--accent);text-decoration:none}.navbar-hamburger{cursor:pointer;background:0 0;border:none;border-radius:8px;flex-direction:column;flex-shrink:0;justify-content:center;gap:5px;width:36px;height:36px;padding:6px;transition:background .15s;display:none}.navbar-hamburger:hover{background:#0000000d}.navbar-hamburger span{background:var(--ink);transform-origin:50%;border-radius:2px;flex-shrink:0;width:100%;height:2px;transition:transform .22s,opacity .22s;display:block}.navbar-hamburger.open span:first-child{transform:translateY(7px)rotate(45deg)}.navbar-hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}.navbar-hamburger.open span:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.navbar-mobile-menu{-webkit-backdrop-filter:blur(20px);background:#f9f8f6f7;border:1px solid #e5e7ebcc;border-radius:14px;max-width:1080px;margin:6px auto 0;padding:12px 16px 16px;display:none;box-shadow:0 8px 32px #0000001a}.mobile-nav-links{flex-direction:column;gap:2px;margin-bottom:12px;display:flex}.mobile-nav-link{color:var(--ink);border-radius:10px;padding:10px 12px;font-size:1rem;font-weight:600;transition:background .13s;display:block}.mobile-nav-link:hover{background:#0000000d;text-decoration:none}.mobile-nav-link.active{color:var(--accent)}.mobile-nav-sub{opacity:0;border-left:2px solid #00000014;flex-direction:column;gap:1px;max-height:0;margin:0 0 0 12px;padding-left:12px;transition:max-height .3s,opacity .2s,margin .3s;display:flex;overflow:hidden}.mobile-nav-sub.open{opacity:1;max-height:300px;margin-top:2px;margin-bottom:4px}.mobile-nav-link.sub{color:var(--muted);padding:7px 10px;font-size:.9rem;font-weight:500}.mobile-nav-link.sub.active{color:var(--accent);font-weight:600}.mobile-nav-user{border-top:1px solid #00000012;flex-wrap:wrap;align-items:center;gap:10px;padding-top:12px;display:flex}.subnav{-webkit-backdrop-filter:blur(20px);background:#f9f8f6eb;border:1px solid #e5e7ebcc;border-radius:16px;max-width:1080px;margin:6px auto 0;box-shadow:0 4px 24px #00000012,0 1px 3px #0000000d}.subnav-inner{gap:2px;padding:0 18px;display:flex}.subnav-link{color:var(--muted);border-bottom:2px solid #0000;padding:8px 12px;font-size:.875rem;font-weight:500;transition:color .15s,border-color .15s;display:inline-block}.subnav-link:hover{color:var(--ink);text-decoration:none}.subnav-link.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.subnav-welcome-btn{color:var(--muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:8px;margin-left:auto;padding:8px 12px;font-size:.8rem;font-weight:500;transition:color .15s,background .15s}.subnav-welcome-btn:hover{color:var(--accent);background:var(--accent-faint)}.mobile-nav-link.subnav-welcome-btn{text-align:left;width:100%;color:var(--accent);margin-top:4px;font-size:.875rem;font-weight:500}@media (width<=640px){.site-header{padding:8px 10px 0}.navbar{border-radius:14px;gap:12px;height:50px;padding:0 14px}.navbar-sections,.navbar-user{display:none}.navbar-hamburger{margin-left:auto;display:flex}.navbar-mobile-menu{display:block}.subnav{display:none}}.button-primary,.button-secondary,.button-danger{border-radius:var(--radius-sm);cursor:pointer;letter-spacing:-.01em;border:none;padding:10px 20px;font-size:.92rem;font-weight:600;transition:transform .15s,box-shadow .15s,opacity .15s;display:inline-block}.button-primary{background:linear-gradient(135deg, var(--accent) 0%, var(--accent-dark) 100%);color:#fff;box-shadow:0 2px 8px #4361ee47,0 1px 2px #4361ee26}.button-primary:hover{box-shadow:var(--shadow-accent);text-decoration:none;transform:translateY(-1px)}.button-primary:active{transform:translateY(0);box-shadow:0 1px 4px #4361ee33}.button-primary:disabled,.button-secondary:disabled{opacity:.45;cursor:not-allowed;box-shadow:none;transform:none}.button-secondary{background:var(--card);color:var(--ink);border:1px solid var(--line);box-shadow:var(--shadow-xs)}.button-secondary:hover{background:var(--surface);box-shadow:var(--shadow-sm);border-color:#d1d5db;text-decoration:none;transform:translateY(-1px)}.button-secondary:active{transform:translateY(0)}.button-danger{color:var(--red);background:#fef2f2;border:1px solid #fecaca}.button-danger:hover{background:#fee2e2;transform:translateY(-1px)}.button-danger:active{transform:translateY(0)}.button-primary.small,.button-secondary.small{padding:7px 14px;font-size:.875rem}.button-primary.block,.button-secondary.block{text-align:center;width:100%;padding:14px 20px;font-size:1rem;display:block}.link-button{color:var(--accent);cursor:pointer;font-weight:500;font-size:inherit;background:0 0;border:none;padding:0;transition:opacity .15s}.link-button:hover{opacity:.75;text-decoration:underline}.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid #e5e7eb99;padding:24px}.auth-card{max-width:400px;margin:56px auto}.auth-card h1{margin-top:0}.form-field{flex-direction:column;gap:6px;margin-bottom:18px;display:flex}.form-field label{color:var(--ink);font-size:.875rem;font-weight:600}.form-field input,.form-field select,.form-field textarea{border:1.5px solid var(--line);border-radius:var(--radius-sm);font:inherit;background:var(--card);outline:none;padding:10px 13px;font-size:.95rem;transition:border-color .15s,box-shadow .15s}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #4361ee1f}.form-field textarea{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.85rem}.form-error{color:var(--red);margin:8px 0;font-size:.9rem}.form-row{gap:14px;display:flex}.form-row .form-field{flex:1}.mission-section{max-width:680px;padding:52px 0 40px}.mission-logo{color:var(--ink);margin-bottom:28px;display:block}.mission-text{color:var(--ink);opacity:.88;margin:0;font-size:1.12rem;font-style:italic;line-height:1.75}.section-chooser{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-bottom:52px;display:grid}.section-card{border-radius:var(--radius-lg);color:var(--ink);align-items:flex-start;gap:20px;padding:28px 26px;text-decoration:none;transition:transform .18s,box-shadow .18s;display:flex}.section-card:hover{text-decoration:none;transform:translateY(-3px)}.section-card-rhythm{background:linear-gradient(135deg,#eef2ff 0%,#e0e7ff 100%);border:1.5px solid #4361ee2e;box-shadow:0 4px 16px #4361ee1a}.section-card-rhythm:hover{border-color:#4361ee59;box-shadow:0 8px 28px #4361ee33}.section-card-theory{background:linear-gradient(135deg,#f5f3ff 0%,#ede9fe 100%);border:1.5px solid #7c3aed2e;box-shadow:0 4px 16px #7c3aed1a}.section-card-theory:hover{border-color:#7c3aed59;box-shadow:0 8px 28px #7c3aed33}.section-card-icon{background:#ffffffb3;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;margin-top:2px;font-size:2.2rem;line-height:1;display:flex}.section-card h2{margin:0 0 8px;font-size:1.25rem;font-weight:750}.section-card p{color:var(--muted);margin:0 0 14px;font-size:.92rem;line-height:1.6}.section-card-cta{color:var(--accent);font-size:.875rem;font-weight:650}.section-card-theory .section-card-cta{color:#7c3aed}.section-card-playalong{background:linear-gradient(135deg,#fff7ed 0%,#ffedd5 100%);border:1.5px solid #f9731633;box-shadow:0 4px 16px #f973161a}.section-card-playalong:hover{border-color:#f9731661;box-shadow:0 8px 28px #f9731638}.section-card-playalong .section-card-cta{color:#ea580c}.hero-section{text-align:center;padding:56px 0 32px}.hero-section h1{letter-spacing:-.04em;background:linear-gradient(135deg, var(--ink) 30%, var(--accent) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:16px;font-size:clamp(2.2rem,5vw,3.4rem);font-weight:800}.hero-section p{color:var(--muted);max-width:540px;margin:0 auto 32px;font-size:1.1rem;line-height:1.65}.hero-actions{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.feature-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin-top:48px;display:grid}.feature-grid .card{transition:transform .2s,box-shadow .2s}.feature-grid .card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.feature-grid h3{margin-top:0;font-size:1rem}.feature-grid p{color:var(--muted);margin-bottom:0;font-size:.92rem;line-height:1.6}.sample-section{margin:0 0 48px}.sample-section h2{margin:0 0 6px;font-size:1.6rem}.sample-section>.muted{margin:0 0 20px;font-size:.95rem}.sample-tabs{border-bottom:1.5px solid var(--line);gap:4px;margin-bottom:0;display:flex}.sample-tab{color:var(--muted);cursor:pointer;letter-spacing:-.01em;background:0 0;border:none;border-bottom:2.5px solid #0000;border-radius:6px 6px 0 0;margin-bottom:-1.5px;padding:10px 22px;font-size:.92rem;font-weight:600;transition:color .15s,border-color .15s}.sample-tab:hover{color:var(--ink)}.sample-tab-active{color:var(--accent);border-bottom-color:var(--accent)}.sample-panel{border:1.5px solid var(--line);border-radius:0 0 var(--radius) var(--radius);background:var(--card);box-shadow:var(--shadow-sm);border-top:none;padding:28px}.rhythm-staff{width:100%;min-width:0;margin:0}.rhythm-staff-canvas{isolation:isolate;width:100%;padding-top:18px;position:relative;overflow-x:auto}.staff-playhead{z-index:2;opacity:.5;pointer-events:none;background:#f97316;border-radius:1px;width:2px;position:absolute;top:0;bottom:0;transform:translate(-1px)}.rhythm-staff figcaption{color:var(--muted);margin-top:4px;font-size:.875rem}.note-dot{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:14px;height:14px;font-size:9px;line-height:1;display:flex;position:absolute;box-shadow:0 1px 3px #00000040}.note-dot-wrong{width:18px;height:18px;box-shadow:none;color:#111;border-radius:0;font-size:13px;font-weight:900;line-height:18px}.note-dot-playing{width:16px;height:16px;animation:.3s ease-out pulse}@keyframes pulse{0%{opacity:.6;transform:scale(1.6)}to{opacity:1;transform:scale(1)}}.notation-example{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-sm);box-shadow:var(--shadow-xs);margin:18px 0;padding:12px 16px 4px}.level-group{margin-bottom:32px}.level-group h2{align-items:center;gap:10px;font-size:1.1rem;display:flex}.level-locked-tag{background:var(--surface);color:var(--muted);letter-spacing:.01em;border-radius:20px;padding:3px 10px;font-size:.75rem;font-weight:600}.exercise-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;display:grid}.exercise-card{background:var(--card);border:1.5px solid var(--line);border-radius:var(--radius);color:var(--ink);box-shadow:var(--shadow-xs);flex-direction:column;gap:8px;padding:18px;transition:transform .15s,box-shadow .15s,border-color .15s;display:flex}.exercise-card:hover{border-color:var(--accent);box-shadow:var(--shadow-sm);text-decoration:none;transform:translateY(-2px)}.exercise-card.locked{opacity:.5;pointer-events:none}.exercise-card-title{justify-content:space-between;gap:8px;font-weight:650;display:flex}.exercise-card-meta{color:var(--muted);font-size:.875rem}.passed-badge{color:var(--green)}.player-header{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:16px;display:flex}.player-header h1{margin:0 0 2px;font-size:1.3rem}.player-header .muted{margin:0;font-size:.82rem}.exercise-status{align-items:center;min-height:2.4em;margin:10px 0 4px;font-size:.95rem;display:flex}.exercise-status-row{align-items:center;gap:14px;display:flex}.text-success{color:#065f46;font-weight:500}.text-warn{color:#92400e;font-weight:500}.player-controls{flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;margin:16px 0;display:flex}.tap-progress{font-variant-numeric:tabular-nums;color:var(--muted);font-size:.9rem;font-weight:600}.metronome{flex-direction:column;flex-shrink:0;align-items:center;gap:2px;display:flex}.metronome-bpm{color:var(--muted);font-variant-numeric:tabular-nums;font-size:.75rem;font-weight:700}.metronome-pendulum{transform-box:view-box;transform-origin:50px 104px;transform:rotate(0)}.metronome-pendulum.swinging{animation-name:metronome-swing;animation-timing-function:ease-in-out;animation-iteration-count:infinite}@keyframes metronome-swing{0%{transform:rotate(-24deg)}50%{transform:rotate(24deg)}to{transform:rotate(-24deg)}}.capturing-hint{border:2px dashed var(--accent);border-radius:var(--radius);background:var(--accent-faint);align-items:center;gap:20px;margin:16px 0;padding:16px 20px;font-size:.95rem;font-weight:500;display:flex}.count-in-number{min-width:1.6em;color:var(--accent);font-variant-numeric:tabular-nums;vertical-align:middle;letter-spacing:-.04em;font-size:2rem;font-weight:800;display:inline-block}.mode-toggle{border:1.5px solid var(--line);border-radius:var(--radius);background:var(--card);box-shadow:var(--shadow-xs);flex-wrap:wrap;gap:10px;margin:18px 0 0;padding:12px 16px 16px;display:flex}.mode-toggle legend{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;padding:0 6px;font-size:.78rem;font-weight:700}.mode-toggle label{border:1.5px solid var(--line);border-radius:var(--radius-sm);cursor:pointer;align-items:center;gap:8px;padding:9px 14px;font-size:.9rem;font-weight:500;transition:border-color .15s,background .15s,color .15s;display:flex}.mode-toggle label.selected{border-color:var(--accent);background:var(--accent-faint);color:var(--accent-dark);font-weight:600}.playback-count-label{text-align:center;letter-spacing:.06em;word-spacing:.2em;-webkit-user-select:none;user-select:none;margin:2px 0;font-family:Georgia,Times New Roman,serif;font-size:1.35rem;font-style:italic}.rp-count-placeholder{color:var(--muted);letter-spacing:normal;font-family:inherit;font-size:.9rem;font-style:italic}.counting-replay-note{color:var(--muted);text-align:center;margin:4px 0 0;font-size:.78rem;font-style:italic}.modal-overlay{-webkit-backdrop-filter:blur(4px);z-index:500;background:#00000073;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal-panel{background:var(--surface,#fff);box-sizing:border-box;border-radius:20px;width:100%;max-width:640px;max-height:92vh;padding:16px 20px 20px;overflow:hidden auto;box-shadow:0 24px 80px #00000038}@media (width<=480px){.modal-overlay{padding:8px}.modal-panel{border-radius:16px;padding:14px 14px 18px}}.modal-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.modal-title{color:var(--ink);margin:0;font-size:1.25rem;font-weight:700}.modal-close{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:4px 8px;font-size:1.1rem;line-height:1;transition:background .15s,color .15s}.modal-close:hover{background:var(--line,#e5e7eb);color:var(--ink)}.rp-wrap{flex-direction:column;align-items:center;gap:4px;display:flex}.rp-status-row{flex-direction:row;align-items:center;gap:8px;display:flex}.rp-status-text{color:var(--muted);text-align:left;flex:none;width:150px;min-height:1.3em;margin:0;font-size:.85rem;line-height:1.3}.rp-staff-wrap{justify-content:center;width:100%;display:flex}.rp-staff-wrap .rhythm-staff{width:auto;max-width:100%}.rp-actions{flex-flow:wrap;justify-content:center;gap:6px;min-height:32px;display:flex}.welcome-modal-panel{max-width:680px;padding:32px 36px 36px}.welcome-modal{flex-direction:column;gap:0;display:flex}.welcome-intro{color:var(--muted);margin:0 0 24px;font-size:1rem;line-height:1.7}.welcome-sections{flex-direction:column;gap:20px;margin-bottom:28px;display:flex}.welcome-section h3{text-transform:uppercase;letter-spacing:.06em;color:var(--accent);margin:0 0 8px;font-size:.875rem;font-weight:700}.welcome-list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.welcome-list li{color:var(--ink);padding-left:20px;font-size:.9rem;line-height:1.6;position:relative}.welcome-list li:before{content:"·";color:var(--accent);font-size:1.2rem;font-weight:700;line-height:1.2;position:absolute;left:6px}.welcome-footer{border-top:1px solid var(--line);justify-content:center;padding-top:8px;display:flex}@media (width<=600px){.welcome-modal-panel{padding:20px 20px 24px}}.result-legend{color:var(--muted);flex-wrap:wrap;justify-content:center;gap:16px;margin:10px 0 0;font-size:.85rem;display:flex}.legend-swatch{border-radius:50%;width:10px;height:10px;margin-right:5px;display:inline-block}.played-back{border-top:1px solid var(--line);margin-top:24px;padding-top:16px}.stat-grid{grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;margin:22px 0;display:grid}.stat-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1.5px solid #e5e7eb99;padding:18px 20px}.stat-card .stat-value{letter-spacing:-.04em;color:var(--accent);font-size:1.9rem;font-weight:800}.stat-card .stat-label{color:var(--muted);margin-top:2px;font-size:.875rem}.concept-list{flex-wrap:wrap;gap:8px;padding:0;list-style:none;display:flex}.concept-pill{border:1.5px solid var(--line);background:var(--card);border-radius:20px;padding:5px 14px;font-size:.875rem;font-weight:500}.concept-pill.mastered{color:var(--green);background:#ecfdf5;border-color:#6ee7b7;font-weight:600}.remediation-banner{border-radius:var(--radius);background:#fffbeb;border:1.5px solid #fcd34d;margin:18px 0;padding:14px 18px;font-size:.95rem}.learn-back-bar{margin-bottom:20px}.learn-layout{grid-template-columns:220px 1fr;align-items:start;gap:40px;display:grid}.learn-toc{border-left:2px solid var(--line);flex-direction:column;gap:8px;padding-left:16px;font-size:.9rem;display:flex;position:sticky;top:80px}.learn-section{margin-bottom:52px;scroll-margin-top:80px}.learn-section h2{border-bottom:1px solid var(--line);padding-bottom:10px}.learn-section p{max-width:70ch;line-height:1.7}@media (width<=800px){.learn-layout{grid-template-columns:1fr}.learn-toc{position:static}}.theory-hero{padding:48px 0 36px}.theory-hero h1{letter-spacing:-.04em;background:linear-gradient(135deg, var(--ink) 30%, #7c3aed 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:12px;font-size:clamp(2rem,4vw,3rem);font-weight:800}.theory-hero p{color:var(--muted);max-width:520px;margin:0;font-size:1.05rem;line-height:1.65}@keyframes fade-in-up{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.theory-overview-card-cta{color:var(--accent);margin-top:4px;font-size:.85rem;font-weight:600}.theory-dashboard{flex-direction:column;gap:32px;display:flex}.theory-dashboard-featured{border:1.5px solid var(--line);background:var(--accent-faint);border-radius:14px;align-items:flex-start;gap:16px;padding:16px 20px;text-decoration:none;transition:border-color .15s,box-shadow .15s,transform .12s;display:flex}.theory-dashboard-featured:hover{border-color:var(--accent);text-decoration:none;transform:translateY(-1px);box-shadow:0 4px 20px #4361ee1f}.theory-dashboard-featured-icon{flex-shrink:0;padding-top:2px;font-size:1.8rem;line-height:1}.theory-dashboard-featured-title{color:var(--ink);margin:0 0 4px;font-size:1rem;font-weight:700}.theory-dashboard-featured-desc{color:var(--muted);margin:0;font-size:.875rem;line-height:1.5}.theory-dashboard-featured-arrow{color:var(--accent);flex-shrink:0;align-self:center;margin-left:auto;font-size:1.1rem}.theory-dashboard-levels{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;display:grid}.theory-dashboard-level-card{border:1.5px solid var(--line);cursor:pointer;text-align:left;background:#fff;border-radius:14px;flex-direction:column;gap:10px;padding:20px;transition:border-color .15s,box-shadow .15s,transform .12s;display:flex}.theory-dashboard-level-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 20px #4361ee1a}.theory-dashboard-level-top{justify-content:space-between;align-items:center;gap:8px;display:flex}.theory-dashboard-level-count{color:var(--muted);font-size:.78rem;font-weight:600}.theory-dashboard-level-tagline{color:var(--muted);margin:0;font-size:.82rem;line-height:1.5}.theory-dashboard-level-bar{background:var(--line);border-radius:2px;height:4px;overflow:hidden}.theory-dashboard-level-bar-fill{background:var(--accent);border-radius:2px;min-width:0;height:100%;transition:width .4s}.theory-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;display:grid}.theory-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-sm);color:var(--ink);border:1.5px solid #e5e7ebb3;align-items:flex-start;gap:18px;padding:22px;transition:transform .18s,box-shadow .18s,border-color .18s;display:flex}a.theory-card:hover{box-shadow:var(--shadow-md);border-color:#7c3aed;text-decoration:none;transform:translateY(-2px)}.theory-card-soon{opacity:.65;cursor:default}.theory-card-completed{background:linear-gradient(135deg, var(--card) 85%, #0596690f 100%);border-color:#0596698c}.theory-card-done{color:#fff;background:#059669;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:.72rem;font-weight:800;display:inline-flex}.theory-card-icon{background:var(--surface);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:2rem;line-height:1;display:flex}.theory-card h3{flex-wrap:wrap;align-items:center;gap:10px;margin:0 0 6px;font-size:1rem;display:flex}.theory-card p{color:var(--muted);margin:0;font-size:.875rem;line-height:1.55}.coming-soon-badge{letter-spacing:.03em;text-transform:uppercase;background:var(--surface);color:var(--muted);border:1px solid var(--line);border-radius:20px;padding:2px 8px;font-size:.72rem;font-weight:600}.theory-level-section{margin-bottom:48px}.theory-level-header{border-bottom:1.5px solid var(--line);align-items:baseline;gap:16px;margin-bottom:16px;padding-bottom:12px;display:flex}.theory-level-badge{letter-spacing:.07em;text-transform:uppercase;border-radius:20px;flex-shrink:0;padding:3px 12px;font-size:.72rem;font-weight:800}.theory-level-badge-beginner{color:#15803d;background:#dcfce7;border:1px solid #bbf7d0}.theory-level-badge-intermediate{color:#6d28d9;background:#ede9fe;border:1px solid #ddd6fe}.theory-level-badge-advanced{color:#b45309;background:#fef3c7;border:1px solid #fde68a}.theory-level-tagline{color:var(--muted);margin:0;font-size:.875rem;line-height:1.5}.cof-header{margin-bottom:32px}.cof-intro{color:var(--muted);max-width:62ch;font-size:1rem;line-height:1.65}.cof-layout{align-items:flex-start;gap:52px;display:flex}.cof-circle-wrap{flex:0 0 440px}.cof-svg{width:100%;height:auto;display:block}.cof-compass{color:var(--muted);letter-spacing:.02em;justify-content:space-between;padding:4px 8px 0;font-size:.75rem;display:flex}.cof-info{flex:1;min-width:0;padding-top:8px}.cof-key-title{letter-spacing:-.03em;margin:0 0 20px;font-family:Georgia,serif;font-size:2rem;font-weight:800}.cof-info-rows{border-top:1px solid var(--line);margin-bottom:24px}.cof-info-row{border-bottom:1px solid var(--line);justify-content:space-between;align-items:baseline;gap:16px;padding:11px 0;display:flex}.cof-info-label{text-transform:uppercase;letter-spacing:.06em;color:var(--muted);flex-shrink:0;font-size:.75rem;font-weight:700}.cof-info-value{text-align:right;font-size:.95rem;font-weight:500}.cof-section-label{text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:20px 0 10px;font-size:.75rem;font-weight:700}.cof-chords{grid-template-columns:repeat(7,1fr);gap:5px;display:grid}.cof-chord-cell{background:var(--surface);border-radius:10px;flex-direction:column;align-items:center;gap:5px;padding:9px 4px 8px;display:flex}.cof-roman{color:var(--muted);font-family:Georgia,serif;font-size:.68rem;font-weight:700}.cof-chord-name{text-align:center;font-family:Georgia,serif;font-size:.82rem;font-weight:700}.cof-chord-legend{color:var(--muted);margin:8px 0 0;font-size:.72rem}.cof-neighbors{gap:10px;display:flex}.cof-neighbor-btn{background:var(--surface);border:1.5px solid var(--line);cursor:pointer;color:var(--ink);border-radius:12px;flex-direction:column;flex:1;align-items:center;gap:3px;padding:10px 12px;font-family:Georgia,serif;font-size:.95rem;font-weight:700;transition:background .13s,border-color .13s;display:flex}.cof-neighbor-btn:hover{background:var(--card);border-color:var(--accent)}.cof-neighbor-hint{color:var(--muted);font-family:system-ui,sans-serif;font-size:.68rem;font-weight:400}.cof-empty-info h2{margin:0 0 12px;font-size:1.4rem}.cof-empty-info p{color:var(--muted);margin:0 0 12px;line-height:1.6}.cof-empty-info ul{color:var(--muted);margin:0 0 20px;padding-left:20px;line-height:1.9}.cof-tip{background:var(--surface);border-left:3px solid #7c3aed;border-radius:0 8px 8px 0;padding:12px 16px;font-size:.875rem;line-height:1.6}@media (width<=760px){.cof-layout{flex-direction:column;gap:28px}.cof-circle-wrap{flex:none;width:100%;max-width:420px;margin:0 auto}.cof-chords{grid-template-columns:repeat(4,1fr)}}.tap-button-area{justify-content:center;padding:0 0 4px;display:flex}.tap-btn{cursor:pointer;color:#fff;min-width:240px;height:56px;font:inherit;-webkit-user-select:none;user-select:none;touch-action:manipulation;-webkit-tap-highlight-color:transparent;will-change:transform;border:none;border-radius:12px;flex-direction:row;justify-content:center;align-items:center;gap:10px;transition:transform .12s,box-shadow .12s;display:flex;position:relative}.tap-btn:after{content:"";pointer-events:none;border:1px solid #ffffff47;border-radius:8px;position:absolute;inset:6px}.tap-btn-green{background:linear-gradient(145deg,#10b981 0%,#059669 100%);box-shadow:0 8px 24px #0596696b,0 2px 6px #05966947,inset 0 1px #ffffff2e}.tap-btn-blue{background:linear-gradient(145deg, #5b7bf5 0%, var(--accent-dark) 100%);box-shadow:0 8px 24px #4361ee6b,0 2px 6px #4361ee47,inset 0 1px #ffffff2e}.tap-btn-disabled{opacity:.38;cursor:not-allowed;box-shadow:none}.tap-btn-green:not(.tap-btn-disabled):hover,.tap-btn-blue:not(.tap-btn-disabled):hover{transform:translateY(-1px)}.tap-btn-inner{flex-direction:column;align-items:center;gap:2px;line-height:1;display:flex}.tap-btn-label{letter-spacing:.12em;font-size:1.5rem;font-weight:800}.tap-btn-sublabel{opacity:.72;font-variant-numeric:tabular-nums;letter-spacing:.04em;font-size:.78rem;font-weight:600}.tap-btn-arrows{gap:1px;display:flex}.tap-btn-arrow{animation:1.35s ease-in-out infinite arrow-glow;animation-delay:calc(var(--i,0) * .22s);opacity:.18;font-size:1.15rem;font-weight:700}@keyframes arrow-glow{0%,30%{opacity:.18}55%{opacity:1;text-shadow:0 0 8px #ffffffe6,0 0 16px #ffffff80}80%,to{opacity:.18}}@keyframes tap-flash{0%{transform:scale(1)}20%{transform:scale(.93)}55%{transform:scale(1.04)}80%{transform:scale(.99)}to{transform:scale(1)}}.tap-btn.tap-btn-flash{animation:.22s cubic-bezier(.36,.07,.19,.97) both tap-flash}.admin-tabs{border-bottom:1.5px solid var(--line);gap:4px;margin-bottom:24px;display:flex}.admin-tabs button{cursor:pointer;color:var(--muted);background:0 0;border:none;border-bottom:2.5px solid #0000;margin-bottom:-1.5px;padding:10px 18px;font-size:.9rem;font-weight:600;transition:color .15s}.admin-tabs button.active{color:var(--accent);border-bottom-color:var(--accent)}.data-table{border-collapse:collapse;background:var(--card);border:1.5px solid var(--line);border-radius:var(--radius);width:100%;box-shadow:var(--shadow-xs);overflow:hidden}.data-table th,.data-table td{text-align:left;border-bottom:1px solid var(--line);padding:11px 16px;font-size:.9rem}.data-table th{background:var(--surface);text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-size:.82rem;font-weight:650}.data-table tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:var(--surface)}.outcome-passed{color:var(--green);font-weight:600}.outcome-failed{color:var(--red);font-weight:600}.outcome-skipped{color:var(--muted)}.test-failure-message{white-space:pre-wrap;border-radius:var(--radius-sm);background:#fef2f2;max-height:240px;margin-top:6px;padding:8px 10px;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.78rem;overflow:auto}.test-summary{gap:20px;margin:14px 0;font-weight:600;display:flex}.admin-detail{margin-top:24px}.admin-two-col{grid-template-columns:1fr 1fr;align-items:start;gap:24px;display:grid}@media (width<=900px){.admin-two-col{grid-template-columns:1fr}}.player-wrap{z-index:2;flex-direction:column;align-items:center;width:100%;max-width:640px;margin:0 auto;display:flex;position:relative}.player-wrap .player-header{align-self:flex-start;width:100%}.player-info-row{align-items:center;gap:10px;width:100%;height:52px;margin-bottom:2px;display:flex}.player-info-text{color:var(--ink);flex:1;font-size:.9rem}.player-info-row .metronome{flex-shrink:0}.player-wrap .exercise-status{align-self:flex-start;align-items:center;width:100%;min-height:2em;margin:8px 0 4px;font-size:.95rem;display:flex}.player-wrap .player-controls{flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;margin:16px 0;display:flex}.player-wrap .mode-toggle{align-self:center;max-width:100%}.player-wrap .played-back{text-align:center;align-self:center}.player-wrap .result-legend{justify-content:center}.sample-login-nudge{justify-content:center;margin-top:12px;display:flex}.pa-banner{border-radius:var(--radius-lg);background:linear-gradient(160deg,#1e1b4b 0%,#312e81 55%,#4338ca 100%);height:230px;margin:0 0 16px;position:relative;overflow:hidden}.pa-banner .vss-viewport{filter:invert();opacity:.22;-webkit-mask-image:linear-gradient(#0000 35%,#000 75% 100%);mask-image:linear-gradient(#0000 35%,#000 75% 100%)}.pa-banner-fade{pointer-events:none;z-index:1;background:linear-gradient(#1e1b4bb8 0%,#1e1b4b61 55%,#0000 100%);position:absolute;inset:0}.pa-banner-content{z-index:2;flex-direction:column;justify-content:center;max-width:560px;padding:0 44px;display:flex;position:absolute;inset:0}.pa-banner-eyebrow{letter-spacing:.12em;text-transform:uppercase;color:#a5b4fc;margin:0 0 6px;font-size:.72rem;font-weight:700}.pa-banner-title{color:#fff;letter-spacing:-.03em;margin:0 0 10px;font-size:2rem;font-weight:800}.pa-banner-desc{color:#c7d2fe;max-width:380px;margin:0 0 20px;font-size:.92rem;line-height:1.55}.pa-banner-btn{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff26;border:1.5px solid #ffffff4d;border-radius:8px;align-items:center;gap:6px;width:fit-content;padding:9px 22px;font-size:.9rem;font-weight:650;text-decoration:none;transition:background .16s,border-color .16s,transform .16s;display:inline-flex}.pa-banner-btn:hover{color:#fff;background:#ffffff40;border-color:#ffffff80;text-decoration:none;transform:translateY(-2px)}@media (width<=600px){.pa-banner{height:200px}.pa-banner-content{padding:0 24px}.pa-banner-title{font-size:1.6rem}.pa-banner-desc{display:none}}.home-logo{color:var(--ink);filter:drop-shadow(0 2px 8px #00000014)}.home-footer-nudge{text-align:center;color:var(--muted);margin:0 0 40px;font-size:.9rem}.vss-viewport{pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,#0000 0%,#000 12% 88%,#0000 100%);mask-image:linear-gradient(90deg,#0000 0%,#000 12% 88%,#0000 100%)}.vss-track{will-change:transform;align-items:center;height:100%;display:flex}.vss-measure{flex-shrink:0;align-items:center;width:380px;height:100%;display:flex}.vss-notation-wrapper{width:100%;position:relative}.about-hero{border-radius:var(--radius-lg);background:0 0;border:none;justify-content:center;align-items:center;height:240px;margin:-8px -24px 32px;display:flex;position:relative;overflow:hidden}.about-hero .vss-viewport{opacity:.25}.about-hero-text{z-index:2;text-align:center;position:relative}.about-tagline{letter-spacing:-.03em;color:var(--accent);margin:0;font-size:clamp(1.4rem,3.5vw,2.2rem);font-weight:800;line-height:1.25}.about-body{max-width:680px}.about-body h2{border-bottom:1px solid var(--line);margin-top:36px;padding-bottom:8px;font-size:1.1rem;font-weight:700}.about-body p{color:var(--ink);opacity:.88;margin:12px 0 0;font-size:1.02rem;line-height:1.75}.section-pill-rhythm.section-pill-active{background:var(--accent);box-shadow:0 2px 8px #4361ee4d}.section-pill-theory.section-pill-active{background:#7c3aed;box-shadow:0 2px 8px #7c3aed4d}.section-pill-playalong.section-pill-active{background:#312e81;box-shadow:0 2px 8px #312e8159}.section-pill-playalong{animation:3.2s ease-in-out infinite pa-pill-glow;position:relative;overflow:hidden}.section-pill-playalong:before{content:"";pointer-events:none;background:linear-gradient(105deg,#0000 35%,#ffffff8c 50%,#0000 65%);width:55%;height:200%;animation:3.2s ease-in-out infinite pa-pill-shimmer;position:absolute;top:-50%;left:-80%}.section-pill-playalong:after{content:"✦";color:#fbbf24;pointer-events:none;font-size:7px;line-height:1;animation:3.2s ease-in-out infinite pa-spark-a;position:absolute;top:3px;right:4px}.pa-sparkle{pointer-events:none;color:#fde68a;-webkit-user-select:none;user-select:none;line-height:1;position:absolute}.pa-sparkle-1{color:#fbbf24;font-size:11px;animation:2.6s ease-in-out .7s infinite pa-spark-b;top:1px;right:16px}.pa-sparkle-2{color:#fef3c7;font-size:6px;animation:4.1s ease-in-out 1.4s infinite pa-spark-c;top:5px;right:9px}.pa-sparkle-3{color:#fbbf24;font-size:9px;animation:3.8s ease-in-out 2s infinite pa-spark-a;bottom:3px;left:7px}@keyframes pa-pill-shimmer{0%{left:-80%}30%,to{left:140%}}@keyframes pa-spark-a{0%,15%{opacity:0;transform:scale(.3)rotate(-15deg)}35%{opacity:1;transform:scale(1.35)rotate(18deg)}55%{opacity:.5;transform:scale(.85)rotate(38deg)}70%{opacity:0;transform:scale(.5)rotate(55deg)}to{opacity:0;transform:scale(.3)rotate(70deg)}}@keyframes pa-spark-b{0%,20%{opacity:0;transform:scale(.4)rotate(20deg)}40%{opacity:1;transform:scale(1.5)rotate(-10deg)}60%{opacity:.6;transform:scale(1)rotate(-28deg)}78%{opacity:0;transform:scale(.5)rotate(-45deg)}to{opacity:0;transform:scale(.4)rotate(-60deg)}}@keyframes pa-spark-c{0%,30%{opacity:0;transform:scale(.2)rotate(5deg)}48%{opacity:1;transform:scale(1.8)rotate(-20deg)}62%{opacity:.4;transform:scale(1.1)rotate(10deg)}80%{opacity:0;transform:scale(.3)rotate(30deg)}to{opacity:0}}@keyframes pa-pill-glow{0%,to{box-shadow:none}30%{box-shadow:0 0 0 2px #6366f140,0 0 10px #6366f12e}60%{box-shadow:none}}.section-pill-playalong.section-pill-active{animation:none}.section-pill-playalong.section-pill-active:before,.section-pill-playalong.section-pill-active:after,.section-pill-playalong.section-pill-active .pa-sparkle{opacity:0;animation:none}.btn-primary{background:var(--accent);cursor:pointer;letter-spacing:-.01em;border:none;border-radius:12px;padding:12px 32px;font-size:1rem;font-weight:700;text-decoration:none;transition:background .15s,transform .1s,box-shadow .1s;display:inline-block;box-shadow:0 3px 14px #4361ee47;color:#fff!important}.btn-primary:hover{background:var(--accent-dark);text-decoration:none;transform:translateY(-1px);box-shadow:0 5px 20px #4361ee61}.btn-signup{border-radius:var(--radius-sm);background:var(--accent);cursor:pointer;letter-spacing:-.01em;border:none;padding:7px 16px;font-size:.88rem;font-weight:700;text-decoration:none;transition:background .15s,transform .1s;display:inline-block;color:#fff!important}.btn-signup:hover{background:var(--accent-dark);text-decoration:none;transform:translateY(-1px)}.navbar-login-link{color:var(--muted);border-radius:var(--radius-sm);padding:6px 10px;font-size:.88rem;font-weight:500;transition:color .15s,background .15s}.navbar-login-link:hover{color:var(--ink);background:#0000000a;text-decoration:none}.sample-section-header{border-bottom:1.5px solid var(--line);align-items:center;gap:16px;margin-bottom:0;display:flex}.sample-section-title{color:var(--ink);white-space:nowrap;border-bottom:2.5px solid var(--accent);margin-bottom:-1.5px;padding:10px 0 10px 4px;font-size:.95rem;font-weight:700}.sample-section .sample-tabs{border-bottom:none;margin-bottom:0}.site-footer{z-index:2;text-align:center;color:var(--muted);border-top:1px solid var(--line);margin-top:24px;padding:20px 24px;font-size:.8rem;position:relative}.home-cta-btn{color:#fff;text-align:center;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;background:linear-gradient(135deg,#6c63ff,#4361ee);border-radius:14px;max-width:280px;padding:14px 28px;font-size:1rem;font-weight:600;text-decoration:none;transition:transform .12s,box-shadow .2s;display:inline-block;box-shadow:0 4px 18px #635aff59}.home-cta-btn:hover{color:#fff;text-decoration:none;transform:translateY(-2px);box-shadow:0 6px 24px #635aff73}.home-cta-btn:active{transform:translateY(0)}.home-tap-wrap{flex-direction:column;align-items:center;gap:8px;margin:-4px 0 20px;display:flex}.badge-section{margin:32px 0 24px}.badge-section h2{align-items:center;gap:10px;margin-bottom:16px;display:flex}.badge-count{color:var(--muted);background:var(--surface);border:1px solid var(--line);border-radius:20px;padding:3px 10px;font-size:.8rem;font-weight:600}.badge-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:16px;display:grid}.badge-item{opacity:.45;flex-direction:column;align-items:center;gap:5px;transition:opacity .2s,transform .15s;display:flex}.badge-item.badge-earned{opacity:1}.badge-item.badge-earned:hover{transform:translateY(-3px)scale(1.05)}.badge-svg{filter:drop-shadow(0 2px 6px #0000001f);width:60px;height:60px}.badge-earned .badge-svg{filter:drop-shadow(0 3px 10px #0000002e)}.badge-name{text-align:center;color:var(--ink);max-width:72px;font-size:.72rem;font-weight:600;line-height:1.3}.skip-level-section{background:var(--card);border:1.5px solid var(--line);border-radius:var(--radius);margin-bottom:28px;padding:16px 20px}.skip-level-label{color:var(--muted);margin:0 0 12px;font-size:.88rem}.skip-level-buttons{flex-wrap:wrap;gap:10px;display:flex}.skip-level-btn{border:1.5px solid var(--accent);border-radius:var(--radius-sm);cursor:pointer;color:var(--ink);background:0 0;flex-direction:column;align-items:flex-start;padding:10px 16px;transition:background .15s,transform .1s;display:flex}.skip-level-btn:hover{background:#4361ee0f;transform:translateY(-1px)}.skip-level-btn-label{color:var(--accent);font-size:.9rem;font-weight:700}.skip-level-btn-sub{color:var(--muted);margin-top:1px;font-size:.78rem}.pa-stage{text-align:center;flex-direction:column;align-items:center;gap:20px;max-width:720px;margin:40px auto;display:flex}.pa-welcome-title{color:#f97316;margin:0;font-size:2rem;font-weight:700}.pa-welcome-body{color:var(--muted);max-width:420px;margin:0;font-size:1rem;line-height:1.6}.pa-welcome-bullets{text-align:left;flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.pa-welcome-bullets li{color:var(--ink);padding-left:24px;font-size:.95rem;position:relative}.pa-welcome-bullets li:before{content:"→";color:var(--accent);font-weight:700;position:absolute;left:0}@media (width<=600px){.pa-stage{margin:16px auto;padding:0 8px}.pa-welcome-title{font-size:1.7rem}.pa-welcome-bullets{width:100%}.pa-welcome-bullets li{font-size:.9rem}}.pa-cta{margin-top:8px;padding:12px 32px;font-size:1rem}.pa-tempo-row{color:var(--ink);margin:0;font-size:1rem;font-weight:600}.pa-tempo-inline-bpm{color:var(--accent);font-variant-numeric:tabular-nums;font-size:1.4rem;font-weight:700}.pa-tempo-inline-label{color:var(--muted);font-weight:400}.pa-setup-heading{color:var(--ink);margin:0;font-size:1.4rem;font-weight:700}.pa-setup-hint{color:var(--muted);margin:0;font-size:.9rem}.pa-bpm-display{align-items:baseline;gap:8px;display:flex}.pa-bpm-number{color:var(--accent);font-variant-numeric:tabular-nums;text-align:right;min-width:4ch;font-size:4rem;font-weight:700;line-height:1}.pa-bpm-unit{color:var(--muted);font-size:1.1rem;font-weight:500}.pa-speed-label{color:var(--muted);margin:-12px 0 0;font-size:.85rem;font-style:italic}.pa-bpm-slider{width:100%;max-width:360px;accent-color:var(--accent)}.pa-slider-labels{width:100%;max-width:360px;color:var(--muted);justify-content:space-between;margin-top:-12px;font-size:.78rem;display:flex}.pa-settings-toggle{cursor:pointer;color:var(--muted);background:0 0;border:none;align-items:center;gap:4px;padding:4px 0;font-size:.9rem;font-weight:500;transition:color .15s;display:flex}.pa-settings-toggle:hover{color:var(--ink)}.pa-settings-caret{font-size:1.1rem;line-height:1;transition:transform .2s;display:inline-block;transform:rotate(0)}.pa-settings-caret.open{transform:rotate(90deg)}.pa-settings-panel{border-top:1px solid var(--border,#e5e7eb);text-align:left;flex-direction:column;gap:20px;width:100%;max-width:420px;padding:16px 0 4px;display:flex}.pa-settings-section{flex-direction:column;gap:10px;display:flex}.pa-settings-heading{color:var(--ink);margin:0;font-size:.95rem;font-weight:700}.pa-settings-row{color:var(--ink);cursor:default;justify-content:space-between;align-items:center;gap:12px;font-size:.9rem;display:flex}.pa-settings-row span{flex:1}.pa-settings-row input[type=number]{border:1px solid var(--border,#e5e7eb);text-align:right;background:var(--surface,#fff);width:72px;color:var(--ink);border-radius:6px;padding:4px 8px;font-size:.9rem}.pa-settings-table{border-collapse:collapse;width:100%;font-size:.88rem}.pa-settings-table th{text-align:left;color:var(--muted);padding:4px 8px 6px 0;font-size:.8rem;font-weight:600}.pa-settings-table td{padding:4px 8px 4px 0}.pa-settings-table input[type=number]{border:1px solid var(--border,#e5e7eb);text-align:right;background:var(--surface,#fff);width:60px;color:var(--ink);border-radius:6px;padding:4px 6px;font-size:.88rem}.pa-settings-remove{border:1px solid var(--border,#e5e7eb);color:var(--muted);cursor:pointer;background:0 0;border-radius:4px;padding:2px 7px;font-size:.85rem;line-height:1;transition:background .15s,color .15s}.pa-settings-remove:hover:not(:disabled){color:#dc2626;background:#fee2e2;border-color:#fca5a5}.pa-settings-remove:disabled{opacity:.3;cursor:not-allowed}.pa-settings-add{border:1px dashed var(--border,#e5e7eb);color:var(--muted);cursor:pointer;background:0 0;border-radius:6px;align-self:flex-start;padding:5px 12px;font-size:.85rem;transition:border-color .15s,color .15s}.pa-settings-add:hover{border-color:var(--accent);color:var(--accent)}.pa-settings-footer{flex-direction:column;gap:.5rem;display:flex}.pa-settings-footnote{color:var(--muted);margin:0;font-size:.78rem;font-style:italic}.pa-settings-reset{cursor:pointer;color:var(--muted);background:0 0;border:none;padding:0;font-size:.82rem;text-decoration:underline;transition:color .15s}.pa-settings-reset:hover{color:var(--ink)}.pa-tap-tempo-btn{border:2px solid var(--accent);color:var(--accent);cursor:pointer;background:0 0;border-radius:12px;padding:10px 24px;font-size:.95rem;font-weight:600;transition:background .15s,color .15s}.pa-tap-tempo-btn:hover{background:var(--accent);color:#fff}.pa-tap-hint{opacity:.7;font-size:.82rem;font-weight:400}.pa-playing{flex-direction:column;align-items:center;gap:24px;padding:28px 0 48px;display:flex;position:relative}.pa-beat-row{gap:20px;display:flex}.pa-beat-dot{background:#0000001f;border-radius:50%;width:18px;height:18px;transition:background 70ms,transform 70ms}.pa-beat-dot.active{background:var(--accent);transform:scale(1.4)}.pa-bpm-label{color:var(--muted);margin:-16px 0 0;font-size:.88rem}.pa-tap-prompt{color:var(--accent);letter-spacing:.02em;margin:-16px 0 0;font-size:.92rem;font-weight:600;animation:1.6s ease-in-out infinite pa-prompt-pulse}@keyframes pa-prompt-pulse{0%,to{opacity:1}50%{opacity:.45}}.pa-reel-viewport{background:#fff;border:1px solid #0000001a;border-radius:16px;width:100%;position:relative;overflow:hidden;box-shadow:inset 0 1px 4px #0000000a}.pa-bpm-notif{z-index:20;background:var(--accent);color:#fff;letter-spacing:.04em;pointer-events:none;border-radius:20px;margin:0;padding:6px 18px;font-size:.88rem;font-weight:700;animation:3.5s ease-out forwards pa-notif-pop;position:absolute;top:10px;right:14px}@keyframes pa-notif-pop{0%{opacity:0;transform:translateY(4px)scale(.95)}12%{opacity:1;transform:translateY(0)scale(1)}75%{opacity:1}to{opacity:0}}.pa-reel-track{will-change:transform;display:flex}.pa-downbeat-arrow{color:#f97316;pointer-events:none;z-index:10;font-size:1.4rem;animation:.14s ease-out both pa-downbeat-pop;position:absolute;top:4px;transform:translate(-50%)}@keyframes pa-downbeat-pop{0%{opacity:0;transform:translate(-50%)translateY(-5px)scale(.75)}to{opacity:1;transform:translate(-50%)translateY(0)scale(1)}}.pa-beat1-arrow{color:#f97316;pointer-events:none;z-index:6;font-size:1.1rem;transition:color .15s;position:absolute;top:2px;transform:translate(-50%)}.pa-beat1-arrow.hit{color:#22c55e}.pa-beat1-arrow.pulsing{animation:.38s ease-out pa-arrow-pulse}@keyframes pa-arrow-pulse{0%{transform:translate(-50%)scale(1)}45%{transform:translate(-50%)scale(1.75)}to{transform:translate(-50%)scale(1)}}.pa-stray-x{color:#111;pointer-events:none;font-size:.72rem;font-weight:700;line-height:1;position:absolute;top:1px;transform:translate(-50%)}.pa-measure-block{cursor:pointer;background:#fff;flex-direction:column;flex-shrink:0;align-items:center;gap:4px;width:380px;padding:16px 0 12px;transition:background .2s;display:flex}.pa-measure-block:hover{background:#f973160d}.pa-notation-wrapper{width:100%;position:relative}.pa-notation-container{width:100%;line-height:0;transition:filter .2s}.pa-dots-layer{pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0}.pa-hit-dot{background:#16a34a;border-radius:50%;width:8px;height:8px;position:absolute;top:5px;transform:translate(-50%)}.pa-miss-dot{background:#f97316;border-radius:50%;width:8px;height:8px;position:absolute;top:5px;transform:translate(-50%)}.pa-measure-block:hover .pa-notation-container{filter:sepia()saturate(6)hue-rotate(340deg)}.pa-measure-block:hover .pa-hit-dot{filter:none;background:#16a34a}.pa-measure-hint{color:#0000;text-align:center;white-space:nowrap;-webkit-user-select:none;user-select:none;height:1em;margin:0;font-size:.67rem;font-style:italic;line-height:1;transition:color .2s}.pa-measure-block:hover .pa-measure-hint{color:#f97316}.pa-notation-container svg{max-width:100%;display:block}.pa-measure-footer{justify-content:space-between;align-items:center;width:100%;padding:0 14px;display:flex}.pa-measure-label{color:var(--muted);letter-spacing:.01em;font-size:.72rem}.pa-measure-level{letter-spacing:.04em;color:var(--accent);opacity:.6;font-size:.55rem}.pa-tap-btn{color:#fff;cursor:pointer;touch-action:none;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;background:radial-gradient(circle at 38% 32%,#818cf8 0%,#4f46e5 48%,#3730a3 100%);border:none;border-radius:50%;width:clamp(160px,46vw,210px);height:clamp(160px,46vw,210px);font-size:0;font-weight:900;transition:transform 80ms cubic-bezier(.36,.07,.19,.97),box-shadow 80ms;animation:2.2s ease-in-out infinite pa-tap-idle;position:relative;overflow:hidden;box-shadow:0 10px 40px #4f46e58c,0 3px 10px #4f46e559,inset 0 2px 5px #ffffff38,inset 0 -3px 6px #0000002e}.pa-tap-btn-label{letter-spacing:.1em;text-shadow:0 2px 6px #00000038;font-size:clamp(1.8rem,5vw,2.4rem);font-weight:900;display:block}.pa-tap-btn-ring{pointer-events:none;border:2px solid #ffffff2e;border-radius:50%;position:absolute;inset:10px}@keyframes pa-tap-idle{0%,to{box-shadow:0 10px 40px #4f46e58c,0 3px 10px #4f46e559,inset 0 2px 5px #ffffff38,inset 0 -3px 6px #0000002e}50%{box-shadow:0 14px 56px #4f46e5b8,0 3px 14px #4f46e580,inset 0 2px 5px #ffffff38,inset 0 -3px 6px #0000002e}}.pa-tap-btn:not(:disabled):not(.flash):hover{transform:scale(1.04)}.pa-tap-btn.flash,.pa-tap-btn:active{animation:none;transform:scale(.88);box-shadow:0 4px 18px #4f46e566,inset 0 3px 8px #00000038}.pa-secondary-controls{align-items:center;gap:10px;margin-top:-8px;display:flex}.pa-stop-btn-pill{color:var(--muted);cursor:pointer;background:0 0;border:1.5px solid #00000024;border-radius:20px;padding:8px 18px;font-size:.85rem;font-weight:600;transition:background .15s,color .15s}.pa-stop-btn-pill:hover{color:var(--ink);background:#0000000d}.pa-pause-hint{color:var(--accent);text-align:center;margin:-4px 0 4px;font-size:.875rem;font-style:italic;font-weight:500;animation:.2s fade-in-up}.pa-controls-row{justify-content:center;align-items:center;display:flex}.pa-tap-btn-muted{opacity:.32;pointer-events:none;animation:none}.pa-pause-btn{background:var(--surface-2,#f3f4f6);border:1.5px solid var(--line,#e5e7eb);cursor:pointer;color:var(--ink);white-space:nowrap;border-radius:20px;align-items:center;gap:5px;padding:8px 20px;font-size:.88rem;font-weight:600;transition:background .15s,border-color .15s,transform .1s;display:flex}.pa-pause-btn:hover{background:var(--accent-faint,#eef2ff);border-color:var(--accent)}.pa-pause-btn.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 4px 16px #4361ee59}.pa-admin{max-width:680px;padding:24px 0}.pa-admin-heading{margin:0 0 6px;font-size:1.35rem;font-weight:700}.pa-admin-hint{color:var(--muted);margin:0 0 20px;font-size:.87rem}.pa-admin-section{margin-bottom:28px}.pa-admin-section h3{border-bottom:1px solid var(--line,#e5e7eb);margin:0 0 12px;padding-bottom:6px;font-size:1rem;font-weight:700}.pa-admin-row{justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px;font-size:.9rem;display:flex}.pa-admin-row span{color:var(--ink);flex:1}.pa-admin-row input[type=number]{border:1.5px solid var(--line,#d1d5db);text-align:right;background:var(--surface-1,#fff);width:90px;color:var(--ink);border-radius:8px;padding:6px 10px;font-size:.92rem}.pa-admin-table{border-collapse:collapse;width:100%;margin-bottom:10px;font-size:.88rem}.pa-admin-table th{text-align:left;color:var(--muted);border-bottom:1px solid var(--line,#e5e7eb);padding:6px 8px;font-weight:600}.pa-admin-table td{padding:6px 8px}.pa-admin-table input[type=number]{border:1.5px solid var(--line,#d1d5db);text-align:right;border-radius:7px;width:80px;padding:5px 8px;font-size:.88rem}.pa-admin-remove{cursor:pointer;color:var(--muted);background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:1rem;transition:background .15s,color .15s}.pa-admin-remove:hover:not(:disabled){color:#dc2626;background:#fee2e2}.pa-admin-remove:disabled{opacity:.3;cursor:not-allowed}.pa-admin-add{border:1.5px dashed var(--line,#d1d5db);color:var(--accent);cursor:pointer;background:0 0;border-radius:8px;padding:7px 16px;font-size:.85rem;font-weight:600;transition:background .15s}.pa-admin-add:hover{background:var(--accent-faint,#eef2ff)}.pa-admin-actions{flex-wrap:wrap;align-items:center;gap:10px;padding-top:8px;display:flex}.pa-admin-saved{color:#16a34a;font-size:.88rem;font-weight:600}.pp-root{background:var(--surface-2,#f8f9fa);border:1px solid var(--line,#e5e7eb);border-radius:12px;flex-direction:column;gap:10px;margin:14px 0;padding:14px 16px;display:flex}.pp-chips{flex-wrap:wrap;gap:8px;display:flex}.pp-chip{background:var(--surface-1,#fff);border:1.5px solid var(--line,#d1d5db);text-align:center;border-radius:8px;min-width:40px;padding:6px 14px;transition:background .12s,border-color .12s,transform .1s}.pp-chip-active{background:var(--accent);border-color:var(--accent);color:#fff;transform:scale(1.08)}.pp-chip-label{font-family:Georgia,serif;font-size:1.05rem;font-weight:700}.pp-controls{align-items:center;gap:12px;display:flex}.pp-play-btn{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:20px;padding:7px 18px;font-size:.88rem;font-weight:700;transition:background .15s,transform .1s}.pp-play-btn:hover{background:var(--accent-dark,#3730a3)}.pp-playing{background:#dc2626}.pp-playing:hover{background:#b91c1c}.pp-context{color:var(--muted);font-size:.8rem;font-style:italic}.iv-play-btn{border:1.5px solid var(--accent);color:var(--accent);cursor:pointer;background:0 0;border-radius:6px;padding:2px 7px;font-size:.78rem;transition:background .12s,color .12s}.iv-play-btn:hover{background:var(--accent);color:#fff}.bach-player{background:#fdfaf5;border:1.5px solid #e8d9a0;border-radius:12px;flex-direction:column;gap:12px;margin:14px 0;padding:16px 18px;display:flex}.bach-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.bach-title{color:var(--ink);margin:0 0 2px;font-size:.95rem;font-weight:700}.bach-subtitle{color:var(--muted);margin:0;font-size:.78rem}.bach-bars{flex-wrap:wrap;gap:6px;display:flex}.bach-bar-chip{background:var(--surface-2,#f3f4f6);border:1px solid var(--line,#e5e7eb);color:var(--muted);border-radius:6px;padding:4px 10px;font-size:.75rem;transition:background .1s,color .1s,border-color .1s}.bach-bar-active{color:#fff;background:#d4a017;border-color:#d4a017;font-weight:700}.bach-voices{gap:12px;display:flex}.bach-voice{background:var(--surface-1,#fff);border:1px solid var(--line,#e5e7eb);border-radius:8px;flex-direction:column;flex:1;align-items:center;gap:4px;padding:10px;display:flex}.bach-voice-rh{border-top:3px solid #4f46e5}.bach-voice-lh{border-top:3px solid #d4a017}.bach-voice-label{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-size:.72rem;font-weight:600}.bach-note{color:var(--muted);min-height:2rem;font-family:Georgia,serif;font-size:1.6rem;font-weight:700;transition:color 80ms,transform 80ms}.bach-note-active{color:var(--accent);transform:scale(1.18)}.bach-caption{color:var(--muted);margin:0;font-size:.82rem;line-height:1.55}.mobile-nav-accordion{text-align:left;width:100%;font:inherit;cursor:pointer;background:0 0;border:none;justify-content:space-between;align-items:center;display:flex}.mobile-nav-chevron{opacity:.5;margin-left:auto;font-size:.6rem;transition:transform .3s;display:inline-block}.mobile-nav-accordion.expanded .mobile-nav-chevron{transform:rotate(180deg)}.mobile-nav-accordion.expanded{color:var(--accent)}.cs-root{background:radial-gradient(ellipse 90% 55% at 50% -10%, #6c63ff21 0%, transparent 58%), radial-gradient(ellipse 60% 40% at 10% 110%, #4361ee12 0%, transparent 52%), var(--paper);flex-direction:column;min-height:100vh;display:flex}.cs-hero{text-align:center;flex-direction:column;align-items:center;gap:20px;padding:56px 24px 40px;display:flex}.cs-badge{letter-spacing:.08em;text-transform:uppercase;color:#6c63ff;background:#6c63ff1a;border:1px solid #6c63ff33;border-radius:100px;padding:5px 16px;font-size:.78rem;font-weight:600;display:inline-block}.cs-sub{color:var(--muted);max-width:540px;margin:0;font-size:clamp(1rem,2.5vw,1.2rem);line-height:1.7}.cs-coming-soon{letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin:8px 0 0;font-size:clamp(1.4rem,4vw,2rem);font-weight:800}.cs-staff-divider{color:var(--line);max-height:60px;padding:0 0 24px;overflow:hidden}.cs-staff-divider svg{width:100%;display:block}.cs-features{box-sizing:border-box;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:24px;width:100%;max-width:940px;margin:0 auto;padding:0 24px 56px;display:grid}.cs-feature-card{background:var(--card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--line);border-top-width:3px;padding:28px 28px 32px}.cs-feature-rhythm{border-top-color:var(--accent)}.cs-feature-playalong{border-top-color:#f97316}.cs-feature-theory{border-top-color:#6c63ff}.cs-feature-icon{margin-bottom:10px;font-size:2.2rem;line-height:1}.cs-feature-card h2{color:var(--ink);margin:0 0 10px;font-size:1.3rem}.cs-feature-intro{color:var(--muted);margin:0 0 18px;font-size:.92rem;line-height:1.6}.cs-feature-list{flex-direction:column;gap:9px;margin:0;padding:0;list-style:none;display:flex}.cs-feature-list li{color:var(--muted);padding-left:1.4em;font-size:.875rem;line-height:1.5;position:relative}.cs-feature-list li:before{content:"→";color:var(--accent);font-size:.8rem;position:absolute;top:.05em;left:0}.cs-feature-playalong .cs-feature-list li:before{color:#f97316}.cs-feature-theory .cs-feature-list li:before{color:#6c63ff}.cs-hero-actions{flex-wrap:wrap;justify-content:center;gap:12px;margin-top:4px;display:flex}.cs-cta-primary{background:var(--accent);color:#fff;border-radius:28px;padding:12px 28px;font-size:.95rem;font-weight:700;text-decoration:none;transition:background .15s,transform .1s;box-shadow:0 4px 14px #4361ee59}.cs-cta-primary:hover{background:var(--accent-dark,#3730a3);transform:translateY(-1px)}.cs-cta-secondary{color:#f97316;background:0 0;border:2px solid #f97316;border-radius:28px;padding:12px 28px;font-size:.95rem;font-weight:700;text-decoration:none;transition:background .15s,color .15s,transform .1s}.cs-cta-secondary:hover{color:#fff;background:#f97316;transform:translateY(-1px)}.cs-card-link{color:var(--accent);margin-top:18px;font-size:.875rem;font-weight:650;text-decoration:none;display:inline-block}.cs-card-link:hover{text-decoration:underline}.cs-feature-playalong .cs-card-link{color:#f97316}.cs-feature-theory .cs-card-link{color:#6c63ff}.cs-footer{text-align:center;color:var(--muted);border-top:1px solid var(--line);margin-top:auto;padding:20px 24px;font-size:.82rem}@media (width<=600px){.cs-hero{gap:16px;padding:40px 20px 28px}.cs-features{gap:16px;padding:0 16px 48px}.cs-feature-card{padding:22px 20px 26px}}.nq-root{flex-direction:column;align-items:center;gap:20px;max-width:520px;margin:0 auto;padding:28px 16px 72px;display:flex}.nq-page-header{text-align:center}.nq-page-header h1{margin:0 0 6px;font-size:1.75rem}.nq-page-sub{color:var(--muted);margin:0;font-size:.95rem}.nq-mode-row{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.nq-mode-btn{border:1px solid var(--line);background:var(--card);color:var(--muted);cursor:pointer;white-space:nowrap;border-radius:100px;padding:6px 16px;font-size:.82rem;font-weight:600;transition:border-color .15s,color .15s,background .15s}.nq-mode-btn:hover{border-color:var(--accent);color:var(--accent)}.nq-mode-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.nq-score-row{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-sizing:border-box;justify-content:center;gap:28px;width:100%;padding:12px 24px;display:flex}.nq-stat{flex-direction:column;align-items:center;gap:1px;display:flex}.nq-stat-value{color:var(--ink);font-size:1.4rem;font-weight:700;line-height:1}.nq-stat-denom{color:var(--muted);font-size:.85rem;font-weight:400}.nq-stat-label{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-size:.68rem}.nq-staff-wrap{flex-direction:column;align-items:center;gap:6px;width:100%;display:flex;overflow:visible}.nq-staff-svg{border-radius:var(--radius);width:100%;max-width:300px;padding:4px;line-height:0;transition:background .18s}.nq-staff-svg svg{width:100%;height:auto;display:block}.nq-staff-correct{background:#05966914}.nq-staff-wrong{background:#dc26260f}.nq-clef-label{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin:0;font-size:.75rem}.nq-question{color:var(--muted);text-align:center;margin:0;font-size:1rem}.nq-choices{grid-template-columns:1fr 1fr;gap:12px;width:100%;max-width:320px;display:grid}.nq-choice{border-radius:var(--radius);border:2px solid var(--line);background:var(--card);height:68px;color:var(--ink);cursor:pointer;letter-spacing:.02em;-webkit-user-select:none;user-select:none;font-size:1.6rem;font-weight:800;transition:border-color .12s,color .12s,background .12s,transform 80ms,box-shadow .12s}.nq-choice:hover:not(:disabled){border-color:var(--accent);color:var(--accent);box-shadow:var(--shadow-sm);transform:translateY(-2px)}.nq-choice:active:not(:disabled){transform:translateY(0)}.nq-correct{color:#fff!important;background:#059669!important;border-color:#059669!important;box-shadow:0 4px 16px #05966959!important}.nq-wrong{color:#fff!important;background:#dc2626!important;border-color:#dc2626!important;box-shadow:0 4px 16px #dc26264d!important}.nq-reveal{gap:1px;animation:1.5s ease-in-out infinite nq-reveal-glow;color:#934710!important;background:#f9731612!important;border-color:#f39716!important;flex-direction:column!important;justify-content:center!important;align-items:center!important;height:auto!important;min-height:68px!important;padding:6px 8px!important;display:flex!important}@keyframes nq-reveal-glow{0%,to{box-shadow:0 0 #f9731600,0 2px 8px #f973161f}50%{box-shadow:0 0 0 5px #f973162e,0 4px 20px #f973164d}}.nq-reveal-top{letter-spacing:.1em;text-transform:uppercase;opacity:.75;font-size:.48em;font-weight:700;line-height:1.3}.nq-reveal-val{font-size:1em;font-weight:800;line-height:1.2}.nq-hint{color:var(--muted);text-align:center;max-width:340px;margin:0;font-size:.82rem;font-style:italic}.nq-choices--text{grid-template-columns:1fr;max-width:480px}.nq-choices--text .nq-choice{text-align:left;white-space:normal;height:auto;min-height:52px;padding:12px 16px;font-size:.92rem;font-weight:600;line-height:1.45}@media (width<=420px){.nq-root{gap:16px}.nq-choice{height:60px;font-size:1.4rem}.nq-choices{gap:10px}.nq-mode-row{gap:6px}.nq-mode-btn{padding:5px 12px;font-size:.78rem}}.tt-page{max-width:780px;margin:0 auto}.tt-page-header{margin-bottom:24px}.tt-page-header h1{margin:0 0 6px}.tt-page-sub{color:var(--muted);margin:0;font-size:1rem}.tt-layout{flex-direction:column;display:flex}.tt-tabs{border-bottom:2px solid var(--line);gap:0;display:flex}.tt-tab{color:var(--muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;border-radius:6px 6px 0 0;margin-bottom:-2px;padding:9px 22px;font-size:.92rem;font-weight:600;transition:color .14s,border-color .14s}.tt-tab:hover{color:var(--ink)}.tt-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.tt-panel{padding:24px 0 0}.tt-level-back{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);color:var(--muted);align-items:center;gap:6px;margin-bottom:16px;padding:6px 12px;font-size:.82rem;font-weight:600;text-decoration:none;transition:background .14s,color .14s;display:inline-flex}.tt-level-back:hover{background:var(--accent-faint);color:var(--accent);text-decoration:none}.tt-back-btn{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);color:var(--accent);cursor:pointer;align-items:center;gap:6px;margin-bottom:20px;padding:7px 14px;font-size:.85rem;font-weight:600;transition:background .14s;display:inline-flex}.tt-back-btn:hover{background:var(--accent-faint)}.tt-help-row{border-top:1px solid var(--line);justify-content:center;margin-top:28px;padding-top:16px;display:flex}.tt-help-link{color:var(--muted);cursor:pointer;text-underline-offset:3px;background:0 0;border:none;font-size:.85rem;text-decoration:underline;transition:color .14s}.tt-help-link:hover{color:var(--accent)}.tt-completion{border-top:1px solid var(--line);justify-content:center;margin-top:36px;padding-top:28px;display:flex}.tt-complete-btn{background:var(--accent);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;padding:13px 32px;font-size:1rem;font-weight:700;transition:opacity .15s,transform .1s,box-shadow .15s;box-shadow:0 2px 10px #7c3aed40}.tt-complete-btn:hover{opacity:.88;transform:translateY(-1px);box-shadow:0 4px 16px #7c3aed59}.tt-complete-btn:active{transform:translateY(0)}.tt-completed-badge{color:#fff;border-radius:var(--radius);background:#059669;align-items:center;gap:10px;padding:13px 28px;font-size:1rem;font-weight:700;display:inline-flex}.tt-completed-check{background:#ffffff40;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:.85rem;font-weight:800;display:inline-flex}.tt-learn{flex-direction:column;gap:36px;max-width:700px;display:flex}.tt-learn-section h2{align-items:center;gap:6px;margin:0 0 12px;font-size:1.15rem;font-weight:700;display:flex}.tt-learn-section p{margin:0 0 10px;line-height:1.75}.tt-learn-section p:last-child{margin-bottom:0}.tt-clef-glyph{opacity:.75;font-size:1.05em}.tt-learn-tip{background:var(--accent-faint);border-left:3px solid var(--accent);border-radius:0 var(--radius-sm) var(--radius-sm) 0;padding:10px 14px;font-size:.88rem;line-height:1.6;margin-top:14px!important;margin-bottom:0!important}.tt-learn-list{flex-direction:column;gap:10px;margin:10px 0 0;padding-left:22px;line-height:1.7;display:flex}.tt-learn-list li{padding-left:4px}.tt-learn-list-bullets{flex-direction:column;gap:10px;margin:10px 0 0;padding-left:22px;line-height:1.7;list-style:outside;display:flex}.tt-learn-list-bullets li{padding-left:4px}.tt-mnemonic-pair{flex-wrap:wrap;gap:12px;margin-top:14px;display:flex}.tt-mnemonic-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);min-width:200px;box-shadow:var(--shadow-xs);flex-direction:column;flex:1;gap:10px;padding:14px 16px;display:flex}.tt-mnemonic-label{text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:0;font-size:.76rem;font-weight:700}.tt-notes-row{flex-wrap:wrap;gap:6px;display:flex}.tt-note-pill{border:2px solid #0000;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-size:.92rem;font-weight:700;line-height:1;display:inline-flex}.tt-pill-line{color:#1d4ed8;background:#dbeafe;border-color:#bfdbfe}.tt-pill-space{color:#92400e;background:#fef3c7;border-color:#fde68a}.tt-mnemonic-phrase{color:var(--muted);margin:0;font-size:.87rem;font-style:italic;line-height:1.4}.tt-sig-table{border:1px solid var(--line);border-radius:var(--radius);margin-top:14px;font-size:.9rem;overflow:hidden}.tt-sig-row{background:var(--card);border-bottom:1px solid var(--line);grid-template-columns:1.2fr 1.2fr 2.6fr;padding:9px 16px;display:grid}.tt-sig-row:last-child{border-bottom:none}.tt-sig-row:nth-child(2n){background:var(--surface)}.tt-sig-header{color:#fff;text-transform:uppercase;letter-spacing:.06em;font-size:.76rem;font-weight:700;background:var(--ink)!important}.tt-sig-key{font-weight:700}.tt-sig-notes{color:var(--muted);font-size:.85em}.tt-roman-row{flex-wrap:wrap;gap:8px;margin-top:14px;display:flex}.tt-roman-pill{border-radius:var(--radius-sm);justify-content:center;align-items:center;min-width:48px;height:40px;padding:0 12px;font-family:Georgia,Times New Roman,serif;font-size:1rem;font-weight:700;display:inline-flex}.tt-roman-major{background:var(--accent-faint);color:var(--accent);border:1.5px solid #4361ee40}.tt-roman-minor{background:var(--surface);color:var(--muted);border:1.5px solid var(--line)}.tt-roman-note{color:var(--muted);margin:10px 0 0;font-size:.8rem}.theory-practice-empty{max-width:560px;padding:32px 0}.theory-practice-empty h2{margin:0 0 16px}.practice-topic-bar{border-bottom:1px solid var(--line);flex-wrap:wrap;gap:8px;margin-bottom:28px;padding:20px 0 16px;display:flex}.practice-topic-chip{border:1.5px solid var(--line);background:var(--card);cursor:pointer;color:var(--muted);border-radius:20px;padding:6px 14px;font-size:.85rem;font-weight:500;transition:border-color .14s,color .14s,background .14s}.practice-topic-chip:hover{border-color:var(--accent);color:var(--ink)}.practice-topic-chip.active{background:var(--bg);font-weight:700}.practice-quiz-header{flex-wrap:wrap;align-items:baseline;gap:12px;margin-bottom:20px;display:flex}.practice-level-badge{text-transform:uppercase;letter-spacing:.06em;font-size:.75rem;font-weight:700}.practice-quiz-title{margin:0;font-size:1.25rem;font-weight:700}.practice-topic-link{color:var(--muted);white-space:nowrap;margin-left:auto;font-size:.85rem;text-decoration:none}.practice-topic-link:hover{color:var(--accent)}@media (width<=480px){.tt-tab{padding:7px 14px;font-size:.85rem}.tt-mnemonic-pair{flex-direction:column}.tt-mnemonic-card{min-width:unset}.tt-roman-pill{min-width:40px;height:36px;font-size:.9rem}.tt-sig-row{padding:8px 12px;font-size:.83rem}}.theory-q-card{background:var(--card);border:1.5px solid var(--line);border-radius:var(--radius);text-align:center;width:100%;max-width:420px;box-shadow:var(--shadow-xs);margin:0 auto;padding:22px 28px 18px;transition:border-color .2s,background .2s}.theory-q-correct{border-color:var(--green)!important;background:#0596690d!important}.theory-q-wrong{border-color:var(--red)!important;background:#dc26260a!important}.theory-q-main{letter-spacing:-.02em;color:var(--ink);font-size:2rem;font-weight:800;line-height:1.1}.theory-q-sub{color:var(--muted);margin-top:8px;font-size:.85rem;line-height:1.5}.theory-q-prompt{color:var(--ink);margin-top:14px;font-size:.9rem;font-weight:600}.theory-q-verdict{margin-top:10px;font-size:.9rem;font-weight:600}.theory-q-pair{justify-content:center;align-items:center;gap:0;display:flex}.theory-q-arrow{color:var(--muted);margin:0 4px;font-size:1.4rem}.theory-q-numeral{color:var(--ink);font-family:Georgia,Times New Roman,serif;font-size:2.4rem;font-weight:800;line-height:1}.theory-q-chord{justify-content:center;align-items:flex-end;gap:20px;display:flex}.theory-q-note{flex-direction:column;align-items:center;gap:5px;display:flex}.theory-q-note-name{font-size:1.7rem;font-weight:800;line-height:1}.theory-q-note-role{text-transform:uppercase;letter-spacing:.07em;color:var(--muted);font-size:.65rem}.theory-q-prog{flex-wrap:wrap;justify-content:center;align-items:center;gap:4px;margin:4px auto 16px;display:flex}.theory-q-prog-chord{background:var(--surface);border:1.5px solid var(--line);border-radius:var(--radius-sm);text-align:center;min-width:48px;color:var(--ink);padding:8px 14px;font-family:Georgia,serif;font-size:1.25rem;font-weight:800}.theory-q-prog-blank{min-width:56px;border:2px dashed var(--accent)!important;background:var(--accent-faint)!important;color:var(--accent)!important}.theory-q-prog-reveal-correct{border-color:var(--green)!important;color:var(--green)!important;background:#0596691a!important}.theory-q-prog-reveal-wrong{border-color:var(--red)!important;color:var(--red)!important;background:#dc262614!important}.theory-q-prog-sep{color:var(--muted);padding:0 2px;font-size:1.1rem;font-weight:600}.piano-diagram-wrap{margin:20px 0 8px;overflow-x:auto}.piano-diagram-legend{color:var(--muted);text-align:center;margin:6px 0 0;font-size:.8rem;line-height:1.5}.scales-pattern{flex-wrap:wrap;justify-content:center;align-items:center;gap:0;margin:14px 0;display:flex}.scales-step{align-items:center;gap:0;display:flex}.scales-step-note{text-align:center;min-width:28px;font-size:1.1rem;font-weight:700}.scales-step-arrow{color:#1d4ed8;letter-spacing:.02em;background:#dbeafe;border-radius:4px;margin:0 4px;padding:3px 7px;font-size:.78rem;font-weight:700}.scales-step-arrow.scales-half{color:#92400e;background:#fef3c7}.scales-mini-strip{border-top:1px solid var(--line);flex-wrap:wrap;justify-content:center;gap:4px;margin-top:16px;padding-top:14px;display:flex}.scales-mini-note{background:var(--surface);border-radius:6px;flex-direction:column;align-items:center;gap:2px;min-width:32px;padding:5px 6px;transition:background .15s;display:flex}.scales-mini-note.scales-mini-target{background:var(--accent-faint);outline:2px solid var(--accent)}.scales-mini-notename{color:var(--ink);font-size:.8rem;font-weight:700;line-height:1}.scales-mini-deg{color:var(--muted);font-size:.6rem;line-height:1}@media (width<=480px){.theory-q-card{padding:16px 16px 14px}.theory-q-main{font-size:1.6rem}.theory-q-numeral{font-size:2rem}.theory-q-note-name{font-size:1.4rem}.theory-q-prog-chord{min-width:38px;padding:6px 10px;font-size:1rem}.scales-mini-note{min-width:26px;padding:4px}.scales-mini-notename{font-size:.7rem}}.tt-panel-overview{justify-content:center;padding:1.5rem 1rem 2rem;display:flex}.ns-overview{flex-direction:column;align-items:center;gap:.5rem;width:100%;max-width:600px;display:flex}.ns-overview-title{color:var(--text,#1e293b);margin:0;font-size:1.3rem;font-weight:700}.ns-overview-subtitle{color:var(--muted,#64748b);letter-spacing:.04em;margin:0 0 .5rem;font-size:.85rem}.ns-staff-wrap{width:100%;padding:.5rem 0}.ns-staff-line{opacity:.55;color:var(--text,#334155)}.ns-clef{fill:var(--text,#334155);opacity:.7}.ns-overview-controls{margin-top:.75rem}.ns-play-btn{border:1.5px solid var(--muted,#94a3b8);color:var(--muted,#64748b);cursor:pointer;background:0 0;border-radius:20px;padding:.3rem 1.1rem;font-size:.85rem;transition:all .15s}.ns-play-btn:hover{border-color:var(--accent,#f97316);color:var(--accent,#f97316)}.ns-play-btn.active{color:#22c55e;background:#22c55e14;border-color:#22c55e}.ns-ripple{transform-box:fill-box;transform-origin:50%;animation:.45s ease-out forwards ns-ripple-expand}@keyframes ns-ripple-expand{0%{opacity:.9;transform:scale(1)}to{opacity:0;transform:scale(5)}}.nq-choices .nq-choice:first-child{color:#7e2525;background:#fbe9e9;border-color:#e6a8a8}.nq-choices .nq-choice:nth-child(2){color:#777022;background:#faf9e5;border-color:#e2dc9c}.nq-choices .nq-choice:nth-child(3){color:#246b41;background:#e2f8eb;border-color:#94dbb2}.nq-choices .nq-choice:nth-child(4){color:#25437e;background:#e6ecfa;border-color:#a0b7e3}.nq-mode-row .nq-mode-btn:first-child{color:#822b2b;background:#faefef;border-color:#e3b5b5}.nq-mode-row .nq-mode-btn:nth-child(2){color:#775822;background:#fbf4ea;border-color:#e3ceab}.nq-mode-row .nq-mode-btn:nth-child(3){color:#476b24;background:#f0f8e7;border-color:#bfdca3}.nq-mode-row .nq-mode-btn:nth-child(4){color:#20686f;background:#e7f7f9;border-color:#9fdadf}.nq-mode-row .nq-mode-btn:nth-child(5){color:#25347e;background:#ebedfa;border-color:#abb4e3}.nq-mode-row .nq-mode-btn:nth-child(6){color:#5e2b82;background:#f3ebf9;border-color:#cbaee0}.nq-mode-row .nq-mode-btn:first-child.active{color:#fff!important;background:#a82424!important;border-color:#931f1f!important}.nq-mode-row .nq-mode-btn:nth-child(2).active{color:#fff!important;background:#a87824!important;border-color:#93691f!important}.nq-mode-row .nq-mode-btn:nth-child(3).active{color:#fff!important;background:#5c8c2c!important;border-color:#4f7826!important}.nq-mode-row .nq-mode-btn:nth-child(4).active{color:#fff!important;background:#258a93!important;border-color:#20777e!important}.nq-mode-row .nq-mode-btn:nth-child(5).active{color:#fff!important;background:#2d43b4!important;border-color:#283c9f!important}.nq-mode-row .nq-mode-btn:nth-child(6).active{color:#fff!important;background:#7433a3!important;border-color:#672d8f!important}.ns-note-name{letter-spacing:.04em;text-align:center;min-height:1.2em;margin:2px 0 0;font-size:.85rem;font-weight:700;transition:color .15s}.ec-quiz .nq-choice{white-space:normal;word-break:break-word;height:auto;min-height:52px;padding:6px 8px;font-size:clamp(.72rem,1.8vw,1.1rem);line-height:1.25}.th-overview-card{text-align:center;flex-direction:column;align-items:center;gap:1rem;max-width:520px;margin:0 auto;padding:2rem 1.5rem;display:flex}.th-overview-icon{font-size:4rem;line-height:1}.th-overview-title{color:var(--ink,#1e293b);margin:0;font-size:1.5rem;font-weight:700}.th-overview-desc{color:var(--text,#334155);margin:0;font-size:1rem;line-height:1.6}.th-overview-fact{text-align:left;box-sizing:border-box;background:#f973160f;border-left:3px solid;border-radius:0 8px 8px 0;width:100%;padding:.6rem 1rem;font-size:.88rem;font-weight:600;line-height:1.4}.ks-overview{flex-direction:column;align-items:center;gap:.4rem;width:100%;max-width:520px;margin:0 auto;padding:1rem 0 .5rem;display:flex}.ks-overview-key{color:var(--ink,#1e293b);margin:0;font-size:1.5rem;font-weight:700;animation:.4s ks-fade-in}.ks-overview-sf{color:var(--muted,#64748b);letter-spacing:.04em;text-transform:uppercase;margin:0 0 .4rem;font-size:.85rem}.ks-staff-wrap{width:50%;max-width:200px;position:relative;overflow:visible}.ks-staff-fadein{width:100%;animation:.4s ks-fade-in;overflow:visible}.ks-staff-fadein svg{overflow:visible!important}.ks-arrow-svg{pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0;overflow:visible}@keyframes ks-fade-in{0%{opacity:0}to{opacity:1}}.ks-dots{flex-wrap:wrap;justify-content:center;gap:5px;margin-top:.5rem;display:flex}.ks-dot{background:var(--border,#cbd5e1);border-radius:50%;width:7px;height:7px;transition:background .3s}.ks-dot.active{background:#cf8217}.ks-description{text-align:center;flex-direction:column;gap:.5rem;max-width:420px;margin-top:.75rem;display:flex}.ks-description p{color:var(--text,#334155);margin:0;font-size:.92rem;line-height:1.6}.nq-next-btn{border-radius:var(--radius,8px);background:var(--accent,#f97316);color:#fff;cursor:pointer;border:none;margin-top:.75rem;padding:.55rem 1.6rem;font-size:.95rem;font-weight:700;transition:opacity .15s}.nq-next-btn:hover{opacity:.85}.pa-gameover-title{color:var(--ink);margin:0;font-size:1.8rem;font-weight:700}.pa-gameover-body{color:var(--muted);text-align:center;max-width:420px;margin:0;font-size:1rem;line-height:1.6}.pa-gameover-review{flex-direction:column;align-items:center;gap:16px;max-width:400px;margin:32px auto;padding:0 16px 48px;display:flex}.pa-mistakes-header{color:var(--ink);text-align:center;margin:0;font-size:1rem;font-weight:600}.pa-mistakes-list{flex-direction:column;gap:12px;width:100%;display:flex}.pa-mistake-card{cursor:pointer;background:#fff;border:1.5px solid #0000001a;border-radius:12px;padding:8px 0 4px;transition:background .15s,border-color .15s;overflow:hidden}.pa-mistake-card:hover{background:#f973160d;border-color:#f97316}.pa-mistake-card-inner{flex-direction:column;align-items:center;gap:2px;display:flex}.pa-mistake-card-inner .pa-notation-container svg{max-width:100%}.profile-page{max-width:720px}.profile-header{align-items:center;gap:20px;margin-bottom:32px;display:flex}.profile-avatar{background:linear-gradient(135deg, var(--accent) 0%, #6c63ff 100%);color:#fff;-webkit-user-select:none;user-select:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:64px;height:64px;font-size:1.8rem;font-weight:700;display:flex}.profile-username{margin:0 0 4px;font-size:1.6rem;font-weight:700}.profile-since{color:var(--muted);margin:0;font-size:.88rem}.profile-section{margin-top:36px}.profile-section h2{border-bottom:1px solid var(--line);align-items:center;gap:10px;margin:0 0 14px;padding-bottom:8px;font-size:1.1rem;font-weight:700;display:flex}.profile-topic-grid{flex-wrap:wrap;gap:8px;display:flex}.concept-pill.visited{color:#1d4ed8;background:#eff6ff;border-color:#93c5fd}.stat-card--complete{background:linear-gradient(135deg,#ecfdf5 0%,#d1fae5 100%);border-color:#6ee7b7}.stat-card--complete .stat-value{color:#059669}.stat-card--complete .stat-label{color:#065f46}.stat-complete-star{color:#d97706;margin-left:4px;font-size:1rem}.profile-tab-earned{color:var(--muted);align-self:center;margin-left:auto;padding-right:4px;font-size:.78rem}.badge-count--complete{color:#065f46;background:#d1fae5;border-radius:20px;padding:1px 10px}.profile-section--warning{border-radius:0 var(--radius) var(--radius) 0;background:#fffbeb;border-left:3px solid #fbbf24;padding-top:14px;padding-bottom:14px;padding-left:16px}.profile-section--warning h2{border-bottom-color:#fde68a}.profile-warning-temper{color:#78350f;margin:0;font-size:.92rem}.about-badge-grid{grid-template-columns:repeat(auto-fill,minmax(72px,1fr));margin-top:16px}.about-badge-entry{flex-direction:column;align-items:center;gap:4px;display:flex}.about-badge-desc{color:var(--muted);text-align:center;margin:0;font-size:.7rem;line-height:1.3}
