:root{--paper: #ffffff;--bg: #f4f6f8;--bg-2: #eef1f4;--bg-3: #e7ebf0;--ink: #1a2230;--ink-2: #5b6776;--ink-3: #8a94a0;--line: #e1e5ea;--line-2: #d3dae2;--accent: #2f6df0;--accent-soft: #e8f0fe;--accent-ink: #1b4fc0;--fn-t: #2e7d5b;--fn-pd: #b8860b;--fn-d: #c0392b;--fn-chr: #7d5ba6;--fn-t-soft: #e3f2ea;--fn-pd-soft: #f6eed7;--fn-d-soft: #f7e2df;--fn-chr-soft: #efe7f5;--radius: 10px;--radius-sm: 6px;--shadow: 0 1px 2px rgba(20,30,48,.06), 0 6px 18px rgba(20,30,48,.08);--shadow-lg: 0 10px 40px rgba(20,30,48,.18);--mono: "SF Mono", ui-monospace, "Cascadia Code", "JetBrains Mono", Menlo, Consolas, monospace;--sans: -apple-system, system-ui, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--topbar-h: 46px;--menubar-h: 34px;--rail-w: 232px;--inspector-w: 340px}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--sans);color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased}.app{display:grid;grid-template-rows:auto auto auto 1fr;height:100%}.workspace{position:relative;display:grid;grid-template-columns:var(--rail-w) 1fr var(--inspector-w);min-height:0}.workspace.rail-collapsed{grid-template-columns:0 1fr var(--inspector-w)}.rail,.inspector{background:var(--paper);overflow-y:auto;min-height:0}.rail{border-right:1px solid var(--line)}.rail.collapsed{overflow:hidden;border-right:0}.rail-toggle{position:absolute;top:50%;left:var(--rail-w);transform:translate(-50%,-50%);z-index:5;width:18px;height:40px;padding:0;display:flex;align-items:center;justify-content:center;border:1px solid var(--line-2);border-radius:6px;background:var(--paper);color:var(--ink-3);box-shadow:var(--shadow);cursor:pointer;font-size:13px;line-height:1;transition:left .12s ease,color .12s ease,background .12s ease}.rail-toggle:hover{color:var(--ink);background:var(--bg-2)}.workspace.rail-collapsed .rail-toggle{left:0;transform:translate(-2px,-50%)}.right-col{display:flex;flex-direction:column;min-height:0;border-left:1px solid var(--line);background:var(--paper)}.right-col .inspector{flex:1 1 auto;border-left:0}.canvas{overflow:auto;background:var(--bg);padding:16px 18px;min-height:0}.viz-panel{border-bottom:1px solid var(--line);flex:none}.viz-head{display:flex;align-items:center;gap:6px;width:100%;padding:11px 16px;background:transparent;border:0;cursor:pointer;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);text-align:left}.viz-head:hover{color:var(--ink-2)}.viz-chevron{font-size:10px;width:10px}.viz-body{padding:0 16px 16px}.viz-item-label{font-size:11px;color:var(--ink-3);margin-bottom:8px}.circle-of-fifths{display:block;margin:0 auto;max-width:100%}.cof-seg{fill:var(--paper);stroke:var(--line-2);stroke-width:1}.cof-seg.active{fill:var(--accent-soft);stroke:var(--accent)}.cof-label{font-family:var(--mono);fill:var(--ink-2);pointer-events:none;-webkit-user-select:none;user-select:none}.cof-label-outer{font-size:13px}.cof-label-inner{font-size:11px;fill:var(--ink-3)}.cof-label.active{fill:var(--accent-ink);font-weight:700}.topbar{display:flex;align-items:center;gap:14px;height:var(--topbar-h);padding:0 14px;background:var(--paper);border-bottom:1px solid var(--line)}.brand{font-weight:800;font-size:17px;letter-spacing:-.02em;margin:0}.brand .y{color:var(--accent)}.transport button{padding:5px 8px}.transport .measure-readout{font-family:var(--mono);font-size:12px;color:var(--ink-2);min-width:38px;text-align:center;-webkit-user-select:none;user-select:none}.history-controls{gap:2px}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;color:var(--ink-2)}.icon-btn:not(:disabled):hover{color:var(--ink)}.icon-btn:disabled{color:var(--ink-3);opacity:.5}.song-name{font-size:13px;color:var(--ink);border:1px solid transparent;background:transparent;width:150px;border-left:1px solid var(--line);border-radius:0;padding:3px 7px 3px 12px}.song-name:hover{background:var(--bg-2);border-radius:6px}.song-name:focus{outline:none;background:var(--bg);border-radius:6px}.legend{display:flex;gap:12px;font-size:11px;color:var(--ink-2)}.legend span.item{display:inline-flex;align-items:center;gap:5px}.dot{width:9px;height:9px;border-radius:999px;display:inline-block;background:var(--fn, var(--ink-3))}.spacer{flex:1}.menubar{display:flex;align-items:stretch;gap:2px;height:var(--menubar-h);padding:0 8px;background:var(--bg-2);border-bottom:1px solid var(--line)}.menu{position:relative}.menu>button{height:100%;border:0;background:transparent;border-radius:6px;padding:0 12px;font-size:13px;color:var(--ink);cursor:pointer}.menu>button:hover,.menu.open>button{background:var(--bg-3)}.menu-pop{position:absolute;top:100%;left:0;min-width:210px;z-index:100;background:var(--paper);border:1px solid var(--line-2);border-radius:8px;box-shadow:var(--shadow-lg);padding:5px;margin-top:2px}.menu-item{display:flex;align-items:center;gap:10px;width:100%;border:0;background:transparent;border-radius:6px;cursor:pointer;padding:7px 9px;font-size:13px;color:var(--ink);text-align:left}.menu-item:hover{background:var(--accent-soft);color:var(--accent-ink)}.menu-item[disabled]{color:var(--ink-3);cursor:default;background:transparent}.menu-item .check{width:14px;color:var(--accent)}.menu-item .sc{margin-left:auto;color:var(--ink-3);font-size:11px;font-family:var(--mono)}.menu-sep{height:1px;background:var(--line);margin:5px 4px}.menu-label{padding:6px 9px 3px;font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3)}.toolbar{display:flex;align-items:center;gap:12px;padding:6px 14px;background:var(--paper);border-bottom:1px solid var(--line)}.toolbar .tool-sep{width:1px;align-self:stretch;margin:2px;background:var(--line)}.tool-field{display:inline-flex;align-items:center;gap:6px;font-size:12px}button,.btn{font-family:var(--sans);font-size:13px;border:1px solid var(--line-2);background:var(--paper);color:var(--ink);border-radius:var(--radius-sm);padding:5px 10px;cursor:pointer;display:inline-flex;align-items:center;gap:6px}button:hover,.btn:hover{border-color:var(--accent);color:var(--accent-ink)}button.primary{background:var(--accent);border-color:var(--accent);color:#fff}button.primary:hover{filter:brightness(1.05);color:#fff}button.ghost{border-color:transparent;background:transparent}button.ghost:hover{background:var(--bg-2);color:var(--ink)}button:disabled{opacity:.5;cursor:default}.seg{display:inline-flex;border:1px solid var(--line-2);border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-2)}.seg button{border:0;border-radius:0;background:transparent;padding:5px 11px;color:var(--ink-2)}.seg button.active{background:var(--paper);color:var(--ink);font-weight:600}select,input[type=text],input[type=number]{font-family:var(--sans);font-size:13px;color:var(--ink);border:1px solid var(--line-2);border-radius:var(--radius-sm);background:var(--paper);padding:4px 7px}.eyebrow{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);font-weight:700}.muted{color:var(--ink-2)}.faint{color:var(--ink-3)}.row{display:flex;align-items:center;gap:10px}.rail-sec{padding:12px;border-bottom:1px solid var(--line)}.rail-sec h4{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);margin:0 0 8px}.struct-item{display:flex;align-items:center;gap:9px;padding:7px 9px;border-radius:var(--radius-sm);cursor:pointer;font-size:13px}.struct-item:hover{background:var(--bg-2)}.struct-item.active{background:var(--accent-soft);color:var(--accent-ink);font-weight:600}.mark{font-family:var(--mono);font-weight:700;min-width:20px;height:20px;display:grid;place-items:center;background:var(--bg-3);border-radius:4px;font-size:11px;color:var(--ink-2)}.struct-item.active .mark{background:var(--accent);color:#fff}.struct-item .del{margin-left:auto;opacity:0}.struct-item:hover .del{opacity:.7}.struct-item[draggable=true]{cursor:grab}.struct-item.dragging{opacity:.4}.struct-item.drop-target{box-shadow:inset 0 2px 0 var(--accent)}.struct-menu{position:fixed;top:0;left:0}.struct-rename{flex:1;min-width:0;font-size:13px;font-family:inherit;padding:1px 4px;border:1px solid var(--accent);border-radius:4px;background:var(--paper);color:var(--ink)}.toolstrip{display:flex;align-items:center;gap:10px;margin-bottom:12px}.lane-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;width:fit-content;min-width:480px;max-width:100%}.lane-head{font-size:11px;color:var(--ink-3);padding:6px 12px;letter-spacing:.05em;text-transform:uppercase;background:var(--bg-2);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:8px}.lane-head .note{margin-left:auto;text-transform:none;letter-spacing:0}.lane-head .lane-gear{width:24px;height:24px;margin:-4px -4px -4px auto;border:0;background:transparent;border-radius:0}.lane-head .lane-gear:hover{border:0;background:transparent}.lane-scroll{overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.lane-scroll::-webkit-scrollbar{display:none}.staff-lane{display:block;background:var(--paper);border-top:1px solid var(--line)}.staff-line{stroke:var(--ink-3);stroke-width:1}.staff-brace{stroke:var(--ink-2);stroke-width:1.5}.notehead{fill:var(--ink)}.accidental{fill:var(--ink-2);font-size:12px;font-family:var(--sans)}.voice-line{stroke-width:1.5;stroke-dasharray:2 3;opacity:.75}.opt-text{display:flex;flex-direction:column;gap:2px;text-align:left}.measure-ruler{position:relative;background:var(--bg-2)}.measure-cell{position:absolute;top:0;height:100%;border:0;border-left:1px solid var(--line);background:transparent;font-family:var(--mono);font-size:11px;color:var(--ink-3);display:grid;place-items:center;cursor:context-menu}.measure-cell:hover{background:var(--bg-3);color:var(--ink-2)}.measure-cell.active{background:var(--accent-soft);color:var(--accent-ink);font-weight:600}.measure-cell.is-selected{background:color-mix(in srgb,var(--accent) 28%,transparent);color:var(--accent-ink);font-weight:600;box-shadow:inset 0 0 0 1px var(--accent)}.measure-cell.is-selected:hover{background:color-mix(in srgb,var(--accent) 38%,transparent)}.ruler-cursor{position:absolute;top:0;width:0;height:0;transform:translate(-5px);border-left:5px solid transparent;border-right:5px solid transparent;border-top:6px solid var(--accent);z-index:3;pointer-events:none}.measure-insert{position:absolute;top:0;height:100%;width:18px;transform:translate(-50%);border:0;background:transparent;padding:0;cursor:pointer;z-index:2;color:var(--accent);font-size:13px;line-height:1;opacity:0;display:grid;place-items:center}.measure-insert:hover,.measure-insert:focus-visible{opacity:1;background:var(--accent-soft)}.measure-pop{position:fixed;margin-top:2px}.paste-prompt-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;place-items:center;background:#00000040}.paste-prompt{position:static;min-width:220px}.measure-custom{display:flex;align-items:center;gap:6px;padding:2px 4px}.measure-custom input{width:56px}.insp-empty{padding:18px 16px;color:var(--ink-3);font-size:13px}.insp-head{padding:14px 16px 12px;border-bottom:1px solid var(--line)}.insp-title{font-family:var(--mono);font-size:24px;font-weight:700;color:var(--fn, var(--ink))}.insp-roman{font-family:var(--mono);font-size:14px;color:var(--fn, var(--ink-2))}.insp-fn{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--fn);border:1px solid var(--fn);border-radius:4px;padding:1px 6px}.insp-alts{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin-top:8px}.insp-alts-label{font-size:10px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3)}.alt-chip{gap:6px;padding:2px 9px;border-radius:999px;font-family:var(--mono);font-size:12px}.alt-chip .sym{font-weight:650}.alt-chip .rn{font-size:11px}.insp-sec{padding:14px 16px;border-bottom:1px solid var(--line)}.insp-sec:last-child{border-bottom:0}.insp-sec>.eyebrow{margin-bottom:10px}.field-grid{display:grid;grid-template-columns:auto 1fr;gap:9px 10px;align-items:center;font-size:13px}.field-grid label{color:var(--ink-2)}.collapsible{border-top:2px solid var(--line-2)}.collapsible-header{display:flex;align-items:center;gap:9px;width:100%;padding:11px 0;border:0;background:transparent;cursor:pointer;font-size:11px;letter-spacing:.08em;text-transform:uppercase;font-weight:700;color:var(--ink-3);text-align:left}.collapsible-header:hover,.collapsible-header:hover .collapsible-chevron{color:var(--ink)}.collapsible-chevron{width:16px;font-size:15px;line-height:1;color:var(--ink-2);transition:transform .12s ease}.collapsible-body{padding:0 0 12px}.icon-play{width:24px;height:24px;padding:0;justify-content:center;border-radius:999px;font-size:9px;line-height:1;color:var(--fn, var(--accent));border-color:var(--line-2)}.icon-play:hover{background:var(--fn-soft, var(--accent-soft));border-color:var(--fn, var(--accent));color:var(--fn, var(--accent-ink))}.quick-qual{margin-bottom:12px}.quick-qual>.faint{display:block;margin-bottom:6px}.quick-qual .reharm-qual{margin-bottom:0}.reharm-qual{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}.qchip{display:inline-flex;align-items:stretch;overflow:hidden;border:1px solid var(--line-2);border-radius:999px;font-family:var(--mono);font-size:12.5px}.qchip.current{border-color:var(--fn, var(--accent));background:var(--fn-soft, var(--accent-soft))}.qchip-main{border:0;border-radius:0;background:transparent;padding:4px 5px 4px 11px;color:var(--ink)}.qchip-main:hover{background:var(--bg-2);color:var(--ink)}.qchip-play{border:0;border-radius:0;background:transparent;padding:4px 9px 4px 4px;color:var(--ink-3);font-size:8px}.qchip-play:hover{background:var(--bg-2);color:var(--accent-ink)}.reharm-group{margin-bottom:10px}.reharm-tier{display:flex;align-items:center;gap:5px;font-size:10px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3);margin-bottom:5px}.info-badge{display:inline-grid;place-items:center;width:13px;height:13px;border:1px solid var(--line-2);border-radius:999px;font-family:var(--mono);font-size:9px;font-weight:700;line-height:1;letter-spacing:0;text-transform:none;color:var(--ink-3);cursor:help;-webkit-user-select:none;user-select:none}.info-badge:hover,.info-badge:focus-visible{color:var(--accent-ink);border-color:var(--accent);outline:none}.app-tooltip{position:fixed;z-index:1000;padding:9px 11px;background:var(--ink);color:#fff;font-size:11.5px;line-height:1.5;font-weight:400;letter-spacing:0;text-transform:none;border-radius:7px;box-shadow:var(--shadow-lg);pointer-events:none}.app-tooltip-title{font-weight:700;margin-bottom:3px}.reharm-rows{display:flex;flex-direction:column;gap:4px}.reharm-desc{margin:0 0 10px;font-size:12px;color:var(--ink-2);line-height:1.5}.reharm-row{display:flex;align-items:stretch;gap:6px}.reharm-apply{flex:1;justify-content:flex-start;gap:8px}.reharm-apply:hover{border-color:var(--fn, var(--accent));color:var(--ink)}.reharm-apply .sym{font-family:var(--mono);font-weight:650}.reharm-apply .rn{font-family:var(--mono);font-size:12px;margin-left:auto;color:var(--fn, var(--ink-2))}.pm-option{align-items:center}.pm-check{width:14px;flex:none;text-align:center;color:var(--accent-ink);font-size:11px;font-weight:700}.pm-option.selected{border-color:var(--accent);background:var(--accent-soft);color:var(--ink)}.pm-option.selected .rn{color:var(--accent-ink)}.reharm-play{width:32px;padding:0;justify-content:center;color:var(--ink-3);font-size:9px}.reharm-play:hover{border-color:var(--accent);color:var(--accent-ink)}.reharm-star{display:inline-grid;place-items:center;width:15px;height:15px;flex:none;border:1px solid #c9a000;border-radius:999px;font-size:9px;line-height:1;color:#b8860b;cursor:help;-webkit-user-select:none;user-select:none}.reharm-star:hover,.reharm-star:focus-visible{color:#7a5800;border-color:#7a5800;outline:none}.reharm-row--dim{opacity:.55}.reharm-row--dim .reharm-apply{border-style:dashed}.fit-pie{display:inline-block;flex:none;border-radius:50%;background:conic-gradient(var(--fit-color, var(--accent)) calc(var(--fit-pct, 0) * 1%),var(--bg-3) 0);box-shadow:inset 0 0 0 1px var(--line-2)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#141e3052;z-index:200;display:grid;place-items:center}.modal{background:var(--paper);border-radius:var(--radius);box-shadow:var(--shadow-lg);width:420px;max-width:calc(100vw - 32px);overflow:hidden}.modal-head{padding:14px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center}.modal-head h3{margin:0;font-size:15px}.modal-body{padding:16px 18px}.modal-foot{padding:12px 18px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:8px}.device-list{display:flex;flex-direction:column;gap:6px;max-height:240px;overflow-y:auto}.device{display:flex;align-items:center;gap:10px;padding:9px 11px;border:1px solid var(--line-2);border-radius:8px;cursor:pointer;font-size:13px}.device:hover{border-color:var(--accent)}.device.sel{border-color:var(--accent);background:var(--accent-soft)}.device .radio{width:14px;height:14px;border-radius:999px;border:2px solid var(--line-2)}.device.sel .radio{border-color:var(--accent);background:var(--accent);box-shadow:inset 0 0 0 2px #fff}.modal.modal-wide{width:560px}.reharm-controls{display:flex;flex-direction:column;gap:6px;align-items:flex-end}.reharm-controls .seg{font-size:11px}.reharm-controls .seg button{padding:3px 9px}.seg-tabs button{padding:6px 14px;font-size:13px}.reharm-toolbar{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end;margin-bottom:14px;font-size:11px}.reharm-toolbar .seg button{padding:4px 10px}.reharm-trigger{margin-left:auto;border:1px solid var(--accent);color:var(--accent-ink);background:var(--accent-soft);border-radius:var(--radius-sm);padding:4px 10px;font-size:12px;font-weight:600;cursor:pointer}.reharm-trigger:hover{background:var(--accent);color:#fff}.lane-head .reharm-trigger{margin-left:auto}.lane-head .reharm-trigger~.lane-gear{margin-left:0}.reharm-context{display:flex;align-items:center;gap:10px;margin-bottom:14px;padding:8px 10px;border:1px dashed var(--line-2);border-radius:8px}.ctx-chip{font-family:var(--mono);font-size:13px;padding:2px 8px;border:1px solid var(--line-2);border-radius:6px;background:var(--bg-2)}.ctx-chip.faded{opacity:.45}.ctx-gap{flex:1;text-align:center;font-size:11px;color:var(--ink-3);letter-spacing:.04em;text-transform:uppercase}.reharm-variants{display:flex;flex-direction:column;gap:6px;max-height:360px;overflow-y:auto}.reharm-variant{display:flex;align-items:center;gap:10px;padding:8px 10px;border:1px solid var(--line-2);border-radius:8px}.reharm-variant:hover{border-color:var(--accent)}.reharm-variant.playing{border-color:var(--accent);background:var(--accent-soft)}.rv-main{flex:1;min-width:0}.rv-chords{display:flex;flex-wrap:wrap;gap:5px}.rv-chip{font-family:var(--mono);font-weight:650;font-size:13px;padding:2px 8px;border-radius:6px;border:1px solid var(--fn, var(--line-2));color:var(--ink);background:color-mix(in srgb,var(--fn, var(--accent)) 10%,transparent)}.rv-chip-btn{cursor:pointer;font:inherit}.rv-chip-btn:hover{border-color:var(--fn, var(--accent));background:color-mix(in srgb,var(--fn, var(--accent)) 22%,transparent)}.rv-chip.locked{border-color:var(--fn, var(--accent));background:color-mix(in srgb,var(--fn, var(--accent)) 28%,transparent);box-shadow:0 0 0 1px var(--fn, var(--accent)) inset}.rv-lock{font-size:10px;margin-right:3px;vertical-align:1px}.reharm-locks{display:flex;align-items:center;gap:10px;margin-bottom:10px;font-size:12px}.reharm-locks-info{flex:1;min-width:0}.reharm-locks-clear{border:1px solid var(--line-2);color:var(--ink-2);background:var(--bg-2);border-radius:var(--radius-sm);padding:3px 10px;font-size:11px;cursor:pointer}.reharm-locks-clear:hover{border-color:var(--accent);color:var(--accent-ink)}.rv-meta{display:flex;align-items:center;gap:8px;margin-top:5px}.rv-strategy{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--accent-ink);background:var(--accent-soft);border-radius:999px;padding:2px 8px;white-space:nowrap}.rv-rn{font-family:var(--mono);font-size:11px;color:var(--ink-3)}.rv-apply{border:1px solid var(--accent);color:var(--accent-ink);background:var(--paper);border-radius:var(--radius-sm);padding:5px 12px;font-size:12px;font-weight:600;cursor:pointer}.rv-apply:hover{background:var(--accent);color:#fff}::-webkit-scrollbar{width:11px;height:11px}::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:8px;border:3px solid transparent;background-clip:content-box}
