@font-face{font-family:Archivo;font-style:normal;font-weight:400;font-stretch:100%;font-display:swap;src:url(../media/a2947afc6a06879b-s.1gyfqm5yhhzs7.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");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:Archivo;font-style:normal;font-weight:400;font-stretch:100%;font-display:swap;src:url(../media/651aaf1801011892-s.357dd_6abeqge.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");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:Archivo;font-style:normal;font-weight:400;font-stretch:100%;font-display:swap;src:url(../media/75affa71d1e2f6a7-s.p.17-aodiw50953.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");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:Archivo;font-style:normal;font-weight:500;font-stretch:100%;font-display:swap;src:url(../media/a2947afc6a06879b-s.1gyfqm5yhhzs7.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");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:Archivo;font-style:normal;font-weight:500;font-stretch:100%;font-display:swap;src:url(../media/651aaf1801011892-s.357dd_6abeqge.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");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:Archivo;font-style:normal;font-weight:500;font-stretch:100%;font-display:swap;src:url(../media/75affa71d1e2f6a7-s.p.17-aodiw50953.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");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:Archivo;font-style:normal;font-weight:600;font-stretch:100%;font-display:swap;src:url(../media/a2947afc6a06879b-s.1gyfqm5yhhzs7.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");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:Archivo;font-style:normal;font-weight:600;font-stretch:100%;font-display:swap;src:url(../media/651aaf1801011892-s.357dd_6abeqge.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");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:Archivo;font-style:normal;font-weight:600;font-stretch:100%;font-display:swap;src:url(../media/75affa71d1e2f6a7-s.p.17-aodiw50953.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");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:Archivo;font-style:normal;font-weight:700;font-stretch:100%;font-display:swap;src:url(../media/a2947afc6a06879b-s.1gyfqm5yhhzs7.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");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:Archivo;font-style:normal;font-weight:700;font-stretch:100%;font-display:swap;src:url(../media/651aaf1801011892-s.357dd_6abeqge.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");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:Archivo;font-style:normal;font-weight:700;font-stretch:100%;font-display:swap;src:url(../media/75affa71d1e2f6a7-s.p.17-aodiw50953.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");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:Archivo;font-style:normal;font-weight:800;font-stretch:100%;font-display:swap;src:url(../media/a2947afc6a06879b-s.1gyfqm5yhhzs7.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");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:Archivo;font-style:normal;font-weight:800;font-stretch:100%;font-display:swap;src:url(../media/651aaf1801011892-s.357dd_6abeqge.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");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:Archivo;font-style:normal;font-weight:800;font-stretch:100%;font-display:swap;src:url(../media/75affa71d1e2f6a7-s.p.17-aodiw50953.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");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:Archivo;font-style:normal;font-weight:900;font-stretch:100%;font-display:swap;src:url(../media/a2947afc6a06879b-s.1gyfqm5yhhzs7.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");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:Archivo;font-style:normal;font-weight:900;font-stretch:100%;font-display:swap;src:url(../media/651aaf1801011892-s.357dd_6abeqge.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");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:Archivo;font-style:normal;font-weight:900;font-stretch:100%;font-display:swap;src:url(../media/75affa71d1e2f6a7-s.p.17-aodiw50953.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");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:Archivo Fallback;src:local(Arial);ascent-override:88.96%;descent-override:21.28%;line-gap-override:0.0%;size-adjust:98.7%}.archivo_64b04faf-module__38IuDq__className{font-family:Archivo,Archivo Fallback;font-style:normal}.archivo_64b04faf-module__38IuDq__variable{--font-display:"Archivo", "Archivo Fallback"}
@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:400;font-display:swap;src:url(../media/04c5164763c40239-s.1kd-r_s9smv5m.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:400;font-display:swap;src:url(../media/26f284dcc38c84c0-s.3hlisc-pwq13z.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:400;font-display:swap;src:url(../media/7e7f32a39836f228-s.0-oo9_1x_xmvg.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:400;font-display:swap;src:url(../media/fa39153a3fc630ba-s.36fqqi66-3tjb.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");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:JetBrains Mono;font-style:normal;font-weight:400;font-display:swap;src:url(../media/6a5386fd6038edbe-s.3_z45zcoc-xoz.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");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:JetBrains Mono;font-style:normal;font-weight:400;font-display:swap;src:url(../media/051742360c26797e-s.p.1bkzbscqrt8rl.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");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:JetBrains Mono;font-style:normal;font-weight:500;font-display:swap;src:url(../media/04c5164763c40239-s.1kd-r_s9smv5m.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:500;font-display:swap;src:url(../media/26f284dcc38c84c0-s.3hlisc-pwq13z.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:500;font-display:swap;src:url(../media/7e7f32a39836f228-s.0-oo9_1x_xmvg.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:500;font-display:swap;src:url(../media/fa39153a3fc630ba-s.36fqqi66-3tjb.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");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:JetBrains Mono;font-style:normal;font-weight:500;font-display:swap;src:url(../media/6a5386fd6038edbe-s.3_z45zcoc-xoz.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");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:JetBrains Mono;font-style:normal;font-weight:500;font-display:swap;src:url(../media/051742360c26797e-s.p.1bkzbscqrt8rl.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");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:JetBrains Mono;font-style:normal;font-weight:700;font-display:swap;src:url(../media/04c5164763c40239-s.1kd-r_s9smv5m.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:700;font-display:swap;src:url(../media/26f284dcc38c84c0-s.3hlisc-pwq13z.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:700;font-display:swap;src:url(../media/7e7f32a39836f228-s.0-oo9_1x_xmvg.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:700;font-display:swap;src:url(../media/fa39153a3fc630ba-s.36fqqi66-3tjb.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");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:JetBrains Mono;font-style:normal;font-weight:700;font-display:swap;src:url(../media/6a5386fd6038edbe-s.3_z45zcoc-xoz.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");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:JetBrains Mono;font-style:normal;font-weight:700;font-display:swap;src:url(../media/051742360c26797e-s.p.1bkzbscqrt8rl.woff2?dpl=dpl_DcU1ipRXG1gxETEte9jDG6EQKvmL)format("woff2");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:JetBrains Mono Fallback;src:local(Arial);ascent-override:75.79%;descent-override:22.29%;line-gap-override:0.0%;size-adjust:134.59%}.jetbrains_mono_eba81453-module__mQv8zq__className{font-family:JetBrains Mono,JetBrains Mono Fallback;font-style:normal}.jetbrains_mono_eba81453-module__mQv8zq__variable{--font-mono:"JetBrains Mono", "JetBrains Mono Fallback"}
:root{--paper:#ece7da;--card:#f5f1e8;--ink:#1c1a16;--ink-soft:#6a665b;--line:#d2cbb9;--accent:#2b5dd6;--accent-dk:#1f48ab;--accent-ink:#f2f6ff;--shadow:#1c1a1624;--key-w:#f8f5ee;--key-w-edge:#d8d1bf;--key-b:#6b6b73;--r:12px}*{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--paper);color:var(--ink);font-family:var(--font-display), system-ui, sans-serif;-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility}body{min-height:100dvh}.mono{font-family:var(--font-mono), ui-monospace, monospace}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}.wrap{gap:clamp(14px,2.5vw,20px);max-width:640px;margin:0 auto;padding:clamp(16px,3vw,28px) clamp(14px,4vw,24px) 40px;display:grid}.topbar{border-bottom:1.5px solid var(--ink);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding-bottom:10px;display:flex}.brand{letter-spacing:-.02em;align-items:center;gap:8px;font-size:16px;font-weight:900;display:flex}.dot{background:var(--accent);border-radius:50%;width:9px;height:9px}.kbd{letter-spacing:.04em;color:var(--ink-soft);align-items:center;gap:5px;font-size:10px;display:flex}.kbd span{margin-right:4px}kbd{font-family:var(--font-mono), ui-monospace, monospace;background:var(--card);border:1px solid var(--line);min-width:17px;height:17px;color:var(--ink);border-bottom-width:2px;border-radius:5px;justify-content:center;align-items:center;padding:0 4px;font-size:10px;display:inline-flex}.hero{gap:10px;display:grid}.keyname{letter-spacing:-.04em;flex-wrap:wrap;align-items:baseline;gap:.16em;font-size:clamp(44px,12vw,76px);font-weight:900;line-height:.9;display:flex}.keyname .qual{color:var(--accent);font-size:.5em;font-weight:800}.meta{color:var(--ink-soft);align-items:center;gap:8px;font-size:12px;display:flex}.meta b{color:var(--ink);font-weight:700}.meta .sep{opacity:.4}.scale-strip{flex-wrap:wrap;gap:6px;display:flex}.note-pill{text-align:center;background:var(--card);border:1.5px solid var(--line);letter-spacing:-.02em;border-radius:9px;min-width:40px;padding:7px 10px;font-size:15px;font-weight:800;transition:transform 80ms,background .12s}.note-pill:hover{border-color:var(--ink);transform:translateY(-1px)}.note-pill.root{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}.controls{flex-wrap:wrap;align-items:stretch;gap:8px;display:flex}.modes{flex-wrap:wrap;gap:5px;display:flex}.mode-pill{border:1.5px solid var(--line);background:var(--card);letter-spacing:-.01em;border-radius:999px;padding:6px 13px;font-size:12px;font-weight:800;transition:transform 80ms,background .12s,border-color .12s}.mode-pill:hover{border-color:var(--ink);transform:translateY(-1px)}.mode-pill.on{background:var(--ink);color:var(--paper);border-color:var(--ink)}.stepper{border:1.5px solid var(--ink);border-radius:999px;display:inline-flex;overflow:hidden}.stepper button{padding:7px 14px;font-size:12px;font-weight:800;transition:background .12s}.stepper button:hover{background:var(--card)}.stepper button:first-child{border-right:1.5px solid var(--ink)}.shuffle{background:var(--accent);color:var(--accent-ink);border-radius:999px;margin-left:auto;padding:7px 16px;font-size:12px;font-weight:800;transition:transform 80ms,background .12s}.shuffle:hover{background:var(--accent-dk)}.shuffle:active{transform:scale(.97)}.roots{grid-template-columns:repeat(12,1fr);gap:5px;display:grid}@media (max-width:560px){.roots{grid-template-columns:repeat(6,1fr)}}.root-btn{aspect-ratio:1;border:1.5px solid var(--line);background:var(--card);letter-spacing:-.02em;border-radius:8px;font-size:13px;font-weight:800;transition:transform 80ms,background .12s,border-color .12s}.root-btn:hover{border-color:var(--ink);transform:translateY(-1px)}.root-btn.active{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}.kb-wrap{padding-bottom:4px;overflow-x:auto}.keyboard{-webkit-user-select:none;user-select:none;min-width:560px;height:clamp(130px,26vw,180px);display:flex;position:relative}.wkey{background:var(--key-w);border:1.5px solid var(--key-w-edge);border-top:none;border-radius:0 0 7px 7px;flex:1;justify-content:center;align-items:flex-end;padding-bottom:9px;transition:background .1s,transform 50ms;display:flex;position:relative}.wkey:active{transform:translateY(2px)}.wkey.inscale{background:#cfe0ff;border-color:#9bbcf2}.wkey.root{background:var(--accent);border-color:var(--accent-dk)}.bkeys{pointer-events:none;position:absolute;inset:0}.bkey{background:var(--key-b);pointer-events:auto;border-radius:0 0 6px 6px;justify-content:center;align-items:flex-end;width:4.2%;height:60%;padding-bottom:7px;transition:background .1s,transform 50ms;display:flex;position:absolute;top:0;transform:translate(-50%);box-shadow:0 3px 5px #00000038}.bkey:active{transform:translate(-50%)translateY(2px)}.bkey.inscale{background:var(--accent)}.bkey.root{background:var(--accent-dk)}.klabel{letter-spacing:-.02em;pointer-events:none;font-size:12px;font-weight:800}.wkey .klabel{color:var(--accent-dk)}.wkey.root .klabel{color:var(--accent-ink)}.bkey .klabel{color:#fff;font-size:9px}.chord-grid{grid-template-columns:repeat(7,1fr);gap:5px;display:grid}@media (max-width:560px){.chord-grid{grid-template-columns:repeat(4,1fr)}}.chord{background:var(--card);border:1.5px solid var(--line);text-align:center;border-radius:9px;gap:2px;padding:9px 4px 8px;transition:transform 80ms,border-color .12s;display:grid}.chord:hover{border-color:var(--ink);transform:translateY(-1px)}.chord .rn{letter-spacing:.04em;color:var(--accent);font-size:9px;font-weight:700}.chord .cn{letter-spacing:-.03em;font-size:clamp(14px,2vw,18px);font-weight:900}.detect{border-top:1.5px solid var(--ink);gap:12px;margin-top:6px;padding-top:clamp(14px,2.5vw,20px);display:grid}.detect-head{flex-wrap:wrap;align-items:baseline;gap:10px;display:flex}.detect-title{letter-spacing:.02em;font-size:13px;font-weight:700}.detect-sub{color:var(--ink-soft);font-size:11px}.clear{font-family:var(--font-mono), ui-monospace, monospace;color:var(--ink-soft);border:1px solid var(--line);border-radius:999px;margin-left:auto;padding:3px 10px;font-size:11px;transition:border-color .12s,color .12s}.clear:hover{border-color:var(--ink);color:var(--ink)}.pick-kb .wkey.sel{background:var(--accent);border-color:var(--accent-dk)}.pick-kb .wkey.sel .klabel{color:var(--accent-ink)}.pick-kb .bkey.sel{background:var(--accent-dk)}.results{gap:6px;display:grid}.results-empty{color:var(--ink-soft);padding:6px 2px;font-size:12px}.match{border:1.5px solid var(--line);background:var(--card);text-align:left;border-radius:10px;grid-template-columns:38px 1fr 90px 38px;align-items:center;gap:10px;padding:9px 12px;transition:transform 80ms,border-color .12s;display:grid}.match:hover{border-color:var(--ink);transform:translateY(-1px)}.match.best{border-color:var(--accent);background:#eaf0ff}.match-rank{letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);font-size:10px}.match.best .match-rank{color:var(--accent);font-weight:700}.match-name{letter-spacing:-.02em;font-size:clamp(15px,2.4vw,18px);font-weight:900}.match-bar{background:var(--line);border-radius:999px;height:6px;overflow:hidden}.match-bar span{background:#c9a23a;border-radius:999px;height:100%;transition:width .2s;display:block}.match-bar span.full{background:var(--accent)}.match-pct{color:var(--ink-soft);text-align:right;font-size:11px;font-weight:700}@media (max-width:440px){.match{grid-template-columns:34px 1fr 34px}.match-bar{display:none}}@keyframes pop{0%{opacity:.5;transform:scale(.98)}to{opacity:1;transform:scale(1)}}.animate{animation:.18s pop}.analyzer{border-top:1.5px solid var(--ink);gap:12px;margin-top:6px;padding-top:clamp(14px,2.5vw,20px);display:grid}.dropzone{border:1.5px dashed var(--line);border-radius:var(--r);background:var(--card);text-align:center;cursor:pointer;justify-items:center;gap:6px;padding:clamp(22px,5vw,36px) 16px;transition:border-color .14s,background .14s;display:grid}.dropzone:hover{border-color:var(--ink-soft)}.dropzone.over{border-color:var(--accent);background:#eaf0ff}.dz-icon{color:var(--accent);font-size:28px;line-height:1}.dz-main{letter-spacing:-.01em;font-size:clamp(14px,2.2vw,16px);font-weight:800}.dz-sub{color:var(--ink-soft);font-size:11px}.dz-error{color:#b23b2e;font-size:12px}.analyzing{gap:8px;padding:8px 2px;display:grid}.an-name{white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:700;overflow:hidden}.progress{background:var(--line);border-radius:999px;height:8px;overflow:hidden}.progress span{background:var(--accent);border-radius:999px;height:100%;transition:width .25s;display:block}.an-stage{color:var(--ink-soft);font-size:11px}.song-result{gap:12px;display:grid}.readout{grid-template-columns:1.4fr 1fr;gap:8px;display:grid}@media (max-width:440px){.readout{grid-template-columns:1fr}}.ro-key,.ro-bpm{border:1.5px solid var(--line);background:var(--card);text-align:left;border-radius:10px;align-content:start;gap:2px;padding:12px 14px;display:grid}.ro-key{border-color:var(--accent);background:#eaf0ff;transition:transform 80ms}.ro-key:hover{transform:translateY(-1px)}.ro-label{text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft);font-size:10px}.ro-key .ro-label{color:var(--accent)}.ro-value{letter-spacing:-.03em;align-items:baseline;gap:7px;font-size:clamp(22px,5vw,30px);font-weight:900;display:flex}.ro-qual{letter-spacing:0;color:var(--ink-soft);font-size:13px;font-weight:700}.ro-conf{color:var(--ink-soft);font-size:10px}.transport{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.tp-btn{background:var(--accent);color:var(--accent-ink);border-radius:999px;padding:8px 16px;font-size:13px;font-weight:800;transition:background .12s}.tp-btn:hover{background:var(--accent-dk)}.tp-time{color:var(--ink-soft);font-size:12px}.tp-use{font-family:var(--font-mono), ui-monospace, monospace;color:var(--ink-soft);border:1px solid var(--line);border-radius:999px;margin-left:auto;padding:6px 12px;font-size:11px;transition:border-color .12s,color .12s}.tp-use:hover{border-color:var(--ink);color:var(--ink)}.timeline-wrap{overflow:hidden}.timeline{border:1.5px solid var(--line);background:var(--card);cursor:pointer;border-radius:10px;height:52px;position:relative;overflow:hidden}.tl-chord{border-right:1px solid var(--paper);letter-spacing:-.02em;color:var(--ink);white-space:nowrap;background:#e3ddcd;justify-content:center;align-items:center;padding:0 2px;font-size:11px;font-weight:800;transition:background .1s;display:flex;position:absolute;top:0;bottom:0;overflow:hidden}.tl-chord.on{background:var(--accent);color:var(--accent-ink)}.tl-chord span{overflow:hidden}.playhead{pointer-events:none;background:#b23b2e;width:2px;position:absolute;top:0;bottom:0;box-shadow:0 0 4px #b23b2e99}.voicing{border:1.5px solid var(--line);background:var(--card);border-radius:10px;gap:10px;padding:12px 14px;display:grid}.voicing-head{flex-wrap:wrap;align-items:baseline;gap:10px;display:flex}.v-name{letter-spacing:-.03em;font-size:clamp(20px,4vw,26px);font-weight:900}.v-notes{color:var(--ink-soft);font-size:12px}.v-play{background:var(--accent);color:var(--accent-ink);border-radius:999px;margin-left:auto;padding:6px 12px;font-size:12px;font-weight:700;transition:background .12s}.v-play:hover{background:var(--accent-dk)}.mini-kb{-webkit-user-select:none;user-select:none;max-width:320px;height:clamp(96px,22vw,120px);display:flex;position:relative}.mwkey{background:var(--key-w);border:1.5px solid var(--key-w-edge);border-top:none;border-radius:0 0 6px 6px;flex:1;justify-content:center;align-items:flex-end;padding-bottom:7px;transition:background .1s;display:flex;position:relative}.mwkey.on{background:#cfe0ff;border-color:#9bbcf2}.mwkey.root{background:var(--accent);border-color:var(--accent-dk)}.mlabel{color:var(--accent-dk);pointer-events:none;font-size:11px;font-weight:800}.mwkey.root .mlabel{color:var(--accent-ink)}.mbkeys{pointer-events:none;position:absolute;inset:0}.mbkey{background:var(--key-b);pointer-events:auto;border-radius:0 0 5px 5px;width:8%;height:60%;transition:background .1s;position:absolute;top:0;transform:translate(-50%);box-shadow:0 3px 5px #00000038}.mbkey.on{background:var(--accent)}.mbkey.root{background:var(--accent-dk)}.v-degrees{color:var(--ink-soft);gap:14px;font-size:10px;display:flex}
