.app{max-width:1080px;margin:0 auto;padding:clamp(1.25rem,4vw,2.75rem) clamp(1rem,4vw,2rem) 5rem}.app-header{margin-bottom:1.75rem}.app-title-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.wordmark{display:flex;align-items:center;gap:.6rem;margin:0}.wordmark-mark{font-family:var(--font-display);font-size:2.4rem;line-height:1;color:var(--brass);text-shadow:0 0 22px rgba(224,167,62,.35)}.wordmark-text{font-family:var(--font-display);font-weight:600;font-size:clamp(1.5rem,4.5vw,2.3rem);letter-spacing:-.015em}.tagline{margin:.6rem 0 0;max-width:52ch;color:var(--muted);font-size:var(--step-0)}.app-main{display:flex;flex-direction:column;gap:1.5rem}.chart{display:flex;flex-direction:column;gap:1.1rem;background:linear-gradient(180deg,var(--panel) 0%,var(--bg-2) 100%);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(1rem,3vw,1.5rem);box-shadow:var(--shadow)}.chart-controls{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.9rem 1.5rem;padding-top:.25rem;border-top:1px solid var(--line)}.stage{display:flex;flex-direction:column;align-items:center;gap:1rem}.stage-controls{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:.75rem 1.25rem}.chord-stamp{display:flex;flex-direction:column;align-items:center;gap:.1rem;text-align:center}.chord-stamp-symbol{font-family:var(--font-display);font-weight:600;font-size:var(--step-4);line-height:1;color:var(--brass-soft);text-shadow:0 0 30px rgba(224,167,62,.25)}.chord-stamp-function{font-family:var(--font-mono);font-size:var(--step--1);letter-spacing:.12em;text-transform:lowercase;color:var(--muted)}.chord-stamp-play{display:flex;align-items:center;gap:.6rem;margin-top:.5rem}.audio-loading{font-size:var(--step--1);color:var(--brass-soft);font-style:italic}.builder{display:flex;flex-direction:column;gap:.9rem}.builder-tabs{display:flex;gap:.25rem;border-bottom:1px solid var(--line)}.builder-tab{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;padding:.5rem .9rem;font:inherit;font-size:var(--step--1);font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);cursor:pointer;transition:color .14s,border-color .14s}.builder-tab:hover{color:var(--ink)}.builder-tab.is-active{color:var(--brass);border-bottom-color:var(--brass)}.builder-timeline{display:flex;flex-wrap:wrap;gap:.5rem}.builder-hint{margin:0;font-size:var(--step--1);color:var(--muted)}.tl-chip-wrap{display:inline-flex;align-items:center;gap:.2rem}.tl-chip{font-family:var(--font-mono);font-size:1.02rem;font-weight:500;padding:.45rem .9rem;min-height:2.6rem;border:1px solid var(--line);border-radius:999px;background:var(--panel);color:var(--ink);cursor:grab;transition:background .14s,border-color .14s,color .14s,transform .05s}.tl-chip:hover{border-color:var(--brass)}.tl-chip:active{transform:translateY(1px)}.tl-chip.is-selected{background:var(--brass);border-color:var(--brass);color:#1c1208;font-weight:700;box-shadow:0 0 22px -6px #e0a73e99}.tl-chip.is-error{border-style:dashed;border-color:#b9606f;color:#f0a6b2;background:#b9606f1f}.tl-chip.is-swapped:not(.is-selected){border-color:var(--brass);box-shadow:inset 0 0 0 1px var(--brass-deep)}.tl-revert,.tl-remove{display:inline-flex;align-items:center;justify-content:center;width:1.7rem;height:1.7rem;padding:0;font-size:1rem;line-height:1;border:1px solid var(--brass-deep);border-radius:50%;background:transparent;color:var(--brass-soft);cursor:pointer;transition:background .14s,color .14s,border-color .14s}.tl-remove{border-color:var(--line);color:var(--muted)}.tl-revert:hover{background:var(--brass);color:#1c1208}.tl-remove:hover{border-color:#b9606f;color:#f0a6b2}.builder-build{display:flex;flex-direction:column;gap:.9rem}.builder-entry{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.builder-input{flex:1 1 16rem;font-family:var(--font-mono);font-size:1.05rem;padding:.65rem .85rem;border:1px solid var(--line);border-radius:var(--r);background:#00000038;color:var(--ink)}.builder-input::placeholder{color:#5e7c7a}.builder-input:focus{outline:2px solid var(--brass);outline-offset:1px;border-color:var(--brass)}.builder-btn{font:inherit;font-weight:600;padding:.6rem 1rem;min-height:2.7rem;border:1px solid var(--brass);border-radius:var(--r);background:var(--brass);color:#1c1208;cursor:pointer;transition:background .14s,transform .05s}.builder-btn:hover{background:var(--brass-soft)}.builder-btn:active{transform:translateY(1px)}.builder-btn--ghost{background:transparent;color:var(--brass-soft)}.builder-btn--ghost:hover{background:#e0a73e1f}.builder-error{margin:0;font-size:var(--step--1);color:#f0a6b2}.palette{display:flex;flex-direction:column;gap:.55rem}.palette-row{display:flex;align-items:flex-start;gap:.75rem}.palette-label{flex:0 0 5rem;padding-top:.5rem;font-size:var(--step--1);font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--brass-soft)}.palette-chips{display:flex;flex-wrap:wrap;gap:.4rem}.palette-chip{display:inline-flex;flex-direction:column;align-items:center;gap:.05rem;min-width:3.4rem;padding:.4rem .7rem;border:1px solid var(--line);border-radius:10px;background:#0000002e;color:var(--ink);cursor:pointer;transition:border-color .14s,background .14s,transform .05s}.palette-chip:hover{border-color:var(--brass);background:#e0a73e1a}.palette-chip:active{transform:translateY(1px)}.palette-symbol{font-family:var(--font-mono);font-size:.98rem;font-weight:600}.palette-numeral{font-size:.72rem;font-style:italic;color:var(--muted)}.builder-genres{display:flex;flex-direction:column;gap:.7rem}.genre-selects{display:flex;flex-wrap:wrap;gap:.6rem}.genre-field{display:flex;flex-direction:column;gap:.3rem;font-size:var(--step--1);font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}.genre-field--wide{flex:1 1 16rem}.genre-field select{font:inherit;font-size:1rem;text-transform:none;letter-spacing:normal;font-weight:500;padding:.6rem .7rem;min-height:2.7rem;border:1px solid var(--line);border-radius:var(--r);background:#00000038;color:var(--ink);cursor:pointer}.genre-field select:focus{outline:2px solid var(--brass);outline-offset:1px;border-color:var(--brass)}.genre-desc{margin:0;font-size:.9rem;line-height:1.5;color:var(--muted)}@media(max-width:540px){.palette-row{flex-direction:column;gap:.3rem}.palette-label{padding-top:0}.genre-field{width:100%}}.key-context{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;font-size:.95rem}.key-context-label{color:var(--muted);font-weight:600;font-size:var(--step--1);letter-spacing:.04em;text-transform:uppercase}.key-select{font:inherit;padding:.4rem .55rem;border:1px solid var(--line);border-radius:var(--r-sm);background:#00000038;color:var(--ink);min-height:2.4rem}.key-select:focus{outline:2px solid var(--brass);outline-offset:1px;border-color:var(--brass)}.key-context-hint{color:var(--muted);font-size:var(--step--1);font-style:italic}.key-context-auto{font:inherit;font-size:var(--step--1);font-weight:600;padding:.35rem .75rem;border:1px solid var(--brass-deep);border-radius:999px;background:transparent;color:var(--brass-soft);cursor:pointer}.key-context-auto:hover{background:#e0a73e1f;border-color:var(--brass)}.voicing-selector{display:inline-flex;flex-wrap:wrap;gap:2px;padding:3px;background:#00000040;border:1px solid var(--line);border-radius:12px}.voicing-option{font:inherit;font-size:.9rem;font-weight:600;padding:.45rem .85rem;min-height:2.35rem;border:none;border-radius:9px;background:transparent;color:var(--muted);cursor:pointer;transition:background .14s,color .14s}.voicing-option:hover{color:var(--ink)}.voicing-option-active{background:var(--brass);color:#1c1208;box-shadow:0 0 18px -6px #e0a73e8c}.grand-staff{display:inline-block;background:var(--paper);border:1px solid #e3ddc8;border-radius:var(--r);padding:8px 12px;min-width:240px;max-width:100%;overflow-x:auto;box-shadow:var(--shadow-paper)}.grand-staff svg{display:block}.keyboard-scroll{overflow-x:auto;overflow-y:hidden;padding:10px 0;width:100%;-webkit-overflow-scrolling:touch}.keyboard{position:relative;margin:0 auto;-webkit-user-select:none;user-select:none}.key{position:absolute;top:0;padding:0;margin:0;border:1px solid #b9c3c0;box-sizing:border-box;cursor:pointer;display:flex;align-items:flex-end;justify-content:center}.key--white{background:#f3f1ea;border-radius:0 0 4px 4px;z-index:1}.key--white:hover{background:#fbf3df}.key--black{background:#1a2c2d;border-radius:0 0 3px 3px;z-index:2}.key--black:hover{filter:brightness(1.4)}.key--on.key--white{background:var(--brass-soft)}.key--on.key--black{background:var(--brass-deep)}.key--root.key--white,.key--root.key--black{background:var(--brass)}.key__root-dot{width:8px;height:8px;margin-bottom:7px;border-radius:50%;background:#1c1208;box-shadow:0 0 0 2px #ffffffbf}.key--black .key__root-dot{margin-bottom:5px}.key__octave{position:absolute;bottom:3px;left:0;right:0;text-align:center;font-family:var(--font-mono);font-size:8px;line-height:1;color:#8a948f;pointer-events:none}.key__octave--mid{color:var(--brass-deep);font-weight:700;font-size:9px}.key--middle-c.key--white{box-shadow:inset 2px 0 0 var(--brass)}.sub-list{display:flex;flex-direction:column;gap:1.1rem}.sub-list-heading{font-size:var(--step-2);font-weight:600;margin:0}.sub-list-empty{margin:0;color:var(--muted)}.sub-group{display:flex;flex-direction:column;gap:.65rem}.sub-group-heading{font-family:var(--font-ui);font-size:var(--step--1);font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--brass);margin:0;padding-bottom:.3rem;border-bottom:1px solid var(--line)}.sub-list-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:.85rem}.sub-card{border:1px solid var(--line);border-radius:var(--r);background:linear-gradient(180deg,var(--panel) 0%,var(--bg-2) 100%);padding:.95rem 1.05rem;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:.55rem;transition:border-color .14s,transform .08s}.sub-card:hover{border-color:var(--brass-deep);transform:translateY(-1px)}.sub-card-head{display:flex;align-items:baseline;gap:.6rem;flex-wrap:wrap}.sub-card-symbol{font-family:var(--font-display);font-size:1.5rem;font-weight:600;color:var(--brass-soft)}.sub-card-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--brass);border:1px solid var(--brass-deep);padding:.15rem .5rem;border-radius:999px}.sub-card-actions{display:flex;align-items:center;gap:.4rem;margin-left:auto}.sub-card-ab,.sub-card-use{font-family:var(--font-ui);font-size:.74rem;font-weight:700;letter-spacing:.04em;padding:.3rem .6rem;min-height:2.1rem;border:1px solid var(--brass-deep);border-radius:999px;background:transparent;color:var(--brass-soft);cursor:pointer;transition:background .14s,color .14s}.sub-card-ab:hover{background:var(--brass);color:#1c1208}.sub-card-use{background:var(--brass);color:#1c1208;border-color:var(--brass)}.sub-card-use:hover{background:var(--brass-soft)}.sub-card-explanation{margin:0;font-size:.92rem;line-height:1.45;color:var(--muted)}.sub-card .keyboard-scroll{padding:6px;background:var(--paper);border-radius:var(--r-sm)}.play-btn{display:inline-flex;align-items:center;justify-content:center;width:2.1rem;height:2.1rem;padding:0;border:1px solid var(--brass-deep);border-radius:50%;background:#e0a73e1f;color:var(--brass-soft);cursor:pointer;flex:none;transition:background .14s,transform .06s,color .14s}.play-btn svg{margin-left:1px}.play-btn:hover{background:var(--brass);color:#1c1208}.play-btn:active{transform:scale(.94)}.help{position:relative;display:inline-flex}.help-btn{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;font-family:var(--font-display, Georgia, serif);font-size:1.15rem;font-weight:700;line-height:1;border:1.5px solid var(--brass-deep);border-radius:50%;background:transparent;color:var(--brass-soft);cursor:pointer;transition:background .14s,color .14s,border-color .14s}.help-btn:hover,.help-btn[aria-expanded=true]{background:var(--brass);border-color:var(--brass);color:#1c1208}.help-pop{position:absolute;top:calc(100% + .6rem);right:0;z-index:40;width:min(92vw,30rem);max-height:min(72vh,34rem);overflow-y:auto;padding:1.1rem 1.2rem 1.25rem;border:1px solid var(--line);border-radius:14px;background:var(--panel);color:var(--ink);box-shadow:0 18px 48px -16px #000000b3;text-align:left}.help-section+.help-section{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--line)}.help-section h3{margin:0 0 .5rem;font-size:var(--step--1);font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--brass-soft)}.help-steps{margin:0;padding-left:1.2rem;display:flex;flex-direction:column;gap:.45rem;font-size:.92rem;line-height:1.45}.help-steps strong{color:var(--brass-soft);font-weight:600}.help-platforms{margin:0;padding-left:1.1rem;display:flex;flex-direction:column;gap:.4rem;font-size:.92rem;line-height:1.45}.help-kbd{display:inline-block;padding:.05rem .4rem;font-size:.85em;border:1px solid var(--line);border-radius:6px;background:#0003}.help-install-btn{font:inherit;font-weight:600;padding:.6rem 1rem;border:1px solid var(--brass);border-radius:var(--r);background:var(--brass);color:#1c1208;cursor:pointer}.help-install-btn:hover{background:var(--brass-soft)}.help-note,.help-installed{margin:.5rem 0 0;font-size:.86rem;color:var(--muted)}.legend{border:1px solid var(--line);border-radius:var(--r);background:var(--bg-2)}.legend-summary{cursor:pointer;padding:.85rem 1.1rem;font-weight:600;color:var(--ink);list-style:none;display:flex;align-items:center;gap:.5rem}.legend-summary::-webkit-details-marker{display:none}.legend-summary:before{content:"+";color:var(--brass);font-weight:700;font-size:1.1rem;width:1ch}.legend[open] .legend-summary:before{content:"–"}.legend-body{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem;padding:.25rem 1.1rem 1.25rem}.legend-col-title{font-size:var(--step--1);text-transform:uppercase;letter-spacing:.08em;color:var(--brass);margin:0 0 .6rem}.legend-dl{margin:0}.legend-row{margin-bottom:.7rem}.legend-row dt{font-weight:700;color:var(--ink);font-size:.95rem}.legend-row dd{margin:.1rem 0 0;color:var(--muted);font-size:.9rem;line-height:1.45}.transport{display:inline-flex;align-items:center;gap:.5rem;font:inherit;font-weight:600;font-size:.95rem;padding:.5rem 1.1rem;min-height:2.6rem;border:1px solid var(--brass-deep);border-radius:999px;background:#e0a73e1f;color:var(--brass-soft);cursor:pointer;transition:background .14s,color .14s,transform .06s}.transport:hover{background:var(--brass);color:#1c1208}.transport:active{transform:translateY(1px)}.transport-playing{background:var(--brass);color:#1c1208}.export-bar{display:inline-flex;align-items:center;gap:.5rem;flex-wrap:wrap}.export-label{font-size:var(--step--1);font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}.export-btn{font:inherit;font-size:.92rem;font-weight:600;padding:.5rem .9rem;min-height:2.5rem;border:1px solid var(--brass-deep);border-radius:999px;background:transparent;color:var(--brass-soft);cursor:pointer;transition:background .14s,color .14s,border-color .14s,transform .05s}.export-btn:hover:not(:disabled){background:var(--brass);border-color:var(--brass);color:#1c1208}.export-btn:active:not(:disabled){transform:translateY(1px)}.export-btn:disabled{opacity:.45;cursor:not-allowed}:root{--bg: #0c2426;--bg-2: #0f2e30;--panel: #123a3c;--panel-2: #16484b;--paper: #f6f2e8;--paper-ink: #143230;--paper-muted: #5c706e;--ink: #eef3f1;--muted: #93acaa;--line: #1f4a4d;--brass: #e0a73e;--brass-soft: #f0cd84;--brass-deep: #a9781f;--staff-label: #143230;--staff-accent: #a9781f;--font-display: "Fraunces", Georgia, "Times New Roman", serif;--font-ui: "Hanken Grotesk", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--font-mono: ui-monospace, "SF Mono", SFMono-Regular, Menlo, monospace;--step--1: .82rem;--step-0: 1rem;--step-1: 1.2rem;--step-2: 1.5rem;--step-3: 2rem;--step-4: clamp(2.4rem, 7vw, 3.6rem);--r-sm: 9px;--r: 13px;--r-lg: 20px;--shadow: 0 14px 32px -18px rgba(0, 0, 0, .7);--shadow-paper: 0 10px 26px -14px rgba(0, 0, 0, .55);font-family:var(--font-ui);line-height:1.5;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}body{background:radial-gradient(1100px 620px at 78% -8%,#15464a 0%,transparent 60%),radial-gradient(900px 500px at 0% 110%,#0f3133 0%,transparent 55%),var(--bg);background-attachment:fixed}h1,h2,h3{font-family:var(--font-display);font-weight:600;letter-spacing:-.01em}button,select,input{font-family:inherit}:focus-visible{outline:2px solid var(--brass);outline-offset:2px;border-radius:4px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.001ms!important;transition-duration:.001ms!important}}
