@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.fixed{position:fixed}.relative{position:relative}.start{inset-inline-start:var(--spacing)}.start\!{inset-inline-start:var(--spacing)!important}.end{inset-inline-end:var(--spacing)}.end\!{inset-inline-end:var(--spacing)!important}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.border{border-style:var(--tw-border-style);border-width:1px}.p-45{padding:calc(var(--spacing) * 45)}.p-115{padding:calc(var(--spacing) * 115)}.p-125{padding:calc(var(--spacing) * 125)}.p-225{padding:calc(var(--spacing) * 225)}.p-515{padding:calc(var(--spacing) * 515)}.lowercase{text-transform:lowercase}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.blur{--tw-blur:blur(8px);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}:root{--bg:#07080f;--bg-surface:#0d0f1c;--bg-card:#ffffff0a;--border:#ffffff14;--border-glow:#00d2ff40;--text:#e2e6f8;--text-muted:#5a6080;--accent:#00d4ff;--accent-2:#7c4dff;--danger:#f35}*,:before,:after{box-sizing:border-box}html,body{background:var(--bg);color:var(--text);width:100%;height:100%;margin:0;padding:0;font-family:SF Pro Display,Inter,system-ui,sans-serif;font-size:14px;overflow:hidden}.app-shell{flex-direction:column;width:100vw;height:100vh;display:flex;overflow:hidden}.header{border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:20;background:#07080fe6;flex-shrink:0;justify-content:space-between;align-items:center;height:56px;padding:0 28px;display:flex}.logo{letter-spacing:-.02em;color:var(--text);align-items:center;gap:10px;font-size:18px;font-weight:700;display:flex}.logo-accent{color:var(--accent)}.logo-badge{color:var(--text-muted);background:var(--bg-card);border:1px solid var(--border);letter-spacing:.05em;text-transform:uppercase;border-radius:4px;padding:2px 7px;font-size:10px;font-weight:600}.main-content{flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.waterfall-section{flex:1;min-height:0;position:relative;overflow:hidden}.waterfall-section:before{content:"aspiano";letter-spacing:-.04em;white-space:nowrap;color:#ffffff07;pointer-events:none;z-index:0;-webkit-user-select:none;user-select:none;font-size:clamp(48px,10vw,96px);font-weight:800;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.waterfall-section canvas{display:block}.key-range-btn{color:#ffffffb3;cursor:pointer;white-space:nowrap;appearance:none;background:#ffffff0d;border:1px solid #fff3;border-radius:8px;outline:none;flex-shrink:0;align-items:center;gap:3px;padding:4px 10px;font-size:11.5px;font-weight:600;transition:color .15s,border-color .15s,background .15s;display:flex}.key-range-btn:hover{color:var(--text);background:#ffffff0f;border-color:#ffffff40}.key-picker-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:9999;background:#000000a6;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.key-picker-dialog{background:#161926;border:1px solid #ffffff2e;border-radius:20px;flex-direction:column;align-items:center;gap:10px;width:90%;max-width:440px;padding:36px 32px 32px;display:flex;position:relative;box-shadow:0 24px 80px #000c,0 0 0 1px #00d4ff0f}.key-picker-close{color:#ffffff59;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:16px;line-height:1;transition:color .15s;position:absolute;top:14px;right:14px}.key-picker-close:hover{color:var(--text)}.key-picker-icon{font-size:36px;line-height:1}.key-picker-title{letter-spacing:-.3px;color:var(--text);text-align:center;margin:0;font-size:20px;font-weight:800}.key-picker-sub{color:var(--text-muted);text-align:center;max-width:320px;margin:0;font-size:13px;line-height:1.6}.key-picker-grid{flex-wrap:wrap;justify-content:center;gap:10px;margin-top:8px;display:flex}.key-picker-btn{color:var(--text);cursor:pointer;appearance:none;background:#222638;border:1px solid #fff3;border-radius:14px;outline:none;flex-direction:column;align-items:center;gap:2px;min-width:72px;padding:14px 18px;transition:all .15s;display:flex}.key-picker-btn:hover{color:var(--accent);background:#1a2f42;border-color:#00d4ff8c}.key-picker-btn-active{color:var(--accent);background:#0e2840;border-color:#00d4ffbf;box-shadow:0 0 0 2px #00d4ff2e}.key-picker-num{letter-spacing:-.5px;font-size:22px;font-weight:800;line-height:1}.key-picker-label{opacity:.6;text-transform:uppercase;letter-spacing:.06em;font-size:10px;font-weight:500}.key-picker-hint{color:var(--text-muted);text-align:center;margin:4px 0 0;font-size:11.5px}.hud-child .key-picker-title{font-size:26px}.hud-child .key-picker-sub{font-size:15px}.hud-child .key-picker-num{font-size:28px}.synth-toggle-btn{color:#ffffff73;cursor:pointer;background:0 0;border:1px solid #ffffff1f;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;transition:color .15s,border-color .15s,background .15s;display:flex}.synth-toggle-btn:hover{color:var(--text);background:#ffffff0f;border-color:#ffffff40}.synth-toggle-open{background:#00d4ff12;border-color:#00d4ff59}.synth-toggle-active{color:var(--accent);border-color:#00d4ff73}.synth-toggle-active:hover{background:#00d4ff1a}.synth-bar{scrollbar-width:none;background:#07080f;border-bottom:1px solid #ffffff0d;flex-shrink:0;align-items:center;gap:4px;padding:6px 12px;display:flex;overflow:auto hidden}.synth-bar::-webkit-scrollbar{display:none}.synth-preset-btn{color:#ffffff8c;cursor:pointer;white-space:nowrap;appearance:none;background:#1a1d2e;border:1px solid #ffffff2e;border-radius:20px;outline:none;flex-shrink:0;align-items:center;gap:5px;padding:5px 12px;font-size:11.5px;font-weight:500;line-height:1.4;transition:color .15s,border-color .15s,background .15s;display:inline-flex}.synth-preset-btn:hover{color:var(--text);background:#22273a;border-color:#ffffff59}.synth-preset-btn-active{color:#00d4ff;background:#0a1e2e;border-color:#00d4ff8c}.synth-preset-btn-active:hover{background:#0e2840;border-color:#00d4ffbf}.synth-preset-emoji{font-size:13px;line-height:1}.synth-preset-label{letter-spacing:.02em}.piano-section{background:linear-gradient(#0a0b14 0%,#060710 100%);border-top:1px solid #ffffff0f;flex-shrink:0;padding:0;position:relative;overflow:hidden}.piano-section:before{content:"";pointer-events:none;background:radial-gradient(#00d4ff0d 0%,#0000 70%);width:60%;height:120px;position:absolute;top:-80px;left:50%;transform:translate(-50%)}.piano-wrapper{width:100%;padding:16px 16px 20px;position:relative}.piano-svg{filter:drop-shadow(0 -4px 20px #000c);width:100%;height:auto;display:block}.piano-particles{pointer-events:none;width:100%;height:100%;position:absolute;inset:0}.notes-display{pointer-events:none;z-index:5;align-items:center;gap:6px;padding:6px 0;display:flex;position:absolute;bottom:0;right:16px}.note-chip{letter-spacing:.04em;text-shadow:0 0 8px;opacity:.9;border:1px solid;border-radius:4px;padding:3px 8px;font-size:11px;font-weight:700}.device-panel-root{position:relative}.status-pill{background:var(--bg-card);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:20px;align-items:center;gap:8px;padding:6px 14px 6px 10px;font-size:13px;font-weight:500;transition:border-color .2s,background .2s;display:flex}.status-pill:hover{border-color:var(--border-glow);background:#00d4ff0f}.dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.dot-on{background:#0f8;animation:2s ease-in-out infinite pulse-dot;box-shadow:0 0 6px #0f8}.dot-idle{background:var(--accent);box-shadow:0 0 6px var(--accent)}.dot-off{background:var(--text-muted)}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.5}}.pill-label{text-overflow:ellipsis;white-space:nowrap;max-width:180px;overflow:hidden}.device-dropdown{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border);z-index:100;background:#0c0d16f7;border-radius:12px;width:320px;padding:16px;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 20px 60px #0009,0 0 0 1px #00d4ff0d}.panel-section{flex-direction:column;gap:10px;display:flex}.panel-section-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin:0;font-size:11px;font-weight:600}.panel-desc{color:var(--text-muted);margin:0;font-size:12px;line-height:1.6}.panel-notice{color:var(--danger);margin:0;font-size:12px}.panel-error{color:var(--danger);background:#ff335514;border:1px solid #f353;border-radius:6px;margin:8px 0 0;padding:8px;font-size:12px}.device-list{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.device-item{border:1px solid var(--border);width:100%;color:var(--text);cursor:pointer;text-align:left;background:0 0;border-radius:8px;align-items:center;gap:8px;padding:9px 12px;font-size:13px;transition:border-color .15s,background .15s;display:flex}.device-item:hover{border-color:var(--border-glow);background:#00d4ff0d}.device-item-active{border-color:var(--accent);color:var(--accent);background:#00d4ff14}.device-name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.device-mfg{color:var(--text-muted);flex-shrink:0;font-size:11px}.btn-primary{background:var(--accent);color:#07080f;cursor:pointer;border:none;border-radius:8px;padding:9px 16px;font-size:13px;font-weight:700;transition:opacity .15s,transform .1s}.btn-primary:hover{opacity:.9}.btn-primary:active{transform:scale(.98)}.btn-ghost{color:var(--text-muted);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:8px;align-self:flex-start;padding:7px 14px;font-size:12px;transition:color .15s,border-color .15s}.btn-ghost:hover{color:var(--danger);border-color:#ff33554d}.panel-hint{color:var(--text-muted);background:#ffffff05;border-radius:6px;margin-top:10px;padding:8px 10px;font-size:11px;line-height:1.5}.splash{pointer-events:none;z-index:1;flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex;position:absolute;inset:0}.splash-icon{opacity:.15;width:48px;height:48px}.splash-text{color:var(--text-muted);text-align:center;max-width:260px;font-size:13px;line-height:1.6}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.mode-tabs{border:1px solid var(--border);background:#ffffff08;border-radius:10px;gap:4px;padding:4px;display:flex}.mode-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:7px;padding:6px 16px;font-size:13px;font-weight:500;transition:all .16s}.mode-tab:hover{color:var(--text)}.mode-tab-active{background:var(--bg-surface);color:var(--text);box-shadow:0 1px 4px #0006}.level-badge{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;align-items:center;gap:6px;padding:4px 10px;display:flex}.level-num{color:var(--accent);font-size:15px;font-weight:700}.level-label{color:var(--text-muted);font-size:11px}.practice-layout{flex:1;min-height:0;display:flex;overflow:hidden}.practice-sidebar{border-right:1px solid var(--border);background:#ffffff03;flex-shrink:0;width:300px;overflow-y:auto}.practice-main{flex-direction:column;flex:1;min-width:0;display:flex;position:relative;overflow:hidden}.practice-hud-wrapper{z-index:10;flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.piano-section-practice{flex-shrink:0;margin-top:auto}.practice-empty{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;display:flex}.practice-empty-icon{opacity:.3;font-size:48px}.practice-empty-text{color:var(--text-muted);font-size:14px}.practice-empty-sub{color:var(--text-muted);opacity:.6;font-size:12px}.cb-root{flex-direction:column;gap:0;padding:16px;display:flex}.cb-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.cb-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-size:11px;font-weight:700}.cb-level{color:var(--accent);font-size:12px;font-weight:700}.cb-xp-row{align-items:center;gap:8px;margin-bottom:16px;display:flex}.cb-xp-bar-track{background:var(--border);border-radius:2px;flex:1;height:4px;overflow:hidden}.cb-xp-bar-fill{background:linear-gradient(to right, var(--accent), var(--accent-2));border-radius:2px;height:100%;transition:width .5s}.cb-xp-label{color:var(--text-muted);flex-shrink:0;font-size:11px}.cb-units{flex-direction:column;gap:4px;display:flex}.cb-unit{border:1px solid var(--border);border-radius:10px;overflow:hidden}.cb-unit-locked{opacity:.5}.cb-unit-header{background:var(--bg-card);align-items:center;gap:10px;padding:12px;display:flex}.cb-unit-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.cb-unit-info{flex:1;min-width:0}.cb-unit-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;display:block;overflow:hidden}.cb-unit-sub{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;margin-top:1px;font-size:11px;display:block;overflow:hidden}.cb-unit-stats{flex-shrink:0}.cb-unit-progress{color:var(--text-muted);font-size:11px}.cb-lock{font-size:12px}.cb-lessons{flex-direction:column;gap:2px;padding:4px 8px 8px;display:flex}.cb-lesson{width:100%;color:var(--text);cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;border-radius:8px;align-items:center;gap:10px;padding:9px 10px;transition:border-color .15s,background .15s;display:flex}.cb-lesson:hover{border-color:var(--border);background:#ffffff08}.cb-lesson-active{box-shadow:0 0 0 1px var(--unit-color,var(--accent));background:#ffffff0a;border-color:var(--unit-color,var(--accent))!important}@supports (color:color-mix(in lab, red, red)){.cb-lesson-active{box-shadow:0 0 0 1px color-mix(in srgb, var(--unit-color,var(--accent)) 20%, transparent)}}.cb-lesson-done{opacity:.8}.cb-lesson-locked{opacity:.35;cursor:not-allowed}.cb-lesson-icon{text-align:center;flex-shrink:0;width:20px;font-size:16px}.cb-lesson-text{flex:1;min-width:0}.cb-lesson-title{white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:600;display:block;overflow:hidden}.cb-lesson-desc{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;margin-top:1px;font-size:11px;display:block;overflow:hidden}.cb-lesson-right{flex-shrink:0}.cb-stars{color:gold;letter-spacing:-1px;font-size:12px}.cb-lesson-xp{color:var(--accent);font-size:11px;font-weight:600}.cb-lesson-soon{color:var(--text-muted);padding:8px 10px;font-size:11px;font-style:italic}.cb-reset-btn{color:var(--text-muted);cursor:pointer;opacity:.55;background:0 0;border:none;align-items:center;gap:6px;margin-bottom:12px;padding:4px 2px;font-size:11px;transition:opacity .16s,color .16s;display:flex}.cb-reset-btn:hover{opacity:1;color:var(--danger)}.cb-reset-confirm{background:#ff335512;border:1px solid #ff335540;border-radius:8px;flex-direction:column;gap:8px;margin-bottom:12px;padding:10px 12px;display:flex}.cb-reset-warning{color:var(--danger);font-size:12px;font-weight:600}.cb-reset-actions{gap:8px;display:flex}.cb-reset-yes{background:var(--danger);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:5px 12px;font-size:12px;font-weight:600;transition:opacity .15s}.cb-reset-yes:hover{opacity:.85}.cb-reset-no{color:var(--text-muted);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:6px;padding:5px 12px;font-size:12px;transition:color .15s}.cb-reset-no:hover{color:var(--text)}.hud-root{background:linear-gradient(#0a0b14fa,#080910f2);flex-direction:column;flex:1;min-height:0;padding:0 20px 16px;display:flex;overflow:hidden}.hud-top{flex-shrink:0;align-items:center;gap:12px;padding:10px 0 8px;display:flex}.hud-exit-btn{border:1px solid var(--border);width:28px;height:28px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:50%;flex-shrink:0;font-size:11px;transition:all .15s}.hud-exit-btn:hover{border-color:var(--danger);color:var(--danger)}.hud-lesson-title{color:var(--text);flex:1;font-size:14px;font-weight:600}.hud-score-row{align-items:center;gap:8px;display:flex}.hud-streak{color:#ff9500;font-size:12px;font-weight:700}.hud-score{color:var(--accent);font-variant-numeric:tabular-nums;font-size:18px;font-weight:700}.hud-progress-track{background:var(--border);border-radius:2px;flex-shrink:0;height:3px;margin-bottom:0;overflow:hidden}.hud-progress-fill{background:linear-gradient(to right, var(--accent), var(--accent-2));border-radius:2px;height:100%}.hud-body{flex-direction:column;flex:1;justify-content:center;align-items:center;min-height:0;padding:16px 0;display:flex;overflow-y:auto}.hud-info-card{flex-direction:column;align-items:center;gap:18px;width:100%;max-width:660px;display:flex}.hud-info-title{color:var(--text);text-align:center;letter-spacing:-.3px;margin:0;font-size:28px;font-weight:800;line-height:1.25}.hud-info-body{color:var(--text-muted);white-space:pre-line;text-align:left;border:1px solid var(--border);background:#ffffff08;border-radius:14px;width:100%;margin:0;padding:20px 26px;font-size:14px;line-height:1.85}.hud-info-visual{width:100%;padding:4px 0}.hud-next-btn{background:var(--accent);color:#07080f;cursor:pointer;border:none;border-radius:12px;margin-top:4px;padding:14px 44px;font-size:15px;font-weight:700;transition:opacity .15s,transform .1s}.hud-next-btn:hover{opacity:.9}.hud-next-btn:active{transform:scale(.97)}@keyframes kid-btn-pulse{0%,to{transform:scale(1);box-shadow:0 0 #00d4ff80,0 4px 24px #00d4ff40}50%{transform:scale(1.03);box-shadow:0 0 0 8px #00d4ff00,0 4px 32px #00d4ff66}}.hud-child .hud-info-card{gap:22px;max-width:700px}.hud-child .hud-info-title{letter-spacing:-1px;-webkit-text-fill-color:transparent;filter:drop-shadow(0 2px 16px #00d4ff4d);background:linear-gradient(135deg,#00d4ff 0%,#7c4dff 100%);-webkit-background-clip:text;background-clip:text;font-size:40px;font-weight:900}.hud-child .hud-info-visual{background:#00d4ff0d;border:1px solid #00d4ff26;border-radius:16px;padding:0;overflow:hidden}.hud-child .hud-info-body{color:#d8ddf5;text-align:center;background:#ffffff0a;border:1px solid #ffffff1a;border-radius:16px;padding:22px 28px;font-size:18px;font-weight:500;line-height:2}.hud-child .hud-next-btn{color:#fff;background:linear-gradient(135deg,#00d4ff 0%,#7c4dff 100%);border-radius:18px;margin-top:8px;padding:18px 56px;font-size:20px;font-weight:900;animation:2s ease-in-out infinite kid-btn-pulse;box-shadow:0 4px 24px #00d4ff4d}.hud-hint{background:#ffffff05;border:1px solid #ffffff12;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;gap:12px;width:100%;max-width:560px;padding:24px 16px;transition:border-color .2s,background .2s;display:flex}.hud-hint-correct{background:#00ff880a!important;border-color:#00ff8859!important}.hud-hint-wrong{background:#ff33550a!important;border-color:#ff335559!important}.hud-feedback-icon{color:#0f8;text-align:center;font-size:40px;font-weight:800}.hud-feedback-wrong{color:var(--danger)!important}.hud-hint-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:12px;font-weight:600}.hud-hint-note{color:gold;letter-spacing:.04em;text-align:center;font-size:64px;font-weight:800;line-height:1}.hud-hint-sub{color:var(--text-muted);text-align:center;max-width:420px;font-size:13px;line-height:1.5}.hud-complete{border:1px solid var(--border);background:#ffffff08;border-radius:16px;flex-direction:column;align-items:center;gap:10px;width:100%;max-width:480px;padding:28px 32px;display:flex}.hud-complete-stars{gap:8px;display:flex}.hud-complete-star{color:gold;font-size:40px;display:inline-block}.hud-complete-score{color:var(--accent);margin-top:4px;font-size:72px;font-weight:800;line-height:1}.hud-complete-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em;font-size:12px}.hud-complete-xp{color:#a855f7;font-size:20px;font-weight:700}.hud-complete-actions{flex-wrap:wrap;justify-content:center;gap:10px;margin-top:12px;display:flex}@keyframes target-pulse{0%,to{opacity:.7}50%{opacity:.25}}.target-pulse{animation:.9s ease-in-out infinite target-pulse}.fs-btn{background:var(--bg-card);border:1px solid var(--border);width:34px;height:34px;color:var(--text-muted);cursor:pointer;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;transition:all .16s;display:flex}.fs-btn:hover{border-color:var(--border-glow);color:var(--text);background:#00d4ff0f}.age-toggle{border:1px solid var(--border);background:var(--bg-card);color:var(--text-muted);cursor:pointer;white-space:nowrap;border-radius:8px;padding:5px 12px;font-size:12px;font-weight:500;transition:all .16s}.age-toggle:hover{border-color:var(--border-glow);color:var(--text)}.age-toggle-child{color:gold;background:#ffc8000f;border-color:#ffc8004d}.welcome-overlay{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);z-index:1000;background:#04050ceb;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.welcome-card{border:1px solid var(--border);background:#0c0d16fa;border-radius:20px;flex-direction:column;align-items:center;gap:12px;width:380px;padding:40px;display:flex;box-shadow:0 40px 100px #000000b3}.welcome-logo{letter-spacing:-.02em;color:var(--text);margin-bottom:4px;font-size:24px;font-weight:800}.welcome-title{color:var(--text);margin:0;font-size:28px;font-weight:800}.welcome-desc{color:var(--text-muted);margin:0;font-size:15px}.welcome-choices{gap:12px;width:100%;margin-top:8px;display:flex}.welcome-btn{border:2px solid var(--border);background:var(--bg-card);cursor:pointer;border-radius:14px;flex-direction:column;flex:1;align-items:center;gap:6px;padding:20px 16px;transition:all .2s;display:flex}.welcome-btn:hover{transform:translateY(-2px)}.welcome-btn-child{background:#ffc8000a;border-color:#ffc8004d}.welcome-btn-child:hover{border-color:gold;box-shadow:0 8px 30px #ffc8001f}.welcome-btn-adult{background:#00d4ff0a;border-color:#00d4ff4d}.welcome-btn-adult:hover{border-color:var(--accent);box-shadow:0 8px 30px #00d4ff1f}.welcome-btn-icon{font-size:36px}.welcome-btn-label{color:var(--text);font-size:18px;font-weight:700}.welcome-btn-sub{color:var(--text-muted);font-size:12px}.welcome-note{color:var(--text-muted);opacity:.5;margin:0;font-size:11px}.child-mode{--text:#f0f2ff;--text-muted:#8890cc}.child-mode .hud-hint-note{font-size:28px}.child-mode .hud-feedback-icon{font-size:16px;font-weight:800}.child-mode .cb-lesson-title{font-size:13px}.child-mode .cb-lesson-icon{font-size:18px}.child-mode .hud-complete-score{font-size:56px}.child-mode .hud-complete-star{font-size:36px}.child-mode .hud-complete-kid-msg{color:gold;font-size:20px;font-weight:800}.conn-pill{border:1px solid var(--border);background:var(--bg-card);color:var(--text-muted);cursor:pointer;border-radius:20px;align-items:center;gap:7px;padding:6px 14px 6px 10px;transition:border-color .18s,background .18s,color .18s;display:flex}.conn-pill:hover{border-color:var(--border-glow);color:var(--text);background:#00d4ff0f}.conn-pill-on{color:var(--text);border-color:#00ff884d}.conn-pill-on:hover{border-color:#0f89}.setup-overlay{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);z-index:999;background:#04050ce0;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.setup-card{border:1px solid var(--border);background:#0a0b14fa;border-radius:20px;flex-direction:column;gap:0;width:440px;padding:32px;display:flex;box-shadow:0 40px 100px #000000b3,0 0 0 1px #00d4ff0a}.setup-steps{justify-content:center;gap:6px;margin-bottom:28px;display:flex}.setup-step-dot{background:var(--border);border-radius:50%;width:6px;height:6px;transition:background .3s,transform .3s}.setup-step-dot.active{background:var(--accent);transform:scale(1.3)}.setup-step-dot.done{background:#0f8}.setup-body{text-align:center;flex-direction:column;align-items:center;gap:12px;display:flex}.setup-icon{width:80px;height:80px;color:var(--accent);background:#00d4ff0f;border:1px solid #00d4ff26;border-radius:20px;justify-content:center;align-items:center;margin-bottom:4px;display:flex}.setup-icon-warn{color:#fa0;background:#ffaa000f;border-color:#fa03}.setup-icon-ok{color:#0f8;background:#00ff880f;border-color:#0f83}.setup-title{color:var(--text);letter-spacing:-.02em;margin:0;font-size:22px;font-weight:800}.setup-desc{color:var(--text-muted);max-width:320px;margin:0;font-size:14px;line-height:1.65}.setup-warning{color:#ff9044;background:#ff640014;border:1px solid #ff640040;border-radius:8px;max-width:340px;padding:10px 14px;font-size:13px}.setup-error{color:var(--danger);background:#ff335514;border:1px solid #ff335540;border-radius:8px;max-width:340px;padding:10px 14px;font-size:13px}.setup-actions{flex-direction:column;align-items:center;gap:8px;width:100%;margin-top:8px;display:flex}.setup-btn-primary{background:var(--accent);color:#07080f;cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;width:100%;padding:13px 24px;font-size:14px;font-weight:700;transition:opacity .15s,transform .1s;display:flex}.setup-btn-primary:hover{opacity:.9}.setup-btn-primary:active{transform:scale(.98)}.setup-btn-primary:disabled{opacity:.4;cursor:not-allowed}.setup-btn-ghost{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:6px;font-size:12px;transition:color .15s}.setup-btn-ghost:hover{color:var(--text)}.setup-spinner{border:2px solid #07080f4d;border-top-color:#07080f;border-radius:50%;flex-shrink:0;width:16px;height:16px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.setup-instructions{border:1px solid var(--border);text-align:left;background:#ffffff05;border-radius:10px;flex-direction:column;gap:10px;width:100%;padding:14px;display:flex}.setup-instruction{color:var(--text-muted);align-items:flex-start;gap:10px;font-size:13px;line-height:1.5;display:flex}.setup-instr-num{width:20px;height:20px;color:var(--accent);background:#00d4ff26;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-top:1px;font-size:11px;font-weight:700;display:flex}.setup-device-list{flex-direction:column;gap:6px;width:100%;display:flex}.setup-device-item{background:var(--bg-card);border:1px solid var(--border);cursor:pointer;text-align:left;color:var(--text);border-radius:10px;align-items:center;gap:12px;width:100%;padding:12px 14px;transition:border-color .15s,background .15s;display:flex}.setup-device-item:hover{background:#00d4ff0a;border-color:#00d4ff4d}.setup-device-item.selected{border-color:var(--accent);background:#00d4ff14}.setup-device-icon{width:36px;height:36px;color:var(--text-muted);background:#ffffff0a;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.selected .setup-device-icon{color:var(--accent);background:#00d4ff1a}.setup-device-info{flex:1;min-width:0}.setup-device-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:600;display:block;overflow:hidden}.setup-device-mfg{color:var(--text-muted);margin-top:2px;font-size:11px;display:block}.setup-device-radio{border:2px solid var(--border);border-radius:50%;flex-shrink:0;width:16px;height:16px;transition:border-color .15s;position:relative}.setup-device-radio.checked{border-color:var(--accent)}.setup-device-radio.checked:after{content:"";background:var(--accent);border-radius:50%;position:absolute;inset:3px}.sb-root{flex-direction:column;gap:0;height:100%;display:flex;overflow-y:auto}.sb-header{border-bottom:1px solid var(--border);flex-shrink:0;padding:14px 16px 10px}.sb-title{letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);font-size:13px;font-weight:700;display:block}.sb-sub{color:var(--text-muted);opacity:.6;margin-top:2px;font-size:11px;display:block}.sb-list{flex-direction:column;flex:1;gap:4px;padding:8px 8px 0;display:flex;overflow-y:auto}.sb-song{cursor:pointer;text-align:left;width:100%;color:var(--text);background:0 0;border:1px solid #0000;border-radius:10px;align-items:center;gap:10px;padding:10px 12px;transition:background .15s,border-color .15s;display:flex;position:relative}.sb-song:hover{border-color:var(--border);background:#ffffff0a}.sb-song-active{background:#00ccff14!important;border-color:#00ccff59!important}.sb-song-icon{flex-shrink:0;font-size:22px}.sb-song-info{flex:1;min-width:0}.sb-song-title{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;display:block;overflow:hidden}.sb-song-meta{gap:8px;margin-top:2px;display:flex}.sb-bpm{color:var(--text-muted);font-size:11px}.sb-diff{font-size:11px;font-weight:600}.sb-playing-dot{background:var(--accent);width:7px;height:7px;box-shadow:0 0 8px var(--accent);border-radius:50%;flex-shrink:0;animation:1.2s ease-in-out infinite song-pulse}@keyframes song-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.7)}}.sb-hint{color:var(--text-muted);opacity:.55;text-align:center;border-top:1px solid var(--border);flex-shrink:0;padding:12px 16px;font-size:11px}.song-canvas-wrapper{background:#0a0a14;border-radius:12px;flex:1;min-height:0;position:relative;overflow:hidden}.song-hud{z-index:10;pointer-events:none;background:linear-gradient(#0a0a14d9 0%,#0000 100%);justify-content:space-between;align-items:center;padding:10px 16px;display:flex;position:absolute;top:0;left:0;right:0}.song-hud>*{pointer-events:auto}.song-hud-score,.song-hud-combo{flex-direction:column;align-items:center;min-width:80px;display:flex}.song-hud-label{letter-spacing:.1em;text-transform:uppercase;color:#ffffff80;font-size:10px;font-weight:600}.song-hud-value{color:#fff;letter-spacing:-.02em;font-size:22px;font-weight:800;line-height:1.1}.song-hud-center{flex-direction:column;align-items:center;gap:2px;display:flex}.song-hud-title{color:#fffc;font-size:13px;font-weight:600}.song-hud-acc-row{align-items:baseline;gap:4px;display:flex}.song-hud-acc{color:#0f8;font-size:16px;font-weight:700}.song-hud-acc-label{color:#fff6;font-size:10px}.song-hud-combo-val{color:#ffe600;text-shadow:0 0 12px #ffe600;font-size:20px;font-weight:900;animation:.25s ease-out combo-pop}@keyframes combo-pop{0%{transform:scale(1.4)}to{transform:scale(1)}}.song-stop-btn{color:#fff9;cursor:pointer;background:#ffffff14;border:1px solid #ffffff26;border-radius:6px;margin-top:4px;padding:4px 10px;font-size:11px;font-weight:600;transition:background .15s}.song-stop-btn:hover{color:#f35;background:#f353;border-color:#f356}.song-complete{z-index:20;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0a0a14eb;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex;position:absolute;inset:0}.song-complete-icon{font-size:52px;line-height:1}.song-complete-title{letter-spacing:-.02em;margin:0;font-size:28px;font-weight:800}.song-complete-stats{gap:32px;display:flex}.song-stat{flex-direction:column;align-items:center;gap:2px;display:flex}.song-stat-v{color:var(--accent);font-size:28px;font-weight:800}.song-stat-l{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-size:11px;font-weight:600}.song-complete-actions{gap:10px;margin-top:8px;display:flex}.song-countdown-overlay{z-index:30;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#07071ad1;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex;position:absolute;inset:0}.song-countdown-num{color:#fff;text-shadow:0 0 30px #0cfc,0 0 80px #0cf6;letter-spacing:-.04em;font-size:96px;font-weight:900;line-height:1}.song-countdown-go{color:#ffe600;text-shadow:0 0 30px #ffe600e6,0 0 80px #ffe60080;font-size:64px}.song-countdown-title{color:#ffffff8c;letter-spacing:.03em;font-size:18px;font-weight:600}.icon-btn{width:30px;height:30px;color:var(--text-muted);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,border-color .15s,color .15s;display:flex}.icon-btn:hover{border-color:var(--border);color:var(--text);background:#ffffff0f}.kbd-badge{opacity:.75;border:1px solid var(--border);background:#ffffff0a;border-radius:6px;padding:2px 6px;font-size:14px}.splash-sub{color:var(--text-muted);opacity:.55;margin-top:6px;font-size:11px}.settings-backdrop{z-index:200;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0006;position:fixed;inset:0}.settings-panel{z-index:201;background:var(--bg-card);border-left:1px solid var(--border);flex-direction:column;width:320px;display:flex;position:fixed;top:0;bottom:0;right:0;box-shadow:-12px 0 40px #0006}.settings-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.settings-title{letter-spacing:.04em;font-size:14px;font-weight:700}.settings-close{width:28px;height:28px;color:var(--text-muted);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:6px;justify-content:center;align-items:center;font-size:14px;transition:background .15s;display:flex}.settings-close:hover{color:#f35;background:#ff335526;border-color:#ff33554d}.settings-body{flex-direction:column;flex:1;gap:20px;padding:16px;display:flex;overflow-y:auto}.settings-label{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:8px;font-size:11px;font-weight:700;display:block}.settings-row{flex-wrap:wrap;gap:6px;display:flex}.settings-chip{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;padding:6px 12px;font-size:12px;font-weight:500;transition:all .15s}.settings-chip:hover{border-color:var(--accent);color:var(--text)}.settings-chip-active{border-color:var(--accent);color:var(--accent);background:#00ccff1f;font-weight:700}.settings-toggle{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:20px;padding:5px 14px;font-size:12px;font-weight:600;transition:all .15s}.settings-toggle-on{color:#0f8;background:#00ff881f;border-color:#0f8}.settings-bpm-row{align-items:center;gap:12px;margin-top:6px;display:flex}.settings-bpm-btn{border:1px solid var(--border);width:32px;height:32px;color:var(--text);cursor:pointer;background:#ffffff0a;border-radius:8px;justify-content:center;align-items:center;font-size:18px;font-weight:700;transition:background .12s;display:flex}.settings-bpm-btn:hover{border-color:var(--accent);background:#00ccff1a}.settings-bpm-val{text-align:center;min-width:80px;font-size:18px;font-weight:800}.settings-keyboard-map{flex-wrap:wrap;gap:4px;margin-top:6px;display:flex}.settings-key-hint{flex-direction:column;align-items:center;gap:2px;display:flex}.settings-key-cap{border:1px solid var(--border);background:#ffffff0f;border-radius:4px;justify-content:center;align-items:center;width:22px;height:22px;font-size:10px;font-weight:700;display:flex}.settings-key-note{font-size:8px;font-weight:600}.settings-hint-text{color:var(--text-muted);margin-top:8px;font-size:11px;line-height:1.5}.stats-overlay{z-index:150;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.stats-card{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;flex-direction:column;width:460px;max-width:95vw;max-height:85vh;display:flex;overflow-y:auto;box-shadow:0 24px 80px #00000080}.stats-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:18px 20px 14px;display:flex}.stats-title{font-size:15px;font-weight:700}.stats-level-block{border-bottom:1px solid var(--border);align-items:center;gap:16px;padding:18px 20px;display:flex}.stats-level-circle{border:3px solid var(--accent);border-radius:50%;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;width:64px;height:64px;display:flex;box-shadow:0 0 20px #00ccff40}.stats-level-num{font-size:22px;font-weight:900;line-height:1}.stats-level-lbl{opacity:.6;text-transform:uppercase;font-size:9px;font-weight:600}.stats-level-info{flex:1}.stats-level-name{margin-bottom:8px;font-size:15px;font-weight:700;display:block}.stats-xp-bar-track{background:#ffffff12;border-radius:3px;height:6px;margin-bottom:6px;overflow:hidden}.stats-xp-bar-fill{background:linear-gradient(to right, var(--accent), var(--accent-2));border-radius:3px;height:100%}.stats-xp-text{color:var(--text-muted);font-size:11px}.stats-grid{background:var(--border);border-bottom:1px solid var(--border);grid-template-columns:repeat(4,1fr);gap:1px;display:grid}.stats-tile{background:var(--bg-card);flex-direction:column;align-items:center;gap:4px;padding:14px 8px;display:flex}.stats-tile-val{color:var(--accent);font-size:22px;font-weight:800}.stats-tile-lbl{color:var(--text-muted);text-align:center;font-size:10px;font-weight:600}.stats-section-title{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);padding:14px 20px 8px;font-size:11px;font-weight:700;display:block}.stats-lessons{border-bottom:1px solid var(--border)}.stats-lesson-list{flex-direction:column;gap:4px;padding:0 12px 12px;display:flex}.stats-lesson-row{background:#ffffff05;border-radius:8px;align-items:center;gap:8px;padding:7px 8px;display:flex}.stats-lesson-icon{flex-shrink:0;font-size:14px}.stats-lesson-name{flex:1;font-size:12px;font-weight:500}.stats-lesson-stars{color:#ffe600;flex-shrink:0;font-size:11px}.stats-lesson-score{color:var(--text-muted);text-align:right;min-width:28px;font-size:11px;font-weight:700}.stats-empty{text-align:center;color:var(--text-muted);padding:24px 20px;font-size:13px}.stats-footer{justify-content:center;padding:12px 20px;display:flex}.metro-widget{border:1px solid var(--border);background:#ffffff08;border-radius:10px;flex-shrink:0;align-self:flex-start;align-items:center;gap:6px;margin-bottom:6px;padding:6px 12px;display:flex}.metro-beat{background:#fff3;border-radius:50%;width:10px;height:10px}.metro-beat-down{background:var(--accent)!important}.metro-beat-active{background:#ffffffb3}.metro-bpm{color:var(--text-muted);margin-left:4px;font-size:11px;font-weight:700}.song-progress-track{background:#ffffff1a;border-radius:2px;width:100%;height:3px;margin:4px 0;overflow:hidden}.song-progress-fill{background:linear-gradient(to right, var(--accent), var(--accent-2));border-radius:2px;height:100%;transition:width .3s linear}.song-upcoming{flex-wrap:wrap;justify-content:center;align-items:center;gap:5px;display:flex}.song-upcoming-label{color:#fff6;flex-shrink:0;font-size:10px}.song-upcoming-note{border:1px solid;border-radius:6px;padding:2px 7px;font-size:11px;font-weight:700}.song-countdown-hint{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:16px;flex-direction:column;align-items:center;gap:10px;margin-top:8px;padding:16px 24px;display:flex}.song-countdown-hint-label{color:#ffffffb3;font-size:14px;font-weight:600}.song-countdown-hint-notes{flex-wrap:wrap;justify-content:center;gap:10px;display:flex}.song-countdown-hint-note{border:2px solid;border-radius:12px;padding:8px 16px;font-size:20px;font-weight:800;animation:1s ease-in-out infinite hint-pulse}@keyframes hint-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.06)}}.song-countdown-hint-sub{color:#ffffff8c;margin:0;font-size:13px}.streak-badge{cursor:default;-webkit-user-select:none;user-select:none;background:#ffa0001f;border:1px solid #ffa0004d;border-radius:20px;align-items:center;gap:4px;padding:4px 9px;font-size:13px;display:flex}.streak-count{color:orange;font-size:12px;font-weight:700}.sb-stars{gap:1px;margin-top:3px;display:flex}.sb-star-filled{color:gold;text-shadow:0 0 6px #ffd700b3;font-size:11px}.sb-star-empty{color:#ffffff26;font-size:11px}.sb-song-locked{opacity:.45;cursor:not-allowed!important}.sb-lock-hint{color:var(--text-muted);font-size:10px;font-style:italic}.song-complete-stars{justify-content:center;gap:8px;margin:8px 0 4px;display:flex}.complete-star-filled{color:gold;text-shadow:0 0 16px #ffd700cc;font-size:36px;display:inline-block}.complete-star-empty{color:#ffffff1f;font-size:36px;display:inline-block}.sheet-controls{z-index:5;background:#0d0f1ce6;border-top:1px solid #ffffff1a;flex-shrink:0;align-items:center;gap:10px;padding:10px 16px;display:flex}.sheet-ctrl-btn{width:36px;height:36px;color:var(--text);cursor:pointer;appearance:none;background:#ffffff12;border:1px solid #ffffff26;border-radius:8px;outline:none;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:14px;line-height:1;transition:background .15s,border-color .15s;display:flex}.sheet-ctrl-btn:hover{background:#ffffff24;border-color:#ffffff4d}.sheet-ctrl-btn:active{background:#fff3;transform:scale(.95)}.sheet-ctrl-play{width:44px;height:36px;color:var(--accent);background:#00d2ff1a;border-color:#00d2ff66;font-size:16px}.sheet-ctrl-play:hover{background:#00d2ff2e;border-color:#00d2ff99}.sheet-speed-wrapper{flex:1;align-items:center;gap:10px;display:flex}.sheet-speed-slider{appearance:none;cursor:pointer;height:5px;accent-color:var(--accent);background:#ffffff26;border-radius:3px;outline:none;flex:1}.sheet-speed-slider::-webkit-slider-thumb{appearance:none;background:var(--accent);cursor:pointer;border-radius:50%;width:16px;height:16px;box-shadow:0 0 8px #00d2ff80}.sheet-speed-slider::-moz-range-thumb{background:var(--accent);cursor:pointer;border:none;border-radius:50%;width:16px;height:16px}.sheet-speed-label{color:var(--accent);text-align:right;min-width:56px;font-size:12px;font-weight:700}.achievement-toast{z-index:9999;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#0d0f1cf2;border:1px solid #00d2ff59;border-radius:16px;align-items:center;gap:12px;min-width:240px;padding:14px 22px;display:flex;position:fixed;bottom:32px;left:50%;transform:translate(-50%);box-shadow:0 8px 32px #00000080,0 0 0 1px #00d2ff1a}.achievement-toast-icon{flex-shrink:0;font-size:28px}.achievement-toast-text{flex-direction:column;gap:2px;display:flex}.achievement-toast-label{letter-spacing:.1em;text-transform:uppercase;color:var(--accent);font-size:10px;font-weight:700}.achievement-toast-title{color:var(--text);font-size:15px;font-weight:700}.stats-badges-section{margin-top:12px}.stats-badge-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px;margin-top:8px;display:grid}.stats-badge-item{border:1px solid var(--border);background:var(--bg-card);cursor:default;text-align:center;border-radius:10px;flex-direction:column;align-items:center;gap:4px;padding:10px 6px;display:flex}.stats-badge-earned{background:#ffd7000f;border-color:#ffd7004d}.stats-badge-locked{opacity:.38}.stats-badge-icon{font-size:22px}.stats-badge-title{color:var(--text-muted);font-size:9px;font-weight:600;line-height:1.2}.stats-streak-banner{background:#ffa0001a;border:1px solid #ffa00040;border-radius:10px;justify-content:center;align-items:center;gap:8px;margin-bottom:12px;padding:10px;display:flex}.stats-streak-fire{font-size:20px}.stats-streak-text{color:orange;font-size:14px;font-weight:700}.defter-layout{flex-direction:column;flex:1;height:100%;display:flex;overflow:hidden}.defter-root{background:var(--bg-surface);flex-direction:column;height:100%;display:flex;overflow:hidden}.defter-toolbar{background:#0e1020;border-bottom:1px solid #ffffff1a;flex-wrap:wrap;flex-shrink:0;align-items:center;gap:12px;padding:10px 16px;display:flex}.defter-toolbar-left,.defter-toolbar-center,.defter-toolbar-right{align-items:center;gap:8px;display:flex}.defter-toolbar-center{flex:1;justify-content:center}.defter-toolbar-right{margin-left:auto}.defter-btn{color:var(--text);cursor:pointer;white-space:nowrap;appearance:none;background:#1e2238;border:1px solid #ffffff47;border-radius:8px;outline:none;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:500;line-height:1.4;text-decoration:none;transition:background .15s,border-color .15s,opacity .15s;display:inline-flex}.defter-btn:hover{background:#262d48;border-color:#fff6}.defter-btn:active{transform:scale(.96)}.defter-btn-record{color:#ff6060;background:#2a1520;border-color:#ff505099}.defter-btn-record:hover{background:#381a28}.defter-btn-finish{color:#fa0;background:#241a08;border-color:#ffaa008c}.defter-btn-finish:hover{background:#302208}.defter-btn-play{color:#3ddc74;letter-spacing:.02em;background:#0a2016;border-color:#3cdc648c;font-weight:700}.defter-btn-play:hover{background:#0f2e1e;border-color:#3cdc64bf}.defter-btn-play-active{color:#ff6060;background:#2a0e0e;border-color:#ff505099;animation:1.4s ease-in-out infinite defter-play-pulse}@keyframes defter-play-pulse{0%,to{box-shadow:0 0 #ff50504d}50%{box-shadow:0 0 0 5px #ff505000}}.defter-btn-print{color:var(--accent);background:#0a1e26;border-color:#00d2ff80}.defter-btn-print:hover{background:#0e2a36}.defter-btn-export{color:#b39dff;background:#180e30;border-color:#7c4dff80}.defter-btn-export:hover{background:#221440}.defter-btn-import{color:var(--text-muted);background:#191d2e;border-color:#ffffff38;font-size:12px}.defter-btn-import:hover{color:var(--text);background:#1e2238}.defter-btn-reset{color:var(--text-muted);background:#191d2e;border-color:#ffffff2e;padding:6px 10px;font-size:15px}.defter-btn-reset:hover{background:#1e2238}.defter-export-group{align-items:center;gap:6px;display:flex}.defter-rec-dot{background:#f35;border-radius:50%;flex-shrink:0;width:8px;height:8px}.defter-rec-dot-live{animation:1.1s ease-in-out infinite recPulse}@keyframes recPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}.defter-recording-label{color:#ff6060;align-items:center;gap:6px;font-size:13px;font-weight:600;display:flex}.defter-measure-count{color:var(--text-muted);font-size:12px;font-weight:400}.defter-bpm-badge{color:var(--accent);letter-spacing:.02em;background:#00d2ff14;border:1px solid #00d2ff59;border-radius:20px;align-items:center;padding:3px 12px;font-size:13px;font-weight:600;display:inline-flex}.defter-detecting-label{color:var(--accent)!important}.defter-scroll{flex-direction:column;flex:1;align-items:stretch;padding:20px 24px 40px;display:flex;position:relative;overflow:hidden auto}.defter-scroll:before{content:"aspiano";letter-spacing:-.04em;color:#ffffff07;pointer-events:none;z-index:0;-webkit-user-select:none;user-select:none;white-space:nowrap;font-size:clamp(48px,10vw,96px);font-weight:800;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.defter-empty{width:100%;height:100%;min-height:300px;color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.defter-empty-icon{font-size:56px}.defter-empty-text{white-space:pre-line;max-width:400px;font-size:14px;line-height:1.6}.defter-print-area{box-sizing:border-box;background:#fff;border-radius:6px;width:100%;padding:16px;box-shadow:0 4px 24px #00000080}.staff-svg{width:100%;height:auto;display:block}@media print{body>*{display:none!important}.app-shell{display:block!important}.header,.defter-toolbar,.defter-empty,.defter-scroll>:not(.defter-print-area){display:none!important}.defter-scroll,.defter-root,.defter-layout,.main-content,.app-shell{background:#fff!important;height:auto!important;display:block!important;overflow:visible!important}.defter-print-area{page-break-inside:auto;box-shadow:none!important;border-radius:0!important;padding:0!important}.staff-svg{width:100%!important;height:auto!important}}.guide-page{background:var(--bg);color:var(--text);font-family:SF Pro Display,Inter,system-ui,sans-serif;position:fixed;inset:0;overflow:hidden auto}.guide-header{z-index:30;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#07080feb;justify-content:space-between;align-items:center;height:60px;padding:0 32px;display:flex;position:sticky;top:0}.guide-logo{letter-spacing:-.02em;color:var(--text);font-size:20px;font-weight:700;text-decoration:none}.guide-logo-accent{color:var(--accent)}.guide-nav{align-items:center;gap:16px;display:flex}.guide-nav-link{color:var(--text-muted);font-size:13px;text-decoration:none;transition:color .15s}.guide-nav-link:hover{color:var(--text)}.guide-nav-cta{color:var(--bg);background:var(--accent);border-radius:8px;padding:7px 16px;font-size:13px;font-weight:600;text-decoration:none;transition:opacity .15s}.guide-nav-cta:hover{opacity:.85}.guide-main{max-width:760px;margin:0 auto;padding:60px 24px 80px}.guide-hero{text-align:center;margin-bottom:64px}.guide-hero-title{letter-spacing:-.03em;margin:0 0 16px;font-size:clamp(28px,5vw,48px);font-weight:800;line-height:1.15}.guide-accent{color:var(--accent)}.guide-hero-sub{color:var(--text-muted);max-width:560px;margin:0 auto 24px;font-size:16px;line-height:1.6}.guide-badges{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.guide-badge{color:var(--accent);background:#00d4ff14;border:1px solid #00d4ff33;border-radius:100px;padding:4px 12px;font-size:12px;font-weight:600}.guide-sections{flex-direction:column;gap:0;display:flex}.guide-section{border-bottom:1px solid var(--border);gap:24px;padding:32px 0;display:flex}.guide-section:first-child{border-top:1px solid var(--border)}.guide-section-icon{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;margin-top:2px;font-size:26px;display:flex}.guide-section-content{flex:1;min-width:0}.guide-section-title{letter-spacing:-.01em;color:var(--text);margin:0 0 10px;font-size:18px;font-weight:700}.guide-section-body{color:var(--text-muted);margin:0 0 12px;font-size:14px;line-height:1.75}.guide-section-body:last-child{margin-bottom:0}.guide-faq{margin-top:64px}.guide-faq-title{letter-spacing:-.02em;margin:0 0 28px;font-size:22px;font-weight:700}.guide-faq-item{border-left:2px solid var(--border-glow);margin-bottom:28px;padding-left:20px}.guide-faq-item h3{color:var(--text);margin:0 0 6px;font-size:15px;font-weight:600}.guide-faq-item p{color:var(--text-muted);margin:0;font-size:13px;line-height:1.7}.guide-cta-block{text-align:center;background:var(--bg-card);border:1px solid var(--border);border-radius:20px;margin-top:64px;padding:48px 32px}.guide-cta-text{color:var(--text-muted);margin:0 0 20px;font-size:16px}.guide-cta-btn{color:var(--bg);background:var(--accent);border-radius:12px;padding:14px 32px;font-size:15px;font-weight:700;text-decoration:none;transition:opacity .15s,transform .15s;display:inline-block}.guide-cta-btn:hover{opacity:.88;transform:translateY(-1px)}.guide-footer{text-align:center;color:var(--text-muted);border-top:1px solid var(--border);padding:24px;font-size:12px}.guide-footer a{color:var(--accent);text-decoration:none}@media (max-width:540px){.guide-header{padding:0 16px}.guide-main{padding:40px 16px 60px}.guide-section{flex-direction:column;gap:16px}.guide-section-icon{width:40px;height:40px;font-size:22px}}.midi-req-box{background:#00d4ff0a;border:1px solid #00d4ff26;border-radius:16px;margin-bottom:48px;padding:24px 28px}.midi-req-title{text-transform:uppercase;letter-spacing:.06em;color:var(--accent);margin:0 0 16px;font-size:14px;font-weight:700}.midi-req-list{flex-direction:column;gap:12px;margin:0;padding:0;list-style:none;display:flex}.midi-req-list li{color:var(--text-muted);align-items:flex-start;gap:12px;font-size:13px;line-height:1.6;display:flex}.midi-req-list li strong{color:var(--text)}.midi-req-icon{flex-shrink:0;margin-top:1px;font-size:18px}.midi-os-block{margin-bottom:48px}.midi-os-header{border-bottom:1px solid var(--border);align-items:center;gap:12px;margin-bottom:24px;padding-bottom:16px;display:flex}.midi-os-icon{font-size:28px}.midi-os-title{letter-spacing:-.02em;margin:0;font-size:22px;font-weight:800}.midi-method{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;margin-bottom:16px;padding:24px}.midi-method-title{align-items:center;gap:10px;margin:0 0 20px;font-size:16px;font-weight:700;display:flex}.midi-method-badge{text-transform:uppercase;letter-spacing:.05em;border-radius:100px;padding:3px 9px;font-size:11px;font-weight:700}.midi-badge-usb{color:var(--accent);background:#00d4ff1f;border:1px solid #00d4ff40}.midi-badge-bt{color:var(--accent-2);background:#7c4dff1f;border:1px solid #7c4dff40}.midi-steps{flex-direction:column;gap:14px;margin:0 0 16px;padding:0;list-style:none;display:flex}.midi-steps li{color:var(--text-muted);align-items:flex-start;gap:14px;font-size:13px;line-height:1.7;display:flex}.midi-steps li strong{color:var(--text)}.midi-steps li em{color:var(--text-muted);font-style:italic}.midi-step-num{width:24px;height:24px;color:var(--accent);background:#00d4ff1a;border:1px solid #00d4ff33;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-top:2px;font-size:11px;font-weight:700;display:flex}.midi-tip{color:var(--text-muted);background:#ffaa000f;border:1px solid #fa03;border-radius:10px;padding:12px 16px;font-size:12px;line-height:1.6}.midi-tip strong{color:#fa0}.setup-howto-link{text-align:center;color:var(--accent);opacity:.8;margin-top:12px;font-size:12px;text-decoration:none;transition:opacity .15s;display:block}.setup-howto-link:hover{opacity:1}.mobile-warning{display:none}@media (max-width:767px){.mobile-warning{z-index:9999;background:var(--bg);text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:32px 24px;display:flex;position:fixed;inset:0}.mobile-warning-icon{margin-bottom:20px;font-size:56px}.mobile-warning-title{letter-spacing:-.02em;color:var(--text);margin:0 0 12px;font-size:22px;font-weight:800}.mobile-warning-desc{color:var(--text-muted);max-width:320px;margin:0 0 28px;font-size:14px;line-height:1.7}.mobile-warning-logo{color:var(--text-muted);letter-spacing:-.01em;font-size:16px;font-weight:700}.mobile-warning-logo span{color:var(--accent)}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
