@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/fef07dbb0973bf53-s.12tyk43_3sh9u.woff2)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:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/8a480f0b521d4e75-s.0jzbimsg8vl84.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/53b9e256198e5412-s.0-wfv7uh4i7h9.woff2)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:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/7178b3e590c64307-s.0nx0ww8fni_q3.woff2)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:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/caa3a2e1cccd8315-s.p.09~u27dqhyhd6.woff2)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:Geist Fallback;src:local(Arial);ascent-override:95.94%;descent-override:28.16%;line-gap-override:0.0%;size-adjust:104.76%}.geist_22e2a02c-module__MwEO2a__className{font-family:Geist,Geist Fallback;font-style:normal}.geist_22e2a02c-module__MwEO2a__variable{--font-geist-sans:"Geist", "Geist Fallback"}
@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/5ce348bf30bf5439-s.0ee55_hj9qcer.woff2)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:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/4fa387ec64143e14-s.0.qu-9752pffj.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/6306c77e7c8268e4-s.0mao5jbfbduzp.woff2)format("woff2");unicode-range:U+2000-2001,U+2004-2008,U+200A,U+23B8-23BD,U+2500-259F}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/7d817b4c03b0c5f1-s.0uzt.a6d44yda.woff2)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:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/bbc41e54d2fcbd21-s.0mvwgmnhv29no.woff2)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:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/797e433ab948586e-s.p.09zddjkbdep5a.woff2)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:Geist Mono Fallback;src:local(Arial);ascent-override:74.67%;descent-override:21.92%;line-gap-override:0.0%;size-adjust:134.59%}.geist_mono_42eec60-module__Gb1_vG__className{font-family:Geist Mono,Geist Mono Fallback;font-style:normal}.geist_mono_42eec60-module__Gb1_vG__variable{--font-geist-mono:"Geist Mono", "Geist Mono Fallback"}
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-red-300:#ffa3a3;--color-red-400:#ff6568;--color-red-500:#fb2c36;--color-yellow-400:#fac800;--color-yellow-500:#edb200;--color-yellow-600:#cd8900;--color-green-600:#00a544;--color-emerald-400:#00d294;--color-zinc-100:#f4f4f5;--color-zinc-200:#e4e4e7;--color-zinc-300:#d4d4d8;--color-zinc-400:#9f9fa9;--color-zinc-500:#71717b;--color-zinc-600:#52525c;--color-zinc-700:#3f3f46;--color-zinc-800:#27272a;--color-zinc-900:#18181b;--color-zinc-950:#09090b;--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-md:28rem;--container-3xl:48rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--text-4xl:2.25rem;--text-4xl--line-height:calc(2.5 / 2.25);--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--radius-sm:.25rem;--radius-lg:.5rem;--radius-xl:.75rem;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}@supports (color:lab(0% 0 0)){:root,:host{--color-red-300:lab(76.5514% 36.422 15.5335);--color-red-400:lab(63.7053% 60.745 31.3109);--color-red-500:lab(55.4814% 75.0732 48.8528);--color-yellow-400:lab(83.2664% 8.65132 106.895);--color-yellow-500:lab(76.3898% 14.5258 98.4589);--color-yellow-600:lab(62.7799% 22.4197 86.1544);--color-green-600:lab(59.0978% -58.6621 41.2579);--color-emerald-400:lab(75.0771% -60.7313 19.4147);--color-zinc-100:lab(96.1634% .0993311 -.364041);--color-zinc-200:lab(90.6853% .399232 -1.45452);--color-zinc-300:lab(84.9837% .601262 -2.17986);--color-zinc-400:lab(65.6464% 1.53497 -5.42429);--color-zinc-500:lab(47.8878% 1.65477 -5.77283);--color-zinc-600:lab(35.1166% 1.78212 -6.1173);--color-zinc-700:lab(26.8019% 1.35387 -4.68303);--color-zinc-800:lab(15.7305% .613764 -2.16959);--color-zinc-900:lab(8.30603% .618205 -2.16572);--color-zinc-950:lab(2.51107% .242703 -.886115)}}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.invisible{visibility:hidden}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.inset-0{inset:calc(var(--spacing) * 0)}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.bottom-4{bottom:calc(var(--spacing) * 4)}.left-4{left:calc(var(--spacing) * 4)}.z-50{z-index:50}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.mx-auto{margin-inline:auto}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-3{margin-top:calc(var(--spacing) * 3)}.mt-4{margin-top:calc(var(--spacing) * 4)}.mt-6{margin-top:calc(var(--spacing) * 6)}.mb-0\.5{margin-bottom:calc(var(--spacing) * .5)}.mb-1{margin-bottom:calc(var(--spacing) * 1)}.mb-1\.5{margin-bottom:calc(var(--spacing) * 1.5)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-5{margin-bottom:calc(var(--spacing) * 5)}.mb-6{margin-bottom:calc(var(--spacing) * 6)}.ml-4{margin-left:calc(var(--spacing) * 4)}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.table{display:table}.h-64{height:calc(var(--spacing) * 64)}.h-full{height:100%}.max-h-40{max-height:calc(var(--spacing) * 40)}.max-h-\[70vh\]{max-height:70vh}.min-h-full{min-height:100%}.w-\[500px\]{width:500px}.w-full{width:100%}.max-w-3xl{max-width:var(--container-3xl)}.max-w-\[calc\(100vw-4rem\)\]{max-width:calc(100vw - 4rem)}.max-w-md{max-width:var(--container-md)}.flex-1{flex:1}.shrink-0{flex-shrink:0}.border-collapse{border-collapse:collapse}.cursor-grab{cursor:grab}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.resize{resize:both}.resize-none{resize:none}.flex-col{flex-direction:column}.items-center{align-items:center}.items-stretch{align-items:stretch}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:.25rem}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.border-r{border-right-style:var(--tw-border-style);border-right-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-l{border-left-style:var(--tw-border-style);border-left-width:1px}.border-dashed{--tw-border-style:dashed;border-style:dashed}.border-\[var\(--line\)\]{border-color:var(--line)}.border-zinc-600{border-color:var(--color-zinc-600)}.border-zinc-700{border-color:var(--color-zinc-700)}.border-zinc-800{border-color:var(--color-zinc-800)}.bg-\[var\(--bg\)\]{background-color:var(--bg)}.bg-\[var\(--surface\)\]{background-color:var(--surface)}.bg-\[var\(--surface-sunken\)\]{background-color:var(--surface-sunken)}.bg-black\/40{background-color:#0006}@supports (color:color-mix(in lab, red, red)){.bg-black\/40{background-color:color-mix(in oklab, var(--color-black) 40%, transparent)}}.bg-zinc-800{background-color:var(--color-zinc-800)}.bg-zinc-900{background-color:var(--color-zinc-900)}.bg-zinc-950{background-color:var(--color-zinc-950)}.p-2{padding:calc(var(--spacing) * 2)}.p-6{padding:calc(var(--spacing) * 6)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-6{padding-inline:calc(var(--spacing) * 6)}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-4{padding-block:calc(var(--spacing) * 4)}.py-16{padding-block:calc(var(--spacing) * 16)}.pt-1{padding-top:calc(var(--spacing) * 1)}.pr-2{padding-right:calc(var(--spacing) * 2)}.pr-3{padding-right:calc(var(--spacing) * 3)}.text-center{text-align:center}.text-left{text-align:left}.align-top{vertical-align:top}.font-mono{font-family:var(--font-mono)}.text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.leading-none{--tw-leading:1;line-height:1}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-normal{--tw-font-weight:var(--font-weight-normal);font-weight:var(--font-weight-normal)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.break-all{word-break:break-all}.whitespace-pre-wrap{white-space:pre-wrap}.text-\[var\(--bad\)\]{color:var(--bad)}.text-\[var\(--ink\)\]{color:var(--ink)}.text-\[var\(--ink-3\)\]{color:var(--ink-3)}.text-\[var\(--ink-4\)\]{color:var(--ink-4)}.text-emerald-400{color:var(--color-emerald-400)}.text-green-600{color:var(--color-green-600)}.text-red-400{color:var(--color-red-400)}.text-red-500{color:var(--color-red-500)}.text-yellow-400{color:var(--color-yellow-400)}.text-yellow-500{color:var(--color-yellow-500)}.text-yellow-600{color:var(--color-yellow-600)}.text-zinc-100{color:var(--color-zinc-100)}.text-zinc-200{color:var(--color-zinc-200)}.text-zinc-300{color:var(--color-zinc-300)}.text-zinc-400{color:var(--color-zinc-400)}.text-zinc-500{color:var(--color-zinc-500)}.text-zinc-600{color:var(--color-zinc-600)}.text-zinc-700{color:var(--color-zinc-700)}.capitalize{text-transform:capitalize}.lowercase{text-transform:lowercase}.italic{font-style:italic}.underline{text-decoration-line:underline}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.shadow-md{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a), 0 2px 4px -2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.select-all{-webkit-user-select:all;user-select:all}.select-none{-webkit-user-select:none;user-select:none}.file\:mr-3::file-selector-button{margin-right:calc(var(--spacing) * 3)}.file\:cursor-pointer::file-selector-button{cursor:pointer}.file\:rounded-lg::file-selector-button{border-radius:var(--radius-lg)}.file\:border::file-selector-button{border-style:var(--tw-border-style);border-width:1px}.file\:border-\[var\(--line\)\]::file-selector-button{border-color:var(--line)}.file\:bg-\[var\(--surface-2\)\]::file-selector-button{background-color:var(--surface-2)}.file\:px-3::file-selector-button{padding-inline:calc(var(--spacing) * 3)}.file\:py-1\.5::file-selector-button{padding-block:calc(var(--spacing) * 1.5)}.file\:text-\[var\(--ink-2\)\]::file-selector-button{color:var(--ink-2)}.placeholder\:text-\[var\(--ink-4\)\]::placeholder{color:var(--ink-4)}@media (hover:hover){.hover\:border-zinc-400:hover{border-color:var(--color-zinc-400)}.hover\:text-\[var\(--ink\)\]:hover{color:var(--ink)}.hover\:text-red-300:hover{color:var(--color-red-300)}.hover\:text-white:hover{color:var(--color-white)}.hover\:text-zinc-200:hover{color:var(--color-zinc-200)}.hover\:text-zinc-300:hover{color:var(--color-zinc-300)}.hover\:text-zinc-400:hover{color:var(--color-zinc-400)}.hover\:file\:bg-\[var\(--surface-sunken\)\]:hover::file-selector-button{background-color:var(--surface-sunken)}}.focus\:border-\[var\(--accent\)\]:focus{border-color:var(--accent)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.active\:cursor-grabbing:active{cursor:grabbing}}:root{--bg:#f6f2e8;--bg-2:#efeadf;--surface:#fbf8f0;--surface-2:#f0ebdd;--surface-sunken:#e8e2d2;--line:#1e160c1a;--line-soft:#1e160c0f;--line-strong:#1e160c2e;--ink:#1f1812;--ink-2:#1f1812cc;--ink-3:#1f18129e;--ink-4:#1f18126b;--ink-5:#1f181240;--accent:#c46a0e;--accent-2:#d4791c;--accent-soft:#faead3;--accent-ink:#fff;--good:#2f8654;--good-soft:#deede3;--bad:#b7402b;--bad-soft:#f3d9d3;--warn:#b86e00;--warn-soft:#f5e5c8;--shadow-sm:0 1px 2px #140e060d;--shadow-md:0 1px 3px #140e0612, 0 8px 20px -12px #140e061a;--shadow-focus:0 0 0 3px #c46a0e38;--radius:8px;--radius-sm:6px;--radius-lg:12px;--f-ui:var(--font-geist-sans), ui-sans-serif, system-ui, sans-serif;--f-title:var(--font-geist-sans), ui-sans-serif, system-ui, sans-serif;--f-mono:var(--font-geist-mono), ui-monospace, Menlo, monospace}[data-theme=dark]{--bg:#0e0c0f;--bg-2:#14111a;--surface:#181519;--surface-2:#1f1b22;--surface-sunken:#0a0809;--line:#ffffff14;--line-soft:#ffffff0d;--line-strong:#ffffff29;--ink:#f1ebe0;--ink-2:#f1ebe0d9;--ink-3:#f1ebe0a6;--ink-4:#f1ebe080;--ink-5:#f1ebe04d;--accent:#fdb852;--accent-2:#fecc79;--accent-soft:#fdb85224;--accent-ink:#1a1207;--good:#84d6a8;--good-soft:#84d6a824;--bad:#e27867;--bad-soft:#e2786724;--warn:#e0a84a;--warn-soft:#e0a84a24;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 1px 3px #00000059, 0 8px 24px -12px #00000080;--shadow-focus:0 0 0 3px #fdb85252}html,body{margin:0;padding:0}body{background:var(--bg);color:var(--ink);font-family:var(--f-ui);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;font-size:14px;line-height:1.5;transition:background-color .25s,color .25s}.app{flex-direction:column;min-height:100vh;display:flex}.topbar{border-bottom:1px solid var(--line-soft);background:var(--bg)}.topbar-inner{align-items:center;gap:24px;max-width:1000px;margin:0 auto;padding:14px 40px;display:flex}.topbar-brand{color:inherit;flex-shrink:0;text-decoration:none}.topbar-nav{flex-wrap:wrap;justify-content:flex-end;gap:2px;margin-left:auto;display:flex}.topbar-link{border-radius:var(--radius-sm);color:var(--ink-3);padding:8px 12px;font-size:13.5px;text-decoration:none;transition:background-color .12s,color .12s;position:relative}.topbar-link-text-short{display:none}.topbar-link:hover{color:var(--ink);background:var(--surface-2)}.topbar-link.active{color:var(--ink)}.topbar-link.active:after{content:"";background:var(--accent);border-radius:1px;height:2px;position:absolute;bottom:-1px;left:12px;right:12px}.theme-switch{background:var(--surface-sunken);border:1px solid var(--line-soft);border-radius:7px;gap:2px;padding:3px;display:flex}.theme-switch button{color:var(--ink-4);cursor:pointer;background:0 0;border:0;border-radius:5px;flex:1;justify-content:center;align-items:center;gap:5px;padding:5px 8px;font-family:inherit;font-size:11.5px;transition:background-color .15s,color .15s;display:inline-flex}.theme-switch button:hover{color:var(--ink-2)}.theme-switch button.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}.theme-switch svg{width:12px;height:12px}.brand-name{font-family:var(--f-title);letter-spacing:-.02em;font-size:19px;font-weight:600}.brand-period{color:var(--accent)}.main{flex:1;width:100%;max-width:920px;margin:0 auto;padding:28px 40px 40px}.site-footer{border-top:1px solid var(--line-soft);background:var(--bg);flex-direction:column;align-items:center;gap:2px;padding:12px 16px 16px;display:flex}.site-footer-links{justify-content:center;gap:4px;display:flex}.site-footer-link{color:var(--ink-4);cursor:pointer;background:0 0;border:0;padding:6px 10px;font-family:inherit;font-size:12px;text-decoration:none;transition:color .15s}.site-footer-link:hover{color:var(--ink-2)}.site-footer-attribution{color:var(--ink-4);letter-spacing:.01em;margin:0;font-size:11px}.site-footer-attribution-link{color:inherit;border-bottom:1px solid var(--line-soft);padding-bottom:1px;text-decoration:none;transition:color .15s,border-color .15s}.site-footer-attribution-link:hover{color:var(--accent);border-bottom-color:var(--accent)}.page-head{border-bottom:1px solid var(--line-soft);margin-bottom:32px;padding-bottom:24px}.hero{border-bottom:1px solid var(--line-soft);flex-direction:column;align-items:flex-start;margin:12px 0 44px;padding-bottom:32px;display:flex}.hero-wordmark{font-family:var(--f-title);letter-spacing:-.025em;color:var(--ink);margin:0 0 18px;font-size:52px;font-weight:600;line-height:1}.hero-tagline{color:var(--ink-3);max-width:34em;margin:0;font-size:17px;line-height:1.5}.about-prose{max-width:38em;margin:0 0 36px}.about-prose-heading{font-family:var(--f-title);color:var(--ink-4);margin:0 0 14px;font-size:14px;font-weight:500}.about-prose p{color:var(--ink);margin:0 0 14px;font-size:16px;font-style:italic;line-height:1.6}.about-prose p:last-of-type{margin-bottom:0}.about-prose-sig{color:var(--ink-3);margin-top:12px!important}.about-details{border-top:1px solid var(--line-soft);margin-top:32px;padding-top:24px}.about-feature-list{color:var(--ink);margin:6px 0 0;padding-left:20px;list-style:outside}.about-feature-list li{margin:2px 0;font-size:16px;line-height:1.5}.about-grid{grid-template-columns:150px 1fr;gap:22px 28px;max-width:640px;margin:0;display:grid}.about-grid dt{color:var(--ink-4);padding-top:2px;font-size:12.5px}.about-grid dd{color:var(--ink);margin:0;font-size:16px;line-height:1.55}.about-link{color:var(--ink);border-bottom:1px solid var(--accent);padding-bottom:1px;text-decoration:none;transition:color .15s}.about-link:hover{color:var(--accent)}@media (max-width:540px){.about-grid{grid-template-columns:1fr;row-gap:4px}.about-grid dt{padding-top:14px}.about-grid dt:first-of-type{padding-top:0}}.page-title{font-family:var(--f-title);letter-spacing:-.015em;color:var(--ink);align-items:center;gap:10px;margin:0;font-size:32px;font-weight:500;line-height:1.15;display:flex}.page-sub{color:var(--ink-3);max-width:80ch;margin:8px 0 0;font-size:14px;line-height:1.55}.page-head-row{justify-content:space-between;align-items:flex-start;gap:24px;display:flex}.exercise-list{border:1px solid var(--line-soft);border-radius:var(--radius-lg);background:var(--surface);flex-direction:column;display:flex;overflow:hidden}.ex-row{border-bottom:1px solid var(--line-soft);text-align:left;color:inherit;grid-template-columns:1fr auto;align-items:center;gap:18px;padding:18px 20px;text-decoration:none;transition:background-color .12s;display:grid;position:relative}.ex-row:last-child{border-bottom:0}.ex-row:hover{background:var(--surface-2)}.ex-row:hover .ex-arrow{color:var(--accent);transform:translate(2px)}.ex-main h3{font-family:var(--f-title);letter-spacing:-.005em;margin:0 0 2px;font-size:18px;font-weight:500}.ex-main p{color:var(--ink-3);margin:0;font-size:13px}.ex-arrow{color:var(--ink-4);justify-content:flex-end;width:24px;font-size:16px;transition:transform .18s,color .18s;display:inline-flex}.ex-arrow svg{width:16px;height:16px}.section-title{color:var(--ink-3);align-items:center;gap:10px;margin:36px 0 12px;font-size:12.5px;font-weight:500;display:flex}.section-title:after{content:"";background:var(--line-soft);flex:1;height:1px}.card{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px 28px}.card-head{border-bottom:1px solid var(--line-soft);justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:16px;display:flex}.card-title{font-family:var(--f-title);margin:0;font-size:18px;font-weight:500}.form{grid-template-columns:180px 1fr;align-items:start;gap:20px 32px;display:grid}.form .field-label{color:var(--ink-2);flex-direction:column;gap:2px;padding-top:8px;font-size:12.5px;font-weight:500;display:flex}.form .field-label .hint{color:var(--ink-4);font-size:11.5px;font-weight:400}.form .field-value{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.form .field-divider{background:var(--line-soft);grid-column:1/-1;height:1px;margin:4px 0}.form .field-hint{color:var(--ink-4);grid-column:2/-1;margin-top:-2px;font-size:11.5px;font-style:italic;line-height:1.4}.seg{background:var(--surface-sunken);border:1px solid var(--line-soft);border-radius:8px;gap:2px;padding:3px;display:inline-flex}.seg button{color:var(--ink-3);cursor:pointer;background:0 0;border:0;border-radius:5px;padding:6px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:background-color .12s,color .12s}.seg button:hover{color:var(--ink)}.seg button.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}.chip{font-family:var(--f-mono);border:1px solid var(--line);background:var(--surface);min-width:44px;color:var(--ink-3);text-align:center;letter-spacing:.02em;cursor:pointer;border-radius:6px;padding:6px 12px;font-size:12px;line-height:1.3;transition:all .12s}.chip:hover{border-color:var(--line-strong);color:var(--ink-2);background:var(--surface-2)}.chip.on{background:var(--accent-soft);color:var(--accent);border:1px solid var(--accent);font-weight:600}.chip.on:hover{background:var(--accent-soft);color:var(--accent);border-color:var(--accent)}.chip.wide{min-width:0;font-family:var(--f-ui);padding:6px 14px;font-weight:500}.chip:disabled:not(.on),.chip:disabled:not(.on):hover{opacity:.45;color:var(--ink-3);border:1px dashed var(--line);cursor:not-allowed;background:0 0}.chip.on:disabled,.chip.on:disabled:hover{opacity:.75;cursor:not-allowed}.chip-select-all{font-size:11.5px;font-family:var(--f-ui);color:var(--ink-3);text-underline-offset:3px;text-decoration:underline;-webkit-text-decoration-color:var(--line-strong);-webkit-text-decoration-color:var(--line-strong);-webkit-text-decoration-color:var(--line-strong);text-decoration-color:var(--line-strong);cursor:pointer;background:0 0;border:0;padding:6px 10px}.chip-select-all:hover{color:var(--ink);-webkit-text-decoration-color:var(--ink-3);-webkit-text-decoration-color:var(--ink-3);-webkit-text-decoration-color:var(--ink-3);text-decoration-color:var(--ink-3)}.btn{border-radius:var(--radius);cursor:pointer;box-sizing:border-box;appearance:none;border:0;justify-content:center;align-items:center;gap:8px;height:36px;min-height:36px;padding:0 16px;font-family:inherit;font-size:13.5px;font-weight:500;line-height:1;transition:background-color .15s,color .15s,box-shadow .15s;display:inline-flex}.btn.primary{background:var(--accent);color:var(--accent-ink)}.btn.primary:hover{background:var(--accent-2)}.btn.primary:focus-visible{box-shadow:var(--shadow-focus);outline:0}.btn.primary:disabled{opacity:.5;cursor:not-allowed}.btn.ghost{color:var(--ink-2);border:1px solid var(--line);background:var(--surface)}.btn.ghost:hover{border-color:var(--line-strong);color:var(--ink);background:var(--surface-2)}.btn.ghost:disabled{opacity:.5;cursor:not-allowed}.go-row{border-top:1px solid var(--line-soft);justify-content:flex-end;align-items:center;gap:10px;margin-top:24px;padding-top:20px;display:flex}.kbd{font-family:var(--f-mono);border:1px solid var(--line);color:var(--ink-3);background:var(--surface);border-bottom-width:2px;border-radius:4px;padding:2px 5px;font-size:10px;line-height:1;display:inline-block}.btn.primary .kbd{color:inherit;background:#ffffff26;border-color:#fff3}.player{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.player-bar{background:var(--bg-2);border-bottom:1px solid var(--line-soft);justify-content:space-between;align-items:center;padding:12px 18px;display:flex}.player-bar-l,.player-bar-r{align-items:center;gap:10px;display:flex}.player-bar .pill{font-family:var(--f-mono);color:var(--ink-3);background:var(--surface);border:1px solid var(--line-soft);letter-spacing:.03em;border-radius:4px;padding:3px 8px;font-size:11px}.player-bar .back{color:var(--ink-3);cursor:pointer;background:0 0;border:0;align-items:center;gap:4px;font-family:inherit;font-size:13px;display:inline-flex}.player-bar .back:hover{color:var(--ink)}.player-bar .tools{gap:4px;display:flex}.player-bar .icon-btn{width:28px;height:28px;color:var(--ink-3);cursor:pointer;background:0 0;border:0;border-radius:6px;justify-content:center;align-items:center;display:inline-flex}.player-bar .icon-btn:hover{background:var(--surface);color:var(--ink)}.player-bar .icon-btn.on{color:var(--ink);background:var(--surface)}.player-body{padding:36px 32px 28px}.play-area{border:1px solid var(--line-soft);border-radius:var(--radius);background:var(--surface-2);flex-wrap:wrap;align-items:center;gap:18px;margin-bottom:28px;padding:24px 22px;display:flex}.play-btn{background:var(--accent);width:48px;height:48px;color:var(--accent-ink);cursor:pointer;border:0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:transform .15s,background-color .15s;display:inline-flex;position:relative}.play-btn:hover:not(:disabled){background:var(--accent-2);transform:scale(1.04)}.play-btn:focus-visible{box-shadow:var(--shadow-focus);outline:0}.play-btn:disabled{opacity:.5;cursor:not-allowed}.play-btn svg{width:18px;height:18px}.play-btn.playing:after{content:"";border:2px solid var(--accent);opacity:0;border-radius:50%;animation:1.4s ease-out infinite pulse-ring;position:absolute;inset:-5px}.play-btn:not(.playing):not(:disabled){animation:3.2s ease-in-out infinite idle-breath}@keyframes idle-breath{0%,to{box-shadow:0 0 0 0 color-mix(in oklab, var(--accent) 0%, transparent)}50%{box-shadow:0 0 0 6px color-mix(in oklab, var(--accent) 14%, transparent)}}@keyframes pulse-ring{0%{opacity:.6;transform:scale(.95)}to{opacity:0;transform:scale(1.4)}}.play-info{flex-direction:column;flex:1;gap:3px;display:flex}.play-info .kind{font-family:var(--f-mono);color:var(--ink-4);letter-spacing:.06em;font-size:11px}.play-info .round{font-family:var(--f-title);color:var(--ink);font-size:18px;font-weight:500;display:inline-grid}.play-info .round>.round-label{visibility:hidden;grid-area:1/1}.play-info .round>.round-label.is-active{visibility:visible}.waveform{min-width:120px;height:32px;color:var(--ink-4);flex:1;justify-content:center;align-items:center;gap:3px;display:flex}.waveform i{background:currentColor;border-radius:2px;width:2px;transition:height .15s;display:block}.replay{color:var(--ink-3);font-size:12px;font-family:var(--f-mono);background:var(--surface);border:1px solid var(--line);cursor:pointer;border-radius:6px;flex-shrink:0;align-items:center;gap:6px;padding:6px 10px;display:inline-flex}.replay:hover{border-color:var(--line-strong);background:var(--surface-2);color:var(--ink)}.replay:disabled{opacity:.5;cursor:not-allowed}.tonic-group,.replay-group{border:1px solid var(--line);background:0 0;border-radius:8px;flex-shrink:0;align-items:center;gap:6px;min-width:0;padding:8px 10px 6px;display:inline-flex}.feedback-notes{font-feature-settings:"tnum"}.feedback:has(.feedback-notes){flex-direction:column;align-items:flex-start;gap:4px}.skip-row{justify-content:center;margin:18px 0 6px;display:flex}.skip-link{color:var(--ink-4);font-family:var(--f-mono);cursor:pointer;background:0 0;border:0;padding:4px 8px;font-size:12px}.skip-link:hover{color:var(--ink);text-decoration:underline}.skip-link:focus-visible{box-shadow:var(--shadow-focus);border-radius:var(--radius-sm);outline:0}.tonic-group>legend,.replay-group>legend{font-family:var(--f-mono);letter-spacing:.08em;color:var(--ink-4);margin-left:4px;padding:0 6px;font-size:10px}.ans-label{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.ans-label .l{font-family:var(--f-mono);color:var(--ink-4);letter-spacing:.06em;text-transform:uppercase;font-size:11px}.ans-label .r{font-family:var(--f-mono);color:var(--ink-4);font-size:11px}.ans-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;display:grid}.ans-grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.ans-grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.ans-grid.cols-7{grid-template-columns:repeat(7,minmax(0,1fr))}.ans-btn{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);color:var(--ink);font-family:var(--f-mono);letter-spacing:.02em;cursor:pointer;flex-direction:column;align-items:center;gap:4px;padding:18px 10px;font-size:15px;font-weight:500;transition:all .1s;display:flex;position:relative}.ans-btn.active:not(:disabled):not(.correct):not(.wrong):not(.revealed){border-color:var(--line-strong);box-shadow:0 0 0 1px var(--line-strong) inset;font-weight:600}.ans-btn:hover:not(:disabled){border-color:var(--accent);background:var(--surface-2);transform:translateY(-1px)}.ans-btn.active:hover:not(:disabled):not(.correct):not(.wrong):not(.revealed){box-shadow:0 0 0 1px var(--accent) inset}.ans-btn .sub{font-family:var(--f-mono);color:var(--ink-4);letter-spacing:0;font-size:11px;font-weight:400}.ans-btn:disabled{cursor:not-allowed}.ans-btn:disabled:not(.correct):not(.wrong):not(.revealed){opacity:.3;background:var(--surface-sunken);color:var(--ink-4)}.ans-btn.revealed{opacity:.55}.ans-btn.correct{border-color:var(--good);background:var(--good-soft);color:var(--good);box-shadow:0 0 0 1px var(--good) inset}.ans-btn.correct .sub{color:var(--good);opacity:.75}.ans-btn.wrong{border-color:var(--bad);background:var(--bad-soft);color:var(--bad)}.ans-btn.wrong .sub{color:var(--bad);opacity:.75}.feedback{border-radius:var(--radius);font-family:var(--f-mono);justify-content:space-between;align-items:center;margin-top:18px;padding:12px 14px;font-size:12px;animation:.2s ease-out slide-in;display:flex}.feedback.ok{background:var(--good-soft);color:var(--good)}.feedback.no{background:var(--bad-soft);color:var(--bad)}@keyframes slide-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}.player-foot{border-top:1px solid var(--line-soft);background:var(--bg-2);padding:16px 32px 20px}.progress-rail{grid-template-columns:repeat(20,1fr);gap:3px;display:grid}.pip{background:var(--line);border-radius:2px;height:8px;transition:background-color .2s}.pip.good{background:var(--good)}.pip.warn{background:var(--warn)}.pip.bad{background:var(--bad)}.pip.cur{background:var(--accent);animation:1s ease-in-out infinite pip-pulse}@keyframes pip-pulse{0%,to{opacity:1}50%{opacity:.5}}.progress-stats{font-family:var(--f-mono);color:var(--ink-4);letter-spacing:.04em;justify-content:space-between;font-size:11px;display:flex}.progress-stats .cluster{gap:18px;display:flex}.progress-stats b{color:var(--ink-2);font-weight:500}.tag{font-family:var(--f-mono);background:var(--surface-sunken);color:var(--ink-3);letter-spacing:.04em;border-radius:4px;align-items:center;gap:4px;padding:2px 7px;font-size:10.5px;display:inline-flex}.tag.accent{background:var(--accent-soft);color:var(--accent)}.tag.good{background:var(--good-soft);color:var(--good)}.tag.warn{background:var(--warn-soft);color:var(--warn)}.menu-panel{z-index:10;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-md);min-width:160px;position:absolute;top:calc(100% + 4px);right:0;overflow:hidden}.menu-item{width:100%;color:var(--ink-2);text-align:left;cursor:pointer;background:0 0;border:0;align-items:center;gap:8px;padding:9px 12px;font-family:inherit;font-size:13px;transition:background-color .12s,color .12s;display:flex}.menu-item:hover{background:var(--surface-2);color:var(--ink)}.menu-item svg{flex-shrink:0;width:14px;height:14px}.score-pill{font-family:var(--f-mono);color:var(--ink-3);background:var(--surface);border:1px solid var(--line-soft);letter-spacing:.03em;border-radius:4px;gap:6px;padding:3px 8px;font-size:11px;display:inline-flex}.score-pill b{color:var(--ink);font-weight:600}.prog-slots{gap:8px;margin-bottom:18px;display:flex}.prog-slot{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);min-width:0;height:56px;font-family:var(--f-mono);color:var(--ink-4);cursor:pointer;box-sizing:border-box;flex:1;justify-content:center;align-items:center;font-size:16px;font-weight:600;transition:border-color .12s,background-color .12s,color .12s,opacity .12s;display:flex}.prog-slot:hover:not(.disabled):not(.playing){opacity:.75}.prog-slot.prefilled{color:var(--ink-2)}.prog-slot.active{border-color:var(--ink);color:var(--ink);box-shadow:0 0 0 1px var(--ink)}.prog-slot.answered{border-color:var(--good);background:var(--good-soft);color:var(--good)}.prog-slot.answered-tried{border-color:var(--warn);background:var(--warn-soft);color:var(--warn)}.prog-slot.wrong{border-color:var(--bad);background:var(--bad-soft);color:var(--bad)}.prog-slot.playing{cursor:default}.voice-row{gap:8px;margin:0 0 4px;display:flex}.voice-row-bass{margin:4px 0 18px}.prog-slots:has(+.voice-row-bass){margin-bottom:0}.voice-slot{border-radius:var(--radius-sm);min-width:0;height:36px;font-family:var(--f-mono);border:1.5px dashed var(--line-strong);color:var(--ink-2);cursor:pointer;-webkit-user-select:none;user-select:none;box-sizing:border-box;background:0 0;flex:1;justify-content:center;align-items:center;font-size:13px;font-weight:600;transition:border-color .12s,background-color .12s,color .12s;display:flex}.voice-slot.voice-slot-empty{color:var(--ink-4);font-size:14px;font-weight:500}.voice-slot.prefilled{cursor:default;border:1px solid var(--line);background:var(--surface);color:var(--ink-2);border-style:solid}.voice-slot.active{border:1.5px solid var(--accent);background:var(--accent-soft);color:var(--accent)}.voice-slot.answered{border:1px solid var(--good);background:var(--good-soft);color:var(--good)}.voice-slot.answered-tried{border:1px solid var(--warn);background:var(--warn-soft);color:var(--warn)}.voice-slot.wrong{border:1px solid var(--bad);background:var(--bad-soft);color:var(--bad)}.prog-slot.drill-active{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.note-picker{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius);flex-wrap:wrap;gap:4px;margin-bottom:16px;padding:12px 14px;display:flex}.note-picker .np-btn{font-family:var(--f-mono);border-radius:var(--radius-sm);border:1px solid var(--line);background:var(--surface);width:40px;height:36px;color:var(--ink-2);cursor:pointer;font-size:13px;font-weight:600;transition:border-color .12s,background-color .12s,color .12s}.note-picker .np-btn.np-sharp{background:var(--surface-sunken);width:36px;color:var(--ink-3)}.note-picker .np-btn:hover{border-color:var(--line-strong)}.confusions-panel{border:1px solid var(--line-soft);border-radius:var(--radius);background:var(--surface-2);margin:16px 0 0;padding:14px 16px}.confusions-panel h4{font-family:var(--f-mono);letter-spacing:.06em;color:var(--ink-4);margin:0 0 8px;font-size:11px}.confusions-row{font-family:var(--f-mono);color:var(--ink-3);align-items:center;gap:8px;font-size:12px;display:flex}.confusions-row b{color:var(--ink);font-weight:500}@media (max-width:860px){.form{grid-template-columns:1fr;gap:12px}.form .field-label{padding-top:0}.main{padding:20px 20px 32px}.player-body{padding:24px 16px 20px}.player-foot{padding:14px 16px}.play-area{gap:12px;padding:18px 14px}.play-area .waveform{display:none}.tonic-group{gap:4px;padding:6px 6px 4px}.tonic-group>legend{margin-left:2px;padding:0 4px;font-size:9px}.tonic-group .replay{padding:5px 7px;font-size:11px}.ans-grid.cols-7{gap:4px}.ans-grid.cols-7 .ans-btn{letter-spacing:0;padding:10px 2px;font-size:13px}.topbar-inner{gap:14px;padding:10px 16px}.topbar-link{padding:6px 8px;font-size:12.5px}.topbar-link.active:after{left:8px;right:8px}}@media (max-width:540px){.topbar-inner{flex-direction:column;align-items:flex-start;gap:4px;padding:10px 16px 8px}.topbar-nav{justify-content:flex-start;gap:0;width:100%;margin-left:0}.topbar-link{margin-right:6px;padding:6px 10px 6px 0;font-size:12.5px}.topbar-link.active:after{left:0;right:10px}.topbar-link-text-long{display:none}.topbar-link-text-short{display:inline}.hero{margin:6px 0 28px;padding-bottom:22px}.hero-wordmark{margin-bottom:12px;font-size:40px}.hero-tagline{font-size:15.5px}}@media (max-width:429px){.ans-grid.cols-7{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.ans-grid.cols-7 .ans-btn{letter-spacing:.02em;padding:14px 6px;font-size:14px}}@media (max-width:480px){.prog-slots,.voice-row{gap:4px}.prog-slot{min-width:0;height:48px;font-size:14px}.voice-slot{min-width:0;height:32px;font-size:12px}.voice-slot.voice-slot-empty{font-size:13px}}:focus-visible{box-shadow:var(--shadow-focus);border-radius:var(--radius-sm);outline:0}.chip:focus-visible,.seg button:focus-visible,.ans-btn:focus-visible{box-shadow:var(--shadow-focus)}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
