:root{--bg-1: #FFFFFF;--bg-2: #F7F6F1;--bg-3: #F1EFE8;--fg-1: #2C2C2A;--fg-2: #5F5E5A;--fg-3: #7B7A74;--border-1: rgba(44,44,42,.4);--border-2: rgba(44,44,42,.22);--border-3: rgba(44,44,42,.12);--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--font: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--mono: ui-monospace, "SF Mono", Menlo, monospace;--neutral-fill: #EFEEE9}[data-mode=dark]{--bg-1: #16161A;--bg-2: #1F1E22;--bg-3: #28272C;--fg-1: #F1EFE8;--fg-2: #B4B2A9;--fg-3: #8B8983;--border-1: rgba(241,239,232,.4);--border-2: rgba(241,239,232,.22);--border-3: rgba(241,239,232,.1);--neutral-fill: #2C2B30}[data-theme=teal]{--a-100: oklch(93% .04 168);--a-200: oklch(86% .072 168);--a-300: oklch(76% .105 168);--a-400: oklch(66% .118 168);--a-500: oklch(56% .115 168);--a-600: oklch(46% .098 168);--a-700: oklch(36% .078 168);--a-800: oklch(27% .058 168);--a-900: oklch(19% .042 168);--a-fg-on-tint: oklch(24% .058 168);--a-fg-on-fill: oklch(97% .018 168)}[data-theme=indigo]{--a-100: oklch(93% .034 285);--a-200: oklch(86% .072 285);--a-300: oklch(76% .115 285);--a-400: oklch(64% .155 285);--a-500: oklch(54% .175 285);--a-600: oklch(45% .155 285);--a-700: oklch(36% .125 285);--a-800: oklch(27% .09 285);--a-900: oklch(20% .062 285);--a-fg-on-tint: oklch(26% .11 285);--a-fg-on-fill: oklch(97% .01 285)}[data-theme=amber]{--a-100: oklch(94% .04 75);--a-200: oklch(88% .08 75);--a-300: oklch(80% .12 75);--a-400: oklch(72% .145 75);--a-500: oklch(63% .15 65);--a-600: oklch(52% .135 55);--a-700: oklch(41% .11 50);--a-800: oklch(30% .078 48);--a-900: oklch(22% .052 48);--a-fg-on-tint: oklch(28% .08 50);--a-fg-on-fill: oklch(98% .018 75)}[data-theme=rose]{--a-100: oklch(93% .034 10);--a-200: oklch(87% .062 10);--a-300: oklch(78% .095 10);--a-400: oklch(68% .125 10);--a-500: oklch(58% .145 8);--a-600: oklch(48% .135 5);--a-700: oklch(38% .11 2);--a-800: oklch(28% .08 0);--a-900: oklch(20% .055 0);--a-fg-on-tint: oklch(26% .09 5);--a-fg-on-fill: oklch(97% .014 10)}:root{--em-tint: var(--a-100);--em-soft: var(--a-200);--em-mid: var(--a-400);--em-strong: var(--a-600);--em-emph: var(--a-700);--em-line: var(--a-500);--em-fg-on-tint: var(--a-fg-on-tint);--em-fg-on-emph: var(--a-fg-on-fill)}[data-mode=dark]{--em-tint: var(--a-800);--em-soft: var(--a-700);--em-mid: var(--a-500);--em-strong: var(--a-400);--em-emph: var(--a-300);--em-line: var(--a-400);--em-fg-on-tint: var(--a-fg-on-fill);--em-fg-on-emph: var(--a-fg-on-tint)}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--font);font-size:14px;line-height:1.6;color:var(--fg-1);background:var(--bg-1);-webkit-font-smoothing:antialiased}code{font-family:var(--mono);font-size:.92em;background:var(--bg-3);padding:1px 5px;border-radius:4px}button,select,input{font-family:inherit}.app{max-width:980px;margin:0 auto;padding:28px 24px 64px}.topbar{display:flex;align-items:center;gap:16px;padding-bottom:18px;margin-bottom:24px;border-bottom:.5px solid var(--border-3);flex-wrap:wrap}.wordmark{font-size:14px;font-weight:500;letter-spacing:-.005em;color:var(--fg-1);margin-right:auto}.wordmark .dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--a-600);margin-right:8px;vertical-align:1px}.wordmark .muted{color:var(--fg-3);font-weight:400;margin-left:8px}.theme-picker{display:flex;align-items:center;gap:4px;padding:4px;background:var(--bg-2);border-radius:999px}.theme-swatch{width:22px;height:22px;border-radius:50%;border:1.5px solid transparent;cursor:pointer;padding:0;transition:transform .12s ease}.theme-swatch:hover{transform:scale(1.08)}.theme-swatch[aria-pressed=true]{border-color:var(--fg-1)}.theme-swatch[data-color=teal]{background:#008968;background:oklch(56% .115 168)}.theme-swatch[data-color=indigo]{background:#6858ce}.theme-swatch[data-color=amber]{background:#c27400;background:oklch(63% .15 65)}.theme-swatch[data-color=rose]{background:#bf4f6a}.mode-toggle{height:30px;padding:0 12px;border:.5px solid var(--border-2);background:var(--bg-1);color:var(--fg-2);border-radius:999px;font-size:12px;cursor:pointer;transition:all .12s ease}.mode-toggle:hover{color:var(--fg-1);border-color:var(--border-1)}.lang-picker{display:flex;align-items:center;gap:2px;padding:3px;background:var(--bg-2);border-radius:999px}.lang-btn{border:0;background:transparent;color:var(--fg-3);font-family:var(--mono);font-size:11px;letter-spacing:.04em;padding:4px 9px;border-radius:999px;cursor:pointer;transition:color .12s ease,background .12s ease}.lang-btn:hover{color:var(--fg-1)}.lang-btn[aria-pressed=true]{background:var(--bg-1);color:var(--fg-1)}.nav{display:flex;gap:4px;margin-bottom:32px;border-bottom:.5px solid var(--border-3);padding-bottom:0}.nav button{display:inline-flex;align-items:baseline;gap:8px;background:transparent;border:0;padding:10px 14px;margin-bottom:-1px;font-family:inherit;font-size:14px;color:var(--fg-2);cursor:pointer;border-bottom:2px solid transparent;transition:color .12s ease,border-color .12s ease}.nav button:hover{color:var(--fg-1)}.nav button[aria-current=page]{color:var(--fg-1);border-bottom-color:var(--em-strong);font-weight:500}.nav .nav-num{font-family:var(--mono);font-size:11px;color:var(--fg-3);letter-spacing:.04em}.nav button[aria-current=page] .nav-num{color:var(--em-strong)}.section{display:none}.section[aria-current=true]{display:block}.page-head{margin-bottom:28px}.page-head .kicker{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--a-600);margin-bottom:8px}.page-head h1{font-size:28px;font-weight:500;letter-spacing:-.015em;margin:0 0 8px;line-height:1.15}.page-head .lead{font-size:14px;color:var(--fg-2);max-width:60ch;margin:0}.circle-row,.type-row,.variant-row{display:flex;flex-wrap:wrap;gap:4px}.circle-row{margin-bottom:14px}.type-row{margin-bottom:6px}.variant-row{margin-bottom:20px}.circle-btn,.type-btn,.variant-btn{padding:6px 11px;font-size:12.5px;border:.5px solid var(--border-3);border-radius:var(--radius-md);background:transparent;color:var(--fg-2);cursor:pointer;transition:all .12s ease;font-weight:400;font-family:inherit}.circle-btn:hover,.type-btn:hover,.variant-btn:hover{border-color:var(--border-2);color:var(--fg-1)}.circle-btn.active,.type-btn.active,.variant-btn.active{background:var(--em-tint);color:var(--em-fg-on-tint);border-color:var(--em-line);font-weight:500}.explain{font-size:13px;color:var(--fg-2);margin-bottom:18px;max-width:60ch;line-height:1.6}.explain code{font-size:.92em}.sheet-wrap{background:var(--bg-2);border-radius:var(--radius-lg);padding:24px;overflow:auto;margin-bottom:18px;height:320px;position:relative}.sheet-wrap[data-systems="2"]{height:540px}.sheet-wrap[data-systems="3"]{height:760px}.controls{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.controls button{height:32px;padding:0 14px;border:.5px solid var(--border-2);background:var(--bg-1);color:var(--fg-2);border-radius:999px;font-size:12px;cursor:pointer;transition:color .12s ease,border-color .12s ease;font-family:inherit;display:inline-flex;align-items:center;gap:6px}.btn-icon{flex-shrink:0}.controls button:hover{color:var(--fg-1);border-color:var(--border-1)}.abc-source{margin-top:12px}.abc-source details{background:var(--bg-2);border-radius:var(--radius-md);border:none}.abc-source summary{cursor:pointer;padding:10px 16px;font-size:12px;color:var(--fg-2);font-family:var(--mono);letter-spacing:.04em}.abc-source pre{padding:10px 16px;margin:0;font-size:11.5px;overflow-x:auto;font-family:var(--mono);color:var(--fg-1)}.note-playing,.note-playing *{fill:var(--em-emph)!important;stroke:var(--em-emph)!important;transition:fill .08s ease,stroke .08s ease}.annotations-toggle-row{display:flex;gap:4px;margin-top:12px}.qz-tab{padding:6px 11px;font-size:12.5px;border:.5px solid var(--border-3);border-radius:var(--radius-md);background:transparent;color:var(--fg-2);cursor:pointer;transition:all .12s ease;font-weight:400;font-family:inherit}.qz-tab:hover{border-color:var(--border-2);color:var(--fg-1)}.qz-tab[aria-pressed=true]{background:var(--em-tint);color:var(--em-fg-on-tint);border-color:var(--em-line);font-weight:500}.foot{margin-top:56px;padding-top:18px;border-top:.5px solid var(--border-3);font-size:11.5px;color:var(--fg-3);display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}.foot .mono{font-family:var(--mono);letter-spacing:.04em}.qz-tabs{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:16px}.qz-stage{background:var(--bg-2);border-radius:var(--radius-lg);padding:24px;display:grid;grid-template-columns:1fr 280px;gap:28px;align-items:start}.qz-svg-wrap{display:flex;align-items:center;justify-content:center}#qz-svg{display:block;width:100%;max-width:440px;height:auto}.qz-side h3{font-size:15px;font-weight:500;margin:0 0 8px;color:var(--fg-1);letter-spacing:-.005em}.qz-explain{font-size:13px;color:var(--fg-2);line-height:1.6;max-width:36ch}.qz-explain code{font-size:11.5px}.qz-controls{display:none;align-items:center;gap:10px;margin-top:18px;padding-top:16px;border-top:.5px solid var(--border-3);font-size:12px;color:var(--fg-3)}.qz-controls.show{display:flex}.qz-controls label{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase}.qz-controls select{flex:1}.qz-legend{display:flex;flex-wrap:wrap;gap:6px;margin-top:18px;padding-top:16px;border-top:.5px solid var(--border-3)}.qz-pill{font-size:11.5px;padding:3px 9px;border-radius:999px;border:.5px solid var(--border-3);background:var(--bg-1);color:var(--fg-2);font-variant-numeric:tabular-nums}.qz-pill.swatch:before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--swatch);margin-right:6px;vertical-align:0}.qz-click{cursor:pointer}.qz-click:hover{fill:#7d7d7d0f}@media(max-width:720px){.qz-stage{grid-template-columns:1fr}}.me-controls{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:20px}.me-controls label{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--fg-3)}.me-modes{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:6px}.me-mode{padding:14px 6px;border-radius:var(--radius-md);text-align:center;cursor:pointer;border:1px solid transparent;transition:transform .12s ease,border-color .12s ease;font-size:12.5px;font-weight:500}.me-mode:hover{transform:translateY(-1px)}.me-mode[aria-pressed=true]{border-color:var(--fg-1);transform:translateY(-2px)}.me-axis{display:flex;justify-content:space-between;font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;color:var(--fg-3);margin:0 2px 22px}.me-card{background:var(--bg-2);border-radius:var(--radius-lg);padding:22px 24px;border-top:3px solid var(--a-600)}.me-card-head{display:flex;align-items:baseline;gap:12px;margin-bottom:4px;flex-wrap:wrap}.me-card h3{font-size:22px;margin:0;font-weight:500;letter-spacing:-.01em}.me-card .me-parent{font-size:12px;color:var(--fg-3);font-family:var(--mono)}.me-flavor{font-size:13px;color:var(--fg-2);margin-bottom:18px;max-width:60ch}.me-notes-actions{display:flex;justify-content:flex-end;margin-bottom:10px}.me-play{display:inline-flex;align-items:center;gap:6px;height:28px;padding:0 12px;border:.5px solid var(--border-2);background:var(--bg-1);color:var(--fg-2);border-radius:999px;font-size:12px;cursor:pointer;transition:color .12s ease,border-color .12s ease,opacity .12s ease;font-family:inherit}.me-play:hover:not(:disabled){color:var(--fg-1);border-color:var(--border-1)}.me-play:disabled{cursor:default;opacity:.55}.me-notes{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:18px}.me-note{background:var(--bg-1);border:.5px solid var(--border-3);border-radius:var(--radius-md);padding:10px 12px;min-width:56px;text-align:center;cursor:pointer;transition:transform .12s ease,border-color .12s ease,box-shadow .15s ease;position:relative}.me-note:hover{border-color:var(--border-1)}.me-note:active{transform:scale(.96)}.me-note.playing{transform:scale(1.08);border-color:var(--a-500);box-shadow:0 0 0 2px var(--a-500);z-index:1}.me-note-deg{font-family:var(--mono);font-size:10px;letter-spacing:.04em;color:var(--fg-3);margin-bottom:3px;font-variant-numeric:tabular-nums}.me-note-name{font-size:16px;font-weight:500;letter-spacing:-.005em}.me-note.tonic{background:var(--fg-1);color:var(--bg-1);border-color:var(--fg-1)}.me-note.tonic .me-note-deg{color:var(--bg-2);opacity:.7}.me-note.char{background:var(--em-tint);border:1.5px solid var(--em-line)}.me-note.char .me-note-deg,.me-note.char .me-note-name{color:var(--em-fg-on-tint)}.me-char-info{font-size:13px;padding:12px 16px;background:var(--bg-1);border-radius:var(--radius-md);border-left:3px solid var(--em-line);color:var(--fg-2)}.me-char-info strong{color:var(--fg-1);font-weight:500}.hm-controls{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-bottom:18px}.hm-controls label{font-size:13px;color:var(--fg-2)}.hm-controls select{font-family:inherit;font-size:14px;height:34px;padding:0 10px;border:.5px solid var(--border-3);border-radius:var(--radius-md);background:var(--bg-1);color:var(--fg-1)}.hm-layers{display:flex;gap:6px;flex-wrap:wrap}.hm-layer-btn{padding:6px 10px;font-size:12px;border:.5px solid var(--border-3);border-radius:var(--radius-md);background:transparent;color:var(--fg-2);cursor:pointer;font-family:inherit}.hm-layer-btn:hover{color:var(--fg-1);border-color:var(--border-2)}.hm-layer-btn.active{background:var(--fg-1);color:var(--bg-1);border-color:var(--fg-1)}.hm-stage-explain{background:var(--bg-2);border-radius:var(--radius-md);padding:14px 18px;margin-bottom:18px}.hm-stage-explain h3{font-size:14px;font-weight:600;margin:0 0 6px}.hm-stage-explain code{background:var(--bg-3);padding:1px 5px;border-radius:4px;font-size:11.5px}.hm-matrix{display:flex;flex-direction:column;gap:10px;margin-bottom:22px;overflow-x:auto}.hm-row{display:grid;grid-template-columns:100px repeat(6,1fr);gap:6px;align-items:stretch}.hm-row-label{font-size:12px;display:flex;align-items:center;padding-right:6px;color:var(--fg-2)}.hm-row-tert .hm-row-label{color:#3c3489;font-weight:600}.hm-row-sec .hm-row-label{color:#854f0b;font-weight:600}.hm-row-family .hm-row-label{color:#04342c;font-weight:700}.hm-row-upside .hm-row-label{color:#72243e;font-weight:700}.hm-cell{display:flex;flex-direction:column;align-items:center;gap:4px}.hm-cell-stack{display:flex;flex-direction:column;gap:3px;width:100%}.hm-chord-box{background:var(--bg-2);border:.5px solid var(--border-3);border-radius:var(--radius-md);padding:8px 6px;text-align:center;font-size:13px;font-weight:500;cursor:pointer;transition:transform .12s ease,background .12s ease;font-family:inherit}.hm-chord-box:hover{transform:translateY(-1px)}.hm-chord-box.playing{background:#1d9e75!important;color:#fff!important;border-color:#1d9e75!important}.hm-chord-box.crossed{opacity:.35;text-decoration:line-through;cursor:default}.hm-degree{font-size:11px;font-weight:500}.hm-family-row .hm-chord-box{background:#9fe1cb;color:#04342c;border-color:#04342c44}.hm-family-row .hm-chord-box.tonic{background:#1d9e75;color:#fff;border-color:#1d9e75}.hm-sec-row .hm-chord-box{font-size:11px;padding:4px}.hm-sec-row .hm-chord-box.primary{background:#fac775;color:#412402;border-color:#41240244}.hm-sec-row .hm-chord-box.sub{background:#f5c4b3;color:#712b13;font-style:italic;border-color:#712b1344}.hm-sec-row .hm-chord-box.backdoor{background:#e8d7a4;color:#4f3a11;font-style:italic;border-color:#4f3a1144}.hm-tert-row .hm-chord-box{background:#cecbf6;color:#3c3489;font-size:11px;padding:4px;border-color:#3c348944}.hm-upside-row .hm-chord-box{background:#f0bfcc;color:#72243e;border-color:#72243e44}.hm-arrow{font-size:16px;line-height:1;height:14px}.hm-arrow-sec{color:#851313}.hm-arrow-tert{color:#3c3489}.hm-example-label{font-size:12px;color:var(--fg-3);margin-bottom:8px}.hm-progression{display:flex;gap:6px;margin:0 0 14px;flex-wrap:wrap}.hm-prog-chord{background:var(--bg-2);border:.5px solid var(--border-3);border-radius:var(--radius-md);padding:8px 10px;font-size:13px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:2px;transition:transform .12s ease}.hm-prog-chord:hover{transform:translateY(-1px)}.hm-prog-chord.playing{background:#1d9e75;color:#fff;border-color:#1d9e75}.hm-prog-chord.family{background:#9fe1cb;color:#04342c}.hm-prog-chord.sec{background:#fac775;color:#412402}.hm-prog-chord.subv{background:#f5c4b3;color:#712b13}.hm-prog-chord.backdoor{background:#e8d7a4;color:#4f3a11}.hm-prog-chord.tert{background:#cecbf6;color:#3c3489}.hm-prog-chord.upside{background:#f0bfcc;color:#72243e}.hm-prog-role{font-size:10px;opacity:.75;font-family:var(--mono)}.hm-play-row{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--fg-2)}.hm-play-btn{height:32px;padding:0 14px;background:var(--em-strong);color:var(--em-fg-on-emph);border:0;border-radius:999px;font-size:12px;font-family:inherit;cursor:pointer}.hm-play-btn:disabled{opacity:.5;cursor:default}.hm-play-btn:hover:not(:disabled){background:var(--em-emph)}.print-modal{border:none;border-radius:var(--radius-lg);padding:0;background:var(--bg-1);color:var(--fg-1);max-width:560px;width:calc(100% - 32px);max-height:calc(100vh - 64px);box-shadow:0 12px 40px #0000002e}.print-modal::backdrop{background:#00000059}.print-modal__header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:.5px solid var(--border-3)}.print-modal__title{font-size:15px;font-weight:500;margin:0}.print-modal__close{background:transparent;border:0;font-size:18px;color:var(--fg-3);cursor:pointer;padding:4px 8px;line-height:1}.print-modal__close:hover{color:var(--fg-1)}.print-modal__body{padding:16px 20px;overflow-y:auto;max-height:calc(100vh - 200px)}.print-row{background:var(--bg-2);border:.5px solid var(--border-3);border-radius:var(--radius-md);padding:12px;margin-bottom:10px}.print-row__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.print-row__label{font-size:12px;font-weight:500;color:var(--fg-2)}.print-row__remove{background:transparent;border:0;color:var(--fg-3);cursor:pointer;font-size:14px;padding:2px 6px;border-radius:4px;line-height:1}.print-row__remove:hover:not(:disabled){color:var(--fg-1);background:var(--bg-3)}.print-row__remove:disabled{opacity:.3;cursor:not-allowed}.print-row__pillrow{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:6px}.print-row__pillrow:last-child{margin-bottom:0}.print-row__pilllabel{font-size:11px;color:var(--fg-3);width:60px;flex-shrink:0}.print-modal__add{width:100%;background:transparent;border:1px dashed var(--border-2);color:var(--fg-2);padding:9px;border-radius:var(--radius-md);cursor:pointer;font-size:12px;font-family:inherit;margin-top:4px}.print-modal__add:hover{border-color:var(--border-1);color:var(--fg-1)}.print-modal__footer{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;border-top:.5px solid var(--border-3);gap:8px}.print-modal__annot{font-size:11px;color:var(--fg-3)}.print-modal__actions{display:flex;gap:6px}.print-modal__btn{height:32px;padding:0 14px;border-radius:999px;font-size:12px;cursor:pointer;font-family:inherit;border:.5px solid var(--border-2);background:var(--bg-1);color:var(--fg-2);display:inline-flex;align-items:center;gap:6px}.print-modal__btn:hover{color:var(--fg-1);border-color:var(--border-1)}.print-modal__btn--primary{background:var(--em-strong);color:var(--em-fg-on-emph);border-color:var(--em-strong)}.print-modal__btn--primary:hover{background:var(--em-emph);border-color:var(--em-emph);color:var(--em-fg-on-emph)}.print-modal__btn--primary:disabled{opacity:.4;cursor:not-allowed}#print-root{display:none}@media print{body>*:not(#print-root){display:none!important}#print-root{display:block!important;padding:0}.print-header{font-size:16pt;font-weight:500;margin:18mm 0 10mm;text-align:center;letter-spacing:-.01em}.print-sheet{break-inside:avoid;margin-bottom:18mm}.print-sheet[data-large=true]{break-after:page}.print-sheet:last-child{margin-bottom:0}body{background:#fff;color:#000}@page{size:A4;margin:18mm 15mm}}
