@font-face {
  font-family: "NeonTrackerClassic";
  src:
    local("TopazPlus a500"),
    local("Topaz a500"),
    local("Topaz-8"),
    local("TopazPlus");
  font-display: swap;
}

:root {
  color-scheme: dark;
  --bg: #101015;
  --panel: #191a21;
  --panel-2: #20222c;
  --line: rgba(255, 255, 255, 0.11);
  --text: #f3f0e8;
  --muted: #a9a8b5;
  --cyan: #38d8e9;
  --lime: #b9f45b;
  --pink: #ff5c9d;
  --amber: #ffc857;
  --black-key: #09090d;
  --tracker-font: "NeonTrackerClassic", ui-monospace, "SFMono-Regular", Menlo, Monaco, Consolas, "Liberation Mono", monospace;
  --tracker-cell: #11131a;
  --tracker-cell-2: #171920;
  --tracker-panel-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06), 0 14px 42px rgba(0, 0, 0, 0.24);
  --page-background:
    radial-gradient(circle at 18% 10%, rgba(56, 216, 233, 0.16), transparent 26rem),
    radial-gradient(circle at 88% 12%, rgba(255, 92, 157, 0.13), transparent 24rem),
    linear-gradient(135deg, #101015 0%, #15131a 42%, #0e1415 100%);
}

html[data-theme="classic"] {
  --bg: #050706;
  --panel: #101414;
  --panel-2: #1b2020;
  --line: rgba(191, 206, 198, 0.28);
  --text: #eef2db;
  --muted: #aeb9ad;
  --cyan: #68d8a0;
  --lime: #d7e56c;
  --pink: #ff8e5f;
  --amber: #ffd36b;
  --black-key: #030404;
  --tracker-font: "NeonTrackerClassic", ui-monospace, "SFMono-Regular", Menlo, Monaco, Consolas, "Liberation Mono", monospace;
  --tracker-cell: #080d0d;
  --tracker-cell-2: #151a1a;
  --tracker-panel-shadow: inset 1px 1px 0 rgba(238, 242, 219, 0.14), inset -1px -1px 0 rgba(0, 0, 0, 0.72);
  --page-background: linear-gradient(180deg, #060807 0%, #0a0d0c 52%, #050706 100%);
}

* {
  box-sizing: border-box;
}

html {
  min-height: 100%;
  background: var(--page-background);
}

body {
  min-height: 100vh;
  margin: 0;
  color: var(--text);
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

html[data-theme="classic"] body {
  font-family: var(--tracker-font);
}

button,
input,
select {
  font: inherit;
}

button {
  cursor: pointer;
}

button:disabled,
select:disabled,
input:disabled {
  cursor: not-allowed;
  opacity: 0.45;
}

.synth-shell {
  display: flex;
  flex-direction: column;
  width: min(1180px, calc(100vw - 28px));
  margin: 0 auto;
  padding: 24px 0 32px;
}

.topbar,
.visual-panel,
.module,
.sequencer,
.tracker,
.drums,
.keyboard,
.performance-surface {
  border: 1px solid var(--line);
  background: rgba(25, 26, 33, 0.88);
  box-shadow: var(--tracker-panel-shadow);
}

.topbar {
  display: grid;
  grid-template-columns: minmax(220px, 0.44fr) minmax(520px, 0.56fr);
  align-items: center;
  justify-content: stretch;
  gap: 8px 14px;
  min-height: 86px;
  padding: 10px;
  border-radius: 8px 8px 0 0;
  font-family: var(--tracker-font);
}

.topbar-identity {
  min-width: 0;
}

.eyebrow {
  margin: 0 0 5px;
  color: var(--cyan);
  font-family: var(--tracker-font);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  line-height: 1.1;
  text-transform: uppercase;
}

h1,
h2 {
  margin: 0;
  letter-spacing: 0;
}

h1 {
  font-family: var(--tracker-font);
  font-size: clamp(1.35rem, 3.2vw, 2.6rem);
  line-height: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-transform: uppercase;
}

h2 {
  font-size: 1.2rem;
}

.transport {
  display: grid;
  grid-column: 1 / -1;
  grid-template-columns: repeat(auto-fit, minmax(74px, max-content));
  align-items: center;
  justify-content: end;
  gap: 5px;
  min-width: 0;
  padding: 5px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--tracker-cell) 86%, transparent);
}

.transport:focus-within {
  border-color: color-mix(in srgb, var(--cyan) 38%, var(--line));
}

.mode-tabs {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  align-items: center;
  justify-content: center;
  gap: 4px;
  min-width: 0;
  width: 100%;
  padding: 4px;
  border: 1px solid var(--line);
  background: var(--tracker-cell);
}

.mode-tabs:focus-within {
  border-color: color-mix(in srgb, var(--cyan) 42%, var(--line));
}

html[data-work-mode="tracking"] .topbar .preset-rack,
html[data-work-mode="tracking"] .topbar .dice-rack,
html[data-work-mode="tracking"] .topbar .audition-rack,
html[data-work-mode="tracking"] #savePresetBtn,
html[data-work-mode="tracking"] #randomPatchBtn,
html[data-work-mode="modulation"] .topbar .preset-rack,
html[data-work-mode="modulation"] .topbar .dice-rack,
html[data-work-mode="modulation"] .topbar .audition-rack,
html[data-work-mode="modulation"] #savePresetBtn,
html[data-work-mode="modulation"] #randomPatchBtn,
html[data-work-mode="effects"] .topbar .preset-rack,
html[data-work-mode="effects"] .topbar .dice-rack,
html[data-work-mode="effects"] #savePresetBtn,
html[data-work-mode="effects"] #randomPatchBtn,
html[data-work-mode="performance"] .topbar .preset-rack,
html[data-work-mode="performance"] .topbar .dice-rack,
html[data-work-mode="performance"] .topbar .audition-rack,
html[data-work-mode="performance"] #savePresetBtn,
html[data-work-mode="performance"] #randomPatchBtn {
  display: none;
}

html[data-work-mode="synth"] .transport {
  justify-content: start;
}

html[data-work-mode="tracking"] .transport,
html[data-work-mode="modulation"] .transport,
html[data-work-mode="effects"] .transport,
html[data-work-mode="performance"] .transport {
  grid-column: 1 / -1;
  justify-self: end;
  width: 100%;
  padding: 0;
  border: 0;
  background: transparent;
}

.mode-tab {
  min-height: 32px;
  min-width: 0;
  padding: 0 6px;
  border: 1px solid var(--line);
  border-radius: 0;
  color: var(--muted);
  background: var(--tracker-cell-2);
  font-family: var(--tracker-font);
  font-size: 0.62rem;
  font-weight: 900;
  line-height: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-transform: uppercase;
}

.mode-tab.active {
  border-color: rgba(56, 216, 233, 0.68);
  color: #071011;
  background: var(--cyan);
  box-shadow: inset 0 -2px 0 rgba(7, 16, 17, 0.32);
}

.mode-tab:hover,
.mode-tab:focus-visible {
  border-color: color-mix(in srgb, var(--cyan) 54%, var(--line));
  color: var(--text);
  outline: 1px solid color-mix(in srgb, var(--cyan) 42%, transparent);
  outline-offset: 1px;
}

.primary-button,
.ghost-button,
.icon-button {
  min-height: 36px;
  border: 1px solid var(--line);
  border-radius: 0;
  color: var(--text);
  background: var(--tracker-cell-2);
  font-family: var(--tracker-font);
  font-size: 0.72rem;
  font-weight: 800;
  line-height: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-transform: uppercase;
}

.primary-button {
  padding: 0 14px;
  border-color: rgba(185, 244, 91, 0.42);
  color: #09100c;
  background: var(--lime);
  box-shadow: inset 0 -2px 0 rgba(5, 7, 6, 0.24);
}

.primary-button:hover,
.primary-button:focus-visible {
  border-color: color-mix(in srgb, var(--lime) 84%, white 8%);
  outline: 1px solid color-mix(in srgb, var(--lime) 58%, transparent);
  outline-offset: 1px;
}

.ghost-button {
  padding: 0 11px;
}

.ghost-button:hover,
.ghost-button:focus-visible {
  border-color: color-mix(in srgb, var(--cyan) 46%, var(--line));
  color: var(--text);
  background: color-mix(in srgb, var(--tracker-cell-2) 72%, var(--cyan) 12%);
  outline: 1px solid color-mix(in srgb, var(--cyan) 34%, transparent);
  outline-offset: 1px;
}

.ghost-button.active {
  color: #071011;
  background: var(--cyan);
  box-shadow: inset 0 -2px 0 rgba(7, 16, 17, 0.24);
}

.audition-button:active,
.audition-button:focus-visible {
  border-color: color-mix(in srgb, var(--cyan) 72%, white 8%);
  color: #071011;
  background: var(--cyan);
  outline: 1px solid color-mix(in srgb, var(--cyan) 64%, transparent);
  outline-offset: 1px;
}

.hold-note-button.active {
  border-color: color-mix(in srgb, var(--lime) 78%, white 6%);
  color: #050706;
  background: var(--lime);
  box-shadow:
    inset 0 0 0 1px rgba(5, 7, 6, 0.28),
    0 0 0 1px color-mix(in srgb, var(--lime) 32%, transparent);
}

.hold-note-button:active,
.hold-note-button:focus-visible,
.hold-note-button.active:active,
.hold-note-button.active:focus-visible {
  border-color: color-mix(in srgb, var(--lime) 82%, white 8%);
  color: #050706;
  background: var(--lime);
  outline: 1px solid color-mix(in srgb, var(--lime) 62%, transparent);
  outline-offset: 1px;
}

.icon-button {
  min-width: 58px;
  padding: 0 10px;
  border-color: rgba(56, 216, 233, 0.38);
}

.icon-button.active {
  color: #071011;
  background: var(--cyan);
}

.tempo,
.preset-rack,
.dice-rack,
.audition-rack,
.theme-rack {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 8px;
  min-height: 36px;
  padding: 0 7px;
  border: 1px solid var(--line);
  border-radius: 0;
  background: var(--tracker-cell);
  color: var(--muted);
  font-family: var(--tracker-font);
  font-size: 0.7rem;
  font-weight: 800;
  min-width: 0;
  text-transform: uppercase;
}

.tempo:focus-within,
.preset-rack:focus-within,
.dice-rack:focus-within,
.audition-rack:focus-within,
.theme-rack:focus-within {
  border-color: color-mix(in srgb, var(--amber) 42%, var(--line));
}

.tempo label,
.preset-rack label,
.dice-rack label,
.audition-rack label,
.theme-rack label {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.preset-rack {
  grid-template-columns: auto 148px;
}

.dice-rack {
  grid-template-columns: auto 104px;
}

.audition-rack {
  grid-template-columns: 54px 54px 62px;
  gap: 5px;
}

.audition-rack > label[for="auditionNoteSelect"] {
  display: none;
}

.theme-rack {
  grid-template-columns: auto 132px;
}

.tempo input,
.preset-rack select,
.dice-rack select,
.audition-rack select,
.theme-rack select {
  width: 72px;
  border: 0;
  color: var(--text);
  background: transparent;
  font-weight: 800;
  min-width: 0;
}

.tempo input:focus-visible,
.preset-rack select:focus-visible,
.dice-rack select:focus-visible,
.audition-rack select:focus-visible,
.theme-rack select:focus-visible {
  outline: 1px solid color-mix(in srgb, var(--amber) 64%, transparent);
  outline-offset: 1px;
}

.preset-rack select,
.dice-rack select,
.audition-rack select,
.theme-rack select {
  cursor: pointer;
}

.tempo-controls {
  display: grid;
  grid-template-columns: 26px 78px 26px;
  align-items: center;
  gap: 4px;
  min-width: 0;
}

.tempo-controls .tempo-step-button {
  min-height: 28px;
  min-width: 26px;
  padding: 0;
}

.tempo-controls input {
  width: 100%;
  min-height: 28px;
  font-variant-numeric: tabular-nums;
  text-align: center;
}

.preset-rack select {
  width: 148px;
}

.dice-rack select {
  width: 104px;
}

.dice-taming {
  display: grid;
  grid-column: 1 / -1;
  grid-template-columns: auto minmax(46px, 1fr) 28px;
  align-items: center;
  gap: 5px;
  min-width: 0;
  color: var(--muted);
}

.dice-taming span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dice-taming input {
  width: 100%;
  min-width: 0;
  accent-color: var(--amber);
}

.dice-taming strong {
  display: inline-grid;
  place-items: center;
  min-height: 20px;
  border: 1px solid color-mix(in srgb, var(--amber) 34%, var(--line));
  color: var(--amber);
  background: #11131a;
  font-size: 0.58rem;
  font-variant-numeric: tabular-nums;
  line-height: 1;
}

.audition-rack select {
  width: 54px;
}

.audition-rack .ghost-button {
  min-height: 28px;
  padding: 0 8px;
  font-size: 0.64rem;
}

.audition-button {
  min-width: 54px;
}

.hold-note-button {
  min-width: 62px;
}

.audition-status {
  grid-column: 1 / -1;
  min-height: 24px;
  width: 100%;
  padding: 5px 7px 3px;
  border: 1px solid color-mix(in srgb, var(--line) 74%, transparent);
  color: var(--muted);
  background: rgba(0, 0, 0, 0.18);
  font-size: 0.58rem;
  font-weight: 900;
  line-height: 1;
  text-align: center;
  white-space: nowrap;
}

.audition-status[data-state="held"] {
  border-color: color-mix(in srgb, var(--lime) 62%, var(--line));
  color: var(--lime);
  background: color-mix(in srgb, var(--tracker-cell) 72%, var(--lime) 12%);
}

.audition-rack .ghost-button,
.tempo-controls .tempo-step-button {
  align-self: center;
}

.panel-command {
  min-height: 36px;
  padding-inline: 10px;
  max-width: 120px;
}

.synth-control-strip .panel-command {
  align-self: stretch;
}

.theme-rack select {
  width: 132px;
}

.visual-panel {
  position: relative;
  overflow: hidden;
  height: 210px;
  border-top: 0;
  border-radius: 0;
  background:
    linear-gradient(rgba(255,255,255,0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.035) 1px, transparent 1px),
    #101118;
  background-size: 36px 36px;
}

#scope {
  display: block;
  width: 100%;
  height: 100%;
}

.readout {
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: 10px;
  display: flex;
  justify-content: space-between;
  gap: 12px;
  color: var(--muted);
  font-family: var(--tracker-font);
  font-size: 0.72rem;
  font-weight: 800;
}

.scope-mode {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  min-width: 0;
}

.scope-mode select {
  width: 132px;
  min-height: 26px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 0;
  color: var(--text);
  background: var(--tracker-cell);
  font-family: var(--tracker-font);
  font-size: 0.68rem;
  font-weight: 800;
}

.controls-grid {
  display: grid;
  grid-template-columns: repeat(8, minmax(0, 1fr));
  gap: 6px;
  margin: 8px 0;
}

html[data-work-mode="synth"] .visual-panel {
  height: 150px;
}

html[data-work-mode="synth"] .controls-grid {
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 5px;
  margin-top: 6px;
}

html[data-work-mode="synth"] .module {
  min-height: 142px;
  padding: 7px;
}

html[data-work-mode="synth"] .module-title {
  min-height: 24px;
  margin-bottom: 6px;
  padding: 3px 6px;
}

html[data-work-mode="synth"] .field {
  margin: 4px 0;
}

html[data-work-mode="synth"] .keyboard {
  margin-top: 6px;
}

html[data-work-mode="modulation"] .visual-panel,
html[data-work-mode="effects"] .visual-panel,
html[data-work-mode="performance"] .visual-panel {
  height: 170px;
}

html[data-work-mode="tracking"] .controls-grid .module:not(.module-rack):not(.module-export):not(.module-project),
html[data-work-mode="synth"] .controls-grid .module-lfo,
html[data-work-mode="synth"] .controls-grid .module-macros,
html[data-work-mode="synth"] .controls-grid .module-matrix,
html[data-work-mode="synth"] .controls-grid .module-studio-mixer,
html[data-work-mode="synth"] .controls-grid .module-modulation-guide,
html[data-work-mode="synth"] .controls-grid .module-modulation-signal,
html[data-work-mode="synth"] .controls-grid .module-effect-guide,
html[data-work-mode="synth"] .controls-grid .module-effect-signal,
html[data-work-mode="synth"] .controls-grid .module-effect-xy,
html[data-work-mode="synth"] .controls-grid .module-effect-rack,
html[data-work-mode="synth"] .controls-grid .module-effect-routing,
html[data-work-mode="synth"] .controls-grid .module-effect-parameters,
html[data-work-mode="modulation"] .controls-grid .module-osc,
html[data-work-mode="modulation"] .controls-grid .module-source,
html[data-work-mode="modulation"] .controls-grid .module-digital,
html[data-work-mode="modulation"] .controls-grid .module-filter,
html[data-work-mode="modulation"] .controls-grid .module-env,
html[data-work-mode="modulation"] .controls-grid .module-live-slot,
html[data-work-mode="modulation"] .controls-grid .module-space,
html[data-work-mode="modulation"] .controls-grid .module-arp,
html[data-work-mode="modulation"] .controls-grid .module-effect-guide,
html[data-work-mode="modulation"] .controls-grid .module-effect-signal,
html[data-work-mode="modulation"] .controls-grid .module-effect-xy,
html[data-work-mode="modulation"] .controls-grid .module-effect-rack,
html[data-work-mode="modulation"] .controls-grid .module-effect-routing,
html[data-work-mode="modulation"] .controls-grid .module-effect-parameters,
html[data-work-mode="performance"] .controls-grid .module-osc,
html[data-work-mode="performance"] .controls-grid .module-source,
html[data-work-mode="performance"] .controls-grid .module-digital,
html[data-work-mode="performance"] .controls-grid .module-filter,
html[data-work-mode="performance"] .controls-grid .module-env,
html[data-work-mode="performance"] .controls-grid,
html[data-work-mode="effects"] .controls-grid .module-osc,
html[data-work-mode="effects"] .controls-grid .module-source,
html[data-work-mode="effects"] .controls-grid .module-env,
html[data-work-mode="effects"] .controls-grid .module-digital,
html[data-work-mode="effects"] .controls-grid .module-live-slot,
html[data-work-mode="effects"] .controls-grid .module-motion,
html[data-work-mode="effects"] .controls-grid .module-macros,
html[data-work-mode="effects"] .controls-grid .module-matrix,
html[data-work-mode="effects"] .controls-grid .module-studio-mixer,
html[data-work-mode="effects"] .controls-grid .module-modulation-guide,
html[data-work-mode="effects"] .controls-grid .module-modulation-signal,
html[data-work-mode="synth"] .sequencer,
html[data-work-mode="synth"] .tracker,
html[data-work-mode="synth"] .drums,
html[data-work-mode="synth"] .performance-surface,
html[data-work-mode="modulation"] .sequencer,
html[data-work-mode="modulation"] .tracker,
html[data-work-mode="modulation"] .drums,
html[data-work-mode="modulation"] .keyboard,
html[data-work-mode="modulation"] .performance-surface,
html[data-work-mode="effects"] .sequencer,
html[data-work-mode="effects"] .tracker,
html[data-work-mode="effects"] .drums,
html[data-work-mode="effects"] .keyboard,
html[data-work-mode="effects"] .performance-surface,
html[data-work-mode="performance"] .sequencer,
html[data-work-mode="performance"] .tracker,
html[data-work-mode="performance"] .drums,
html[data-work-mode="performance"] .keyboard,
html[data-work-mode="tracking"] .performance-surface {
  display: none;
}

html[data-work-mode="tracking"] .controls-grid,
html[data-work-mode="modulation"] .controls-grid,
html[data-work-mode="effects"] .controls-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

html[data-work-mode="effects"] .controls-grid .module-space {
  display: block;
}

html[data-work-mode="effects"] .controls-grid .module-effect-guide {
  order: 1;
  grid-column: span 2;
}

html[data-work-mode="effects"] .controls-grid .module-effect-signal {
  order: 2;
  grid-column: span 2;
}

html[data-work-mode="effects"] .controls-grid .module-effect-rack {
  order: 3;
  grid-column: span 2;
}

html[data-work-mode="effects"] .controls-grid .module-effect-xy {
  order: 4;
  grid-column: span 2;
}

html[data-work-mode="effects"] .controls-grid .module-effect-parameters {
  order: 5;
  grid-column: span 2;
}

html[data-work-mode="effects"] .controls-grid .module-effect-routing {
  order: 6;
  grid-column: span 2;
}

html[data-work-mode="effects"] .controls-grid .module-space {
  order: 7;
}

html[data-work-mode="modulation"] .controls-grid .module-modulation-guide {
  order: 2;
  grid-column: span 2;
}

html[data-work-mode="modulation"] .controls-grid .module-modulation-signal {
  order: 3;
  grid-column: span 2;
}

html[data-work-mode="modulation"] .controls-grid .module-studio-mixer {
  order: 1;
  grid-column: span 4;
}

html[data-work-mode="modulation"] .controls-grid .module-macros {
  order: 4;
  grid-column: span 2;
}

html[data-work-mode="modulation"] .controls-grid .module-matrix {
  order: 5;
  grid-column: span 3;
}

html[data-work-mode="modulation"] .controls-grid .module-lfo {
  order: 6;
}

html[data-work-mode="performance"] .visual-panel,
html[data-work-mode="modulation"] .visual-panel,
html[data-work-mode="effects"] .visual-panel {
  border-radius: 0;
}

html[data-work-mode="tracking"] .visual-panel {
  display: none;
}

html[data-work-mode="tracking"] .topbar {
  order: 0;
  margin-bottom: 8px;
  border-radius: 8px;
}

html[data-work-mode="tracking"] .tracker {
  order: 1;
  margin-top: 0;
}

html[data-work-mode="tracking"] .sequencer {
  order: 2;
}

html[data-work-mode="tracking"] .controls-grid {
  order: 3;
  margin: 8px 0 0;
}

html[data-work-mode="tracking"] .drums {
  order: 4;
}

html[data-work-mode="tracking"] .keyboard {
  order: 5;
}

html[data-work-mode="tracking"] .module-rack,
html[data-work-mode="tracking"] .module-project,
html[data-work-mode="tracking"] .module-export {
  min-height: 0;
}

.module {
  --accent: var(--cyan);
  min-height: 168px;
  padding: 9px;
  border-radius: 0;
  border-color: color-mix(in srgb, var(--accent) 32%, var(--line));
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--accent) 8%, transparent), transparent 44%),
    rgba(25, 26, 33, 0.88);
  box-shadow:
    inset 0 2px 0 color-mix(in srgb, var(--accent) 58%, transparent),
    var(--tracker-panel-shadow);
}

.module:hover {
  border-color: color-mix(in srgb, var(--accent) 42%, var(--line));
}

.module-osc {
  --accent: var(--cyan);
}

.module-source,
.module-digital {
  --accent: var(--pink);
}

.module-filter {
  --accent: var(--lime);
}

.module-env {
  --accent: var(--amber);
}

.module-motion {
  --accent: #9ba7ff;
}

.module-macros {
  --accent: #d5e56c;
}

.module-modulation-guide,
.module-modulation-signal,
.module-studio-mixer,
.module-matrix {
  --accent: #d5e56c;
}

.module-space,
.module-project,
.module-export,
.module-effect-guide,
.module-effect-signal,
.module-effect-xy,
.module-effect-rack,
.module-effect-routing,
.module-effect-parameters {
  --accent: #7de0ad;
}

.effect-guide-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 5px;
  margin: 6px 0;
}

.effect-guide-grid span,
.effect-guide-flow span,
.effect-guide-status {
  min-width: 0;
  border: 1px solid color-mix(in srgb, var(--accent) 24%, var(--line));
  color: var(--muted);
  background: color-mix(in srgb, var(--tracker-cell) 84%, transparent);
  font-family: var(--tracker-font);
  font-size: 0.58rem;
  font-weight: 900;
  line-height: 1.2;
  text-transform: uppercase;
}

.effect-guide-grid span {
  display: grid;
  gap: 3px;
  min-height: 54px;
  padding: 7px;
}

.effect-guide-grid strong {
  color: var(--lime);
  font-size: 0.62rem;
}

.effect-guide-flow {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 4px;
  margin: 6px 0;
}

.effect-guide-flow span {
  display: inline-grid;
  place-items: center;
  min-height: 24px;
  padding: 0 6px;
  color: var(--text);
}

.effect-guide-flow span:not(:last-child)::after {
  content: ">";
  margin-left: 6px;
  color: var(--amber);
}

.mode-basis-status {
  min-height: 24px;
  margin: 0 0 6px;
  padding: 5px 7px 3px;
  border: 1px solid color-mix(in srgb, var(--cyan) 32%, var(--line));
  color: var(--cyan);
  background: color-mix(in srgb, var(--tracker-cell) 84%, transparent);
  font-family: var(--tracker-font);
  font-size: 0.58rem;
  font-weight: 900;
  line-height: 1.2;
  text-transform: uppercase;
}

.mode-basis-status[data-source="synth-editor"] {
  border-color: color-mix(in srgb, var(--lime) 48%, var(--line));
  color: var(--lime);
}

.mode-basis-status[data-source="master"] {
  border-color: color-mix(in srgb, var(--amber) 56%, var(--line));
  color: var(--amber);
}

.effect-guide-status {
  margin: 0;
  padding: 5px 7px 3px;
  color: var(--amber);
}

.effect-guide-status[data-state="active"] {
  border-color: color-mix(in srgb, var(--lime) 44%, var(--line));
  color: var(--lime);
}

.effect-guide-status[data-state="warning"] {
  border-color: color-mix(in srgb, var(--amber) 58%, var(--line));
  color: var(--amber);
}

.modulation-guide-flow,
.modulation-guide-grid {
  display: grid;
  gap: 5px;
  margin: 6px 0;
}

.modulation-guide-flow {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.modulation-guide-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.modulation-guide-flow span,
.modulation-guide-grid span {
  min-width: 0;
  border: 1px solid color-mix(in srgb, var(--accent) 24%, var(--line));
  color: var(--muted);
  background: color-mix(in srgb, var(--tracker-cell) 84%, transparent);
  font-family: var(--tracker-font);
  font-size: 0.58rem;
  font-weight: 900;
  line-height: 1.2;
  text-transform: uppercase;
}

.modulation-guide-flow span {
  display: inline-grid;
  place-items: center;
  min-height: 24px;
  padding: 0 6px;
  color: var(--text);
}

.modulation-guide-flow span:not(:last-child)::after {
  content: ">";
  margin-left: 6px;
  color: var(--amber);
}

.modulation-guide-grid span {
  display: grid;
  gap: 3px;
  min-height: 54px;
  padding: 7px;
}

.modulation-guide-grid strong {
  color: var(--lime);
  font-size: 0.62rem;
}

.studio-mixer-board {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(132px, 1fr);
  gap: 8px;
  min-width: 0;
  overflow-x: auto;
  padding: 6px 0 8px;
}

.studio-mixer-strip {
  display: grid;
  grid-template-rows: 30px minmax(190px, 1fr) 18px auto auto auto auto;
  gap: 6px;
  align-items: center;
  justify-items: center;
  min-width: 132px;
  min-height: 520px;
  padding: 8px;
  border: 1px solid color-mix(in srgb, var(--accent) 26%, var(--line));
  color: var(--text);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--tracker-cell) 92%, var(--accent) 4%), var(--tracker-cell) 58%, color-mix(in srgb, #050807 80%, var(--tracker-cell) 20%));
  font-family: var(--tracker-font);
  font-size: 0.58rem;
  font-weight: 900;
  box-shadow:
    inset 0 1px 0 color-mix(in srgb, var(--accent) 26%, transparent),
    inset 0 -1px 0 rgba(0, 0, 0, 0.62);
  text-transform: uppercase;
  user-select: none;
}

.studio-mixer-title {
  display: inline-grid;
  place-items: center;
  width: 100%;
  min-height: 30px;
  padding: 0 8px;
  border: 1px solid color-mix(in srgb, var(--accent) 26%, var(--line));
  border-radius: 2px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--panel) 92%, var(--accent) 8%), color-mix(in srgb, #050807 74%, var(--panel) 26%));
  max-width: 100%;
  color: var(--lime);
  font-size: 0.66rem;
  letter-spacing: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  box-shadow:
    inset 0 1px 0 color-mix(in srgb, var(--accent) 26%, transparent),
    inset 0 -1px 0 rgba(0, 0, 0, 0.72);
}

.studio-mixer-strip.muted {
  border-color: color-mix(in srgb, var(--amber) 50%, var(--line));
}

.studio-mixer-strip.solo,
.studio-mixer-master {
  border-color: color-mix(in srgb, var(--lime) 44%, var(--line));
}

.studio-mixer-strip.active-signal {
  border-color: color-mix(in srgb, var(--cyan) 45%, var(--lime) 36%);
  box-shadow:
    inset 0 1px 0 color-mix(in srgb, var(--cyan) 28%, transparent),
    inset 0 -1px 0 rgba(0, 0, 0, 0.62),
    0 0 14px color-mix(in srgb, var(--cyan) 16%, transparent);
}

.studio-mixer-master {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--tracker-cell) 88%, var(--amber) 8%), var(--tracker-cell) 58%, color-mix(in srgb, #050807 76%, var(--amber) 8%));
}

.studio-mixer-fader-deck {
  position: relative;
  display: grid;
  place-items: center;
  width: 100%;
  min-height: 190px;
  border: 1px solid color-mix(in srgb, var(--accent) 18%, var(--line));
  overflow: visible;
  background:
    linear-gradient(90deg, transparent 0 46%, color-mix(in srgb, var(--accent) 24%, transparent) 47% 53%, transparent 54%),
    repeating-linear-gradient(0deg, color-mix(in srgb, var(--line) 42%, transparent) 0 1px, transparent 1px 24px),
    color-mix(in srgb, #030706 82%, var(--tracker-cell) 18%);
  touch-action: none;
  cursor: ns-resize;
}

.studio-mixer-fader-deck::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  border: 1px solid transparent;
  background:
    linear-gradient(90deg, transparent 0 46%, color-mix(in srgb, var(--accent) 24%, transparent) 47% 53%, transparent 54%),
    repeating-linear-gradient(0deg, color-mix(in srgb, var(--line) 42%, transparent) 0 1px, transparent 1px 24px),
    color-mix(in srgb, #030706 82%, var(--tracker-cell) 18%);
  pointer-events: none;
}

.studio-mixer-eq-graphic {
  position: absolute;
  inset: 12px 34px;
  display: grid;
  align-items: end;
  justify-items: center;
  opacity: 0.72;
  z-index: 1;
  pointer-events: none;
}

.studio-mixer-eq-graphic span {
  display: block;
  width: 32px;
  min-height: 9px;
  height: var(--bar-height, 30%);
  border: 1px solid color-mix(in srgb, var(--lime) 30%, transparent);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--cyan) 56%, var(--lime) 24%), color-mix(in srgb, var(--lime) 44%, var(--amber) 18%));
  box-shadow:
    0 0 12px color-mix(in srgb, var(--cyan) 24%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.14);
  transform-origin: 50% 100%;
  transition:
    height 70ms ease,
    opacity 130ms ease,
    border-color 130ms ease;
}

.studio-mixer-strip.active-signal .studio-mixer-eq-graphic span {
  border-color: color-mix(in srgb, var(--cyan) 46%, var(--lime) 28%);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--cyan) 50%, var(--lime) 28%), color-mix(in srgb, var(--amber) 34%, transparent));
  opacity: 0.96;
}

.studio-mixer-scale {
  position: absolute;
  inset: 8px 4px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  z-index: 2;
  pointer-events: none;
}

.studio-mixer-scale span {
  color: color-mix(in srgb, var(--muted) 74%, transparent);
  font-size: 0.48rem;
}

.studio-mixer-fader {
  width: 30px;
  height: 162px;
  accent-color: var(--lime);
  writing-mode: vertical-lr;
  direction: rtl;
  cursor: pointer;
  z-index: 3;
  opacity: 0;
  pointer-events: none;
}

.studio-mixer-fader-cap {
  position: absolute;
  left: 50%;
  top: var(--fader-position, 0%);
  z-index: 5;
  width: 32px;
  height: 22px;
  border: 1px solid color-mix(in srgb, #fff 70%, var(--line) 30%);
  border-radius: 2px;
  background:
    linear-gradient(180deg, #ff756f 0 18%, #e92e31 19% 46%, #b7131a 47% 100%);
  box-shadow:
    inset 0 3px 0 rgba(255, 255, 255, 0.16),
    inset 0 -4px 0 rgba(0, 0, 0, 0.18),
    0 1px 5px rgba(0, 0, 0, 0.62);
  transform: translate(-50%, -50%);
  pointer-events: none;
}

.studio-mixer-master .studio-mixer-fader-cap {
  background:
    linear-gradient(180deg, #f8f8ec 0 18%, #d8d8cb 19% 48%, #aaa99e 49% 100%);
}

.studio-mixer-value {
  display: inline-grid;
  place-items: center;
  min-height: 16px;
  color: var(--amber);
  font-size: 0.52rem;
  font-variant-numeric: tabular-nums;
}

.studio-mixer-knob-control {
  display: grid;
  grid-template-columns: 34px minmax(42px, 1fr) 48px;
  gap: 5px;
  align-items: center;
  width: 100%;
  min-width: 0;
  color: var(--muted);
  --knob-color: #e8ebd7;
  --knob-ring: color-mix(in srgb, var(--knob-color) 76%, #101715 24%);
}

.studio-mixer-knob-pan,
.studio-mixer-knob-fx {
  --knob-color: #38bde9;
}

.studio-mixer-knob-hp,
.studio-mixer-knob-lp {
  --knob-color: #d9e96b;
}

.studio-mixer-knob-low,
.studio-mixer-knob-mid,
.studio-mixer-knob-high {
  --knob-color: #f0efe2;
}

.studio-mixer-knob-control > span:first-child {
  justify-self: start;
  font-size: 0.49rem;
}

.studio-mixer-knob-shell {
  justify-self: center;
}

.studio-mixer-knob-control .studio-mixer-value {
  justify-content: end;
  overflow: hidden;
  text-align: right;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.studio-mixer-knob-shell {
  position: relative;
  display: inline-grid;
  place-items: center;
  width: 42px;
  height: 42px;
  touch-action: none;
  cursor: grab;
}

.studio-mixer-knob-shell::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background:
    repeating-conic-gradient(from -140deg, color-mix(in srgb, var(--text) 52%, transparent) 0 2deg, transparent 2deg 18deg);
  opacity: 0.32;
  mask: radial-gradient(circle, transparent 0 57%, #000 58% 68%, transparent 69%);
  pointer-events: none;
}

.studio-mixer-knob-face {
  position: relative;
  display: inline-grid;
  place-items: center;
  width: 33px;
  height: 33px;
  border: 1px solid color-mix(in srgb, var(--knob-color) 64%, #0a0e0d 36%);
  border-radius: 50%;
  background:
    radial-gradient(circle at 33% 24%, rgba(255, 255, 238, 0.42) 0 9%, transparent 10%),
    radial-gradient(circle at 50% 54%, color-mix(in srgb, var(--knob-color) 16%, #26302b 84%) 0 42%, #101715 43% 60%, #050807 61% 100%),
    conic-gradient(from -135deg, var(--knob-ring) 0 var(--knob-fill, 50%), color-mix(in srgb, var(--line) 54%, #050807 46%) var(--knob-fill, 50%) 75%, transparent 75% 100%);
  box-shadow:
    inset 0 4px 6px rgba(255, 255, 255, 0.10),
    inset 0 -7px 9px rgba(0, 0, 0, 0.80),
    0 0 0 1px rgba(0, 0, 0, 0.68),
    0 2px 6px rgba(0, 0, 0, 0.64);
}

.studio-mixer-knob-shell.dragging,
.studio-mixer-knob-shell:hover {
  cursor: ns-resize;
}

.studio-mixer-knob-shell.dragging .studio-mixer-knob-face,
.studio-mixer-knob-shell:hover .studio-mixer-knob-face {
  border-color: color-mix(in srgb, var(--cyan) 38%, var(--lime) 34%);
  box-shadow:
    inset 0 4px 6px rgba(255, 255, 226, 0.15),
    inset 0 -7px 9px rgba(0, 0, 0, 0.78),
    0 0 0 1px rgba(0, 0, 0, 0.68),
    0 0 10px color-mix(in srgb, var(--cyan) 14%, transparent);
}

.studio-mixer-knob-tick {
  position: absolute;
  left: 50%;
  top: 4px;
  width: 3px;
  height: 12px;
  border-radius: 999px;
  background: var(--knob-color);
  box-shadow: 0 0 5px color-mix(in srgb, var(--knob-color) 42%, transparent);
  transform: translateX(-50%) rotate(var(--knob-angle, 0deg));
  transform-origin: 50% 12px;
}

.studio-mixer-knob-input {
  position: absolute;
  inset: 0;
  width: 42px;
  height: 42px;
  cursor: pointer;
  opacity: 0;
  pointer-events: none;
}

.studio-mixer-eq-section {
  display: grid;
  grid-template-columns: 1fr;
  gap: 4px;
  width: 100%;
  padding: 5px;
  border: 1px solid color-mix(in srgb, var(--accent) 16%, var(--line));
  background: color-mix(in srgb, #030706 72%, var(--panel) 28%);
}

.studio-mixer-filter-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 4px;
  width: 100%;
  padding-top: 4px;
  border-top: 1px solid color-mix(in srgb, var(--accent) 14%, transparent);
}

.studio-mixer-filter-row .studio-mixer-knob-control {
  grid-template-columns: 1fr;
  gap: 2px;
  justify-items: center;
}

.studio-mixer-filter-row .studio-mixer-knob-control > span:first-child,
.studio-mixer-filter-row .studio-mixer-knob-control .studio-mixer-value {
  justify-self: center;
  text-align: center;
}

.studio-mixer-button-bank,
.studio-mixer-dsp-bank {
  display: grid;
  gap: 4px;
  width: 100%;
}

.studio-mixer-button-bank {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.studio-mixer-dsp-bank {
  grid-template-columns: 1fr;
}

.studio-mixer-button {
  width: 100%;
  min-height: 22px;
  padding: 0 4px;
  font-size: 0.54rem;
}

.studio-mixer-button:disabled {
  color: color-mix(in srgb, var(--muted) 55%, transparent);
  cursor: not-allowed;
  opacity: 0.58;
}

.effect-xy-head {
  display: grid;
  grid-template-columns: minmax(76px, 0.7fr) minmax(118px, 1.3fr);
  gap: 5px;
  margin-bottom: 6px;
}

.effect-xy-select,
.effect-xy-axis {
  display: grid;
  align-items: center;
  min-width: 0;
  border: 1px solid color-mix(in srgb, var(--accent) 24%, var(--line));
  color: var(--muted);
  background: color-mix(in srgb, var(--tracker-cell) 84%, transparent);
  font-family: var(--tracker-font);
  font-size: 0.58rem;
  font-weight: 900;
  text-transform: uppercase;
}

.effect-xy-select {
  grid-template-columns: 44px minmax(0, 1fr);
  min-height: 26px;
}

.effect-xy-select span,
.effect-xy-axis span {
  min-width: 0;
  padding: 0 6px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.effect-xy-select select {
  width: 100%;
  min-width: 0;
  min-height: 24px;
  border: 0;
  border-left: 1px solid color-mix(in srgb, var(--accent) 24%, var(--line));
  border-radius: 0;
  color: var(--text);
  background: var(--tracker-cell);
  font-family: var(--tracker-font);
  font-size: 0.58rem;
  font-weight: 900;
}

.effect-xy-pad {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  min-height: 138px;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--accent) 42%, var(--line));
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--accent) 18%, transparent) 1px, transparent 1px),
    linear-gradient(0deg, color-mix(in srgb, var(--accent) 16%, transparent) 1px, transparent 1px),
    radial-gradient(circle at 72% 26%, color-mix(in srgb, var(--lime) 20%, transparent), transparent 38%),
    color-mix(in srgb, var(--tracker-cell) 88%, var(--accent) 7%);
  background-size: 25% 25%, 25% 25%, auto, auto;
  touch-action: none;
  cursor: crosshair;
}

.effect-xy-pad:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--amber) 68%, transparent);
  outline-offset: 2px;
}

.effect-xy-pad::before,
.effect-xy-pad::after {
  content: "";
  position: absolute;
  inset: 50% 0 auto;
  border-top: 1px solid color-mix(in srgb, var(--accent) 36%, transparent);
  pointer-events: none;
}

.effect-xy-pad::after {
  inset: 0 auto 0 50%;
  border-top: 0;
  border-left: 1px solid color-mix(in srgb, var(--accent) 36%, transparent);
}

.effect-xy-corner {
  position: absolute;
  z-index: 1;
  color: color-mix(in srgb, var(--muted) 82%, transparent);
  font-family: var(--tracker-font);
  font-size: 0.54rem;
  font-weight: 900;
  text-transform: uppercase;
  pointer-events: none;
}

.effect-xy-corner.top-left {
  top: 6px;
  left: 7px;
}

.effect-xy-corner.top-right {
  top: 6px;
  right: 7px;
}

.effect-xy-corner.bottom-left {
  bottom: 6px;
  left: 7px;
}

.effect-xy-corner.bottom-right {
  right: 7px;
  bottom: 6px;
}

.effect-xy-cursor {
  position: absolute;
  z-index: 2;
  width: 16px;
  height: 16px;
  border: 2px solid var(--amber);
  background: color-mix(in srgb, var(--amber) 16%, transparent);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--panel) 86%, transparent);
  transform: translate(-50%, -50%);
  pointer-events: none;
}

.effect-xy-readout {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 5px;
  margin-top: 6px;
}

.effect-xy-axis {
  grid-template-columns: minmax(54px, 0.7fr) minmax(64px, 1fr) 34px;
  min-height: 28px;
}

.effect-xy-axis input[type="range"] {
  width: 100%;
  min-width: 0;
  accent-color: var(--accent);
}

.effect-xy-axis strong {
  min-height: 24px;
  display: inline-grid;
  place-items: center;
  border-left: 1px solid color-mix(in srgb, var(--accent) 24%, var(--line));
  color: var(--amber);
  background: var(--tracker-cell);
  font-variant-numeric: tabular-nums;
}

.effect-xy-status {
  min-height: 22px;
  margin: 6px 0 0;
  padding: 5px 7px 3px;
  border: 1px solid color-mix(in srgb, var(--accent) 24%, var(--line));
  color: var(--muted);
  background: color-mix(in srgb, var(--tracker-cell) 84%, transparent);
  font-family: var(--tracker-font);
  font-size: 0.58rem;
  font-weight: 900;
  line-height: 1.15;
  text-transform: uppercase;
}

.effect-xy-status[data-state="active"] {
  border-color: color-mix(in srgb, var(--lime) 44%, var(--line));
  color: var(--lime);
}

.effect-xy-status[data-state="warning"] {
  border-color: color-mix(in srgb, var(--amber) 58%, var(--line));
  color: var(--amber);
}

.effect-rack-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin: 0 0 6px;
  min-width: 0;
}

.effect-rack-actions .ghost-button {
  min-height: 24px;
  min-width: 0;
  padding: 0 7px;
  border-color: color-mix(in srgb, var(--accent) 34%, var(--line));
  color: var(--text);
  background: color-mix(in srgb, var(--tracker-cell) 86%, var(--accent) 12%);
  font-size: 0.58rem;
}

.effect-rack-actions .ghost-button:hover,
.effect-rack-actions .ghost-button:focus-visible,
.effect-rack-actions .ghost-button.active {
  border-color: color-mix(in srgb, var(--amber) 58%, var(--line));
  color: var(--amber);
}

.effect-target-toggle {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 5px;
  margin: 0 0 7px;
  min-width: 0;
}

.effect-target-toggle label {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 6px;
  min-width: 0;
  min-height: 28px;
  padding: 3px 7px;
  border: 1px solid color-mix(in srgb, var(--accent) 28%, var(--line));
  color: var(--muted);
  background: color-mix(in srgb, var(--tracker-cell) 88%, transparent);
  font-family: var(--tracker-font);
  font-size: 0.6rem;
  font-weight: 900;
  text-transform: uppercase;
  cursor: pointer;
}

.effect-target-toggle input {
  accent-color: var(--amber);
}

.effect-target-toggle label:has(input:checked) {
  border-color: color-mix(in srgb, var(--amber) 62%, var(--line));
  color: var(--amber);
  background: color-mix(in srgb, var(--tracker-cell) 76%, var(--amber) 12%);
}

.effect-rack-dice {
  display: grid;
  grid-template-columns: auto auto auto minmax(180px, 1fr);
  align-items: center;
  gap: 5px;
  margin: 0 0 6px;
}

.effect-rack-dice .ghost-button {
  min-height: 26px;
  padding: 0 8px;
  border-color: color-mix(in srgb, var(--amber) 44%, var(--line));
  color: var(--amber);
  background: color-mix(in srgb, var(--tracker-cell) 82%, var(--accent) 14%);
  font-size: 0.58rem;
}

.effect-rack-tame {
  display: grid;
  grid-template-columns: 42px minmax(64px, 1fr) 34px;
  align-items: center;
  gap: 5px;
  min-width: 0;
  padding: 3px 5px;
  border: 1px solid color-mix(in srgb, var(--accent) 24%, var(--line));
  color: var(--muted);
  background: color-mix(in srgb, var(--panel) 86%, transparent);
  font-family: var(--tracker-font);
  font-size: 0.58rem;
  font-weight: 900;
  text-transform: uppercase;
}

.effect-rack-tame input[type="range"] {
  width: 100%;
  min-width: 0;
  accent-color: var(--accent);
}

.effect-rack-tame strong {
  min-height: 20px;
  display: inline-grid;
  place-items: center;
  border: 1px solid color-mix(in srgb, var(--amber) 38%, var(--line));
  color: var(--amber);
  background: var(--tracker-cell);
  font-variant-numeric: tabular-nums;
}

.effect-enable-field {
  grid-template-columns: minmax(78px, 0.6fr) auto;
}

.effect-enable-field input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--amber);
  justify-self: end;
}

.effect-rack-status {
  min-height: 22px;
  margin: 0 0 5px;
  padding: 5px 7px 3px;
  border: 1px solid color-mix(in srgb, var(--accent) 24%, var(--line));
  color: var(--muted);
  background: color-mix(in srgb, var(--tracker-cell) 84%, transparent);
  font-family: var(--tracker-font);
  font-size: 0.58rem;
  font-weight: 900;
  line-height: 1.15;
  text-transform: uppercase;
}

.effect-rack-status[data-state="active"] {
  border-color: color-mix(in srgb, var(--lime) 44%, var(--line));
  color: var(--lime);
}

.effect-rack-status[data-state="warning"] {
  border-color: color-mix(in srgb, var(--amber) 58%, var(--line));
  color: var(--amber);
}

.effect-rack-grid {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.effect-rack-row {
  display: grid;
  grid-template-columns: 34px 18px 18px minmax(104px, 1fr) minmax(92px, 1fr) 34px minmax(72px, 0.8fr) 78px;
  align-items: center;
  gap: 5px;
  min-width: 0;
}

.effect-rack-slot-label {
  min-height: 24px;
  display: inline-grid;
  place-items: center;
  border: 1px solid color-mix(in srgb, var(--accent) 30%, var(--line));
  color: var(--muted);
  background: color-mix(in srgb, var(--panel-2) 82%, transparent);
  font-family: var(--tracker-font);
  font-size: 0.58rem;
  font-weight: 900;
  cursor: pointer;
}

.effect-rack-row[data-state="active"] select,
.effect-rack-row[data-state="active"] .effect-rack-mix-value,
.effect-rack-row[data-state="active"] .effect-rack-slot-label {
  border-color: color-mix(in srgb, var(--lime) 42%, var(--line));
}

.effect-rack-row[data-state="incomplete"] select,
.effect-rack-row[data-state="incomplete"] .effect-rack-mix-value,
.effect-rack-row[data-state="incomplete"] .effect-rack-slot-label {
  border-color: color-mix(in srgb, var(--amber) 62%, var(--line));
  color: var(--amber);
}

.effect-rack-row[data-state="zero"] select,
.effect-rack-row[data-state="zero"] .effect-rack-mix-value,
.effect-rack-row[data-state="zero"] .effect-rack-slot-label {
  border-color: color-mix(in srgb, var(--accent) 46%, var(--line));
}

.effect-rack-row[data-locked="true"] .effect-rack-slot-label {
  color: var(--amber);
  background: color-mix(in srgb, var(--tracker-cell) 72%, var(--amber) 10%);
}

.effect-rack-row[data-selected="true"] .effect-rack-slot-label {
  border-color: color-mix(in srgb, var(--amber) 68%, var(--line));
  color: var(--amber);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--amber) 42%, transparent);
}

.effect-rack-slot-label:hover,
.effect-rack-slot-label:focus-visible {
  border-color: color-mix(in srgb, var(--amber) 62%, var(--line));
  color: var(--amber);
  outline: 0;
}

.effect-rack-row input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: var(--lime);
}

.effect-rack-row .effect-rack-lock {
  accent-color: var(--amber);
}

.effect-rack-row select,
.effect-rack-mix-value {
  min-width: 0;
  min-height: 24px;
  border: 1px solid color-mix(in srgb, var(--accent) 28%, var(--line));
  border-radius: 0;
  color: var(--text);
  background: var(--tracker-cell);
  font-family: var(--tracker-font);
  font-size: 0.6rem;
  font-weight: 900;
}

.effect-rack-row select {
  width: 100%;
  padding: 0 5px;
}

.effect-rack-row input[type="range"] {
  width: 100%;
  min-width: 0;
  accent-color: var(--accent);
}

.effect-rack-mix-value {
  display: inline-grid;
  place-items: center;
  color: var(--amber);
  font-variant-numeric: tabular-nums;
}

.effect-rack-row:focus-within select,
.effect-rack-row:focus-within .effect-rack-mix-value,
.effect-rack-row:focus-within .effect-rack-slot-label {
  border-color: color-mix(in srgb, var(--amber) 54%, var(--line));
}

.effect-rack-row-actions {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 3px;
  min-width: 0;
}

.effect-rack-row-button {
  min-width: 0;
  min-height: 24px;
  padding: 0;
  border: 1px solid color-mix(in srgb, var(--accent) 24%, var(--line));
  color: var(--muted);
  background: var(--tracker-cell);
  font-family: var(--tracker-font);
  font-size: 0.58rem;
  font-weight: 900;
  line-height: 1;
}

.effect-rack-row-button:hover,
.effect-rack-row-button:focus-visible {
  border-color: color-mix(in srgb, var(--amber) 54%, var(--line));
  color: var(--amber);
  outline: 0;
}

.effect-routing-status {
  min-height: 22px;
  margin: 0 0 6px;
  padding: 5px 7px 3px;
  border: 1px solid color-mix(in srgb, var(--accent) 24%, var(--line));
  color: var(--muted);
  background: color-mix(in srgb, var(--tracker-cell) 84%, transparent);
  font-family: var(--tracker-font);
  font-size: 0.58rem;
  font-weight: 900;
  line-height: 1.15;
  text-transform: uppercase;
}

.effect-routing-status[data-state="active"] {
  border-color: color-mix(in srgb, var(--lime) 44%, var(--line));
  color: var(--lime);
}

.effect-routing-status[data-state="warning"] {
  border-color: color-mix(in srgb, var(--amber) 58%, var(--line));
  color: var(--amber);
}

.effect-routing-lanes {
  display: grid;
  gap: 5px;
}

.effect-routing-lane {
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr);
  align-items: stretch;
  min-height: 34px;
  border: 1px solid color-mix(in srgb, var(--accent) 24%, var(--line));
  background: color-mix(in srgb, var(--panel) 88%, transparent);
}

.effect-routing-lane[data-state="active"] {
  border-color: color-mix(in srgb, var(--lime) 40%, var(--line));
}

.effect-routing-lane[data-state="warning"] {
  border-color: color-mix(in srgb, var(--amber) 50%, var(--line));
}

.effect-routing-label {
  display: inline-grid;
  place-items: center;
  padding: 0 7px;
  border-right: 1px solid color-mix(in srgb, var(--accent) 26%, var(--line));
  color: var(--text);
  background: color-mix(in srgb, var(--tracker-cell) 88%, var(--accent) 10%);
  font-family: var(--tracker-font);
  font-size: 0.58rem;
  font-weight: 900;
  text-transform: uppercase;
}

.effect-routing-flow {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 4px;
  min-width: 0;
  padding: 5px;
}

.effect-routing-chip,
.effect-routing-empty {
  display: inline-grid;
  place-items: center;
  min-height: 22px;
  padding: 0 7px;
  border: 1px solid color-mix(in srgb, var(--accent) 30%, var(--line));
  color: var(--muted);
  background: var(--tracker-cell);
  font-family: var(--tracker-font);
  font-size: 0.58rem;
  font-weight: 900;
  white-space: nowrap;
}

.effect-routing-chip[data-state="active"] {
  border-color: color-mix(in srgb, var(--lime) 42%, var(--line));
  color: var(--lime);
}

.effect-routing-chip[data-state="zero"],
.effect-routing-chip[data-state="incomplete"] {
  border-color: color-mix(in srgb, var(--amber) 54%, var(--line));
  color: var(--amber);
}

.effect-routing-empty {
  color: color-mix(in srgb, var(--muted) 72%, transparent);
}

.effect-parameters-status {
  min-height: 22px;
  margin: 0 0 6px;
  padding: 5px 7px 3px;
  border: 1px solid color-mix(in srgb, var(--accent) 24%, var(--line));
  color: var(--muted);
  background: color-mix(in srgb, var(--tracker-cell) 84%, transparent);
  font-family: var(--tracker-font);
  font-size: 0.58rem;
  font-weight: 900;
  line-height: 1.15;
  text-transform: uppercase;
}

.effect-parameters-status[data-state="active"] {
  border-color: color-mix(in srgb, var(--lime) 44%, var(--line));
  color: var(--lime);
}

.effect-parameters-grid {
  display: grid;
  gap: 4px;
}

.effect-param-row {
  display: grid;
  grid-template-columns: 34px 76px minmax(0, 1fr);
  align-items: stretch;
  min-height: 34px;
  border: 1px solid color-mix(in srgb, var(--accent) 22%, var(--line));
  background: color-mix(in srgb, var(--panel) 88%, transparent);
}

.effect-param-row[data-state="active"] {
  border-color: color-mix(in srgb, var(--lime) 36%, var(--line));
}

.effect-param-row[data-selected="true"] {
  border-color: color-mix(in srgb, var(--amber) 58%, var(--line));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--amber) 28%, transparent);
}

.effect-param-row[data-selected="true"] .effect-param-slot {
  color: var(--amber);
}

.effect-param-slot,
.effect-param-type {
  display: inline-grid;
  place-items: center;
  padding: 0 6px;
  border-right: 1px solid color-mix(in srgb, var(--accent) 24%, var(--line));
  font-family: var(--tracker-font);
  font-size: 0.58rem;
  font-weight: 900;
  text-transform: uppercase;
}

.effect-param-slot {
  color: var(--muted);
  background: color-mix(in srgb, var(--panel-2) 82%, transparent);
}

.effect-param-type {
  color: var(--text);
  background: color-mix(in srgb, var(--tracker-cell) 86%, var(--accent) 10%);
}

.effect-param-controls {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: center;
  gap: 5px;
  min-width: 0;
  padding: 5px;
}

.effect-param-field {
  display: grid;
  grid-template-columns: 42px minmax(58px, 1fr) 34px;
  align-items: center;
  gap: 5px;
  min-width: 0;
  color: var(--muted);
  font-family: var(--tracker-font);
  font-size: 0.58rem;
  font-weight: 900;
  text-transform: uppercase;
}

.effect-param-field input[type="range"] {
  width: 100%;
  min-width: 0;
  accent-color: var(--accent);
}

.effect-param-value {
  min-height: 22px;
  display: inline-grid;
  place-items: center;
  border: 1px solid color-mix(in srgb, var(--accent) 30%, var(--line));
  color: var(--amber);
  background: var(--tracker-cell);
  font-size: 0.58rem;
  font-variant-numeric: tabular-nums;
}

.effect-param-empty {
  display: inline-grid;
  align-items: center;
  min-height: 24px;
  padding: 0 7px;
  color: color-mix(in srgb, var(--muted) 72%, transparent);
  font-family: var(--tracker-font);
  font-size: 0.58rem;
  font-weight: 900;
  text-transform: uppercase;
}

.macro-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 4px 10px;
  min-width: 0;
}

.macro-help-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 5px;
  margin: 6px 0;
}

.macro-help-grid span {
  display: grid;
  gap: 3px;
  min-width: 0;
  min-height: 54px;
  padding: 7px;
  border: 1px solid color-mix(in srgb, var(--accent) 24%, var(--line));
  color: var(--muted);
  background: color-mix(in srgb, var(--tracker-cell) 84%, transparent);
  font-family: var(--tracker-font);
  font-size: 0.58rem;
  font-weight: 900;
  line-height: 1.2;
  text-transform: uppercase;
}

.macro-help-grid strong {
  color: var(--lime);
  font-size: 0.62rem;
}

.macro-example-note {
  margin: 0 0 6px;
  padding: 6px 7px 4px;
  border: 1px solid color-mix(in srgb, var(--amber) 34%, var(--line));
  color: var(--amber);
  background: color-mix(in srgb, var(--tracker-cell) 82%, var(--amber) 8%);
  font-family: var(--tracker-font);
  font-size: 0.58rem;
  font-weight: 900;
  line-height: 1.25;
  text-transform: uppercase;
}

.macro-name-field input {
  width: 100%;
  min-width: 0;
  min-height: 24px;
  padding: 0 7px;
  border: 1px solid color-mix(in srgb, var(--accent) 28%, var(--line));
  border-radius: 0;
  color: var(--text);
  background: var(--tracker-cell);
  font-family: var(--tracker-font);
  font-size: 0.62rem;
  font-weight: 900;
}

.macro-name-field input:focus-visible {
  border-color: color-mix(in srgb, var(--amber) 64%, var(--line));
  outline: 1px solid color-mix(in srgb, var(--amber) 54%, transparent);
  outline-offset: 1px;
}

.matrix-grid {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.matrix-quick-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin: 0 0 6px;
  min-width: 0;
}

.matrix-quick-actions .ghost-button {
  min-height: 24px;
  min-width: 0;
  padding: 0 7px;
  border-color: color-mix(in srgb, var(--accent) 34%, var(--line));
  color: var(--text);
  background: color-mix(in srgb, var(--tracker-cell) 86%, var(--accent) 12%);
  font-size: 0.58rem;
}

.matrix-quick-actions .ghost-button:hover,
.matrix-quick-actions .ghost-button:focus-visible,
.matrix-quick-actions .ghost-button.active {
  border-color: color-mix(in srgb, var(--amber) 58%, var(--line));
  color: var(--amber);
}

.matrix-dice-actions {
  display: grid;
  grid-template-columns: minmax(120px, 1fr) auto minmax(160px, 1fr);
  gap: 5px;
  align-items: center;
  margin: 0 0 6px;
  min-width: 0;
}

.matrix-dice-actions .ghost-button {
  min-height: 26px;
  border-color: color-mix(in srgb, var(--amber) 46%, var(--line));
  color: var(--amber);
  background: color-mix(in srgb, var(--tracker-cell) 78%, var(--amber) 12%);
  font-size: 0.58rem;
}

.matrix-dice-actions label {
  display: grid;
  grid-template-columns: auto minmax(72px, 1fr) auto;
  gap: 6px;
  align-items: center;
  min-width: 0;
  min-height: 26px;
  padding: 3px 6px;
  border: 1px solid color-mix(in srgb, var(--accent) 28%, var(--line));
  color: var(--muted);
  background: color-mix(in srgb, var(--tracker-cell) 84%, transparent);
  font-family: var(--tracker-font);
  font-size: 0.58rem;
  font-weight: 900;
  text-transform: uppercase;
}

.matrix-dice-actions input[type="range"] {
  width: 100%;
  min-width: 0;
  accent-color: var(--amber);
}

.matrix-dice-actions select {
  min-width: 0;
  width: 100%;
  border: 1px solid color-mix(in srgb, var(--accent) 28%, var(--line));
  color: var(--text);
  background: var(--tracker-cell);
  font-family: var(--tracker-font);
  font-size: 0.58rem;
  font-weight: 900;
}

.matrix-dice-actions strong {
  color: var(--amber);
  font-variant-numeric: tabular-nums;
  text-align: right;
}

.matrix-routes-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-height: 28px;
  margin: 0 0 6px;
  padding: 5px 7px;
  border: 1px solid color-mix(in srgb, var(--accent) 30%, var(--line));
  color: var(--text);
  background: color-mix(in srgb, var(--tracker-cell) 88%, var(--accent) 8%);
  font-family: var(--tracker-font);
  font-size: 0.62rem;
  font-weight: 900;
  text-transform: uppercase;
}

.matrix-routes-toggle input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--lime);
}

.matrix-status {
  min-height: 22px;
  margin: 0 0 5px;
  padding: 5px 7px 3px;
  border: 1px solid color-mix(in srgb, var(--accent) 24%, var(--line));
  color: var(--muted);
  background: color-mix(in srgb, var(--tracker-cell) 84%, transparent);
  font-family: var(--tracker-font);
  font-size: 0.58rem;
  font-weight: 900;
  line-height: 1.15;
  text-transform: uppercase;
}

.matrix-status[data-state="active"] {
  border-color: color-mix(in srgb, var(--lime) 44%, var(--line));
  color: var(--lime);
}

.matrix-status[data-state="warning"] {
  border-color: color-mix(in srgb, var(--amber) 58%, var(--line));
  color: var(--amber);
}

.matrix-route-row {
  display: grid;
  grid-template-columns: 18px minmax(82px, 1fr) minmax(96px, 1.1fr) 64px minmax(76px, 1fr) 34px 54px;
  align-items: center;
  gap: 5px;
  min-width: 0;
}

.matrix-route-row[data-state="active"] select,
.matrix-route-row[data-state="active"] .matrix-route-scope,
.matrix-route-row[data-state="active"] .matrix-amount-value {
  border-color: color-mix(in srgb, var(--lime) 42%, var(--line));
}

.matrix-route-row[data-state="incomplete"] select,
.matrix-route-row[data-state="incomplete"] .matrix-route-scope,
.matrix-route-row[data-state="incomplete"] .matrix-amount-value {
  border-color: color-mix(in srgb, var(--amber) 62%, var(--line));
  color: var(--amber);
}

.matrix-route-row[data-state="zero"] select,
.matrix-route-row[data-state="zero"] .matrix-route-scope,
.matrix-route-row[data-state="zero"] .matrix-amount-value {
  border-color: color-mix(in srgb, var(--accent) 46%, var(--line));
}

.matrix-route-row::before {
  content: attr(data-route);
  display: none;
}

.matrix-route-row input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: var(--lime);
}

.matrix-route-row select,
.matrix-route-scope,
.matrix-amount-value {
  min-width: 0;
  min-height: 24px;
  border: 1px solid color-mix(in srgb, var(--accent) 28%, var(--line));
  border-radius: 0;
  color: var(--text);
  background: var(--tracker-cell);
  font-family: var(--tracker-font);
  font-size: 0.6rem;
  font-weight: 900;
}

.matrix-route-row select {
  width: 100%;
  padding: 0 5px;
}

.matrix-route-scope {
  display: inline-grid;
  place-items: center;
  padding: 0 4px;
  color: var(--muted);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.matrix-route-scope[data-scope="live"] {
  border-color: color-mix(in srgb, var(--lime) 48%, var(--line));
  color: var(--lime);
}

.matrix-route-scope[data-scope="stored"] {
  border-color: color-mix(in srgb, var(--cyan) 36%, var(--line));
  color: var(--cyan);
}

.matrix-route-scope[data-scope="routes-off"] {
  border-color: color-mix(in srgb, var(--amber) 56%, var(--line));
  color: var(--amber);
}

.matrix-route-row input[type="range"] {
  width: 100%;
  min-width: 0;
  accent-color: var(--accent);
}

.matrix-amount-value {
  display: inline-grid;
  place-items: center;
  color: var(--amber);
  font-variant-numeric: tabular-nums;
}

.matrix-route-row:focus-within select,
.matrix-route-row:focus-within .matrix-route-scope,
.matrix-route-row:focus-within .matrix-amount-value {
  border-color: color-mix(in srgb, var(--amber) 54%, var(--line));
}

.tracker-midi-panel {
  --accent: #7de0ad;
  min-height: 0;
  margin: 0 0 8px;
  padding: 8px;
}

.tracker-midi-panel .button-row {
  padding: 3px 0 0;
  gap: 4px;
}

.tracker-midi-panel .module-title {
  min-height: 24px;
  margin-bottom: 6px;
  padding: 3px 6px;
}

.tracker-midi-panel .module-title span {
  font-size: 0.72rem;
  line-height: 1;
}

.tracker-midi-panel .module-title strong {
  font-size: 0.66rem;
  line-height: 1;
}

.tracker-midi-panel .ghost-button {
  min-height: 26px;
  padding: 0 8px;
  border-color: color-mix(in srgb, var(--accent) 34%, var(--line));
  background: color-mix(in srgb, var(--tracker-cell) 88%, var(--accent) 12%);
  font-size: 0.66rem;
  line-height: 1;
  max-width: 150px;
}

.tracker-midi-panel .ghost-button:hover,
.tracker-midi-panel .ghost-button:focus-visible {
  border-color: color-mix(in srgb, var(--accent) 58%, var(--line));
  background: color-mix(in srgb, var(--tracker-cell) 72%, var(--accent) 22%);
}

.tracker-midi-panel .module-note {
  margin-top: 6px;
  font-size: 0.66rem;
  line-height: 1.25;
}

.module-rack {
  --accent: #ff8a5c;
  grid-column: span 4;
}

.module-wide {
  grid-column: span 2;
}

.module-live-slot {
  --accent: #7bdff2;
  position: relative;
  z-index: 5;
  grid-column: span 3;
}

.module-project {
  grid-column: span 2;
}

.module-rack.module-wide {
  grid-column: span 4;
}

.module-title,
.section-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

.module-title {
  min-height: 28px;
  margin: -1px -1px 8px;
  padding: 4px 6px;
  border: 1px solid color-mix(in srgb, var(--accent) 26%, var(--line));
  background: var(--tracker-cell);
  min-width: 0;
}

.module:focus-within .module-title {
  border-color: color-mix(in srgb, var(--accent) 48%, var(--line));
}

.module-title span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
  color: var(--text);
  font-family: var(--tracker-font);
  font-size: 0.76rem;
  font-weight: 800;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-transform: uppercase;
}

.module-title strong {
  flex: 0 0 auto;
  max-width: 48%;
  color: var(--amber);
  font-family: var(--tracker-font);
  font-size: 0.64rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.field {
  display: grid;
  grid-template-columns: minmax(62px, 0.8fr) minmax(0, 1.4fr);
  align-items: center;
  gap: 6px;
  margin: 5px 0;
  color: var(--muted);
  font-family: var(--tracker-font);
  font-size: 0.66rem;
  font-weight: 800;
  min-width: 0;
}

.field.has-value-cell {
  grid-template-columns: minmax(58px, 0.76fr) minmax(0, 1fr) minmax(48px, 0.48fr);
}

.field.has-value-unit {
  grid-template-columns: minmax(58px, 0.74fr) minmax(0, 0.92fr) minmax(42px, 0.42fr) minmax(28px, 0.26fr);
}

.field.has-knob {
  grid-template-columns: minmax(58px, 0.74fr) 34px minmax(48px, 0.5fr);
}

.field.has-knob.has-value-unit {
  grid-template-columns: minmax(58px, 0.68fr) 34px minmax(42px, 0.44fr) minmax(24px, 0.24fr);
}

.field > span,
.toggle-field > span,
.section-head h2 {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--tracker-font);
  line-height: 1.05;
  min-width: 0;
}

.field > span,
.toggle-field > span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.help-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  border: 1px solid color-mix(in srgb, var(--accent, var(--cyan)) 42%, rgba(255, 255, 255, 0.18));
  border-radius: 50%;
  color: var(--text);
  background: rgba(10, 11, 16, 0.62);
  font-size: 0.68rem;
  font-weight: 900;
  line-height: 1;
  cursor: help;
  flex: 0 0 auto;
}

.help-icon:hover {
  border-color: color-mix(in srgb, var(--amber) 58%, var(--line));
  color: var(--amber);
}

.help-icon:focus-visible {
  outline: 2px solid var(--amber);
  outline-offset: 2px;
}

.toggle-field {
  display: flex;
  align-items: center;
  gap: 7px;
  min-height: 30px;
  margin: 5px 0 8px;
  color: var(--text);
  font-family: var(--tracker-font);
  font-size: 0.7rem;
  font-weight: 800;
  min-width: 0;
}

.toggle-field input {
  flex: 0 0 auto;
  width: 16px;
  height: 16px;
  accent-color: var(--lime);
}

.toggle-field:focus-within {
  color: var(--lime);
}

.mini-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 6px;
  min-width: 0;
}

.mini-grid .field {
  grid-template-columns: minmax(58px, 0.76fr) minmax(0, 1fr);
}

.mini-grid .field.has-value-cell {
  grid-template-columns: minmax(58px, 0.72fr) minmax(76px, 1fr) minmax(48px, 0.44fr);
}

.mini-grid .field.has-value-unit {
  grid-template-columns: minmax(58px, 0.68fr) minmax(72px, 0.86fr) minmax(42px, 0.42fr) minmax(24px, 0.24fr);
}

.mini-grid .field.has-knob {
  grid-template-columns: minmax(58px, 0.7fr) 34px minmax(48px, 0.46fr);
}

.mini-grid .field.has-knob.has-value-unit {
  grid-template-columns: minmax(58px, 0.64fr) 34px minmax(42px, 0.42fr) minmax(24px, 0.22fr);
}

.range-backed-by-knob {
  display: none;
}

.range-knob {
  --knob-angle: -135deg;
  position: relative;
  width: 32px;
  height: 32px;
  min-width: 32px;
  min-height: 32px;
  margin: 0 auto;
  padding: 0;
  border: 1px solid color-mix(in srgb, var(--accent, var(--cyan)) 44%, var(--line));
  border-radius: 50%;
  color: var(--text);
  background:
    radial-gradient(circle at 50% 50%, color-mix(in srgb, var(--panel) 76%, #ffffff 8%) 0 42%, transparent 44%),
    conic-gradient(from -135deg, color-mix(in srgb, var(--accent, var(--cyan)) 86%, #eef2db 8%) 0deg, color-mix(in srgb, var(--accent, var(--cyan)) 86%, #eef2db 8%) calc(var(--knob-angle) + 135deg), color-mix(in srgb, var(--tracker-cell) 90%, #000 10%) 0 270deg, transparent 270deg 360deg);
  box-shadow:
    inset 0 0 0 3px rgba(0, 0, 0, 0.42),
    0 0 0 1px rgba(255, 255, 255, 0.035);
  cursor: ns-resize;
  touch-action: none;
}

.range-knob::before {
  content: "";
  position: absolute;
  inset: 5px;
  border: 1px solid color-mix(in srgb, var(--line) 70%, var(--accent, var(--cyan)) 30%);
  border-radius: 50%;
  background: color-mix(in srgb, var(--panel-2) 86%, #000 14%);
}

.range-knob-zone {
  display: none;
  position: absolute;
  inset: 2px;
  border-radius: 50%;
  pointer-events: none;
}

.range-knob.is-log-taper .range-knob-zone {
  display: block;
  transform: rotate(var(--knob-guide-angle, -21deg));
}

.range-knob.is-log-taper .range-knob-zone::before {
  content: "";
  position: absolute;
  top: 0;
  left: calc(50% - 1px);
  width: 2px;
  height: 6px;
  background: color-mix(in srgb, var(--amber) 72%, var(--accent, var(--cyan)) 28%);
  box-shadow: 0 0 6px color-mix(in srgb, var(--amber) 42%, transparent);
}

.range-knob-pointer {
  position: absolute;
  inset: 4px;
  border-radius: 50%;
  transform: rotate(var(--knob-angle));
  pointer-events: none;
}

.range-knob-pointer::before {
  content: "";
  position: absolute;
  top: 2px;
  left: calc(50% - 1px);
  width: 2px;
  height: 10px;
  background: var(--amber);
  box-shadow: 0 0 8px color-mix(in srgb, var(--amber) 56%, transparent);
}

.range-knob:hover,
.range-knob:focus-visible,
.range-knob.is-dragging {
  border-color: color-mix(in srgb, var(--amber) 70%, var(--line));
  outline: none;
}

.range-knob:hover .range-knob-pointer::before,
.range-knob:focus-visible .range-knob-pointer::before,
.range-knob.is-dragging .range-knob-pointer::before {
  background: color-mix(in srgb, var(--amber) 82%, #ffffff 18%);
}

.range-knob.is-dragging {
  background:
    radial-gradient(circle at 50% 50%, color-mix(in srgb, var(--panel) 62%, var(--amber) 12%) 0 42%, transparent 44%),
    conic-gradient(from -135deg, color-mix(in srgb, var(--amber) 82%, var(--accent, var(--cyan)) 18%) 0deg, color-mix(in srgb, var(--amber) 82%, var(--accent, var(--cyan)) 18%) calc(var(--knob-angle) + 135deg), color-mix(in srgb, var(--tracker-cell) 90%, #000 10%) 0 270deg, transparent 270deg 360deg);
}

.range-knob.is-default .range-knob-pointer::before {
  background: color-mix(in srgb, var(--text) 72%, var(--amber) 28%);
  box-shadow: none;
}

.range-knob:focus-visible {
  box-shadow:
    inset 0 0 0 3px rgba(0, 0, 0, 0.42),
    0 0 0 2px color-mix(in srgb, var(--amber) 52%, transparent);
}

.range-knob.is-default {
  border-color: color-mix(in srgb, var(--accent, var(--cyan)) 30%, var(--line));
}

.range-knob.is-default::after {
  content: "";
  position: absolute;
  left: calc(50% - 1px);
  bottom: 5px;
  width: 2px;
  height: 3px;
  background: color-mix(in srgb, var(--muted) 74%, var(--accent, var(--cyan)) 26%);
}

body.is-knob-dragging,
body.is-knob-dragging * {
  cursor: ns-resize !important;
  user-select: none;
}

.range-value-cell {
  width: 100%;
  min-width: 0;
  min-height: 24px;
  padding: 0 6px;
  border: 1px solid color-mix(in srgb, var(--accent) 28%, var(--line));
  border-radius: 0;
  color: var(--amber);
  background: var(--tracker-cell);
  font-family: var(--tracker-font);
  font-size: 0.62rem;
  font-weight: 900;
  font-variant-numeric: tabular-nums;
  line-height: 1;
  text-align: right;
}

.range-value-cell:focus-visible {
  border-color: color-mix(in srgb, var(--amber) 64%, var(--line));
  outline: 1px solid color-mix(in srgb, var(--amber) 54%, transparent);
  outline-offset: 1px;
}

.range-value-cell.invalid-input {
  border-color: color-mix(in srgb, var(--pink) 74%, var(--line));
  color: var(--pink);
  background: color-mix(in srgb, var(--tracker-cell) 78%, var(--pink) 14%);
}

.range-value-unit {
  min-width: 0;
  color: color-mix(in srgb, var(--muted) 82%, var(--accent) 18%);
  font-family: var(--tracker-font);
  font-size: 0.56rem;
  font-weight: 900;
  line-height: 1;
  overflow: hidden;
  text-overflow: clip;
  text-transform: uppercase;
  white-space: nowrap;
}


.button-row {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 5px;
  min-width: 0;
}

.module-note {
  margin: 7px 0;
  color: var(--muted);
  font-family: var(--tracker-font);
  font-size: 0.64rem;
  font-weight: 800;
  line-height: 1.2;
  text-transform: uppercase;
  overflow-wrap: anywhere;
}

.live-slot-row {
  display: grid;
  grid-template-columns: minmax(180px, 1.4fr) repeat(4, minmax(68px, 0.62fr));
  gap: 5px;
  align-items: stretch;
  min-width: 0;
}

.live-slot-field {
  position: relative;
  margin: 0;
  min-height: 30px;
  overflow: visible;
}

.live-slot-row button {
  min-height: 30px;
  padding: 0 7px;
  border: 1px solid color-mix(in srgb, var(--accent) 34%, var(--line));
  border-radius: 0;
  color: var(--text);
  background: var(--tracker-cell);
  font-family: var(--tracker-font);
  font-size: 0.62rem;
  font-weight: 900;
  letter-spacing: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.live-slot-row button:hover,
.live-slot-row button:focus-visible,
.live-slot-row button.active {
  border-color: color-mix(in srgb, var(--accent) 68%, white 6%);
  color: var(--amber);
  background: color-mix(in srgb, var(--accent) 14%, var(--tracker-cell));
}

.live-slot-native-select {
  display: none;
}

.live-slot-picker-button {
  width: 100%;
  text-align: left;
}

.live-slot-picker-button::after {
  content: "▾";
  float: right;
  color: var(--muted);
}

.live-slot-picker-popup {
  position: absolute;
  z-index: 30;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  display: grid;
  gap: 3px;
  max-height: 310px;
  overflow-y: auto;
  padding: 5px;
  border: 1px solid color-mix(in srgb, var(--accent) 58%, var(--line));
  background: color-mix(in srgb, var(--panel) 94%, #000 6%);
  box-shadow: 0 14px 28px rgba(0, 0, 0, 0.42);
}

.live-slot-picker-popup[hidden] {
  display: none;
}

.live-slot-option {
  display: grid;
  grid-template-columns: 36px minmax(0, 1fr) 38px;
  gap: 5px;
  align-items: center;
  min-height: 28px;
  padding: 0 6px;
  text-align: left;
}

.live-slot-option span,
.live-slot-option em {
  display: inline-grid;
  place-items: center;
  min-height: 20px;
  border: 1px solid color-mix(in srgb, var(--accent) 26%, var(--line));
  color: var(--amber);
  background: color-mix(in srgb, var(--tracker-cell) 88%, #000 12%);
  font-style: normal;
  font-variant-numeric: tabular-nums;
}

.live-slot-option strong {
  overflow: hidden;
  color: var(--text);
  text-overflow: ellipsis;
  white-space: nowrap;
}

.live-slot-option.active {
  border-color: color-mix(in srgb, var(--accent) 72%, white 8%);
  background: color-mix(in srgb, var(--accent) 16%, var(--tracker-cell));
}

.live-slot-option:hover,
.live-slot-option:focus-visible {
  border-color: color-mix(in srgb, var(--amber) 72%, var(--line));
  color: var(--amber);
  outline: none;
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--amber) 38%, transparent);
}

.live-slot-option.triggered {
  border-color: color-mix(in srgb, var(--lime) 78%, white 10%);
  color: var(--lime);
  background: color-mix(in srgb, var(--lime) 14%, var(--tracker-cell));
  box-shadow: 0 0 12px color-mix(in srgb, var(--lime) 28%, transparent);
}

.live-slot-option.linked,
.live-slot-picker-button.linked {
  border-color: color-mix(in srgb, var(--lime) 72%, white 8%);
  color: var(--lime);
  background: color-mix(in srgb, var(--lime) 11%, var(--tracker-cell));
}

.live-slot-option.dirty,
.live-slot-picker-button.dirty {
  border-color: color-mix(in srgb, var(--amber) 70%, var(--lime) 18%);
  color: var(--amber);
  background: color-mix(in srgb, var(--amber) 9%, var(--tracker-cell));
}

.module-live-slot.triggered {
  border-color: color-mix(in srgb, var(--lime) 72%, white 8%);
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--lime) 38%, transparent),
    0 0 18px color-mix(in srgb, var(--lime) 24%, transparent);
}

.live-slot-picker-button.triggered {
  border-color: color-mix(in srgb, var(--lime) 78%, white 10%);
  color: var(--lime);
  background: color-mix(in srgb, var(--lime) 14%, var(--tracker-cell));
  box-shadow: 0 0 12px color-mix(in srgb, var(--lime) 34%, transparent);
}

#liveSlotValue.linked {
  border-color: color-mix(in srgb, var(--lime) 72%, white 8%);
  color: var(--lime);
  background: color-mix(in srgb, var(--lime) 11%, var(--tracker-cell));
  box-shadow: inset 0 -2px 0 color-mix(in srgb, var(--lime) 76%, transparent);
}

#liveSlotValue.dirty {
  border-color: color-mix(in srgb, var(--amber) 70%, var(--lime) 18%);
  color: var(--amber);
  background: color-mix(in srgb, var(--amber) 9%, var(--tracker-cell));
  box-shadow: inset 0 -2px 0 color-mix(in srgb, var(--amber) 76%, transparent);
}

.live-slot-status {
  min-height: 28px;
  margin: 7px 0 0;
  padding: 5px 6px;
  border: 1px solid color-mix(in srgb, var(--accent) 22%, var(--line));
  color: var(--muted);
  background: color-mix(in srgb, var(--tracker-cell) 86%, black 14%);
  font-family: var(--tracker-font);
  font-size: 0.62rem;
  font-weight: 800;
  line-height: 1.25;
  overflow-wrap: anywhere;
  text-transform: uppercase;
}

.project-row {
  display: grid;
  grid-template-columns: minmax(180px, 1fr) repeat(4, minmax(72px, auto));
  gap: 5px;
  align-items: stretch;
  min-width: 0;
}

.project-title-field {
  margin: 0;
  min-height: 30px;
}

.project-title-field input {
  width: 100%;
  min-width: 0;
}

.project-row .ghost-button {
  min-height: 30px;
  padding: 0 8px;
  border-radius: 0;
  font-size: 0.62rem;
  font-weight: 900;
}

.project-status {
  min-height: 28px;
  margin-top: 7px;
  padding: 5px 6px;
  border: 1px solid color-mix(in srgb, var(--accent) 22%, var(--line));
  background: color-mix(in srgb, var(--tracker-cell) 86%, black 14%);
}

#songProjectValue.dirty {
  color: var(--pink);
}

.instrument-slots {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 5px;
  margin-bottom: 8px;
}

.instrument-slot-wrap {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 38px;
  min-width: 0;
  border: 1px solid var(--line);
  background: var(--tracker-cell);
}

.instrument-slot-wrap.active {
  border-color: color-mix(in srgb, var(--accent) 68%, white 6%);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent) 46%, transparent);
}

.instrument-slot-wrap.triggered {
  border-color: color-mix(in srgb, var(--lime) 76%, white 10%);
  background: color-mix(in srgb, var(--lime) 12%, var(--tracker-cell));
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--lime) 36%, transparent),
    0 0 14px color-mix(in srgb, var(--lime) 30%, transparent);
}

.instrument-slot-wrap.triggered .instrument-slot span {
  color: #071011;
  background: var(--lime);
}

.instrument-slot-wrap.triggered .instrument-slot strong,
.instrument-slot-wrap.triggered .instrument-slot small,
.instrument-slot-wrap.triggered .instrument-slot em {
  color: var(--lime);
}

.instrument-slot-wrap:focus-within,
.instrument-slot-wrap:hover {
  border-color: color-mix(in srgb, var(--accent) 54%, var(--line));
}

.instrument-slot {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  grid-template-rows: auto auto auto;
  column-gap: 8px;
  row-gap: 2px;
  min-height: 48px;
  padding: 6px;
  border: 0;
  border-right: 1px solid color-mix(in srgb, var(--line) 84%, transparent);
  border-radius: 0;
  color: var(--text);
  background: transparent;
  text-align: left;
  min-width: 0;
}

.instrument-slot:hover,
.instrument-slot:focus-visible,
.instrument-slot-ps:hover,
.instrument-slot-ps:focus-visible {
  color: var(--amber);
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  outline: 1px solid color-mix(in srgb, var(--accent) 34%, transparent);
  outline-offset: -1px;
}

.instrument-slot span {
  grid-row: span 3;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  width: 24px;
  height: 24px;
  border-radius: 0;
  color: #15110f;
  background: var(--accent);
  font-size: 0.78rem;
  font-weight: 900;
}

.instrument-slot strong,
.instrument-slot small,
.instrument-slot em {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.instrument-slot strong {
  font-family: var(--tracker-font);
  font-size: 0.7rem;
}

.instrument-slot small {
  color: var(--muted);
  font-size: 0.64rem;
  font-weight: 800;
}

.instrument-slot em {
  color: var(--amber);
  font-family: var(--tracker-font);
  font-size: 0.58rem;
  font-style: normal;
  font-weight: 900;
}

.instrument-mixer-panel {
  display: grid;
  grid-template-columns: 56px minmax(104px, 1fr) repeat(6, minmax(58px, auto));
  gap: 5px;
  align-items: stretch;
  min-width: 0;
  margin: 0 0 8px;
}

.instrument-mixer-label,
.instrument-mixer-panel strong {
  display: inline-grid;
  place-items: center;
  min-height: 28px;
  padding: 0 7px;
  border: 1px solid color-mix(in srgb, var(--accent) 24%, var(--line));
  color: var(--muted);
  background: var(--tracker-cell);
  font-family: var(--tracker-font);
  font-size: 0.62rem;
  font-weight: 900;
  text-transform: uppercase;
  white-space: nowrap;
}

.instrument-mixer-panel strong {
  color: var(--amber);
  font-variant-numeric: tabular-nums;
}

.instrument-mixer-panel .ghost-button {
  min-height: 28px;
  padding: 0 7px;
  border-radius: 0;
  font-size: 0.6rem;
}

.instrument-mixer-panel .ghost-button.active {
  color: #071011;
  background: var(--lime);
  border-color: color-mix(in srgb, var(--lime) 72%, white 8%);
}

.instrument-slot-ps {
  display: grid;
  place-items: center;
  min-width: 0;
  min-height: 48px;
  padding: 0;
  border: 0;
  border-left: 1px solid color-mix(in srgb, var(--accent) 36%, var(--line));
  color: #15110f;
  background: var(--accent);
  font-family: var(--tracker-font);
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0;
}

select {
  width: 100%;
  height: 28px;
  border: 1px solid var(--line);
  border-radius: 0;
  color: var(--text);
  background: var(--tracker-cell);
  padding: 0 7px;
  font-family: var(--tracker-font);
  font-size: 0.68rem;
  min-width: 0;
}

select:hover {
  border-color: color-mix(in srgb, var(--accent, var(--cyan)) 40%, var(--line));
}

select:focus-visible {
  border-color: color-mix(in srgb, var(--accent, var(--cyan)) 68%, var(--line));
  outline: 1px solid color-mix(in srgb, var(--accent, var(--cyan)) 38%, transparent);
  outline-offset: 1px;
}

input[type="range"] {
  width: 100%;
  accent-color: var(--cyan);
  min-height: 20px;
  margin: 0;
  background: transparent;
  appearance: none;
  cursor: pointer;
}

input[type="range"]:focus-visible {
  outline: 1px solid color-mix(in srgb, var(--accent, var(--cyan)) 54%, transparent);
  outline-offset: 3px;
}

input[type="range"]::-moz-range-track {
  height: 5px;
  border: 1px solid color-mix(in srgb, var(--accent, var(--cyan)) 34%, var(--line));
  background: #050706;
}

input[type="range"]::-moz-range-progress {
  height: 5px;
  background: color-mix(in srgb, var(--accent, var(--cyan)) 70%, #eef2db 6%);
}

input[type="range"]::-moz-range-thumb {
  width: 14px;
  height: 18px;
  border: 1px solid #eef2db;
  border-radius: 0;
  background: #30363f;
  cursor: pointer;
}

input[type="range"]::-webkit-slider-runnable-track {
  height: 5px;
  border: 1px solid color-mix(in srgb, var(--accent, var(--cyan)) 34%, var(--line));
  background: #050706;
}

input[type="range"]::-webkit-slider-thumb {
  width: 14px;
  height: 18px;
  margin-top: -7px;
  border: 1px solid #eef2db;
  border-radius: 0;
  background: #30363f;
  appearance: none;
  cursor: pointer;
}

input[type="range"]:active::-moz-range-thumb {
  background: var(--amber);
}

input[type="range"]:active::-webkit-slider-thumb {
  background: var(--amber);
}

.sequencer,
.tracker,
.drums,
.keyboard,
.performance-surface {
  --accent: var(--cyan);
  border-radius: 0;
  padding: 10px;
  border-color: color-mix(in srgb, var(--accent) 30%, var(--line));
  box-shadow:
    inset 0 2px 0 color-mix(in srgb, var(--accent) 54%, transparent),
    var(--tracker-panel-shadow);
}

.performance-surface {
  display: none;
  margin: 8px 0 0;
}

html[data-work-mode="performance"] .performance-surface {
  display: block;
}

.performance-surface .section-head > strong {
  display: inline-grid;
  place-items: center;
  min-height: 26px;
  padding: 0 8px;
  border: 1px solid color-mix(in srgb, var(--amber) 38%, var(--line));
  color: var(--amber);
  background: var(--tracker-cell-2);
  font-family: var(--tracker-font);
  font-size: 0.68rem;
  text-transform: uppercase;
}

.performance-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr) minmax(0, 1fr);
  gap: 8px;
  margin-bottom: 8px;
}

.performance-basis-status {
  margin: 0 0 6px;
}

.performance-status {
  min-height: 24px;
  margin: 0 0 8px;
  padding: 6px 8px 4px;
  border: 1px solid color-mix(in srgb, var(--accent) 24%, var(--line));
  color: var(--muted);
  background: var(--tracker-cell);
  font-family: var(--tracker-font);
  font-size: 0.62rem;
  font-weight: 900;
  text-transform: uppercase;
}

.performance-guide-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 5px;
  margin: 0 0 8px;
  min-width: 0;
}

.performance-guide-strip span {
  display: inline-grid;
  place-items: center;
  min-width: 0;
  min-height: 26px;
  padding: 4px 6px 3px;
  border: 1px solid color-mix(in srgb, var(--accent) 24%, var(--line));
  color: var(--muted);
  background: color-mix(in srgb, var(--panel) 84%, transparent);
  font-family: var(--tracker-font);
  font-size: 0.58rem;
  font-weight: 900;
  line-height: 1.1;
  text-align: center;
  text-transform: uppercase;
}

.performance-guide-strip span[data-state="active"] {
  border-color: color-mix(in srgb, var(--lime) 44%, var(--line));
  color: var(--lime);
}

.performance-guide-strip span[data-state="warning"] {
  border-color: color-mix(in srgb, var(--amber) 58%, var(--line));
  color: var(--amber);
}

.performance-panel {
  display: grid;
  align-content: start;
  gap: 7px;
  min-height: 180px;
  padding: 10px;
  border: 1px solid color-mix(in srgb, var(--amber) 28%, var(--line));
  background: var(--tracker-cell);
}

.performance-panel:hover {
  border-color: color-mix(in srgb, var(--amber) 44%, var(--line));
  background: color-mix(in srgb, var(--tracker-cell) 88%, var(--amber) 6%);
}

.performance-panel-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-height: 28px;
  padding: 0 7px;
  border: 1px solid color-mix(in srgb, var(--amber) 28%, var(--line));
  background: color-mix(in srgb, var(--panel) 88%, transparent);
  color: var(--text);
  font-family: var(--tracker-font);
  font-size: 0.62rem;
  font-weight: 900;
  text-transform: uppercase;
}

.performance-panel-title strong,
.performance-macro-readout,
.performance-xy-axis strong {
  color: var(--amber);
  font-variant-numeric: tabular-nums;
}

.performance-panel-note {
  min-height: 24px;
  margin: 0;
  padding: 5px 7px 3px;
  border: 1px solid color-mix(in srgb, var(--accent) 24%, var(--line));
  color: var(--muted);
  background: color-mix(in srgb, var(--panel) 84%, transparent);
  font-family: var(--tracker-font);
  font-size: 0.58rem;
  font-weight: 900;
  line-height: 1.2;
  text-transform: uppercase;
}

.performance-macro-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
}

.performance-macro-pad,
.performance-xy-axis,
.performance-program {
  display: grid;
  grid-template-columns: 1fr;
  gap: 5px;
  min-width: 0;
  padding: 7px;
  border: 1px solid color-mix(in srgb, var(--accent) 22%, var(--line));
  background: color-mix(in srgb, var(--panel) 86%, transparent);
}

.performance-macro-name,
.performance-xy-axis span,
.performance-program span {
  min-width: 0;
  overflow: hidden;
  color: var(--text);
  font-family: var(--tracker-font);
  font-size: 0.62rem;
  font-weight: 900;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-transform: uppercase;
}

.performance-macro-pad input[type="range"],
.performance-xy-axis input[type="range"] {
  width: 100%;
  min-width: 0;
  accent-color: var(--amber);
}

.performance-program select {
  width: 100%;
  min-height: 28px;
  border: 1px solid color-mix(in srgb, var(--amber) 28%, var(--line));
  color: var(--text);
  background: var(--tracker-cell-2);
  font-family: var(--tracker-font);
  font-size: 0.62rem;
  font-weight: 900;
  text-transform: uppercase;
}

.performance-xy-pad {
  position: relative;
  min-height: 190px;
  border: 1px solid color-mix(in srgb, var(--amber) 42%, var(--line));
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--panel) 94%, transparent), color-mix(in srgb, var(--amber) 10%, var(--panel))),
    linear-gradient(0deg, color-mix(in srgb, var(--panel) 94%, transparent), color-mix(in srgb, var(--cyan) 12%, transparent)),
    repeating-linear-gradient(90deg, transparent 0 24px, color-mix(in srgb, var(--line) 32%, transparent) 24px 25px),
    repeating-linear-gradient(0deg, transparent 0 24px, color-mix(in srgb, var(--line) 32%, transparent) 24px 25px);
  cursor: crosshair;
  touch-action: none;
  overflow: hidden;
}

.performance-xy-pad:focus-visible {
  outline: 1px solid color-mix(in srgb, var(--amber) 62%, var(--line));
  outline-offset: 2px;
}

.performance-xy-pad::before,
.performance-xy-pad::after {
  content: "";
  position: absolute;
  pointer-events: none;
  background: color-mix(in srgb, var(--amber) 34%, transparent);
}

.performance-xy-pad::before {
  left: 50%;
  top: 0;
  bottom: 0;
  width: 1px;
}

.performance-xy-pad::after {
  left: 0;
  right: 0;
  top: 50%;
  height: 1px;
}

.performance-xy-corner {
  position: absolute;
  z-index: 1;
  padding: 4px 5px;
  color: color-mix(in srgb, var(--muted) 76%, transparent);
  font-family: var(--tracker-font);
  font-size: 0.54rem;
  font-weight: 900;
  text-transform: uppercase;
  pointer-events: none;
}

.performance-xy-corner.top-left {
  top: 0;
  left: 0;
}

.performance-xy-corner.top-right {
  top: 0;
  right: 0;
}

.performance-xy-corner.bottom-left {
  bottom: 0;
  left: 0;
}

.performance-xy-corner.bottom-right {
  right: 0;
  bottom: 0;
}

.performance-xy-cursor {
  position: absolute;
  z-index: 2;
  width: 18px;
  height: 18px;
  border: 2px solid var(--amber);
  background: color-mix(in srgb, var(--tracker-cell) 64%, transparent);
  box-shadow:
    0 0 0 1px #000,
    0 0 18px color-mix(in srgb, var(--amber) 36%, transparent);
  transform: translate(-50%, -50%);
  pointer-events: none;
}

.performance-macro-readout,
.performance-xy-axis strong {
  min-height: 24px;
  display: inline-grid;
  place-items: center;
  border: 1px solid color-mix(in srgb, var(--amber) 34%, var(--line));
  background: var(--tracker-cell-2);
  font-family: var(--tracker-font);
  font-size: 0.62rem;
  font-weight: 900;
}

.performance-xy-readout,
.performance-scenes,
.performance-fx-grid {
  display: grid;
  gap: 6px;
}

.performance-xy-readout {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.performance-scenes {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.performance-scenes .ghost-button {
  min-height: 30px;
  padding: 0 8px;
  color: var(--text);
  border-color: color-mix(in srgb, var(--amber) 30%, var(--line));
  background: color-mix(in srgb, var(--tracker-cell) 86%, var(--amber) 8%);
  font-size: 0.58rem;
}

.performance-scenes .ghost-button[data-performance-action] {
  color: var(--amber);
  border-color: color-mix(in srgb, var(--amber) 48%, var(--line));
  background: color-mix(in srgb, var(--tracker-cell) 78%, var(--amber) 14%);
}

.performance-scenes .ghost-button:hover,
.performance-scenes .ghost-button:focus-visible {
  color: var(--amber);
  border-color: color-mix(in srgb, var(--amber) 56%, var(--line));
}

.performance-fx-chip {
  min-height: 28px;
  display: inline-grid;
  align-items: center;
  padding: 0 8px;
  border: 1px solid color-mix(in srgb, var(--accent) 22%, var(--line));
  color: var(--muted);
  background: color-mix(in srgb, var(--panel) 86%, transparent);
  font-family: var(--tracker-font);
  font-size: 0.58rem;
  font-weight: 900;
  text-transform: uppercase;
}

.performance-fx-chip[data-state="active"] {
  border-color: color-mix(in srgb, var(--lime) 42%, var(--line));
  color: var(--lime);
}

.performance-system {
  min-height: 0;
  border-color: color-mix(in srgb, var(--cyan) 34%, var(--line));
}

.system-monitor-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 6px;
}

.system-metric {
  display: grid;
  gap: 4px;
  min-width: 0;
  min-height: 44px;
  padding: 6px 7px 5px;
  border: 1px solid color-mix(in srgb, var(--cyan) 24%, var(--line));
  background: color-mix(in srgb, var(--panel) 88%, transparent);
  font-family: var(--tracker-font);
  text-transform: uppercase;
}

.system-metric span {
  overflow: hidden;
  color: var(--muted);
  font-size: 0.54rem;
  font-weight: 900;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.system-metric strong {
  overflow: hidden;
  color: var(--cyan);
  font-size: 0.68rem;
  font-weight: 900;
  font-variant-numeric: tabular-nums;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.system-metric[data-state="active"] strong {
  color: var(--lime);
}

.system-metric[data-state="warning"] strong {
  color: var(--amber);
}

.signal-flow-strip {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 6px;
  align-items: stretch;
}

.signal-flow-mode-strip {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(122px, 1fr));
  gap: 6px;
  overflow: visible;
  padding-bottom: 0;
}

.signal-flow-mode-strip .signal-flow-node:not(:last-child)::after {
  display: none;
}

.module-effect-signal .signal-flow-mode-strip {
  grid-template-columns: 1fr;
}

.patchbay-lane {
  display: grid;
  grid-template-columns: 82px minmax(0, 1fr);
  align-items: stretch;
  gap: 6px;
  min-width: 0;
}

.patchbay-lane-label {
  display: grid;
  place-items: center;
  min-height: 48px;
  padding: 4px 5px;
  border: 1px solid color-mix(in srgb, var(--cyan) 22%, var(--line));
  color: var(--muted);
  background: color-mix(in srgb, var(--tracker-cell-2) 90%, transparent);
  font-family: var(--tracker-font);
  font-size: 0.5rem;
  font-weight: 900;
  line-height: 1.15;
  letter-spacing: 0;
  text-align: center;
  text-transform: uppercase;
}

.patchbay-lane-flow {
  display: grid;
  grid-template-columns: var(--patchbay-flow-columns, repeat(auto-fit, minmax(98px, 1fr)));
  align-items: stretch;
  gap: 0;
  min-width: 0;
  padding: 0;
  background:
    linear-gradient(
      to right,
      color-mix(in srgb, var(--cyan) 10%, transparent),
      transparent 14%,
      transparent 86%,
      color-mix(in srgb, var(--cyan) 10%, transparent)
    );
}

.patchbay-lane[data-lane="main"] .patchbay-lane-flow {
  --patchbay-node-min: 92px;
}

.patchbay-lane[data-lane="send"] .patchbay-lane-flow {
  --patchbay-node-min: 120px;
}

.patchbay-lane[data-lane="control"] .patchbay-lane-flow {
  --patchbay-node-min: 98px;
}

.patchbay-lane[data-lane="control"] .patchbay-lane-label,
.patchbay-lane[data-lane="control"] .signal-flow-node {
  border-style: dashed;
}

.patchbay-lane[data-lane="send"] .patchbay-lane-label {
  color: color-mix(in srgb, var(--cyan) 72%, var(--muted));
}

.patchbay-lane[data-lane="control"] .patchbay-lane-label {
  color: var(--amber);
}

.patchbay-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  min-width: 0;
}

.patchbay-legend span {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  min-height: 20px;
  padding: 2px 6px;
  border: 1px solid color-mix(in srgb, var(--cyan) 24%, var(--line));
  color: var(--muted);
  background: color-mix(in srgb, var(--panel) 84%, transparent);
  font-family: var(--tracker-font);
  font-size: 0.52rem;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.patchbay-legend span::before {
  content: "";
  display: inline-block;
  width: 14px;
  border-top: 3px solid color-mix(in srgb, var(--cyan) 62%, var(--line));
}

.patchbay-legend [data-legend="audio"] {
  color: var(--lime);
  border-color: color-mix(in srgb, var(--lime) 34%, var(--line));
}

.patchbay-legend [data-legend="audio"]::before {
  border-top-color: color-mix(in srgb, var(--lime) 66%, var(--line));
}

.patchbay-legend [data-legend="control"],
.patchbay-legend [data-legend="stored"] {
  color: var(--amber);
  border-color: color-mix(in srgb, var(--amber) 34%, var(--line));
}

.patchbay-legend [data-legend="control"]::before,
.patchbay-legend [data-legend="stored"]::before {
  border-top-color: color-mix(in srgb, var(--amber) 62%, var(--line));
  border-top-style: dashed;
}

.patchbay-legend [data-legend="bypassed"] {
  color: color-mix(in srgb, var(--muted) 82%, var(--text));
  border-color: color-mix(in srgb, var(--muted) 38%, var(--line));
}

.patchbay-legend [data-legend="bypassed"]::before {
  border-top-color: color-mix(in srgb, var(--muted) 62%, var(--line));
}

.patchbay-legend [data-legend="warning"] {
  color: var(--amber);
  border-color: color-mix(in srgb, var(--amber) 54%, var(--line));
}

.patchbay-legend [data-legend="warning"]::before {
  border-top-color: var(--amber);
}

.signal-flow-node {
  position: relative;
  display: grid;
  grid-template-columns: 18px minmax(0, 1fr) 20px;
  align-items: center;
  gap: 6px;
  min-width: 0;
  min-height: 48px;
  padding: 7px 9px;
  border: 1px solid color-mix(in srgb, var(--cyan) 26%, var(--line));
  background:
    linear-gradient(to bottom, color-mix(in srgb, var(--panel) 92%, transparent), color-mix(in srgb, var(--bg) 82%, var(--panel))),
    color-mix(in srgb, var(--panel) 86%, transparent);
  font-family: var(--tracker-font);
  text-transform: uppercase;
}

.signal-flow-node::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 24px;
  right: 26px;
  z-index: 0;
  border-top: 3px solid color-mix(in srgb, var(--cyan) 48%, var(--line));
  transform: translateY(-50%);
}

.signal-flow-node:not(:last-child)::after {
  content: ">";
  position: absolute;
  top: 50%;
  right: -9px;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  width: 11px;
  height: 13px;
  border-top: 0;
  color: color-mix(in srgb, var(--cyan) 72%, var(--text));
  background: linear-gradient(
    to right,
    color-mix(in srgb, var(--cyan) 58%, var(--line)),
    color-mix(in srgb, var(--cyan) 58%, var(--line))
  ) left 50% / 100% 3px no-repeat;
  font-family: var(--tracker-font);
  font-size: 0.62rem;
  font-weight: 900;
  line-height: 1;
  transform: translateY(-50%);
}

.patchbay-lane-flow .signal-flow-node:not(:last-child)::after {
  display: none;
}

.signal-flow-body {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 4px;
  min-width: 0;
  padding: 1px 4px;
  background: color-mix(in srgb, var(--panel) 90%, var(--bg));
}

.patchbay-lane-flow .signal-flow-body {
  background: color-mix(in srgb, var(--panel) 82%, var(--bg));
  box-shadow: 0 0 12px color-mix(in srgb, var(--bg) 72%, transparent);
}

.signal-flow-port {
  position: relative;
  z-index: 2;
  display: block;
  width: 16px;
  height: 16px;
  border: 1px solid color-mix(in srgb, white 42%, var(--line));
  border-radius: 50%;
  background:
    radial-gradient(circle at 50% 50%, var(--bg) 0 26%, transparent 28%),
    radial-gradient(circle at 40% 32%, color-mix(in srgb, white 42%, transparent) 0 18%, transparent 20%),
    color-mix(in srgb, var(--muted) 58%, var(--line));
  box-shadow:
    0 0 0 2px color-mix(in srgb, var(--panel) 84%, transparent),
    inset 0 0 0 2px color-mix(in srgb, var(--bg) 62%, transparent),
    inset 0 0 5px color-mix(in srgb, black 56%, transparent);
}

.signal-flow-port-in::before,
.signal-flow-port-out::before {
  content: "";
  position: absolute;
  top: 50%;
  width: 12px;
  border-top: 4px solid color-mix(in srgb, var(--cyan) 44%, var(--line));
  transform: translateY(-50%);
}

.signal-flow-port-in::before {
  left: -12px;
}

.signal-flow-port-out::before {
  right: -12px;
}

.signal-flow-port-out::after {
  display: none;
}

.signal-flow-port-terminal {
  width: 18px;
  height: 10px;
  align-self: center;
  border: 1px solid color-mix(in srgb, var(--muted) 58%, var(--line));
  border-radius: 2px;
  background:
    linear-gradient(
      to right,
      color-mix(in srgb, var(--muted) 68%, var(--line)),
      color-mix(in srgb, var(--panel) 66%, var(--muted))
    );
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--bg) 64%, transparent),
    0 0 0 2px color-mix(in srgb, var(--panel) 84%, transparent);
}

.signal-flow-port-terminal::before {
  content: "";
  position: absolute;
  top: 50%;
  left: -10px;
  width: 10px;
  border-top: 4px solid color-mix(in srgb, var(--muted) 48%, var(--line));
  transform: translateY(-50%);
}

.signal-flow-port-terminal::after {
  content: "";
  position: absolute;
  top: 50%;
  right: -3px;
  width: 3px;
  height: 14px;
  border-radius: 2px;
  background: color-mix(in srgb, var(--muted) 62%, var(--line));
  transform: translateY(-50%);
}

.signal-flow-port-source {
  width: 18px;
  height: 10px;
  align-self: center;
  border: 1px solid color-mix(in srgb, var(--cyan) 42%, var(--line));
  border-radius: 2px;
  background:
    linear-gradient(
      to right,
      color-mix(in srgb, var(--panel) 66%, var(--cyan)),
      color-mix(in srgb, var(--cyan) 58%, var(--line))
    );
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--bg) 62%, transparent),
    0 0 0 2px color-mix(in srgb, var(--panel) 84%, transparent);
}

.signal-flow-port-source::before {
  content: "";
  position: absolute;
  top: 50%;
  left: -3px;
  width: 3px;
  height: 14px;
  border-radius: 2px;
  background: color-mix(in srgb, var(--cyan) 46%, var(--line));
  transform: translateY(-50%);
}

.signal-flow-port-source::after {
  content: "";
  position: absolute;
  top: 50%;
  right: -10px;
  width: 10px;
  border-top: 4px solid color-mix(in srgb, var(--cyan) 50%, var(--line));
  transform: translateY(-50%);
}

.signal-flow-node[data-port-role="terminal"] .signal-flow-port-out::before {
  display: none;
}

.signal-flow-node[data-port-role="source"] .signal-flow-port-in::before {
  display: none;
}

.signal-flow-node span:not(.signal-flow-port) {
  overflow: hidden;
  color: var(--text);
  font-size: 0.58rem;
  font-weight: 900;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.patchbay-cable {
  --patchbay-cable-color: color-mix(in srgb, var(--muted) 46%, var(--line));
  --patchbay-plug-color: color-mix(in srgb, var(--muted) 58%, var(--line));
  position: relative;
  z-index: 4;
  display: grid;
  place-items: center;
  min-width: 38px;
  min-height: 48px;
  margin: 0 -5px;
  pointer-events: none;
}

.patchbay-cable-curve {
  display: block;
  width: calc(100% + 10px);
  height: 22px;
  overflow: visible;
  filter: drop-shadow(0 3px 4px color-mix(in srgb, black 40%, transparent));
}

.patchbay-cable-path {
  fill: none;
  stroke: var(--patchbay-cable-color);
  stroke-width: 5;
  stroke-linecap: round;
  stroke-linejoin: round;
  vector-effect: non-scaling-stroke;
}

.patchbay-cable-plug {
  position: absolute;
  top: 50%;
  z-index: 7;
  width: 20px;
  height: 20px;
  border: 1px solid color-mix(in srgb, white 34%, var(--patchbay-plug-color));
  border-radius: 50%;
  background:
    radial-gradient(circle at 36% 28%, color-mix(in srgb, white 42%, transparent) 0 15%, transparent 17%),
    radial-gradient(circle at 55% 58%, color-mix(in srgb, black 22%, transparent) 0 28%, transparent 31%),
    var(--patchbay-plug-color);
  box-shadow:
    0 0 0 2px color-mix(in srgb, var(--bg) 78%, transparent),
    inset 0 0 0 2px color-mix(in srgb, white 12%, transparent),
    0 2px 4px color-mix(in srgb, black 46%, transparent);
  transform: translateY(-50%);
}

.patchbay-cable-plug::before {
  content: "";
  position: absolute;
  top: 50%;
  z-index: -1;
  width: 18px;
  height: 9px;
  border-radius: 999px;
  background:
    repeating-linear-gradient(
      to right,
      color-mix(in srgb, black 18%, transparent) 0 2px,
      transparent 2px 5px
    ),
    linear-gradient(
      to bottom,
      color-mix(in srgb, white 18%, transparent),
      color-mix(in srgb, black 18%, var(--patchbay-plug-color))
    );
  box-shadow: 0 2px 4px color-mix(in srgb, black 42%, transparent);
  transform: translateY(-50%);
}

.patchbay-cable-plug-left {
  left: -20px;
}

.patchbay-cable-plug-left::before {
  right: -14px;
}

.patchbay-cable-plug-right {
  right: -20px;
}

.patchbay-cable-plug-right::before {
  left: -14px;
}

.patchbay-cable::after {
  content: ">";
  position: absolute;
  top: calc(50% + 2px);
  right: 2px;
  color: color-mix(in srgb, var(--muted) 82%, var(--text));
  font-family: var(--tracker-font);
  font-size: 0.62rem;
  font-weight: 900;
  line-height: 1;
  transform: translateY(-50%);
}

.patchbay-cable[data-state="active"] .patchbay-cable-curve {
  filter: drop-shadow(0 2px 3px color-mix(in srgb, black 34%, transparent));
}

.patchbay-cable[data-state="active"] {
  --patchbay-cable-color: color-mix(in srgb, var(--lime) 76%, var(--line));
  --patchbay-plug-color: color-mix(in srgb, var(--lime) 70%, var(--line));
}

.patchbay-cable[data-state="active"] .patchbay-cable-path {
  animation: patchbay-cable-drift 8.4s ease-in-out infinite;
}

.patchbay-cable[data-state="active"]::after {
  color: var(--lime);
}

.patchbay-cable[data-state="warning"] {
  --patchbay-cable-color: var(--amber);
  --patchbay-plug-color: color-mix(in srgb, var(--amber) 88%, var(--line));
}

.patchbay-cable[data-state="warning"]::after {
  color: var(--amber);
}

.patchbay-cable[data-state="bypassed"],
.patchbay-cable[data-state="off"] {
  opacity: 0.46;
}

.patchbay-cable[data-state="stored"] .patchbay-cable-path,
.patchbay-cable[data-kind="control"] .patchbay-cable-path {
  stroke: var(--patchbay-cable-color);
  stroke-width: 4;
  stroke-dasharray: 7 6;
}

.patchbay-cable[data-state="stored"],
.patchbay-cable[data-kind="control"] {
  --patchbay-cable-color: color-mix(in srgb, var(--amber) 64%, var(--line));
  --patchbay-plug-color: color-mix(in srgb, var(--amber) 58%, var(--line));
}

.patchbay-cable[data-state="stored"]::after,
.patchbay-cable[data-kind="control"]::after {
  color: var(--amber);
}

.patchbay-cable[data-route-role="internal"] {
  --patchbay-cable-color: color-mix(in srgb, var(--lime) 56%, var(--line));
  --patchbay-plug-color: color-mix(in srgb, var(--lime) 48%, var(--line));
}

.patchbay-cable[data-route-role="insert"],
.patchbay-cable[data-route-role="send"] {
  --patchbay-cable-color: color-mix(in srgb, var(--amber) 82%, var(--lime));
  --patchbay-plug-color: color-mix(in srgb, var(--amber) 88%, var(--line));
}

.patchbay-cable[data-route-role="terminal"] {
  --patchbay-cable-color: color-mix(in srgb, var(--amber) 70%, var(--line));
  --patchbay-plug-color: color-mix(in srgb, var(--amber) 58%, var(--line));
}

.patchbay-cable[data-route-role="terminal"] .patchbay-cable-plug-right {
  opacity: 0.82;
}

.patchbay-cable[data-route-role="control"] {
  --patchbay-cable-color: color-mix(in srgb, var(--amber) 58%, var(--line));
  --patchbay-plug-color: color-mix(in srgb, var(--amber) 52%, var(--line));
}

.patchbay-cable[data-state="off"][data-route-role="internal"],
.patchbay-cable[data-state="off"][data-route-role="terminal"] {
  --patchbay-cable-color: color-mix(in srgb, var(--muted) 44%, var(--line));
  --patchbay-plug-color: color-mix(in srgb, var(--muted) 48%, var(--line));
}

@keyframes patchbay-cable-drift {
  0%,
  100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(0.45px);
  }
}

@media (prefers-reduced-motion: reduce) {
  .patchbay-cable-path {
    animation: none !important;
  }
}

html[data-energy-mode="idle"] .patchbay-cable-path,
html[data-energy-mode="hidden"] .patchbay-cable-path {
  animation: none !important;
}

html[data-energy-mode="idle"] .patchbay-cable-curve,
html[data-energy-mode="hidden"] .patchbay-cable-curve {
  filter: none;
}

html[data-energy-mode="idle"] .patchbay-cable-plug,
html[data-energy-mode="hidden"] .patchbay-cable-plug,
html[data-energy-mode="idle"] .signal-flow-node[data-state="active"] .signal-flow-port,
html[data-energy-mode="hidden"] .signal-flow-node[data-state="active"] .signal-flow-port {
  box-shadow: inset 0 0 0 2px color-mix(in srgb, var(--bg) 52%, transparent);
}

.signal-flow-node strong {
  overflow: hidden;
  color: var(--muted);
  font-size: 0.52rem;
  font-weight: 900;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.signal-flow-node[data-state="active"] {
  border-color: color-mix(in srgb, var(--lime) 44%, var(--line));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--lime) 16%, transparent);
}

.signal-flow-node[data-state="active"] strong {
  color: var(--lime);
}

.signal-flow-node[data-state="active"] .signal-flow-port {
  border-color: color-mix(in srgb, var(--lime) 74%, var(--line));
  background:
    radial-gradient(circle at 50% 50%, color-mix(in srgb, var(--bg) 64%, transparent) 0 24%, transparent 26%),
    var(--lime);
  box-shadow:
    0 0 10px color-mix(in srgb, var(--lime) 58%, transparent),
    inset 0 0 0 2px color-mix(in srgb, var(--bg) 52%, transparent);
}

.signal-flow-node[data-state="active"] .signal-flow-port-in::before,
.signal-flow-node[data-state="active"] .signal-flow-port-out::before {
  border-top-color: color-mix(in srgb, var(--lime) 64%, var(--line));
}

.signal-flow-node[data-state="active"]:not(:last-child)::after {
  color: var(--lime);
  background: linear-gradient(
    to right,
    color-mix(in srgb, var(--lime) 64%, var(--line)),
    color-mix(in srgb, var(--lime) 64%, var(--line))
  ) left 50% / 100% 3px no-repeat;
}

.signal-flow-node[data-state="active"]::before {
  border-top-color: color-mix(in srgb, var(--lime) 60%, var(--line));
}

.signal-flow-node[data-state="active"] .signal-flow-port-out::after {
  color: var(--lime);
}

.signal-flow-node[data-state="warning"] {
  border-color: color-mix(in srgb, var(--amber) 58%, var(--line));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--amber) 14%, transparent);
}

.signal-flow-node[data-state="warning"] strong {
  color: var(--amber);
}

.signal-flow-node[data-state="warning"] .signal-flow-port {
  border-color: color-mix(in srgb, var(--amber) 72%, var(--line));
  background:
    radial-gradient(circle at 50% 50%, color-mix(in srgb, var(--bg) 64%, transparent) 0 24%, transparent 26%),
    var(--amber);
}

.signal-flow-node[data-state="warning"] .signal-flow-port-in::before,
.signal-flow-node[data-state="warning"] .signal-flow-port-out::before {
  border-top-color: color-mix(in srgb, var(--amber) 64%, var(--line));
}

.signal-flow-node[data-state="warning"]:not(:last-child)::after {
  color: var(--amber);
  background: linear-gradient(
    to right,
    color-mix(in srgb, var(--amber) 64%, var(--line)),
    color-mix(in srgb, var(--amber) 64%, var(--line))
  ) left 50% / 100% 3px no-repeat;
}

.signal-flow-node[data-state="warning"]::before {
  border-top-color: color-mix(in srgb, var(--amber) 62%, var(--line));
}

.signal-flow-node[data-state="warning"] .signal-flow-port-out::after {
  color: var(--amber);
}

.signal-flow-node[data-state="bypassed"] {
  border-color: color-mix(in srgb, var(--muted) 52%, var(--line));
  background: color-mix(in srgb, var(--panel) 78%, var(--bg));
  opacity: 0.58;
}

.signal-flow-node[data-state="bypassed"] strong {
  color: color-mix(in srgb, var(--muted) 78%, var(--text));
}

.signal-flow-node[data-state="bypassed"] .signal-flow-port {
  border-color: color-mix(in srgb, var(--muted) 64%, var(--line));
  background: color-mix(in srgb, var(--panel) 60%, var(--muted));
}

.signal-flow-node[data-state="bypassed"] .signal-flow-port-in::before,
.signal-flow-node[data-state="bypassed"] .signal-flow-port-out::before {
  border-top-color: color-mix(in srgb, var(--muted) 58%, var(--line));
}

.signal-flow-node[data-state="bypassed"]:not(:last-child)::after {
  color: color-mix(in srgb, var(--muted) 76%, var(--text));
  background: linear-gradient(
    to right,
    color-mix(in srgb, var(--muted) 58%, var(--line)),
    color-mix(in srgb, var(--muted) 58%, var(--line))
  ) left 50% / 100% 3px no-repeat;
}

.signal-flow-node[data-state="bypassed"]::before {
  border-top-color: color-mix(in srgb, var(--muted) 54%, var(--line));
}

.signal-flow-node[data-state="bypassed"] .signal-flow-port-out::after {
  color: color-mix(in srgb, var(--muted) 80%, var(--text));
}

.signal-flow-node[data-state="stored"] {
  border-color: color-mix(in srgb, var(--amber) 42%, var(--line));
  border-style: dashed;
  background: color-mix(in srgb, var(--panel) 82%, transparent);
}

.signal-flow-node[data-state="stored"] strong {
  color: color-mix(in srgb, var(--amber) 76%, var(--muted));
}

.signal-flow-node[data-state="stored"] .signal-flow-port {
  border-color: color-mix(in srgb, var(--amber) 62%, var(--line));
  background: color-mix(in srgb, var(--panel) 62%, var(--amber));
}

.signal-flow-node[data-state="stored"] .signal-flow-port-in::before,
.signal-flow-node[data-state="stored"] .signal-flow-port-out::before {
  border-top-color: color-mix(in srgb, var(--amber) 48%, var(--line));
  border-top-style: dashed;
}

.signal-flow-node[data-state="stored"]:not(:last-child)::after {
  color: color-mix(in srgb, var(--amber) 72%, var(--muted));
  background: repeating-linear-gradient(
    to right,
    color-mix(in srgb, var(--amber) 48%, var(--line)) 0 4px,
    transparent 4px 7px
  ) left 50% / 100% 3px no-repeat;
}

.signal-flow-node[data-state="stored"]::before {
  border-top-color: color-mix(in srgb, var(--amber) 46%, var(--line));
  border-top-style: dashed;
}

.signal-flow-node[data-state="stored"] .signal-flow-port-out::after {
  color: color-mix(in srgb, var(--amber) 72%, var(--muted));
}

.signal-flow-node[data-state="off"] {
  opacity: 0.5;
}

.signal-flow-node[data-kind="control"] {
  border-style: dashed;
}

.signal-flow-node[data-kind="control"]::before {
  border-top-color: color-mix(in srgb, var(--amber) 50%, var(--line));
  border-top-style: dashed;
}

.signal-flow-node[data-kind="control"] .signal-flow-port {
  border-color: color-mix(in srgb, var(--amber) 64%, var(--line));
  background: color-mix(in srgb, var(--panel) 64%, var(--amber));
}

.signal-flow-node[data-kind="control"] .signal-flow-port-in::before,
.signal-flow-node[data-kind="control"] .signal-flow-port-out::before {
  border-top-color: color-mix(in srgb, var(--amber) 58%, var(--line));
  border-top-style: dashed;
}

.signal-flow-node[data-kind="control"] .signal-flow-port-out::after {
  color: var(--amber);
}

.signal-flow-node[data-kind="control"]::after {
  color: var(--amber);
  background: repeating-linear-gradient(
    to right,
    color-mix(in srgb, var(--amber) 58%, var(--line)) 0 4px,
    transparent 4px 7px
  ) left 50% / 100% 3px no-repeat;
}

.signal-flow-node[data-port-role="source"] .signal-flow-port-source {
  border-color: color-mix(in srgb, var(--cyan) 42%, var(--line));
  border-radius: 2px;
  background:
    linear-gradient(
      to right,
      color-mix(in srgb, var(--panel) 66%, var(--cyan)),
      color-mix(in srgb, var(--cyan) 58%, var(--line))
    );
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--bg) 62%, transparent),
    0 0 0 2px color-mix(in srgb, var(--panel) 84%, transparent);
}

.signal-flow-node[data-port-role="source"] .signal-flow-port-source::before {
  background: color-mix(in srgb, var(--cyan) 46%, var(--line));
}

.signal-flow-node[data-port-role="source"] .signal-flow-port-source::after {
  border-top-color: color-mix(in srgb, var(--cyan) 50%, var(--line));
}

.signal-flow-node[data-port-role="source"][data-state="active"] .signal-flow-port-source {
  border-color: color-mix(in srgb, var(--lime) 58%, var(--line));
  background:
    linear-gradient(
      to right,
      color-mix(in srgb, var(--panel) 56%, var(--lime)),
      color-mix(in srgb, var(--lime) 68%, var(--line))
    );
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--bg) 52%, transparent),
    0 0 7px color-mix(in srgb, var(--lime) 38%, transparent);
}

.signal-flow-node[data-port-role="source"][data-state="active"] .signal-flow-port-source::before {
  background: color-mix(in srgb, var(--lime) 62%, var(--line));
}

.signal-flow-node[data-port-role="source"][data-state="active"] .signal-flow-port-source::after {
  border-top-color: color-mix(in srgb, var(--lime) 64%, var(--line));
}

.signal-flow-node[data-port-role="source"][data-state="warning"] .signal-flow-port-source,
.signal-flow-node[data-port-role="source"][data-kind="control"] .signal-flow-port-source {
  border-color: color-mix(in srgb, var(--amber) 70%, var(--line));
  background:
    linear-gradient(
      to right,
      color-mix(in srgb, var(--panel) 58%, var(--amber)),
      color-mix(in srgb, var(--amber) 70%, var(--line))
    );
}

.signal-flow-node[data-port-role="source"][data-state="warning"] .signal-flow-port-source::before,
.signal-flow-node[data-port-role="source"][data-kind="control"] .signal-flow-port-source::before {
  background: color-mix(in srgb, var(--amber) 64%, var(--line));
}

.signal-flow-node[data-port-role="source"][data-state="warning"] .signal-flow-port-source::after,
.signal-flow-node[data-port-role="source"][data-kind="control"] .signal-flow-port-source::after {
  border-top-color: color-mix(in srgb, var(--amber) 64%, var(--line));
}

.signal-flow-node[data-port-role="source"][data-state="bypassed"] .signal-flow-port-source,
.signal-flow-node[data-port-role="source"][data-state="off"] .signal-flow-port-source {
  border-color: color-mix(in srgb, var(--muted) 54%, var(--line));
  background:
    linear-gradient(
      to right,
      color-mix(in srgb, var(--panel) 76%, var(--muted)),
      color-mix(in srgb, var(--muted) 54%, var(--line))
    );
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--bg) 62%, transparent);
}

.signal-flow-node[data-port-role="terminal"] .signal-flow-port-terminal {
  border-color: color-mix(in srgb, var(--muted) 58%, var(--line));
  border-radius: 2px;
  background:
    linear-gradient(
      to right,
      color-mix(in srgb, var(--muted) 68%, var(--line)),
      color-mix(in srgb, var(--panel) 66%, var(--muted))
    );
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--bg) 64%, transparent),
    0 0 0 2px color-mix(in srgb, var(--panel) 84%, transparent);
}

.signal-flow-node[data-port-role="terminal"][data-state="active"] .signal-flow-port-terminal {
  border-color: color-mix(in srgb, var(--lime) 54%, var(--line));
  background:
    linear-gradient(
      to right,
      color-mix(in srgb, var(--lime) 58%, var(--line)),
      color-mix(in srgb, var(--panel) 58%, var(--lime))
    );
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--bg) 54%, transparent),
    0 0 7px color-mix(in srgb, var(--lime) 36%, transparent);
}

.signal-flow-node[data-port-role="terminal"][data-state="warning"] .signal-flow-port-terminal {
  border-color: color-mix(in srgb, var(--amber) 70%, var(--line));
  background:
    linear-gradient(
      to right,
      color-mix(in srgb, var(--amber) 72%, var(--line)),
      color-mix(in srgb, var(--panel) 52%, var(--amber))
    );
}

.debug-log-toolbar {
  display: flex;
  align-items: center;
  gap: 6px;
  min-height: 30px;
  padding: 4px 6px;
  border: 1px solid color-mix(in srgb, var(--amber) 24%, var(--line));
  background: color-mix(in srgb, var(--panel) 88%, transparent);
  font-family: var(--tracker-font);
  font-size: 0.58rem;
  font-weight: 900;
  text-transform: uppercase;
}

.debug-log-toolbar span {
  margin-right: auto;
  color: var(--amber);
}

.debug-mode-field {
  display: inline-grid;
  grid-template-columns: auto minmax(74px, 92px);
  align-items: center;
  gap: 5px;
  min-width: 0;
  color: var(--muted);
}

.debug-mode-field span {
  margin: 0;
  color: var(--muted);
}

.debug-mode-field select {
  min-height: 24px;
  width: 100%;
  border: 1px solid color-mix(in srgb, var(--cyan) 28%, var(--line));
  color: var(--text);
  background: var(--tracker-cell-2);
  font-family: var(--tracker-font);
  font-size: 0.54rem;
  font-weight: 900;
  text-transform: uppercase;
}

.debug-log-toolbar .ghost-button {
  min-height: 24px;
  padding: 0 8px;
  font-size: 0.54rem;
}

.debug-log-list {
  display: grid;
  align-content: start;
  gap: 3px;
  max-height: 150px;
  min-height: 78px;
  overflow: auto;
  padding: 5px;
  border: 1px solid color-mix(in srgb, var(--cyan) 18%, var(--line));
  background: var(--tracker-cell-2);
}

.debug-log-entry {
  display: grid;
  grid-template-columns: 72px 82px minmax(0, 1fr);
  gap: 6px;
  min-width: 0;
  padding: 3px 5px;
  color: var(--muted);
  font-family: var(--tracker-font);
  font-size: 0.54rem;
  font-weight: 900;
  line-height: 1.25;
  text-transform: uppercase;
}

.debug-log-entry strong {
  color: var(--amber);
  font-weight: 900;
}

.debug-log-entry span:last-child {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.section-pattern {
  --accent: var(--lime);
}

.section-tracker {
  --accent: var(--cyan);
}

.section-tracker.learning {
  --accent: var(--lime);
}

.section-drums {
  --accent: var(--amber);
}

.section-keyboard {
  --accent: #9ba7ff;
}

.tracker,
.drums {
  margin-top: 12px;
}

.section-head {
  align-items: center;
  margin: -1px -1px 8px;
  padding: 5px 7px;
  border: 1px solid color-mix(in srgb, var(--accent) 24%, var(--line));
  background: var(--tracker-cell);
}

.section-head h2 {
  line-height: 1.1;
}

.section-head .eyebrow {
  margin-bottom: 3px;
}

.section-tracker .section-head {
  display: grid;
  grid-template-columns: minmax(190px, auto) minmax(0, 1fr);
  align-items: flex-start;
}

.tracker-toolbar {
  display: flex;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 4px;
  max-width: 100%;
}

.tracker-tool-group {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 3px;
  min-height: 30px;
  padding: 3px;
  border: 1px solid color-mix(in srgb, var(--accent) 20%, var(--line));
  border-radius: 0;
  background: rgba(17, 19, 26, 0.72);
}

.tracker-tool-group-main {
  border-color: color-mix(in srgb, var(--accent) 38%, var(--line));
}

.tracker-tool-transport {
  --group-color: var(--cyan);
}

.tracker-tool-quantize {
  --group-color: var(--amber);
}

.tracker-tool-pattern,
.tracker-tool-buffer {
  --group-color: var(--lime);
}

.tracker-tool-edit {
  --group-color: var(--pink);
}

.tracker-tool-transpose {
  --group-color: #9d8cff;
}

.tracker-tool-group[class*="tracker-tool-"] {
  border-color: color-mix(in srgb, var(--group-color) 34%, var(--line));
  background: color-mix(in srgb, rgba(17, 19, 26, 0.82) 86%, var(--group-color) 14%);
}

.tracker-tool-group[class*="tracker-tool-"] .ghost-button {
  border-color: color-mix(in srgb, var(--group-color) 30%, var(--line));
  background-color: color-mix(in srgb, #11131a 90%, var(--group-color) 10%);
}

.tracker-tool-group[class*="tracker-tool-"] .ghost-button:hover,
.tracker-tool-group[class*="tracker-tool-"] .ghost-button:focus-visible,
.tracker-tool-group[class*="tracker-tool-"] .ghost-button.active {
  border-color: color-mix(in srgb, var(--group-color) 62%, var(--line));
  color: var(--group-color);
}

.tracker-tool-group[class*="tracker-tool-"]:focus-within {
  border-color: color-mix(in srgb, var(--group-color) 64%, var(--line));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--group-color) 34%, transparent);
}

.tracker-tool-label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 24px;
  padding: 0 5px;
  border-right: 1px solid color-mix(in srgb, var(--group-color, var(--accent)) 28%, transparent);
  color: var(--muted);
  font-size: 0.66rem;
  font-weight: 900;
  text-transform: uppercase;
}

.tracker-toolbar .ghost-button,
.tracker-toolbar .tracker-step-value {
  min-height: 24px;
  padding: 0 6px;
  font-size: 0.62rem;
}

.tracker-toolbar .ghost-button {
  min-width: 28px;
  line-height: 1;
  white-space: nowrap;
}

.tracker-play-button {
  border-color: rgba(185, 244, 91, 0.58);
  color: var(--lime);
}

.tracker-play-button.playing {
  border-color: rgba(255, 92, 157, 0.72);
  color: #101015;
  background: var(--pink);
}

.tracker-step-presets {
  display: inline-flex;
  align-items: center;
  gap: 3px;
}

.tracker-toolbar .tracker-step-preset {
  min-width: 27px;
  padding: 0 6px;
}

.tracker-step-preset.active {
  border-color: rgba(255, 200, 87, 0.78);
  color: #101015;
  background: var(--amber);
}

.tracker-step-preset:focus-visible {
  outline: 1px solid color-mix(in srgb, var(--amber) 72%, transparent);
  outline-offset: 1px;
}

.tracker-toolbar .tracker-help-button {
  min-width: 28px;
  padding: 0;
}

.tracker-instrument-panel {
  margin: 0 0 12px;
}

.tracker-instrument-panel .module-rack {
  border-color: color-mix(in srgb, var(--cyan) 30%, var(--line));
}

.instrument-source-row {
  display: flex;
  align-items: end;
  flex-wrap: wrap;
  gap: 5px;
  margin-top: 7px;
}

.instrument-source-row .ghost-button {
  min-height: 28px;
  padding-inline: 8px;
}

.instrument-preset-field {
  min-width: min(260px, 100%);
  flex: 1 1 220px;
  margin: 0;
}

.steps {
  display: grid;
  grid-template-columns: repeat(16, minmax(34px, 1fr));
  gap: 7px;
}

.step {
  display: grid;
  grid-template-rows: 28px 72px 34px;
  gap: 7px;
}

.step button,
.step select {
  border-radius: 7px;
}

.step-toggle {
  border: 1px solid var(--line);
  color: var(--muted);
  background: #12141b;
  font-size: 0.75rem;
  font-weight: 800;
}

.step-toggle.on {
  border-color: rgba(185, 244, 91, 0.55);
  color: #0b1108;
  background: var(--lime);
}

.step-toggle.current {
  box-shadow: 0 0 0 2px var(--pink);
}

.step-slider {
  writing-mode: bt-lr;
  appearance: slider-vertical;
  width: 100%;
  height: 72px;
  accent-color: var(--pink);
}

.tracker-head,
.tracker-row {
  display: grid;
  grid-template-columns: 44px repeat(var(--tracker-channel-count, 4), minmax(176px, 1fr));
  gap: 4px;
  align-items: center;
}

.tracker-grid-shell {
  position: relative;
}

.tracker-grid-viewport {
  --tracker-visible-rows: 24;
  --tracker-row-step: 32px;
  height: calc((var(--tracker-visible-rows) * var(--tracker-row-step)) + 58px);
  max-height: calc(100vh - 250px);
  overflow: auto;
  position: relative;
  border: 1px solid rgba(255, 255, 255, 0.09);
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(14, 16, 22, 0.98), rgba(15, 16, 22, 0.94));
  scrollbar-width: thin;
  scrollbar-color: color-mix(in srgb, var(--cyan) 42%, #11131a) rgba(17, 19, 26, 0.55);
}

.tracker-guide {
  position: absolute;
  left: 5px;
  right: 5px;
  pointer-events: none;
  display: none;
  border-radius: 4px;
  border: 1px solid transparent;
  outline: 1px solid rgba(255, 255, 255, 0.02);
}

.tracker-cursor-guide {
  z-index: 4;
  background: linear-gradient(
    to right,
    rgba(56, 216, 233, 0.01) 0%,
    rgba(56, 216, 233, 0.22) 5%,
    rgba(56, 216, 233, 0.22) 95%,
    rgba(56, 216, 233, 0.01) 100%
  );
  border-color: #38d8e9;
  box-shadow: inset 0 0 0 1px rgba(56, 216, 233, 0.34), 0 0 0 1px rgba(6, 8, 12, 0.65);
  border-top-width: 2px;
  border-bottom-width: 2px;
}

.tracker-playhead {
  z-index: 8;
  background: linear-gradient(
    to right,
    rgba(220, 220, 220, 0.02) 0%,
    rgba(220, 220, 220, 0.26) 5%,
    rgba(220, 220, 220, 0.26) 95%,
    rgba(220, 220, 220, 0.02) 100%
  );
  border-color: #d7d9e1;
  box-shadow: inset 0 0 0 1px rgba(220, 220, 220, 0.34), 0 0 0 1px rgba(6, 8, 12, 0.65);
  border-top-width: 2px;
  border-bottom-width: 2px;
}

.tracker-head {
  position: sticky;
  top: 0;
  z-index: 3;
  min-width: max-content;
  margin-bottom: 0;
  padding: 5px;
  color: var(--muted);
  font-size: 0.66rem;
  font-weight: 900;
  text-transform: uppercase;
  background: rgba(18, 20, 28, 0.98);
  border-bottom: 1px solid var(--line);
  box-shadow: 0 2px 0 rgba(0, 0, 0, 0.26);
}

.tracker-row-head-label {
  display: grid;
  place-items: center;
  min-height: 42px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 6px;
  background: #11131a;
  font-variant-numeric: tabular-nums;
}

.tracker-channel-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 28px 28px;
  grid-template-areas:
    "name mute solo"
    "cols cols cols";
  gap: 4px;
  align-items: center;
  min-width: 0;
}

.tracker-channel-name {
  grid-area: name;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.tracker-channel-toggle:first-of-type {
  grid-area: mute;
}

.tracker-channel-toggle:last-of-type {
  grid-area: solo;
}

.tracker-channel-columns {
  grid-area: cols;
  display: grid;
  grid-template-columns: minmax(58px, 1fr) 32px 38px 46px;
  gap: 2px;
  color: color-mix(in srgb, var(--muted) 76%, transparent);
  font-size: 0.58rem;
}

.tracker-channel-columns span {
  display: grid;
  place-items: center;
  min-height: 14px;
  border-top: 1px solid rgba(255, 255, 255, 0.07);
  font-variant-numeric: tabular-nums;
}

.tracker-channel-head.muted > span {
  color: rgba(169, 168, 181, 0.58);
}

.tracker-channel-head.active-channel {
  color: var(--cyan);
}

.tracker-channel-head.active-channel .tracker-channel-name {
  color: var(--cyan);
}

.tracker-channel-toggle {
  min-width: 0;
  min-height: 26px;
  padding: 0;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--muted);
  background: #11131a;
  font-size: 0.68rem;
  font-weight: 900;
  cursor: pointer;
}

.tracker-channel-toggle:hover,
.tracker-channel-toggle:focus-visible {
  border-color: rgba(255, 200, 87, 0.58);
  color: var(--amber);
  outline: 1px solid rgba(255, 200, 87, 0.24);
  outline-offset: 1px;
}

.tracker-channel-toggle.active {
  border-color: rgba(56, 216, 233, 0.65);
  color: var(--cyan);
  background: rgba(56, 216, 233, 0.12);
}

.tracker-rows {
  display: grid;
  gap: 3px;
  min-width: max-content;
  padding: 5px;
}

.tracker-row {
  min-height: 29px;
  background: transparent;
  scroll-margin-top: 54px;
}

.tracker-row:nth-child(even) input,
.tracker-row:nth-child(even) select,
.tracker-row:nth-child(even) > span {
  background-color: #0f1117;
}

.tracker-row.bar-row > span {
  color: var(--pink);
  border-color: rgba(255, 92, 157, 0.42);
}

.tracker-row.bar-row input,
.tracker-row.bar-row select,
.tracker-row.bar-row > span {
  border-top-color: rgba(255, 92, 157, 0.54);
  background-color: color-mix(in srgb, #11131a 86%, var(--pink) 14%);
}

.tracker-row.beat-row:not(.bar-row) > span {
  color: var(--lime);
  border-color: rgba(185, 244, 91, 0.28);
}

.tracker-row.beat-row:not(.bar-row) input,
.tracker-row.beat-row:not(.bar-row) select,
.tracker-row.beat-row:not(.bar-row) > span {
  border-top-color: rgba(185, 244, 91, 0.35);
  background-color: color-mix(in srgb, #11131a 90%, var(--lime) 10%);
}

.tracker-row.edit-step-row:not(.cursor-row):not(.current) input,
.tracker-row.edit-step-row:not(.cursor-row):not(.current) select,
.tracker-row.edit-step-row:not(.cursor-row):not(.current) > span {
  border-left-color: rgba(255, 200, 87, 0.44);
  background-color: color-mix(in srgb, #11131a 91%, var(--amber) 9%);
}

.tracker-row.next-step-row:not(.cursor-row):not(.current) input,
.tracker-row.next-step-row:not(.cursor-row):not(.current) select,
.tracker-row.next-step-row:not(.cursor-row):not(.current) > span {
  border-color: rgba(56, 216, 233, 0.42);
}

.tracker-row > span {
  display: grid;
  place-items: center;
  height: 29px;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--amber);
  background: #11131a;
  font-size: 0.72rem;
  font-weight: 900;
  font-variant-numeric: tabular-nums;
}

.tracker-channel-cell {
  display: grid;
  grid-template-columns: minmax(58px, 1fr) 32px 38px 46px;
  gap: 2px;
  align-items: center;
  min-width: 0;
}

.tracker-channel-cell.cursor input,
.tracker-channel-cell.cursor select {
  border-color: rgba(56, 216, 233, 0.54);
  box-shadow: none;
}

.tracker-channel-cell.selected input,
.tracker-channel-cell.selected select {
  border-color: rgba(185, 244, 91, 0.5);
  background-color: color-mix(in srgb, #11131a 84%, var(--lime) 16%);
}

.tracker-channel-cell.selected.cursor input,
.tracker-channel-cell.selected.cursor select {
  border-color: rgba(56, 216, 233, 0.76);
  box-shadow: none;
}

.tracker-channel-cell.active-channel:not(.cursor):not(.selected) input,
.tracker-channel-cell.active-channel:not(.cursor):not(.selected) select {
  border-color: rgba(56, 216, 233, 0.22);
  background-color: color-mix(in srgb, #11131a 90%, var(--cyan) 10%);
}

.tracker-row input,
.tracker-row select {
  appearance: none;
  -webkit-appearance: none;
  width: 100%;
  height: 29px;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--text);
  background-color: #11131a;
  padding: 0 5px;
  font-family: var(--tracker-font);
  font-size: 0.76rem;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
  outline: 0;
  overflow: hidden;
  text-overflow: clip;
}

.tracker-row input {
  caret-color: var(--amber);
}

.tracker-row input:focus-visible,
.tracker-row select:focus-visible {
  border-color: var(--cyan);
  box-shadow: inset 0 0 0 1px rgba(56, 216, 233, 0.38);
}

.tracker-row input[readonly] {
  cursor: default;
  caret-color: transparent;
}

.tracker-row select {
  appearance: none;
  padding: 0 12px 0 5px;
  background:
    linear-gradient(45deg, transparent 50%, var(--muted) 50%) calc(100% - 8px) 50% / 5px 5px no-repeat,
    #11131a;
  cursor: pointer;
}

.tracker-row.cursor-row input,
.tracker-row.cursor-row select,
.tracker-row.cursor-row span,
.tracker-row.current input,
.tracker-row.current select,
.tracker-row.current span {
  border-color: rgba(169, 168, 181, 0.68);
  background-color: rgba(169, 168, 181, 0.18);
  box-shadow: none;
}

.tracker-row.cursor-row > span {
  color: var(--text);
}

.tracker-row.current input,
.tracker-row.current select,
.tracker-row.current span {
  border-color: rgba(255, 255, 255, 0.7);
  color: #050706;
  background-color: rgba(211, 213, 220, 0.86);
  box-shadow: inset 0 0 0 1px rgba(5, 7, 6, 0.42);
}

.tracker-row.cursor-row .tracker-cell-field.cursor-field {
  border-color: var(--cyan);
  color: #071011;
  background: var(--cyan);
  box-shadow: inset 0 0 0 1px #071011;
}

.tracker-row.current .tracker-cell-field.cursor-field {
  border-color: var(--amber);
  color: #050706;
  background: var(--amber);
}

.tracker-row .tracker-cell-field.edit-position {
  background-image: linear-gradient(90deg, var(--amber), var(--amber));
  background-repeat: no-repeat;
  background-size: calc(100% / var(--field-chars, 2)) 3px;
  background-position: var(--field-pos-percent, 0%) 100%;
}

.tracker-row .tracker-cell-field.invalid-input {
  border-color: var(--pink);
  color: var(--pink);
  background-color: rgba(255, 92, 157, 0.14);
  box-shadow: inset 0 0 0 1px rgba(255, 92, 157, 0.22);
}

.tracker-row .tracker-cell-field::selection {
  color: #071011;
  background: var(--amber);
}

.tracker-status-cell.warning {
  border-color: rgba(255, 92, 157, 0.68);
  color: var(--pink);
}

.tracker-cell-field::selection {
  color: #050706;
  background: var(--amber);
}

.tracker-row.cursor-row .tracker-channel-cell.selected .tracker-cell-field.cursor-field {
  border-color: var(--amber);
  color: #101015;
  background: var(--amber);
  box-shadow: inset 0 0 0 1px #101015;
}

.tracker-cell-field:focus-visible {
  outline: 1px solid var(--cyan);
  outline-offset: -2px;
}

.tracker-cell-note {
  color: var(--lime);
}

.tracker-cell-instrument,
.tracker-cell-volume {
  color: var(--cyan);
}

.tracker-cell-effect {
  color: var(--amber);
}

html[data-theme="classic"] .synth-shell {
  width: min(1320px, calc(100vw - 18px));
  padding-top: 12px;
}

html[data-theme="classic"] .topbar,
html[data-theme="classic"] .visual-panel,
html[data-theme="classic"] .module,
html[data-theme="classic"] .sequencer,
html[data-theme="classic"] .tracker,
html[data-theme="classic"] .drums,
html[data-theme="classic"] .keyboard,
html[data-theme="classic"] .performance-surface {
  border-color: rgba(174, 185, 173, 0.46);
  border-radius: 0;
  background: rgba(16, 20, 20, 0.96);
  box-shadow: none;
}

html[data-theme="classic"] .topbar {
  min-height: 72px;
  padding: 12px 14px;
  grid-template-columns: minmax(220px, 0.42fr) minmax(560px, 0.58fr);
}

html[data-theme="classic"] h1 {
  font-size: clamp(1.5rem, 3.4vw, 3rem);
  line-height: 1;
}

html[data-theme="classic"] h2 {
  font-size: 1rem;
}

html[data-theme="classic"] .eyebrow {
  letter-spacing: 0;
}

html[data-theme="classic"] .primary-button,
html[data-theme="classic"] .ghost-button,
html[data-theme="classic"] .icon-button,
html[data-theme="classic"] .mode-tab,
html[data-theme="classic"] .tempo,
html[data-theme="classic"] .preset-rack,
html[data-theme="classic"] .dice-rack,
html[data-theme="classic"] .audition-rack,
html[data-theme="classic"] .theme-rack,
html[data-theme="classic"] .tracker-channel-toggle,
html[data-theme="classic"] .tracker-order-item,
html[data-theme="classic"] .tracker-step-value {
  border-radius: 0;
  background: #1b2020;
  box-shadow: inset 1px 1px 0 rgba(238, 242, 219, 0.16);
}

html[data-theme="classic"] .primary-button {
  color: #050706;
  background: var(--lime);
}

html[data-theme="classic"] .primary-button:hover,
html[data-theme="classic"] .primary-button:focus-visible {
  border-color: rgba(215, 229, 108, 0.86);
}

html[data-theme="classic"] .mode-tab.active {
  color: #050706;
  background: var(--cyan);
}

html[data-theme="classic"] .mode-tab:hover,
html[data-theme="classic"] .mode-tab:focus-visible {
  border-color: rgba(104, 216, 160, 0.62);
  color: #eef2db;
}

html[data-theme="classic"] .mode-tab.active:hover,
html[data-theme="classic"] .mode-tab.active:focus-visible {
  color: #050706;
}

html[data-theme="classic"] .mode-tab {
  min-height: 30px;
  padding: 0 6px;
  font-size: 0.62rem;
}

html[data-theme="classic"] .transport {
  gap: 6px;
  border-color: rgba(174, 185, 173, 0.34);
  background: #111615;
}

html[data-theme="classic"] .transport:focus-within {
  border-color: rgba(255, 211, 107, 0.42);
}

html[data-theme="classic"] .primary-button,
html[data-theme="classic"] .ghost-button,
html[data-theme="classic"] .icon-button,
html[data-theme="classic"] .tempo,
html[data-theme="classic"] .preset-rack,
html[data-theme="classic"] .dice-rack,
html[data-theme="classic"] .audition-rack,
html[data-theme="classic"] .theme-rack,
html[data-theme="classic"] select {
  font-size: 0.7rem;
  line-height: 1;
}

html[data-theme="classic"] .tracker {
  padding: 10px;
  border-color: rgba(215, 229, 108, 0.48);
  background: #151b24;
  box-shadow:
    inset 0 2px 0 rgba(215, 229, 108, 0.42),
    inset 0 -1px 0 rgba(0, 0, 0, 0.8);
}

html[data-theme="classic"] .section-head {
  margin-bottom: 8px;
}

html[data-theme="classic"] .tracker-song-strip {
  gap: 5px;
  padding: 3px;
  border-radius: 0;
  background: #080b0b;
}

html[data-theme="classic"] .tracker-midi-panel {
  padding: 7px;
}

html[data-theme="classic"] .tracker-midi-panel .module-title {
  min-height: 24px;
  margin-bottom: 5px;
}

html[data-theme="classic"] .tracker-midi-panel .ghost-button {
  min-height: 24px;
  padding: 0 7px;
  font-size: 0.64rem;
}

html[data-theme="classic"] .tracker-toolbar {
  gap: 3px;
}

html[data-theme="classic"] .tracker-tool-group {
  gap: 3px;
  min-height: 28px;
  padding: 2px;
  border-radius: 0;
  background: #0a0d0d;
}

html[data-theme="classic"] .tracker-tool-group:focus-within {
  border-color: color-mix(in srgb, var(--group-color, #ffd36b) 54%, rgba(174, 185, 173, 0.34));
}

html[data-theme="classic"] .tracker-tool-label {
  min-height: 24px;
  padding: 0 5px;
  font-size: 0.6rem;
}

html[data-theme="classic"] .tracker-toolbar .ghost-button,
html[data-theme="classic"] .tracker-toolbar .tracker-step-value {
  min-height: 22px;
  padding: 0 5px;
  font-size: 0.6rem;
}

html[data-theme="classic"] .tracker-meta-cells > strong,
html[data-theme="classic"] .tracker-status-cell,
html[data-theme="classic"] .tracker-sequence-label,
html[data-theme="classic"] .tracker-order-item,
html[data-theme="classic"] .tracker-pattern-bank-item {
  min-height: 24px;
  border-radius: 0;
  font-size: 0.68rem;
}

html[data-theme="classic"] .tracker-order-list,
html[data-theme="classic"] .tracker-pattern-list {
  gap: 2px;
}

html[data-theme="classic"] .tracker-order-item {
  grid-template-columns: 22px 38px;
  min-width: 60px;
}

html[data-theme="classic"] .tracker-pattern-bank-item {
  grid-template-columns: 40px 34px;
  min-width: 74px;
}

html[data-theme="classic"] .tracker-order-item:hover,
html[data-theme="classic"] .tracker-order-item:focus-visible,
html[data-theme="classic"] .tracker-pattern-bank-item:hover,
html[data-theme="classic"] .tracker-pattern-bank-item:focus-visible {
  border-color: rgba(255, 211, 107, 0.58);
}

html[data-theme="classic"] .tracker-order-item span,
html[data-theme="classic"] .tracker-order-item strong,
html[data-theme="classic"] .tracker-pattern-bank-item span,
html[data-theme="classic"] .tracker-pattern-bank-item strong {
  min-height: 22px;
}

html[data-theme="classic"] .tracker-order-item span {
  color: #ffd36b;
  background: #151a1a;
}

html[data-theme="classic"] .tracker-order-item.active {
  box-shadow: inset 0 -2px 0 #ffd36b;
}

html[data-theme="classic"] .tracker-order-item.active span {
  color: #050706;
  background: #ffd36b;
}

html[data-theme="classic"] .tracker-pattern-bank-item.active {
  box-shadow: inset 0 -2px 0 #68d8a0;
}

html[data-theme="classic"] .tracker-head,
html[data-theme="classic"] .tracker-row {
  grid-template-columns: 34px repeat(var(--tracker-channel-count, 4), minmax(144px, 1fr));
  gap: 2px;
}

html[data-theme="classic"] .tracker-cursor-guide {
  left: 3px;
  right: 3px;
  border-radius: 0;
  background: repeating-linear-gradient(
    90deg,
    rgba(255, 211, 107, 0.08) 0px,
    rgba(255, 211, 107, 0.08) 4px,
    rgba(255, 211, 107, 0.2) 4px,
    rgba(255, 211, 107, 0.2) 8px
  );
  border-color: #ffd36b;
  box-shadow: inset 0 0 0 1px rgba(255, 211, 107, 0.55), 0 0 0 1px rgba(12, 16, 21, 0.82);
}

html[data-theme="classic"] .tracker-playhead {
  left: 3px;
  right: 3px;
  border-radius: 0;
  background: linear-gradient(
    to right,
    rgba(238, 242, 219, 0.05) 0%,
    rgba(238, 242, 219, 0.22) 6%,
    rgba(238, 242, 219, 0.22) 94%,
    rgba(238, 242, 219, 0.05) 100%
  );
  border-color: rgba(238, 242, 219, 0.76);
  box-shadow: inset 0 0 0 1px rgba(238, 242, 219, 0.34), 0 0 0 1px rgba(12, 16, 21, 0.82);
}

html[data-theme="classic"] .tracker-grid-viewport {
  --tracker-visible-rows: 24;
  --tracker-row-step: 25px;
  border-radius: 0;
  border-color: rgba(238, 242, 219, 0.36);
  background: #06090d;
}

html[data-theme="classic"] .tracker-head {
  padding: 3px;
  background: #2b3544;
  font-size: 0.58rem;
}

html[data-theme="classic"] .tracker-row-head-label {
  min-height: 34px;
  border-radius: 0;
  background: #18212d;
}

html[data-theme="classic"] .tracker-channel-columns {
  grid-template-columns: minmax(48px, 1fr) 26px 30px 38px;
  gap: 1px;
  font-size: 0.52rem;
}

html[data-theme="classic"] .tracker-channel-columns span {
  min-height: 11px;
}

html[data-theme="classic"] .tracker-rows {
  gap: 1px;
  padding: 3px;
}

html[data-theme="classic"] .tracker-row {
  min-height: 24px;
}

html[data-theme="classic"] .tracker-row > span,
html[data-theme="classic"] .tracker-row input,
html[data-theme="classic"] .tracker-row select {
  height: 24px;
  border-radius: 0;
  border-color: rgba(174, 185, 173, 0.24);
  background: #081018;
  font-size: 0.68rem;
  font-smooth: never;
  -webkit-font-smoothing: none;
}

html[data-theme="classic"] .tracker-row > span {
  color: #ffd36b;
}

html[data-theme="classic"] .tracker-row:nth-child(even) input,
html[data-theme="classic"] .tracker-row:nth-child(even) select,
html[data-theme="classic"] .tracker-row:nth-child(even) > span {
  background-color: #060b11;
}

html[data-theme="classic"] .tracker-row.bar-row input,
html[data-theme="classic"] .tracker-row.bar-row select,
html[data-theme="classic"] .tracker-row.bar-row > span {
  border-top-color: rgba(255, 142, 95, 0.72);
  background-color: #1a1116;
}

html[data-theme="classic"] .tracker-row.bar-row > span {
  color: #ff8e5f;
}

html[data-theme="classic"] .tracker-row.beat-row:not(.bar-row) input,
html[data-theme="classic"] .tracker-row.beat-row:not(.bar-row) select,
html[data-theme="classic"] .tracker-row.beat-row:not(.bar-row) > span {
  border-top-color: rgba(215, 229, 108, 0.5);
  background-color: #12191c;
}

html[data-theme="classic"] .tracker-row.edit-step-row:not(.cursor-row):not(.current) input,
html[data-theme="classic"] .tracker-row.edit-step-row:not(.cursor-row):not(.current) select,
html[data-theme="classic"] .tracker-row.edit-step-row:not(.cursor-row):not(.current) > span {
  border-left-color: rgba(255, 211, 107, 0.52);
  background-color: #14170e;
}

html[data-theme="classic"] .tracker-row.next-step-row:not(.cursor-row):not(.current) input,
html[data-theme="classic"] .tracker-row.next-step-row:not(.cursor-row):not(.current) select,
html[data-theme="classic"] .tracker-row.next-step-row:not(.cursor-row):not(.current) > span {
  border-color: rgba(104, 216, 160, 0.48);
}

html[data-theme="classic"] .tracker-channel-cell {
  grid-template-columns: minmax(48px, 1fr) 26px 30px 38px;
  gap: 1px;
}

html[data-theme="classic"] .tracker-channel-head.active-channel,
html[data-theme="classic"] .tracker-channel-head.active-channel .tracker-channel-name {
  color: #68d8a0;
}

html[data-theme="classic"] .tracker-channel-cell.active-channel:not(.cursor):not(.selected) input,
html[data-theme="classic"] .tracker-channel-cell.active-channel:not(.cursor):not(.selected) select {
  border-color: rgba(104, 216, 160, 0.3);
  background-color: #0d1918;
}

html[data-theme="classic"] .tracker-row input,
html[data-theme="classic"] .tracker-row select {
  padding: 0 3px;
}

html[data-theme="classic"] .tracker-row input:focus-visible,
html[data-theme="classic"] .tracker-row select:focus-visible {
  border-color: #68d8a0;
  box-shadow: inset 0 0 0 1px rgba(104, 216, 160, 0.38);
}

html[data-theme="classic"] .tracker-row.cursor-row input,
html[data-theme="classic"] .tracker-row.cursor-row select,
html[data-theme="classic"] .tracker-row.cursor-row span,
html[data-theme="classic"] .tracker-row.current input,
html[data-theme="classic"] .tracker-row.current select,
html[data-theme="classic"] .tracker-row.current span {
  border-color: rgba(174, 185, 173, 0.68);
  background-color: #2f3540;
  box-shadow: none;
}

html[data-theme="classic"] .tracker-row.current input,
html[data-theme="classic"] .tracker-row.current select,
html[data-theme="classic"] .tracker-row.current span {
  border-color: rgba(238, 242, 219, 0.8);
  color: #050706;
  background-color: #b8beb8;
  box-shadow: inset 0 0 0 1px #050706;
}

html[data-theme="classic"] .tracker-channel-head {
  grid-template-columns: minmax(0, 1fr) 24px 24px;
  gap: 1px;
}

html[data-theme="classic"] .tracker-channel-toggle {
  min-height: 20px;
  font-size: 0.58rem;
}

html[data-theme="classic"] .tracker-channel-toggle:hover,
html[data-theme="classic"] .tracker-channel-toggle:focus-visible {
  border-color: rgba(255, 211, 107, 0.58);
  color: #ffd36b;
}

html[data-theme="classic"] .tracker-row.cursor-row .tracker-cell-field.cursor-field {
  border-color: #ffd36b;
  color: #050706;
  background: #ffd36b;
  box-shadow: inset 0 0 0 1px #050706;
}

html[data-theme="classic"] .tracker-row .tracker-cell-field.edit-position {
  background-image: linear-gradient(90deg, #050706, #050706);
}

html[data-theme="classic"] .tracker-row .tracker-cell-field.invalid-input {
  border-color: #ff8e5f;
  color: #ff8e5f;
  background-color: rgba(255, 142, 95, 0.18);
  box-shadow: inset 0 0 0 1px rgba(255, 142, 95, 0.26);
}

html[data-theme="classic"] .tracker-status-cell.warning {
  border-color: rgba(255, 142, 95, 0.7);
  color: #ff8e5f;
}

html[data-theme="classic"] .tracker-row.cursor-row .tracker-channel-cell.selected .tracker-cell-field.cursor-field {
  border-color: #68d8a0;
  color: #050706;
  background: #68d8a0;
}

.tracker-song-strip {
  display: grid;
  grid-template-columns: minmax(280px, 0.62fr) minmax(220px, 0.48fr) minmax(260px, 1fr);
  gap: 7px;
  align-items: start;
  margin: 0 0 12px;
  padding: 5px;
  border: 1px solid color-mix(in srgb, var(--accent) 20%, var(--line));
  border-radius: 7px;
  background: rgba(17, 19, 26, 0.58);
  min-width: 0;
}

.tracker-meta-cells {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 5px;
  min-width: 0;
}

.tracker-meta-cells > strong,
.tracker-status-cell {
  display: inline-grid;
  place-items: center;
  min-height: 28px;
  padding: 0 8px;
  border: 1px solid var(--line);
  border-radius: 7px;
  background: #11131a;
  font-size: 0.72rem;
  font-weight: 900;
  font-variant-numeric: tabular-nums;
}

.tracker-meta-cells > strong {
  min-width: 88px;
  max-width: 150px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.tracker-meta-cells > strong {
  color: var(--cyan);
}

.tracker-status-cell {
  justify-items: start;
  min-width: min(100%, 300px);
  max-width: 100%;
  color: var(--muted);
  text-align: left;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.tracker-status-cell.warning {
  background-color: color-mix(in srgb, var(--tracker-cell) 82%, var(--pink) 12%);
}

.tracker-workflow-strip {
  display: grid;
  grid-template-columns: 1fr;
  gap: 4px;
  min-width: 0;
}

.tracker-workflow-strip span {
  display: inline-grid;
  align-items: center;
  min-width: 0;
  min-height: 28px;
  padding: 0 8px;
  border: 1px solid var(--line);
  border-radius: 7px;
  color: var(--muted);
  background: #11131a;
  font-family: var(--tracker-font);
  font-size: 0.64rem;
  font-weight: 900;
  font-variant-numeric: tabular-nums;
  overflow: hidden;
  text-overflow: ellipsis;
  text-transform: uppercase;
  white-space: nowrap;
}

.tracker-workflow-strip span[data-state="active"] {
  border-color: color-mix(in srgb, var(--lime) 42%, var(--line));
  color: var(--lime);
}

.tracker-workflow-strip span[data-state="warning"] {
  border-color: color-mix(in srgb, var(--amber) 58%, var(--line));
  color: var(--amber);
}

.section-tracker.learning #trackerModeValue {
  border-color: rgba(185, 244, 91, 0.72);
  color: #071108;
  background: var(--lime);
}

.tracker-learning-button.active {
  border-color: rgba(185, 244, 91, 0.72);
  color: #071108;
  background: var(--lime);
}

.tracker-learning-copy-button:not([hidden]) {
  border-color: rgba(185, 244, 91, 0.52);
  color: var(--lime);
  background: rgba(185, 244, 91, 0.1);
}

.tracker-learning-discard-button:not([hidden]) {
  border-color: rgba(255, 139, 94, 0.52);
  color: var(--orange);
  background: rgba(255, 139, 94, 0.08);
}

.tracker-sequence-row {
  display: grid;
  grid-template-columns: 62px minmax(0, 1fr);
  align-items: center;
  gap: 4px;
  min-width: 0;
}

.tracker-sequence-label {
  display: inline-grid;
  place-items: center;
  min-height: 28px;
  padding: 0 6px;
  color: var(--amber);
  background: #11131a;
  border: 1px solid var(--line);
  border-radius: 7px;
  font-size: 0.62rem;
  font-weight: 900;
  text-transform: uppercase;
}

.tracker-order-list,
.tracker-pattern-list {
  display: flex;
  gap: 4px;
  min-width: 0;
  overflow-x: auto;
  padding-bottom: 2px;
  scrollbar-width: thin;
  scrollbar-color: color-mix(in srgb, var(--cyan) 46%, #11131a) transparent;
}

.tracker-order-item,
.tracker-pattern-bank-item {
  display: grid;
  grid-template-columns: 24px 42px;
  align-items: center;
  flex: 0 0 auto;
  min-width: 72px;
  min-height: 28px;
  padding: 0;
  border: 1px solid var(--line);
  border-radius: 7px;
  color: var(--muted);
  background: #11131a;
  font-size: 0.68rem;
  font-weight: 900;
  overflow: hidden;
}

.tracker-order-item span,
.tracker-order-item strong,
.tracker-pattern-bank-item span,
.tracker-pattern-bank-item strong {
  display: grid;
  place-items: center;
  min-height: 28px;
}

.tracker-order-item span {
  color: var(--amber);
  background: rgba(255, 255, 255, 0.04);
}

.tracker-order-item strong {
  color: var(--muted);
  font-size: 0.66rem;
}

.tracker-pattern-bank-item {
  grid-template-columns: 44px 42px;
  min-width: 88px;
}

.tracker-pattern-bank-item strong {
  color: var(--text);
  font-size: 0.66rem;
}

.tracker-pattern-bank-item span {
  color: var(--muted);
  background: rgba(255, 255, 255, 0.04);
  font-size: 0.58rem;
}

.tracker-pattern-bank-item.orphan span {
  color: var(--amber);
}

.tracker-order-item.active {
  border-color: rgba(56, 216, 233, 0.72);
  background: rgba(56, 216, 233, 0.15);
  box-shadow: inset 0 -2px 0 var(--cyan);
}

.tracker-pattern-bank-item.active {
  border-color: rgba(185, 244, 91, 0.72);
  background: rgba(185, 244, 91, 0.14);
  box-shadow: inset 0 -2px 0 var(--lime);
}

.tracker-order-item.active span {
  color: #071011;
  background: var(--cyan);
}

.tracker-order-item.active strong {
  color: var(--text);
}

.tracker-order-item:hover,
.tracker-order-item:focus-visible,
.tracker-pattern-bank-item:hover,
.tracker-pattern-bank-item:focus-visible {
  border-color: rgba(255, 200, 87, 0.7);
  color: var(--text);
  transform: translateY(-1px);
}

.tracker-step-button,
.tracker-help-button {
  min-width: 42px;
  padding: 0 10px;
}

.tracker-step-value {
  display: inline-grid;
  place-items: center;
  min-height: 42px;
  padding: 0 10px;
  border: 1px solid var(--line);
  border-radius: 7px;
  color: var(--amber);
  background: #11131a;
  font-size: 0.82rem;
}

.tracker-toolbar .tracker-step-button,
.tracker-toolbar .tracker-help-button,
.tracker-toolbar .tracker-step-preset {
  min-width: 34px;
  padding: 0 8px;
}

.tracker-help-panel {
  margin: 0 0 12px;
  padding: 12px;
  border: 1px solid rgba(56, 216, 233, 0.22);
  border-radius: 7px;
  background: rgba(10, 11, 16, 0.82);
  box-shadow: inset 0 1px 0 rgba(56, 216, 233, 0.14);
}

.tracker-help-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(56, 216, 233, 0.14);
}

.tracker-help-head strong {
  color: var(--cyan);
  font-family: var(--tracker-font);
  font-size: 0.82rem;
  text-transform: uppercase;
}

.tracker-help-close {
  min-height: 32px;
}

.tracker-help-close:hover,
.tracker-help-close:focus-visible {
  border-color: color-mix(in srgb, var(--amber) 58%, var(--line));
  background: color-mix(in srgb, var(--tracker-cell) 72%, var(--amber) 18%);
}

.tracker-example-panel {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 0 0 12px;
  padding: 10px;
  border: 1px solid rgba(246, 199, 91, 0.18);
  border-radius: 6px;
  background: rgba(246, 199, 91, 0.04);
}

.tracker-example-panel strong {
  color: var(--amber);
  font-family: var(--tracker-font);
  font-size: 0.78rem;
  text-transform: uppercase;
}

.tracker-example-panel p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 700;
  line-height: 1.35;
}

.tracker-example-buttons {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 5px;
}

.tracker-example-buttons .ghost-button {
  min-height: 28px;
  padding: 0 8px;
  font-size: 0.64rem;
}

.tracker-help-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.tracker-help-grid h3 {
  margin: 0 0 7px;
  color: var(--cyan);
  font-family: var(--tracker-font);
  font-size: 0.82rem;
  text-transform: uppercase;
}

.tracker-help-grid p {
  margin: 5px 0;
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 700;
  line-height: 1.35;
}

.tracker-help-grid p strong {
  color: var(--text);
}

.tracker-command-group {
  margin-top: 12px;
}

.tracker-command-group h4 {
  margin: 0 0 8px;
  color: var(--amber);
  font-family: var(--tracker-font);
  font-size: 0.76rem;
  text-transform: uppercase;
}

.tracker-command-list {
  display: grid;
  gap: 8px;
}

.tracker-command-help {
  padding: 8px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.025);
  min-width: 0;
}

.tracker-command-help-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 4px;
  min-width: 0;
}

.tracker-command-help-head strong {
  min-width: 0;
  color: var(--fg);
  font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
  font-size: 0.82rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.tracker-command-title {
  color: var(--cyan) !important;
}

.tracker-command-status {
  flex: 0 0 auto;
  padding: 2px 6px;
  border-radius: 999px;
  color: var(--fg);
  background: rgba(56, 216, 233, 0.16);
  font-size: 0.62rem;
  line-height: 1.2;
  text-transform: uppercase;
}

.tracker-command-status.status-sample-later,
.tracker-command-status.status-legacy-hardware-later,
.tracker-command-status.status-reserved,
.tracker-command-status.status-neon-later {
  color: var(--muted);
  background: rgba(255, 255, 255, 0.08);
}

.drum-pads {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.drum-pad {
  display: grid;
  place-items: center;
  min-height: 70px;
  border: 1px solid rgba(255, 200, 87, 0.32);
  border-radius: 8px;
  color: var(--text);
  background: linear-gradient(180deg, #242733, #12141b);
  font-family: var(--tracker-font);
  font-weight: 900;
  letter-spacing: 0;
  line-height: 1;
  text-transform: uppercase;
}

.drum-pad:hover,
.drum-pad:focus-visible {
  border-color: rgba(255, 200, 87, 0.68);
  outline: 1px solid rgba(255, 200, 87, 0.36);
  outline-offset: 1px;
}

.drum-pad:active,
.drum-pad.active {
  color: #100b08;
  background: var(--amber);
  transform: translateY(1px);
}

.keyboard {
  margin-top: 12px;
  padding-bottom: 10px;
}

.keyboard-tools {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: -1px -1px 8px;
  padding: 5px 7px;
  border: 1px solid color-mix(in srgb, var(--accent) 24%, var(--line));
  background: var(--tracker-cell);
  min-width: 0;
}

.keyboard-tools strong {
  display: inline-grid;
  place-items: center;
  min-width: 42px;
  min-height: 30px;
  border: 1px solid color-mix(in srgb, var(--amber) 34%, var(--line));
  color: var(--amber);
  background: #11131a;
  font-family: var(--tracker-font);
  font-variant-numeric: tabular-nums;
  text-align: center;
}

.keyboard-tools .ghost-button {
  min-width: 42px;
  min-height: 34px;
  padding: 0 10px;
  flex: 0 0 auto;
}

.keyboard-tools .ghost-button:hover,
.keyboard-tools .ghost-button:focus-visible {
  border-color: color-mix(in srgb, #9ba7ff 58%, var(--line));
  background: color-mix(in srgb, var(--tracker-cell) 76%, #9ba7ff 18%);
}

.key-row {
  position: relative;
  display: block;
  height: 166px;
  min-height: 166px;
  margin: 0 4px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: #050706;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05);
  overflow: hidden;
}

.key {
  position: absolute;
  bottom: 0;
  left: var(--key-left, 0%);
  display: flex;
  align-items: flex-end;
  justify-content: center;
  height: 100%;
  border: 1px solid #050706;
  border-radius: 0 0 3px 3px;
  color: #202326;
  background: linear-gradient(180deg, #fffef5 0%, #e8ebe8 72%, #c8cfca 100%);
  padding: 0 0 14px;
  font-family: var(--tracker-font);
  font-size: 0.72rem;
  font-weight: 900;
  cursor: pointer;
  line-height: 1;
  user-select: none;
}

.key:hover {
  filter: brightness(1.08);
}

.key.white {
  z-index: 1;
  width: var(--key-width, 10%);
}

.key.black {
  z-index: 3;
  top: 0;
  bottom: auto;
  width: var(--black-key-width, 7.2%);
  height: 64%;
  border-color: #000;
  border-radius: 0 0 3px 3px;
  color: #eef2db;
  background: linear-gradient(180deg, #1d2028 0%, #050607 100%);
  padding-bottom: 16px;
}

html[data-theme="classic"] .key-row {
  border-color: rgba(174, 185, 173, 0.34);
}

html[data-theme="classic"] .key {
  border-radius: 0;
  font-smooth: never;
  -webkit-font-smoothing: none;
}

html[data-theme="classic"] .key.white {
  background: linear-gradient(180deg, #f1f0e8 0%, #d8ddd8 72%, #adb7b0 100%);
}

html[data-theme="classic"] .key.black {
  background: linear-gradient(180deg, #161a21 0%, #030404 100%);
}

.key.active {
  transform: translateY(2px);
  border-color: var(--cyan);
  box-shadow: 0 0 20px rgba(56, 216, 233, 0.48);
}

.key.audition-held {
  border-color: var(--lime);
  box-shadow:
    inset 0 0 0 2px color-mix(in srgb, var(--lime) 72%, transparent),
    0 0 18px color-mix(in srgb, var(--lime) 34%, transparent);
}

.key.black.active {
  color: #071011;
  background: var(--cyan);
}

.key.black.audition-held {
  color: #071011;
  background: var(--lime);
}

.hint {
  margin: 12px 0 0;
  color: var(--muted);
  font-family: var(--tracker-font);
  font-size: 0.86rem;
  font-weight: 700;
  line-height: 1.35;
  overflow-wrap: anywhere;
}

.hint strong {
  color: var(--text);
}

html[data-theme="classic"] .tracker-status-cell.warning {
  background-color: rgba(255, 142, 95, 0.12);
}

html[data-theme="classic"] .module:hover {
  border-color: color-mix(in srgb, var(--accent) 48%, rgba(174, 185, 173, 0.46));
}

@media (max-width: 980px) {
  .topbar {
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .topbar-identity {
    display: grid;
    gap: 2px;
  }

  .transport {
    justify-content: stretch;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  html[data-work-mode="tracking"] .transport,
  html[data-work-mode="modulation"] .transport,
  html[data-work-mode="effects"] .transport,
  html[data-work-mode="performance"] .transport,
  html[data-work-mode="synth"] .transport {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .mode-tabs {
    min-width: 0;
  }

  .mode-tab {
    min-height: 34px;
  }

  .controls-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .module-wide {
    grid-column: span 2;
  }

  .steps {
    grid-template-columns: repeat(8, minmax(34px, 1fr));
  }

  .performance-layout {
    grid-template-columns: 1fr;
  }

  .system-monitor-grid,
  .signal-flow-strip {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .tracker-help-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 680px) {
  .synth-shell {
    width: min(100vw - 16px, 1180px);
    padding-top: 8px;
  }

  .topbar {
    align-items: stretch;
  }

  .transport {
    justify-content: stretch;
    grid-template-columns: 1fr;
    width: 100%;
  }

  html[data-work-mode="tracking"] .transport,
  html[data-work-mode="modulation"] .transport,
  html[data-work-mode="effects"] .transport,
  html[data-work-mode="performance"] .transport,
  html[data-work-mode="synth"] .transport {
    grid-template-columns: 1fr;
  }

  .mode-tabs {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    width: 100%;
  }

  .mode-tab {
    width: 100%;
  }

  .visual-panel {
    height: 178px;
  }

  .system-monitor-grid,
  .signal-flow-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .debug-log-entry {
    grid-template-columns: 58px 64px minmax(0, 1fr);
  }

  .readout {
    flex-direction: column;
    gap: 6px;
    font-size: 0.66rem;
  }

  .scope-mode {
    align-items: flex-start;
    justify-content: flex-start;
    gap: 6px;
  }

  .scope-mode select {
    width: min(100%, 160px);
  }

  .controls-grid {
    grid-template-columns: 1fr;
    gap: 7px;
  }

  .field,
  .mini-grid .field {
    grid-template-columns: 1fr;
  }

  .field.has-knob,
  .field.has-knob.has-value-unit,
  .mini-grid .field.has-knob,
  .mini-grid .field.has-knob.has-value-unit {
    grid-template-columns: minmax(82px, 0.95fr) 36px minmax(58px, 0.62fr);
  }

  .field.has-knob.has-value-unit,
  .mini-grid .field.has-knob.has-value-unit {
    grid-template-columns: minmax(82px, 0.9fr) 36px minmax(50px, 0.52fr) minmax(28px, 0.28fr);
  }

  .range-knob {
    width: 34px;
    height: 34px;
    min-width: 34px;
    min-height: 34px;
  }

  .live-slot-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .live-slot-field {
    grid-column: 1 / -1;
  }

  .project-row {
    grid-template-columns: 1fr;
  }

  .instrument-mixer-panel {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .instrument-mixer-panel strong {
    grid-column: span 1;
  }

  .macro-grid,
  .macro-help-grid {
    grid-template-columns: 1fr;
  }

  .matrix-dice-actions,
  .matrix-dice-actions label {
    grid-template-columns: 1fr;
  }

  .matrix-dice-actions strong {
    text-align: left;
  }

  .matrix-route-row {
    grid-template-columns: 18px minmax(0, 1fr) minmax(0, 1fr);
  }

  .matrix-route-row input[type="range"],
  .matrix-route-scope,
  .matrix-amount-value,
  .matrix-route-row select:last-child {
    grid-column: span 1;
  }

  .effect-xy-head,
  .effect-xy-readout,
  .effect-guide-grid,
  .effect-guide-flow,
  .modulation-guide-flow,
  .modulation-guide-grid,
  .macro-help-grid,
  .performance-guide-strip {
    grid-template-columns: 1fr;
  }

  html[data-work-mode="effects"] .controls-grid .module-effect-guide,
  html[data-work-mode="effects"] .controls-grid .module-effect-rack,
  html[data-work-mode="effects"] .controls-grid .module-effect-xy,
  html[data-work-mode="effects"] .controls-grid .module-effect-parameters,
  html[data-work-mode="effects"] .controls-grid .module-effect-routing {
    grid-column: span 1;
  }

  html[data-work-mode="modulation"] .controls-grid .module-modulation-guide,
  html[data-work-mode="modulation"] .controls-grid .module-studio-mixer,
  html[data-work-mode="modulation"] .controls-grid .module-macros,
  html[data-work-mode="modulation"] .controls-grid .module-matrix {
    grid-column: span 1;
  }

  .effect-xy-pad {
    min-height: 180px;
  }

  .effect-rack-row {
    grid-template-columns: 34px 18px 18px minmax(0, 1fr);
  }

  .effect-rack-dice {
    grid-template-columns: 1fr;
  }

  .effect-rack-row input[type="range"],
  .effect-rack-mix-value,
  .effect-rack-row select:last-of-type,
  .effect-rack-row-actions {
    grid-column: span 1;
  }

  .effect-routing-lane {
    grid-template-columns: 1fr;
  }

  .effect-routing-label {
    min-height: 26px;
    border-right: 0;
    border-bottom: 1px solid color-mix(in srgb, var(--accent) 26%, var(--line));
  }

  .effect-param-row {
    grid-template-columns: 34px minmax(0, 1fr);
  }

  .effect-param-type {
    border-right: 0;
  }

  .effect-param-controls {
    grid-column: 1 / -1;
    grid-template-columns: 1fr;
  }

  .module-wide {
    grid-column: auto;
  }

  .module {
    min-height: 0;
  }

  .preset-rack,
  .dice-rack,
  .audition-rack,
  .theme-rack {
    grid-template-columns: auto minmax(130px, 1fr);
    width: 100%;
  }

  .preset-rack select,
  .dice-rack select,
  .audition-rack select,
  .theme-rack select {
    width: 100%;
  }

  .audition-rack {
    grid-template-columns: minmax(74px, 1fr) minmax(54px, auto) minmax(62px, auto);
  }

  .audition-status {
    grid-column: 1 / -1;
    width: 100%;
  }

  .tempo-controls {
    grid-template-columns: 32px minmax(72px, 1fr) 32px;
  }

  .panel-command {
    max-width: none;
  }

  .steps {
    grid-template-columns: repeat(4, minmax(42px, 1fr));
  }

  .key-row {
    height: 132px;
    min-height: 132px;
    overflow: hidden;
  }

  .key {
    font-size: 0.62rem;
    padding-bottom: 10px;
  }

  .key.black {
    padding-bottom: 12px;
  }

  .tracker-head,
  .tracker-row {
    grid-template-columns: 42px repeat(var(--tracker-channel-count, 4), minmax(196px, 1fr));
  }

  .tracker-grid-viewport {
    --tracker-visible-rows: 18;
    max-height: calc(100vh - 210px);
  }

  .tracker-channel-cell {
    grid-template-columns: minmax(62px, 1fr) 38px 46px 56px;
  }

  .tracker-row input,
  .tracker-row select {
    padding: 0 6px;
  }

  .tracker-help-grid {
    grid-template-columns: 1fr;
  }

  .tracker-song-strip {
    grid-template-columns: 1fr;
  }

  .tracker-sequence-row {
    grid-template-columns: 1fr;
  }

  .tracker-meta-cells,
  .tracker-workflow-strip,
  .tracker-status-cell {
    width: 100%;
  }

  .tracker-toolbar {
    justify-content: flex-start;
    max-width: 100%;
    gap: 5px;
  }

  .tracker-tool-group {
    width: 100%;
  }

  .tracker-toolbar .ghost-button,
  .tracker-toolbar .tracker-step-value {
    min-height: 28px;
  }

  .tracker-example-panel {
    align-items: stretch;
    flex-direction: column;
  }

  .tracker-example-buttons {
    justify-content: flex-start;
  }

  .drum-pads {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .drum-pad {
    min-height: 58px;
  }
}

@media (max-width: 420px) {
  .mode-tabs {
    grid-template-columns: 1fr;
  }

  .audition-rack {
    grid-template-columns: auto minmax(66px, 1fr);
  }

  .audition-rack .ghost-button {
    grid-column: span 2;
    width: 100%;
  }

  .tracker-channel-cell {
    grid-template-columns: minmax(58px, 1fr) 34px 42px 50px;
  }
}
