/*! 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-tracking: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:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-amber-100:oklch(96.2% .059 95.617);--color-amber-300:oklch(87.9% .169 91.605);--color-teal-200:oklch(91% .096 180.426);--color-teal-300:oklch(85.5% .138 181.071);--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-7xl:80rem;--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-xl:1.25rem;--text-xl--line-height:calc(1.75 / 1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2 / 1.5);--text-5xl:3rem;--text-5xl--line-height:1;--text-7xl:4.5rem;--text-7xl--line-height:1;--font-weight-medium:500;--font-weight-semibold:600;--radius-md:.375rem;--radius-lg:.5rem;--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)}}@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{.visible{visibility:visible}.fixed{position:fixed}.relative{position:relative}.static{position:static}.mx-auto{margin-inline:auto}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-3{margin-top:calc(var(--spacing) * 3)}.mt-4{margin-top:calc(var(--spacing) * 4)}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-flex{display:inline-flex}.table{display:table}.size-10{width:calc(var(--spacing) * 10);height:calc(var(--spacing) * 10)}.min-h-6{min-height:calc(var(--spacing) * 6)}.min-h-\[calc\(100vh-1\.5rem\)\]{min-height:calc(100vh - 1.5rem)}.min-h-screen{min-height:100vh}.max-w-7xl{max-width:var(--container-7xl)}.min-w-0{min-width:calc(var(--spacing) * 0)}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.grid-rows-\[auto_auto_1fr_auto\]{grid-template-rows:auto auto 1fr auto}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.place-items-center{place-items:center}.items-center{align-items:center}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.border{border-style:var(--tw-border-style);border-width:1px}.border-amber-300\/20{border-color:#ffd23633}@supports (color:color-mix(in lab, red, red)){.border-amber-300\/20{border-color:color-mix(in oklab, var(--color-amber-300) 20%, transparent)}}.border-white\/10{border-color:#ffffff1a}@supports (color:color-mix(in lab, red, red)){.border-white\/10{border-color:color-mix(in oklab, var(--color-white) 10%, transparent)}}.bg-\[var\(--color-bg\)\]{background-color:var(--color-bg)}.bg-\[var\(--color-panel\)\]{background-color:var(--color-panel)}.bg-amber-300\/10{background-color:#ffd2361a}@supports (color:color-mix(in lab, red, red)){.bg-amber-300\/10{background-color:color-mix(in oklab, var(--color-amber-300) 10%, transparent)}}.bg-black\/20{background-color:#0003}@supports (color:color-mix(in lab, red, red)){.bg-black\/20{background-color:color-mix(in oklab, var(--color-black) 20%, transparent)}}.bg-teal-300\/10{background-color:#46ecd51a}@supports (color:color-mix(in lab, red, red)){.bg-teal-300\/10{background-color:color-mix(in oklab, var(--color-teal-300) 10%, transparent)}}.bg-white\/5{background-color:#ffffff0d}@supports (color:color-mix(in lab, red, red)){.bg-white\/5{background-color:color-mix(in oklab, var(--color-white) 5%, transparent)}}.p-3{padding:calc(var(--spacing) * 3)}.p-4{padding:calc(var(--spacing) * 4)}.p-5{padding:calc(var(--spacing) * 5)}.p-6{padding:calc(var(--spacing) * 6)}.px-3{padding-inline:calc(var(--spacing) * 3)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-3{padding-block:calc(var(--spacing) * 3)}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-5xl{font-size:var(--text-5xl);line-height:var(--tw-leading,var(--text-5xl--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-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--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)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-\[0\.18em\]{--tw-tracking:.18em;letter-spacing:.18em}.text-\[var\(--color-accent\)\]{color:var(--color-accent)}.text-\[var\(--color-error\)\]{color:var(--color-error)}.text-\[var\(--color-muted\)\]{color:var(--color-muted)}.text-\[var\(--color-text\)\]{color:var(--color-text)}.text-amber-100{color:var(--color-amber-100)}.text-teal-200{color:var(--color-teal-200)}.uppercase{text-transform:uppercase}.shadow-2xl{--tw-shadow:0 25px 50px -12px var(--tw-shadow-color,#00000040);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-black\/20{--tw-shadow-color:#0003}@supports (color:color-mix(in lab, red, red)){.shadow-black\/20{--tw-shadow-color:color-mix(in oklab, color-mix(in oklab, var(--color-black) 20%, transparent) var(--tw-shadow-alpha), transparent)}}.blur{--tw-blur:blur(8px);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,)}.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))}@media (hover:hover){.hover\:bg-white\/10:hover{background-color:#ffffff1a}@supports (color:color-mix(in lab, red, red)){.hover\:bg-white\/10:hover{background-color:color-mix(in oklab, var(--color-white) 10%, transparent)}}}@media (width>=48rem){.md\:min-h-\[calc\(100vh-2\.5rem\)\]{min-height:calc(100vh - 2.5rem)}.md\:grid-cols-\[1fr_220px\]{grid-template-columns:1fr 220px}.md\:flex-row{flex-direction:row}.md\:items-center{align-items:center}.md\:justify-between{justify-content:space-between}.md\:px-6{padding-inline:calc(var(--spacing) * 6)}.md\:py-5{padding-block:calc(var(--spacing) * 5)}.md\:text-7xl{font-size:var(--text-7xl);line-height:var(--tw-leading,var(--text-7xl--line-height))}}}:root{--color-bg:#101214;--color-panel:#181c20;--color-panel-soft:#20262b;--color-text:#f3f5f1;--color-muted:#a7b0aa;--color-key-white:#f4efe4;--color-key-white-pressed:#8ee8dc;--color-key-black:#17191c;--color-key-black-pressed:#12b8aa;--color-accent:#f2b84b;--color-error:#d46666}*,:before,:after{box-sizing:border-box}body{background:var(--color-bg);min-width:320px;font-family:var(--font-sans);margin:0}button{font:inherit}.app-shell{min-height:100vh;color:var(--color-text);background:radial-gradient(circle at 20% 0,#f2b84b2e,#0000 30rem),linear-gradient(135deg,#101214 0%,#181c20 54%,#101214 100%);overflow-x:hidden}.app-workspace{gap:1.25rem;min-height:calc(100vh - 6.25rem);padding:1rem;display:grid}.app-workspace__readout{align-content:start;gap:1rem;display:grid}.progression-controls{flex-wrap:wrap;gap:.625rem;display:flex}.progression-controls__field{color:var(--color-muted);text-transform:uppercase;flex:8rem;gap:.25rem;font-size:.72rem;font-weight:700;display:grid}.progression-controls__field select{min-height:2.5rem;color:var(--color-text);font:inherit;text-transform:none;background:#f3f5f10f;border:1px solid #f3f5f121;border-radius:.5rem;padding:0 .75rem}.progression-mode-toggle{background:#f3f5f10f;border:1px solid #f3f5f121;border-radius:.5rem;width:fit-content;max-width:100%;display:inline-flex;overflow:hidden}.progression-mode-toggle button{min-height:2.5rem;color:var(--color-muted);cursor:pointer;background:0 0;border:0;padding:0 .875rem;font-size:.85rem;font-weight:750}.progression-mode-toggle button[aria-pressed=true]{color:var(--color-text);background:#f2b84b29}.status-bar{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#101214c7;border-bottom:1px solid #f3f5f114;gap:.875rem;padding:1rem;display:grid}.status-bar__brand{align-items:center;gap:.75rem;min-width:0;display:flex}.status-bar__brand-icon{width:2.5rem;height:2.5rem;color:var(--color-accent);background:#f2b84b21;border:1px solid #f2b84b59;border-radius:.5rem;flex:none;place-items:center;display:grid}.status-bar__title,.status-bar__subtitle,.chord-readout__label,.chord-readout__heading,.chord-readout__notes,.chord-readout__pitch-classes,.progression-trail__label,.progression-trail__empty,.progression-compass__label,.progression-compass__heading,.progression-compass__empty,.progression-practice__label,.progression-practice__heading,.progression-practice__empty,.progression-practice__complete{margin:0}.status-bar__title{font-size:1.05rem;font-weight:750;line-height:1.1}.status-bar__subtitle{color:var(--color-muted);margin-top:.15rem;font-size:.85rem}.status-bar__controls{flex-wrap:wrap;gap:.625rem;display:flex}.status-bar__segmented{min-height:2.5rem;color:var(--color-muted);background:#f3f5f10f;border:1px solid #f3f5f121;border-radius:.5rem;align-items:center;gap:.25rem;padding:.25rem;display:inline-flex}.status-bar__segmented>svg{margin-inline:.5rem .25rem}.status-bar__segment{min-height:1.875rem;color:var(--color-muted);cursor:pointer;background:0 0;border:0;border-radius:.375rem;padding:0 .65rem;font-size:.9rem;font-weight:750}.status-bar__segment[aria-pressed=true]{color:var(--color-text);background:#f2b84b2e}.status-bar__segment:hover{color:var(--color-text)}.status-bar__button{min-width:0;min-height:2.5rem;color:var(--color-text);cursor:pointer;background:#f3f5f10f;border:1px solid #f3f5f121;border-radius:.5rem;justify-content:center;align-items:center;gap:.5rem;padding:0 .875rem;display:inline-flex}.status-bar__button:disabled{cursor:wait;opacity:.65}.status-bar__button:not(:disabled):hover{background:#f2b84b1f;border-color:#f2b84b73}.status-bar__message{color:var(--color-muted);margin:0;font-size:.85rem}.status-bar__message--error{color:var(--color-error)}.chord-readout,.progression-trail{background:#181c20db;border:1px solid #f3f5f11a;border-radius:.5rem;box-shadow:0 1.5rem 4rem #0000003d}.chord-readout{gap:1rem;padding:1rem;display:grid}.chord-readout__primary{min-width:0}.chord-readout__label,.progression-trail__label{color:var(--color-muted);letter-spacing:0;text-transform:uppercase;font-size:.72rem;font-weight:700}.chord-readout__heading{margin-top:.45rem;font-size:clamp(2.5rem,16vw,5.5rem);font-weight:800;line-height:.92}.chord-readout__notes{color:var(--color-text);margin-top:.75rem;font-size:1rem;font-weight:700}.chord-readout__pitch-classes{color:var(--color-muted);margin-top:.45rem;font-size:.9rem}.chord-readout__alternates{border-top:1px solid #f3f5f11a;min-width:0;padding-top:1rem}.chord-readout__alternate-list,.progression-trail__list{flex-wrap:wrap;gap:.5rem;margin:.75rem 0 0;padding:0;list-style:none;display:flex}.chord-readout__alternate,.progression-trail__entry{color:var(--color-text);background:#f3f5f10f;border:1px solid #f3f5f121;border-radius:.5rem;padding:.45rem .65rem;font-size:.9rem;font-weight:700}.chord-readout__empty,.progression-trail__empty{color:var(--color-muted);margin-top:.75rem}.progression-trail{padding:1rem}.progression-compass{background:#181c20db;border:1px solid #f3f5f11a;border-radius:.5rem;padding:1rem;box-shadow:0 1.5rem 4rem #0003}.progression-compass__header{justify-content:space-between;align-items:start;gap:1rem;display:flex}.progression-compass__label{color:var(--color-muted);letter-spacing:0;text-transform:uppercase;font-size:.72rem;font-weight:700}.progression-compass__heading{margin-top:.35rem;font-size:1.35rem;line-height:1.1}.progression-compass__suggestions{gap:.625rem;margin-top:.875rem;display:grid}.progression-compass__card{width:100%;color:var(--color-text);cursor:pointer;text-align:left;background:#f3f5f10f;border:1px solid #f3f5f121;border-radius:.5rem;gap:.35rem;padding:.75rem;display:grid}.progression-compass__card:hover,.progression-compass__card[data-selected=true]{background:#f2b84b21;border-color:#f2b84b8c}.progression-compass__card[data-matched=true]{background:#8ee8dc29;border-color:#8ee8dcc7}.progression-compass__card-title{font-size:1rem;font-weight:800}.progression-compass__meta,.progression-compass__keys,.progression-compass__reason,.progression-compass__empty{color:var(--color-muted);font-size:.86rem}.progression-compass__keys{color:var(--color-text);font-weight:750}.progression-practice{background:#181c20db;border:1px solid #f3f5f11a;border-radius:.5rem;gap:1rem;padding:1rem;display:grid;box-shadow:0 1.5rem 4rem #0003}.progression-practice__browser,.progression-practice__rail{min-width:0}.progression-practice__rail{border-top:1px solid #f3f5f11a;padding-top:1rem}.progression-practice__header{justify-content:space-between;align-items:start;gap:1rem;display:flex}.progression-practice__label{color:var(--color-muted);letter-spacing:0;text-transform:uppercase;font-size:.72rem;font-weight:700}.progression-practice__heading{margin-top:.35rem;font-size:1.35rem;line-height:1.1}.progression-practice__cards,.progression-practice__steps{gap:.625rem;margin-top:.875rem;display:grid}.progression-practice__steps{padding:0;list-style:none}.progression-practice__card,.progression-practice__step{width:100%;color:var(--color-text);cursor:pointer;text-align:left;background:#f3f5f10f;border:1px solid #f3f5f121;border-radius:.5rem}.progression-practice__card{gap:.35rem;padding:.75rem;display:grid}.progression-practice__step{align-items:center;gap:.75rem;padding:.65rem .75rem;display:flex}.progression-practice__card:hover,.progression-practice__step:hover,.progression-practice__card[data-selected=true],.progression-practice__step[data-active=true]{background:#f2b84b21;border-color:#f2b84b8c}.progression-practice__step[data-matched=true]{background:#8ee8dc29;border-color:#8ee8dcc7}.progression-practice__card-title,.progression-practice__step-name{font-size:1rem;font-weight:800}.progression-practice__sequence,.progression-practice__description,.progression-practice__keys,.progression-practice__empty{color:var(--color-muted);font-size:.86rem}.progression-practice__sequence,.progression-practice__description,.progression-practice__keys{overflow-wrap:anywhere}.progression-practice__sequence,.progression-practice__keys{color:var(--color-text);font-weight:750}.progression-practice__step-number{width:2rem;height:2rem;color:var(--color-text);background:#f3f5f11a;border-radius:999px;flex:none;place-items:center;font-size:.85rem;font-weight:800;display:grid}.progression-practice__step-body{flex:auto;gap:.2rem;min-width:0;display:grid}.progression-practice__matched{color:var(--color-key-white-pressed);text-transform:uppercase;background:#8ee8dc29;border-radius:999px;flex:none;padding:.18rem .45rem;font-size:.72rem;font-weight:800}.progression-practice__complete{color:var(--color-key-white-pressed);margin-top:.75rem;font-size:.86rem;font-weight:800}.progression-practice__empty{margin-top:.875rem}.app-workspace div[role=tablist][aria-label=Learning\ workspace],.workspace-tabs{background:#f3f5f10f;border:1px solid #f3f5f121;border-radius:.5rem;width:fit-content;max-width:100%;display:inline-flex;overflow:hidden}.app-workspace div[role=tablist][aria-label=Learning\ workspace] button,.workspace-tabs__tab{min-width:0;min-height:2.5rem;color:var(--color-muted);cursor:pointer;overflow-wrap:anywhere;background:0 0;border:0;padding:0 .875rem;font-size:.85rem;font-weight:750}.app-workspace div[role=tablist][aria-label=Learning\ workspace] button[aria-selected=true],.workspace-tabs__tab[aria-selected=true]{color:var(--color-text);background:#f2b84b29}.app-workspace div[role=tablist][aria-label=Learning\ workspace] button:hover,.workspace-tabs__tab:hover{color:var(--color-text)}.chord-construction{gap:1rem;min-width:0;display:grid}.chord-construction__controls{flex-wrap:wrap;align-items:end;gap:.625rem;min-width:0;display:flex}.chord-construction__controls label{min-width:0;color:var(--color-muted);text-transform:uppercase;flex:8rem;gap:.25rem;font-size:.72rem;font-weight:700;display:grid}.chord-construction__controls select{min-width:0;min-height:2.5rem;color:var(--color-text);font:inherit;text-transform:none;background:#f3f5f10f;border:1px solid #f3f5f121;border-radius:.5rem;padding:0 .75rem}.chord-construction__scale{color:var(--color-muted);overflow-wrap:anywhere;flex:999 12rem;margin:0;font-size:.9rem;font-weight:750}.chord-type-list,.chord-type-detail,.chord-detail,.chord-example-list,.chord-examples{background:#181c20db;border:1px solid #f3f5f11a;border-radius:.5rem;min-width:0;padding:1rem;box-shadow:0 1.5rem 4rem #0003}.chord-type-list{gap:1rem;display:grid}.chord-type-list__family+.chord-type-list__family{margin-top:0}.chord-type-list__family-heading,.chord-type-list__heading,.chord-type-detail__scale,.chord-detail__label,.chord-example-list__heading,.chord-examples__heading{color:var(--color-muted);letter-spacing:0;text-transform:uppercase;margin:0;font-size:.72rem;font-weight:700}.chord-type-list__buttons,.chord-type-list__items,.chord-example-list__buttons,.chord-examples__grid{gap:.5rem;min-width:0;margin-top:.625rem;display:grid}.chord-type-list__button,.chord-example-list__button,.chord-examples__button{width:100%;min-width:0;color:var(--color-text);cursor:pointer;text-align:left;background:#f3f5f10f;border:1px solid #f3f5f121;border-radius:.5rem;justify-content:space-between;align-items:center;gap:.75rem;padding:.65rem .75rem;display:flex}.chord-type-list__button:hover,.chord-type-list__button[data-selected=true],.chord-example-list__button:hover,.chord-example-list__button[data-selected=true],.chord-examples__button:hover,.chord-examples__button[data-selected=true]{background:#f2b84b21;border-color:#f2b84b8c}.chord-type-list__name,.chord-type-detail__facts dd,.chord-detail__facts dd,.chord-example-list__name,.chord-examples__button span:first-child{overflow-wrap:anywhere;min-width:0;font-weight:800}.chord-type-list__symbol,.chord-example-list__notes,.chord-examples__button span:last-child,.chord-example-list__empty,.chord-examples__empty{min-width:0;color:var(--color-muted);overflow-wrap:anywhere;text-align:right;flex:0 auto;font-size:.86rem}.chord-type-detail,.chord-detail{gap:1rem;display:grid}.chord-type-detail__header,.chord-detail__header{justify-content:space-between;align-items:start;gap:1rem;min-width:0;display:flex}.chord-type-detail__header>div,.chord-detail__header>div{min-width:0}.chord-type-detail__heading,.chord-type-detail__name,.chord-type-detail__section h3,.chord-type-detail__section p,.chord-type-detail__facts,.chord-type-detail__facts dd,.chord-detail__heading,.chord-detail__symbol,.chord-detail__section h3,.chord-detail__section p,.chord-detail__facts,.chord-detail__facts dd,.chord-example-list__empty,.chord-examples__empty{margin:0}.chord-type-detail__heading,.chord-detail__heading{overflow-wrap:anywhere;margin-top:.35rem;font-size:1.6rem;line-height:1.1}.chord-type-detail__name,.chord-detail__symbol{color:var(--color-accent);overflow-wrap:anywhere;margin-top:.35rem;font-size:1.05rem;font-weight:800}.chord-type-detail__match,.chord-detail__match{color:var(--color-muted);text-align:center;text-transform:uppercase;background:#f3f5f114;border-radius:999px;flex:0 auto;padding:.25rem .55rem;font-size:.72rem;font-weight:800}.chord-type-detail__match[data-matched=true],.chord-detail__match[data-matched=true]{color:var(--color-key-white-pressed);background:#8ee8dc29}.chord-type-detail__facts,.chord-detail__facts{gap:.625rem;display:grid}.chord-type-detail__facts div,.chord-detail__facts div{gap:.25rem;min-width:0;display:grid}.chord-type-detail__facts dt,.chord-type-detail__section h3,.chord-detail__facts dt,.chord-detail__section h3{color:var(--color-muted);letter-spacing:0;text-transform:uppercase;font-size:.72rem;font-weight:700}.chord-type-detail__section,.chord-detail__section{gap:.35rem;min-width:0;display:grid}.chord-type-detail__section p,.chord-detail__section p,.chord-detail__examples{color:var(--color-muted);overflow-wrap:anywhere;font-size:.92rem;line-height:1.45}.chord-detail__examples{flex-wrap:wrap;gap:.5rem;padding:0;list-style:none;display:flex}.chord-detail__examples li{color:var(--color-text);overflow-wrap:anywhere;background:#f3f5f10f;border:1px solid #f3f5f121;border-radius:.5rem;padding:.4rem .55rem;font-weight:750}.chord-example-list,.chord-examples{gap:1rem;display:grid}.piano-shell{background:linear-gradient(#20262b 0%,#111315 100%);border:1px solid #f3f5f11a;border-radius:.5rem;align-self:end;padding:.625rem;box-shadow:0 1.75rem 4.5rem #0000005c}.piano-keyboard{width:100%;min-width:0;height:clamp(15rem,42vh,25rem);position:relative}.piano-keyboard__white-keys{grid-template-columns:repeat(var(--white-key-count), minmax(0, 1fr));height:100%;display:grid}.piano-keyboard__black-keys{pointer-events:none;position:absolute;inset:0}.piano-key{touch-action:none;-webkit-user-select:none;user-select:none;border:0;border-radius:0 0 .45rem .45rem;justify-content:center;align-items:flex-end;padding:0 .25rem .85rem;display:flex;position:relative}.piano-key:focus-visible{z-index:4;outline:3px solid var(--color-accent);outline-offset:-3px}.piano-key--white{background:linear-gradient(180deg, #fffaf0 0%, var(--color-key-white) 100%);color:#303336;border-right:1px solid #10121438;height:100%}.piano-key--white:first-child{border-radius:.45rem 0 0 .45rem}.piano-key--white:last-child{border-radius:0 .45rem .45rem 0}.piano-key--white[data-active=true]{background:linear-gradient(180deg, #c8fff7 0%, var(--color-key-white-pressed) 100%)}.piano-key--white[data-hinted=true]{box-shadow:inset 0 0 0 3px #f2b84bb8}.piano-key--black{z-index:3;pointer-events:auto;background:linear-gradient(180deg, #2a2d31 0%, var(--color-key-black) 100%);color:#f3f5f1;height:62%;position:absolute;top:0;box-shadow:0 .75rem 1.25rem #00000075}.piano-key--black[data-active=true]{background:linear-gradient(180deg, #2ed8ca 0%, var(--color-key-black-pressed) 100%);color:#061312}.piano-key--black[data-hinted=true]{box-shadow:inset 0 0 0 2px #f2b84bd1,0 .75rem 1.25rem #00000075}.piano-key__label{opacity:.72;text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:.72rem;font-weight:800;line-height:1;overflow:hidden}@media (width>=58rem){.chord-construction{grid-template-columns:minmax(13rem,.8fr) minmax(0,1.6fr);align-items:start}.chord-construction__controls{grid-column:1/-1}.chord-type-list{grid-row:span 2;max-height:calc(100vh - 11rem);overflow-y:auto}.progression-practice{grid-template-columns:minmax(0,1.1fr) minmax(18rem,.9fr)}.progression-practice__rail{border-top:0;border-left:1px solid #f3f5f11a;padding-top:0;padding-left:1rem}}@media (width>=768px){.app-workspace{grid-template-rows:auto minmax(20rem,1fr);padding:1.25rem}.app-workspace__readout{grid-template-columns:minmax(0,1fr)}.status-bar{grid-template-columns:minmax(0,1fr) auto;align-items:center;padding:1rem 1.25rem}.status-bar__message{grid-column:1/-1}.chord-readout{grid-template-columns:minmax(0,1fr) minmax(13rem,.38fr);align-items:stretch}.chord-readout__alternates{border-top:0;border-left:1px solid #f3f5f11a;padding-top:0;padding-left:1rem}.progression-compass__suggestions{grid-template-columns:repeat(3,minmax(0,1fr))}.piano-shell{overflow-x:hidden}.piano-keyboard{min-width:0}}@media (width<=767px){.app-workspace{grid-template-rows:auto minmax(15rem,1fr)}.status-bar__button{flex:calc(50% - .3125rem);padding-inline:.5rem}.status-bar__segmented{flex:100%}.status-bar__segment{flex:1 1 0}.progression-compass__suggestions{scroll-snap-type:x proximity;padding-bottom:.25rem;display:flex;overflow-x:auto}.progression-compass__card{scroll-snap-align:start;flex:0 0 min(17rem,82vw)}.piano-shell{border-left:0;border-right:0;border-radius:0;align-self:start;margin-inline:-1rem;overflow-x:auto}.piano-keyboard{height:clamp(13rem,34vh,16rem)}.piano-key{padding-inline:.1rem;padding-bottom:.65rem}.piano-key__label{text-overflow:clip;font-size:.58rem}}@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-tracking{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}
