@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-cyrillic-ext-wght-normal-BOeWTOD4.woff2)format("woff2-variations");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-cyrillic-wght-normal-DqGufNeO.woff2)format("woff2-variations");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-greek-ext-wght-normal-DlzME5K_.woff2)format("woff2-variations");unicode-range:U+1F??}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-greek-wght-normal-CkhJZR-_.woff2)format("woff2-variations");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-vietnamese-wght-normal-CBcvBZtf.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:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-latin-ext-wght-normal-DO1Apj_S.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:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-latin-wght-normal-Dx4kXJAl.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:Inter Variable;font-style:italic;font-display:swap;font-weight:100 900;src:url(/assets/inter-cyrillic-ext-wght-italic-B5xAaiFk.woff2)format("woff2-variations");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter Variable;font-style:italic;font-display:swap;font-weight:100 900;src:url(/assets/inter-cyrillic-wght-italic-DzZdc28x.woff2)format("woff2-variations");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter Variable;font-style:italic;font-display:swap;font-weight:100 900;src:url(/assets/inter-greek-ext-wght-italic-DcOpz6Lw.woff2)format("woff2-variations");unicode-range:U+1F??}@font-face{font-family:Inter Variable;font-style:italic;font-display:swap;font-weight:100 900;src:url(/assets/inter-greek-wght-italic-CILZdfAp.woff2)format("woff2-variations");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter Variable;font-style:italic;font-display:swap;font-weight:100 900;src:url(/assets/inter-vietnamese-wght-italic-K3WlGtc8.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:Inter Variable;font-style:italic;font-display:swap;font-weight:100 900;src:url(/assets/inter-latin-ext-wght-italic-0pjOp8NU.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:Inter Variable;font-style:italic;font-display:swap;font-weight:100 900;src:url(/assets/inter-latin-wght-italic-DpCbqKDY.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:Fraunces Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/fraunces-vietnamese-full-normal-7BpKI3vF.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-full-normal-YHFkNujK.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-full-normal-CFFu7zhK.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:Fraunces Variable;font-style:italic;font-display:swap;font-weight:100 900;src:url(/assets/fraunces-vietnamese-full-italic-BHALq22K.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:italic;font-display:swap;font-weight:100 900;src:url(/assets/fraunces-latin-ext-full-italic-B8-t4Nou.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:italic;font-display:swap;font-weight:100 900;src:url(/assets/fraunces-latin-full-italic-D2JnYqd-.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}:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--ink:#121212;--ink-soft:#2c2b29;--paper:#fbfbf9;--panel:#fff;--line:#e4e2dc;--hairline:#cfccc4;--muted:#75726a;--green:#16803c;--red:#c1121f;--red-deep:#9c0f1a;--focus:#1e66a8;--lacquer:linear-gradient(177deg, #2a2a28 0%, #161513 42%, #0c0b0a 100%);--font-body:"Inter Variable", "Inter", "SF Pro Display", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif;--font-display:var(--font-body);--font-serif:"Fraunces Variable", "Georgia", "Times New Roman", serif;--radius-card:14px;--radius-control:10px;--shadow-card:0 1px 2px #1212120a, 0 1px 1px #12121208;--shadow-card-hover:0 24px 50px -26px #12121273, 0 2px 6px #1212120f;--horizontal-controls-height:133px}*{box-sizing:border-box}html,body{background:var(--paper);min-height:100%;color:var(--ink);font-family:var(--font-body);font-feature-settings:"cv01", "ss03";-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;margin:0}#library[hidden],.practice-shell[hidden]{display:none!important}#library{width:100%;display:block;position:relative}#library:before{content:"";z-index:0;pointer-events:none;opacity:.5;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");position:fixed;top:0;bottom:0;left:0;right:0}.app-navbar{z-index:100;-webkit-backdrop-filter:saturate(1.4)blur(16px);border-bottom:1px solid var(--line);background:#fbfbf9d1;width:100%;position:sticky;top:0}.app-navbar-inner{align-items:stretch;gap:2px;width:min(1120px,100% - 48px);margin:0 auto;display:flex}.app-navbar button{min-height:58px;color:var(--muted);cursor:pointer;font-family:var(--font-body);letter-spacing:-.005em;background:0 0;border:none;border-bottom:2px solid #0000;padding:0 14px;font-size:13.5px;font-weight:500;transition:color .18s,border-color .18s}.app-navbar button[aria-current=page]{color:var(--ink);border-bottom-color:var(--red)}.app-navbar button:hover:not(:disabled){color:var(--ink)}.app-navbar button:focus-visible{outline:2px solid var(--focus);outline-offset:-2px;border-radius:4px}.app-navbar button:disabled{cursor:not-allowed;opacity:.34}.app-navbar-status{align-items:center;gap:2px;margin-left:auto;display:flex}.nav-streak,.nav-today{cursor:default;height:30px;font-family:var(--font-body);font-variant-numeric:tabular-nums;letter-spacing:-.01em;align-items:center;display:inline-flex}.nav-streak{color:var(--muted);gap:5px;padding:0 8px;font-size:13px;font-weight:600}.nav-streak-flame{background:var(--muted);width:14px;height:14px;-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M8.5 14.5A2.5 2.5 0 0 0 11 12c0-1.38-.5-2-1-3-1.072-2.143-.224-4.054 2-6 .5 2.5 2 4.9 4 6.5 2 1.6 3 3.5 3 5.5a7 7 0 1 1-14 0c0-1.153.433-2.294 1-3a2.5 2.5 0 0 0 2.5 2.5z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M8.5 14.5A2.5 2.5 0 0 0 11 12c0-1.38-.5-2-1-3-1.072-2.143-.224-4.054 2-6 .5 2.5 2 4.9 4 6.5 2 1.6 3 3.5 3 5.5a7 7 0 1 1-14 0c0-1.153.433-2.294 1-3a2.5 2.5 0 0 0 2.5 2.5z'/%3E%3C/svg%3E");-webkit-mask-position:50%;mask-position:50%;-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.nav-streak-count{color:var(--ink)}.nav-streak[data-live] .nav-streak-flame{background:var(--red)}.nav-today{color:var(--ink-soft);gap:3px;padding:0 6px}.nav-today-value{color:var(--ink);font-size:13px;font-weight:600}.nav-today-unit{color:var(--muted);font-size:11px;font-weight:500}.app-navbar-status-divider{background:var(--line);width:1px;height:18px;margin:0 4px}.app-navbar-settings{border-radius:50%;place-items:center;width:32px;height:32px;text-decoration:none;transition:background .18s;display:inline-grid;position:relative}.app-navbar-settings:before{content:"";position:absolute;top:-6px;bottom:-6px;left:-6px;right:-6px}.app-navbar-settings span{background:var(--muted);width:18px;height:18px;transition:background .18s,transform .45s cubic-bezier(.22,.61,.36,1);-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='3'/%3E%3Cpath d='M19.4 15a1.65 1.65 0 0 0 .33 1.82l.06.06a2 2 0 1 1-2.83 2.83l-.06-.06a1.65 1.65 0 0 0-1.82-.33 1.65 1.65 0 0 0-1 1.51V21a2 2 0 0 1-4 0v-.09A1.65 1.65 0 0 0 9 19.4a1.65 1.65 0 0 0-1.82.33l-.06.06a2 2 0 1 1-2.83-2.83l.06-.06a1.65 1.65 0 0 0 .33-1.82 1.65 1.65 0 0 0-1.51-1H3a2 2 0 0 1 0-4h.09A1.65 1.65 0 0 0 4.6 9a1.65 1.65 0 0 0-.33-1.82l-.06-.06a2 2 0 1 1 2.83-2.83l.06.06a1.65 1.65 0 0 0 1.82.33H9a1.65 1.65 0 0 0 1-1.51V3a2 2 0 0 1 4 0v.09a1.65 1.65 0 0 0 1 1.51 1.65 1.65 0 0 0 1.82-.33l.06-.06a2 2 0 1 1 2.83 2.83l-.06.06a1.65 1.65 0 0 0-.33 1.82V9a1.65 1.65 0 0 0 1.51 1H21a2 2 0 0 1 0 4h-.09a1.65 1.65 0 0 0-1.51 1z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='3'/%3E%3Cpath d='M19.4 15a1.65 1.65 0 0 0 .33 1.82l.06.06a2 2 0 1 1-2.83 2.83l-.06-.06a1.65 1.65 0 0 0-1.82-.33 1.65 1.65 0 0 0-1 1.51V21a2 2 0 0 1-4 0v-.09A1.65 1.65 0 0 0 9 19.4a1.65 1.65 0 0 0-1.82.33l-.06.06a2 2 0 1 1-2.83-2.83l.06-.06a1.65 1.65 0 0 0 .33-1.82 1.65 1.65 0 0 0-1.51-1H3a2 2 0 0 1 0-4h.09A1.65 1.65 0 0 0 4.6 9a1.65 1.65 0 0 0-.33-1.82l-.06-.06a2 2 0 1 1 2.83-2.83l.06.06a1.65 1.65 0 0 0 1.82.33H9a1.65 1.65 0 0 0 1-1.51V3a2 2 0 0 1 4 0v.09a1.65 1.65 0 0 0 1 1.51 1.65 1.65 0 0 0 1.82-.33l.06-.06a2 2 0 1 1 2.83 2.83l-.06.06a1.65 1.65 0 0 0-.33 1.82V9a1.65 1.65 0 0 0 1.51 1H21a2 2 0 0 1 0 4h-.09a1.65 1.65 0 0 0-1.51 1z'/%3E%3C/svg%3E");-webkit-mask-position:50%;mask-position:50%;-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.app-navbar-settings:hover{background:color-mix(in srgb, var(--ink) 6%, transparent)}.app-navbar-settings:hover span{background:var(--ink);transform:rotate(40deg)}.app-navbar-settings:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.library-shell{z-index:1;background:radial-gradient(120% 70% at 50% -8%,#fff 0%,#fff0 58%),0 0;width:min(1120px,100% - 48px);margin:0 auto;padding:28px 0 88px;position:relative}.verify-email-notice{border:1px solid color-mix(in srgb, var(--red) 36%, var(--line));background:color-mix(in srgb, var(--red) 6%, var(--panel));color:var(--ink);border-radius:8px;grid-template-columns:1fr auto;align-items:center;gap:10px 16px;margin:0 0 18px;padding:13px 14px;display:grid}.verify-email-notice p{color:var(--ink-soft);margin:0;font-size:.92rem;line-height:1.45}.verify-email-actions{align-items:center;gap:8px;display:inline-flex}.verify-email-resend,.verify-email-dismiss{cursor:pointer;min-height:34px;font-family:var(--font-body);border-radius:6px;padding:7px 11px;font-size:.82rem;font-weight:700}.verify-email-resend{border:1px solid var(--ink);background:var(--ink);color:var(--paper)}.verify-email-dismiss{border:1px solid var(--hairline);color:var(--ink-soft);background:0 0}.verify-email-resend:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.verify-email-dismiss:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.verify-email-resend:disabled{opacity:.55;cursor:default}.verify-email-feedback,.verify-email-error{grid-column:1/-1}.verify-email-notice .verify-email-feedback{color:var(--ink)}.verify-email-notice .verify-email-error{color:var(--red-deep)}.library-first-run{gap:22px;padding:clamp(20px,3vw,38px) 0 0;display:grid}.first-run-heading{max-width:860px}.first-run-heading h1{font-family:var(--font-serif);font-variation-settings:"opsz" 144, "SOFT" 0, "WONK" 0;letter-spacing:-.02em;color:var(--ink);text-wrap:balance;margin:0;font-size:clamp(34px,4.6vw,54px);font-weight:430;line-height:1.02}.first-run-heading,.first-run-search{animation:.5s cubic-bezier(.22,.61,.36,1) both piece-card-in}.first-run-search{align-items:center;animation-delay:60ms;display:flex}.first-run-search .filter-search-wrap{flex-basis:min(620px,100%);max-width:620px}.first-run-search .filter-search-wrap:before{width:17px;height:17px;left:17px}.first-run-search .filter-search-input{background:var(--panel);height:54px;box-shadow:var(--shadow-card);border-radius:12px;padding:0 18px 0 46px;font-size:16px}.first-run-search .filter-search-input:focus{box-shadow:0 0 0 4px color-mix(in srgb, var(--focus) 10%, transparent), var(--shadow-card)}.starter-shelf{grid-template-columns:repeat(auto-fit,minmax(min(260px,100%),1fr));align-items:stretch;gap:18px;display:grid}.starter-shelf .piece-card{min-height:270px}.starter-shelf .piece-card-body{padding-right:64px}.starter-shelf .piece-title{max-width:12ch}#starter-shelf{flex-wrap:wrap;gap:16px;display:flex}#starter-shelf .piece-card:not(:first-child){flex:200px}#starter-shelf .piece-card:not(:first-child),.starter-shelf--results .piece-card{grid-template-rows:auto auto 1fr;gap:14px;min-height:224px;padding:20px 20px 18px}#starter-shelf .piece-card:not(:first-child) .piece-portrait,.starter-shelf--results .piece-card .piece-portrait{opacity:1;object-position:center 14%;filter:grayscale()contrast(1.06);background:color-mix(in srgb, var(--paper) 92%, var(--ink) 8%);width:56px;height:56px;box-shadow:0 0 0 1px var(--line);border-radius:50%;position:relative;top:auto;bottom:auto;left:auto;right:auto}#starter-shelf .piece-card:not(:first-child) .piece-card-body,.starter-shelf--results .piece-card .piece-card-body{padding-right:0}#starter-shelf .piece-card:not(:first-child) .piece-title,.starter-shelf--results .piece-card .piece-title{max-width:none;font-size:22px}#starter-shelf .piece-card:first-child{isolation:isolate;flex:100%;grid-template:"plate kicker""plate body""plate badge"1fr/clamp(132px,16vw,180px) minmax(0,1fr);align-items:start;gap:8px 28px;min-height:0;padding:22px 26px 20px}#starter-shelf .piece-card:first-child:before{content:none}#starter-shelf .piece-card:first-child .piece-portrait{opacity:1;object-position:center 12%;filter:grayscale()contrast(1.06);background:color-mix(in srgb, var(--paper) 92%, var(--ink) 8%);width:100%;height:100%;min-height:150px;box-shadow:0 0 0 1px var(--line);border-radius:11px;grid-area:plate;align-self:stretch;margin:0;position:relative;top:auto;bottom:auto;left:auto;right:auto}#starter-shelf .piece-card:first-child .piece-card-body{grid-area:body;padding-right:84px}#starter-shelf .piece-card:first-child .piece-title{max-width:none;font-size:clamp(28px,3vw,34px)}#starter-shelf .piece-card:first-child .starter-difficulty-badge{grid-area:badge;margin-top:10px}.starter-featured-kicker{letter-spacing:.16em;text-transform:uppercase;color:var(--red);grid-area:kicker;justify-self:start;font-size:11px;font-weight:760}.starter-difficulty-badge{color:var(--muted);font-family:var(--font-body);letter-spacing:.14em;text-transform:uppercase;place-self:end start;align-items:center;gap:8px;font-size:10.5px;font-weight:720;display:inline-flex}.starter-difficulty-dots{gap:4px;display:inline-flex}.starter-difficulty-dots span{width:6px;height:6px;box-shadow:inset 0 0 0 1.5px var(--hairline);border-radius:50%}.starter-difficulty-dots span[data-filled]{background:var(--ink-soft);box-shadow:none}.starter-difficulty-badge[data-difficulty="4"] .starter-difficulty-dots span[data-filled],.starter-difficulty-badge[data-difficulty="5"] .starter-difficulty-dots span[data-filled]{background:var(--red-deep)}.library-filters{flex-direction:column;gap:12px;padding:14px 0 6px;display:flex}.library-filters-row{flex-wrap:wrap;align-items:center;gap:12px 16px;display:flex}.filter-controls{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.billing-library-banner{border:1px solid color-mix(in srgb, var(--red-deep) 20%, var(--line));border-left:3px solid var(--red);border-radius:var(--radius-control);background:color-mix(in srgb, var(--panel) 82%, var(--red) 4%);justify-content:space-between;align-items:center;gap:18px;margin-top:18px;padding:16px 20px;display:flex}.billing-library-banner h2{font-family:var(--font-serif);font-variation-settings:"opsz" 90, "SOFT" 0, "WONK" 0;letter-spacing:-.01em;color:var(--ink);margin:0;font-size:1.3rem;font-weight:460}.billing-library-banner p{color:var(--ink-soft);margin:3px 0 0;font-size:.92rem}.billing-library-banner a{color:var(--focus);flex:none;font-size:.92rem;font-weight:600}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.filter-search-wrap{flex:240px;align-items:center;max-width:340px;display:flex;position:relative}.filter-search-wrap:before{content:"";opacity:.5;background-color:var(--ink);width:15px;height:15px;position:absolute;top:50%;left:13px;transform:translateY(-50%);-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Ccircle cx='8.5' cy='8.5' r='5.5' fill='none' stroke='black' stroke-width='1.8'/%3E%3Cline x1='12.8' y1='12.8' x2='17' y2='17' stroke='black' stroke-width='1.8' stroke-linecap='round'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Ccircle cx='8.5' cy='8.5' r='5.5' fill='none' stroke='black' stroke-width='1.8'/%3E%3Cline x1='12.8' y1='12.8' x2='17' y2='17' stroke='black' stroke-width='1.8' stroke-linecap='round'/%3E%3C/svg%3E");-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.filter-search-input{border:1px solid var(--line);border-radius:var(--radius-control);background:color-mix(in srgb, var(--panel) 70%, transparent);width:100%;height:40px;color:var(--ink);font-family:var(--font-body);-webkit-appearance:none;padding:0 14px 0 36px;font-size:14px;font-weight:400;transition:border-color .18s,background .18s,box-shadow .18s}.filter-search-input:hover{border-color:var(--hairline)}.filter-search-input:focus{border-color:color-mix(in srgb, var(--ink) 38%, var(--line));background:var(--panel);box-shadow:0 0 0 3px color-mix(in srgb, var(--focus) 12%, transparent);outline:none}.filter-search-input::placeholder{color:var(--muted)}.filter-select-wrap{position:relative}.filter-select{border:1px solid var(--line);border-radius:var(--radius-control);background:color-mix(in srgb, var(--panel) 70%, transparent);height:40px;color:var(--ink-soft);cursor:pointer;font-family:var(--font-body);letter-spacing:-.003em;align-items:center;gap:8px;padding:0 12px 0 14px;font-size:13.5px;font-weight:500;transition:color .18s,border-color .18s,background .18s,box-shadow .18s;display:inline-flex}.filter-select:hover{border-color:var(--hairline);color:var(--ink);background:var(--panel)}.filter-select:focus-visible{border-color:color-mix(in srgb, var(--ink) 38%, var(--line));box-shadow:0 0 0 3px color-mix(in srgb, var(--focus) 12%, transparent);outline:none}.filter-select[data-open]{border-color:color-mix(in srgb, var(--ink) 38%, var(--line));background:var(--panel)}.filter-select--active{color:var(--ink);border-color:var(--hairline)}.filter-select--active .filter-select-label:before{content:"";background:var(--red);vertical-align:1px;border-radius:50%;width:6px;height:6px;margin-right:7px;display:inline-block}.filter-select-chevron{color:var(--muted);transition:transform .18s}.filter-select[data-open] .filter-select-chevron{transform:rotate(180deg)}.filter-popover{z-index:30;border:1px solid var(--line);border-radius:var(--radius-card);background:var(--panel);box-shadow:var(--shadow-card-hover);animation:.14s both filter-popover-in;position:absolute;top:calc(100% + 6px);left:0;overflow:hidden}@keyframes filter-popover-in{0%{opacity:0;transform:translateY(-4px)}}.filter-popover--composer{width:280px}.filter-popover--status{min-width:200px;padding:6px;left:auto;right:0}.filter-popover-search{border-bottom:1px solid var(--line);padding:10px 10px 8px}.filter-popover-search-input{border:1px solid var(--line);border-radius:var(--radius-control);background:color-mix(in srgb, var(--panel) 60%, var(--line) 12%);width:100%;height:34px;color:var(--ink);font-family:var(--font-body);-webkit-appearance:none;padding:0 12px;font-size:13.5px}.filter-popover-search-input:focus{border-color:color-mix(in srgb, var(--ink) 38%, var(--line));background:var(--panel);box-shadow:0 0 0 3px color-mix(in srgb, var(--focus) 12%, transparent);outline:none}.filter-popover-search-input::placeholder{color:var(--muted)}.filter-options{overscroll-behavior:contain;max-height:280px;margin:0;padding:6px;list-style:none;overflow-y:auto}.composer-option{border-radius:var(--radius-control);color:var(--ink-soft);cursor:pointer;align-items:center;gap:8px;padding:8px 10px;font-size:13.5px;line-height:1.2;display:flex}.composer-option[data-active]{background:color-mix(in srgb, var(--ink) 6%, transparent);color:var(--ink)}.composer-option[aria-selected=true]{color:var(--ink);font-weight:560}.composer-option-check{opacity:0;background-color:currentColor;flex:none;width:14px;height:14px;-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath d='M3 8.5 6.5 12 13 4.5' fill='none' stroke='black' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath d='M3 8.5 6.5 12 13 4.5' fill='none' stroke='black' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.composer-option[aria-selected=true] .composer-option-check{opacity:1}.composer-option-name{text-overflow:ellipsis;white-space:nowrap;flex:auto;min-width:0;overflow:hidden}.composer-option-count{color:var(--muted);font-variant-numeric:tabular-nums;flex:none;font-size:12px}.filter-options-empty{color:var(--muted);text-align:center;padding:14px 10px;font-size:13px}.status-options{flex-direction:column;display:flex}.status-option{border-radius:var(--radius-control);width:100%;color:var(--ink-soft);cursor:pointer;font-family:var(--font-body);text-align:left;background:0 0;border:none;align-items:center;gap:9px;padding:8px 10px;font-size:13.5px;display:flex}.status-option:hover{background:color-mix(in srgb, var(--ink) 6%, transparent);color:var(--ink)}.status-option:focus-visible{background:color-mix(in srgb, var(--ink) 6%, transparent);box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--focus) 40%, transparent);outline:none}.status-option-mark{border:1.5px solid var(--hairline);border-radius:50%;flex:none;width:14px;height:14px;transition:border-color .16s}.status-option--repertoire .status-option-mark{border-radius:4px}.status-option[aria-checked=true]{color:var(--ink);font-weight:560}.status-option[aria-checked=true] .status-option-mark{border-color:var(--ink);border-width:4px}.status-option--repertoire[aria-checked=true] .status-option-mark{border-width:1.5px;border-color:var(--red);background:var(--red)}.filter-tokens{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.filter-token{background:var(--lacquer);color:#fbfbf9;cursor:pointer;height:28px;font-family:var(--font-body);letter-spacing:-.003em;border:1px solid #0000;border-radius:100px;align-items:center;gap:6px;padding:0 8px 0 12px;font-size:12.5px;font-weight:500;transition:opacity .16s;display:inline-flex}.filter-token:hover{opacity:.86}.filter-token:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.filter-token-label{text-overflow:ellipsis;white-space:nowrap;max-width:200px;overflow:hidden}.filter-token-x{opacity:.72;flex:none}.filter-token:hover .filter-token-x{opacity:1}.filter-tokens-clear{color:var(--muted);cursor:pointer;font-family:var(--font-body);text-underline-offset:2px;text-decoration:underline;-webkit-text-decoration-color:var(--hairline);text-decoration-color:var(--hairline);background:0 0;border:none;font-size:12.5px;font-weight:500}.filter-tokens-clear:hover{color:var(--ink)}.filter-tokens-clear:focus-visible{outline:2px solid var(--focus);outline-offset:2px;border-radius:4px}.piece-empty-state{border:1px solid var(--line);border-radius:var(--radius-card);background:color-mix(in srgb, var(--panel) 74%, transparent);min-height:200px;box-shadow:var(--shadow-card);text-align:center;grid-column:1/-1;margin-top:28px;padding:56px 28px}.piece-empty-state h2{font-family:var(--font-serif);font-variation-settings:"opsz" 144, "SOFT" 0, "WONK" 0;letter-spacing:-.018em;color:var(--ink);margin:0;font-size:clamp(28px,4vw,36px);font-weight:440;line-height:1.04}.piece-empty-state p{max-width:40ch;font-family:var(--font-body);color:var(--muted);margin:12px auto 0;font-size:14px;line-height:1.6}.piece-request-toggle,.piece-request-submit,.piece-request-secondary{border-radius:var(--radius-control);cursor:pointer;min-height:42px;font-family:var(--font-body);letter-spacing:-.003em;font-size:13.5px;font-weight:600;transition:background .18s,border-color .18s,color .18s,box-shadow .18s,opacity .18s}.piece-request-toggle,.piece-request-submit{background:var(--lacquer);color:#fbfbf9;border:1px solid #0000;margin-top:24px;padding:0 22px}.piece-request-toggle:hover,.piece-request-submit:hover:not(:disabled){box-shadow:var(--shadow-card-hover);transform:translateY(-1px)}.piece-request-toggle:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.piece-request-submit:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.piece-request-secondary:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.piece-request-form{text-align:left;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;width:min(640px,100%);margin:28px auto 0;display:grid}.piece-request-form label{gap:7px;min-width:0;display:grid}.piece-request-form span{color:var(--ink-soft);font-family:var(--font-body);letter-spacing:.1em;text-transform:uppercase;font-size:11px;font-weight:700}.piece-request-form input,.piece-request-form textarea{border:1px solid var(--line);border-radius:var(--radius-control);background:color-mix(in srgb, var(--panel) 80%, transparent);width:100%;color:var(--ink);font-family:var(--font-body);font-size:14px;line-height:1.4;transition:border-color .18s,box-shadow .18s,background .18s}.piece-request-form input{min-height:42px;padding:0 12px}.piece-request-form textarea{resize:vertical;min-height:84px;padding:10px 12px}.piece-request-form input:focus,.piece-request-form textarea:focus{border-color:color-mix(in srgb, var(--ink) 38%, var(--line));background:var(--panel);box-shadow:0 0 0 3px color-mix(in srgb, var(--focus) 12%, transparent);outline:none}.piece-request-form input::placeholder{color:color-mix(in srgb, var(--muted) 72%, transparent)}.piece-request-form-wide,.piece-request-actions,.piece-request-error{grid-column:1/-1}.piece-request-actions{justify-content:flex-end;gap:10px;margin-top:2px;display:flex}.piece-request-submit,.piece-request-secondary{margin-top:0}.piece-request-submit:disabled,.piece-request-secondary:disabled{cursor:default;opacity:.5;box-shadow:none;transform:none}.piece-request-secondary{border:1px solid var(--line);color:var(--muted);background:0 0;padding:0 16px}.piece-request-secondary:hover:not(:disabled){border-color:var(--hairline);color:var(--ink);background:var(--panel)}.piece-request-error{color:var(--red-deep);font-family:var(--font-body);margin:0;font-size:13.5px}.piece-request-success{border:1px solid color-mix(in srgb, var(--focus) 18%, var(--line));border-left:3px solid var(--focus);border-radius:var(--radius-control);background:var(--panel);width:min(440px,100%);box-shadow:var(--shadow-card);text-align:left;margin:28px auto 0;padding:22px}.piece-request-success h3{color:var(--ink);font-family:var(--font-serif);font-variation-settings:"opsz" 90, "SOFT" 0, "WONK" 0;letter-spacing:-.01em;margin:0;font-size:22px;font-weight:460}.piece-request-success p{max-width:none;color:var(--muted);margin:7px 0 0;font-size:14px}.library-sections{gap:52px;padding:30px 0 0;display:grid}.piece-section{gap:18px;display:grid}.piece-section-header{border-bottom:1px solid var(--line);justify-content:space-between;align-items:flex-end;gap:18px;min-width:0;padding-bottom:12px;display:flex}.piece-section-header h2{font-family:var(--font-serif);font-variation-settings:"opsz" 72, "SOFT" 0, "WONK" 0;letter-spacing:-.012em;color:var(--ink);flex-direction:column;gap:5px;margin:0;font-size:21px;font-weight:470;line-height:1.12;display:flex}.piece-section-header span{font-family:var(--font-body);letter-spacing:.1em;text-transform:uppercase;font-variant-numeric:tabular-nums;color:var(--muted);flex:none;font-size:11px;font-weight:700}.piece-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-card);width:100%;min-height:244px;box-shadow:var(--shadow-card);color:inherit;cursor:pointer;font:inherit;text-align:left;animation:.5s cubic-bezier(.22,.61,.36,1) both piece-card-in;animation-delay:calc(min(var(--enter-index,0), 12) * 40ms);grid-template-rows:1fr auto auto;gap:20px;padding:26px 26px 24px;transition:transform .32s cubic-bezier(.22,.61,.36,1),box-shadow .32s cubic-bezier(.22,.61,.36,1),border-color .32s,background .18s;display:grid;position:relative;overflow:hidden}@keyframes piece-card-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.piece-card:before{content:"";background:var(--hairline);transform-origin:top;width:3px;transition:transform .18s cubic-bezier(.22,.61,.36,1);position:absolute;top:0;bottom:0;left:0;right:auto;transform:scaleY(0)}.piece-card:hover:before,.piece-card:focus-within:before{transform:scaleY(1)}.piece-card[data-current-repertoire=true]:before{background:linear-gradient(180deg, var(--red), var(--red-deep));transform:scaleY(1)}.piece-card:hover,.piece-card:focus-within{border-color:var(--hairline);box-shadow:var(--shadow-card-hover);transform:translateY(-4px)}.piece-card[role=button]:focus-visible{outline:2px solid var(--focus);outline-offset:3px}.piece-card[aria-disabled=true]{cursor:default}.piece-card[aria-disabled=true]:hover{border-color:var(--line);box-shadow:var(--shadow-card);transform:none}.piece-card[aria-disabled=true]:hover:before{transform:scaleY(0)}.piece-card[data-pending=true]{border-color:var(--hairline);box-shadow:var(--shadow-card-hover)}.piece-portrait{object-fit:cover;object-position:center top;opacity:.06;filter:grayscale()contrast(1.05);pointer-events:none;width:150px;height:150px;transition:opacity .32s;position:absolute;top:-14px;right:-14px}.piece-card-body{min-width:0;padding-right:80px}.piece-title{font-family:var(--font-serif);font-optical-sizing:auto;font-variation-settings:"opsz" 144, "SOFT" 0, "WONK" 0;letter-spacing:-.014em;color:var(--ink);text-wrap:balance;align-self:start;margin:0;font-size:27px;font-weight:440;line-height:1.08}.piece-subtitle{font-family:var(--font-serif);font-variation-settings:"opsz" 36, "SOFT" 0, "WONK" 0;letter-spacing:.01em;color:var(--muted);margin:4px 0 0;font-size:14px;font-weight:400;line-height:1.35}.piece-composer{font-family:var(--font-serif);font-variation-settings:"opsz" 36, "SOFT" 0, "WONK" 0;color:var(--muted);margin:8px 0 0;font-size:15px;font-style:italic;font-weight:400;line-height:1.4}.piece-card-quick-actions{z-index:3;align-items:center;gap:8px;display:flex;position:absolute;top:16px;right:16px}.piece-preview-button,.piece-repertoire-toggle{border:1px solid var(--line);background:color-mix(in srgb, var(--panel) 70%, transparent);width:32px;height:32px;color:var(--ink-soft);cursor:pointer;-webkit-backdrop-filter:blur(4px);border-radius:50%;place-items:center;padding:0;transition:background .18s,border-color .18s,color .18s,opacity .18s,transform .18s;display:grid}.piece-preview-button span{background:currentColor;width:14px;height:16px;margin-left:2px;-webkit-mask-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 18 20' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 2.7v14.6L15 10 4 2.7Z' fill='black'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 18 20' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 2.7v14.6L15 10 4 2.7Z' fill='black'/%3E%3C/svg%3E");-webkit-mask-position:50%;mask-position:50%;-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.piece-preview-button[aria-pressed=true]{background:var(--ink);color:var(--panel);border-color:#0000}.piece-preview-button[aria-pressed=true] span{width:12px;height:12px;margin-left:0;-webkit-mask-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 3h3v10H4V3Zm5 0h3v10H9V3Z' fill='black'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 3h3v10H4V3Zm5 0h3v10H9V3Z' fill='black'/%3E%3C/svg%3E")}.piece-preview-button[aria-busy=true]{cursor:progress;opacity:.72}.piece-preview-button:disabled{cursor:default;opacity:.38;background:color-mix(in srgb, var(--panel) 52%, transparent);color:var(--muted)}.piece-repertoire-toggle span{background:currentColor;width:15px;height:17px;-webkit-mask-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 18 22' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 2.5h10a1.5 1.5 0 0 1 1.5 1.5v15.2L9 15.6l-6.5 3.6V4A1.5 1.5 0 0 1 4 2.5Z' fill='black'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 18 22' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 2.5h10a1.5 1.5 0 0 1 1.5 1.5v15.2L9 15.6l-6.5 3.6V4A1.5 1.5 0 0 1 4 2.5Z' fill='black'/%3E%3C/svg%3E");-webkit-mask-position:50%;mask-position:50%;-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.piece-preview-button:hover:not(:disabled),.piece-repertoire-toggle:hover:not(:disabled){border-color:var(--hairline);background:var(--panel);color:var(--ink);transform:translateY(-1px)}.piece-preview-button:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.piece-repertoire-toggle:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.piece-repertoire-toggle[aria-pressed=true]{background:var(--lacquer);color:#fbfbf9;border-color:#0000}.piece-repertoire-toggle[aria-busy=true]{cursor:progress;opacity:.72}.piece-repertoire-toggle:disabled{cursor:default;opacity:.42}.piece-repertoire-toggle[data-error=true]{border-color:var(--red);color:var(--red-deep)}.piece-progress{grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:12px;display:grid}.piece-progress-name,.piece-progress-count{font-family:var(--font-body);letter-spacing:.12em;font-variant-numeric:tabular-nums;color:var(--ink-soft);text-transform:uppercase;font-size:10.5px;font-weight:700}.piece-progress-count{color:var(--muted)}.piece-progress-bar{background:var(--line);border-radius:100px;height:5px;overflow:hidden}.piece-progress-bar div{background:var(--ink);min-width:0;height:100%;box-shadow:2px 0 0 var(--red);border-radius:100px;transition:width .5s cubic-bezier(.22,.61,.36,1)}.piece-actions{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:10px;display:grid}.piece-action{border-radius:var(--radius-control);cursor:pointer;min-height:42px;font-family:var(--font-body);letter-spacing:-.003em;padding:0 14px;font-size:13.5px;font-weight:600;transition:background .18s,border-color .18s,color .18s,box-shadow .18s,transform .18s,opacity .18s}.piece-action--memorization{background:var(--lacquer);color:#fbfbf9;border:1px solid #0000}.piece-action--memorization:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 22px -12px #0c0b0ab3}.piece-action--practice{border:1px solid var(--line);color:var(--ink-soft);background:0 0}.piece-action--practice:hover:not(:disabled){border-color:var(--hairline);background:color-mix(in srgb, var(--panel) 64%, transparent);color:var(--ink)}.piece-action:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.piece-action:disabled{cursor:default;opacity:.52;box-shadow:none;transform:none}.piece-action[aria-busy=true]{cursor:progress;opacity:.78}.continue-hero{border:1px solid var(--line);border-radius:var(--radius-card);background:var(--panel);box-shadow:var(--shadow-card);grid-template-columns:132px minmax(0,1fr) auto;align-items:stretch;gap:22px;margin:0 0 28px;padding:22px 24px;display:grid}.continue-hero-portrait{object-fit:cover;object-position:center 12%;filter:grayscale()contrast(1.06);border-radius:11px;width:132px;height:100%;min-height:132px}.continue-hero-body{align-self:center;min-width:0}.continue-hero-kicker{letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);margin:0 0 8px;font-size:11px;font-weight:650;line-height:1.2}.continue-hero-title{font-family:var(--font-serif);font-optical-sizing:auto;font-variation-settings:"opsz" 120, "SOFT" 0, "WONK" 0;letter-spacing:0;color:var(--ink);text-wrap:balance;margin:0;font-size:clamp(30px,4vw,44px);font-weight:430;line-height:1.02}.continue-hero-composer{font-family:var(--font-serif);font-variation-settings:"opsz" 36, "SOFT" 0, "WONK" 0;color:var(--muted);margin:8px 0 0;font-size:16px;font-style:italic;line-height:1.35}.continue-hero-summary{color:var(--ink-soft);margin:16px 0 0;font-size:14px;font-weight:560;line-height:1.35}.continue-hero-action{border-radius:var(--radius-control);background:var(--lacquer);color:#fbfbf9;cursor:pointer;min-width:146px;min-height:46px;font-family:var(--font-body);letter-spacing:0;border:1px solid #0000;align-self:center;padding:0 22px;font-size:14px;font-weight:650;transition:box-shadow .18s,transform .18s,opacity .18s}.continue-hero-action:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 12px 24px -13px #0c0b0abd}.continue-hero-action:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.continue-hero-action:disabled{cursor:default;opacity:.52;box-shadow:none;transform:none}.continue-hero-action[aria-busy=true]{cursor:progress;opacity:.78}.piece-section--current .piece-section-header h2{font-variation-settings:"opsz" 90, "SOFT" 0, "WONK" 0}#current-repertoire{--current-repertoire-gap:20px;gap:var(--current-repertoire-gap);flex-wrap:wrap;display:flex}#current-repertoire .piece-card{flex:1 1 max(360px, calc((100% - var(--current-repertoire-gap)) / 2));isolation:isolate;grid-template:"plate body"1fr"plate progress""plate actions"/122px minmax(0,1fr);gap:16px 24px;max-width:560px;min-height:246px;padding:24px 26px 22px}#current-repertoire .piece-card[data-rated=true]{grid-template-rows:1fr auto auto auto;grid-template-areas:"plate body""plate badge""plate progress""plate actions"}#current-repertoire .piece-card:before{content:none}#current-repertoire .piece-card-body{grid-area:body;align-self:start;padding-right:64px}#current-repertoire .piece-progress{grid-area:progress}#current-repertoire .starter-difficulty-badge{grid-area:badge}#current-repertoire .piece-progress-bar{height:7px}#current-repertoire .piece-actions{grid-area:actions}#current-repertoire .piece-title{font-size:30px}#current-repertoire .piece-portrait{opacity:1;object-position:center 12%;filter:grayscale()contrast(1.06);border-radius:11px;grid-area:plate;align-self:stretch;width:100%;height:100%;min-height:188px;margin:0;position:relative;top:auto;bottom:auto;left:auto;right:auto}#piece-list{flex-direction:column;display:flex}.composer-divider{grid-template-columns:auto auto minmax(16px,1fr);align-items:center;gap:12px;margin:0;padding:26px 14px 10px;display:grid}.composer-divider:first-child{padding-top:6px}.composer-divider:after{content:"";background:var(--line);height:1px}.composer-divider-letter{font-family:var(--font-serif);font-variation-settings:"opsz" 40, "SOFT" 0, "WONK" 0;color:var(--muted);font-size:18px;font-weight:500;line-height:1}.composer-divider-name{font-family:var(--font-body);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);font-size:11.5px;font-weight:700}#piece-list .piece-card{border:none;border-top:1px solid var(--line);min-height:0;box-shadow:none;background:0 0;border-radius:0;grid-template-rows:auto;grid-template-columns:minmax(0,1fr) auto clamp(118px,16vw,190px) auto auto;align-items:center;gap:0 24px;padding:15px 16px;display:grid;overflow:hidden}.composer-divider+.piece-card{border-top:none}#piece-list .piece-card:hover,#piece-list .piece-card:focus-within{box-shadow:none;border-color:var(--line);background:color-mix(in srgb, var(--panel) 96%, var(--ink));transform:none}#piece-list .piece-card:before{width:2px}#piece-list .piece-portrait{display:none}#piece-list .piece-card-body{grid-area:1/1;min-width:0;padding-right:0}#piece-list .piece-composer{display:none}#piece-list .piece-title{white-space:nowrap;text-overflow:ellipsis;font-size:18px;line-height:1.25;overflow:hidden}#piece-list .starter-difficulty-badge{grid-area:1/2;align-self:center}#piece-list .piece-progress{grid-area:1/3;grid-template-columns:minmax(0,1fr) auto;gap:10px}#piece-list .piece-progress-name{display:none}#piece-list .piece-actions{grid-area:1/4;grid-template-columns:auto auto;gap:8px}#piece-list .piece-action{min-height:34px;padding:0 13px;font-size:12.5px}#piece-list .piece-card-quick-actions{z-index:auto;grid-area:1/5;position:static}#piece-list .piece-preview-button,#piece-list .piece-repertoire-toggle{-webkit-backdrop-filter:none;width:30px;height:30px}@media (prefers-reduced-motion:reduce){.app-navbar button,.app-navbar-settings,.app-navbar-settings span,.piece-card,.piece-card:before,.piece-portrait,.piece-preview-button,.piece-repertoire-toggle,.filter-select,.filter-select-chevron,.filter-token,.filter-search-input,.piece-request-toggle,.piece-request-submit,.piece-request-secondary,.piece-action,.continue-hero-action,.piece-request-form input,.piece-request-form textarea,.piece-progress-bar div{transition:none}.piece-card,.first-run-heading,.first-run-search,.filter-popover{animation:none}.app-navbar-settings:hover span{transform:none}}@media (max-width:640px){.app-navbar-inner,.library-shell{width:calc(100% - 32px)}.library-first-run{gap:20px;padding-top:26px}.first-run-heading h1{font-size:clamp(31px,10.5vw,44px)}#starter-shelf .piece-card:not(:first-child){flex-basis:calc(50% - 8px)}#starter-shelf .piece-card:not(:first-child),.starter-shelf--results .piece-card{min-height:190px;padding:16px 16px 14px}#starter-shelf .piece-card:not(:first-child) .piece-title,.starter-shelf--results .piece-card .piece-title{font-size:19px}#starter-shelf .piece-card:first-child{grid-template:"plate"120px"kicker""body""badge"/minmax(0,1fr);gap:12px}#starter-shelf .piece-card:first-child .piece-portrait{object-position:center 24%;min-height:120px}#starter-shelf .piece-card:first-child .piece-card-body{padding-right:56px}.app-navbar button{padding:0 11px;font-size:13px}.app-navbar-status-divider,.nav-today{display:none}.filter-search-wrap{flex:100%;max-width:none}.filter-controls{flex:100%}.filter-select{flex:1 1 0;justify-content:space-between}.filter-popover--composer{width:min(320px,100vw - 48px)}.piece-request-form{grid-template-columns:1fr}.piece-request-form-wide,.piece-request-actions,.piece-request-error{grid-column:1}.piece-request-actions{justify-content:stretch}.piece-request-actions button{flex:1}.continue-hero{grid-template-rows:120px auto auto;grid-template-columns:minmax(0,1fr);gap:18px;padding:20px}.continue-hero-portrait{width:100%;min-height:120px}.continue-hero-action{width:100%}#current-repertoire .piece-card{grid-template:"plate"120px"body""progress""actions"/minmax(0,1fr);max-width:none}#current-repertoire .piece-card[data-rated=true]{grid-template-rows:120px auto auto auto auto;grid-template-areas:"plate""body""badge""progress""actions"}#current-repertoire .piece-card-body{padding-right:56px}#current-repertoire .piece-portrait{min-height:120px}#current-repertoire .piece-actions{grid-template-columns:1fr 1fr}#piece-list .piece-card{grid-template-rows:auto auto;grid-template-columns:minmax(0,1fr) auto;gap:12px 14px;padding:16px}#piece-list .piece-card[data-rated=true]{grid-template-rows:auto auto auto}#piece-list .piece-card-body{grid-area:1/1/auto/-1;padding-right:96px}#piece-list .piece-title{white-space:normal;-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box}#piece-list .starter-difficulty-badge,#piece-list .piece-progress{grid-area:2/1}#piece-list .piece-card[data-rated=true] .piece-progress{grid-row:3}#piece-list .piece-actions{grid-area:2/2}#piece-list .piece-card[data-rated=true] .piece-actions{grid-row:3}#piece-list .piece-card-quick-actions{grid-area:auto;position:absolute;top:12px;right:12px}}.activity-panel{border:1px solid var(--line);border-radius:var(--radius-card);background:linear-gradient(180deg, color-mix(in srgb, var(--panel) 95%, var(--green) 3%), var(--panel)), var(--panel);box-shadow:var(--shadow-card);gap:16px;margin:18px 0 22px;padding:18px 20px 16px;display:grid}.activity-panel-header{justify-content:space-between;align-items:start;gap:16px;display:flex}.activity-panel h2{font-family:var(--font-body);color:var(--ink);margin:0;font-size:14px;font-weight:720}.activity-streak-summary{color:var(--muted);flex-wrap:wrap;gap:8px 12px;margin:6px 0 0;font-size:12.5px;line-height:1.35;display:flex}.activity-streak-summary span{align-items:center;gap:4px;display:inline-flex}.activity-streak-summary span:not(:first-child):before{content:"";background:var(--hairline);border-radius:50%;width:3px;height:3px;margin-right:4px}.activity-streak-summary strong{color:var(--ink);font-variant-numeric:tabular-nums}.activity-heatmap-scroll{padding-bottom:2px;overflow-x:auto}.activity-heatmap{--activity-cell-size:10px;--activity-cell-gap:3px;min-width:max-content;color:var(--muted);font-variant-numeric:tabular-nums;gap:5px;font-size:10px;display:inline-grid}.activity-months{grid-template-columns:26px repeat(53, var(--activity-cell-size));gap:var(--activity-cell-gap);align-items:end;min-height:14px;display:grid}.activity-months span{white-space:nowrap;min-width:0;overflow:visible}.activity-grid-body{gap:var(--activity-cell-gap);grid-template-columns:26px max-content;display:grid}.activity-weekdays,.activity-week,.activity-weeks{gap:var(--activity-cell-gap);display:grid}.activity-weekdays,.activity-week{grid-template-rows:repeat(7, var(--activity-cell-size))}.activity-weekdays span{align-items:center;min-width:0;line-height:1;display:flex}.activity-weeks{grid-auto-flow:column;grid-auto-columns:var(--activity-cell-size)}.activity-cell{width:var(--activity-cell-size,10px);height:var(--activity-cell-size,10px);background:color-mix(in srgb, var(--line) 48%, var(--panel));border:1px solid #0000;border-radius:2px;position:relative}.activity-cell[data-kind=empty],.activity-cell[data-kind=future-empty]{background:color-mix(in srgb, var(--line) 42%, var(--panel))}.activity-cell[data-kind=past][data-level="1"],.activity-cell[data-kind=today][data-level="1"]{background:color-mix(in srgb, var(--green) 20%, var(--paper));border-color:color-mix(in srgb, var(--green) 12%, var(--line))}.activity-cell[data-kind=past][data-level="2"],.activity-cell[data-kind=today][data-level="2"]{background:color-mix(in srgb, var(--green) 38%, var(--paper));border-color:color-mix(in srgb, var(--green) 20%, var(--line))}.activity-cell[data-kind=past][data-level="3"],.activity-cell[data-kind=today][data-level="3"]{background:color-mix(in srgb, var(--green) 62%, var(--paper));border-color:color-mix(in srgb, var(--green) 28%, var(--line))}.activity-cell[data-kind=past][data-level="4"],.activity-cell[data-kind=today][data-level="4"]{background:color-mix(in srgb, var(--green) 86%, var(--ink) 6%);border-color:color-mix(in srgb, var(--green) 54%, var(--line))}.activity-cell[data-kind=today]{outline:1px solid var(--red);outline-offset:1px}.activity-cell[data-kind=frozen]{background:color-mix(in srgb, var(--muted) 10%, var(--panel));border-color:color-mix(in srgb, var(--muted) 34%, var(--line))}.activity-cell[data-kind=future-forecast]{border-color:color-mix(in srgb, var(--focus) 42%, var(--line));background:0 0}.activity-cell[data-kind=future-forecast]:after{content:"";inset:calc(50% - var(--forecast-dot-size,2px));background:var(--focus);border-radius:50%;position:absolute}.activity-cell[data-kind=future-forecast][data-level="1"]{--forecast-dot-size:2px}.activity-cell[data-kind=future-forecast][data-level="2"]{--forecast-dot-size:3px}.activity-cell[data-kind=future-forecast][data-level="3"]{--forecast-dot-size:4px}.activity-cell[data-kind=future-forecast][data-level="4"]{--forecast-dot-size:5px}.activity-cell[data-kind=out-of-range]{opacity:0}.activity-legend{color:var(--muted);flex-wrap:wrap;align-items:center;gap:6px;font-size:11px;display:flex}.activity-legend-swatch{--activity-cell-size:10px;flex:none}.activity-legend-gap{width:8px}@media (max-width:720px){.activity-panel{padding:16px}.activity-streak-summary{font-size:12px}}.practice-shell{grid-template-rows:auto auto minmax(320px,1fr) auto auto minmax(0,250px);height:100vh;display:grid;overflow:hidden}.practice-navbar{-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--line);z-index:30;background:#fbfbf9e6;grid-row:1;align-items:center;gap:16px;width:100%;min-height:54px;padding:0 16px;display:none}body[data-library-available=true] .practice-navbar{display:flex}.practice-back{border:1px solid var(--hairline);min-height:36px;color:var(--ink);cursor:pointer;font-family:var(--font-body);letter-spacing:.18em;text-transform:uppercase;background:0 0;border-radius:100px;align-items:center;gap:7px;padding:0 16px 0 13px;font-size:11px;font-weight:600;transition:border-color .18s,color .18s,background .18s;display:inline-flex}.practice-back:hover{border-color:var(--ink-soft);background:var(--panel)}.practice-back:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.practice-back-chevron{margin-top:-1px;font-size:17px;font-weight:700;line-height:0}.practice-piece-title{min-width:0;color:var(--ink);font-family:var(--font-display);text-align:center;text-overflow:ellipsis;white-space:nowrap;flex:auto;font-size:20px;font-weight:600;line-height:1.1;overflow:hidden}.practice-piece-title[hidden]{display:none}.practice-source-edit-link{border:1px solid var(--hairline);min-height:36px;color:var(--ink-soft);font-family:var(--font-body);letter-spacing:.12em;text-transform:uppercase;background:0 0;border-radius:100px;flex:none;justify-content:center;align-items:center;gap:7px;padding:0 14px;font-size:11px;font-weight:650;text-decoration:none;transition:border-color .18s,color .18s,background .18s,transform .18s;display:inline-flex}.practice-source-edit-link[hidden]{display:none}.practice-source-edit-link span{background:currentColor;width:14px;height:14px;-webkit-mask-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M13.7 2.4a2.1 2.1 0 0 1 3 3l-9.4 9.4-4.1 1.1 1.1-4.1 9.4-9.4Zm1.9 1.1a.8.8 0 0 0-1.1 0l-.8.8 1.1 1.1.8-.8a.8.8 0 0 0 0-1.1ZM5.5 12.4l-.5 1.8 1.8-.5 7-7-1.3-1.3-7 7Z' fill='black'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M13.7 2.4a2.1 2.1 0 0 1 3 3l-9.4 9.4-4.1 1.1 1.1-4.1 9.4-9.4Zm1.9 1.1a.8.8 0 0 0-1.1 0l-.8.8 1.1 1.1.8-.8a.8.8 0 0 0 0-1.1ZM5.5 12.4l-.5 1.8 1.8-.5 7-7-1.3-1.3-7 7Z' fill='black'/%3E%3C/svg%3E");-webkit-mask-position:50%;mask-position:50%;-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.practice-source-edit-link:hover{border-color:var(--ink-soft);background:var(--panel);color:var(--ink);transform:translateY(-1px)}.practice-source-edit-link:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.practice-youtube-button{border:1px solid var(--hairline);width:42px;height:36px;color:var(--ink);cursor:pointer;background:0 0;border-radius:100px;flex:none;justify-content:center;align-items:center;transition:border-color .18s,background .18s,transform .18s;display:inline-flex}.practice-youtube-button[hidden]{display:none}.practice-youtube-button:hover{border-color:var(--red);background:#c1121f0f}.practice-youtube-button:active{transform:translateY(1px)}.practice-youtube-button:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.render-settings-menu{flex:none;position:relative}.render-settings-trigger{border:1px solid var(--hairline);min-height:36px;color:var(--ink-soft);cursor:pointer;font-family:var(--font-body);letter-spacing:.12em;text-transform:uppercase;background:0 0;border-radius:100px;justify-content:center;align-items:center;gap:8px;padding:0 13px;font-size:11px;font-weight:650;transition:border-color .18s,color .18s,background .18s,transform .18s;display:inline-flex}.render-settings-trigger:hover:not(:disabled),.render-settings-trigger[aria-expanded=true]{border-color:var(--ink-soft);background:var(--panel);color:var(--ink)}.render-settings-trigger:active:not(:disabled){transform:translateY(1px)}.render-settings-trigger:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.render-settings-option:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.render-settings-trigger:disabled{cursor:default;opacity:.62}.render-settings-icon{background:color-mix(in srgb, var(--ink) 8%, transparent);width:18px;height:18px;color:var(--ink);letter-spacing:0;border-radius:50%;place-items:center;font-size:13px;font-weight:800;line-height:1;display:inline-grid}.render-settings-trigger-label{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.render-settings-chevron{opacity:.58;border-bottom:1.5px solid;border-right:1.5px solid;width:7px;height:7px;margin-top:-3px;transform:rotate(45deg)}.render-settings-popover{z-index:60;border:1px solid var(--line);width:218px;box-shadow:var(--shadow-card-hover);color:var(--ink);-webkit-backdrop-filter:blur(14px);background:#fbfbf9fa;border-radius:8px;padding:8px;position:absolute;top:calc(100% + 8px);right:0}.render-settings-popover[hidden]{display:none}.render-settings-group-label{color:var(--muted);font-family:var(--font-body);letter-spacing:.12em;text-transform:uppercase;padding:5px 8px 8px;font-size:11px;font-weight:700}.render-settings-option{width:100%;min-height:36px;color:var(--ink);cursor:pointer;font-family:var(--font-body);letter-spacing:0;text-align:left;background:0 0;border:0;border-radius:6px;grid-template-columns:18px minmax(0,1fr);align-items:center;gap:9px;padding:0 9px;font-size:13px;font-weight:620;display:grid}.render-settings-option:hover:not(:disabled),.render-settings-option[data-selected=true]{background:color-mix(in srgb, var(--ink) 7%, transparent)}.render-settings-option:disabled{cursor:default;opacity:.65}.render-settings-option-check{border:1px solid var(--hairline);border-radius:50%;place-items:center;width:18px;height:18px;display:grid}.render-settings-option[data-selected=true] .render-settings-option-check{border-color:var(--ink);background:var(--ink)}.render-settings-option[data-selected=true] .render-settings-option-check:after{content:"";border-right:2px solid var(--panel);border-bottom:2px solid var(--panel);width:6px;height:9px;margin-top:-1px;transform:rotate(40deg)}.render-settings-option-label{overflow-wrap:anywhere;min-width:0}.render-settings-size{grid-template-columns:28px minmax(0,1fr) 28px;align-items:center;gap:6px;padding:0 9px 6px;display:grid}.render-settings-size-step{border:1px solid var(--hairline);width:28px;height:28px;color:var(--ink);cursor:pointer;font-family:var(--font-body);background:0 0;border-radius:50%;place-items:center;font-size:15px;font-weight:650;line-height:1;display:grid}.render-settings-size-step:hover:not(:disabled){border-color:var(--ink-soft);background:color-mix(in srgb, var(--ink) 7%, transparent)}.render-settings-size-step:disabled{cursor:default;opacity:.4}.render-settings-size-step:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.render-settings-size-value{color:var(--ink);font-family:var(--font-body);font-variant-numeric:tabular-nums;text-align:center;font-size:13px;font-weight:620}.practice-youtube-mark{background:#f03;border-radius:5px;width:24px;height:17px;display:block;position:relative;box-shadow:0 5px 12px #c1121f33}.practice-youtube-play{border-top:4px solid #0000;border-bottom:4px solid #0000;border-left:7px solid #fff;width:0;height:0;position:absolute;top:50%;left:50%;transform:translate(-36%,-50%)}.practice-video-modal[hidden]{display:none}.practice-video-modal{z-index:100;place-items:center;padding:24px;display:grid;position:fixed;top:0;bottom:0;left:0;right:0}.practice-video-backdrop{-webkit-backdrop-filter:blur(4px);background:#1212129e;position:absolute;top:0;bottom:0;left:0;right:0}.practice-video-panel{background:#11100f;border:1px solid #ffffff38;border-radius:8px;width:min(960px,100%);max-height:calc(100vh - 48px);position:relative;overflow:hidden;box-shadow:0 30px 80px #0000005c}.practice-video-header{color:#fff;background:#11100f;border-bottom:1px solid #ffffff1f;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:12px;min-height:56px;padding:0 12px 0 18px;display:grid}.practice-video-header h2{font-family:var(--font-body);letter-spacing:0;text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:14px;font-weight:650;line-height:1.2;overflow:hidden}.practice-video-open-link{color:#fff;font-family:var(--font-body);letter-spacing:0;opacity:.74;font-size:12px;font-weight:650;text-decoration:none}.practice-video-open-link:hover{opacity:1;text-underline-offset:3px;text-decoration:underline}.practice-video-open-link:focus-visible{outline-offset:2px;outline:2px solid #fff}.practice-video-close:focus-visible{outline-offset:2px;outline:2px solid #fff}.practice-video-close{color:#fff;cursor:pointer;width:34px;height:34px;font-family:var(--font-body);background:#ffffff0f;border:1px solid #ffffff38;border-radius:100px;justify-content:center;align-items:center;font-size:24px;line-height:1;display:inline-flex}.practice-video-close:hover{background:#ffffff1f}.practice-video-close span{transform:translateY(-1px)}.practice-video-frame-shell{aspect-ratio:16/9;background:#000;width:100%}.practice-video-frame-shell iframe{border:0;width:100%;height:100%;display:block}.memorization-session-progress{border-bottom:1px solid var(--line);z-index:20;background:#fbfbf9db;grid-row:2;justify-items:center;gap:6px;width:100%;min-height:48px;padding:8px 24px 9px;display:grid}.memorization-session-progress[hidden],.memorization-session-goal[hidden],.memorization-session-rail[hidden]{display:none}.memorization-session-goal{width:100%;max-width:100%;color:var(--ink-soft);font-family:var(--font-body);text-align:center;text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:12px;font-weight:650;line-height:1.25;overflow:hidden}.memorization-session-rail{flex-wrap:wrap;justify-content:center;align-items:center;gap:7px;min-height:18px;display:flex}.memorization-session-pip{border:1.5px solid var(--ink-soft);width:18px;height:10px;color:var(--ink-soft);background:0 0;border-radius:999px;flex:none;justify-content:center;align-items:center;font-size:14px;line-height:1;transition:background .25s,border-color .25s,box-shadow .25s,color .25s,transform .25s;display:inline-flex}.memorization-session-pip[data-state=active]{border-color:var(--ink);box-shadow:0 0 0 3px color-mix(in srgb, var(--ink) 10%, transparent);animation:1.35s ease-in-out infinite session-pip-pulse}.memorization-session-pip[data-state=introduced],.memorization-session-pip[data-state=in_recovery]{border-color:var(--green);background:linear-gradient(90deg, var(--green) 50%, transparent 50%)}.memorization-session-pip[data-state=in_recovery]{border-color:var(--red);animation:1.35s ease-in-out infinite session-pip-pulse;box-shadow:0 0 0 3px #b12e371a}.memorization-session-pip[data-state=done]{border-color:var(--green);background:var(--green)}.memorization-session-pip[data-kind=bonus]{opacity:.78;border-style:dashed}.memorization-session-pip[data-kind=checkpoint]{width:18px;height:18px;color:var(--ink-soft);background:0 0;border:0;border-radius:0;font-size:17px}.memorization-session-pip[data-kind=checkpoint][data-state=done]{color:var(--green)}.memorization-session-pip--celebrate{animation:.7s ease-out session-pip-complete}.memorization-session-pip[data-kind=checkpoint].memorization-session-pip--celebrate{animation:1.05s cubic-bezier(.22,1,.36,1) session-star-complete}@keyframes session-pip-pulse{0%,to{transform:translateY(0)}50%{transform:translateY(-1px)}}@keyframes session-pip-complete{0%{transform:scale(1);box-shadow:0 0 #297d4f3d}42%{transform:scale(1.2);box-shadow:0 0 0 7px #297d4f24}to{transform:scale(1);box-shadow:0 0 #297d4f00}}.memorization-session-pip--shimmer{animation:.6s ease-out both session-rail-shimmer}.memorization-session-pip[data-kind=checkpoint].memorization-session-pip--shimmer{animation:1.05s cubic-bezier(.22,1,.36,1) both session-star-complete}@keyframes session-rail-shimmer{0%{transform:translateY(0);box-shadow:0 0 #297d4f00}40%{transform:translateY(-3px);box-shadow:0 0 0 4px #297d4f29}to{transform:translateY(0);box-shadow:0 0 #297d4f00}}@keyframes session-star-complete{0%{text-shadow:0 0 #297d4f00;transform:scale(1)rotate(0)}30%{text-shadow:0 0 14px #297d4f80;transform:scale(1.6)rotate(-8deg)}60%{text-shadow:0 0 8px #297d4f4d;transform:scale(1.2)rotate(4deg)}to{text-shadow:0 0 #297d4f00;transform:scale(1)rotate(0)}}.memorization-guidance{text-align:center;color:var(--ink);z-index:10;background:0 0;grid-row:4;justify-items:center;gap:4px;padding:14px 24px 12px;display:grid}.memorization-guidance[hidden]{display:none}.memorization-guidance p{overflow-wrap:break-word;width:min(100%,720px);margin:0}.memorization-guidance-instruction{font-family:var(--font-display);font-optical-sizing:auto;color:var(--ink-soft);font-size:20px;font-style:italic;font-weight:600;line-height:1.3}.memorization-guidance-commentary{min-height:1.2em;color:var(--ink-soft);font-family:var(--font-display);font-size:17px;font-weight:700;line-height:1.2}.memorization-guidance[data-commentary-cue=target_error] .memorization-guidance-commentary{color:var(--red)}.memorization-hud-status{justify-content:center;align-items:center;gap:12px;min-height:22px;display:flex}.memorization-badge{border:1px solid var(--hairline);background:var(--panel);color:var(--ink-soft);letter-spacing:.04em;text-transform:uppercase;white-space:nowrap;border-radius:999px;align-items:center;padding:2px 10px;font-size:12px;font-weight:600;display:inline-flex}.memorization-badge[data-stage=test]{border-color:var(--red);color:var(--red)}.memorization-badge[hidden]{display:none}.memorization-dots{align-items:center;gap:7px;display:inline-flex}.memorization-dots[hidden]{display:none}.memorization-dot{border:1.5px solid var(--ink-soft);background:0 0;border-radius:50%;width:10px;height:10px;transition:background .25s,border-color .25s}.memorization-dot[data-filled=true]{border-color:var(--green);background:var(--green)}.stage{scroll-behavior:smooth;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E"),radial-gradient(150% 120% at 50% -25%,#ffffffb8 0%,#fff0 55%),radial-gradient(120% 100% at 50% 125%,#1c1b1812 0%,#1c1b1800 62%),linear-gradient(#f4f1ea 0%,#efeae0 100%);grid-row:3;min-width:0;min-height:0;padding:24px;overflow:auto}#score{width:min(calc(1180px * var(--clef-score-size,1)), 100%);background:var(--panel);border:1px solid var(--hairline);border-radius:2px;min-height:100%;margin:0 auto;position:relative;box-shadow:inset 0 1px #ffffffe6,0 1px 1px #1918140d,0 22px 60px -26px #19181480}#score svg{width:100%;height:auto;display:block;overflow:visible}body[data-layout=horizontal] #score,#score[data-layout=horizontal]{width:max-content;min-width:100%;height:calc(100% * var(--clef-score-size,1));min-height:0}body[data-layout=horizontal] #score svg,#score[data-layout=horizontal] svg{width:auto;max-width:none;height:100%}.clef-correct,.clef-correct *{color:var(--green)!important;fill:var(--green)!important;stroke:var(--green)!important}.clef-incorrect,.clef-incorrect *{color:var(--red)!important;fill:var(--red)!important;stroke:var(--red)!important}.clef-cursor-ring{fill:var(--focus);fill-opacity:.3;pointer-events:none}.memo-tip-card{z-index:60;border:1px solid var(--hairline);background:var(--panel);max-width:320px;color:var(--ink);border-radius:10px;padding:14px 16px;position:fixed;box-shadow:0 14px 40px -18px #1918148c}.memo-tip-card p{margin:0}.memo-tip-card-title{font-family:var(--font-display);margin-bottom:4px;font-size:17px;font-weight:700}.memo-tip-card-body{color:var(--ink-soft);font-size:14px;line-height:1.45}.memo-tip-card-button{border:1px solid var(--ink);background:var(--ink);color:var(--panel);cursor:pointer;border-radius:999px;margin-top:10px;padding:6px 14px;font-size:13px;font-weight:600}.memo-tip-card-button:hover{opacity:.88}.clef-target-spotlight{fill:var(--focus);fill-opacity:.1;stroke:var(--focus);stroke-opacity:.4;stroke-width:4px;pointer-events:none}.clef-lead-in-tint{opacity:.45}.clef-hidden-measure{visibility:hidden!important}.clef-hidden-measure>.staff>path,.clef-hidden-measure>.barLine,.clef-hidden-measure>.barLine *,.clef-hidden-measure.clef-revealed-target,.clef-hidden-measure .clef-revealed-target,.clef-hidden-measure .clef-revealed-target *,.clef-hidden-measure .clef-wrong-overlay,.clef-hidden-measure .clef-wrong-overlay *{visibility:visible!important}.clef-review-feedback-edge{pointer-events:none;z-index:2147483647;opacity:0;box-shadow:none;transition:opacity .28s ease-out,box-shadow .28s ease-out;position:fixed}.clef-review-feedback-edge.top,.clef-review-feedback-edge.bottom{width:100%;height:0;left:0}.clef-review-feedback-edge.left,.clef-review-feedback-edge.right{width:0;height:100%;top:0}.clef-review-feedback-edge.top{top:0}.clef-review-feedback-edge.bottom{bottom:0}.clef-review-feedback-edge.left{left:0}.clef-review-feedback-edge.right{right:0}.clef-review-feedback-edge.good,.clef-review-feedback-edge.again{transition:opacity 80ms ease-out,box-shadow 80ms ease-out}.clef-review-feedback-edge.good{opacity:1;box-shadow:0 0 7vh 1.2vh var(--green)}.clef-review-feedback-edge.again{opacity:.45;box-shadow:0 0 3vh .5vh var(--red)}.controls{border-top:1px solid var(--line);z-index:10;background:#f7f3eaf5;grid-row:5;justify-content:center;align-items:center;gap:14px;padding:16px 24px;display:none;box-shadow:0 -12px 32px #19181414}.controls[data-visible=true]{display:flex}.controls button{border:1px solid var(--hairline);min-width:152px;min-height:52px;color:var(--ink);cursor:pointer;font-family:var(--font-body);letter-spacing:.2em;text-transform:uppercase;background:0 0;border-radius:100px;justify-content:center;align-items:center;gap:11px;padding:0 26px;font-size:12px;font-weight:600;transition:transform .2s,box-shadow .32s,border-color .18s,color .18s;display:inline-flex;position:relative;overflow:hidden}.controls button[hidden]{display:none}.controls button:hover:not(:disabled){border-color:var(--ink-soft)}.controls button:active:not(:disabled){transform:translateY(1px)}.controls button:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.control-key{min-width:18px;height:18px;font-family:var(--font-body);letter-spacing:.06em;opacity:.5;border:1px solid;border-radius:4px;justify-content:center;align-items:center;padding:0 5px;font-size:9px;font-weight:600;line-height:1;display:inline-flex}@media (max-width:720px){.stage,.memorization-session-progress,.memorization-guidance,.controls{justify-self:start;width:100vw;max-width:100vw}.stage{padding:12px}.memorization-guidance{padding:12px 14px 10px}.memorization-session-progress{min-height:46px;padding:7px 12px 8px}.memorization-session-goal{text-overflow:clip;white-space:normal;font-size:11px;overflow:visible}.memorization-session-rail{gap:6px}.practice-piece-title{text-align:left;padding-right:0;font-size:18px}.practice-youtube-button{width:40px}.render-settings-trigger{gap:0;width:40px;min-width:40px;padding:0}.render-settings-trigger-label,.render-settings-chevron{display:none}.render-settings-popover{width:min(218px,100vw - 24px)}.practice-source-edit-link{letter-spacing:0;width:40px;padding:0}.practice-source-edit-link:not([hidden]){display:inline-flex}.practice-source-edit-link{font-size:0}.practice-video-modal{padding:12px}.practice-video-panel{max-height:calc(100vh - 24px)}.practice-video-header{grid-template-columns:minmax(0,1fr) auto;min-height:52px;padding-left:14px}.practice-video-open-link{display:none}.memorization-guidance-instruction{font-size:18px}.memorization-guidance-commentary{font-size:16px}.controls{flex-wrap:wrap;gap:10px;padding:14px 16px}.controls button{flex:140px;min-width:0;min-height:50px;padding:0 16px;font-size:11px}}@media (prefers-reduced-motion:reduce){.stage{scroll-behavior:auto}.memorization-session-pip,.memorization-session-pip[data-state=active],.memorization-session-pip[data-state=in_recovery],.memorization-session-pip--celebrate,.memorization-session-pip[data-kind=checkpoint].memorization-session-pip--celebrate,.memorization-session-pip--shimmer,.memorization-session-pip[data-kind=checkpoint].memorization-session-pip--shimmer,.practice-back,.render-settings-trigger,.practice-source-edit-link,.practice-youtube-button,.controls button,.clef-review-feedback-edge{transition:none;animation:none}}.session-complete-panel{z-index:55;right:max(20px, env(safe-area-inset-right));bottom:max(20px, env(safe-area-inset-bottom));border:1px solid color-mix(in srgb, var(--ink) 18%, var(--paper));border-left:4px solid var(--green);background:linear-gradient(180deg, #fffffffa, #fbfbf9f5), var(--panel);width:min(520px,100vw - 40px);color:var(--ink);font-family:var(--font-body);border-radius:8px;gap:14px;padding:22px;animation:.32s cubic-bezier(.22,1,.36,1) .45s both session-complete-in;display:grid;position:fixed;box-shadow:0 18px 60px #12121233}@keyframes session-complete-in{0%{opacity:0;transform:translateY(10px)scale(.98)}}.session-complete-kicker{color:var(--green);letter-spacing:.08em;text-transform:uppercase;font-size:.72rem;font-weight:800}.session-complete-panel h2,.session-complete-panel p{margin:0}.session-complete-panel h2{font-family:var(--font-display);letter-spacing:0;font-size:1.35rem;font-weight:800;line-height:1.15}.session-complete-copy{color:var(--ink-soft);font-size:.96rem;line-height:1.45}.session-complete-stats{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;padding-top:2px;display:grid}.session-complete-stat{border:1px solid var(--line);background:color-mix(in srgb, var(--paper) 80%, var(--panel));border-radius:8px;align-content:center;gap:4px;min-width:0;min-height:74px;padding:12px;display:grid}.session-complete-stat strong{font-size:1.45rem;font-weight:850;line-height:1}.session-complete-stat span{color:var(--muted);font-size:.82rem;font-weight:700;line-height:1.25}.session-complete-mastery{gap:7px;min-width:0;display:grid}.session-complete-mastery-track{border:1px solid color-mix(in srgb, var(--green) 34%, var(--line));background:color-mix(in srgb, var(--green) 8%, var(--paper));border-radius:999px;width:100%;height:7px;overflow:hidden}.session-complete-mastery-track span{border-radius:inherit;background:var(--green);height:100%;transition:width .32s;display:block}.session-complete-mastery p{color:var(--ink-soft);font-size:.9rem;font-weight:720;line-height:1.3}.session-complete-streak{color:var(--ink-soft);font-variant-numeric:tabular-nums;justify-self:start;align-items:center;gap:7px;font-size:.94rem;font-weight:760;line-height:1.25;display:inline-flex}.session-complete-streak .nav-streak-flame{background:var(--muted);flex:none;width:16px;height:16px}.session-complete-streak[data-live] .nav-streak-flame{background:var(--red);animation:.55s ease-out .9s both session-streak-flame-pop}@keyframes session-streak-flame-pop{0%{transform:scale(1)}40%{transform:scale(1.35)rotate(-5deg)}70%{transform:scale(.92)rotate(3deg)}to{transform:scale(1)rotate(0)}}.session-complete-next{border-left:3px solid color-mix(in srgb, var(--green) 72%, var(--paper));background:color-mix(in srgb, var(--green) 8%, var(--paper));color:var(--ink-soft);padding:10px 12px;font-size:.9rem;font-weight:650;line-height:1.35}.session-complete-actions{flex-wrap:wrap;justify-content:flex-end;gap:10px;padding-top:2px;display:flex}.session-complete-primary,.session-complete-secondary{cursor:pointer;min-height:40px;font-family:var(--font-body);letter-spacing:0;border-radius:6px;padding:9px 14px;font-size:.92rem;font-weight:800}.session-complete-primary{border:1px solid var(--ink);background:var(--ink);color:var(--paper)}.session-complete-secondary{border:1px solid var(--hairline);color:var(--ink);background:0 0}.session-complete-secondary:disabled{cursor:not-allowed;opacity:.48}.session-complete-primary:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.session-complete-secondary:focus-visible{outline:2px solid var(--focus);outline-offset:2px}@media (prefers-reduced-motion:reduce){.session-complete-panel,.session-complete-streak[data-live] .nav-streak-flame{animation:none}}@media (max-width:720px){.session-complete-panel{right:max(12px, env(safe-area-inset-right));bottom:max(12px, env(safe-area-inset-bottom));width:calc(100vw - 24px);padding:18px}.session-complete-stats{grid-template-columns:1fr}.session-complete-actions{justify-content:stretch}.session-complete-primary,.session-complete-secondary{flex:160px}}.tour-sheet{z-index:40;right:max(18px, env(safe-area-inset-right));bottom:max(18px, env(safe-area-inset-bottom));border:1px solid color-mix(in srgb, var(--ink) 18%, var(--paper));background:linear-gradient(180deg, #fffffff7, #fbfbf9f0), var(--panel);width:min(560px,100vw - 36px);color:var(--ink);border-radius:8px;gap:14px;padding:22px;display:grid;position:fixed;box-shadow:0 18px 60px #1212122e}.tour-sheet--compact{width:min(460px,100vw - 36px)}.tour-sheet-kicker{color:var(--red-deep);letter-spacing:.08em;text-transform:uppercase;font-size:.72rem;font-weight:800}.tour-sheet h2,.tour-sheet h3,.tour-sheet p{margin:0}.tour-sheet h2{font-family:var(--font-display);font-size:1.35rem;font-weight:700;line-height:1.15}.tour-sheet-copy{color:var(--ink-soft);font-size:.96rem;line-height:1.45}.tour-steps{gap:10px;margin:0;padding:2px 0 0;list-style:none;display:grid}.tour-steps li{grid-template-columns:30px minmax(0,1fr);align-items:start;gap:10px;display:grid}.tour-step-index{border:1px solid var(--hairline);background:var(--paper);width:28px;height:28px;color:var(--ink);border-radius:999px;place-items:center;font-size:.82rem;font-weight:800;line-height:1;display:inline-grid}.tour-steps h3{font-size:.94rem;font-weight:800}.tour-steps p{color:var(--muted);margin-top:2px;font-size:.88rem;line-height:1.35}.tour-actions{flex-wrap:wrap;justify-content:flex-end;gap:10px;padding-top:2px;display:flex}.tour-primary,.tour-secondary{cursor:pointer;min-height:40px;font-family:var(--font-body);border-radius:6px;padding:9px 14px;font-size:.92rem;font-weight:800}.tour-primary{border:1px solid var(--ink);background:var(--ink);color:var(--paper)}.tour-secondary{border:1px solid var(--hairline);color:var(--ink);background:0 0}.tour-primary:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.tour-secondary:focus-visible{outline:2px solid var(--focus);outline-offset:2px}@media (max-width:720px){.tour-sheet,.tour-sheet--compact{right:max(12px, env(safe-area-inset-right));bottom:max(12px, env(safe-area-inset-bottom));width:calc(100vw - 24px);padding:18px}.tour-actions{justify-content:stretch}.tour-primary,.tour-secondary{flex:160px}}.auth-page{background:var(--paper);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-card{background:var(--panel);border:1px solid var(--line);border-radius:10px;flex-direction:column;gap:16px;width:100%;max-width:380px;padding:32px;display:flex}.auth-title{font-family:var(--font-display);color:var(--ink);margin:0;font-size:1.9rem;font-weight:600}.auth-google{border:1px solid var(--hairline);background:var(--paper);min-height:44px;color:var(--ink);font-family:var(--font-body);border-radius:6px;justify-content:center;align-items:center;gap:10px;padding:10px 14px;font-size:.95rem;font-weight:700;text-decoration:none;display:inline-flex}.auth-google:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.auth-google-mark{flex:none;width:20px;height:20px;display:block}.auth-divider{color:var(--muted);text-transform:uppercase;align-items:center;gap:10px;font-size:.78rem;font-weight:700;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--line);flex:1;height:1px}.auth-field{color:var(--ink-soft);flex-direction:column;gap:6px;font-size:.9rem;display:flex}.auth-field input,.auth-field select{border:1px solid var(--hairline);background:var(--paper);color:var(--ink);font-family:var(--font-body);border-radius:6px;padding:10px 12px;font-size:1rem}.auth-field input:focus-visible{outline:2px solid var(--focus);outline-offset:1px}.auth-field select:focus-visible{outline:2px solid var(--focus);outline-offset:1px}.auth-error{color:var(--red-deep);margin:0;font-size:.9rem}.auth-copy{color:var(--ink-soft);margin:0;font-size:.95rem;line-height:1.5}.auth-submit{background:var(--ink);color:var(--paper);cursor:pointer;font-family:var(--font-body);border:none;border-radius:6px;padding:11px 16px;font-size:1rem;font-weight:600}.auth-submit:disabled{opacity:.6;cursor:default}.auth-link-button{justify-content:center;align-items:center;text-decoration:none;display:inline-flex}.auth-footer{color:var(--muted);font-size:.9rem}.auth-footer a,.auth-footer-link{color:var(--focus)}.billing-start-card{max-width:420px}.billing-start-kicker{color:var(--red-deep);letter-spacing:.11em;text-transform:uppercase;margin:0;font-size:.75rem;font-weight:800}.billing-start-copy,.billing-start-note{color:var(--ink-soft);margin:0;font-size:.95rem;line-height:1.5}.billing-start-note{color:var(--muted);font-size:.88rem}.billing-start-note a{color:var(--focus)}.settings-account{color:var(--ink-soft);margin:0}.settings-password{border-top:1px solid var(--line);flex-direction:column;gap:12px;padding-top:16px;display:flex}.settings-password h2,.settings-section-heading h2{font-family:var(--font-display);margin:0;font-size:1.3rem;font-weight:600}.settings-telemetry,.settings-billing{border-top:1px solid var(--line);flex-direction:column;gap:12px;padding-top:16px;display:flex}.settings-section-heading{justify-content:space-between;align-items:center;gap:12px;display:flex}.settings-secondary-button{border:1px solid var(--hairline);min-width:92px;color:var(--ink);cursor:pointer;font-family:var(--font-body);background:0 0;border-radius:999px;padding:8px 12px;font-size:.82rem;font-weight:700}.settings-secondary-button:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.settings-secondary-button:disabled{opacity:.5;cursor:default}.settings-telemetry-copy{color:var(--ink-soft);margin:0;font-size:.9rem}.settings-telemetry-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.settings-billing-status{border:1px solid var(--line);color:var(--ink-soft);letter-spacing:.04em;text-transform:uppercase;border-radius:999px;padding:4px 9px;font-size:.74rem;font-weight:700}.settings-billing-status[data-status=active],.settings-billing-status[data-status=trialing]{border-color:color-mix(in srgb, var(--green) 30%, var(--line));color:var(--green)}.settings-billing-status[data-status=past_due],.settings-billing-status[data-status=unpaid],.settings-billing-status[data-status=canceled],.settings-billing-status[data-status=incomplete],.settings-billing-status[data-status=incomplete_expired]{border-color:color-mix(in srgb, var(--red-deep) 30%, var(--line));color:var(--red-deep)}.settings-telemetry-status{border:1px solid var(--line);color:var(--ink-soft);letter-spacing:.04em;text-transform:uppercase;border-radius:999px;padding:4px 9px;font-size:.74rem;font-weight:700}.settings-telemetry-status[data-status=granted]{border-color:color-mix(in srgb, var(--green) 30%, var(--line));color:var(--green)}.settings-telemetry-status[data-status=denied]{border-color:color-mix(in srgb, var(--red-deep) 24%, var(--line));color:var(--red-deep)}.settings-billing-copy,.settings-billing-warning{color:var(--ink-soft);margin:0;font-size:.9rem}.settings-billing-warning{color:var(--red-deep)}.settings-billing-actions{align-items:center;gap:10px;display:flex}.settings-billing-actions .auth-submit,.settings-billing-actions .settings-secondary-button{width:auto}.settings-saved{color:var(--green);margin:0;font-size:.9rem}.settings-logout{border:1px solid var(--hairline);color:var(--ink);background:0 0}.onboarding-page{background:radial-gradient(120% 80% at 50% -10%, color-mix(in srgb, var(--panel) 70%, var(--paper)) 0%, var(--paper) 60%);place-items:center;min-height:100vh;padding:clamp(20px,5vw,72px);display:grid}.midi-setup{flex-direction:column;gap:18px;display:flex}.midi-setup--onboarding{background:var(--panel);border:1px solid var(--line);width:min(100%,560px);box-shadow:0 1px 2px color-mix(in srgb, var(--ink) 5%, transparent), 0 28px 60px -36px color-mix(in srgb, var(--ink) 42%, transparent);border-radius:16px;margin:0 auto;padding:clamp(26px,4vw,44px)}.midi-setup--onboarding[data-step=connection_guide]{width:min(100%,760px)}.midi-setup--settings{border-top:1px solid var(--line);padding-top:16px}.midi-setup-progress{grid-auto-columns:1fr;grid-auto-flow:column;gap:0;margin:0 0 6px;padding:0;list-style:none;display:grid}.midi-setup-progress-step{flex-direction:column;align-items:center;gap:8px;min-width:0;display:flex;position:relative}.midi-setup-progress-step:before,.midi-setup-progress-step:after{content:"";background:var(--line);height:2px;position:absolute;top:8px}.midi-setup-progress-step:before{margin-right:9px;left:0;right:50%}.midi-setup-progress-step:after{margin-left:9px;left:50%;right:0}.midi-setup-progress-step:first-child:before,.midi-setup-progress-step:last-child:after{display:none}.midi-setup-progress-step[data-state=complete]:before,.midi-setup-progress-step[data-state=complete]:after,.midi-setup-progress-step[data-state=current]:before{background:var(--ink)}.midi-setup-progress-node{z-index:1;border:2px solid var(--line);background:var(--panel);width:16px;height:16px;color:var(--paper);border-radius:999px;place-items:center;transition:border-color .3s,background .3s,box-shadow .3s;display:grid;position:relative}.midi-setup-progress-step[data-state=complete] .midi-setup-progress-node{border-color:var(--ink);background:var(--ink)}.midi-setup-progress-step[data-state=current] .midi-setup-progress-node{border-color:var(--red);box-shadow:0 0 0 3px color-mix(in srgb, var(--red) 16%, transparent)}.midi-setup-progress-node svg{width:10px;height:10px}.midi-setup-progress-label{max-width:100%;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;text-overflow:ellipsis;font-size:.68rem;font-weight:700;transition:color .3s;overflow:hidden}.midi-setup-progress-step[data-state=complete] .midi-setup-progress-label,.midi-setup-progress-step[data-state=current] .midi-setup-progress-label{color:var(--ink)}.midi-setup-stage-live{flex-direction:column;display:flex}.midi-setup-step{text-align:center;flex-direction:column;align-items:center;gap:14px;display:flex}.midi-setup-visual{place-items:center;margin-bottom:2px;display:grid}.midi-setup-visual-token{border:1px solid var(--line);background:linear-gradient(180deg, color-mix(in srgb, var(--ink) 4%, var(--panel)), var(--panel));width:68px;height:68px;color:var(--ink);border-radius:18px;place-items:center;display:grid;position:relative}.midi-setup-visual-token svg{z-index:1;width:30px;height:30px;position:relative}.midi-setup-visual--default .midi-icon-accent{color:var(--red)}.midi-setup-visual--success .midi-setup-visual-token{color:var(--green);border-color:color-mix(in srgb, var(--green) 32%, var(--line));background:color-mix(in srgb, var(--green) 8%, var(--panel))}.midi-setup-visual--failure .midi-setup-visual-token{color:var(--red-deep);border-color:color-mix(in srgb, var(--red-deep) 28%, var(--line));background:color-mix(in srgb, var(--red-deep) 7%, var(--panel))}.midi-setup-visual--listening .midi-setup-visual-token{color:var(--red);border-color:color-mix(in srgb, var(--red) 28%, var(--line))}.midi-setup-visual--spinner .midi-setup-visual-token{color:var(--ink-soft)}.midi-setup-visual--listening .midi-setup-visual-token:before,.midi-setup-visual--listening .midi-setup-visual-token:after{content:"";z-index:0;border-radius:inherit;border:1.5px solid color-mix(in srgb, var(--red) 55%, transparent);opacity:0;position:absolute;top:0;bottom:0;left:0;right:0}.midi-setup-kicker{color:var(--red-deep);letter-spacing:.14em;text-transform:uppercase;margin:0;font-size:.72rem;font-weight:800}.midi-setup h1,.midi-setup h2{font-family:var(--font-display);color:var(--ink);letter-spacing:-.01em;margin:0;font-weight:600}.midi-setup--onboarding h1{font-size:clamp(1.6rem,3.5vw,2.4rem);line-height:1.08}.midi-setup h2{font-size:1.3rem}.midi-setup-lede{max-width:42ch;color:var(--ink-soft);margin:0;font-size:1rem;line-height:1.6}.midi-setup--settings .midi-setup-lede{font-size:.9rem;line-height:1.45}.midi-connection-visuals{grid-template-columns:1fr 1fr;gap:14px;width:100%;margin-top:2px;display:grid}.midi-connection-card{border:1px solid var(--line);background:var(--panel);min-width:0;box-shadow:0 1px 2px color-mix(in srgb, var(--ink) 5%, transparent);border-radius:12px;margin:0;overflow:hidden}.midi-connection-card img{aspect-ratio:3/2;object-fit:contain;background:linear-gradient(135deg, color-mix(in srgb, var(--paper) 70%, white), white 60%);width:100%;padding:clamp(12px,3vw,20px);display:block}.midi-connection-card figcaption{border-top:1px solid var(--line);color:var(--muted);letter-spacing:.05em;text-transform:uppercase;padding:9px 12px 11px;font-size:.68rem;font-weight:800;line-height:1.3}.midi-setup-status,.midi-setup-device{border:1px solid var(--line);width:-moz-fit-content;width:fit-content;min-height:26px;color:var(--ink-soft);letter-spacing:.04em;text-transform:uppercase;border-radius:999px;align-items:center;gap:6px;padding:3px 11px;font-size:.74rem;font-weight:700;display:inline-flex}.midi-setup-status:before{content:"";background:currentColor;border-radius:999px;flex:none;width:6px;height:6px}.midi-setup-status[data-status=connected],.midi-setup-device{border-color:color-mix(in srgb, var(--green) 30%, var(--line));color:var(--green)}.midi-setup-status[data-status=permission_denied],.midi-setup-status[data-status=insecure_context],.midi-setup-status[data-status=permissions_policy_blocked],.midi-setup-status[data-status=request_failed],.midi-setup-status[data-status=socket_error],.midi-setup-status[data-status=selected_input_missing]{border-color:color-mix(in srgb, var(--red-deep) 28%, var(--line));color:var(--red-deep)}.midi-setup-actions{flex-wrap:wrap;gap:10px;display:flex}.midi-setup-actions--primary{margin-top:6px}.midi-setup-actions .auth-submit,.midi-setup-actions .settings-secondary-button{min-height:40px}.midi-setup--onboarding .midi-setup-actions--primary{flex-direction:column;align-items:stretch;width:100%;max-width:320px;margin-inline-start:auto;margin-inline-end:auto}.midi-setup--onboarding .auth-submit{background:var(--lacquer);letter-spacing:.01em;border-radius:10px;min-height:46px;transition:transform .18s,box-shadow .18s,opacity .18s}.midi-setup--onboarding .auth-submit:hover:not(:disabled){box-shadow:0 12px 26px -14px color-mix(in srgb, var(--ink) 65%, transparent);transform:translateY(-1px)}.midi-setup--onboarding .auth-submit:active:not(:disabled){transform:translateY(0)}.midi-setup--onboarding .auth-submit:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.midi-setup--onboarding .settings-secondary-button{border-color:var(--line);border-radius:10px;min-height:44px;padding:10px 16px;transition:border-color .18s,background .18s,color .18s}.midi-setup--onboarding .settings-secondary-button:hover:not(:disabled){border-color:var(--hairline);background:color-mix(in srgb, var(--ink) 4%, transparent)}.midi-setup-field{min-width:0}.midi-manual-picker{text-align:left;flex-direction:column;gap:10px;width:min(100%,360px);display:flex}.midi-setup--onboarding .midi-manual-picker{margin-inline-start:auto;margin-inline-end:auto}.midi-setup-step--soundcheck{width:min(100%,700px)}.soundcheck-lede{max-width:46ch}.soundcheck-score-frame{border:1px solid var(--line);background:var(--panel);width:min(100%,620px);height:clamp(210px,34vh,320px);box-shadow:inset 0 1px 0 #ffffffe6, 0 16px 36px -28px color-mix(in srgb, var(--ink) 65%, transparent);border-radius:8px;position:relative;overflow:hidden}.soundcheck-score-surface{position:absolute;top:0;bottom:0;left:0;right:0}.soundcheck-score-surface .score-surface-stage{background:linear-gradient(#f8f6f0,#f2eee5);width:100%;height:100%;overflow:auto}.soundcheck-score-surface .score-surface-score{background:#fff;min-width:100%;min-height:100%;padding:14px 16px 18px;position:relative}.soundcheck-score-surface .score-surface-score svg{width:100%;height:auto;display:block;overflow:visible}.soundcheck-score-surface .score-surface-score[data-layout=horizontal]{width:max-content;height:100%;min-height:0}.soundcheck-score-surface .score-surface-score[data-layout=horizontal] svg{width:auto;max-width:none;height:100%}.soundcheck-score-frame[data-loaded=false] .score-surface-stage{opacity:0}.soundcheck-score-status{color:var(--muted);place-items:center;margin:0;font-size:.86rem;font-weight:700;display:grid;position:absolute;top:0;bottom:0;left:0;right:0}.soundcheck-actions{margin-top:2px}@media (prefers-reduced-motion:no-preference){.midi-setup-stage-live{animation:.32s cubic-bezier(.22,1,.36,1) both midi-step-in}.midi-setup-visual--listening .midi-setup-visual-token:before{animation:2.1s ease-out infinite midi-listen-pulse}.midi-setup-visual--listening .midi-setup-visual-token:after{animation:2.1s ease-out 1.05s infinite midi-listen-pulse}.midi-setup-visual--spinner .midi-setup-visual-token svg{transform-origin:50%;animation:.9s linear infinite midi-spin}.midi-setup-visual--success .midi-icon-check{stroke-dasharray:14;stroke-dashoffset:14px;animation:.45s cubic-bezier(.65,0,.35,1) .12s forwards midi-check-draw}}@keyframes midi-step-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}@keyframes midi-listen-pulse{0%{opacity:.7;transform:scale(1)}to{opacity:0;transform:scale(1.65)}}@keyframes midi-spin{to{transform:rotate(360deg)}}@keyframes midi-check-draw{to{stroke-dashoffset:0}}@media (prefers-reduced-motion:reduce){.midi-setup-visual--listening .midi-setup-visual-token:before,.midi-setup-visual--listening .midi-setup-visual-token:after{display:none}}@media (max-width:760px){.onboarding-page{align-items:stretch;padding:16px}.midi-setup--onboarding,.midi-setup--onboarding[data-step=connection_guide]{width:100%;padding:clamp(22px,6vw,30px)}.midi-connection-visuals{grid-template-columns:1fr}.midi-setup-progress-label{letter-spacing:.04em;font-size:.6rem}}.settings-shell{background:var(--paper);grid-template-columns:minmax(220px,268px) minmax(0,1fr);min-height:100vh;display:grid}.settings-sidebar{border-right:1px solid var(--line);background:color-mix(in srgb, var(--panel) 55%, var(--paper));flex-direction:column;align-self:start;height:100vh;padding:30px 16px 20px;display:flex;position:sticky;top:0}.settings-sidebar-head{flex-direction:column;gap:14px;margin-bottom:22px;padding:0 10px;display:flex}.settings-back{width:max-content;color:var(--muted);align-items:center;gap:7px;font-size:.84rem;font-weight:600;text-decoration:none;transition:color .12s;display:inline-flex}.settings-back:before{content:"←";font-size:.95rem;line-height:1}.settings-back:hover{color:var(--ink)}.settings-back:focus-visible{outline:2px solid var(--focus);outline-offset:3px;border-radius:3px}.settings-title{font-family:var(--font-display);letter-spacing:.005em;color:var(--ink);margin:0;font-size:1.7rem;font-weight:600}.settings-nav{flex-direction:column;gap:2px;display:flex}.settings-nav-link{color:var(--ink-soft);border-radius:8px;align-items:center;gap:11px;padding:8px 11px;font-size:.92rem;font-weight:600;text-decoration:none;transition:background-color .12s,color .12s;display:flex}.settings-nav-link:hover{background:color-mix(in srgb, var(--ink) 5%, transparent);color:var(--ink)}.settings-nav-link.is-active{background:color-mix(in srgb, var(--ink) 8%, transparent);color:var(--ink);font-weight:700}.settings-nav-link:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.settings-nav-icon{width:16px;height:16px;color:var(--muted);opacity:.88;flex:none;justify-content:center;align-items:center;transition:color .12s,opacity .12s,transform .12s;display:inline-flex}.settings-nav-icon-svg{width:16px;height:16px;display:block;overflow:visible}.settings-nav-link:hover .settings-nav-icon,.settings-nav-link.is-active .settings-nav-icon{color:currentColor;opacity:1}.settings-nav-link.is-active .settings-nav-icon{transform:translate(1px)}.settings-sidebar-foot{border-top:1px solid var(--line);color:var(--muted);overflow-wrap:anywhere;margin:auto 0 0;padding:14px 11px 0;font-size:.8rem;line-height:1.4}.settings-content{min-width:0;padding:clamp(30px,5vw,68px) clamp(20px,5vw,48px) 96px;overflow-y:auto}.settings-content-inner{width:100%;max-width:600px;margin-inline-start:auto;margin-inline-end:auto}@media (prefers-reduced-motion:no-preference){.settings-content-inner{animation:.32s cubic-bezier(.22,1,.36,1) both settings-panel-in}}@keyframes settings-panel-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.settings-content-inner .settings-telemetry,.settings-content-inner .settings-billing,.settings-content-inner .midi-setup--settings{border-top:none;padding-top:0}.settings-content-inner .settings-section-heading h2,.settings-content-inner .settings-password h2{font-size:1.45rem}.settings-section-desc{color:var(--muted);margin:4px 0 0;font-size:.92rem;line-height:1.5}.settings-credit{color:var(--muted);margin:18px 0 0;font-size:.8rem;line-height:1.5}.settings-credit a{color:inherit;white-space:nowrap;text-decoration:underline}.settings-content-inner .settings-language,.settings-content-inner .settings-account-section{flex-direction:column;gap:14px;display:flex}@media (max-width:720px){.settings-shell{grid-template-columns:1fr}.settings-sidebar{height:auto;padding:20px 16px;position:static}.settings-sidebar-head{margin-bottom:16px}.settings-nav{flex-flow:wrap;gap:4px}.settings-sidebar-foot{display:none}}.midi-status-pill{z-index:85;border:1px solid var(--line);-webkit-backdrop-filter:blur(14px);max-width:min(360px,100vw - 32px);box-shadow:var(--shadow-card);color:var(--ink);font-family:var(--font-body);white-space:nowrap;text-overflow:ellipsis;background:#fbfbf9f0;border-radius:999px;align-items:center;gap:8px;padding:8px 14px;font-size:13px;font-weight:600;line-height:1.2;animation:.25s cubic-bezier(.22,.61,.36,1) both midi-status-pill-in;display:inline-flex;position:fixed;top:12px;left:50%;overflow:hidden}.midi-status-pill[data-leaving]{animation:.25s cubic-bezier(.22,.61,.36,1) both midi-status-pill-out}.midi-status-pill-dot{border-radius:50%;flex:none;width:8px;height:8px}.midi-status-pill[data-variant=connected] .midi-status-pill-dot{background:var(--green)}.midi-status-pill[data-variant=disconnected] .midi-status-pill-dot{background:var(--red)}.midi-status-pill[data-variant=absent] .midi-status-pill-dot{background:var(--muted)}.midi-status-pill[data-variant=absent]{color:var(--muted)}.midi-status-pill[data-armed]{white-space:normal;text-align:center;max-width:min(520px,100vw - 32px)}body[data-view=practice] .midi-status-pill{top:62px}@keyframes midi-status-pill-in{0%{opacity:0;transform:translate(-50%,-10px)}to{opacity:1;transform:translate(-50%)}}@keyframes midi-status-pill-out{0%{opacity:1;transform:translate(-50%)}to{opacity:0;transform:translate(-50%,-10px)}}@media (prefers-reduced-motion:reduce){.midi-status-pill{animation:none;transform:translate(-50%)}.midi-status-pill[data-leaving]{animation:none}}.compact-viewport-notice{z-index:10000;background:linear-gradient(#fbfbf9eb,#fbfbf9eb),repeating-linear-gradient(#0000 0 30px,#1212120b 31px,#0000 32px);place-items:center;min-height:100vh;padding:28px;display:grid;position:fixed;top:0;bottom:0;left:0;right:0;overflow:auto}.compact-viewport-notice__content{border-top:4px solid var(--ink);flex-direction:column;gap:18px;width:min(100%,430px);padding-top:26px;display:flex}.compact-viewport-notice__title{color:var(--ink);font-family:var(--font-display);margin:0;font-size:clamp(2rem,12vw,3rem);font-weight:700;line-height:.98}.compact-viewport-notice__copy{color:var(--ink-soft);margin:0;font-size:1rem;line-height:1.55}.compact-viewport-notice__button{background:var(--ink);width:100%;min-height:48px;color:var(--paper);cursor:pointer;font-family:var(--font-body);border:0;border-radius:6px;margin-top:6px;padding:12px 16px;font-size:1rem;font-weight:700}.compact-viewport-notice__button:focus-visible{outline:2px solid var(--focus);outline-offset:3px}
