@font-face{font-family:Fraunces Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/fraunces-vietnamese-wght-normal-CnvboYUG.woff2)format("woff2-variations");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Fraunces Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/fraunces-latin-ext-wght-normal-Ca2vKHc0.woff2)format("woff2-variations");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Fraunces Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/fraunces-latin-wght-normal-ukD16Tqj.woff2)format("woff2-variations");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Instrument Sans;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/instrument-sans-latin-ext-400-normal-Q_nF8v4l.woff2)format("woff2"),url(/assets/instrument-sans-latin-ext-400-normal-r32jotim.woff)format("woff");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Instrument Sans;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/instrument-sans-latin-400-normal-DRC__1Mx.woff2)format("woff2"),url(/assets/instrument-sans-latin-400-normal-D1W7dsQl.woff)format("woff");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Instrument Sans;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/instrument-sans-latin-ext-500-normal-CTEe1bJa.woff2)format("woff2"),url(/assets/instrument-sans-latin-ext-500-normal-CAxz3nsc.woff)format("woff");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Instrument Sans;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/instrument-sans-latin-500-normal-Dk9ku72i.woff2)format("woff2"),url(/assets/instrument-sans-latin-500-normal-Z6ESRlEs.woff)format("woff");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Instrument Sans;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/instrument-sans-latin-ext-600-normal-BsaQcF38.woff2)format("woff2"),url(/assets/instrument-sans-latin-ext-600-normal-DMks36a2.woff)format("woff");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Instrument Sans;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/instrument-sans-latin-600-normal-B7fBEWYG.woff2)format("woff2"),url(/assets/instrument-sans-latin-600-normal-B9e8oLYv.woff)format("woff");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Libre Baskerville;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/libre-baskerville-latin-ext-400-normal-DehDhP4C.woff2)format("woff2"),url(/assets/libre-baskerville-latin-ext-400-normal-Dm_CMUlS.woff)format("woff");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Libre Baskerville;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/libre-baskerville-latin-400-normal-C42RasBZ.woff2)format("woff2"),url(/assets/libre-baskerville-latin-400-normal-B6A5kCEq.woff)format("woff");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Libre Baskerville;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/libre-baskerville-latin-ext-700-normal-URU-TBJY.woff2)format("woff2"),url(/assets/libre-baskerville-latin-ext-700-normal-CwmVKpN0.woff)format("woff");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Libre Baskerville;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/libre-baskerville-latin-700-normal-CLGq6Yj4.woff2)format("woff2"),url(/assets/libre-baskerville-latin-700-normal-DFRs2Bxw.woff)format("woff");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--primary:#2c3e50;--secondary:#ecf0f1;--accent:#14b8a6;--bg:#fff;--text:#34495e;--text-light:#7f8c8d;--border:#dee2e6;--sidebar-width:280px;--topbar-height:52px;--controls-height:56px;--keyboard-height:80px;--ios-window-controls-left:0px;--ios-safe-area-bottom:env(safe-area-inset-bottom,0px)}html.ios-simulator{--ios-safe-area-bottom:0px}*{box-sizing:border-box;margin:0;padding:0}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.skip-to-content{z-index:9999;background:var(--accent);color:#fff;border-radius:0 0 8px;width:1px;height:1px;padding:12px 24px;font-size:14px;font-weight:600;text-decoration:none;position:absolute;top:auto;left:-9999px;overflow:hidden}.skip-to-content:focus{width:auto;height:auto;position:fixed;top:0;left:0;overflow:visible}html{height:100dvh}body,#root{width:100%;height:100%;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none;font-family:Instrument Sans,-apple-system,BlinkMacSystemFont,sans-serif;overflow:hidden}input,textarea{-webkit-user-select:text;user-select:text}.loading-screen{background:#2c3e50;justify-content:center;align-items:center;height:100%;display:flex}.auth-overlay{z-index:1000;background:linear-gradient(135deg,#2c3e50 0%,#34495e 50%,#2c3e50 100%);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.auth-container{width:100%;max-width:400px;padding:24px}.auth-brand{text-align:center;margin-bottom:32px}.auth-title{color:#ecf0f1;letter-spacing:-.5px;margin-top:16px;font-family:Fraunces Variable,serif;font-size:32px;font-weight:700}.auth-subtitle{color:#ecf0f1b3;margin-top:6px;font-size:14px}.auth-form{-webkit-backdrop-filter:blur(20px);background:#ffffff14;border:1px solid #ffffff1f;border-radius:16px;padding:28px}.form-group{margin-bottom:16px}.form-group label{color:#ecf0f1cc;margin-bottom:6px;font-size:13px;font-weight:500;display:block}.form-group input{color:#ecf0f1;background:#ffffff0f;border:1px solid #ffffff26;border-radius:10px;outline:none;width:100%;padding:12px 14px;font-family:inherit;font-size:15px;transition:border-color .2s}.form-group input:focus{border-color:var(--accent)}.form-group input::placeholder{color:#ecf0f159}.form-error{color:var(--accent);margin-bottom:12px;font-size:13px}.form-success{color:#2ecc71;text-align:center;background:#2ecc711a;border-radius:6px;margin-bottom:12px;padding:12px;font-size:14px}.auth-switch{text-align:center;color:#ecf0f199;margin-top:16px;font-size:13px}.auth-switch a,.auth-form a{color:var(--accent);font-weight:500;text-decoration:none}.auth-form a:hover{text-decoration:underline}.btn{cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-family:inherit;font-size:14px;font-weight:600;transition:all .15s;display:inline-flex}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:#0d9488}.btn-primary:active{transform:scale(.98)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:var(--secondary);color:var(--text)}.btn-secondary:hover{background:#d5dbdb}.btn-full{width:100%}.btn-sm{border-radius:8px;padding:6px 14px;font-size:13px}.icon-btn{color:#fff;cursor:pointer;background:0 0;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:background .15s;display:flex}.icon-btn:hover{background:#ffffff1a}.app{flex-direction:column;height:100%;display:flex}.native-audio-status{border:1px solid #0000;border-radius:12px;align-items:center;gap:10px;margin:8px 12px 0;padding:9px 12px;display:flex;position:relative;overflow:hidden}.native-audio-status-content{flex-direction:column;min-width:0;display:flex}.native-audio-status-title{letter-spacing:.04em;text-transform:uppercase;opacity:.85;font-size:11px;font-weight:700}.native-audio-status-message{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;line-height:1.2;overflow:hidden}.native-audio-status-indicator{border-radius:999px;flex-shrink:0;width:10px;height:10px}.native-audio-status-info{color:#1e4f7d;background:linear-gradient(#f8fcff 0%,#eff7fe 100%);border-color:#cce0f2}.native-audio-status-info .native-audio-status-indicator{background:var(--accent)}.native-audio-status-error{color:#9b322a;background:linear-gradient(#fff8f7 0%,#fdefea 100%);border-color:#f0c8c1}.native-audio-status-error .native-audio-status-indicator{background:#e66a57}.native-audio-status-warning{color:#8a5a00;background:linear-gradient(#fffbf0 0%,#fef3d8 100%);border-color:#f0d89a}.native-audio-status-warning .native-audio-status-indicator{background:#e0a82e}.native-audio-status.is-active-download:after{content:"";background:linear-gradient(90deg,#0000 0%,#14b8a6e6 50%,#0000 100%);height:2px;animation:1.3s linear infinite native-audio-download-sweep;position:absolute;inset:auto 0 0;transform:translate(-100%)}@keyframes native-audio-download-sweep{0%{transform:translate(-100%)}to{transform:translate(100%)}}.app-body{flex:1;display:flex;position:relative;overflow:hidden}.top-bar{height:calc(var(--topbar-height) + env(safe-area-inset-top,0px));padding-top:env(safe-area-inset-top,0px);background:var(--primary);padding-left:calc(12px + env(safe-area-inset-left,0px) + var(--ios-window-controls-left));z-index:300;touch-action:manipulation;border-bottom:1px solid #14b8a64d;flex-shrink:0;align-items:center;gap:12px;padding-right:12px;display:flex;position:relative}.top-bar-left{flex-shrink:0;align-items:center;gap:8px;display:flex}.brand-mini{align-items:center;gap:8px;display:flex}.brand-mini .brand-name{color:#ececec;font-family:Fraunces Variable,serif;font-size:16px;font-weight:700}.brand-mini svg{display:block}.top-bar-center{text-align:center;flex:1;min-width:0}.file-title{color:#ffffff8c;white-space:nowrap;text-overflow:ellipsis;letter-spacing:.01em;font-family:Instrument Sans,sans-serif;font-size:14px;font-weight:500;overflow:hidden}.file-title.active{color:#fff;font-size:15px;font-weight:600}.top-bar-right{flex-shrink:0;align-items:center;gap:8px;margin-left:auto;display:flex}.midi-status{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:20px;align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:500;transition:all .2s;display:flex}.midi-status.disconnected{color:#c0392b;background:#fdecea}.midi-status.connected{color:#27ae60;background:#e8f8f0}.midi-status.unsupported{color:#e67e22;background:#fef3e2}.guest-auth-actions{align-items:center;gap:6px;display:flex}.btn-ghost-subtle{border:1px solid var(--border);color:var(--text-light);cursor:pointer;white-space:nowrap;background:0 0;border-radius:8px;padding:5px 12px;font-size:13px;font-weight:500;transition:border-color .15s,color .15s,background .15s}.btn-ghost-subtle:hover{border-color:var(--accent);color:var(--accent);background:#14b8a60a}.user-menu{position:relative}.dropdown{background:var(--bg);border:1px solid var(--border);z-index:100;border-radius:10px;min-width:180px;margin-top:4px;position:absolute;top:100%;right:0;overflow:hidden;box-shadow:0 8px 24px #0000001f}.dropdown-header{color:var(--text);border-bottom:1px solid var(--border);padding:12px 16px;font-size:13px;font-weight:600}.dropdown-item{width:100%;color:var(--text);text-align:left;cursor:pointer;background:0 0;border:none;padding:10px 16px;font-family:inherit;font-size:14px}.dropdown-item:hover{background:var(--secondary)}.midi-settings{position:relative}.midi-settings-trigger{color:var(--text-light);cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:6px;padding:6px 10px;font-size:12px;font-weight:500;transition:all .15s;display:flex}.midi-settings-trigger:hover{background:var(--secondary)}.midi-settings-trigger.connected{color:var(--accent)}.midi-settings-trigger.open{background:var(--secondary)}.midi-settings-trigger .chevron{transition:transform .2s}.midi-settings-trigger.open .chevron{transform:rotate(180deg)}.midi-settings-dropdown{background:var(--bg);border:1px solid var(--border);z-index:100;border-radius:12px;width:280px;padding:16px;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 8px 24px #0000001f}.midi-settings-section{margin-bottom:16px}.midi-settings-section:last-child{margin-bottom:0}.midi-settings-label{color:var(--text);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:12px;font-weight:600;display:block}.midi-mode-selector{background:var(--secondary);border-radius:8px;gap:4px;padding:4px;display:flex}.midi-mode-btn{color:var(--text-light);cursor:pointer;background:0 0;border:none;border-radius:6px;flex:1;padding:8px 4px;font-size:12px;font-weight:500;transition:all .15s}.midi-mode-btn:hover:not(:disabled){background:#ffffff80}.midi-mode-btn.active{background:var(--bg);color:var(--text);box-shadow:0 1px 3px #0000001a}.midi-mode-btn:disabled{opacity:.4;cursor:not-allowed}.midi-mode-description{color:var(--text-light);margin-top:6px;font-size:11px;font-style:italic}.midi-volume-slider{width:100%;accent-color:var(--accent)}.midi-volume-value{text-align:right;color:var(--text-light);margin-top:4px;font-size:12px}.midi-device-select{border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text);cursor:pointer;border-radius:8px;padding:8px 10px;font-size:13px}.midi-device-list-text{color:var(--text);background:var(--secondary);border-radius:8px;padding:8px 10px;font-size:13px}.midi-device-select:focus{border-color:var(--accent);outline:none}.midi-settings-info{color:var(--text-light);background:var(--secondary);border-radius:8px;margin-bottom:12px;padding:8px;font-size:12px}.midi-settings-info.midi-settings-warning{color:#e67e22;background:#fef3e2}.midi-settings-actions{gap:8px;margin-top:12px;display:flex}.midi-settings-btn{border:1px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:6px;padding:8px;font-size:12px;font-weight:500;transition:all .15s;display:flex}.midi-settings-btn:hover{background:var(--secondary)}.midi-last-message{color:var(--text-light);text-align:center;border-top:1px solid var(--border);margin-top:12px;padding-top:12px;font-size:11px}.sidebar{width:var(--sidebar-width);background:var(--bg);border-right:1px solid var(--border);top:calc(var(--topbar-height) + env(safe-area-inset-top,0px));z-index:200;flex-direction:column;flex-shrink:0;transition:transform .25s;display:flex;position:fixed;bottom:0;left:0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-backdrop{top:calc(var(--topbar-height) + env(safe-area-inset-top,0px));z-index:199;background:#0006;position:fixed;bottom:0;left:0;right:0}.sidebar-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px;display:flex}.sidebar-header h2{font-family:Fraunces Variable,serif;font-size:18px;font-weight:700}.upload-section{padding:12px 16px}.upload-area{cursor:pointer;text-align:center;background:#14b8a605;border:2px dashed #14b8a659;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:20px;transition:all .2s;display:flex}.upload-area:hover,.upload-area.dragover,.upload-area:focus-visible{border-color:var(--accent);background:#14b8a60a;outline:none}.upload-area:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.upload-text{color:var(--text);font-size:14px;font-weight:500}.upload-hint{color:var(--text-light);font-size:12px}.guest-cta-card{background:linear-gradient(145deg,#14b8a60f 0%,#14b8a605 100%);border:1px solid #14b8a638;border-radius:12px;flex-direction:column;gap:12px;padding:16px;display:flex}.guest-cta-headline{color:var(--primary);font-family:Fraunces Variable,serif;font-size:15px;font-weight:600;line-height:1.3}.guest-cta-benefits{flex-direction:column;gap:7px;list-style:none;display:flex}.guest-cta-benefit{color:var(--text-light);align-items:center;gap:7px;font-size:12px;line-height:1.4;display:flex}.guest-cta-benefit-check{color:#14b8a6;background:#14b8a61a;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;display:flex}.guest-cta-button{background:var(--accent);color:#fff;cursor:pointer;text-align:center;border:none;border-radius:8px;width:100%;padding:9px 16px;font-size:13px;font-weight:600;transition:background .15s,box-shadow .15s;box-shadow:0 4px 12px #14b8a633}.guest-cta-button:hover{background:#0d9488;box-shadow:0 6px 16px #14b8a64d}.upload-progress{background:var(--secondary);border-radius:6px;margin-top:8px;overflow:hidden}.upload-progress-bar{background:var(--accent);width:60%;height:3px;animation:1.5s infinite progressAnim}@keyframes progressAnim{0%{transform:translate(-100%)}to{transform:translate(200%)}}.upload-progress-text{text-align:center;color:var(--text-light);padding:6px;font-size:12px;display:block}.file-list-container{flex:1;padding:8px 12px;overflow-y:auto}.file-list-empty{text-align:center;color:var(--text-light);padding:40px 20px}.file-list-empty p{margin-top:12px;font-size:14px}.file-list-empty .hint{margin-top:4px;font-size:12px}.file-item{margin-bottom:2px;position:relative}.file-item-main{cursor:pointer;width:100%;font:inherit;color:inherit;text-align:left;background:0 0;border:none;border-radius:10px;align-items:center;gap:10px;padding:10px 12px;transition:background .15s;display:flex}.file-item-main:hover{background:var(--secondary)}.file-item-main:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.file-item.active .file-item-main{background:#14b8a61a}.file-item-icon{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.file-item-icon.midi{color:var(--accent);background:#14b8a61f}.file-item-icon.pdf{color:var(--accent);background:#e74c3c1f}.file-item-info{flex:1;min-width:0}.file-item-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.file-item-meta{color:var(--text-light);margin-top:2px;font-size:11px}.file-item-meta.difficulty-row{align-items:center;gap:6px;display:flex}.file-item-delete{width:28px;height:28px;color:var(--text-light);cursor:pointer;opacity:0;z-index:1;background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;transition:all .15s;display:flex;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.file-item:hover .file-item-delete,.file-item:focus-within .file-item-delete{opacity:1}.file-item-delete:hover,.file-item-delete:focus-visible{color:var(--accent);opacity:1;background:#fdecea}.file-list-divider{color:var(--accent);text-transform:uppercase;letter-spacing:.8px;align-items:center;gap:8px;margin:8px 12px;font-size:11px;font-weight:600;display:flex}.file-list-divider:before,.file-list-divider:after{content:"";background:var(--border);flex:1;height:1px}.difficulty-stars{vertical-align:middle;gap:1px;display:inline-flex}.difficulty-unrated{font-style:italic}.main-content{flex-direction:column;flex:1;transition:margin-left .25s;display:flex;position:relative;overflow:hidden}.welcome-screen{flex:1;justify-content:center;align-items:center;padding:40px;display:flex}.welcome-inner{text-align:center;max-width:480px}.welcome-inner h2{color:var(--primary);margin-top:20px;font-family:Fraunces Variable,serif;font-size:24px;font-weight:700}.welcome-inner p{color:var(--text-light);margin-top:8px;font-size:14px;line-height:1.5}.welcome-features{flex-wrap:wrap;justify-content:center;gap:16px;margin-top:28px;display:flex}.feature{color:var(--text);align-items:center;gap:8px;font-size:13px;font-weight:500;display:flex}.notation-view{background:linear-gradient(#f9fbfd 0%,#f5f8fb 100%);flex-direction:column;flex:1;display:flex;overflow:hidden}.notation-title{color:var(--primary);text-align:center;letter-spacing:-.5px;margin:0;padding:24px 16px 8px;font-family:Fraunces Variable,serif;font-size:28px;font-weight:700}.notation-header{text-align:center;border-bottom:1px solid #2c3e5014;padding:14px 16px 8px}.notation-header .notation-title{padding:0}.notation-subtitle{color:var(--text-light);margin-top:6px;font-size:15px;font-weight:500}.notation-meta{color:var(--text-light);flex-wrap:wrap;justify-content:center;gap:8px 16px;margin-top:10px;font-size:12px;display:flex}.notation-meta-row{align-items:center;gap:6px;display:inline-flex}.notation-meta-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-light);font-weight:600}.notation-meta-value{color:var(--text);font-weight:500}.notation-scroll-wrapper{-webkit-overflow-scrolling:touch;flex:1;padding:12px;overflow:auto}.notation-container{background:var(--bg);touch-action:pan-y;-webkit-user-select:none;user-select:none;border:1px solid #2c3e5014;border-radius:12px;min-width:800px;max-width:1200px;min-height:400px;margin:0 auto;padding:20px;position:relative;overflow:visible;box-shadow:0 10px 28px #00000014}.notation-container svg,.notation-container text{-webkit-user-select:none;user-select:none}.notation-render{z-index:2;position:relative}.notation-render canvas{margin:0 auto;display:block}.notation-loop-overlay{pointer-events:none;z-index:5;position:absolute;inset:0}.notation-loop-rect{background:#14b8a61f;border:2px solid #14b8a680;border-radius:6px;position:absolute}.notation-loop-handle{pointer-events:auto;cursor:ew-resize;touch-action:none;background:#14b8a640;border:1px solid #14b8a680;border-radius:6px;width:12px;position:absolute;box-shadow:0 2px 6px #00000026}.notation-loop-handle:before{content:"";min-width:44px;min-height:44px;position:absolute;inset:-6px -16px}.notation-loop-handle.start{border-top-right-radius:3px;border-bottom-right-radius:3px}.notation-loop-handle.end{border-top-left-radius:3px;border-bottom-left-radius:3px}.notation-loop-remove{color:#1b1b1b;text-align:center;pointer-events:auto;cursor:pointer;background:#14b8a6f2;border:none;border-radius:999px;width:30px;height:30px;font-size:16px;font-weight:700;line-height:30px;position:absolute;box-shadow:0 2px 6px #00000040}.notation-container svg{overflow:visible}@media (width>=900px){.notation-container{width:100%;min-width:auto}}@media (width<=768px){.notation-container{width:100%;min-width:0;min-height:200px;padding:4px}}@media (width<=899px){.notation-scroll-wrapper{padding:8px}.notation-container{padding:12px}.notation-title{font-size:24px}}.pianolab-cursor{pointer-events:none;z-index:-1;background:#14b8a661;border-left:3px solid #14b8a6;border-radius:0 2px 2px 0;transition:left 80ms linear;position:absolute}.pdf-view{background:#f5f5f5;flex:1;padding:16px;overflow:auto}.pdf-container{flex-direction:column;align-items:center;gap:12px;max-width:900px;margin:0 auto;display:flex}.pdf-container canvas{background:#fff;border-radius:4px;max-width:100%;box-shadow:0 2px 8px #0000001a}.loading-overlay{z-index:20;background:#ffffffe6;flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex;position:absolute;inset:0}@keyframes badge-in{0%{opacity:0;transform:translateY(-8px)scale(.94)}to{opacity:1;transform:translateY(0)scale(1)}}.notation-rendering-badge{z-index:20;-webkit-backdrop-filter:blur(14px)saturate(1.6);background:#ffffffc7;border-radius:100px;align-items:center;gap:6px;padding:5px 11px 5px 7px;animation:.28s cubic-bezier(.34,1.4,.64,1) both badge-in;display:flex;position:absolute;top:12px;right:12px;box-shadow:0 2px 10px #00000014,0 0 0 .5px #00000012}.notation-rendering-badge span{color:#00000073;white-space:nowrap;letter-spacing:.01em;font-size:11.5px;font-weight:500}.notation-rendering-spinner{background:conic-gradient(var(--accent) 0deg, #14b8a626 210deg, #14b8a626 360deg);border-radius:50%;flex-shrink:0;width:14px;height:14px;animation:.7s linear infinite spin;position:relative}.notation-rendering-spinner:after{content:"";background:#ffffffc7;border-radius:50%;position:absolute;inset:2.5px}.loading-spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.controls-bar{height:calc(var(--controls-height) + var(--ios-safe-area-bottom));background:linear-gradient(to bottom, #2d4057 0%, var(--primary) 100%);padding:0 16px var(--ios-safe-area-bottom);touch-action:manipulation;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;border-top:1px solid #14b8a640;flex-shrink:0;align-items:center;gap:16px;display:flex}.app.keyboard-visible .controls-bar{height:var(--controls-height);padding-bottom:0}.controls-left,.controls-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.controls-left{gap:6px}.controls-center{flex:1;justify-content:center;align-items:center;gap:24px;display:flex}.prep-center{justify-content:flex-start}.control-btn{color:#ecf0f1;cursor:pointer;background:#ffffff1a;border:none;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;transition:background .15s;display:flex}.control-btn:hover{background:#fff3}.control-btn.active{background:var(--accent)}.hand-toggle-group{align-items:center;gap:4px;display:flex}.hand-toggle{letter-spacing:.3px;gap:6px;width:auto;min-width:52px;height:34px;padding:0 8px;font-size:10px;font-weight:700}.hand-toggle-label{opacity:.95;white-space:nowrap;font-size:10px;font-weight:600}.playalong-control{align-items:center;display:flex;position:relative}.playalong-btn{letter-spacing:.2px;gap:8px;width:auto;min-width:136px;padding:0 10px;font-size:11px;font-weight:700}.playalong-state{letter-spacing:.3px;text-transform:uppercase;color:#d1d5db;background:#ffffff29;border-radius:999px;margin-left:auto;padding:2px 6px;font-size:9px;font-weight:700}.playalong-state.is-on{color:#ecfeff;background:#14b8a673}.playalong-state.is-disabled{color:#d1d5db;background:#94a3b84d}.playalong-tooltip{white-space:nowrap;color:#e2e8f0;letter-spacing:.3px;pointer-events:none;opacity:0;background:#0f141af2;border:1px solid #ffffff14;border-radius:5px;padding:5px 10px;font-size:11px;font-weight:600;transition:opacity .12s,transform .12s;position:absolute;bottom:calc(100% + 8px);left:0;right:auto;transform:translateY(4px);box-shadow:0 4px 12px #0006}.playalong-tooltip:after{content:"";border-top:5px solid #0f141af2;border-left:5px solid #0000;border-right:5px solid #0000;position:absolute;bottom:-5px;left:18px}.playalong-control:hover .playalong-tooltip,.playalong-control:focus-within .playalong-tooltip{opacity:1;transform:translateY(0)}.controls-bar.is-compact .playalong-btn{gap:0;width:34px;min-width:34px;padding:0}.controls-bar.is-compact .playalong-btn span:not(.playalong-state),.controls-bar.is-compact .playalong-state{display:none}.controls-bar.is-compact .hand-toggle{justify-content:center;width:34px;min-width:34px;padding:0}.controls-bar.is-compact .hand-toggle-label{display:none}.midi-audio-control{background:#ffffff0f;border-radius:10px;align-items:center;gap:8px;padding:0 6px;display:flex}.midi-audio-label{letter-spacing:.3px;text-transform:uppercase;color:#ecf0f1b3;font-size:11px;font-weight:600}.volume-bar{width:90px;accent-color:var(--accent)}.volume-bar:disabled{opacity:.4}.tempo-control,.measure-control{align-items:center;gap:8px;display:flex}.tempo-control label,.measure-control label{color:#ecf0f199;text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:500}.tempo-value,.measure-value{color:#ecf0f1;text-align:center;min-width:44px;font-size:14px;font-weight:600}.tempo-btn{color:#ecf0f1;cursor:pointer;background:#ffffff1a;border:none;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;font-weight:600;transition:background .15s;display:flex}.tempo-btn:hover{background:#fff3}.tempo-select{color:#ecf0f1;cursor:pointer;background:#ffffff1a;border:none;border-radius:6px;width:100%;padding:4px 6px;font-size:13px;font-weight:600}.prep-status-panel{background:#ffffff0f;border:1px solid #ffffff1a;border-radius:10px;justify-content:space-between;align-items:center;gap:10px;min-width:228px;padding:6px 10px;display:flex}.prep-progress-ring{flex-shrink:0;display:block}.prep-progress-ring-track{fill:none;stroke:#ffffff38;stroke-width:2px}.prep-progress-ring-value{fill:none;stroke:var(--accent);stroke-width:2.5px;stroke-linecap:round;transform-origin:50%;transition:stroke-dashoffset .3s;animation:1.2s ease-in-out infinite prep-pulse;transform:rotate(-90deg)}.prep-status-panel.is-failed .prep-progress-ring-value{stroke:#ff7b7b;animation:none}.prep-status-copy{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.prep-status-row{align-items:baseline;gap:6px;display:flex}.prep-status-title{color:#ecf0f1;letter-spacing:.1px;font-size:13px;font-weight:700}.prep-status-percent{color:#ecf0f1b3;font-size:10px;font-weight:700}.prep-status-meta{color:#ecf0f1a3;align-items:center;gap:6px;font-size:10px;font-weight:500;display:flex}.prep-status-error{color:#ffd6d6;font-size:11px;font-weight:600}.prep-fallback-btn{color:#ecf0f1eb;cursor:pointer;white-space:nowrap;background:#ffffff14;border:1px solid #ffffff38;border-radius:999px;justify-content:center;align-items:center;height:22px;padding:0 7px;font-size:10px;font-weight:600;transition:background .15s,border-color .15s;display:flex}.prep-fallback-btn:hover{background:#ffffff24;border-color:#ffffff57}@keyframes prep-pulse{0%,to{opacity:1}50%{opacity:.45}}.keyboard-container{padding:8px 16px calc(12px + var(--ios-safe-area-bottom));-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;background:linear-gradient(#253443 0%,#1e2d3c 100%);border-top:1px solid #14b8a64d;flex-shrink:0;overflow-x:auto}.piano-keyboard{height:var(--keyboard-height);margin:0 auto}.white-key{width:var(--white-key-width,18px);cursor:pointer;z-index:1;background:linear-gradient(#f8f8f8,#fff);border:1px solid #c8c8c8;border-radius:0 0 5px 5px;height:100%;transition:background 80ms}.white-key:hover{background:linear-gradient(#f0f0f0,#f5f5f5)}.white-key.active,.white-key.highlight{border-color:var(--accent);background:var(--accent)!important}.white-key.miss{border-color:#ef4444;background:#ef4444!important}.black-key{width:var(--black-key-width,12px);cursor:pointer;z-index:2;background:linear-gradient(#454545,#202020);border-radius:0 0 4px 4px;height:60%;transition:background 80ms;box-shadow:0 3px 6px #00000080}.black-key:hover{background:linear-gradient(#525252,#2e2e2e)}.black-key.active,.black-key.highlight{background:var(--accent)!important}.black-key.miss{background:#ef4444!important}.keyboard-container.compact .piano-keyboard{height:64px}.keyboard-container.compact .black-key{height:57%}@media (orientation:portrait) and (width>=744px) and (width<=1024px){:root{--controls-height:50px;--keyboard-height:68px}.notation-header{padding:10px 12px 2px}.notation-title{padding:12px 12px 4px;font-size:22px;line-height:1.2}.notation-subtitle{margin-top:4px;font-size:13px}.notation-meta{gap:6px 12px;margin-top:8px;font-size:11px}.notation-scroll-wrapper{padding:8px}.notation-container{width:100%;min-width:0;max-width:900px;padding:10px}.notation-container canvas,.notation-container svg{max-width:100%;height:auto}.controls-bar{padding:0 10px var(--ios-safe-area-bottom);gap:10px}.control-btn{border-radius:9px;width:34px;height:34px}.tempo-value,.measure-value{min-width:36px;font-size:13px}.tempo-btn{width:24px;height:24px}}@media (width>=768px){.sidebar:not(.open){display:none}}@media (width<=767px){.native-audio-status{border-radius:10px;gap:8px;margin:6px 8px 0;padding:8px 10px}.native-audio-status-title{font-size:10px}.native-audio-status-message{font-size:12px}.prep-status-panel{min-width:200px;padding:5px 8px}.prep-fallback-btn{height:20px;padding:0 6px;font-size:10px}.prep-status-meta{flex-wrap:wrap;gap:6px}.sidebar.open{width:100%}.midi-status-text{display:none}.controls-center{gap:12px}.tempo-control label,.measure-control label,.midi-audio-label{display:none}.volume-bar{width:70px}}@media (height<=600px){:root{--keyboard-height:60px}.white-key{width:14px}.black-key{width:9px}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#a0aec0}.landing-page{background:var(--bg);color:var(--text);--landing-ink:#0f1a24;--landing-cream:#f6f4ef;--landing-mist:#d8e2ea;--landing-glow:#14b8a659;--landing-shadow:#0c1b2a38;font-family:Instrument Sans,-apple-system,BlinkMacSystemFont,sans-serif;position:fixed;inset:0;overflow:hidden auto}.landing-header{z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding-top:env(safe-area-inset-top,0px);background:#0f1a24eb;border-bottom:1px solid #ffffff14;position:sticky;top:0}.landing-header-inner{justify-content:space-between;align-items:center;max-width:1200px;height:56px;margin:0 auto;padding:0 24px;display:flex}.landing-brand{align-items:center;gap:10px;display:flex}.landing-brand-name{color:#ecf0f1;font-family:Fraunces Variable,serif;font-size:20px;font-weight:700}.landing-nav{align-items:center;gap:10px;display:flex}.landing-container{max-width:1100px;margin:0 auto;padding:0 24px}.landing-container--wide{max-width:1200px}.landing-container--narrow{max-width:560px}.landing-hero .landing-container{max-width:1200px;margin:0 auto;padding-left:clamp(24px,5vw,80px);padding-right:clamp(24px,5vw,80px)}.landing-hero{text-align:left;background:radial-gradient(circle at 15% 15%,#14b8a659,#0000 45%),radial-gradient(circle at 80% 20%,#54709773,#0000 48%),linear-gradient(135deg,#0f1a24 0%,#1b2c3d 50%,#152130 100%);padding:96px 0 88px;position:relative;overflow:hidden}.landing-hero:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(circle at 25% 30%,#ffffff14,#0000 60%);height:120%;animation:12s ease-in-out infinite landing-glow;position:absolute;inset:-20% -10% auto}.landing-hero:after{content:"";opacity:.35;pointer-events:none;z-index:0;background:repeating-linear-gradient(#ffffff0d 0 1px,#0000 1px 18px);position:absolute;inset:0}.landing-hero-title{color:#ecf0f1;letter-spacing:-1px;z-index:1;opacity:0;margin:0 0 24px;padding:0;font-family:Fraunces Variable,serif;font-size:clamp(38px,6vw,68px);font-weight:700;line-height:1.1;animation:.9s forwards landing-rise;display:block;position:relative;transform:translateY(16px)}.landing-hero-notes{pointer-events:none;z-index:0;position:absolute;inset:0}.landing-hero-notes .note-symbol{color:#ecf0f1b3;opacity:.28;filter:drop-shadow(0 0 4px #0f1a2433);transform-origin:50%;animation:12s ease-in-out infinite note-play;display:block;position:absolute;transform:translate(-50%,-50%)}.landing-hero-notes .note-symbol svg{width:58px;height:auto;display:block;overflow:visible}.landing-hero-notes .note-symbol--single svg{width:38px}.landing-hero-notes .note-symbol--double svg{width:64px}.landing-hero-notes .note-symbol--whole svg{width:44px}.landing-hero-notes .note-symbol--half svg{width:32px}.landing-hero-notes .note-seq-1{animation-delay:0s;top:12%;left:57%}.landing-hero-notes .note-seq-2{animation-delay:2.2s;top:28%;left:83%}.landing-hero-notes .note-seq-3{animation-delay:4.4s;top:62%;left:70%}.landing-hero-notes .note-seq-4{animation-delay:6.6s;top:50%;left:94%}.landing-hero-notes .note-seq-5{animation-delay:8.8s;top:18%;left:87%}.landing-hero-notes .note-seq-6{opacity:.12;max-height:14px;animation-delay:1.1s;top:42%;left:3%;overflow:hidden}.landing-hero-notes .note-seq-6 svg{width:10px;height:14px;overflow:hidden}.landing-hero-notes .note-seq-7{animation-delay:5.5s;top:76%;left:78%}.landing-hero-notes .note-seq-8{opacity:.1;max-height:13px;animation-delay:3.3s;top:80%;left:7%;overflow:hidden}.landing-hero-notes .note-seq-8 svg{width:9px;height:13px;overflow:hidden}.landing-hero-line{margin-bottom:.12em;display:block}.landing-hero-line:last-child{margin-bottom:0}.landing-hero-prefix{display:inline}.landing-hero-rotator{align-items:baseline;min-width:13ch;height:1.4em;padding-bottom:.12em;padding-right:.3em;display:inline-flex;position:relative;overflow:hidden}.landing-hero-rotator:after{content:"Dein Klavier.";visibility:hidden;white-space:nowrap}.landing-hero-rotator span{opacity:0;white-space:nowrap;line-height:1.1;animation:9s infinite landing-rotate;position:absolute;top:0;left:0;transform:translateY(120%)}.landing-hero-rotator span:first-child,.landing-hero-rotator span:nth-child(2){animation-delay:1s}.landing-hero-rotator span:nth-child(3){animation-delay:4s}.landing-hero-rotator span:nth-child(4){animation-delay:7s}@media (width>=768px){.landing-hero-rotator span:first-child{animation-delay:0s}.landing-hero-rotator span:nth-child(3){animation-delay:3s}.landing-hero-rotator span:nth-child(4){animation-delay:6s}}.rotator-mobile{display:none}@media (width<=767px){.rotator-desktop{display:none}.rotator-mobile{display:inline}}.landing-hero-kicker{letter-spacing:.24em;text-transform:uppercase;color:#ecf0f18c;z-index:1;opacity:0;margin-bottom:18px;font-size:13px;animation:.8s forwards landing-rise;position:relative;transform:translateY(12px)}.landing-hero-sub{color:#ecf0f1d1;text-wrap:pretty;z-index:1;opacity:0;max-width:52ch;margin:0 0 32px;font-size:clamp(15px,2vw,18px);line-height:1.6;animation:.9s .1s forwards landing-rise;position:relative;transform:translateY(16px)}.landing-hero-actions{z-index:1;opacity:0;animation:1s .18s forwards landing-rise;position:relative;transform:translateY(16px)}.landing-hero-ctas{flex-wrap:wrap;justify-content:flex-start;gap:12px;display:flex}.landing-hero-ctas .btn{min-height:48px}@keyframes ios-banner-slide-down{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.ios-app-banner{z-index:9999;padding:10px 14px;padding-top:calc(10px + env(safe-area-inset-top));-webkit-backdrop-filter:blur(12px);color:#fff;background:#141416f0;border-bottom:1px solid #ffffff1a;align-items:center;gap:10px;animation:.3s cubic-bezier(.22,1,.36,1) ios-banner-slide-down;display:flex;position:fixed;top:0;left:0;right:0}.ios-app-banner-close{color:#ffffff80;cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:4px;display:flex}.ios-app-banner-icon{background:#0f2e2b;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex;overflow:hidden}.ios-app-banner-content{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.ios-app-banner-title{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.ios-app-banner-desc{color:#ffffff8c;white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.ios-app-banner-cta{color:#fff;white-space:nowrap;background:#14b8a6;border-radius:20px;flex-shrink:0;padding:6px 16px;font-size:13px;font-weight:600;text-decoration:none;transition:background .15s}.ios-app-banner-cta:hover{background:#0d9488}.app-store-badge{border-radius:10px;align-items:center;gap:9px;padding:9px 18px;line-height:1;text-decoration:none;transition:opacity .15s,background .15s;display:inline-flex}.app-store-badge:hover{opacity:.85}.app-store-badge--ghost{color:#fff;background:#ffffff1a;border:1px solid #ffffff38}.app-store-badge--ghost:hover{opacity:1;background:#ffffff2e}.app-store-badge--solid{color:#fff;background:#000;border:1px solid #000}.app-store-badge--solid:hover{opacity:1;background:#1a1a1a}.app-store-badge-logo{flex-shrink:0;width:20px;height:20px}.app-store-badge-text{flex-direction:column;gap:1px;font-family:-apple-system,BlinkMacSystemFont,Helvetica Neue,sans-serif;display:flex}.app-store-badge-line1{letter-spacing:.2px;opacity:.82;text-transform:none;font-size:10px;font-weight:400;line-height:1.2}.app-store-badge-line2{letter-spacing:-.4px;font-size:18px;font-weight:600;line-height:1.1}.landing-hero-app-store{margin-top:14px}@media (width>=768px){.landing-hero-actions{flex-flow:wrap;align-items:center;gap:20px;display:flex}.landing-hero-app-store{border-left:1px solid #ffffff26;margin-top:0;padding-left:20px}}.landing-cta-app-store{flex-direction:column;align-items:center;gap:12px;margin-top:32px;display:flex}.landing-cta-app-store-label{color:var(--text-light);text-transform:uppercase;letter-spacing:.08em;font-size:12px;font-weight:500}.landing-hero-login{z-index:1;opacity:0;margin-top:20px;animation:1s .28s forwards landing-rise;position:relative;transform:translateY(16px)}.landing-hero-link{color:#ecf0f1cc;background:0 0;border:1px solid #ecf0f140;border-radius:999px;padding:8px 16px;font-size:13px}.landing-hero-link:hover{background:#ffffff14}.landing-cta-primary{background:var(--accent);color:#fff;border-radius:12px;padding:14px 30px;font-size:16px;box-shadow:0 10px 24px #14b8a63d}.landing-cta-primary:hover{background:#0d9488}.landing-cta-secondary{color:#ecf0f1;background:#ffffff1f;border:1px solid #fff3;border-radius:12px;padding:14px 28px;font-size:16px}.landing-cta-secondary:hover{background:#fff3}.landing-cta-ghost{color:#ecf0f1cc;background:0 0;border:1px solid #ffffff40;border-radius:12px;padding:12px 24px;font-size:15px}.landing-cta-ghost:hover{background:#ffffff14}.landing-section-title{color:var(--primary);text-align:center;margin-bottom:12px;font-family:Fraunces Variable,serif;font-size:clamp(24px,4vw,36px);font-weight:700}.landing-section-sub{text-align:center;color:var(--text-light);max-width:600px;margin:0 auto 32px;font-size:16px;line-height:1.5}.landing-composers{text-align:center;background:#0f1a24;border-top:1px solid #ffffff12;border-bottom:1px solid #ffffff12;padding:16px 0}.landing-composers-inner{flex-wrap:wrap;justify-content:center;align-items:center;gap:4px 6px;padding:0 16px;font-size:13px;display:flex}.landing-composers-label{color:#ffffff8c;white-space:nowrap;margin-right:4px;font-weight:600}.landing-composers-names{color:#ffffff6b;letter-spacing:.02em}.landing-demo{z-index:1;background:radial-gradient(circle at 90% 10%,#14b8a614,#0000 50%),radial-gradient(circle at 10% 90%,#54709712,#0000 50%),#f0f5f6;padding:64px 0 72px;position:relative}.landing-demo-header{margin-bottom:24px}.landing-demo-label{color:var(--primary);margin-bottom:6px;font-family:Fraunces Variable,serif;font-size:clamp(22px,3vw,30px);font-weight:700}.landing-demo-hint{color:#34495ed1;font-size:15px}.landing-demo-placeholder{border:2px dashed var(--border);cursor:pointer;background:#fff;border-radius:16px;justify-content:center;align-items:center;min-height:320px;margin-bottom:0;transition:border-color .2s,background .2s;display:flex;box-shadow:0 8px 24px #0f1a240f}.landing-demo-placeholder:hover{border-color:var(--accent);background:#14b8a608}.landing-demo-placeholder-inner{text-align:center;padding:40px}.landing-demo-play-btn{margin-bottom:16px;transition:transform .2s;display:inline-flex}.landing-demo-placeholder:hover .landing-demo-play-btn{transform:scale(1.08)}.landing-demo-placeholder-label{color:var(--text);margin-bottom:8px;font-size:18px;font-weight:600}.landing-demo-placeholder-hint{color:var(--text-light);font-size:14px}.landing-demo-frame{border:1px solid var(--border);background:#fff;border-bottom:none;border-radius:18px 18px 0 0;position:relative;overflow:hidden;box-shadow:0 14px 36px #0f1a241f}.landing-demo-frame .demo-player{flex-direction:column;height:680px;display:flex}.landing-demo-frame .demo-notation-area{flex-direction:column;flex:1;display:flex;overflow:hidden}.landing-demo-frame .notation-view{flex:1}.landing-demo-frame .notation-container{width:100%;min-width:0;padding:0}.landing-demo-frame .notation-scroll-wrapper{padding:4px;overflow-x:hidden}.landing-demo-frame .notation-header{padding:8px 6px}.landing-demo-frame .notation-title{letter-spacing:0;padding:0;font-size:14px}.landing-demo-frame .notation-meta{gap:4px;margin-top:2px;font-size:10px}.landing-demo-frame .notation-meta-label{letter-spacing:0;font-size:9px}.landing-demo-gate-bar{border:1px solid var(--border);border-top:2px solid var(--accent);color:var(--text-light);background:#fff;border-radius:0 0 16px 16px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:14px 24px;font-size:14px;display:flex}.landing-showcase{background:#0c1720;padding:100px 0 130px;position:relative}.landing-showcase:before{content:"";pointer-events:none;background-image:repeating-linear-gradient(#0000 0 39px,#ffffff06 39px 40px);position:absolute;inset:0}.landing-showcase-header{text-align:center;max-width:580px;margin:0 auto 72px;position:relative}.landing-showcase-title{color:#f0ebe2;margin-bottom:16px;font-family:Fraunces Variable,serif;font-size:clamp(28px,3.8vw,44px);font-weight:700;line-height:1.15}.landing-showcase-lead{color:#ffffff9e;font-size:16px;line-height:1.7}.landing-feature-strip-wrap{position:relative}.landing-feature-strip-wrap:after{content:"";pointer-events:none;background:linear-gradient(90deg,#0000,#0c1720);width:72px;position:absolute;top:0;bottom:20px;right:0}@media (width>=860px){.landing-feature-strip-wrap:after{display:none}}.landing-feature-strip{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:#14b8a633 transparent;gap:28px;padding-bottom:20px;display:flex;overflow-x:auto}@media (width>=860px){.landing-feature-strip{justify-content:center;align-items:flex-start;padding-bottom:0;overflow:visible}}.landing-feature-card{--stagger-y:0px;scroll-snap-align:start;background:#ffffff04;border-radius:14px;flex-direction:column;flex:0 0 268px;gap:14px;padding:10px 10px 14px;display:flex;position:relative}@media (width>=860px){.landing-feature-card{max-width:296px;transform:translateY(var(--stagger-y));flex:1;transition:transform .35s cubic-bezier(.22,1,.36,1)}.landing-feature-card:first-child{--stagger-y:0px}.landing-feature-card:nth-child(2){--stagger-y:-56px}.landing-feature-card:nth-child(3){--stagger-y:-24px}.landing-feature-card:hover{transform:translateY(calc(var(--stagger-y) - 10px))}}.landing-feature-pill{color:#14b8a6;letter-spacing:.08em;text-transform:uppercase;background:#14b8a61f;border:1px solid #14b8a64d;border-radius:100px;align-items:center;width:fit-content;padding:4px 11px;font-size:11px;font-weight:600;display:inline-flex}.landing-feature-frame{border:1px solid #ffffff14;border-radius:12px;transition:box-shadow .35s cubic-bezier(.22,1,.36,1);overflow:hidden;box-shadow:0 0 0 1px #14b8a612,0 28px 72px #0000008c,0 8px 24px #14b8a612}.landing-feature-card:hover .landing-feature-frame{box-shadow:0 0 0 1px #14b8a62e,0 32px 80px #0000008c,0 8px 32px #14b8a624}.landing-feature-frame img{width:100%;height:auto;display:block}.landing-feature-label{color:#f0ebe2;font-size:15px;font-weight:600}.landing-feature-caption{color:#fff9;margin:0;font-size:13px;line-height:1.5}.landing-showcase-cta{text-align:center;margin-top:72px;position:relative}.landing-cta-section{text-align:center;background:#faf8f5;padding:88px 0}.landing-cta-title{color:var(--primary);margin-bottom:12px;font-family:Fraunces Variable,serif;font-size:clamp(28px,4vw,42px);font-weight:700}.landing-cta-sub{color:var(--text-light);margin-bottom:36px;font-size:16px}.landing-cta-section .landing-cta-ghost{color:var(--text-light);border:1px solid var(--border)}.landing-cta-section .landing-cta-ghost:hover{color:var(--text);border-color:var(--text-light);background:#0000000d}.landing-cta-buttons{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.landing-auth-inline{position:relative}.landing-auth-inline .auth-overlay{background:0 0;padding:0;position:relative}.landing-auth-inline .auth-container{padding:0}.landing-auth-inline .auth-brand{display:none}.landing-footer{background:#1a252f;padding:24px 0}.landing-footer .landing-container{color:#ecf0f180;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;font-size:13px;display:flex}.landing-footer-links{gap:20px;display:flex}.landing-footer-links a{color:#ecf0f1d9;font-size:13px;text-decoration:none}.landing-footer-links a:hover{color:#fff}@keyframes landing-rotate{0%{opacity:0;transform:translateY(110%)}6%{opacity:1;transform:translateY(0)}26%{opacity:1;transform:translateY(0)}30%{opacity:0;transform:translateY(-120%)}to{opacity:0;transform:translateY(-120%)}}@keyframes landing-glow{0%,to{opacity:.7;transform:translate(0,0)scale(1)}50%{opacity:.95;transform:translate(2%,-2%)scale(1.05)}}@keyframes landing-rise{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes note-play{0%{opacity:.15;filter:drop-shadow(0 0 3px #0f1a2426);transform:translate(-50%,-50%)scale(.96)}18%{opacity:.55;filter:drop-shadow(0 0 8px #ecf0f14d);transform:translate(-50%,-50%)scale(1.04)}40%{opacity:.22;filter:drop-shadow(0 0 3px #0f1a2426);transform:translate(-50%,-50%)scale(.99)}to{opacity:.15;filter:drop-shadow(0 0 3px #0f1a2426);transform:translate(-50%,-50%)scale(.96)}}@media (prefers-reduced-motion:reduce){.landing-hero-title,.landing-hero-sub,.landing-hero-kicker,.landing-hero-actions,.landing-hero-login{opacity:1;animation:none;transform:none}.ios-app-banner{animation:none}.landing-hero-rotator span{opacity:1;animation:none;position:static}.landing-hero-rotator span:not(:first-child){display:none}.landing-hero:before{animation:none}.landing-hero-notes .note-symbol{opacity:.2;animation:none}}.interstitial-overlay{-webkit-backdrop-filter:blur(4px);z-index:1000;background:#0009;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.interstitial-card{background:#fff;border-radius:20px;width:100%;max-width:420px;padding:0;position:relative;overflow:hidden;box-shadow:0 32px 80px #00000059}.interstitial-header{background:linear-gradient(145deg,#0d2b28 0%,#174a44 60%,#1a5248 100%);padding:28px 28px 24px;position:relative}.interstitial-close{color:#ffffffbf;cursor:pointer;z-index:1;background:#ffffff1f;border:none;border-radius:8px;justify-content:center;align-items:center;width:30px;height:30px;font-size:13px;transition:background .15s,color .15s;display:flex;position:absolute;top:12px;right:12px}.interstitial-close:hover{color:#fff;background:#ffffff38}.interstitial-trigger-icon{color:#5eead4;background:#14b8a62e;border:1px solid #14b8a64d;border-radius:12px;justify-content:center;align-items:center;width:44px;height:44px;margin-bottom:14px;display:flex}.interstitial-hook{color:#fff;margin-bottom:6px;font-family:Fraunces Variable,serif;font-size:22px;font-weight:700;line-height:1.25}.interstitial-reason{color:#ffffffa6;margin-bottom:0;font-size:13px;line-height:1.55}.interstitial-benefits{background:#fafcfb;border-bottom:1px solid #14b8a61f;flex-direction:column;gap:9px;padding:16px 28px;list-style:none;display:flex}.interstitial-benefit-item{color:#34495e;align-items:center;gap:9px;font-size:13px;line-height:1.4;display:flex}.interstitial-benefit-check{color:#14b8a6;background:#14b8a61f;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;display:flex}.interstitial-form-body{padding:20px 28px 28px}.interstitial-form .form-group label{color:var(--text)}.interstitial-form .form-group input{background:var(--bg);color:var(--text);border:1px solid var(--border)}.interstitial-form .form-group input:focus{border-color:var(--accent)}.interstitial-form .form-group input::placeholder{color:var(--text-light)}.interstitial-form .form-error{color:#e74c3c}.interstitial-form .auth-switch a{color:var(--accent)}.demo-player{flex-direction:column;display:flex}.demo-notation-area{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.demo-player-loading{min-height:320px;color:var(--text-light);flex-direction:column;justify-content:center;align-items:center;gap:16px;font-size:14px;display:flex}.demo-player-error{min-height:200px;color:var(--text-light);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:24px;font-size:14px;display:flex}.demo-player-error-hint{opacity:.7;font-size:12px}@media (width<=767px){.landing-header-inner{padding:0 16px}.landing-hero{min-height:calc(100vh - 120px);padding:48px 16px 56px}.landing-hero-title{line-height:1.15}.landing-hero-rotator{min-width:8ch;height:1.1em}.landing-hero-kicker{margin-bottom:16px}.landing-hero-sub{max-width:36ch;margin-bottom:28px}.landing-hero-actions{margin-top:8px;margin-bottom:4px}.landing-hero-login{margin-top:24px}.landing-hero-notes{opacity:.15}.landing-hero-notes .note-seq-1{top:35%;left:5%}.landing-hero-notes .note-seq-2{top:55%;left:30%}.landing-hero-notes .note-seq-3{top:30%;left:55%}.landing-hero-notes .note-seq-4{top:50%;left:75%}.landing-hero-notes .note-seq-5{top:70%;left:15%}.landing-hero-notes .note-seq-6{top:80%;left:45%}.landing-hero-notes .note-seq-7{top:70%;left:85%}.landing-hero-notes .note-seq-8{top:55%;left:60%}.landing-hero-notes .note-symbol svg{width:32px}.landing-hero-notes .note-symbol--single svg{width:24px}.landing-hero-notes .note-symbol--double svg{width:36px}.landing-hero-notes .note-symbol--whole svg{width:28px}.landing-hero-notes .note-symbol--half svg{width:20px}.landing-nav{gap:8px}.landing-nav .btn-primary{display:none}.landing-nav .btn{padding:8px 12px;font-size:13px}.landing-hero-ctas{flex-direction:column;width:100%}.landing-hero-ctas .btn{text-align:center;width:100%;min-height:46px}.landing-container{padding:0 16px}.landing-demo-frame .demo-player{height:clamp(360px,60svh,520px)}.landing-demo-gate-bar{text-align:center;flex-direction:column}.landing-showcase-lead{color:#ffffffb8}.landing-footer .landing-container{text-align:center;justify-content:center}}.auth-page{z-index:400;grid-template-rows:30% 1fr;grid-template-columns:45% 1fr;display:grid;position:fixed;inset:0;overflow:hidden}.auth-page:before{content:"";background:radial-gradient(circle at 100% 0%, #14b8a624 0%, transparent 50%), radial-gradient(circle at 0% 100%, #14b8a617 0%, transparent 50%), linear-gradient(160deg, #2d4057 0%, var(--primary) 50%, #243343 100%);pointer-events:none;z-index:0;width:45%;height:100%;position:absolute;top:0;left:0}.auth-page:after{content:"";pointer-events:none;z-index:1;background:repeating-linear-gradient(#0000,#0000 56px,#ffffff08 56px 57px);width:45%;height:100%;position:absolute;top:0;left:0}.auth-page-notes{pointer-events:none;z-index:1;width:45%;height:100%;position:absolute;top:0;left:0;overflow:hidden}.auth-page-notes .note-symbol{color:#ecf0f1b3;opacity:.18;animation:14s ease-in-out infinite note-play;display:block;position:absolute;transform:translate(-50%,-50%)}.auth-page-notes .note-symbol svg{width:52px;height:auto;display:block;overflow:visible}.auth-page-notes .note-symbol--single svg{width:34px}.auth-page-notes .note-symbol--double svg{width:58px}.auth-page-notes .note-symbol--whole svg{width:40px}.auth-page-notes .note-symbol--half svg{width:28px}.auth-note-seq-1{animation-delay:0s;top:7%;left:78%}.auth-note-seq-2{animation-delay:3.1s;top:16%;left:55%}.auth-note-seq-3{animation-delay:6.2s;top:30%;left:88%}.auth-note-seq-4{animation-delay:1.5s;top:44%;left:65%}.auth-note-seq-5{animation-delay:8.4s;top:57%;left:82%}.auth-note-seq-6{animation-delay:4.7s;top:68%;left:48%}.auth-note-seq-7{animation-delay:2.3s;top:80%;left:72%}.auth-note-seq-8{animation-delay:9.6s;top:91%;left:90%}.auth-page-top-left{z-index:2;color:#fff;flex-direction:column;gap:28px;padding:52px 52px 48px;display:flex;position:relative}.auth-page-back{color:#ffffff8c;cursor:pointer;background:0 0;border:none;padding:0;font-size:13px;transition:color .15s;position:absolute;top:22px;left:52px}.auth-page-back:hover{color:#ffffffe6}.auth-page-brand{align-items:center;gap:10px;display:flex}.auth-page-brand-name{letter-spacing:-.3px;color:#fff;font-family:Fraunces Variable,serif;font-size:18px;font-weight:700}.auth-page-pitch{margin-top:auto}.auth-page-headline{color:#fff;letter-spacing:-.5px;margin-bottom:10px;font-family:Fraunces Variable,Georgia,serif;font-size:clamp(28px,2.6vw,40px);font-weight:700;line-height:1.1}.auth-page-tagline{color:var(--accent);letter-spacing:.01em;font-size:14px;font-weight:500}.auth-page-top-right{visibility:hidden}.auth-page-bottom-left{z-index:2;color:#fff;flex-direction:column;justify-content:flex-start;padding:48px 52px 52px;display:flex;position:relative;overflow-y:auto}.auth-page-benefits{flex-direction:column;gap:20px;list-style:none;display:flex}.auth-page-benefit{align-items:flex-start;gap:14px;display:flex}.auth-page-benefit-icon{color:#14b8a6;background:#14b8a61f;border:1px solid #14b8a638;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.auth-page-benefit strong{color:#fff;margin-bottom:2px;font-size:13px;font-weight:600;display:block}.auth-page-benefit p{color:#ffffff9e;margin:0;font-size:12px;line-height:1.5}.auth-page-bottom-right{background:#faf9f7;border-left:1px solid #14b8a62e;flex-direction:column;grid-area:1/2/-1;justify-content:center;align-items:center;height:100vh;display:flex;position:relative;overflow-y:auto}.auth-page-form-wrap{width:100%;max-width:360px}.auth-page-context-banner{color:var(--text);background:#14b8a614;border:1px solid #14b8a633;border-radius:10px;align-items:flex-start;gap:10px;margin-bottom:20px;padding:11px 14px;font-size:13px;line-height:1.45;display:flex}.auth-page-context-icon{color:#14b8a6;flex-shrink:0;margin-top:1px}.auth-page-tabs{background:#2c3e5012;border-radius:10px;gap:0;margin-bottom:28px;padding:3px;display:flex}.auth-page-tab{color:#2c3e5080;cursor:pointer;background:0 0;border:none;border-radius:8px;flex:1;padding:8px 0;font-size:13.5px;font-weight:500;transition:background .18s,color .18s,box-shadow .18s}.auth-page-tab.active{color:var(--primary);background:#fff;font-weight:600;box-shadow:0 1px 4px #0000001a}.auth-page-tab:hover:not(.active){color:var(--primary);background:#ffffff8c}.auth-page-form{flex-direction:column;gap:18px;display:flex}.auth-page-form .form-group label{color:var(--text);letter-spacing:.015em;font-size:13px;font-weight:500}.auth-page-form .form-group input{color:var(--text);background:#fff;border:1px solid #d4d8dc}.auth-page-form .form-group input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #14b8a61f}.auth-page-form .form-group input::placeholder{color:var(--text-light)}@media (hover:none) and (pointer:coarse){.auth-form .form-group input,.auth-page-form .form-group input{font-size:16px}}.auth-page-form .form-error{color:#e53e3e;font-size:13px}.auth-page-consent{color:#00000073;margin:4px 0 0;font-size:12px;line-height:1.4}.auth-page-consent a{color:#0000008c;text-decoration:underline}.auth-page-consent a:hover{color:#000000bf}.auth-page-submit{margin-top:6px;padding:13px;font-size:15px;font-weight:600}.auth-page-forgot{color:var(--text-light);cursor:pointer;text-align:center;background:0 0;border:none;padding:4px 0;font-size:13px;-webkit-text-decoration:underline #0000;text-decoration:underline #0000;transition:color .15s,text-decoration-color .15s}.auth-page-forgot:hover{color:var(--text);-webkit-text-decoration-color:var(--text);text-decoration-color:var(--text)}.auth-page-footer-links{justify-content:center;gap:20px;display:flex;position:absolute;bottom:24px;left:0;right:0}.auth-page-footer-links a{color:#00000047;font-size:12px;text-decoration:none}.auth-page-footer-links a:hover{color:#0000008c}.demo-notation-skeleton{background:#fff;flex-direction:column;justify-content:center;gap:40px;height:100%;min-height:400px;padding:48px 40px;display:flex}.dns-staff{flex-direction:column;gap:11px;display:flex;position:relative}.dns-line{background:#d1d5db;height:1px;animation:1.8s ease-in-out infinite dns-shimmer}.dns-line:nth-child(2){animation-delay:.1s}.dns-line:nth-child(3){animation-delay:.2s}.dns-line:nth-child(4){animation-delay:.3s}.dns-line:nth-child(5){animation-delay:.4s}.dns-notes{align-items:flex-end;gap:44px;display:flex;position:absolute;top:-8px;left:32px;right:0}.dns-note{background:#c4cdd6;border-radius:50%;flex-shrink:0;width:11px;height:11px;animation:1.8s ease-in-out infinite dns-pulse}@keyframes dns-shimmer{0%,to{opacity:.35}50%{opacity:.9}}@keyframes dns-pulse{0%,to{opacity:.25;transform:translateY(0)}50%{opacity:.85;transform:translateY(-5px)}}.dns-label{text-align:center;color:var(--text-light);letter-spacing:.02em;font-size:13px}@media (width<=640px){.auth-page{grid-template-rows:auto 1fr;grid-template-columns:1fr;height:auto;min-height:100dvh;position:relative;overflow:visible}.auth-page:before,.auth-page:after{width:100%;height:auto;bottom:0}.auth-page-notes{display:none}.auth-page-top-left{padding:calc(env(safe-area-inset-top,20px) + 12px) 24px 14px;gap:8px}.auth-page-back{align-self:flex-start;margin-bottom:2px;font-size:14px;position:static;top:auto;left:auto}.auth-page-brand{margin-top:0}.auth-page-pitch{margin-top:4px;display:block}.auth-page-headline{display:none}.auth-page-tagline{color:#ecf0f1eb;letter-spacing:.02em;background:#14b8a624;border:1px solid #14b8a647;border-radius:999px;align-items:center;padding:4px 10px;font-size:11px;display:inline-flex}.auth-page-top-right,.auth-page-bottom-left{display:none}.auth-page-bottom-right{border-top:1px solid #14b8a62e;border-left:none;justify-content:flex-start;align-items:stretch;height:auto;padding:18px 24px 40px}.auth-page-tabs{background:#2c3e500f;border-radius:9px;margin-bottom:18px;padding:2px}.auth-page-tab{color:#2c3e5075;border-radius:7px;padding:7px 0;font-size:13px}.auth-page-tab.active{box-shadow:0 1px 2px #00000014}.auth-page-form{gap:8px}.auth-page-form .form-group{margin-bottom:0}.auth-page-form .form-group label{margin-bottom:3px}.auth-page-consent{margin:2px 0 0;font-size:11px;line-height:1.3}.auth-page-submit{margin-top:2px}.auth-page-forgot{padding-top:2px}.auth-page-footer-links{gap:16px;margin-top:14px;padding-bottom:4px;position:static}.auth-page-form-wrap{max-width:100%}.auth-page-form .form-group input{box-sizing:border-box;width:100%}}@media (width<=640px) and (height<=550px){.auth-page-top-left{padding:calc(env(safe-area-inset-top,20px) + 6px) 24px 8px}.auth-page-back{margin-bottom:0}.auth-page-bottom-right{padding:16px 24px 24px}.auth-page-pitch{display:none}.auth-page-tabs{margin-bottom:16px}.auth-page-form{gap:8px}.auth-page-footer-links{margin-top:12px}}.static-page{background:var(--bg);flex-direction:column;display:flex;position:fixed;inset:0;overflow-y:auto}.static-page-back{cursor:pointer;color:var(--secondary);background:0 0;border:none;align-items:center;gap:8px;padding:0;display:flex}.static-page-back:hover .landing-brand-name{opacity:.8}.static-page-content{max-width:700px;color:var(--text);flex:1;margin:0 auto;padding:48px 24px 64px}.static-page-content h1{color:var(--primary);margin-bottom:8px;font-family:Fraunces Variable,Georgia,serif;font-size:2rem;font-weight:700}.static-page-meta{color:var(--text-light);margin-bottom:40px;font-size:13px}.static-page-content h2{color:var(--primary);border-left:3px solid var(--accent);letter-spacing:.01em;margin:36px 0 10px;padding-left:10px;font-size:.95rem;font-weight:700}.static-page-content p,.static-page-content li{margin-bottom:8px;font-size:14px;line-height:1.7}.static-page-content ul{margin-bottom:8px;padding-left:20px}.static-page-content a{color:var(--accent);text-decoration:none}.static-page-content a:hover{text-decoration:underline}.static-page-content code{background:#f1f5f9;border-radius:3px;padding:1px 5px;font-family:monospace;font-size:13px}.static-page-content table{border-collapse:collapse;width:100%;margin-bottom:8px;font-size:13px}.static-page-content th,.static-page-content td{text-align:left;border:1px solid var(--border);padding:8px 12px}.static-page-content th{color:var(--primary);background:#14b8a612;border-color:#14b8a633;font-weight:600}.settings-page{background:#0f1a24;flex-direction:column;display:flex;position:fixed;inset:0;overflow-y:auto}.settings-page-hero{padding:calc(env(safe-area-inset-top,0px) + 44px) 0 40px;background:linear-gradient(160deg,#0f1a24 0%,#1b2c3d 60%,#152130 100%);border-bottom:1px solid #ffffff12;flex-shrink:0}.settings-page-hero-inner{max-width:680px;margin:0 auto;padding:0 24px}.settings-page-hero h1{color:#ecf0f1;letter-spacing:-.02em;margin:0 0 6px;font-family:Fraunces Variable,serif;font-size:clamp(1.8rem,4vw,2.4rem);font-weight:700}.settings-page-hero .settings-email{color:#ecf0f166;margin:0;font-family:Instrument Sans,sans-serif;font-size:13.5px}.settings-page-main{flex-direction:column;flex:1;gap:10px;width:100%;max-width:680px;margin:0 auto;padding:28px 24px 72px;display:flex}.settings-section{background:#ffffff0a;border:1px solid #ffffff14;border-radius:14px;padding:28px;transition:border-color .2s}.settings-section:hover{border-color:#ffffff1f}.settings-section h2{letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin:0 0 20px;font-family:Instrument Sans,sans-serif;font-size:10.5px;font-weight:700}.settings-section .form-group{max-width:360px}.settings-description{color:#ecf0f180;margin-bottom:16px;font-size:13.5px;line-height:1.55}.settings-hint{color:#ecf0f166;margin-top:-8px;font-size:13px;line-height:1.5}.settings-version-hint{text-align:center;color:#ecf0f140;-webkit-user-select:all;user-select:all;padding:16px 24px;font-family:monospace;font-size:11px;line-height:1.6}.settings-page .btn-secondary{color:#ecf0f1d9;background:#ffffff1a;border:1px solid #ffffff24}.settings-page .btn-secondary:hover{background:#ffffff29}.settings-section .form-success{text-align:left;margin-top:12px}.settings-section .form-error{margin-top:10px}.settings-section--danger{background:#e74c3c0a;border-color:#e74c3c24}.settings-section--danger:hover{border-color:#e74c3c38}.settings-section--danger h2{color:#e74c3c99}.settings-delete-confirm{background:#ffffff08;border:1px solid #ffffff14;border-radius:10px;max-width:360px;margin-top:20px;padding:20px}.settings-delete-confirm>p{color:#ecf0f1a6;margin-bottom:0;font-size:13px;line-height:1.5}.settings-delete-actions{gap:8px;margin-top:16px;display:flex}.btn-danger{color:#fff;background:#e74c3c;border:none}.btn-danger:hover{background:#c0392b}.btn-danger:disabled{opacity:.5;cursor:not-allowed}@media (width<=600px){.settings-page-hero{padding:calc(env(safe-area-inset-top,0px) + 32px) 0 28px}.settings-page-main{gap:8px;padding:20px 16px 56px}.settings-section{padding:20px 18px}}.sightreading-btn{color:#ecf0f1b3}.sightreading-btn:hover{color:#fff;background:#ffffff14}.sr-overlay{z-index:200;background:#000000a6;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.sr-panel{color:#ecf0f1;background:#1a1a2e;border:1px solid #ffffff1a;border-radius:14px;width:100%;max-width:460px;max-height:90vh;padding:28px 28px 24px;overflow-y:auto}.sr-panel-loading{color:#ecf0f199;flex-direction:column;align-items:center;gap:16px;padding:48px 28px;display:flex}.sr-panel-summary{max-width:540px}.sr-panel-header{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.sr-panel-title{margin:0;font-size:18px;font-weight:600}.sr-close-btn{color:#ecf0f180;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:22px;line-height:1}.sr-close-btn:hover{color:#ecf0f1;background:#ffffff14}.sr-panel-intro{color:#ecf0f199;margin:0 0 20px;font-size:13px;line-height:1.5}.sr-label{text-transform:uppercase;letter-spacing:.06em;color:#ecf0f173;margin-bottom:8px;font-size:12px;font-weight:600;display:block}.sr-difficulty-picker{flex-direction:column;gap:8px;margin-bottom:20px;display:flex}.sr-difficulty-option{color:#ecf0f1;cursor:pointer;text-align:left;background:#ffffff0a;border:1px solid #ffffff14;border-radius:8px;flex-direction:column;gap:2px;padding:12px 14px;transition:background .15s,border-color .15s;display:flex}.sr-difficulty-option:hover{background:#ffffff12;border-color:#ffffff24}.sr-difficulty-option.is-selected{background:#58a6ff1a;border-color:#58a6ff66}.sr-difficulty-label{font-size:14px;font-weight:600}.sr-difficulty-desc{color:#ecf0f180;font-size:12px}.sr-hand-picker{gap:8px;margin-bottom:20px;display:flex}.sr-hand-option{color:#ecf0f1;cursor:pointer;background:#ffffff0a;border:1px solid #ffffff14;border-radius:8px;flex:1;padding:10px 8px;font-size:13px;transition:background .15s,border-color .15s}.sr-hand-option:hover{background:#ffffff12}.sr-hand-option.is-selected{background:#58a6ff1a;border-color:#58a6ff66}.sr-warning{color:#e6a23c;background:#e6a23c1a;border:1px solid #e6a23c4d;border-radius:6px;margin-bottom:16px;padding:10px 12px;font-size:13px}.sr-error{color:#e74c3c;background:#e74c3c1a;border:1px solid #e74c3c4d;border-radius:6px;margin-bottom:16px;padding:10px 12px;font-size:13px}.sr-panel-actions{gap:8px;margin-top:20px;display:flex}.sr-btn-primary{color:#fff;cursor:pointer;background:#3498db;border:none;border-radius:8px;flex:1;padding:11px 16px;font-size:14px;font-weight:600;transition:background .15s}.sr-btn-primary:hover:not(:disabled){background:#2980b9}.sr-btn-primary:disabled{opacity:.4;cursor:not-allowed}.sr-btn-secondary{color:#ecf0f1b3;cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:8px;padding:11px 16px;font-size:14px;transition:background .15s}.sr-btn-secondary:hover{color:#ecf0f1;background:#ffffff1a}.app.sr-practice-mode{background:#0f1a24}.app.sr-practice-mode .main-content{background:linear-gradient(160deg,#0f1a24 0%,#1b2c3d 60%,#152130 100%);justify-content:center;align-items:center;padding:32px 0 0;overflow:hidden}.app.sr-practice-mode .notation-view{background:#faf8f5;border-radius:8px;flex:0 auto;width:100%;max-width:960px;padding:12px 0 4px;overflow:hidden;box-shadow:0 4px 32px #0006}.app.sr-practice-mode .notation-scroll-wrapper{overflow:hidden}.app.sr-practice-mode .sidebar:not(.open){display:none}.sr-playing-hud{background:0 0;flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;width:100%;max-width:960px;padding:24px 32px 16px;display:flex}.sr-hud-left{flex-direction:column;gap:1px;min-width:80px;display:flex}.sr-hud-label{text-transform:uppercase;letter-spacing:.1em;color:#ecf0f159;font-size:10px;font-weight:600}.sr-hud-exercise{color:#ecf0f1;font-size:22px;font-weight:700;line-height:1}.sr-hud-of{color:#ecf0f166;font-size:14px;font-weight:400}.sr-hud-center{flex-direction:column;align-items:center;gap:3px;display:flex}.sr-hud-score{align-items:center;gap:14px;font-size:16px;font-weight:600;display:flex}.sr-hit{color:#2ecc71;align-items:center;gap:4px;display:flex}.sr-miss{color:#e74c3c;align-items:center;gap:4px;display:flex}.sr-hud-accuracy{color:#ecf0f18c;background:#ffffff0f;border-radius:4px;padding:2px 8px;font-size:15px;font-weight:700}.sr-hud-accuracy.is-good{color:#2ecc71;background:#2ecc711a}.sr-hud-accuracy.is-ok{color:#e6a23c;background:#e6a23c1a}.sr-hud-accuracy.is-low{color:#e74c3c;background:#e74c3c1a}.sr-hud-level{text-transform:uppercase;letter-spacing:.08em;color:#ecf0f14d;font-size:10px}.sr-hud-right{justify-content:flex-end;align-items:center;gap:8px;min-width:80px;display:flex}.sr-skip-icon{display:none}.sr-skip-btn{color:#ecf0f18c;cursor:pointer;white-space:nowrap;background:#ffffff0f;border:1px solid #ffffff1f;border-radius:8px;padding:8px 16px;font-size:13px;font-weight:500;transition:background .15s,color .15s,border-color .15s}.sr-skip-btn:hover{color:#ecf0f1;background:#ffffff1a;border-color:#fff3}.sr-exit-btn{color:#ecf0f159;cursor:pointer;background:0 0;border:1px solid #ffffff14;border-radius:8px;justify-content:center;align-items:center;padding:7px 8px;transition:background .15s,color .15s,border-color .15s;display:flex}.sr-exit-btn:hover{color:#e74c3c;background:#e74c3c1f;border-color:#e74c3c4d}.sr-keyboard-btn{color:#ffffff8c;cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1f;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;transition:background .15s,color .15s,border-color .15s;display:flex}.sr-keyboard-btn:hover{color:#ecf0f1;background:#ffffff1a;border-color:#fff3}.sr-keyboard-btn.active{color:var(--accent);background:#14b8a62e;border-color:#14b8a666}.sr-wrong-note-overlay{color:#fff;pointer-events:none;z-index:9999;white-space:nowrap;background:#ef4444;border-radius:4px;padding:2px 6px;font-size:12px;font-weight:700;animation:.4s forwards sr-wrong-note-fade;position:fixed;transform:translate(-50%)}@keyframes sr-wrong-note-fade{0%{opacity:1;transform:translate(-50%)translateY(-4px)}70%{opacity:1}to{opacity:0;transform:translate(-50%)translateY(-14px)}}.sr-between-grade{text-align:center;margin:8px 0 4px;font-size:56px;font-weight:700}.sr-between-grade[data-grade=A]{color:#2ecc71}.sr-between-grade[data-grade=B]{color:#58a6ff}.sr-between-grade[data-grade=C]{color:#e6a23c}.sr-between-grade[data-grade=D]{color:#e74c3c}.sr-between-accuracy{text-align:center;color:#ecf0f1e6;margin-bottom:16px;font-size:18px;font-weight:600}.sr-between-piece{text-align:center;color:#ecf0f1cc;margin-bottom:6px;font-size:14px}.sr-between-measures{color:#ecf0f173;font-size:12px}.sr-between-detail{text-align:center;color:#ecf0f173;margin-bottom:4px;font-size:12px}.sr-summary-overall{text-align:center;margin-bottom:24px}.sr-summary-grade{font-size:64px;font-weight:700}.sr-summary-grade[data-grade=A]{color:#2ecc71}.sr-summary-grade[data-grade=B]{color:#58a6ff}.sr-summary-grade[data-grade=C]{color:#e6a23c}.sr-summary-grade[data-grade=D]{color:#e74c3c}.sr-summary-avg{color:#ecf0f1b3;margin-top:4px;font-size:16px}.sr-level-change{color:#ecf0f199;margin-top:8px;font-size:14px}.sr-level-change.is-up{color:#2ecc71;font-weight:600}.sr-level-change.is-down{color:#e6a23c}.sr-summary-scores{flex-direction:column;gap:0;display:flex}.sr-score-card{padding:12px 0}.sr-score-divider{background:#ffffff12;height:1px;margin-top:12px}.sr-score-piece{flex-wrap:wrap;align-items:baseline;gap:8px;margin-bottom:4px;display:flex}.sr-score-piece-name{color:#ecf0f1e6;font-size:13px;font-weight:600}.sr-score-piece-composer{color:#ecf0f173;font-size:12px}.sr-score-measures{color:#ecf0f159;margin-left:auto;font-size:11px}.sr-score-stats{align-items:center;gap:12px;display:flex}.sr-score-grade{flex-shrink:0;width:28px;font-size:20px;font-weight:700}.sr-score-grade[data-grade=A]{color:#2ecc71}.sr-score-grade[data-grade=B]{color:#58a6ff}.sr-score-grade[data-grade=C]{color:#e6a23c}.sr-score-grade[data-grade=D]{color:#e74c3c}.sr-score-detail{color:#ecf0f180;flex-wrap:wrap;gap:6px;font-size:12px;display:flex}.sr-score-sep{color:#ecf0f140}@media (width<=600px){.sr-panel{border-radius:12px;padding:20px 18px 18px}.sr-playing-hud{gap:10px;padding:20px 14px 12px}.sr-hud-exercise{font-size:18px}.sr-hud-score{gap:10px;font-size:14px}.sr-skip-btn{padding:7px 9px}.sr-skip-label{display:none}.sr-skip-icon{display:block}.app.sr-practice-mode .main-content{justify-content:flex-start;align-items:center;padding:8px 0 0}}@media screen and (orientation:portrait){.app.sr-phone-landscape{transform-origin:0 0;width:100dvh;height:100dvw;padding-left:env(safe-area-inset-top,0px);padding-right:env(safe-area-inset-bottom,0px);box-sizing:border-box;position:fixed;top:100dvh;left:0;overflow:hidden;transform:rotate(-90deg)}.app.sr-phone-landscape .main-content{height:100%}.app.sr-phone-landscape .notation-scroll-wrapper{margin-top:0}}.app.sr-phone-landscape .top-bar{display:none}.app.sr-phone-landscape .app-body{flex:auto;overflow:hidden}.app.sr-phone-landscape .main-content{background:#1a2a38;flex-direction:column;justify-content:flex-start;align-items:stretch;gap:0;height:100%;padding:0;display:flex}.app.sr-phone-landscape .notation-view{min-height:0;box-shadow:none;contain:layout paint;background:#fff;border-radius:0;flex:1 1 0;width:100%;max-width:100%;padding:0;overflow:hidden}.app.sr-phone-landscape .notation-scroll-wrapper{touch-action:none;overscroll-behavior:contain;margin-top:0;padding:0;overflow:hidden}.app.sr-phone-landscape .notation-container{width:100%;min-width:0;max-width:none;min-height:0;box-shadow:none;touch-action:none;border:none;border-radius:0;margin:0;padding:0}.app.sr-phone-landscape .notation-container.system-paging-switch{opacity:.92;transition:opacity .1s,transform .1s}.app.sr-phone-landscape .notation-render canvas,.app.sr-phone-landscape .notation-render svg{max-width:100%;margin:0}.app.sr-phone-landscape .sr-playing-hud{background:#1e2d3cf2;border-top:1px solid #ffffff0f;border-bottom:none;flex-shrink:0;width:100%;height:40px;min-height:40px;max-height:40px;padding:0 10px;overflow:visible}.app.sr-phone-landscape .sr-hud-label,.app.sr-phone-landscape .sr-hud-level{display:none}.app.sr-phone-landscape .sr-hud-exercise{font-size:12px}.app.sr-phone-landscape .sr-hud-of{font-size:11px}.app.sr-phone-landscape .sr-hud-score{gap:8px;font-size:12px}.app.sr-phone-landscape .sr-hud-accuracy{font-size:11px}.app.sr-phone-landscape .sr-skip-btn,.app.sr-phone-landscape .sr-exit-btn,.app.sr-phone-landscape .sr-keyboard-btn{border-radius:5px;min-width:32px;height:32px;min-height:32px;padding:4px 8px}.app.sr-phone-landscape .sr-skip-label{display:none}.app.sr-phone-landscape .sr-skip-icon{display:block}.app.sr-phone-landscape .keyboard-container{padding:2px 0 calc(2px + var(--ios-safe-area-bottom));background:#1e2d3cf2;border-top:none;flex:none;min-height:clamp(96px,30dvw,140px)}.app.sr-phone-landscape .pianolab-cursor{z-index:1;background:#14b8a638;border-left:4px solid #14b8a6e6}.sr-phone-hint{z-index:100;color:#d4cfc3;white-space:nowrap;pointer-events:none;-webkit-backdrop-filter:blur(8px);background:#0a1423d1;border-radius:100px;width:fit-content;margin:0 auto;padding:5px 16px;font-size:12px;font-weight:500;animation:3.5s forwards sr-hint-show;display:none;position:absolute;top:8px;left:0;right:0}@media screen and (orientation:portrait){.app.sr-phone-landscape .sr-phone-hint{display:none}}@keyframes sr-hint-show{0%{opacity:0;transform:translateY(-4px)}12%{opacity:1;transform:translateY(0)}78%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-4px)}}.toast-container{top:calc(var(--topbar-height) + 12px);z-index:10000;pointer-events:none;flex-direction:column;gap:8px;max-width:calc(100vw - 32px);display:flex;position:fixed;right:16px}.toast{background:var(--primary);color:#fff;pointer-events:auto;border-radius:10px;align-items:flex-start;gap:12px;min-width:240px;max-width:420px;padding:12px 14px;font-size:14px;line-height:1.4;animation:.18s ease-out toast-in;display:flex;box-shadow:0 8px 24px #0000002e}.toast-info{background:var(--primary)}.toast-success{background:#0f9d6a}.toast-error{background:#c0392b}.toast-message{word-break:break-word;flex:auto}.toast-dismiss{color:inherit;cursor:pointer;opacity:.85;background:0 0;border:none;border-radius:4px;flex:none;padding:2px}.toast-dismiss:hover,.toast-dismiss:focus-visible{opacity:1;background:#ffffff26;outline:none}@keyframes toast-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}@media (width<=600px){.toast-container{top:auto;bottom:calc(var(--ios-safe-area-bottom) + 16px);max-width:none;left:12px;right:12px}.toast{min-width:0;max-width:none}}.pa-hud{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:40;pointer-events:auto;-webkit-user-select:none;user-select:none;background:#1e232ae0;border:1px solid #ffffff14;border-radius:10px;align-items:center;gap:12px;padding:8px 12px 8px 10px;display:flex;position:absolute;top:12px;right:16px}.pa-hud-ring-wrap{flex-shrink:0;width:50px;height:50px;position:relative}.pa-hud-ring{transform:rotate(-90deg)}.pa-hud-ring-bg{fill:none;stroke:#ffffff14;stroke-width:4px}.pa-hud-ring-fg{fill:none;stroke-width:4px;stroke-linecap:round;transition:stroke-dashoffset .4s}.pa-ring--good .pa-hud-ring-fg{stroke:#14b8a6}.pa-ring--ok .pa-hud-ring-fg{stroke:#e6a23c}.pa-ring--low .pa-hud-ring-fg{stroke:#e74c3c}.pa-hud-pct{color:#ecf0f1;justify-content:center;align-items:center;font-size:13px;font-weight:700;line-height:1;display:flex;position:absolute;inset:0}.pa-hud-pct-sym{opacity:.7;margin-left:1px;font-size:9px;font-weight:400}.pa-hud-stats{flex-direction:column;gap:2px;min-width:56px;display:flex}.pa-hud-elapsed{color:#ecf0f180;font-variant-numeric:tabular-nums;font-size:13px;font-weight:600}.pa-hud-hits{color:#2ecc71;font-size:13px;font-weight:600}.pa-hud-misses{color:#e74c3c;font-size:13px;font-weight:600}.pa-hud-stop{flex-shrink:0}.pa-result-card{background:var(--bg);border:1px solid var(--border);z-index:200;border-radius:14px;width:320px;animation:.22s cubic-bezier(.34,1.2,.64,1) pa-result-in;position:fixed;top:50%;left:50%;overflow:hidden;transform:translate(-50%,-50%);box-shadow:0 12px 48px #00000029,0 2px 8px #00000014}@keyframes pa-result-in{0%{opacity:0;transform:translate(-50%,-46%)scale(.96)}to{opacity:1;transform:translate(-50%,-50%)scale(1)}}.pa-result-card--a{--pa-accent:#14b8a6;--pa-accent-bg:#14b8a614}.pa-result-card--b{--pa-accent:#2ecc71;--pa-accent-bg:#2ecc7114}.pa-result-card--c{--pa-accent:#e6a23c;--pa-accent-bg:#e6a23c14}.pa-result-card--d{--pa-accent:#e74c3c;--pa-accent-bg:#e74c3c14}.pa-result-hero{background:var(--pa-accent-bg);border-bottom:1px solid var(--border);align-items:center;gap:14px;padding:18px 18px 14px;display:flex}.pa-result-grade-wrap{background:var(--pa-accent);width:52px;height:52px;box-shadow:0 2px 12px color-mix(in srgb, var(--pa-accent) 40%, transparent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.pa-result-grade{color:#fff;font-family:Fraunces Variable,serif;font-size:28px;font-weight:800;line-height:1}.pa-result-hero-text{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.pa-result-pct{color:var(--text);font-variant-numeric:tabular-nums;font-size:30px;font-weight:800;line-height:1}.pa-result-message{color:var(--pa-accent);text-transform:uppercase;letter-spacing:.06em;font-size:12px;font-weight:600}.pa-result-close{cursor:pointer;color:var(--text-light);background:0 0;border:none;border-radius:6px;align-self:flex-start;margin-top:-2px;padding:6px;font-size:14px;line-height:1;transition:background .12s,color .12s}.pa-result-close:hover{background:var(--border);color:var(--text)}.pa-result-bar-track{background:var(--border);height:3px}.pa-result-bar-fill{background:var(--pa-accent);height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}.pa-result-stats{align-items:stretch;padding:14px 0 12px;display:flex}.pa-result-stat{flex-direction:column;flex:1;align-items:center;gap:3px;padding:0 8px;display:flex}.pa-result-stat-divider{background:var(--border);width:1px;margin:4px 0}.pa-result-stat-value{color:var(--text);font-variant-numeric:tabular-nums;font-size:20px;font-weight:700;line-height:1}.pa-result-stat--hit{color:#2ecc71}.pa-result-stat--miss{color:#e74c3c}.pa-result-stat-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-light);font-size:10px;font-weight:500}.pa-result-history{border-top:1px solid var(--border);padding:12px 18px 14px}.pa-result-history-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-light);margin-bottom:8px;font-size:10px;font-weight:600}.pa-result-history-list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.pa-result-history-row{align-items:center;gap:8px;font-size:12px;display:flex}.pa-result-history-date{color:var(--text-light);flex-shrink:0;min-width:48px}.pa-result-history-bar-track{background:var(--border);border-radius:2px;flex:1;height:4px;overflow:hidden}.pa-result-history-bar-fill{background:var(--border);background:color-mix(in srgb, var(--pa-accent) 35%, var(--border));border-radius:2px;height:100%}.pa-result-history-pct{color:var(--text);text-align:right;font-variant-numeric:tabular-nums;min-width:34px;font-weight:600}.pa-result-history-delta{text-align:right;font-variant-numeric:tabular-nums;min-width:32px;font-size:11px;font-weight:600}.pa-delta--up{color:#2ecc71}.pa-delta--down{color:#e74c3c}.pa-result-dismiss-track{background:var(--border);height:2px}.pa-result-dismiss-fill{background:var(--pa-accent);opacity:.4;height:100%;transition:width .1s linear}
