/*! tailwindcss v4.3.0 | MIT License | https://tailwindcss.com */
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-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-outline-style:solid;--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;--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-animation-delay:0s;--tw-animation-direction:normal;--tw-animation-duration:initial;--tw-animation-fill-mode:none;--tw-animation-iteration-count:1;--tw-enter-blur:0;--tw-enter-opacity:1;--tw-enter-rotate:0;--tw-enter-scale:1;--tw-enter-translate-x:0;--tw-enter-translate-y:0;--tw-exit-blur:0;--tw-exit-opacity:1;--tw-exit-rotate:0;--tw-exit-scale:1;--tw-exit-translate-x:0;--tw-exit-translate-y:0}}}:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--font-display:"Tomorrow", "Geist", ui-sans-serif, system-ui, sans-serif;--font-body:"Geist", ui-sans-serif, system-ui, sans-serif;--font-mono:"Geist Mono", "JetBrains Mono", ui-monospace, "SFMono-Regular", monospace;--font-sans:var(--font-body);--color-paper:oklch(12% .018 275);--color-paper-2:oklch(16% .019 275);--color-paper-3:oklch(20% .021 275);--color-paper-4:oklch(25% .023 275);--color-ink:oklch(95% .012 78);--color-ink-2:oklch(80% .014 78);--color-ink-3:oklch(63% .014 70);--color-rule:oklch(28% .02 275);--color-rule-strong:oklch(40% .026 275);--color-accent:oklch(78% .17 72);--color-accent-2:oklch(70% .2 35);--color-accent-soft:oklch(35% .062 72);--color-accent-ink:oklch(14% .035 70);--color-focus:oklch(84% .17 72);--color-success:oklch(76% .15 148);--color-success-soft:oklch(30% .06 148);--color-error:oklch(68% .2 26);--color-error-soft:oklch(29% .064 26);--color-warning:oklch(82% .15 80);--color-warning-soft:oklch(31% .06 80);--color-violet:oklch(75% .15 300);--color-violet-soft:oklch(31% .06 300);--color-bloom-1:oklch(74% .2 58);--color-bloom-2:oklch(62% .2 18);--color-fretboard:oklch(16% .022 55);--color-fretboard-2:oklch(20% .03 55);--color-fretboard-line:oklch(36% .026 62);--color-string:oklch(68% .03 75);--color-cell:oklch(22% .02 275);--color-cell-active:oklch(28% .034 275);--color-cell-inactive:oklch(15% .014 275);--color-cell-heat:oklch(56% .16 28);--color-shadow:oklch(2% .01 275);--background:var(--color-paper);--foreground:var(--color-ink);--card:var(--color-paper-2);--card-foreground:var(--color-ink);--popover:var(--color-paper-3);--popover-foreground:var(--color-ink);--primary:var(--color-accent);--primary-foreground:var(--color-accent-ink);--secondary:var(--color-paper-3);--secondary-foreground:var(--color-ink);--muted:var(--color-paper-3);--muted-foreground:var(--color-ink-3);--accent:var(--color-accent-soft);--accent-foreground:var(--color-ink);--destructive:var(--color-error);--destructive-foreground:var(--color-accent-ink);--border:var(--color-rule);--input:var(--color-rule-strong);--ring:var(--color-focus);--chart-1:var(--color-accent);--chart-2:var(--color-accent-2);--chart-3:var(--color-success);--chart-4:var(--color-violet);--chart-5:var(--color-warning);--radius:.625rem;--sidebar:var(--color-paper-2);--sidebar-foreground:var(--color-ink);--sidebar-primary:var(--color-accent);--sidebar-primary-foreground:var(--color-accent-ink);--sidebar-accent:var(--color-paper-3);--sidebar-accent-foreground:var(--color-ink);--sidebar-border:var(--color-rule);--sidebar-ring:var(--color-focus);--space-3xs:.125rem;--space-2xs:.25rem;--space-xs:.5rem;--space-sm:.75rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--space-3xl:4rem;--space-4xl:6rem;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-md:1.125rem;--text-lg:1.375rem;--text-xl:1.75rem;--text-2xl:2.25rem;--text-3xl:3rem;--text-display:clamp(2.65rem, 7vw + .5rem, 5.5rem);--text-display-sm:clamp(2rem, 4vw + .75rem, 3.75rem);--leading-display:1.02;--leading-tight:1.1;--leading-snug:1.3;--leading-body:1.58;--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-in:cubic-bezier(.7, 0, .84, 0);--ease-in-out:cubic-bezier(.65, 0, .35, 1);--dur-fast:.12s;--dur-base:.22s;--dur-slow:.42s;--rule-hair:1px;--rule-bold:2px;--radius-xs:.25rem;--radius-sm:.375rem;--radius-md:.625rem;--radius-lg:.875rem;--radius-xl:1.25rem;--radius-pill:999px;--page-gutter:clamp(1rem, 4vw, 2.5rem);--page-max:78rem;--tap-target:2.75rem;--shadow-soft:0 1.25rem 4rem var(--color-shadow)}@supports (color:color-mix(in lab, red, red)){:root{--shadow-soft:0 1.25rem 4rem color-mix(in oklch, var(--color-shadow) 52%, transparent)}}:root{--shadow-panel:0 .75rem 2.25rem var(--color-shadow)}@supports (color:color-mix(in lab, red, red)){:root{--shadow-panel:0 .75rem 2.25rem color-mix(in oklch, var(--color-shadow) 42%, transparent)}}:root{--shadow-glow:0 0 2.75rem var(--color-bloom-1)}@supports (color:color-mix(in lab, red, red)){:root{--shadow-glow:0 0 2.75rem color-mix(in oklch, var(--color-bloom-1) 20%, transparent)}}:root{--shadow-nav:0 1rem 3rem var(--color-shadow)}@supports (color:color-mix(in lab, red, red)){:root{--shadow-nav:0 1rem 3rem color-mix(in oklch, var(--color-shadow) 48%, transparent)}}html[data-contrast=high]{--color-paper:oklch(8% .012 275);--color-paper-2:oklch(12% .014 275);--color-paper-3:oklch(18% .016 275);--color-paper-4:oklch(26% .018 275);--color-ink:oklch(99% .008 85);--color-ink-2:oklch(90% .01 85);--color-ink-3:oklch(78% .012 80);--color-rule:oklch(48% .02 275);--color-rule-strong:oklch(64% .024 275);--color-accent:oklch(86% .17 76);--color-accent-soft:oklch(43% .07 76);--color-focus:oklch(92% .16 76);--color-success:oklch(84% .14 148);--color-error:oklch(76% .2 28);--color-warning:oklch(88% .14 82);--color-violet:oklch(84% .14 300);--color-fretboard-line:oklch(56% .03 62);--color-string:oklch(86% .024 75)}@layer theme{:root,:host{--font-mono:var(--font-mono);--color-white:#fff;--spacing:.25rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-base--line-height:calc(1.5 / 1);--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--font-weight-medium:500;--leading-tight:1.25;--leading-snug:1.375;--radius-md:calc(var(--radius) - 2px);--radius-lg:var(--radius);--radius-xl:calc(var(--radius) + 4px);--ease-out:cubic-bezier(0, 0, .2, 1);--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-body);--default-mono-font-family:var(--font-mono);--color-accent:var(--accent)}}@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{.pointer-events-none{pointer-events:none}.visible{visibility:visible}.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.relative{position:relative}.right-2{right:calc(var(--spacing) * 2)}.z-50{z-index:50}.-mx-1{margin-inline:calc(var(--spacing) * -1)}.my-1{margin-block:calc(var(--spacing) * 1)}.block{display:block}.flex{display:flex}.inline-flex{display:inline-flex}.field-sizing-content{field-sizing:content}.size-3\.5{width:calc(var(--spacing) * 3.5);height:calc(var(--spacing) * 3.5)}.size-4{width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}.size-6{width:calc(var(--spacing) * 6);height:calc(var(--spacing) * 6)}.size-8{width:calc(var(--spacing) * 8);height:calc(var(--spacing) * 8)}.size-9{width:calc(var(--spacing) * 9);height:calc(var(--spacing) * 9)}.size-10{width:calc(var(--spacing) * 10);height:calc(var(--spacing) * 10)}.h-6{height:calc(var(--spacing) * 6)}.h-8{height:calc(var(--spacing) * 8)}.h-9{height:calc(var(--spacing) * 9)}.h-10{height:calc(var(--spacing) * 10)}.h-\[var\(--radix-select-trigger-height\)\]{height:var(--radix-select-trigger-height)}.h-px{height:1px}.max-h-\(--radix-select-content-available-height\){max-height:var(--radix-select-content-available-height)}.min-h-16{min-height:calc(var(--spacing) * 16)}.w-fit{width:fit-content}.w-full{width:100%}.min-w-0{min-width:calc(var(--spacing) * 0)}.min-w-44{min-width:calc(var(--spacing) * 44)}.min-w-\[8rem\]{min-width:8rem}.min-w-\[var\(--radix-select-trigger-width\)\]{min-width:var(--radix-select-trigger-width)}.shrink-0{flex-shrink:0}.grow{flex-grow:1}.origin-\(--radix-select-content-transform-origin\){transform-origin:var(--radix-select-content-transform-origin)}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.cursor-default{cursor:default}.touch-none{touch-action:none}.resize{resize:both}.scroll-my-1{scroll-margin-block:calc(var(--spacing) * 1)}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:calc(var(--spacing) * 1)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.overflow-hidden{overflow:hidden}.overflow-x-hidden{overflow-x:hidden}.overflow-y-auto{overflow-y:auto}.rounded-full{border-radius:3.40282e38px}.rounded-md{border-radius:calc(var(--radius) - 2px)}.rounded-sm{border-radius:calc(var(--radius) - 4px)}.border{border-style:var(--tw-border-style);border-width:1px}.border-input{border-color:var(--input)}.border-primary{border-color:var(--primary)}.border-transparent{border-color:#0000}.bg-background{background-color:var(--background)}.bg-border{background-color:var(--border)}.bg-destructive{background-color:var(--destructive)}.bg-muted{background-color:var(--muted)}.bg-popover{background-color:var(--popover)}.bg-primary{background-color:var(--primary)}.bg-secondary{background-color:var(--secondary)}.bg-transparent{background-color:#0000}.bg-white{background-color:var(--color-white)}.p-1{padding:calc(var(--spacing) * 1)}.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-1{padding-block:calc(var(--spacing) * 1)}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-2{padding-block:calc(var(--spacing) * 2)}.pr-8{padding-right:calc(var(--spacing) * 8)}.pl-2{padding-left:calc(var(--spacing) * 2)}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--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-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.whitespace-nowrap{white-space:nowrap}.text-muted-foreground{color:var(--muted-foreground)}.text-popover-foreground{color:var(--popover-foreground)}.text-primary{color:var(--primary)}.text-primary-foreground{color:var(--primary-foreground)}.text-secondary-foreground{color:var(--secondary-foreground)}.text-white{color:var(--color-white)}.underline-offset-4{text-underline-offset:4px}.opacity-50{opacity:.5}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px 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)}.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)}.shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px 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)}.shadow-xs{--tw-shadow:0 1px 2px 0 var(--tw-shadow-color,#0000000d);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.ring-0{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(0px + 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)}.ring-ring\/50{--tw-ring-color:var(--ring)}@supports (color:color-mix(in lab, red, red)){.ring-ring\/50{--tw-ring-color:color-mix(in oklab, var(--ring) 50%, transparent)}}.outline-hidden{--tw-outline-style:none;outline-style:none}@media (forced-colors:active){.outline-hidden{outline-offset:2px;outline:2px solid #0000}}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.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-\[color\,box-shadow\]{transition-property:color,box-shadow;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}.running{animation-play-state:running}.group-data-\[disabled\=true\]\:pointer-events-none:is(:where(.group)[data-disabled=true] *){pointer-events:none}.group-data-\[disabled\=true\]\:opacity-50:is(:where(.group)[data-disabled=true] *){opacity:.5}.group-data-\[size\=default\]\/switch\:size-4:is(:where(.group\/switch)[data-size=default] *){width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}.group-data-\[size\=sm\]\/switch\:size-3:is(:where(.group\/switch)[data-size=sm] *){width:calc(var(--spacing) * 3);height:calc(var(--spacing) * 3)}.peer-disabled\:cursor-not-allowed:is(:where(.peer):disabled~*){cursor:not-allowed}.peer-disabled\:opacity-50:is(:where(.peer):disabled~*){opacity:.5}.selection\:bg-primary ::selection{background-color:var(--primary)}.selection\:bg-primary::selection{background-color:var(--primary)}.selection\:text-primary-foreground ::selection{color:var(--primary-foreground)}.selection\:text-primary-foreground::selection{color:var(--primary-foreground)}.file\:inline-flex::file-selector-button{display:inline-flex}.file\:h-7::file-selector-button{height:calc(var(--spacing) * 7)}.file\:border-0::file-selector-button{border-style:var(--tw-border-style);border-width:0}.file\:bg-transparent::file-selector-button{background-color:#0000}.file\:text-sm::file-selector-button{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.file\:font-medium::file-selector-button{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.file\:text-foreground::file-selector-button{color:var(--foreground)}.placeholder\:text-muted-foreground::placeholder{color:var(--muted-foreground)}@media (hover:hover){.hover\:bg-accent:hover{background-color:var(--accent)}.hover\:bg-destructive\/90:hover{background-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.hover\:bg-destructive\/90:hover{background-color:color-mix(in oklab, var(--destructive) 90%, transparent)}}.hover\:bg-primary\/90:hover{background-color:var(--primary)}@supports (color:color-mix(in lab, red, red)){.hover\:bg-primary\/90:hover{background-color:color-mix(in oklab, var(--primary) 90%, transparent)}}.hover\:bg-secondary\/80:hover{background-color:var(--secondary)}@supports (color:color-mix(in lab, red, red)){.hover\:bg-secondary\/80:hover{background-color:color-mix(in oklab, var(--secondary) 80%, transparent)}}.hover\:text-accent-foreground:hover{color:var(--accent-foreground)}.hover\:underline:hover{text-decoration-line:underline}.hover\:ring-4:hover{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(4px + 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)}}.focus\:bg-accent:focus{background-color:var(--accent)}.focus\:text-accent-foreground:focus{color:var(--accent-foreground)}.focus-visible\:border-ring:focus-visible{border-color:var(--ring)}.focus-visible\:ring-4:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(4px + 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)}.focus-visible\:ring-\[3px\]:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(3px + 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)}.focus-visible\:ring-destructive\/20:focus-visible{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.focus-visible\:ring-destructive\/20:focus-visible{--tw-ring-color:color-mix(in oklab, var(--destructive) 20%, transparent)}}.focus-visible\:ring-ring\/50:focus-visible{--tw-ring-color:var(--ring)}@supports (color:color-mix(in lab, red, red)){.focus-visible\:ring-ring\/50:focus-visible{--tw-ring-color:color-mix(in oklab, var(--ring) 50%, transparent)}}.focus-visible\:outline-hidden:focus-visible{--tw-outline-style:none;outline-style:none}@media (forced-colors:active){.focus-visible\:outline-hidden:focus-visible{outline-offset:2px;outline:2px solid #0000}}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.has-\[\>svg\]\:px-1\.5:has(>svg){padding-inline:calc(var(--spacing) * 1.5)}.has-\[\>svg\]\:px-2\.5:has(>svg){padding-inline:calc(var(--spacing) * 2.5)}.has-\[\>svg\]\:px-3:has(>svg){padding-inline:calc(var(--spacing) * 3)}.has-\[\>svg\]\:px-4:has(>svg){padding-inline:calc(var(--spacing) * 4)}.aria-invalid\:border-destructive[aria-invalid=true]{border-color:var(--destructive)}.aria-invalid\:ring-destructive\/20[aria-invalid=true]{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.aria-invalid\:ring-destructive\/20[aria-invalid=true]{--tw-ring-color:color-mix(in oklab, var(--destructive) 20%, transparent)}}.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}.data-\[orientation\=horizontal\]\:h-1\.5[data-orientation=horizontal]{height:calc(var(--spacing) * 1.5)}.data-\[orientation\=horizontal\]\:h-full[data-orientation=horizontal]{height:100%}.data-\[orientation\=horizontal\]\:w-full[data-orientation=horizontal]{width:100%}.data-\[orientation\=vertical\]\:h-full[data-orientation=vertical]{height:100%}.data-\[orientation\=vertical\]\:min-h-44[data-orientation=vertical]{min-height:calc(var(--spacing) * 44)}.data-\[orientation\=vertical\]\:w-1\.5[data-orientation=vertical]{width:calc(var(--spacing) * 1.5)}.data-\[orientation\=vertical\]\:w-auto[data-orientation=vertical]{width:auto}.data-\[orientation\=vertical\]\:w-full[data-orientation=vertical]{width:100%}.data-\[orientation\=vertical\]\:flex-col[data-orientation=vertical]{flex-direction:column}.data-\[placeholder\]\:text-muted-foreground[data-placeholder]{color:var(--muted-foreground)}.data-\[side\=bottom\]\:translate-y-1[data-side=bottom]{--tw-translate-y:calc(var(--spacing) * 1);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=bottom\]\:slide-in-from-top-2[data-side=bottom]{--tw-enter-translate-y:calc(2*var(--spacing)*-1)}.data-\[side\=left\]\:-translate-x-1[data-side=left]{--tw-translate-x:calc(var(--spacing) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=left\]\:slide-in-from-right-2[data-side=left]{--tw-enter-translate-x:calc(2*var(--spacing))}.data-\[side\=right\]\:translate-x-1[data-side=right]{--tw-translate-x:calc(var(--spacing) * 1);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=right\]\:slide-in-from-left-2[data-side=right]{--tw-enter-translate-x:calc(2*var(--spacing)*-1)}.data-\[side\=top\]\:-translate-y-1[data-side=top]{--tw-translate-y:calc(var(--spacing) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=top\]\:slide-in-from-bottom-2[data-side=top]{--tw-enter-translate-y:calc(2*var(--spacing))}.data-\[size\=default\]\:h-9[data-size=default]{height:calc(var(--spacing) * 9)}.data-\[size\=default\]\:h-\[1\.15rem\][data-size=default]{height:1.15rem}.data-\[size\=default\]\:w-8[data-size=default]{width:calc(var(--spacing) * 8)}.data-\[size\=sm\]\:h-3\.5[data-size=sm]{height:calc(var(--spacing) * 3.5)}.data-\[size\=sm\]\:h-8[data-size=sm]{height:calc(var(--spacing) * 8)}.data-\[size\=sm\]\:w-6[data-size=sm]{width:calc(var(--spacing) * 6)}:is(.\*\:data-\[slot\=select-value\]\:line-clamp-1>*)[data-slot=select-value]{-webkit-line-clamp:1;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}:is(.\*\:data-\[slot\=select-value\]\:flex>*)[data-slot=select-value]{display:flex}:is(.\*\:data-\[slot\=select-value\]\:items-center>*)[data-slot=select-value]{align-items:center}:is(.\*\:data-\[slot\=select-value\]\:gap-2>*)[data-slot=select-value]{gap:calc(var(--spacing) * 2)}.data-\[state\=checked\]\:translate-x-\[calc\(100\%-2px\)\][data-state=checked]{--tw-translate-x:calc(100% - 2px);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[state\=checked\]\:bg-primary[data-state=checked]{background-color:var(--primary)}.data-\[state\=closed\]\:animate-out[data-state=closed]{animation:exit var(--tw-animation-duration,var(--tw-duration,.15s))var(--tw-ease,ease)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none)}.data-\[state\=closed\]\:fade-out-0[data-state=closed]{--tw-exit-opacity:0}.data-\[state\=closed\]\:zoom-out-95[data-state=closed]{--tw-exit-scale:.95}.data-\[state\=open\]\:animate-in[data-state=open]{animation:enter var(--tw-animation-duration,var(--tw-duration,.15s))var(--tw-ease,ease)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none)}.data-\[state\=open\]\:fade-in-0[data-state=open]{--tw-enter-opacity:0}.data-\[state\=open\]\:zoom-in-95[data-state=open]{--tw-enter-scale:.95}.data-\[state\=unchecked\]\:translate-x-0[data-state=unchecked]{--tw-translate-x:calc(var(--spacing) * 0);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[state\=unchecked\]\:bg-input[data-state=unchecked]{background-color:var(--input)}@media (width>=48rem){.md\:text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}}.dark\:border-input:is(.dark *){border-color:var(--input)}.dark\:bg-destructive\/60:is(.dark *){background-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.dark\:bg-destructive\/60:is(.dark *){background-color:color-mix(in oklab, var(--destructive) 60%, transparent)}}.dark\:bg-input\/30:is(.dark *){background-color:var(--input)}@supports (color:color-mix(in lab, red, red)){.dark\:bg-input\/30:is(.dark *){background-color:color-mix(in oklab, var(--input) 30%, transparent)}}@media (hover:hover){.dark\:hover\:bg-accent\/50:is(.dark *):hover{background-color:var(--accent)}@supports (color:color-mix(in lab, red, red)){.dark\:hover\:bg-accent\/50:is(.dark *):hover{background-color:color-mix(in oklab, var(--accent) 50%, transparent)}}.dark\:hover\:bg-input\/50:is(.dark *):hover{background-color:var(--input)}@supports (color:color-mix(in lab, red, red)){.dark\:hover\:bg-input\/50:is(.dark *):hover{background-color:color-mix(in oklab, var(--input) 50%, transparent)}}}.dark\:focus-visible\:ring-destructive\/40:is(.dark *):focus-visible{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.dark\:focus-visible\:ring-destructive\/40:is(.dark *):focus-visible{--tw-ring-color:color-mix(in oklab, var(--destructive) 40%, transparent)}}.dark\:aria-invalid\:ring-destructive\/40:is(.dark *)[aria-invalid=true]{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.dark\:aria-invalid\:ring-destructive\/40:is(.dark *)[aria-invalid=true]{--tw-ring-color:color-mix(in oklab, var(--destructive) 40%, transparent)}}.dark\:data-\[state\=checked\]\:bg-primary-foreground:is(.dark *)[data-state=checked]{background-color:var(--primary-foreground)}.dark\:data-\[state\=unchecked\]\:bg-foreground:is(.dark *)[data-state=unchecked]{background-color:var(--foreground)}.dark\:data-\[state\=unchecked\]\:bg-input\/80:is(.dark *)[data-state=unchecked]{background-color:var(--input)}@supports (color:color-mix(in lab, red, red)){.dark\:data-\[state\=unchecked\]\:bg-input\/80:is(.dark *)[data-state=unchecked]{background-color:color-mix(in oklab, var(--input) 80%, transparent)}}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-3 svg:not([class*=size-]){width:calc(var(--spacing) * 3);height:calc(var(--spacing) * 3)}.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-4 svg:not([class*=size-]){width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}.\[\&_svg\:not\(\[class\*\=\'text-\'\]\)\]\:text-muted-foreground svg:not([class*=text-]){color:var(--muted-foreground)}:is(.\*\:\[span\]\:last\:flex>*):is(span):last-child{display:flex}:is(.\*\:\[span\]\:last\:items-center>*):is(span):last-child{align-items:center}:is(.\*\:\[span\]\:last\:gap-2>*):is(span):last-child{gap:calc(var(--spacing) * 2)}}@property --tw-animation-delay{syntax:"*";inherits:false;initial-value:0s}@property --tw-animation-direction{syntax:"*";inherits:false;initial-value:normal}@property --tw-animation-duration{syntax:"*";inherits:false}@property --tw-animation-fill-mode{syntax:"*";inherits:false;initial-value:none}@property --tw-animation-iteration-count{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-blur{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-opacity{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-rotate{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-scale{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-blur{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-opacity{syntax:"*";inherits:false;initial-value:1}@property --tw-exit-rotate{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-scale{syntax:"*";inherits:false;initial-value:1}@property --tw-exit-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-translate-y{syntax:"*";inherits:false;initial-value:0}*{box-sizing:border-box}html,body{min-height:100%;overflow-x:clip}html{-webkit-text-size-adjust:100%;background:var(--color-paper)}body{min-width:320px;color:var(--color-ink);font-family:var(--font-body);background:radial-gradient(circle at 14% -8%, var(--color-bloom-1), transparent 28rem), radial-gradient(circle at 92% 12%, var(--color-bloom-2), transparent 24rem), linear-gradient(180deg, var(--color-paper-2), var(--color-paper));margin:0}@supports (color:color-mix(in lab, red, red)){body{background:radial-gradient(circle at 14% -8%, color-mix(in oklch, var(--color-bloom-1) 26%, transparent), transparent 28rem), radial-gradient(circle at 92% 12%, color-mix(in oklch, var(--color-bloom-2) 18%, transparent), transparent 24rem), linear-gradient(180deg, var(--color-paper-2), var(--color-paper))}}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button,input,textarea,select{font:inherit}a{color:inherit}svg{flex:none}::selection{background:var(--color-accent);color:var(--color-accent-ink)}:focus-visible{outline:var(--rule-bold) solid var(--color-focus);outline-offset:var(--space-2xs)}.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}.skip-link{top:var(--space-sm);left:var(--space-sm);z-index:80;border:var(--rule-hair) solid var(--color-focus);border-radius:var(--radius-pill);background:var(--color-paper-4);color:var(--color-ink);padding:var(--space-sm) var(--space-md);box-shadow:var(--shadow-nav);font-weight:800;text-decoration:none;position:fixed;transform:translateY(-150%)}.skip-link:focus{transform:translateY(0)}.app-shell{grid-template-rows:auto 1fr;min-height:100svh;display:grid}.app-chrome{z-index:40;gap:var(--space-sm);width:min(var(--page-max), calc(100% - (var(--page-gutter) * 2)));margin:var(--space-md) auto 0;display:grid}.app-header,.app-nav{border:var(--rule-hair) solid var(--color-rule);background:linear-gradient(180deg, var(--color-paper-3), var(--color-paper-2))}@supports (color:color-mix(in lab, red, red)){.app-header,.app-nav{background:linear-gradient(180deg, color-mix(in oklch, var(--color-paper-3) 92%, transparent), color-mix(in oklch, var(--color-paper-2) 92%, transparent))}}.app-header,.app-nav{-webkit-backdrop-filter:blur(18px)saturate(120%);backdrop-filter:blur(18px)saturate(120%);box-shadow:var(--shadow-nav)}.app-header{gap:var(--space-md);border-radius:var(--radius-pill);padding:var(--space-sm) var(--space-sm) var(--space-sm) var(--space-md);grid-template-columns:minmax(0,1fr) auto auto;align-items:center;display:grid}.app-header__brand{align-items:center;gap:var(--space-sm);min-width:0;display:flex}.brand-mark{border:var(--rule-hair) solid var(--color-accent);place-items:center;width:2.5rem;height:2.5rem;display:grid}@supports (color:color-mix(in lab, red, red)){.brand-mark{border:var(--rule-hair) solid color-mix(in oklch, var(--color-accent) 62%, var(--color-rule))}}.brand-mark{border-radius:var(--radius-pill);background:radial-gradient(circle at 35% 25%, var(--color-accent), transparent 58%), var(--color-paper-4)}@supports (color:color-mix(in lab, red, red)){.brand-mark{background:radial-gradient(circle at 35% 25%, color-mix(in oklch, var(--color-accent) 72%, transparent), transparent 58%), var(--color-paper-4)}}.brand-mark{color:var(--color-accent);box-shadow:var(--shadow-glow);overflow:hidden}.brand-mark__icon{width:1.95rem;height:1.95rem;display:block}.app-header h1,.app-header p{margin:0}.app-header h1{color:var(--color-ink);font-family:var(--font-display);font-size:var(--text-lg);letter-spacing:0;font-weight:700;line-height:var(--leading-tight)}.app-kicker{color:var(--color-accent);font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:.08em;font-weight:700;line-height:var(--leading-snug);text-transform:uppercase;margin:0}.app-header__status{gap:var(--space-xs);color:var(--color-ink-2);font-family:var(--font-mono);font-size:var(--text-xs);align-items:center;font-weight:600;display:flex}.app-header__status span,.status-chip{border:var(--rule-hair) solid var(--color-rule);border-radius:var(--radius-pill);background:var(--color-paper-3);min-height:2rem;padding:var(--space-2xs) var(--space-sm);white-space:nowrap;align-items:center;display:inline-flex}.app-header__status .status-warning{border-color:var(--color-error);color:var(--color-error)}.sound-button svg,.app-nav__link svg,.button-row svg,.toolbar-actions svg{width:1rem;height:1rem}.sound-button,[data-slot=button],[data-slot=select-trigger],.app-nav__link,.answer-choice,.button-row [data-slot=button],.toolbar-actions [data-slot=button]{min-height:var(--tap-target)}[data-slot=button]{border-radius:var(--radius-pill);letter-spacing:0;white-space:nowrap;transition:transform var(--dur-fast) var(--ease-out), background-color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);font-weight:800}[data-slot=button]:hover:not(:disabled){transform:translateY(-1px)}[data-slot=button]:active:not(:disabled){transform:translateY(0)}[data-slot=button][data-variant=default]{border:var(--rule-hair) solid var(--color-accent);background:var(--color-accent);color:var(--color-accent-ink);box-shadow:var(--shadow-glow)}[data-slot=button][data-variant=default]:hover{background:var(--color-warning);color:var(--color-accent-ink)}[data-slot=button][data-variant=secondary]{border:var(--rule-hair) solid var(--color-rule-strong);background:var(--color-paper-3);color:var(--color-ink)}[data-slot=button][data-variant=destructive]{border:var(--rule-hair) solid var(--color-error);background:var(--color-error);color:var(--color-accent-ink)}[data-slot=button][data-variant=destructive]:hover{background:var(--color-error)}@supports (color:color-mix(in lab, red, red)){[data-slot=button][data-variant=destructive]:hover{background:color-mix(in oklch, var(--color-error) 88%, var(--color-warning))}}[data-slot=button][data-variant=outline]{border:var(--rule-hair) solid var(--color-rule-strong);color:var(--color-ink);background:0 0}[data-slot=button][data-variant=ghost]{color:var(--color-ink-2)}[data-slot=button]:disabled,[data-slot=button][aria-disabled=true]{opacity:.52;transform:none}[data-slot=select-trigger],[data-slot=input],[data-slot=textarea]{border-color:var(--color-rule-strong);border-radius:var(--radius-md);background:var(--color-paper-2);color:var(--color-ink);box-shadow:none}[data-slot=textarea]{resize:vertical}[data-slot=select-content]{border-color:var(--color-rule-strong);background:var(--color-paper-3);color:var(--color-ink)}[data-slot=select-item]:focus{background:var(--color-accent-soft);color:var(--color-ink)}[data-slot=switch]{border:var(--rule-hair) solid var(--color-rule-strong);background:var(--color-paper-4);min-width:2.85rem;min-height:1.6rem}[data-slot=switch][data-state=checked]{background:var(--color-accent)}[data-slot=slider]{min-height:var(--tap-target)}[data-slot=slider-track]{background:var(--color-paper-4)}[data-slot=slider-range]{background:var(--color-accent)}[data-slot=slider-thumb]{border-color:var(--color-accent);background:var(--color-ink);width:1.5rem;height:1.5rem}.app-nav{justify-self:center;gap:var(--space-2xs);border-radius:var(--radius-pill);width:min(46rem,100%);padding:var(--space-2xs);grid-template-columns:repeat(5,minmax(0,1fr));display:grid}.app-nav__link{justify-content:center;align-items:center;gap:var(--space-xs);border-radius:var(--radius-pill);color:var(--color-ink-3);font-size:var(--text-sm);white-space:nowrap;transition:color var(--dur-fast) var(--ease-out);font-weight:800;text-decoration:none;display:flex}.app-nav__link[data-active=true]{background:var(--color-accent);color:var(--color-accent-ink)}.app-nav__link:focus-visible,.app-nav__link:hover{background:var(--color-paper-4);color:var(--color-ink)}.app-nav__link:hover:not([data-active=true]){transform:translateY(-1px)}.app-nav__link[data-active=true]:focus-visible,.app-nav__link[data-active=true]:hover{background:var(--color-accent);color:var(--color-accent-ink)}.app-main{width:min(var(--page-max), calc(100% - (var(--page-gutter) * 2)));padding:var(--space-xl) 0 var(--space-3xl);min-width:0;margin-inline:auto}.page-stack{gap:var(--space-lg);min-width:0;display:grid}.dashboard-hero,.section-band,.page-heading,.lesson-surface,.course-tier,.setting-group{border:var(--rule-hair) solid var(--color-rule);border-radius:var(--radius-xl);background:linear-gradient(180deg, var(--color-paper-2), var(--color-paper-2)), var(--color-paper-2);min-width:0;box-shadow:var(--shadow-panel)}.dashboard-hero{gap:var(--space-lg);padding:clamp(var(--space-md), 2.2vw, var(--space-xl));grid-template-columns:minmax(0,1.35fr) minmax(18rem,.85fr);align-items:center;display:grid;position:relative;overflow:hidden}.dashboard-hero:before,.section-band--fretboard-map:before{content:"";pointer-events:none;background:radial-gradient(circle, var(--color-bloom-1), transparent 68%);width:18rem;height:18rem;position:absolute;inset:auto 0 0 auto}@supports (color:color-mix(in lab, red, red)){.dashboard-hero:before,.section-band--fretboard-map:before{background:radial-gradient(circle, color-mix(in oklch, var(--color-bloom-1) 16%, transparent), transparent 68%)}}.dashboard-hero__copy{z-index:1;align-content:center;gap:var(--space-md);display:grid;position:relative}.dashboard-hero h2,.page-heading h2,.section-heading h2,.lesson-toolbar h2,.setting-group h3,.session-summary h2{overflow-wrap:anywhere;min-width:0;color:var(--color-ink);font-family:var(--font-display);letter-spacing:0;font-weight:700;line-height:var(--leading-tight);margin:0}.dashboard-hero h2{max-width:22ch;font-size:var(--text-2xl)}.page-heading h2{font-size:var(--text-xl)}.section-heading h2,.lesson-toolbar h2,.session-summary h2{font-size:var(--text-lg)}.setting-group h3,.module-card h3,.pace-card h3{font-size:var(--text-md)}.dashboard-hero p,.page-heading p,.section-band p,.lesson-copy,.lesson-context,.locked-copy,.setting-row p{color:var(--color-ink-2);line-height:var(--leading-body);margin:0}.dashboard-hero__panel{z-index:1;gap:var(--space-sm);align-content:stretch;display:grid;position:relative}.dashboard-metric,.metric-card{gap:var(--space-2xs);border:var(--rule-hair) solid var(--color-rule);border-radius:var(--radius-lg);background:var(--color-paper-3);padding:var(--space-md);display:grid}.dashboard-metric__icon{width:1.25rem;height:1.25rem;color:var(--color-accent)}.dashboard-metric span,.metric-card span{color:var(--color-ink-3);font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;font-weight:700}.dashboard-metric strong,.metric-card strong{color:var(--color-ink);font-family:var(--font-mono);font-size:var(--text-xl);font-variant-numeric:tabular-nums;font-weight:700}.button-row,.toolbar-actions{gap:var(--space-sm);flex-wrap:wrap;align-items:center;display:flex}.section-band,.course-tier,.lesson-surface,.setting-group{padding:clamp(var(--space-md), 3vw, var(--space-xl));position:relative}.page-heading{gap:var(--space-lg);padding:clamp(var(--space-md), 2.2vw, var(--space-lg));grid-template-columns:minmax(0,.9fr) minmax(18rem,1.1fr);align-items:center;display:grid}.page-heading>p{justify-self:end;max-width:58ch}.section-heading,.lesson-toolbar,.module-card__top{justify-content:space-between;align-items:flex-start;gap:var(--space-md);min-width:0;display:flex}.section-heading{margin-bottom:var(--space-md)}.section-heading svg,.module-status{width:1.25rem;height:1.25rem;color:var(--color-accent)}.tier-pill,.session-count,.module-number{border:var(--rule-hair) solid var(--color-accent);justify-content:center;align-items:center;min-height:2rem;display:inline-flex}@supports (color:color-mix(in lab, red, red)){.tier-pill,.session-count,.module-number{border:var(--rule-hair) solid color-mix(in oklch, var(--color-accent) 70%, var(--color-rule))}}.tier-pill,.session-count,.module-number{border-radius:var(--radius-pill);background:var(--color-accent-soft);color:var(--color-warning);padding:var(--space-2xs) var(--space-sm);font-family:var(--font-mono);font-size:var(--text-xs);text-transform:capitalize;white-space:nowrap;font-weight:700}.module-meta,.inline-list{gap:var(--space-xs);margin-top:var(--space-sm);flex-wrap:wrap;padding:0;list-style:none;display:flex}.module-meta span,.inline-list span,.inline-list li,.inline-list strong{border:var(--rule-hair) solid var(--color-rule);border-radius:var(--radius-pill);background:var(--color-paper-3);padding:var(--space-2xs) var(--space-sm);color:var(--color-ink-2);font-family:var(--font-mono);font-size:var(--text-xs);font-weight:700}.two-column,.settings-grid,.backup-grid{gap:var(--space-lg);grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.two-column>*,.settings-grid>*,.backup-grid>*{min-width:0}.progress-rail{height:.75rem;margin-top:var(--space-md);border-radius:var(--radius-pill);background:var(--color-paper-4);overflow:hidden}.progress-rail span{border-radius:inherit;background:linear-gradient(90deg, var(--color-accent), var(--color-accent-2));height:100%;display:block}.practice-list{gap:var(--space-sm);margin:0;padding:0;list-style:none;display:grid}.practice-list li{justify-content:space-between;align-items:center;gap:var(--space-md);border:var(--rule-hair) solid var(--color-rule);border-radius:var(--radius-lg);background:var(--color-paper-3);padding:var(--space-md);display:flex}.practice-list strong{color:var(--color-ink);font-weight:800}.practice-list span{color:var(--color-ink-3);font-family:var(--font-mono);font-size:var(--text-sm)}.module-grid{gap:var(--space-md);grid-template-columns:repeat(3,minmax(0,1fr));display:grid}.course-map .module-grid{position:relative}.course-map .module-grid:before{content:"";inset:2.5rem var(--space-lg) auto var(--space-lg);height:var(--rule-hair);background:linear-gradient(90deg, transparent, var(--color-rule-strong), transparent);position:absolute}.module-card{gap:var(--space-sm);border:var(--rule-hair) solid var(--color-rule);border-radius:var(--radius-lg);background:var(--color-paper-2);padding:var(--space-md);transition:transform var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out);display:grid;position:relative}.module-card:hover{border-color:var(--color-rule-strong);box-shadow:var(--shadow-panel);transform:translateY(-2px)}.module-card[data-current=true]{border-color:var(--color-accent);box-shadow:inset 0 0 0 var(--rule-hair) var(--color-accent), var(--shadow-glow)}.module-card[data-unlocked=false]{opacity:.68}.module-card p{color:var(--color-ink-2);line-height:var(--leading-body);margin:0}.module-status{color:var(--color-ink-3)}.module-status.is-complete,.is-correct{color:var(--color-success)}.notice-band{border:var(--rule-hair) solid var(--color-warning);border-radius:var(--radius-lg);background:var(--color-warning-soft);color:var(--color-warning);padding:var(--space-md);font-weight:800}.lesson-heading{align-items:end}.lesson-mode-control,.setting-row{justify-content:space-between;align-items:center;gap:var(--space-md);display:flex}.lesson-mode-control label,.setting-row label{color:var(--color-ink-2);font-weight:800}.lesson-surface{gap:var(--space-md);min-width:0;display:grid}.lesson-surface--quiz{border-color:var(--color-rule-strong)}.lesson-context{margin-top:var(--space-2xs);font-family:var(--font-mono);font-size:var(--text-sm);font-weight:700}.fretboard-wrap{min-width:0;max-width:100%}.fretboard-orientation-tip{align-items:center;gap:var(--space-xs);margin:0 0 var(--space-sm);border:var(--rule-hair) solid var(--color-warning);border-radius:var(--radius-lg);background:var(--color-warning-soft);color:var(--color-warning);padding:var(--space-sm) var(--space-md);font-weight:800;line-height:var(--leading-snug);display:none}.fretboard-scroll{-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;scrollbar-gutter:stable;border:var(--rule-hair) solid var(--color-fretboard-line);border-radius:var(--radius-xl);background:linear-gradient(90deg, var(--color-paper), transparent 8rem), linear-gradient(180deg, var(--color-fretboard-2), var(--color-fretboard));overflow-x:auto}@supports (color:color-mix(in lab, red, red)){.fretboard-scroll{background:linear-gradient(90deg, color-mix(in oklch, var(--color-paper) 72%, transparent), transparent 8rem), linear-gradient(180deg, var(--color-fretboard-2), var(--color-fretboard))}}.fretboard-scroll{box-shadow:inset -1.4rem 0 1.6rem var(--color-shadow), inset 0 0 0 var(--rule-hair) var(--color-accent)}@supports (color:color-mix(in lab, red, red)){.fretboard-scroll{box-shadow:inset -1.4rem 0 1.6rem color-mix(in oklch, var(--color-shadow) 34%, transparent), inset 0 0 0 var(--rule-hair) color-mix(in oklch, var(--color-accent) 16%, transparent)}}.fretboard-scroll{scrollbar-color:var(--color-accent-soft) var(--color-paper-2)}.fretboard-grid{--fret-cell-size:3rem;grid-template-columns:4.3rem repeat(25, var(--fret-cell-size));grid-template-rows:2.05rem repeat(6, var(--fret-cell-size));width:max-content;min-width:100%;display:grid}.fretboard-corner,.fretboard-fret-label,.string-label{border-right:var(--rule-hair) solid var(--color-fretboard-line);border-bottom:var(--rule-hair) solid var(--color-fretboard-line);background:var(--color-paper-3);justify-content:center;align-items:center;display:flex}@supports (color:color-mix(in lab, red, red)){.fretboard-corner,.fretboard-fret-label,.string-label{background:color-mix(in oklch, var(--color-paper-3) 88%, var(--color-fretboard))}}.fretboard-corner,.fretboard-fret-label,.string-label{color:var(--color-ink-3);font-family:var(--font-mono);font-size:var(--text-xs);font-weight:700}.fretboard-corner{z-index:3;position:sticky;left:0}.string-label{gap:var(--space-xs);z-index:2;position:sticky;left:0}.string-label span{color:var(--color-string);font-size:var(--text-base)}.string-label small{color:var(--color-ink-3);font-size:var(--text-xs)}.fret-cell{--heat:0;width:var(--fret-cell-size);min-width:var(--fret-cell-size);height:var(--fret-cell-size);min-height:var(--fret-cell-size);touch-action:manipulation;border:0;border-right:var(--rule-hair) solid var(--color-fretboard-line);border-bottom:var(--rule-hair) solid var(--color-fretboard-line);background:var(--color-cell-heat);place-items:center;display:grid;position:relative}@supports (color:color-mix(in lab, red, red)){.fret-cell{background:color-mix(in oklch, var(--color-cell-heat) calc(var(--heat) * 74%), var(--color-cell))}}.fret-cell{color:var(--color-ink);cursor:pointer;transition:transform var(--dur-fast) var(--ease-out), background-color var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out)}.fret-cell:disabled{cursor:default}.fret-cell.is-inactive{background:var(--color-cell-inactive);color:var(--color-ink-3)}.fret-cell[data-active=true]{background:var(--color-cell-heat)}@supports (color:color-mix(in lab, red, red)){.fret-cell[data-active=true]{background:color-mix(in oklch, var(--color-cell-heat) calc(var(--heat) * 68%), var(--color-cell-active))}}.fret-cell[data-active=true]:hover:not(:disabled),.fret-cell[data-active=true]:focus-visible{z-index:1;outline:var(--rule-bold) solid var(--color-focus);outline-offset:calc(var(--rule-bold) * -1);background:var(--color-accent-soft);box-shadow:inset 0 0 0 var(--rule-bold) var(--color-accent)}.fret-cell[data-selected=true]{background:var(--color-warning-soft);color:var(--color-warning);box-shadow:inset 0 0 0 var(--rule-bold) var(--color-warning)}.fret-cell[data-correct=true]{background:var(--color-success-soft);color:var(--color-success);box-shadow:inset 0 0 0 var(--rule-bold) var(--color-success)}.fret-cell[data-target=true]{box-shadow:inset 0 0 0 var(--rule-bold) var(--color-violet), 0 0 1.5rem var(--color-violet)}@supports (color:color-mix(in lab, red, red)){.fret-cell[data-target=true]{box-shadow:inset 0 0 0 var(--rule-bold) var(--color-violet), 0 0 1.5rem color-mix(in oklch, var(--color-violet) 28%, transparent)}}.fret-cell[data-pitch=true] .fret-cell__marker{color:var(--color-accent)}.fret-cell__note{z-index:1;font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-weight:800;position:relative}.fret-cell__marker{right:var(--space-2xs);bottom:var(--space-2xs);color:var(--color-string);font-size:var(--text-sm);line-height:1;position:absolute}.answer-grid{gap:var(--space-sm);border:0;grid-template-columns:repeat(auto-fit,minmax(4.75rem,1fr));min-inline-size:0;margin:0;padding:0;display:grid}.answer-choice{min-height:3.15rem;font-family:var(--font-mono);font-size:var(--text-md);font-weight:800}.pace-card,.feedback-bar,.session-summary{justify-content:space-between;align-items:center;gap:var(--space-md);border:var(--rule-hair) solid var(--color-rule);border-radius:var(--radius-lg);background:var(--color-paper-3);padding:var(--space-md);display:flex}.feedback-bar[data-correct=true]{border-color:var(--color-success);background:var(--color-success-soft);color:var(--color-success)}.feedback-bar[data-correct=false]{border-color:var(--color-error);background:var(--color-error-soft);color:var(--color-error)}.feedback-bar svg,.summary-icon{flex:none;width:1.5rem;height:1.5rem}.feedback-bar span{flex:1;font-weight:900}.metric-grid{gap:var(--space-sm);grid-template-columns:repeat(3,minmax(0,1fr));display:grid}.setting-group{gap:var(--space-md);align-content:start;display:grid}.setting-row{border-top:var(--rule-hair) solid var(--color-rule);min-height:3.1rem;padding-top:var(--space-md)}.setting-row>*{min-width:0}.setting-row [data-slot=select-trigger]{min-width:min(12rem,100%);min-height:var(--tap-target)}.setting-row:first-of-type{border-top:0;padding-top:0}.setting-slider{max-width:14rem}.backup-panel{gap:var(--space-sm);display:grid}.backup-panel textarea{min-height:14rem;font-family:var(--font-mono);font-size:var(--text-sm)}.reset-panel{justify-content:space-between;align-items:center;gap:var(--space-md);border:var(--rule-hair) solid var(--color-rule);border-radius:var(--radius-lg);background:var(--color-paper-3);padding:var(--space-md);display:flex}.reset-panel__copy{gap:var(--space-sm);min-width:0;display:grid}.reset-actions{justify-content:flex-end;gap:var(--space-sm);flex-wrap:wrap;flex:none;display:flex}.reset-warning{margin:var(--space-sm) 0 0;color:var(--color-error);font-weight:900}.import-message{color:var(--color-success);margin:0;font-weight:900}.section-band--fretboard-map{overflow:hidden}.string-bars{gap:var(--space-sm);display:grid}.string-bar{gap:var(--space-sm);grid-template-columns:5.5rem minmax(0,1fr) 3rem;align-items:center;display:grid}.string-bar span,.string-bar strong{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:800}.string-bar div{border-radius:var(--radius-pill);background:var(--color-paper-4);height:.75rem;overflow:hidden}.string-bar i{border-radius:inherit;background:linear-gradient(90deg, var(--color-accent-2), var(--color-accent));height:100%;display:block}@media (width<=60rem){.app-chrome{width:min(100% - (var(--space-md) * 2), var(--page-max))}.app-header{border-radius:var(--radius-xl);grid-template-columns:minmax(0,1fr) auto}.app-header__status{display:none}.dashboard-hero,.page-heading,.two-column,.settings-grid,.backup-grid,.module-grid{grid-template-columns:1fr}.course-map .module-grid:before{display:none}.page-heading>p{justify-self:start}.lesson-heading,.lesson-toolbar,.pace-card,.feedback-bar{flex-direction:column;align-items:stretch}.metric-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (width<=40rem){.app-shell{min-height:100svh;display:block}.app-chrome{width:100%;margin:0}.app-header{margin:var(--space-sm) var(--space-sm) 0;padding:var(--space-xs) var(--space-xs) var(--space-xs) var(--space-sm)}.app-header .app-kicker{display:none}.brand-mark{width:2.25rem;height:2.25rem}.brand-mark__icon{width:1.72rem;height:1.72rem}.app-header h1{font-size:var(--text-md)}.sound-button{min-width:var(--tap-target);padding-inline:var(--space-sm)}.sound-button__label{text-overflow:ellipsis;white-space:nowrap;max-width:6.1rem;overflow:hidden}.app-nav{width:auto;margin:var(--space-xs) var(--space-sm) 0;border-radius:var(--radius-xl);padding:var(--space-2xs)}.app-nav__link{gap:var(--space-3xs);min-height:3.25rem;font-size:var(--text-xs);flex-direction:column}.app-main{width:min(100% - (var(--space-sm) * 2), var(--page-max));padding-top:var(--space-sm);padding-bottom:var(--space-xl)}.page-stack{gap:var(--space-sm)}.dashboard-hero,.section-band,.course-tier,.lesson-surface,.setting-group,.page-heading{border-radius:var(--radius-lg);padding:var(--space-md)}.dashboard-hero h2{font-size:var(--text-xl)}.page-heading h2{font-size:var(--text-lg)}.section-heading{align-items:stretch;gap:var(--space-xs);flex-direction:column}.section-heading p,.page-heading>p{font-size:var(--text-sm)}.module-card{padding:var(--space-md)}.module-card .button-row,.lesson-surface>.button-row{grid-template-columns:repeat(2,minmax(0,1fr));align-items:stretch;display:grid}.module-card .button-row [data-slot=button],.lesson-surface>.button-row [data-slot=button]{width:100%}.lesson-toolbar{gap:var(--space-sm)}.toolbar-actions{grid-template-columns:minmax(0,1fr) auto;width:100%;display:grid}.toolbar-actions [data-slot=button]{width:100%}.answer-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.answer-choice{min-height:3.25rem;font-size:var(--text-base)}.feedback-bar{bottom:calc(4.8rem + env(safe-area-inset-bottom));z-index:10;box-shadow:var(--shadow-nav);position:sticky}.feedback-bar [data-slot=button]{width:100%}.metric-grid{grid-template-columns:1fr}.fretboard-scroll{margin-inline:calc(var(--space-2xs) * -1);border-radius:var(--radius-lg)}.string-bar{gap:var(--space-xs);grid-template-columns:4.5rem minmax(0,1fr) 2.5rem}.setting-row{flex-direction:column;align-items:stretch}.setting-slider{max-width:none}.reset-panel{flex-direction:column;align-items:stretch}.reset-actions{grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.reset-actions [data-slot=button]{width:100%}.reset-actions [data-slot=button]:only-child{grid-column:1/-1}}@media (width<=56.25rem) and (orientation:portrait) and (hover:none) and (pointer:coarse),(width<=40rem) and (orientation:portrait){.fretboard-orientation-tip{display:flex}}@media (width<=32.5rem){.sound-button__label{display:none}.app-nav__link{font-size:.68rem}.module-card .button-row,.lesson-surface>.button-row{grid-template-columns:1fr}.fretboard-grid{--fret-cell-size:2.75rem;grid-template-columns:3.6rem repeat(25, var(--fret-cell-size))}}@media (height<=30rem) and (orientation:landscape){.app-chrome{align-items:center;gap:var(--space-xs);width:min(100% - var(--space-md), var(--page-max));margin-top:var(--space-xs);grid-template-columns:minmax(13rem,.5fr) minmax(0,1fr);position:static}.app-header{padding-block:var(--space-2xs);grid-template-columns:minmax(0,1fr) auto}.app-header .app-kicker,.sound-button__label{display:none}.app-nav{width:100%;position:static}.app-main{width:min(100% - var(--space-md), var(--page-max));padding-top:var(--space-xs);padding-bottom:var(--space-md)}.page-stack{gap:var(--space-xs)}.page-heading,.section-band{padding:var(--space-sm)}.lesson-heading{gap:var(--space-sm);grid-template-columns:minmax(0,1fr) auto;align-items:center}.lesson-heading h2{font-size:var(--text-md)}.lesson-workbench .section-band{display:none}.lesson-surface{gap:var(--space-sm);padding:var(--space-sm)}.lesson-toolbar h2{font-size:var(--text-md)}.lesson-surface--quiz .lesson-toolbar{order:1}.lesson-surface--quiz .fretboard-wrap{order:2}.lesson-surface--quiz .answer-grid,.lesson-surface--quiz .pace-card,.lesson-surface--quiz>.button-row{order:3}.lesson-surface--quiz .feedback-bar{order:4}.fretboard-grid{--fret-cell-size:2.75rem;grid-template-rows:1.7rem repeat(6, var(--fret-cell-size))}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:1ms!important;animation-duration:1ms!important;animation-iteration-count:1!important}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-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-outline-style{syntax:"*";inherits:false;initial-value:solid}@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}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@keyframes enter{0%{opacity:var(--tw-enter-opacity,1);transform:translate3d(var(--tw-enter-translate-x,0),var(--tw-enter-translate-y,0),0)scale3d(var(--tw-enter-scale,1),var(--tw-enter-scale,1),var(--tw-enter-scale,1))rotate(var(--tw-enter-rotate,0));filter:blur(var(--tw-enter-blur,0))}}@keyframes exit{to{opacity:var(--tw-exit-opacity,1);transform:translate3d(var(--tw-exit-translate-x,0),var(--tw-exit-translate-y,0),0)scale3d(var(--tw-exit-scale,1),var(--tw-exit-scale,1),var(--tw-exit-scale,1))rotate(var(--tw-exit-rotate,0));filter:blur(var(--tw-exit-blur,0))}}
