:root{color-scheme:light;--font-display: "Fraunces", Georgia, "Times New Roman", serif;--font-body: "Spectral", Georgia, serif;--paper: #f4efe3;--paper-card: #fbf8f0;--ink: #23201a;--ink-muted: #6f6657;--ink-faint: #a89e8b;--rule: #ddd5c3;--rule-strong: #c7bda7;--accent: #9e3b2f;--shadow-sm: 0 1px 2px rgba(45, 36, 22, .07);--shadow-md: 0 1px 2px rgba(45, 36, 22, .06), 0 10px 28px -16px rgba(45, 36, 22, .28);--radius: 7px;--gutter: clamp(1rem, 4vw, 2.75rem)}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0;color:var(--ink);background-color:var(--paper);background-image:repeating-linear-gradient(to bottom,transparent 0,transparent 27px,rgba(45,36,22,.035) 27px,rgba(45,36,22,.035) 28px),radial-gradient(120% 80% at 50% -10%,rgba(255,252,244,.9),transparent 60%),radial-gradient(140% 120% at 50% 120%,rgba(120,96,60,.06),transparent 55%);font-family:var(--font-body);font-size:17px;line-height:1.55;font-feature-settings:"liga","onum","kern"}#app{max-width:1140px;margin:0 auto;padding:clamp(1.25rem,4vw,3rem) var(--gutter) 5rem}#app>*{margin-block:0}.mood-selector,.progression-cards,.staff-panel,.playback-bar,.export-bar,.explanation-panel{padding-block:clamp(.9rem,2.4vw,1.6rem)}.staff-panel,.playback-bar,.export-bar,.explanation-panel{border-top:1px solid var(--rule)}.app-title{font-family:var(--font-display);font-optical-sizing:auto;font-weight:560;font-size:clamp(2rem,5.5vw,3.4rem);line-height:1.04;letter-spacing:-.015em;margin:0 0 1.4rem;padding-bottom:.7rem;max-width:18ch;position:relative}.app-title:before{content:"𝄞";display:block;font-size:.62em;line-height:1;color:var(--accent);opacity:.9;margin-bottom:.1em}.app-title:after{content:"";position:absolute;left:0;bottom:0;width:4.5rem;height:2px;background:var(--accent)}.tab-bar{display:flex;gap:.2rem;border-bottom:1px solid var(--rule);margin-bottom:1.5rem}.tab-bar__tab{font-family:var(--font-display);font-size:1rem;letter-spacing:.01em;color:var(--ink-muted);background:transparent;border:none;border-bottom:2px solid transparent;padding:.5rem 1rem;margin-bottom:-1px;cursor:pointer;transition:color .15s,border-color .15s}.tab-bar__tab:hover{color:var(--ink)}.tab-bar__tab.is-active{color:var(--ink);border-bottom-color:var(--accent)}.workspace[hidden]{display:none}.workspace__placeholder{padding:clamp(2rem,8vw,4.5rem) 0;color:var(--ink-muted)}.workspace__placeholder-title{font-family:var(--font-display);font-weight:540;font-size:clamp(1.5rem,4vw,2.2rem);color:var(--ink);margin:0 0 .5rem}.workspace__placeholder-note{font-style:italic;max-width:46ch;margin:0}.arrange-stub__list{margin:1rem 0 0;padding-left:1.4rem;font-family:var(--font-display);color:var(--ink)}.library{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;padding:.5rem 0;margin-bottom:1rem;border-bottom:1px solid var(--rule)}.library__label{font-family:var(--font-display);font-size:.72rem;text-transform:uppercase;letter-spacing:.16em;color:var(--ink-muted)}.library__btn{padding:.3rem .8rem;font-family:var(--font-body);font-size:.85rem;color:var(--ink);background:var(--paper-card);border:1px solid var(--rule-strong);border-radius:5px;cursor:pointer}.library__btn:hover:not(:disabled){border-color:var(--ink)}.library__btn:disabled{opacity:.4;cursor:not-allowed}.library__feedback{font-size:.8rem;font-style:italic;color:var(--accent)}.library__spacer{flex:1 1 .5rem}.library__list{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center}.library__empty{font-size:.82rem;font-style:italic;color:var(--ink-faint)}.library__item{display:inline-flex;align-items:center;gap:.25rem;padding:.15rem .3rem .15rem .5rem;background:var(--paper-card);border:1px solid var(--rule);border-radius:5px;font-size:.82rem}.library__load{font-family:var(--font-body);color:var(--ink);background:none;border:none;cursor:pointer;max-width:16ch;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.library__type{font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-faint)}.library__icon{width:1.3rem;height:1.3rem;font-size:.8rem;color:var(--ink-muted);background:none;border:none;cursor:pointer;border-radius:3px}.library__icon:hover{color:var(--accent)}.mood-grid{margin-bottom:.2rem}.explore-selector{margin-bottom:1.2rem}.explore-selector__bar{display:flex;align-items:center;flex-wrap:wrap;gap:.7rem;margin-bottom:.7rem}.explore-selector__spacer{flex:1 1 .5rem}.explore-selector__toggle{display:inline-flex;border:1px solid var(--rule-strong);border-radius:5px;overflow:hidden}.explore-selector__toggle-btn{padding:.3rem .9rem;font-family:var(--font-display);font-size:.85rem;color:var(--ink-muted);background:var(--paper-card);border:none;cursor:pointer}.explore-selector__toggle-btn+.explore-selector__toggle-btn{border-left:1px solid var(--rule-strong)}.explore-selector__toggle-btn.is-selected{color:var(--paper-card);background:var(--ink)}.explore-selector__action{padding:.4rem .9rem;font-family:var(--font-body);font-size:.85rem;color:var(--ink);background:var(--paper-card);border:1px solid var(--rule-strong);border-radius:5px;cursor:pointer;transition:border-color .15s,transform .1s}.explore-selector__action:hover:not(:disabled){border-color:var(--ink);transform:translateY(-1px)}.explore-selector__action:disabled{opacity:.4;cursor:not-allowed}.explore-selector__view[hidden]{display:none}.mood-grid__svg{display:block;width:100%;height:auto;background:var(--paper-card);border:1px solid var(--rule);border-radius:var(--radius);box-shadow:var(--shadow-md)}.mood-grid__frame{fill:#fffdf8;stroke:var(--rule);stroke-width:1}.mood-grid__mid{stroke:var(--rule);stroke-width:1;stroke-dasharray:3 6}.mood-grid__axis{fill:var(--ink-muted);font-family:var(--font-display);font-size:17px;letter-spacing:.12em;text-transform:uppercase}.mood-grid__filters{display:flex;flex-wrap:wrap;align-items:center;gap:.6rem;margin-bottom:.7rem}.mood-grid__filter-label{font-family:var(--font-display);font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-muted)}.mood-grid__filter{padding:.35rem .55rem;font-family:var(--font-body);font-size:.85rem;color:var(--ink);background:var(--paper-card);border:1px solid var(--rule-strong);border-radius:5px}.mood-grid__count{font-size:.8rem;font-style:italic;color:var(--ink-muted);margin-left:auto}.mood-grid__dot{r:5.2;stroke:#ffffffb3;stroke-width:1.2;opacity:.68;cursor:pointer;transition:opacity .12s ease,r .12s ease}.mood-grid__dot--hidden{display:none}.mood-grid__dot:hover,.mood-grid__dot:focus-visible{opacity:1;r:9;outline:none}.mood-grid__dot.is-selected{opacity:1;r:9.5;stroke:var(--ink);stroke-width:2.5}.mood-grid__zone{opacity:.18}.mood-grid__zone-label{fill:var(--ink);opacity:.5;font-family:var(--font-display);font-size:19px;letter-spacing:.04em}.build__title{font-family:var(--font-display);font-weight:540;font-size:clamp(1.4rem,4vw,2rem);margin:0 0 .3rem}.build__intro{margin:0 0 1.2rem;max-width:60ch;color:var(--ink-muted);font-style:italic}.build__timeline{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;min-height:86px;padding:.9rem;background:var(--paper-card);border:1px dashed var(--rule-strong);border-radius:var(--radius)}.build__empty{margin:0;color:var(--ink-muted);font-style:italic}.build__chip{position:relative;display:flex;flex-direction:column;align-items:center;gap:.05rem;padding:.55rem 1rem .5rem;min-width:4.2rem;background:var(--paper);border:1px solid var(--rule-strong);border-radius:var(--radius);cursor:grab}.build__chip:active{cursor:grabbing}.build__chip-symbol{font-family:var(--font-display);font-weight:560;font-size:1.1rem}.build__chip-numeral{font-style:italic;font-size:.8rem;color:var(--ink-muted)}.build__chip-remove{position:absolute;top:-7px;right:-7px;width:18px;height:18px;line-height:1;font-size:.85rem;color:var(--paper-card);background:var(--ink-muted);border:none;border-radius:50%;cursor:pointer}.build__chip-remove:hover{background:var(--accent)}.build__banner{display:flex;flex-wrap:wrap;align-items:center;gap:.8rem;margin-bottom:.9rem;padding:.5rem .85rem;background:var(--paper-card);border:1px solid var(--accent);border-left-width:3px;border-radius:var(--radius)}.build__banner-text{font-family:var(--font-body);font-size:.9rem;color:var(--ink)}.build__save-section{padding:.4rem .95rem;font-family:var(--font-display);font-weight:560;color:var(--paper-card);background:var(--accent);border:1px solid var(--accent);border-radius:5px;cursor:pointer}.build__chip--pinned{border-style:dashed;border-color:var(--accent);background:var(--paper-card)}.build__chip--pinned .build__chip-numeral{font-style:normal;letter-spacing:.02em}.build__controls{display:flex;flex-wrap:wrap;align-items:center;gap:.6rem;margin:.8rem 0 1.1rem}.build__chord-entry{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.build__chord-input{width:18rem;max-width:100%;padding:.45rem .7rem;font-family:var(--font-body);color:var(--ink);background:var(--paper);border:1px solid var(--rule-strong);border-radius:5px}.build__chord-input:focus{outline:none;border-color:var(--accent)}.build__chord-add{padding:.45rem 1rem;font-family:var(--font-body);color:var(--ink);background:var(--paper-card);border:1px solid var(--rule-strong);border-radius:5px;cursor:pointer}.build__chord-error{font-size:.82rem;color:var(--accent)}.build__play{padding:.45rem 1.3rem;font-family:var(--font-display);font-weight:560;color:var(--paper-card);background:var(--ink);border:1px solid var(--ink);border-radius:5px;cursor:pointer}.build__clear{padding:.45rem 1rem;font-family:var(--font-body);color:var(--ink);background:var(--paper-card);border:1px solid var(--rule-strong);border-radius:5px;cursor:pointer}.build__palette{display:flex;flex-direction:column;gap:.55rem;margin-bottom:1.3rem}.build__palette-row{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.build__palette-label{font-family:var(--font-display);font-size:.72rem;text-transform:uppercase;letter-spacing:.16em;color:var(--ink-muted);width:4.3rem;flex-shrink:0}.build__suggestion{display:flex;flex-direction:column;align-items:center;gap:.05rem;padding:.45rem .85rem;background:var(--paper-card);border:1px solid var(--rule-strong);border-radius:var(--radius);cursor:pointer;transition:border-color .15s,transform .1s}.build__suggestion:hover{border-color:var(--accent);transform:translateY(-2px)}.build__suggestion:first-of-type{border-color:var(--accent)}.build__suggestion-symbol{font-family:var(--font-display);font-weight:560;font-size:1.05rem}.build__suggestion-numeral{font-style:italic;font-size:.78rem;color:var(--ink-muted)}.build__save{display:flex;flex-wrap:wrap;align-items:center;gap:.6rem}.build__name{flex:1 1 16rem;max-width:22rem;padding:.45rem .7rem;font-family:var(--font-body);font-size:.95rem;color:var(--ink);background:var(--paper-card);border:1px solid var(--rule-strong);border-radius:5px}.build__add{padding:.45rem 1rem;font-family:var(--font-body);color:var(--ink);background:var(--paper-card);border:1px solid var(--rule-strong);border-radius:5px;cursor:pointer}.build__add:hover{border-color:var(--ink)}.arrange__header{display:flex;align-items:center;flex-wrap:wrap;gap:.8rem;margin-bottom:1rem}.arrange__title{font-family:var(--font-display);font-weight:540;font-size:clamp(1.4rem,4vw,2rem);margin:0}.arrange__spacer{flex:1 1 1rem}.arrange__total{font-size:.85rem;color:var(--ink-muted);font-variant-numeric:tabular-nums}.arrange__play{padding:.45rem 1.2rem;font-family:var(--font-display);font-weight:560;color:var(--paper-card);background:var(--ink);border:1px solid var(--ink);border-radius:5px;cursor:pointer}.arrange__play:disabled{opacity:.4;cursor:not-allowed}.arrange__play.is-playing{background:var(--accent);border-color:var(--accent)}.arrange__generate{display:flex;flex-wrap:wrap;align-items:center;gap:.45rem;padding:.7rem .9rem;margin-bottom:1rem;background:var(--paper-card);border:1px solid var(--rule);border-radius:var(--radius);font-size:.88rem}.arrange__gen-title{font-family:var(--font-display);font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-muted);margin-right:.3rem}.arrange__gen-text{color:var(--ink-muted)}.arrange__generate select,.arrange__generate input{font-family:var(--font-body);font-size:.88rem;color:var(--ink);background:var(--paper);border:1px solid var(--rule-strong);border-radius:4px;padding:.25rem .4rem}.arrange__gen-length{width:3.6rem}.arrange__gen-btn{margin-left:.3rem;padding:.35rem 1rem;font-family:var(--font-display);font-weight:560;color:var(--paper-card);background:var(--accent);border:1px solid var(--accent);border-radius:5px;cursor:pointer}.arrange__export{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:1.1rem}.arrange__export-label{font-family:var(--font-display);font-size:.72rem;text-transform:uppercase;letter-spacing:.16em;color:var(--ink-muted)}.arrange__export-btn{padding:.35rem .8rem;font-family:var(--font-body);font-size:.85rem;color:var(--ink);background:var(--paper-card);border:1px solid var(--rule-strong);border-radius:5px;cursor:pointer}.arrange__export-btn:hover:not(:disabled){border-color:var(--ink)}.arrange__export-btn:disabled{opacity:.4;cursor:not-allowed}.arrange__body{display:flex;flex-direction:column;gap:.7rem}.arrange__empty{color:var(--ink-muted);font-style:italic;max-width:52ch}.arrange__card{padding:.75rem 1rem;background:var(--paper-card);border:1px solid var(--rule);border-left:3px solid transparent;border-radius:var(--radius);box-shadow:var(--shadow-sm)}.arrange__card.is-playing{border-left-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,var(--paper-card))}.arrange__card-head{display:flex;align-items:center;gap:.6rem}.arrange__index{font-family:var(--font-display);color:var(--ink-muted);min-width:1.4rem}.arrange__name{font-family:var(--font-display);font-weight:540;font-size:1.05rem;flex:1}.arrange__card-controls{display:flex;align-items:center;gap:.3rem}.arrange__edit{height:1.7rem;padding:0 .6rem;font-family:var(--font-body);font-size:.78rem;color:var(--ink);background:var(--paper);border:1px solid var(--rule-strong);border-radius:4px;cursor:pointer}.arrange__edit:hover{border-color:var(--accent)}.arrange__move{width:1.7rem;height:1.7rem;font-size:.8rem;color:var(--ink);background:var(--paper);border:1px solid var(--rule-strong);border-radius:4px;cursor:pointer}.arrange__move:disabled{opacity:.3;cursor:not-allowed}.arrange__remove{width:1.7rem;height:1.7rem;font-size:1rem;color:var(--paper-card);background:var(--ink-muted);border:none;border-radius:4px;cursor:pointer}.arrange__remove:hover{background:var(--accent)}.arrange__preview{font-family:var(--font-display);letter-spacing:.02em;margin:.45rem 0 .6rem}.arrange__fields{display:flex;flex-wrap:wrap;gap:.8rem}.arrange__field{display:flex;flex-direction:column;gap:.15rem}.arrange__field-label{font-family:var(--font-display);font-size:.68rem;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-muted)}.arrange__field input,.arrange__field select{font-family:var(--font-body);font-size:.9rem;color:var(--ink);background:var(--paper);border:1px solid var(--rule-strong);border-radius:4px;padding:.3rem .4rem}.arrange__repeat,.arrange__tempo{width:4.5rem}.arrange__label-input{width:9rem}.mood-arc{margin-bottom:1.2rem}.mood-arc__title{font-family:var(--font-display);font-size:.72rem;text-transform:uppercase;letter-spacing:.16em;color:var(--ink-muted);margin:0 0 .4rem}.mood-arc__svg{display:block;width:100%;max-width:640px;height:auto;background:var(--paper-card);border:1px solid var(--rule);border-radius:var(--radius)}.mood-arc__frame{fill:#fffdf8;stroke:var(--rule)}.mood-arc__axis{fill:var(--ink-faint);font-family:var(--font-display);font-size:11px;letter-spacing:.08em;text-transform:uppercase}.mood-arc__seg{stroke:var(--ink-muted);stroke-width:2}.mood-arc__seg.is-jump{stroke:var(--accent);stroke-width:2.5;stroke-dasharray:5 4}.mood-arc__pt{fill:var(--paper-card);stroke:var(--ink);stroke-width:2}.mood-arc__pt.is-playing{fill:var(--accent);stroke:var(--accent)}.mood-arc__pt-label{fill:var(--ink);font-family:var(--font-display);font-size:12px;font-weight:600}.mood-arc__pt.is-playing+.mood-arc__pt-label{fill:var(--paper-card)}.mood-arc__warnings{list-style:none;margin:.5rem 0 0;padding:0}.mood-arc__warning{font-size:.82rem;color:var(--accent);padding:.15rem 0}.mood-arc__warning:before{content:"△ "}.staff-panel__title,.explanation-panel__title{font-family:var(--font-display);font-weight:540;font-size:1.15rem;letter-spacing:.01em;margin:0}.controls{margin-bottom:.4rem}.key-selector{display:flex;flex-wrap:wrap;align-items:baseline;gap:.4rem}.key-selector__label{font-family:var(--font-display);font-size:.8rem;text-transform:uppercase;letter-spacing:.18em;color:var(--ink-muted);margin-right:.4rem}.key-chip{font-family:var(--font-body);font-size:.92rem;min-width:2.4ch;padding:.25rem .5rem;color:var(--ink-muted);background:transparent;border:1px solid transparent;border-radius:5px;cursor:pointer;transition:color .15s,background .15s,border-color .15s}.key-chip:hover{color:var(--ink);background:#2d24160d}.key-chip.is-selected{color:var(--paper-card);background:var(--ink);border-color:var(--ink)}.mood-selector{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.7rem}.mood-chip{--mood-accent: #888;display:flex;flex-direction:column;gap:.2rem;text-align:left;padding:.7rem .85rem .75rem;background:var(--paper-card);color:var(--ink);border:1px solid var(--rule);border-left:3px solid var(--mood-accent);border-radius:var(--radius);box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,border-color .16s}.mood-chip:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.mood-chip.is-selected{border-color:var(--mood-accent);box-shadow:var(--shadow-md),inset 0 0 0 1px var(--mood-accent)}.mood-chip__label{font-family:var(--font-display);font-weight:560;font-size:1.02rem;letter-spacing:.005em}.mood-chip.is-selected .mood-chip__label{color:var(--mood-accent)}.mood-chip__blurb{font-size:.82rem;line-height:1.35;color:var(--ink-muted)}.progression-cards__empty,.staff-panel__empty,.explanation-panel__empty{font-style:italic;color:var(--ink-muted)}.progression-cards__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.7rem}.progression-card{display:flex;flex-direction:column;gap:.3rem;text-align:left;padding:.7rem .85rem;background:var(--paper-card);color:var(--ink);border:1px solid var(--rule);border-radius:var(--radius);box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,border-color .16s}.progression-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.progression-card.is-selected{border-color:var(--accent);box-shadow:var(--shadow-md),inset 0 0 0 1px var(--accent)}.progression-card__name{font-family:var(--font-display);font-weight:540;font-size:1rem}.progression-card__degrees{font-size:.85rem;font-style:italic;color:var(--ink-muted);letter-spacing:.02em}.staff-panel__header{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:.7rem}.staff-panel__toggle{display:inline-flex;border:1px solid var(--rule-strong);border-radius:5px;overflow:hidden}.staff-panel__toggle-btn{padding:.28rem .7rem;font-family:var(--font-body);font-size:.82rem;color:var(--ink-muted);background:transparent;border:none;cursor:pointer;transition:background .15s,color .15s}.staff-panel__toggle-btn+.staff-panel__toggle-btn{border-left:1px solid var(--rule-strong)}.staff-panel__toggle-btn:hover{color:var(--ink);background:#2d24160d}.staff-panel__toggle-btn.is-selected{color:var(--paper-card);background:var(--ink)}.staff-panel__svg{display:inline-block;max-width:100%;overflow-x:auto;background:#fff;padding:.5rem .6rem;border:1px solid var(--rule);border-radius:var(--radius);box-shadow:var(--shadow-md)}.staff-panel__error{color:#9e3b2f;font-style:italic}.staff-panel__svg g.is-playing,.staff-panel__svg g.is-playing *{fill:var(--accent)!important;stroke:var(--accent)!important}.playback-bar,.export-bar{display:flex;flex-wrap:wrap;align-items:center;gap:1rem}.playback-bar__field{display:flex;align-items:center;gap:.4rem;font-size:.85rem}.playback-bar__label,.export-bar__label{font-family:var(--font-display);font-size:.72rem;text-transform:uppercase;letter-spacing:.16em;color:var(--ink-muted)}.playback-bar__tempo-wrap{display:inline-flex;align-items:center;gap:.4rem}.playback-bar__readout{min-width:2.4ch;text-align:right;font-variant-numeric:tabular-nums;font-weight:500}input[type=range].playback-bar__tempo{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:9rem;height:2px;background:var(--rule-strong);border-radius:2px;cursor:pointer}input[type=range].playback-bar__tempo::-webkit-slider-thumb{-webkit-appearance:none;width:15px;height:15px;border-radius:50%;background:var(--accent);border:2px solid var(--paper-card);box-shadow:var(--shadow-sm)}input[type=range].playback-bar__tempo::-moz-range-thumb{width:15px;height:15px;border:2px solid var(--paper-card);border-radius:50%;background:var(--accent)}.playback-bar select{font-family:var(--font-body);font-size:.88rem;color:var(--ink);background:var(--paper-card);border:1px solid var(--rule-strong);border-radius:5px;padding:.2rem .4rem}.playback-bar input[type=checkbox]{accent-color:var(--accent);width:1rem;height:1rem}.playback-bar__play{padding:.45rem 1.3rem;font-family:var(--font-display);font-weight:560;font-size:.95rem;letter-spacing:.02em;color:var(--paper-card);background:var(--ink);border:1px solid var(--ink);border-radius:5px;cursor:pointer;transition:background .15s,transform .1s}.playback-bar__play:hover:not(:disabled){transform:translateY(-1px)}.playback-bar__play:disabled{opacity:.4;cursor:not-allowed}.playback-bar__play.is-playing{color:var(--paper-card);background:var(--accent);border-color:var(--accent)}.export-bar__btn{padding:.42rem .95rem;font-family:var(--font-body);font-size:.88rem;color:var(--ink);background:var(--paper-card);border:1px solid var(--rule-strong);border-radius:5px;cursor:pointer;transition:background .15s,border-color .15s,transform .1s}.export-bar__btn:hover:not(:disabled){border-color:var(--ink);transform:translateY(-1px)}.export-bar__btn:disabled{opacity:.4;cursor:not-allowed}.explanation-panel{max-width:68ch}.explanation-panel__title{margin-bottom:.7rem}.explanation-panel__summary{font-family:var(--font-display);font-optical-sizing:auto;font-weight:420;font-size:clamp(1.12rem,2.4vw,1.4rem);line-height:1.4;margin:0 0 1.3rem;text-wrap:balance}.explanation-panel__layer{margin-bottom:1.2rem}.explanation-panel__layer-title{font-family:var(--font-display);margin:0 0 .4rem;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.16em;color:var(--accent)}.explanation-panel__theory{margin:0;line-height:1.6;color:#322d24}.explanation-panel__chords{margin:0;padding:0;list-style:none;display:flex;flex-direction:column}.explanation-panel__chord{display:grid;grid-template-columns:4.5rem 3rem 1fr;align-items:baseline;gap:.6rem;padding:.4rem .6rem;border-left:3px solid transparent;border-radius:0 5px 5px 0}.explanation-panel__chord+.explanation-panel__chord{border-top:1px solid var(--rule)}.explanation-panel__chord-symbol{font-family:var(--font-display);font-weight:560}.explanation-panel__chord-numeral{font-style:italic;color:var(--ink-faint)}.explanation-panel__chord-note{line-height:1.45;color:#322d24}.explanation-panel__chord.is-active{background:color-mix(in srgb,var(--accent) 12%,transparent);border-left-color:var(--accent)}.explanation-panel__chord.is-active .explanation-panel__chord-symbol{color:var(--accent)}.explanation-panel__footnote{margin:1rem 0 0;padding-top:.7rem;border-top:1px solid var(--rule);font-size:.86rem;color:var(--ink-muted)}.explanation-panel__genres{text-transform:capitalize;letter-spacing:.02em}.explanation-panel__example cite{font-style:italic}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}@keyframes ink-rise{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}#app>*{animation:ink-rise .5s cubic-bezier(.2,.7,.2,1) both}#app>*:nth-child(1){animation-delay:.02s}#app>*:nth-child(2){animation-delay:.08s}#app>*:nth-child(3){animation-delay:.14s}#app>*:nth-child(4){animation-delay:.2s}#app>*:nth-child(5){animation-delay:.26s}#app>*:nth-child(6){animation-delay:.32s}#app>*:nth-child(n+7){animation-delay:.38s}#app.is-routed>*{animation:none}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-delay:0s!important;transition-duration:.001ms!important}}@media (max-width: 560px){body{font-size:16px}.mood-selector{grid-template-columns:repeat(auto-fill,minmax(132px,1fr))}.progression-cards__grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.explanation-panel__chord{grid-template-columns:3.6rem 2.4rem 1fr;gap:.45rem}.tab-bar{gap:0}.tab-bar__tab{flex:1;padding:.5rem .4rem;text-align:center}.mood-grid__filters{gap:.4rem .5rem}.mood-grid__filter{flex:1 1 8rem}.mood-grid__count{flex-basis:100%;margin-left:0}.build__chord-input,.build__name{flex:1 1 100%;width:100%;max-width:none}.arrange__header,.arrange__generate{gap:.5rem}}.toast-region{position:fixed;top:1rem;right:1rem;z-index:2000;display:flex;flex-direction:column;align-items:flex-end;gap:.4rem;pointer-events:none}.toast{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .85rem;font-family:var(--font-display);font-size:.86rem;font-weight:560;color:var(--paper-card);background:var(--accent);border-radius:999px;box-shadow:var(--shadow-md);white-space:nowrap;opacity:0;transform:translateY(-4px);transition:opacity .2s ease,transform .2s ease}.toast.is-visible{opacity:1;transform:translateY(0)}.toast__check{font-size:.95em;line-height:1}
