@import "https://fonts.googleapis.com/css2?family=Silkscreen:wght@400;700&family=VT323&display=swap";:root{--bg-primary:#15131a;--bg-secondary:#100e15;--bg-tertiary:#0b0a10;--text-primary:#e8e8f0;--text-energy:#d8d8e0;--text-secondary:#b8b0a0;--text-tertiary:#8a8278;--text-quaternary:#6a6258;--text-trace:#4a4238;--border-primary:#2a2420;--border-secondary:#1f1a18;--border-subtle:#120f0c;--color-mute-red:#c03030;--color-solo-green:#88c898;--color-solo-bg:#2c3828;--color-solo-border:#4a6840;--color-amber-flash:#f4c878;--pc-c-note:#d86868;--pc-c-bg:#4a2f30;--pc-d-note:#90b060;--pc-d-bg:#3d4628;--pc-e-note:#c8b840;--pc-e-bg:#4a4226;--pc-f-note:#d89060;--pc-f-bg:#4a3826;--pc-g-note:#70c080;--pc-g-bg:#2c4232;--pc-a-note:#88b8d8;--pc-a-bg:#2a3a48;--pc-b-note:#b890d8;--pc-b-bg:#3c2d4a;--pc-sharp-bg:#0c0a08;--row-natural-bg:#1a1f24;--row-sharp-bg:#0c0a08;--note-default:#5a6878;--font-label:"Silkscreen", ui-monospace, monospace;--font-readout:"VT323", ui-monospace, monospace}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--font-readout);background:var(--bg-primary);color:var(--text-primary);font-size:16px}@media (width>=1600px){body{zoom:1.2}}@media (width>=2400px){body{zoom:1.4}}.app{flex-direction:column;height:100%;min-height:100vh;display:flex;position:relative}.app:before{content:"";pointer-events:none;mix-blend-mode:overlay;z-index:100;background:repeating-linear-gradient(0deg,#d8d8e005 0 1px,#0000 1px 3px);position:fixed;inset:0}.app:after{content:"";pointer-events:none;z-index:101;background:radial-gradient(#0000 50%,#00000073 100%);position:fixed;inset:0}.header{background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);flex-shrink:0;align-items:center;gap:10px;height:40px;padding:0 14px;display:flex}.header-status-dot{background:var(--text-energy);border-radius:50%;flex-shrink:0;width:7px;height:7px;box-shadow:0 0 8px #d8d8e099}.title{font-family:var(--font-label);letter-spacing:.08em;text-transform:uppercase;color:var(--text-energy);text-shadow:0 0 6px #d8d8e059;flex-shrink:0;font-size:13px}.header-divider{background:var(--border-primary);flex-shrink:0;width:1px;height:18px}.song-name-button{font-family:var(--font-readout);color:var(--text-primary);cursor:pointer;text-overflow:ellipsis;white-space:nowrap;background:0 0;border:1px solid #0000;border-radius:2px;flex-shrink:0;max-width:200px;padding:2px 8px;font-size:15px;transition:background 80ms,border-color 80ms;overflow:hidden}.song-name-button:hover{border-color:var(--border-primary);color:var(--text-energy);background:#d8d8e00d}.pill-toggle{background:var(--bg-tertiary);border:1px solid var(--border-primary);cursor:pointer;font-family:var(--font-label);letter-spacing:.08em;text-transform:uppercase;border-radius:2px;flex-shrink:0;align-items:center;gap:6px;padding:3px 8px;font-size:9px;transition:background 80ms,border-color 80ms,color 80ms;display:inline-flex}.pill-toggle:hover{border-color:var(--text-quaternary)}.pill-label{color:var(--text-tertiary)}.pill-state{color:var(--text-quaternary)}.pill-toggle.on{border-color:#4a4038}.pill-toggle.on .pill-state{color:var(--text-energy);text-shadow:0 0 4px #d8d8e066}.pill-toggle.impr-pill{gap:5px}.impr-slider{width:48px;accent-color:var(--text-energy);cursor:pointer;margin:0 2px}.impr-readout{font-family:var(--font-readout);color:var(--text-energy);font-variant-numeric:tabular-nums;text-transform:none;letter-spacing:0;text-align:right;min-width:26px;font-size:13px}.grid-pill .pill-state{color:var(--text-energy);text-transform:none;letter-spacing:0;font-family:var(--font-readout);font-size:13px}.grid-pill{gap:6px}.header-spacer{flex:1}.header-selection{font-family:var(--font-readout);color:var(--text-secondary);font-variant-numeric:tabular-nums;flex-shrink:0;align-items:center;gap:6px;margin-right:6px;font-size:14px;display:inline-flex}.header-sel-label{font-family:var(--font-label);letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary);font-size:9px}.header-sel-value{color:var(--text-energy)}.header-icon-button{border:1px solid var(--border-primary);width:22px;height:22px;color:var(--text-tertiary);cursor:pointer;font-family:var(--font-readout);background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:15px;font-style:italic;display:inline-flex}.header-icon-button:hover{color:var(--text-energy);border-color:var(--text-quaternary)}.header-overflow-button{border:1px solid var(--border-primary);width:22px;height:22px;color:var(--text-tertiary);cursor:pointer;font-family:var(--font-readout);background:0 0;border-radius:2px;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:16px;display:inline-flex}.header-overflow-button:hover{color:var(--text-energy);border-color:var(--text-quaternary)}.header-overflow-button.rendering{color:var(--color-solo-green);border-color:var(--color-solo-border)}.header-overflow-menu{background:var(--bg-secondary);border:1px solid var(--border-primary);z-index:60;border-radius:2px;flex-direction:column;min-width:180px;padding:4px 0;display:flex;position:absolute;top:36px;right:12px;box-shadow:0 6px 20px #0009}.help-panel{width:min(680px,92vw);max-height:80vh}.help-body{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px 18px;display:grid}.help-section{flex-direction:column;gap:6px;display:flex}.help-section-title{font-family:var(--font-label);letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary);border-bottom:1px solid var(--border-secondary);margin:0;padding-bottom:3px;font-size:9px}.help-entries{flex-direction:column;gap:3px;margin:0;display:flex}.help-entry{grid-template-columns:minmax(110px,auto) 1fr;align-items:baseline;gap:10px;display:grid}.help-keys{flex-wrap:wrap;align-items:center;gap:2px;margin:0;display:inline-flex}.help-plus{color:var(--text-tertiary);margin:0 1px;font-size:12px}.help-label{font-family:var(--font-readout);color:var(--text-primary);margin:0;font-size:14px}.about-panel{width:min(480px,92vw)}.about-body{gap:12px}.about-name{font-family:var(--font-label);letter-spacing:.1em;text-transform:uppercase;color:var(--text-energy);text-shadow:0 0 6px #d8d8e066;font-size:15px}.about-version{font-family:var(--font-readout);color:var(--text-tertiary);margin-top:-8px;font-size:13px}.about-text{font-family:var(--font-readout);color:var(--text-primary);margin:0;font-size:15px;line-height:1.5}.about-credits{border-top:1px solid var(--border-secondary);flex-direction:column;gap:6px;padding-top:10px;display:flex}.about-credit-row{font-family:var(--font-readout);color:var(--text-secondary);grid-template-columns:140px 1fr;align-items:baseline;gap:10px;font-size:14px;display:grid}.about-credit-label{font-family:var(--font-label);letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary);font-size:9px}.about-credit-row a{color:var(--color-solo-green);text-decoration:none}.about-credit-row a:hover{text-decoration:underline}.dim{color:var(--text-tertiary)}.chord-mode-display{background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);border-top:1px solid var(--border-primary);height:32px;font-family:var(--font-readout);grid-template-columns:1fr auto 1fr;align-items:center;gap:16px;padding:0 16px;font-size:14px;display:grid}.chord-mode-content{justify-self:start;align-items:center;gap:8px;min-width:0;display:flex;overflow:hidden}.chord-mode-right{font-family:var(--font-readout);color:var(--text-secondary);font-variant-numeric:tabular-nums;justify-self:end;align-items:center;gap:6px;font-size:14px;display:inline-flex}.chord-mode-right .cmr-label{font-family:var(--font-label);letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary);font-size:9px}.chord-mode-right .cmr-value{color:var(--text-energy)}.cmd-label{font-family:var(--font-label);letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary);font-size:9px}.cmd-value{color:var(--text-energy);text-shadow:0 0 4px #d8d8e059;font-weight:400;font-family:var(--font-label);letter-spacing:.05em;text-transform:uppercase;font-size:11px}.cmd-desc{color:var(--text-secondary);font-size:14px;font-style:italic}.cmd-pos{color:var(--text-tertiary);font-variant-numeric:tabular-nums}.cmd-placeholder{color:var(--text-tertiary);font-style:italic}.mode-compass{flex-direction:column;flex-shrink:0;align-items:center;width:320px;height:32px;display:flex;position:relative}.compass-track{justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative;overflow:hidden}.compass-track:before{content:"";pointer-events:none;z-index:0;background:#d8d8e01f;width:1px;position:absolute;top:4px;bottom:4px;left:50%}.compass-track:after{content:"";pointer-events:none;background:linear-gradient(to right, var(--bg-secondary) 0, transparent 32px), linear-gradient(to left, var(--bg-secondary) 0, transparent 32px);z-index:2;position:absolute;inset:0}.compass-step{font-family:var(--font-label);letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);z-index:1;flex-shrink:0;justify-content:center;align-items:center;font-size:9px;transition:opacity .15s,color .15s;display:inline-flex}.compass-step:not(.active){width:28px}.compass-step-1{opacity:.55}.compass-step-2{opacity:.32}.compass-step-3{opacity:.16}.compass-step.active{opacity:1;width:auto;min-width:96px;padding:0 12px;position:relative}.compass-active{flex-direction:column;align-items:center;gap:0;line-height:1;display:flex}.compass-active-name{font-family:var(--font-label);letter-spacing:.06em;text-transform:uppercase;color:var(--text-energy);text-shadow:0 0 4px #d8d8e066;white-space:nowrap;font-size:11px}.compass-active-desc{font-family:var(--font-readout);color:var(--text-secondary);white-space:nowrap;margin-top:1px;font-size:12px;font-style:italic}.compass-step.active:after{content:"";background:var(--text-energy);width:2px;height:3px;position:absolute;bottom:-3px;left:50%;transform:translate(-50%);box-shadow:0 0 3px #d8d8e099}.compass-info-btn{border:1px solid var(--border-primary);color:var(--text-tertiary);font-family:var(--font-readout);cursor:pointer;z-index:3;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;margin-left:8px;padding:0;font-size:13px;font-style:italic;display:inline-flex}.compass-info-btn:hover{color:var(--text-energy);border-color:var(--text-quaternary)}.compass-axis-labels{font-family:var(--font-label);letter-spacing:.08em;text-transform:uppercase;color:var(--text-trace);pointer-events:none;justify-content:space-between;font-size:8px;display:flex;position:absolute;bottom:-10px;left:0;right:0}.chord-mode-display{height:36px}.timeline-strip{background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);flex-shrink:0;align-items:stretch;gap:12px;height:80px;padding:8px 12px;display:flex;overflow:auto hidden}.timeline-rail{flex-shrink:0;height:100%;position:relative}.timeline-tick{background:var(--border-secondary);pointer-events:none;width:1px;position:absolute;top:0;bottom:0}.timeline-tick.major{background:var(--border-primary)}.block-tile{background:var(--bg-secondary);border:1px solid var(--border-primary);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:2px;flex-direction:column;justify-content:space-between;padding:5px 8px;transition:background 80ms,border-color 80ms;display:flex;position:absolute;top:4px;bottom:4px;overflow:hidden}.block-tile:hover{border-color:var(--text-quaternary);background:#d8d8e00a}.block-tile.active{border-color:var(--text-quaternary);background:#d8d8e012;box-shadow:0 0 8px #d8d8e01a}.block-tile-name{font-family:var(--font-label);letter-spacing:.06em;text-transform:uppercase;color:var(--text-energy);text-overflow:ellipsis;white-space:nowrap;font-size:10px;overflow:hidden}.block-tile.active .block-tile-name{text-shadow:0 0 4px #d8d8e066}.block-tile-meta{font-family:var(--font-readout);color:var(--text-tertiary);text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.timeline-add{flex-shrink:0;align-self:center;margin-left:auto}.timeline-playhead{background:var(--text-energy);pointer-events:none;z-index:5;width:2px;margin-left:-1px;position:absolute;top:0;bottom:0;box-shadow:0 0 6px #d8d8e080}.song-loop-tint{pointer-events:none;z-index:0;background:#d8d8e00a;position:absolute;top:0;bottom:0}.song-bracket{pointer-events:none;z-index:4;width:1px;margin-left:-.5px;position:absolute;top:0;bottom:0}.song-bracket-line{width:2px;height:100%}.song-bracket.auto .song-bracket-line{background:repeating-linear-gradient(to bottom, var(--color-solo-border) 0, var(--color-solo-border) 4px, transparent 4px, transparent 8px)}.song-bracket.manual .song-bracket-line{background:var(--color-solo-green);box-shadow:0 0 4px #88c89880}.transport-bar{background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);flex-shrink:0;align-items:center;gap:8px;height:34px;padding:0 14px;display:flex}.transport-btn{background:var(--bg-tertiary);border:1px solid var(--border-primary);cursor:pointer;font-family:var(--font-label);letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);border-radius:2px;align-items:center;gap:6px;padding:4px 10px;font-size:11px;transition:background 80ms,border-color 80ms,color 80ms;display:inline-flex}.transport-btn:hover:not(:disabled){border-color:var(--text-quaternary);color:var(--text-energy)}.transport-btn:disabled{opacity:.4;cursor:not-allowed}.transport-btn.active{border-color:var(--color-solo-border);color:var(--color-solo-green)}.transport-btn.loop.on{border-color:var(--color-solo-border);background:var(--color-solo-bg);color:var(--color-solo-green);text-shadow:0 0 4px #88c89866}.transport-icon{font-size:13px;line-height:1}.transport-label{font-size:10px}.timeline-resize-handle{background:var(--bg-tertiary);border-top:1px solid var(--border-secondary);border-bottom:1px solid var(--border-secondary);cursor:ns-resize;flex-shrink:0;height:4px}.in-out-strip{background:var(--bg-tertiary);border-bottom:1px solid var(--border-primary);height:22px;font-family:var(--font-readout);color:var(--text-secondary);flex-shrink:0;align-items:center;gap:10px;padding:0 16px;font-size:13px;display:flex}.io-section{align-items:baseline;gap:6px;display:inline-flex}.io-label{font-family:var(--font-label);letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary);font-size:9px}.io-value{color:var(--text-energy);font-variant-numeric:tabular-nums}.io-mode{font-family:var(--font-label);letter-spacing:.08em;text-transform:uppercase;border-radius:2px;padding:1px 5px;font-size:8px}.io-mode.auto{color:var(--text-tertiary);border:1px dashed var(--border-primary)}.io-mode.manual{color:var(--color-solo-green);border:1px solid var(--color-solo-border);background:var(--color-solo-bg)}.io-divider{color:var(--text-quaternary)}.io-bars{align-items:center}.io-bars-btn{background:var(--bg-tertiary);border:1px solid var(--border-primary);width:18px;height:18px;color:var(--text-secondary);font-family:var(--font-label);cursor:pointer;border-radius:2px;justify-content:center;align-items:center;padding:0;font-size:13px;line-height:1;transition:border-color 80ms,color 80ms;display:inline-flex}.io-bars-btn:hover:not(:disabled){border-color:var(--text-quaternary);color:var(--text-energy)}.io-bars-btn:disabled{opacity:.4;cursor:not-allowed}.io-bars-value{text-align:center;min-width:18px}.editor{flex:1;min-height:0;display:flex}.instrument-list{background:var(--bg-secondary);border-right:1px solid var(--border-primary);flex-direction:column;flex-shrink:0;width:140px;display:flex}.instrument-list .section-header{background:var(--bg-tertiary);border-bottom:1px solid var(--border-secondary);font-family:var(--font-label);letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary);padding:5px 8px;font-size:9px}.track-rows{flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.track-row{border-bottom:1px solid var(--border-subtle);cursor:pointer;align-items:center;gap:7px;min-height:38px;padding:7px 8px;transition:background 80ms;display:flex}.track-row:hover{background:#d8d8e006}.track-row.active{border-left:2px solid var(--text-energy);background:#d8d8e00d;padding-left:6px}.mute-indicator{cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:14px;height:14px;transition:filter 80ms;display:inline-flex}.mute-indicator:hover{filter:brightness(1.3)}.mute-indicator.on{background:#5a5868}.mute-indicator.song-muted{background:var(--color-mute-red)}.mute-indicator.song-muted-exception{border:2px solid var(--color-mute-red);background:0 0}.mute-indicator.song-muted-exception:after{content:"";background:#5a5868;border-radius:50%;width:5px;height:5px}.mute-indicator.block-muted{border:2px solid var(--text-quaternary);background:0 0}.mute-indicator.block-muted:after{content:"";background:var(--text-quaternary);border-radius:50%;width:5px;height:5px}.track-name{font-family:var(--font-readout);color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:15px;overflow:hidden}.track-row:not(.active) .track-name{color:var(--text-secondary)}.track-name-input{background:var(--bg-primary);border:1px solid var(--color-solo-border);color:var(--text-primary);font-family:var(--font-readout);border-radius:2px;flex:1;min-width:0;padding:2px 4px;font-size:15px}.track-name-input:focus{outline:none}.solo-btn{width:16px;height:14px;font-family:var(--font-label);letter-spacing:.06em;border:1px solid var(--border-primary);color:var(--text-quaternary);cursor:pointer;background:0 0;border-radius:2px;flex-shrink:0;justify-content:center;align-items:center;font-size:9px;transition:filter 80ms;display:inline-flex}.solo-btn:hover{filter:brightness(1.3)}.solo-btn.on{background:var(--color-solo-bg);border-color:var(--color-solo-border);color:var(--color-solo-green)}.track-menu-btn{color:var(--text-tertiary);cursor:pointer;width:16px;height:16px;font-family:var(--font-readout);background:0 0;border:1px solid #0000;border-radius:2px;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:15px;line-height:1;transition:color 80ms,border-color 80ms,background 80ms;display:inline-flex}.track-menu-btn:hover{color:var(--text-energy);border-color:var(--border-primary);background:#d8d8e00a}.add-track{margin:8px 8px 12px}.current-block-panel{border-top:1px solid var(--border-secondary);background:var(--bg-tertiary);flex-direction:column;gap:2px;margin-top:auto;padding:8px;display:flex}.cb-header{font-family:var(--font-label);letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary);font-size:9px}.cb-name,.cb-name-button{font-family:var(--font-readout);color:var(--text-primary);font-size:16px}.cb-name-button{text-align:left;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:2px;margin-left:-4px;padding:1px 4px;transition:background 80ms,border-color 80ms}.cb-name-button:hover{border-color:var(--border-primary);color:var(--text-energy);background:#d8d8e00d}.cb-meta{font-family:var(--font-readout);color:var(--text-quaternary);font-size:12px}.roll-wrap{background:var(--bg-primary);overscroll-behavior:contain;flex:1;padding:12px;overflow:auto}.chord-list{border-left:1px solid var(--border-primary);background:var(--bg-secondary);flex-direction:column;flex-shrink:0;width:152px;display:flex;overflow-y:auto}.chord-list-header{font-family:var(--font-label);letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary);border-bottom:1px solid var(--border-secondary);background:var(--bg-tertiary);padding:7px 10px;font-size:9px}.chord-list-items{margin:0;padding:4px 0;list-style:none}.chord-list-item{border-left:3px solid #0000;grid-template-rows:auto auto;grid-template-columns:22px 1fr;column-gap:8px;padding:4px 10px;display:grid}.chord-list-item .chord-index{text-align:right;color:var(--text-quaternary);font-family:var(--font-readout);font-variant-numeric:tabular-nums;grid-row:1/span 2;align-self:center;font-size:13px}.chord-list-item .chord-name{color:var(--text-secondary);font-family:var(--font-readout);font-size:14px}.chord-list-item .chord-desc{color:var(--text-tertiary);font-family:var(--font-readout);font-size:12px;font-style:italic}.chord-list-item.active{background:var(--color-solo-bg);border-left-color:var(--color-solo-border)}.chord-list-item.active .chord-name{color:var(--color-solo-green);text-shadow:0 0 4px #88c89866}.chord-list-item.active .chord-desc{color:color-mix(in srgb, var(--color-solo-green) 60%, var(--text-tertiary))}.chord-list-section{border-bottom:1px solid var(--border-secondary);flex-direction:column;display:flex}.chord-list-section:last-child{border-bottom:none}.chord-list-header .kbd-hint{float:right;font-family:var(--font-label);letter-spacing:.08em;color:var(--text-quaternary);font-size:8px}.chord-list-item.compat-full{opacity:1}.chord-list-item.compat-partial{opacity:.7}.chord-list-item.compat-low{opacity:.4}.chord-list-item.active.compat-partial,.chord-list-item.active.compat-low{opacity:1}.chord-list-item.mode-list-item .chord-name{text-transform:capitalize}.chord-list-item.clickable{cursor:pointer}.chord-list-item.clickable:hover{background:var(--bg-hover,#ffffff0a)}.chord-list-item.clickable:hover .chord-name{color:var(--text-primary)}.pattern-sidebar{width:200px}.pattern-section{border-bottom:1px solid var(--border-secondary);flex-direction:column;gap:4px;padding:8px 12px;display:flex}.pattern-section:last-child{border-bottom:none}.pattern-label{font-family:var(--font-label);letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary);justify-content:space-between;align-items:center;font-size:9px;display:flex}.pattern-readout{font-family:var(--font-readout);color:var(--text-energy);font-variant-numeric:tabular-nums;text-transform:none;letter-spacing:0;font-size:13px}.pattern-select{background:var(--bg-primary);border:1px solid var(--border-primary);color:var(--text-primary);font-family:var(--font-readout);border-radius:2px;width:100%;padding:4px 6px;font-size:14px}.pattern-select:focus{border-color:var(--color-solo-border);outline:none}.pattern-feel-desc{font-family:var(--font-readout);font-size:13px;font-style:italic}.pattern-slider{width:100%;accent-color:var(--color-solo-green);cursor:pointer}.pattern-variation-readout{font-family:var(--font-readout);color:var(--text-energy);text-shadow:0 0 4px #d8d8e066;font-variant-numeric:tabular-nums;font-size:16px}.pattern-keep-hint{font-family:var(--font-readout);font-size:12px;font-style:italic}.pattern-actions{flex-direction:row;gap:6px;display:flex}.pattern-actions .btn-new{flex:1}.roll{background:var(--bg-primary);border:1px solid var(--border-primary);width:max-content;display:grid;position:relative}.key-label{font-family:var(--font-readout);font-variant-numeric:tabular-nums;border:none;border-right:1px solid var(--border-primary);border-bottom:1px solid var(--border-subtle);-webkit-user-select:none;user-select:none;cursor:pointer;justify-content:flex-end;align-items:center;margin:0;padding:0 8px 0 0;font-size:13px;transition:filter 80ms;display:flex}.key-label:hover{filter:brightness(1.25)}.key-label:active{filter:brightness(.9)}.key-label.white{background:var(--row-natural-bg);color:var(--text-secondary)}.key-label.black{background:var(--row-sharp-bg);color:var(--text-tertiary)}.cell{border:none;border-right:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle);cursor:pointer;background-color:#0000;background-image:repeating-linear-gradient(to right, transparent 0, transparent calc(var(--subdiv-px,56px) - 1px), #d8d8e00a calc(var(--subdiv-px,56px) - 1px), #d8d8e00a var(--subdiv-px,56px));margin:0;padding:0}.cell.row-white{background-color:var(--row-natural-bg)}.cell.row-black{background-color:var(--row-sharp-bg)}.cell.bar-start{border-left:1px solid var(--border-primary);margin-left:-1px}.cell:focus,.cell:focus-visible{outline:none}.cell.out-of-scale,.key-label.out-of-scale{position:relative}.cell.out-of-scale:before,.key-label.out-of-scale:before{content:"";pointer-events:none;background:#0006;position:absolute;inset:0}.key-label.out-of-scale{color:var(--text-quaternary)}.note{--note-color:var(--note-default);cursor:grab;-webkit-user-select:none;user-select:none;border-radius:2px;transition:filter 80ms,box-shadow 80ms,background 80ms;position:absolute}.note:active{cursor:grabbing}.note-resize-handle{cursor:ew-resize;width:6px;position:absolute;top:0;bottom:0;right:0}.placement-ghost{pointer-events:none;z-index:2;background:#d8d8e00d;border:1px dashed #d8d8e038;border-radius:2px;position:absolute}.impression{background:color-mix(in oklch, var(--row-color,var(--note-default)) var(--impr-pct,12%), var(--bg-primary));pointer-events:none;z-index:0;border-radius:2px;position:absolute}.marquee{border:1px dashed var(--text-energy);pointer-events:none;z-index:10;background:#d8d8e014;position:absolute}.loop-tint{pointer-events:none;z-index:1;background:#d8d8e00a;position:absolute}.loop-bracket{cursor:ew-resize;z-index:6;justify-content:center;width:12px;margin-left:-6px;display:flex;position:absolute;top:0;bottom:0}.loop-bracket-line{width:2px;height:100%}.loop-bracket.auto .loop-bracket-line{background:repeating-linear-gradient(to bottom, var(--color-solo-border) 0, var(--color-solo-border) 4px, transparent 4px, transparent 8px)}.loop-bracket.manual .loop-bracket-line{background:var(--color-solo-green);box-shadow:0 0 4px #88c89880}.loop-bracket:hover .loop-bracket-line{filter:brightness(1.3)}.note.standalone{background:color-mix(in srgb, var(--note-color) 35%, transparent);border:1px solid var(--note-color)}.note.standalone:hover{filter:brightness(1.15)}.note.standalone.selected{background:color-mix(in srgb, var(--note-color) 50%, transparent);border:2px solid var(--text-energy);box-shadow:0 0 0 1px var(--note-color), 0 0 8px color-mix(in srgb, var(--note-color) 60%, transparent)}.note.companion{border:1px dotted var(--note-color);opacity:.85;cursor:pointer;background:0 0}.note.companion:hover{background:color-mix(in srgb, var(--note-color) 18%, transparent);opacity:1}.note.kept{background:var(--note-color);border:1px solid var(--note-color);border-left:3px solid var(--chord-color,var(--note-color))}.note.kept:hover{filter:brightness(1.15)}.note.kept.selected{background:var(--note-color);border:2px solid var(--text-energy);border-left:3px solid var(--chord-color,var(--text-energy));box-shadow:0 0 0 1px var(--note-color), 0 0 8px color-mix(in srgb, var(--note-color) 60%, transparent)}.note.standalone.playing,.note.kept.playing{background:var(--color-amber-flash);border-color:color-mix(in srgb, var(--color-amber-flash) 70%, white);box-shadow:0 0 10px #f4c878b3}.note.companion.playing{background:color-mix(in srgb, var(--color-amber-flash) 55%, transparent);border:1px solid var(--color-amber-flash);opacity:1;box-shadow:0 0 8px #f4c87880}.ctx-menu{background:var(--bg-secondary);border:1px solid var(--border-primary);z-index:60;border-radius:2px;flex-direction:column;min-width:180px;padding:4px 0;display:flex;position:fixed;box-shadow:0 6px 20px #0009}.ctx-section-header{font-family:var(--font-label);letter-spacing:.1em;text-transform:uppercase;color:var(--text-quaternary);border-top:1px solid var(--border-secondary);padding:6px 12px 3px;font-size:8px}.ctx-section-header:first-child{border-top:none}.ctx-item{text-align:left;font-family:var(--font-readout);color:var(--text-primary);cursor:pointer;background:0 0;border:none;padding:6px 14px;font-size:14px}.ctx-item:hover{background:#d8d8e00f}.ctx-item:disabled{opacity:.5;cursor:not-allowed;background:0 0}.ctx-item-danger{color:var(--color-mute-red)}.ctx-item-danger:hover{background:#c030301a}.properties-panel{background:var(--bg-secondary);border:1px solid var(--border-primary);z-index:50;min-width:240px;font-family:var(--font-readout);color:var(--text-primary);border-radius:2px;font-size:14px;position:fixed;box-shadow:0 6px 20px #0009}.properties-panel-header{border-bottom:1px solid var(--border-secondary);background:var(--bg-tertiary);justify-content:space-between;align-items:stretch;display:flex}.properties-panel-tabs{gap:0;display:flex}.properties-panel-tabs .tab{border:none;border-right:1px solid var(--border-secondary);color:var(--text-tertiary);font-family:var(--font-label);letter-spacing:.08em;text-transform:uppercase;cursor:pointer;background:0 0;padding:6px 12px;font-size:9px}.properties-panel-tabs .tab:hover:not(:disabled){color:var(--text-primary);background:#d8d8e00a}.properties-panel-tabs .tab.active{color:var(--color-solo-green);background:var(--color-solo-bg)}.properties-panel-tabs .tab:disabled{color:var(--text-quaternary);cursor:not-allowed}.properties-panel-close{color:var(--text-tertiary);cursor:pointer;font-size:20px;line-height:1;font-family:var(--font-readout);background:0 0;border:none;padding:0 12px}.properties-panel-close:hover{color:var(--text-primary)}.properties-panel-body{flex-direction:column;gap:8px;padding:10px 12px 12px;display:flex}.property-row{grid-template-columns:110px 1fr;align-items:center;gap:10px;display:grid}.property-row label{color:var(--text-tertiary);font-family:var(--font-label);letter-spacing:.08em;text-transform:uppercase;font-size:9px}.property-row input[type=number]{background:var(--bg-primary);border:1px solid var(--border-primary);color:var(--text-primary);font-family:var(--font-readout);font-variant-numeric:tabular-nums;border-radius:2px;width:100%;padding:4px 6px;font-size:15px}.property-row input[type=number]:focus{border-color:var(--color-solo-border);outline:none}.property-row input[type=number]::placeholder{color:var(--text-quaternary);font-style:italic}.property-readonly{color:var(--text-energy);font-family:var(--font-readout);font-variant-numeric:tabular-nums}.property-footnote{font-family:var(--font-readout);color:var(--text-tertiary);margin-top:2px;font-size:13px;font-style:italic}.block-properties-panel{min-width:340px}.picker-backdrop{z-index:80;background:#08070ab3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.picker{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:3px;flex-direction:column;width:min(560px,92vw);max-height:80vh;display:flex;box-shadow:0 8px 30px #000000b3}.picker-header{border-bottom:1px solid var(--border-primary);background:var(--bg-tertiary);justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.picker-title{font-family:var(--font-label);letter-spacing:.08em;text-transform:uppercase;color:var(--text-energy);text-shadow:0 0 4px #d8d8e059;font-size:11px}.picker-close{color:var(--text-tertiary);cursor:pointer;font-family:var(--font-readout);background:0 0;border:none;padding:0 8px;font-size:20px;line-height:1}.picker-close:hover{color:var(--text-primary)}.picker-body{flex-direction:column;gap:12px;padding:8px 14px 14px;display:flex;overflow-y:auto}.picker-category-header{font-family:var(--font-label);letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary);border-bottom:1px solid var(--border-secondary);margin-bottom:4px;padding:6px 0 3px;font-size:9px}.picker-items{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:4px;margin:0;padding:0;list-style:none;display:grid}.picker-item{background:var(--bg-tertiary);border:1px solid var(--border-secondary);cursor:pointer;border-radius:2px;align-items:center;gap:8px;padding:8px 8px 8px 10px;transition:background 80ms,border-color 80ms;display:flex}.picker-item-text{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.picker-item-preview{border:1px solid var(--border-primary);color:var(--text-tertiary);cursor:pointer;width:22px;height:22px;font-family:var(--font-readout);background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0 0 0 2px;font-size:12px;line-height:1;transition:background 80ms,border-color 80ms,color 80ms;display:inline-flex}.picker-item-preview:hover{color:var(--color-solo-green);border-color:var(--color-solo-border);background:#88c89814}.picker-item:hover{border-color:var(--border-primary);background:#d8d8e00a}.picker-item.current{background:var(--color-solo-bg);border-color:var(--color-solo-border)}.picker-item-name{font-family:var(--font-readout);color:var(--text-primary);font-size:15px}.picker-item.current .picker-item-name{color:var(--color-solo-green);text-shadow:0 0 4px #88c89866}.picker-item-desc{font-family:var(--font-readout);color:var(--text-tertiary);font-size:13px;font-style:italic}.song-manager{width:min(640px,92vw)}.song-list{flex-direction:column;gap:4px;margin:0 0 12px;padding:0;list-style:none;display:flex}.song-row{background:var(--bg-tertiary);border:1px solid var(--border-secondary);border-radius:2px;justify-content:space-between;align-items:center;gap:12px;padding:8px 12px;display:flex}.song-row.current{background:var(--color-solo-bg);border-color:var(--color-solo-border)}.song-row-main{cursor:pointer;flex:1;align-items:baseline;gap:12px;min-width:0;display:flex}.song-name{font-family:var(--font-readout);color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:16px;overflow:hidden}.song-row.current .song-name{color:var(--color-solo-green);text-shadow:0 0 4px #88c89866}.song-meta{font-family:var(--font-readout);color:var(--text-tertiary);flex-shrink:0;font-size:13px}.song-name-input{background:var(--bg-primary);border:1px solid var(--color-solo-border);color:var(--text-primary);font-family:var(--font-readout);border-radius:2px;flex:1;min-width:0;padding:2px 6px;font-size:16px}.song-name-input:focus{outline:none}.song-row-actions{flex-shrink:0;gap:4px;display:flex}.btn-tiny{border:1px solid var(--border-primary);color:var(--text-secondary);font-family:var(--font-label);letter-spacing:.08em;text-transform:uppercase;cursor:pointer;background:0 0;border-radius:2px;padding:3px 8px;font-size:8px}.btn-tiny:hover:not(:disabled){color:var(--text-primary);border-color:var(--text-quaternary)}.btn-tiny:disabled{opacity:.4;cursor:not-allowed}.btn-tiny-danger{color:var(--color-mute-red);border-color:#c0303066}.btn-tiny-danger:hover:not(:disabled){border-color:var(--color-mute-red);background:#c030301a}.song-create{align-self:flex-start}.mode-info-panel{min-width:380px;max-width:480px;position:fixed;top:100px;left:50%;transform:translate(-50%)}.mode-info-body{gap:10px}.mode-info-name{font-family:var(--font-label);letter-spacing:.06em;text-transform:uppercase;color:var(--text-energy);text-shadow:0 0 4px #d8d8e066;margin-bottom:2px;font-size:13px}.mode-info-section{flex-direction:column;gap:2px;display:flex}.mode-info-label{font-family:var(--font-label);letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary);font-size:9px}.mode-info-text{font-family:var(--font-readout);color:var(--text-primary);font-size:14px;line-height:1.4}.mode-info-intervals{gap:4px;display:flex}.mode-interval{font-family:var(--font-readout);color:var(--text-energy);background:var(--bg-tertiary);border:1px solid var(--border-primary);font-variant-numeric:tabular-nums;border-radius:2px;padding:1px 6px;font-size:14px}.property-row .text-input,.property-row select{background:var(--bg-primary);border:1px solid var(--border-primary);color:var(--text-primary);font-family:var(--font-readout);border-radius:2px;width:100%;padding:4px 6px;font-size:15px}.property-row .text-input:focus,.property-row select:focus{border-color:var(--color-solo-border);outline:none}.override-row .override-control{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.override-toggle{border:1px solid var(--border-primary);color:var(--text-tertiary);font-family:var(--font-label);letter-spacing:.08em;text-transform:uppercase;cursor:pointer;background:0 0;border-radius:2px;flex-shrink:0;padding:2px 6px;font-size:8px}.override-toggle.on{background:var(--color-solo-bg);border-color:var(--color-solo-border);color:var(--color-solo-green)}.override-toggle:hover{filter:brightness(1.2)}.inherited-value{font-family:var(--font-readout);color:var(--text-secondary);font-size:14px}.ts-edit,.key-edit,.fx-edit{align-items:center;gap:4px;display:inline-flex}.ts-num{width:48px!important}.ts-slash{color:var(--text-tertiary)}.fx-pair{align-items:center;gap:4px;display:inline-flex}.fx-label{font-family:var(--font-label);letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary);font-size:8px}.fx-pair input[type=number]{width:56px!important}.help{background:var(--bg-secondary);border-top:1px solid var(--border-primary);white-space:nowrap;flex-shrink:0;align-items:center;gap:14px;height:28px;padding:0 14px;display:flex;overflow:hidden}.help-hint{flex-shrink:0;align-items:center;gap:4px;display:inline-flex}.help-hint-keys{align-items:center;gap:2px;display:inline-flex}.help-hint-label{font-family:var(--font-readout);color:var(--text-tertiary);font-size:13px}.help-spacer{flex:1}.help-tail{font-family:var(--font-readout);color:var(--text-quaternary);flex-shrink:0;font-size:12px;font-style:italic}kbd{font-family:var(--font-label);letter-spacing:.06em;text-transform:uppercase;background:var(--bg-tertiary);border:1px solid var(--border-primary);color:var(--text-secondary);vertical-align:1px;border-radius:2px;padding:1px 5px;font-size:9px;line-height:1.4;display:inline-block}
