
.pattern-manager[data-v-b96e3eec] {
  flex-shrink: 0;
}
.pm-header[data-v-b96e3eec] {
  background: var(--header-bg);
  color: var(--cyan);
  font-weight: bold;
  padding: 4px 8px;
  font-size: 13px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.pm-rows-dropdown[data-v-b96e3eec] {
  position: relative;
}
.pm-rows[data-v-b96e3eec] {
  font-size: 10px;
  color: var(--text-dim);
  cursor: pointer;
  padding: 1px 4px;
  border: 1px solid var(--border);
}
.pm-rows[data-v-b96e3eec]:hover {
  color: var(--yellow);
  border-color: var(--border-bright);
}
.pm-rows-menu[data-v-b96e3eec] {
  position: absolute;
  top: 100%;
  right: 0;
  z-index: 50;
  background: var(--bg-dark);
  border: 1px solid var(--border-bright);
  margin-top: 2px;
}
.pm-rows-item[data-v-b96e3eec] {
  padding: 3px 12px;
  font-size: 11px;
  color: var(--text);
  cursor: pointer;
  white-space: nowrap;
}
.pm-rows-item[data-v-b96e3eec]:hover {
  background: var(--cursor-bg);
  color: var(--yellow);
}
.pm-rows-item.active[data-v-b96e3eec] {
  color: var(--green);
}
.pm-default-badge[data-v-b96e3eec] {
  margin-left: 4px;
  font-size: 9px;
  color: var(--text-dim);
}
.pm-rows-sep[data-v-b96e3eec] {
  height: 1px;
  background: var(--border);
  margin: 2px 4px;
}
.pm-rows-default[data-v-b96e3eec] {
  font-size: 10px;
  color: var(--text-dim);
}
.pm-rows-default[data-v-b96e3eec]:hover {
  color: var(--yellow);
}
.pm-pool[data-v-b96e3eec] {
  padding: 4px;
  display: flex;
  flex-wrap: wrap;
  gap: 3px;
  max-height: 80px;
  overflow-y: auto;
}
.pm-item[data-v-b96e3eec] {
  background: var(--bg);
  border: 1px solid var(--border);
  color: var(--cyan);
  font-size: 11px;
  padding: 2px 6px;
  cursor: grab;
  white-space: nowrap;
}
.pm-item[data-v-b96e3eec]:hover {
  background: var(--bg-alt);
  border-color: var(--border-bright);
}
.pm-item.active[data-v-b96e3eec] {
  background: var(--cursor-bg);
  border-color: var(--yellow);
  color: var(--yellow);
}
.pm-name[data-v-b96e3eec] {
  padding: 3px 4px;
  border-bottom: 1px solid var(--border);
}
.pm-name-input[data-v-b96e3eec] {
  width: 100%;
  background: var(--bg-dark);
  color: var(--yellow);
  border: 1px solid var(--border);
  font-family: inherit;
  font-size: 11px;
  padding: 2px 4px;
  outline: none;
  box-sizing: border-box;
}
.pm-name-input[data-v-b96e3eec]:focus {
  border-color: var(--cyan);
}
.pm-buttons[data-v-b96e3eec] {
  padding: 4px;
  display: flex;
  gap: 3px;
  border-bottom: 1px solid var(--border);
}
.pm-buttons .btn-sm[data-v-b96e3eec] {
  font-size: 10px;
  padding: 2px 6px;
  flex: 1;
  text-align: center;
}

.arrangement-panel[data-v-366b3685] {
  width: 0;
  min-width: 0;
  overflow: hidden;
  background: var(--bg-dark);
  border-left: 2px solid transparent;
  transition: width 0.2s ease, min-width 0.2s ease, border-color 0.2s ease;
}
.arrangement-panel.open[data-v-366b3685] {
  width: 180px;
  min-width: 180px;
  border-left-color: var(--border);
}
.panel-inner[data-v-366b3685] {
  width: 180px;
  min-width: 180px;
  height: 100%;
  display: flex;
  flex-direction: column;
}
.arr-header[data-v-366b3685] {
  background: var(--header-bg);
  color: var(--cyan);
  font-weight: bold;
  padding: 4px 8px;
  font-size: 13px;
  border-bottom: 1px solid var(--border);
  border-top: 1px solid var(--border);
  margin-top: 6px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.close-btn[data-v-366b3685] {
  background: none;
  border: none;
  color: var(--text-dim);
  font-size: 12px;
  cursor: pointer;
  padding: 0 2px;
  line-height: 1;
  font-family: inherit;
}
.close-btn[data-v-366b3685]:hover {
  color: var(--red);
}
.arrangement-playlist[data-v-366b3685] {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  padding: 4px;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.playlist-block[data-v-366b3685] {
  background: var(--bg);
  border: 1px solid var(--border);
  padding: 6px 8px;
  cursor: grab;
  position: relative;
  transition: background 0.1s, border-color 0.1s;
  flex-shrink: 0;
}
.playlist-block[data-v-366b3685]:hover {
  background: var(--bg-alt);
  border-color: var(--border-bright);
}
.playlist-block.selected[data-v-366b3685] {
  background: var(--cursor-bg);
  border-color: var(--yellow);
}
.playlist-block.playing[data-v-366b3685] {
  background: var(--playing-bg);
  border-color: var(--green);
}
.playlist-block .block-pos[data-v-366b3685] {
  color: var(--text-dim);
  font-size: 10px;
}
.playlist-block .block-name[data-v-366b3685] {
  color: var(--text-bright);
  font-size: 12px;
}
.playlist-block.selected .block-name[data-v-366b3685] {
  color: var(--yellow);
}
.playlist-block.playing .block-name[data-v-366b3685] {
  color: var(--green);
}
.playlist-block.playing .block-pos[data-v-366b3685] {
  color: var(--green);
}
.playlist-block.drag-over-top[data-v-366b3685] {
  border-top: 2px solid var(--drop-color);
  margin-top: -1px;
}
.playlist-block.drag-over-bottom[data-v-366b3685] {
  border-bottom: 2px solid var(--drop-color);
  margin-bottom: -1px;
}
.block-mixer[data-v-366b3685] {
  display: flex;
  gap: 3px;
  margin-top: 1px;
}
.block-mixer-item[data-v-366b3685] {
  font-size: 10px;
  color: var(--text);
  cursor: pointer;
  padding: 1px 3px;
  white-space: nowrap;
}
.block-mixer-item[data-v-366b3685]:hover {
  color: var(--yellow);
}
.block-mixer-item.pan-left[data-v-366b3685]  { color: var(--cyan);
}
.block-mixer-item.pan-right[data-v-366b3685] { color: var(--yellow);
}
.block-actions[data-v-366b3685] {
  position: absolute;
  top: 2px;
  right: 3px;
  display: none;
  gap: 2px;
}
.playlist-block:hover .block-actions[data-v-366b3685] {
  display: flex;
}
.block-action[data-v-366b3685] {
  font-size: 11px;
  width: 16px;
  height: 16px;
  line-height: 16px;
  text-align: center;
  color: var(--text-dim);
  cursor: pointer;
  border: 1px solid transparent;
}
.block-action[data-v-366b3685]:hover {
  color: var(--text-bright);
  border-color: var(--border-bright);
}
.block-remove[data-v-366b3685]:hover {
  color: var(--red);
  border-color: var(--red);
}
@media (max-width: 768px) {
.arrangement-panel.open[data-v-366b3685] {
    width: 140px;
    min-width: 140px;
}
.panel-inner[data-v-366b3685] {
    width: 140px;
    min-width: 140px;
}
}

.confirm-overlay[data-v-202dafe9] {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0, 0, 0, 0.7);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 600;
}
.confirm-box[data-v-202dafe9] {
  background: var(--modal-bg);
  border: 2px solid var(--border-bright);
  padding: 16px 20px;
  min-width: 260px;
  max-width: 400px;
  text-align: center;
}
.confirm-heading[data-v-202dafe9] {
  color: var(--cyan);
  font-weight: bold;
  font-size: 14px;
  margin-bottom: 8px;
}
.confirm-message[data-v-202dafe9] {
  color: var(--text-bright);
  font-size: 13px;
  margin-bottom: 14px;
}
.confirm-buttons[data-v-202dafe9] {
  display: flex;
  gap: 8px;
  justify-content: center;
}
.confirm-buttons .btn[data-v-202dafe9] {
  min-width: 60px;
  text-align: center;
}
.confirm-yes[data-v-202dafe9] {
  color: var(--green);
  border-color: var(--green);
}
.confirm-yes[data-v-202dafe9]:hover {
  background: var(--green);
  color: var(--bg-dark);
}
.confirm-no[data-v-202dafe9] {
  color: var(--red);
  border-color: var(--red);
}
.confirm-no[data-v-202dafe9]:hover {
  background: var(--red);
  color: var(--bg-dark);
}

.help-overlay[data-v-afd22c65] {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0, 0, 0, 0.85);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 600;
}
.help-box[data-v-afd22c65] {
  background: var(--bg);
  border: 2px solid var(--border-bright);
  padding: 20px;
  max-width: 500px;
  width: 90%;
}
.help-box h2[data-v-afd22c65] {
  color: var(--cyan);
  font-size: 16px;
  margin-bottom: 12px;
  font-weight: bold;
}
.help-box table[data-v-afd22c65] {
  width: 100%;
  border-collapse: collapse;
}
.help-box td[data-v-afd22c65] {
  padding: 3px 8px;
  font-size: 12px;
}
.help-box td[data-v-afd22c65]:first-child {
  color: var(--yellow);
  white-space: nowrap;
  width: 120px;
}
.help-box td[data-v-afd22c65]:last-child {
  color: var(--text);
}
.help-close[data-v-afd22c65] {
  margin-top: 12px;
  text-align: center;
}
.help-credit[data-v-afd22c65] {
  margin-top: 10px;
  text-align: center;
  color: var(--text-dim);
  font-size: 11px;
}

.instrument-panel[data-v-f4304ff9] {
  width: 0;
  min-width: 0;
  overflow: hidden;
  background: var(--bg-dark);
  border-right: 2px solid transparent;
  transition: width 0.2s ease, min-width 0.2s ease, border-color 0.2s ease;
}
.instrument-panel.open[data-v-f4304ff9] {
  width: 190px;
  min-width: 190px;
  border-right-color: var(--border);
}
.panel-inner[data-v-f4304ff9] {
  width: 190px;
  min-width: 190px;
  height: 100%;
  display: flex;
  flex-direction: column;
}
.panel-header[data-v-f4304ff9] {
  background: var(--header-bg);
  color: var(--cyan);
  font-weight: bold;
  padding: 4px 8px;
  font-size: 13px;
  border-bottom: 1px solid var(--border);
  user-select: none;
  -webkit-user-select: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.close-btn[data-v-f4304ff9] {
  background: none;
  border: none;
  color: var(--text-dim);
  font-size: 12px;
  cursor: pointer;
  padding: 0 2px;
  line-height: 1;
  font-family: inherit;
}
.close-btn[data-v-f4304ff9]:hover {
  color: var(--red);
}
.instrument-list[data-v-f4304ff9] {
  flex: 1;
  overflow-y: auto;
  padding: 4px;
}
.category-header[data-v-f4304ff9] {
  padding: 3px 6px;
  cursor: pointer;
  font-size: 12px;
  font-weight: bold;
  display: flex;
  align-items: center;
  gap: 4px;
  border-bottom: 1px solid var(--bg-alt);
  border-left: 3px solid transparent;
  user-select: none;
  -webkit-user-select: none;
}
.category-header[data-v-f4304ff9]:hover {
  background: var(--bg-alt);
}
.category-toggle[data-v-f4304ff9] {
  color: var(--text-dim);
  font-size: 11px;
  width: 14px;
  text-align: center;
  flex-shrink: 0;
}
.category-name[data-v-f4304ff9] {
  flex: 1;
}
.category-count[data-v-f4304ff9] {
  color: var(--text-dim);
  font-size: 10px;
}
.instrument-item[data-v-f4304ff9] {
  padding: 3px 6px;
  cursor: pointer;
  color: var(--text);
  font-size: 12px;
  white-space: nowrap;
}
.inst-key[data-v-f4304ff9] {
  color: var(--text-dim);
  display: inline-block;
  width: 10px;
  text-align: right;
  margin-right: 2px;
}
.instrument-item[data-v-f4304ff9]:hover {
  background: var(--bg-alt);
}
.instrument-item.selected[data-v-f4304ff9] {
  background: var(--cursor-bg);
  color: var(--yellow);
}
.velocity-section[data-v-f4304ff9] {
  border-top: 1px solid var(--border);
  padding: 4px 6px;
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 12px;
  user-select: none;
  -webkit-user-select: none;
}
.vel-label[data-v-f4304ff9] {
  color: var(--text-dim);
}
.vel-value[data-v-f4304ff9] {
  color: var(--yellow);
  min-width: 20px;
  text-align: right;
}
.vel-btn[data-v-f4304ff9] {
  background: var(--bg-alt);
  border: 1px solid var(--border);
  color: var(--text);
  font-size: 11px;
  font-family: inherit;
  cursor: pointer;
  padding: 1px 5px;
  line-height: 1;
}
.vel-btn[data-v-f4304ff9]:hover {
  background: var(--cursor-bg);
  color: var(--yellow);
}
.vel-reset[data-v-f4304ff9] {
  margin-left: auto;
  color: var(--text-dim);
}
.vel-reset[data-v-f4304ff9]:hover {
  color: var(--cyan);
}
.samples-section[data-v-f4304ff9] {
  border-top: 1px solid var(--border);
  padding: 4px;
}
.samples-header[data-v-f4304ff9] {
  padding: 3px 6px;
  font-size: 12px;
  font-weight: bold;
  color: #ff5555;
  display: flex;
  align-items: center;
  justify-content: space-between;
  user-select: none;
  -webkit-user-select: none;
}
.samples-empty[data-v-f4304ff9] {
  padding: 4px 6px;
  font-size: 11px;
  color: var(--text-dim);
}
.sample-item[data-v-f4304ff9] {
  padding: 3px 6px;
  cursor: pointer;
  color: var(--text);
  font-size: 12px;
  display: flex;
  align-items: center;
  gap: 4px;
}
.sample-item[data-v-f4304ff9]:hover {
  background: var(--bg-alt);
}
.sample-item.selected[data-v-f4304ff9] {
  background: var(--cursor-bg);
  color: var(--yellow);
}
.sample-name[data-v-f4304ff9] {
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.sample-preview[data-v-f4304ff9],
.sample-delete[data-v-f4304ff9] {
  background: none;
  border: none;
  color: var(--text-dim);
  font-size: 12px;
  cursor: pointer;
  padding: 0 2px;
  line-height: 1;
  font-family: inherit;
  flex-shrink: 0;
}
.sample-preview[data-v-f4304ff9]:hover {
  color: var(--green);
}
.sample-delete[data-v-f4304ff9]:hover {
  color: var(--red);
}
.load-sample-btn[data-v-f4304ff9] {
  width: 100%;
  text-align: center;
  margin-top: 4px;
  font-size: 11px;
}
@media (max-width: 768px) {
.instrument-panel.open[data-v-f4304ff9] {
    width: 150px;
    min-width: 150px;
}
.panel-inner[data-v-f4304ff9] {
    width: 150px;
    min-width: 150px;
}
}

.modal-overlay[data-v-02b81287] {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0, 0, 0, 0.7);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 500;
}
.modal[data-v-02b81287] {
  background: var(--modal-bg);
  border: 2px solid var(--border-bright);
  padding: 0;
  min-width: 300px;
  max-width: 450px;
  max-height: 70vh;
}
.modal-title[data-v-02b81287] {
  background: var(--header-bg);
  color: var(--cyan);
  padding: 6px 12px;
  font-weight: bold;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.modal-title .btn[data-v-02b81287] {
  font-size: 11px;
  padding: 2px 8px;
}
.modal-body[data-v-02b81287] {
  padding: 8px;
  max-height: 50vh;
  overflow-y: auto;
}
.section-label[data-v-02b81287] {
  color: var(--text-dim);
  font-size: 11px;
  text-transform: uppercase;
  padding: 6px 6px 2px;
  border-bottom: 1px solid var(--border);
  margin-top: 4px;
}
.section-label[data-v-02b81287]:first-child {
  margin-top: 0;
}
.load-item[data-v-02b81287] {
  display: flex;
  justify-content: space-between;
  padding: 4px 6px;
  border-bottom: 1px solid var(--bg-alt);
}
.load-name[data-v-02b81287] {
  color: var(--text-bright);
  cursor: pointer;
}
.load-name[data-v-02b81287]:hover {
  color: var(--cyan);
}
.load-name.demo[data-v-02b81287] {
  color: var(--cyan);
}
.load-delete[data-v-02b81287] {
  color: var(--red);
  cursor: pointer;
  font-size: 11px;
}
.load-delete[data-v-02b81287]:hover {
  color: var(--yellow);
}

.message-bar[data-v-394e9661] {
  position: fixed;
  bottom: 30px;
  left: 50%;
  transform: translateX(-50%);
  padding: 6px 16px;
  font-size: 13px;
  z-index: 100;
  border: 1px solid var(--border);
}
.message-bar.info[data-v-394e9661] {
  background: var(--bg-dark);
  color: var(--green);
  border-color: var(--green);
}
.message-bar.warning[data-v-394e9661] {
  background: var(--bg-dark);
  color: var(--yellow);
  border-color: var(--yellow);
}
.message-bar.error[data-v-394e9661] {
  background: var(--bg-dark);
  color: var(--red);
  border-color: var(--red);
}

.mixer-panel[data-v-485278ea] {
  width: 0;
  min-width: 0;
  overflow: hidden;
  background: var(--bg-dark);
  border-left: 2px solid transparent;
  transition: width 0.2s ease, min-width 0.2s ease, border-color 0.2s ease;
}
.mixer-panel.open[data-v-485278ea] {
  width: 180px;
  min-width: 180px;
  border-left-color: var(--border);
}
.panel-inner[data-v-485278ea] {
  width: 180px;
  min-width: 180px;
  height: 100%;
  display: flex;
  flex-direction: column;
}
.panel-header[data-v-485278ea] {
  background: var(--header-bg);
  color: var(--cyan);
  font-weight: bold;
  padding: 4px 8px;
  font-size: 13px;
  border-bottom: 1px solid var(--border);
  user-select: none;
  -webkit-user-select: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.close-btn[data-v-485278ea] {
  background: none;
  border: none;
  color: var(--text-dim);
  font-size: 12px;
  cursor: pointer;
  padding: 0 2px;
  line-height: 1;
  font-family: inherit;
}
.close-btn[data-v-485278ea]:hover {
  color: var(--red);
}
.mixer-body[data-v-485278ea] {
  flex: 1;
  overflow-y: auto;
}
/* Mixer section */
.mixer-section[data-v-485278ea] {
  padding: 6px 8px;
  border-bottom: 1px solid var(--border);
}
.mixer-row[data-v-485278ea] {
  display: flex;
  align-items: center;
  gap: 4px;
  margin-bottom: 6px;
}
.mixer-row label[data-v-485278ea] {
  color: var(--text-dim);
  font-size: 12px;
  flex-shrink: 0;
}
.bpm-input[data-v-485278ea] {
  background: var(--bg-dark);
  color: var(--yellow);
  border: 1px solid var(--border);
  font-family: inherit;
  font-size: 13px;
  padding: 2px 4px;
  outline: none;
  width: 50px;
  flex: 1;
}
.bpm-input[data-v-485278ea]:focus {
  border-color: var(--cyan);
}
.tap-btn[data-v-485278ea] {
  font-size: 11px;
  padding: 2px 6px;
  flex-shrink: 0;
}
.mixer-param[data-v-485278ea] {
  margin-bottom: 4px;
}
.mixer-param-label[data-v-485278ea] {
  color: var(--text-dim);
  font-size: 11px;
}
.mixer-param input[type="range"][data-v-485278ea] {
  width: 100%;
  accent-color: var(--cyan);
  margin-top: 1px;
  height: 14px;
}
/* EQ section */
.eq-section[data-v-485278ea] {
  margin-top: 6px;
  padding-top: 6px;
  border-top: 1px solid var(--border);
}
.eq-params[data-v-485278ea] {
  transition: opacity 0.15s;
}
.eq-params.disabled[data-v-485278ea] {
  opacity: 0.4;
  pointer-events: none;
}
/* Effects collapse header */
.fx-collapse-header[data-v-485278ea] {
  padding: 4px 8px;
  background: var(--header-bg);
  color: var(--cyan);
  font-weight: bold;
  font-size: 12px;
  user-select: none;
  -webkit-user-select: none;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.fx-collapse-header span[data-v-485278ea] {
  cursor: pointer;
}
.fx-collapse-header[data-v-485278ea]:hover {
  background: var(--bg-alt);
}
.fx-header-btns[data-v-485278ea] {
  display: flex;
  gap: 3px;
}
.fx-byp-btn[data-v-485278ea],
.fx-clear-btn[data-v-485278ea] {
  background: none;
  border: 1px solid var(--border);
  color: var(--text-dim);
  font-family: inherit;
  font-size: 10px;
  padding: 1px 4px;
  cursor: pointer;
  line-height: 1;
}
.fx-byp-btn[data-v-485278ea]:hover:not(:disabled) {
  color: var(--yellow);
  border-color: var(--yellow);
}
.fx-byp-btn.active[data-v-485278ea] {
  color: var(--yellow);
  border-color: var(--yellow);
  animation: byp-pulse-485278ea 1.5s ease-in-out infinite;
}
@keyframes byp-pulse-485278ea {
0%, 100% { opacity: 1;
}
50% { opacity: 0.4;
}
}
.fx-clear-btn[data-v-485278ea]:hover:not(:disabled) {
  color: var(--red);
  border-color: var(--red);
}
.fx-byp-btn[data-v-485278ea]:disabled,
.fx-clear-btn[data-v-485278ea]:disabled {
  opacity: 0.3;
  cursor: default;
}
/* Effects body */
.effects-body[data-v-485278ea] {
  padding: 4px 6px;
  transition: opacity 0.15s;
}
.effects-body.bypassed[data-v-485278ea] {
  opacity: 0.45;
  pointer-events: none;
}
.fx-section[data-v-485278ea] {
  padding: 4px 0;
  border-bottom: 1px solid var(--bg-alt);
}
.fx-section[data-v-485278ea]:last-child {
  border-bottom: none;
}
.fx-header[data-v-485278ea] {
  margin-bottom: 2px;
}
.fx-toggle[data-v-485278ea] {
  display: flex;
  align-items: center;
  gap: 4px;
  cursor: pointer;
  font-size: 11px;
  color: var(--text-dim);
}
.fx-toggle input[type="checkbox"][data-v-485278ea] {
  accent-color: var(--cyan);
}
.fx-toggle span[data-v-485278ea] {
  margin-left: 4px;
}
.fx-toggle span.enabled[data-v-485278ea] {
  color: var(--cyan);
}
.fx-params[data-v-485278ea] {
  transition: opacity 0.15s;
}
.fx-params.disabled[data-v-485278ea] {
  opacity: 0.4;
  pointer-events: none;
}
.fx-param[data-v-485278ea] {
  margin: 1px 0;
}
.fx-param-label[data-v-485278ea] {
  color: var(--text);
  font-size: 10px;
}
.fx-param input[type="range"][data-v-485278ea] {
  width: 100%;
  accent-color: var(--cyan);
  margin-top: 1px;
  height: 14px;
}
@media (max-width: 768px) {
.mixer-panel.open[data-v-485278ea] {
    width: 150px;
    min-width: 150px;
}
.panel-inner[data-v-485278ea] {
    width: 150px;
    min-width: 150px;
}
}

.note-editor-overlay[data-v-eeb5a223] {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0, 0, 0, 0.7);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 600;
}
.note-editor-box[data-v-eeb5a223] {
  background: var(--modal-bg);
  border: 2px solid var(--border-bright);
  min-width: 320px;
  max-width: 380px;
}
.note-editor-header[data-v-eeb5a223] {
  display: flex;
  align-items: center;
  padding: 8px 12px;
  border-bottom: 1px solid var(--border);
  gap: 8px;
}
.note-editor-title[data-v-eeb5a223] {
  color: var(--cyan);
  font-weight: bold;
  font-size: 14px;
}
.note-editor-pos[data-v-eeb5a223] {
  color: var(--text-dim);
  font-size: 11px;
  margin-left: auto;
}
.note-editor-close[data-v-eeb5a223] {
  background: none;
  border: none;
  color: var(--text-dim);
  font-size: 18px;
  cursor: pointer;
  padding: 0 4px;
  line-height: 1;
}
.note-editor-close[data-v-eeb5a223]:hover {
  color: var(--red);
}
.note-editor-body[data-v-eeb5a223] {
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.note-editor-row[data-v-eeb5a223] {
  display: flex;
  align-items: center;
  gap: 8px;
}
.note-editor-label[data-v-eeb5a223] {
  color: var(--text-dim);
  font-size: 12px;
  min-width: 65px;
}
.note-editor-slider[data-v-eeb5a223] {
  flex: 1;
  accent-color: var(--cyan);
  height: 16px;
}
.note-editor-val[data-v-eeb5a223] {
  color: var(--text-bright);
  font-size: 12px;
  min-width: 36px;
  text-align: right;
}
.note-editor-select[data-v-eeb5a223] {
  flex: 1;
  background: var(--bg-dark);
  color: var(--note-color);
  border: 1px solid var(--border);
  font-family: inherit;
  font-size: 12px;
  padding: 3px 4px;
  cursor: pointer;
}
.note-editor-select[data-v-eeb5a223]:focus {
  border-color: var(--cyan);
  outline: none;
}
.note-editor-select optgroup[data-v-eeb5a223] {
  color: var(--cyan);
  font-style: normal;
  font-weight: bold;
}
.note-editor-select option[data-v-eeb5a223] {
  color: var(--text-bright);
  background: var(--bg-dark);
}
.note-editor-ch-default[data-v-eeb5a223] {
  flex: 1;
  color: var(--text-dim);
  font-size: 11px;
  cursor: pointer;
  padding: 2px 0;
}
.note-editor-ch-default[data-v-eeb5a223]:hover {
  color: var(--cyan);
}
.note-editor-preview[data-v-eeb5a223] {
  padding: 2px 6px;
  font-size: 11px;
  min-width: 0;
  color: var(--green);
  border-color: var(--green);
}
.note-editor-preview[data-v-eeb5a223]:hover {
  background: var(--green);
  color: var(--bg-dark);
}
.note-editor-reset[data-v-eeb5a223] {
  padding: 2px 5px;
  font-size: 12px;
  min-width: 0;
  color: var(--text-dim);
  border-color: var(--border);
}
.note-editor-reset[data-v-eeb5a223]:hover {
  color: var(--yellow);
  border-color: var(--yellow);
}
.note-editor-footer[data-v-eeb5a223] {
  display: flex;
  justify-content: space-between;
  padding: 10px 12px;
  border-top: 1px solid var(--border);
}
.note-editor-delete[data-v-eeb5a223] {
  color: var(--red);
  border-color: var(--red);
}
.note-editor-delete[data-v-eeb5a223]:hover {
  background: var(--red);
  color: var(--bg-dark);
}
.note-editor-done[data-v-eeb5a223] {
  color: var(--cyan);
  border-color: var(--cyan);
}
.note-editor-done[data-v-eeb5a223]:hover {
  background: var(--cyan);
  color: var(--bg-dark);
}

.grid-container[data-v-2b3c7894] {
  flex: 1;
  overflow-y: auto;
  overflow-x: auto;
  overscroll-behavior: none;
}
.pattern-grid[data-v-2b3c7894] {
  display: flex;
  flex-direction: column;
  min-width: fit-content;
}
.grid-row[data-v-2b3c7894] {
  display: flex;
  border-bottom: 1px solid var(--bg-alt);
}
.grid-row.beat-boundary[data-v-2b3c7894] {
  border-top: 1px solid var(--border);
}
.grid-row.grid-header[data-v-2b3c7894] {
  position: sticky;
  top: 0;
  z-index: 10;
  background: var(--header-bg);
  border-bottom: 2px solid var(--border-bright);
}
.grid-cell[data-v-2b3c7894] {
  padding: 2px 8px;
  white-space: nowrap;
  font-size: 13px;
  min-width: 70px;
  text-align: center;
}
.row-header[data-v-2b3c7894] {
  min-width: 50px;
  max-width: 50px;
  color: var(--text-dim);
  text-align: right;
  padding-right: 6px;
  background: var(--bg-dark);
  border-right: 1px solid var(--border);
}
.corner-cell[data-v-2b3c7894] {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 2px 2px;
  line-height: 1;
}
.corner-main[data-v-2b3c7894] {
  color: var(--green);
  font-weight: bold;
  font-size: 15px;
}
.corner-sub[data-v-2b3c7894] {
  color: var(--text-dim);
  font-size: 10px;
}
.row-header.playing[data-v-2b3c7894] {
  color: var(--green);
  background: var(--playing-bg);
}
.channel-header[data-v-2b3c7894] {
  color: var(--cyan);
  font-weight: bold;
  cursor: default;
  background: var(--header-bg);
  display: flex;
  flex-direction: column;
  align-items: center;
  line-height: 1.2;
  padding-top: 3px;
  padding-bottom: 2px;
}
.channel-header.flash[data-v-2b3c7894] {
  background: var(--flash-bg);
  color: var(--yellow);
}
.ch-badges[data-v-2b3c7894] {
  display: flex;
  gap: 3px;
  margin-top: 2px;
}
.ch-badge[data-v-2b3c7894] {
  font-size: 9px;
  font-weight: bold;
  width: 14px;
  height: 14px;
  line-height: 14px;
  text-align: center;
  border: 1px solid var(--border);
  color: var(--text-dim);
  cursor: pointer;
}
.ch-badge[data-v-2b3c7894]:hover {
  border-color: var(--border-bright);
}
.ch-m.on[data-v-2b3c7894] {
  color: var(--red);
  border-color: var(--red);
}
.ch-s.on[data-v-2b3c7894] {
  color: var(--bg-dark);
  background: var(--green);
  border-color: var(--green);
}
.ch-mixer[data-v-2b3c7894] {
  display: flex;
  gap: 3px;
  margin-top: 1px;
}
.ch-mixer-item[data-v-2b3c7894] {
  font-size: 10px;
  color: var(--text);
  cursor: pointer;
  padding: 1px 3px;
  white-space: nowrap;
}
.ch-mixer-item[data-v-2b3c7894]:hover {
  color: var(--yellow);
}
.ch-mixer-item.pan-left[data-v-2b3c7894]  { color: var(--cyan);
}
.ch-mixer-item.pan-right[data-v-2b3c7894] { color: var(--yellow);
}
.pan-bar[data-v-2b3c7894] {
  position: relative;
  width: 30px;
  height: 5px;
  margin-top: 1px;
}
.pan-track[data-v-2b3c7894] {
  position: absolute;
  top: 2px;
  left: 0;
  right: 0;
  height: 1px;
  background: var(--border);
}
.pan-knob[data-v-2b3c7894] {
  position: absolute;
  top: 0;
  width: 3px;
  height: 5px;
  background: var(--text-dim);
  transform: translateX(-1px);
}
.pan-bar.pan-left .pan-knob[data-v-2b3c7894]  { background: var(--cyan);
}
.pan-bar.pan-right .pan-knob[data-v-2b3c7894] { background: var(--yellow);
}
.ch-meter[data-v-2b3c7894] {
  display: block;
  width: 30px;
  height: 3px;
  background: var(--bg-dark);
  margin-top: 1px;
  position: relative;
  overflow: hidden;
}
.ch-meter-bar[data-v-2b3c7894] {
  display: block;
  height: 100%;
  transition: width 0.05s linear;
}
.note-cell[data-v-2b3c7894] {
  color: var(--text-dim);
  cursor: pointer;
}
.note-cell.fl[data-v-2b3c7894],
.channel-header.fl[data-v-2b3c7894] {
  min-width: 80px;
}
.note-cell.fl.has-note[data-v-2b3c7894] {
  color: var(--bg-dark);
  border-radius: 2px;
  text-shadow: none;
}
.note-cell.fl.cursor.has-note[data-v-2b3c7894] {
  box-shadow: inset 0 0 0 2px var(--text-bright);
}
.note-cell.fl.playing.has-note[data-v-2b3c7894] {
  text-shadow: none;
}
.note-cell[data-v-2b3c7894]:hover {
  background: var(--bg-alt);
}
.note-cell.has-note[data-v-2b3c7894] {
  color: var(--note-color);
}
.note-cell.missing[data-v-2b3c7894] {
  opacity: 0.3;
}
.note-cell.cursor[data-v-2b3c7894] {
  background: var(--cursor-bg);
  color: var(--text-bright);
  box-shadow: inset 0 0 0 1px var(--red);
}
.note-cell.cursor.has-note[data-v-2b3c7894] {
  color: var(--yellow);
}
.note-cell.playing[data-v-2b3c7894] {
  background: var(--playing-bg);
}
.note-cell.playing.has-note[data-v-2b3c7894] {
  color: var(--green);
  text-shadow: 0 0 6px rgba(85, 255, 85, 0.5);
}
@media (max-width: 768px) {
.grid-cell[data-v-2b3c7894] {
    font-size: 12px;
    padding: 2px 4px;
    min-width: 58px;
}
}

.needle-vu-section[data-v-832d9c95] {
  flex-shrink: 0;
  border-top: 1px solid var(--border);
}
.needle-vu-header[data-v-832d9c95] {
  background: var(--header-bg);
  color: var(--cyan);
  font-weight: bold;
  padding: 3px 8px;
  font-size: 12px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  user-select: none;
  -webkit-user-select: none;
}
.close-btn[data-v-832d9c95] {
  background: none;
  border: none;
  color: var(--text-dim);
  font-size: 12px;
  cursor: pointer;
  padding: 0 2px;
  line-height: 1;
  font-family: inherit;
}
.close-btn[data-v-832d9c95]:hover {
  color: var(--red);
}
.needle-vu-canvas[data-v-832d9c95] {
  display: block;
  width: 100%;
}

.soundboard-panel[data-v-0efa6fec] {
  width: 0;
  min-width: 0;
  overflow: hidden;
  background: var(--bg-dark);
  border-left: 2px solid transparent;
  transition: width 0.2s ease, min-width 0.2s ease, border-color 0.2s ease;
}
.soundboard-panel.open[data-v-0efa6fec] {
  width: 200px;
  min-width: 200px;
  border-left-color: var(--border);
}
.panel-inner[data-v-0efa6fec] {
  width: 200px;
  min-width: 200px;
  height: 100%;
  display: flex;
  flex-direction: column;
}
.panel-inner.has-vu[data-v-0efa6fec] {
  overflow-y: auto;
}
.panel-header[data-v-0efa6fec] {
  background: var(--header-bg);
  color: var(--cyan);
  font-weight: bold;
  padding: 4px 8px;
  font-size: 13px;
  border-bottom: 1px solid var(--border);
  user-select: none;
  -webkit-user-select: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-shrink: 0;
}
.close-btn[data-v-0efa6fec] {
  background: none;
  border: none;
  color: var(--text-dim);
  font-size: 12px;
  cursor: pointer;
  padding: 0 2px;
  line-height: 1;
  font-family: inherit;
}
.close-btn[data-v-0efa6fec]:hover {
  color: var(--red);
}
.pads-body[data-v-0efa6fec] {
  padding: 4px;
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
}
.pads-body.pads-fill[data-v-0efa6fec] {
  flex: 1;
  overflow-y: auto;
}
.pads-grid[data-v-0efa6fec] {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2px;
}
.pad-cell[data-v-0efa6fec] {
  height: 34px;
  border: 2px solid var(--border);
  background: var(--bg);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  position: relative;
  user-select: none;
  -webkit-user-select: none;
  transition: background 0.08s, border-color 0.08s;
}
.pad-cell[data-v-0efa6fec]:hover {
  background: var(--bg-alt);
}
.pad-cell.active[data-v-0efa6fec] {
  background: var(--cursor-bg);
}
.pad-cell.user-pad[data-v-0efa6fec] {
  border-style: dashed;
}
.pad-label[data-v-0efa6fec] {
  color: var(--text);
  font-size: 10px;
  text-align: center;
  line-height: 1.2;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  padding: 0 2px;
}
@media (max-width: 768px) {
.soundboard-panel.open[data-v-0efa6fec] {
    width: 160px;
    min-width: 160px;
}
.panel-inner[data-v-0efa6fec] {
    width: 160px;
    min-width: 160px;
}
}

.splash[data-v-b6e0fe69] {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: var(--bg-dark);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  cursor: pointer;
}
.splash-logo-row[data-v-b6e0fe69] {
  display: flex;
  align-items: center;
  margin-bottom: 30px;
}
.splash-icon[data-v-b6e0fe69] {
  height: 80px;
  width: auto;
  margin-right: 28px;
  flex-shrink: 0;
  align-self: center;
  margin-top: 8px;
}
.splash-logo[data-v-b6e0fe69] {
  height: 83px;
  width: auto;
}
.splash-prompt[data-v-b6e0fe69] {
  color: var(--yellow);
  font-size: 16px;
  animation: blink-b6e0fe69 1s step-end infinite;
}
@keyframes blink-b6e0fe69 {
50% { opacity: 0;
}
}

.spectrum-meter[data-v-27cb8e0e] {
  display: block;
  height: 20px;
  border: 1px solid var(--border);
  flex-shrink: 0;
}

.vu-meter[data-v-6a7f5755] {
  display: block;
  height: 16px;
  width: 120px;
  border: 1px solid var(--border);
  flex-shrink: 0;
}

.status-bar[data-v-22214ec2] {
  background: var(--header-bg);
  padding: 4px 12px;
  font-size: 12px;
  color: var(--text-dim);
  flex-shrink: 0;
  border-top: 2px solid var(--border-bright);
  white-space: nowrap;
  overflow: hidden;
  display: flex;
  align-items: center;
}
.status-left[data-v-22214ec2] {
  overflow: hidden;
  text-overflow: ellipsis;
  flex: 1;
  min-width: 0;
}
.status-bar[data-v-22214ec2] .vu-meter {
  margin-left: 12px;
}
.status-bar[data-v-22214ec2] .spectrum-meter {
  margin-left: 8px;
}

.title-bar[data-v-3efa82f6] {
  background: var(--header-bg);
  border-bottom: 2px solid var(--border-bright);
  padding: 6px 12px;
  display: flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
  flex-wrap: nowrap;
}
.title-bar .app-title[data-v-3efa82f6] {
  color: var(--cyan);
  font-weight: bold;
  font-size: 15px;
  margin-right: 20px;
  white-space: nowrap;
  flex-shrink: 0;
}
.song-controls[data-v-3efa82f6] {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  white-space: nowrap;
}
.title-bar label[data-v-3efa82f6] {
  color: var(--text-dim);
  margin-right: 2px;
  white-space: nowrap;
  flex-shrink: 0;
}
.title-bar input[type="number"][data-v-3efa82f6] {
  background: var(--bg-dark);
  color: var(--yellow);
  border: 1px solid var(--border);
  font-family: inherit;
  font-size: 13px;
  padding: 2px 6px;
  outline: none;
  width: 55px;
  flex-shrink: 0;
}
.title-bar input[data-v-3efa82f6]:focus {
  border-color: var(--cyan);
}
/* Marquee song name */
.song-name-box[data-v-3efa82f6] {
  width: 120px;
  min-width: 120px;
  overflow: hidden;
  cursor: text;
  background: var(--bg-dark);
  border: 1px solid var(--border);
  padding: 2px 6px;
  height: 21px;
  display: flex;
  align-items: center;
  flex-shrink: 0;
}
.song-name-box[data-v-3efa82f6]:hover {
  border-color: var(--cyan);
}
.song-name-text[data-v-3efa82f6] {
  display: inline-block;
  white-space: nowrap;
  color: var(--yellow);
  font-size: 13px;
}
.song-name-text.scrolling[data-v-3efa82f6] {
  animation: marquee-3efa82f6 6s linear infinite;
  animation-delay: 2s;
}
@keyframes marquee-3efa82f6 {
0%, 15% { transform: translateX(0);
}
45%, 55% { transform: translateX(var(--scroll-dist));
}
85%, 100% { transform: translateX(0);
}
}
.song-name-edit[data-v-3efa82f6] {
  background: var(--bg-dark);
  color: var(--yellow);
  border: 1px solid var(--cyan);
  font-family: inherit;
  font-size: 13px;
  padding: 2px 6px;
  outline: none;
  width: 120px;
  flex-shrink: 0;
}
.toolbar-sep[data-v-3efa82f6] {
  width: 0;
  height: 0;
  margin: 0 8px;
}
.transport-btn[data-v-3efa82f6] {
  min-width: 60px;
  text-align: center;
}
.menu-group[data-v-3efa82f6] {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}
/* File dropdown */
.file-dropdown[data-v-3efa82f6] {
  position: relative;
}
.file-menu[data-v-3efa82f6] {
  position: absolute;
  top: 100%;
  left: 0;
  z-index: 50;
  background: var(--bg-dark);
  border: 1px solid var(--border-bright);
  min-width: 130px;
  max-height: 60vh;
  overflow-y: auto;
  padding: 2px 0;
  margin-top: 2px;
}
.file-menu-item[data-v-3efa82f6] {
  padding: 4px 12px;
  color: var(--text);
  font-size: 12px;
  cursor: pointer;
  white-space: nowrap;
}
.file-menu-item[data-v-3efa82f6]:hover {
  background: var(--cursor-bg);
  color: var(--yellow);
}
.file-menu-sep[data-v-3efa82f6] {
  height: 1px;
  background: var(--border);
  margin: 2px 4px;
}
/* View menu */
.view-menu[data-v-3efa82f6] {
  min-width: 200px;
}
.view-item[data-v-3efa82f6] {
  display: flex;
  align-items: center;
  padding: 4px 8px;
}
.view-check[data-v-3efa82f6] {
  width: 18px;
  text-align: center;
  flex-shrink: 0;
  color: var(--green);
  font-size: 12px;
}
.view-hint[data-v-3efa82f6] {
  margin-left: auto;
  padding-left: 16px;
  color: var(--text-dim);
  font-size: 11px;
}
.view-disabled[data-v-3efa82f6] {
  opacity: 0.4;
  cursor: default;
}
.view-disabled[data-v-3efa82f6]:hover {
  background: none;
  color: var(--text);
}
.theme-menu[data-v-3efa82f6] {
  right: 0;
  left: auto;
}
.theme-active[data-v-3efa82f6] {
  color: var(--green) !important;
}

.hidden-input {
  display: none;
}
.export-overlay {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0, 0, 0, 0.7);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 700;
}
.export-box {
  background: var(--modal-bg);
  border: 2px solid var(--border-bright);
  padding: 20px 28px;
  text-align: center;
}
.export-heading {
  color: var(--cyan);
  font-weight: bold;
  font-size: 14px;
  margin-bottom: 8px;
}
.export-message {
  color: var(--text-dim);
  font-size: 12px;
}
/* style.css - Retro DOS styling for NoiseHacker */

/* DOS bitmap font */
@font-face {
  font-family: 'Perfect DOS VGA 437';
  src: url('../fonts/PerfectDOSVGA437.woff') format('woff');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

:root {
  --bg: #0a0a2e;
  --bg-alt: #0d0d3a;
  --bg-dark: #050520;
  --border: #3a3a7a;
  --border-bright: #5a5aba;
  --text: #aaaacc;
  --text-bright: #ddddff;
  --text-dim: #555577;
  --cyan: #55ffff;
  --yellow: #ffff55;
  --green: #55ff55;
  --red: #ff5555;
  --magenta: #ff55ff;
  --cursor-bg: #6b1010;
  --playing-bg: #1a3a1a;
  --beat-bg: #0e0e38;
  --note-color: #55ffff;
  --header-bg: #1a1a4a;
  --flash-bg: #3a3a00;
  --muted-color: #333355;
  --btn-bg: #1a1a4a;
  --btn-hover: #2a2a6a;
  --btn-active: #3a3a8a;
  --modal-bg: #0a0a2e;
  --scrollbar-bg: #0d0d3a;
  --scrollbar-thumb: #3a3a7a;
  --drop-color: #55ffff;
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  background: var(--bg);
  color: var(--text);
  font-family: 'Perfect DOS VGA 437', 'Courier New', 'Consolas', 'Monaco', monospace;
  font-size: 14px;
  line-height: 1.4;
  overflow: hidden;
  height: 100vh;
  width: 100vw;
  user-select: none;
  -webkit-user-select: none;
}

/* Small screen warning */
.small-screen-warning {
  display: none;
}
@media (max-width: 1279px) {
  .small-screen-warning {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    background: var(--bg-dark);
    z-index: 2000;
    text-align: center;
    padding: 20px;
    overflow: hidden;
  }
  .small-screen-warning p {
    color: var(--text-dim);
    font-size: 14px;
    margin: 4px 0;
  }
  .small-screen-warning p:first-of-type {
    margin-top: 8px;
  }
  .small-screen-icon {
    height: 64px;
    width: auto;
    margin-bottom: 20px;
    filter: drop-shadow(0 0 8px rgba(85, 255, 255, 0.3));
  }
  .small-screen-logo {
    height: 48px;
    width: auto;
    max-width: 80vw;
    margin-bottom: 28px;
    filter: drop-shadow(0 0 8px rgba(85, 255, 255, 0.3));
  }
}

/* Scrollbar */
::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}
::-webkit-scrollbar-track {
  background: var(--scrollbar-bg);
}
::-webkit-scrollbar-thumb {
  background: var(--scrollbar-thumb);
}

/* Splash screen */
#splash {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: var(--bg-dark);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  cursor: pointer;
}
#splash.hidden {
  display: none;
}
pre.splash-logo {
  color: var(--cyan);
  font-family: 'Courier New', 'Consolas', 'Monaco', monospace !important;
  font-size: 16px;
  white-space: pre;
  line-height: 1.15;
  margin-bottom: 30px;
  text-shadow: 0 0 10px rgba(85, 255, 255, 0.3);
}
.splash-prompt {
  color: var(--yellow);
  font-size: 16px;
  animation: blink 1s step-end infinite;
}
@keyframes blink {
  50% { opacity: 0; }
}

/* App layout */
#app {
  display: flex;
  flex-direction: column;
  height: calc(100vh / var(--zoom, 1));
}

/* Title bar */
.title-bar {
  background: var(--header-bg);
  border-bottom: 2px solid var(--border-bright);
  padding: 6px 12px;
  display: flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
  flex-wrap: wrap;
}
.title-bar .app-title {
  color: var(--cyan);
  font-weight: bold;
  font-size: 15px;
  margin-right: 10px;
  white-space: nowrap;
}
.title-bar label {
  color: var(--text-dim);
  margin-right: 2px;
}
.title-bar input[type="text"],
.title-bar input[type="number"] {
  background: var(--bg-dark);
  color: var(--yellow);
  border: 1px solid var(--border);
  font-family: inherit;
  font-size: 13px;
  padding: 2px 6px;
  outline: none;
}
.title-bar input[type="text"] {
  width: 120px;
}
.title-bar input[type="number"] {
  width: 55px;
}
.title-bar input:focus {
  border-color: var(--cyan);
}

/* Buttons */
.btn {
  background: var(--btn-bg);
  color: var(--text-bright);
  border: 1px solid var(--border);
  font-family: inherit;
  font-size: 12px;
  padding: 3px 10px;
  cursor: pointer;
  white-space: nowrap;
  outline: none;
}
.btn:hover {
  background: var(--btn-hover);
  border-color: var(--border-bright);
}
.btn:active {
  background: var(--btn-active);
}
.btn.active {
  color: var(--green);
  border-color: var(--green);
}
.btn.loop-active {
  color: var(--yellow);
  border-color: var(--yellow);
}
.btn.disabled {
  color: var(--text-dim);
  border-color: var(--bg-alt);
  cursor: default;
}
.btn.disabled:hover {
  background: var(--btn-bg);
  border-color: var(--bg-alt);
}

.toolbar-sep {
  width: 0;
  height: 0;
  margin: 0 8px;
}

.pattern-info {
  color: var(--green);
  font-size: 13px;
  white-space: nowrap;
}

/* Main content area — 3-panel layout */
.main-content {
  display: flex;
  flex: 1;
  overflow: hidden;
  border-bottom: 2px solid var(--border-bright);
}

/* Left panel: Instruments */
.instrument-panel {
  width: 190px;
  min-width: 190px;
  background: var(--bg-dark);
  display: flex;
  flex-direction: column;
  border-right: 2px solid var(--border);
}
.panel-header {
  background: var(--header-bg);
  color: var(--cyan);
  font-weight: bold;
  padding: 4px 8px;
  font-size: 13px;
  border-bottom: 1px solid var(--border);
}

#instrument-list {
  flex: 1;
  overflow-y: auto;
  padding: 4px;
}
.instrument-item {
  padding: 3px 6px;
  cursor: pointer;
  color: var(--text);
  font-size: 12px;
  white-space: nowrap;
}
.instrument-item:hover {
  background: var(--bg-alt);
}
.instrument-item.selected {
  background: var(--cursor-bg);
  color: var(--yellow);
}

/* Instrument category headers */
.category-header {
  padding: 3px 6px;
  cursor: pointer;
  font-size: 12px;
  font-weight: bold;
  display: flex;
  align-items: center;
  gap: 4px;
  border-bottom: 1px solid var(--bg-alt);
  user-select: none;
  -webkit-user-select: none;
}
.category-header:hover {
  background: var(--bg-alt);
}
.category-toggle {
  color: var(--text-dim);
  font-size: 11px;
  width: 14px;
  text-align: center;
  flex-shrink: 0;
}
.category-name {
  flex: 1;
}
.category-count {
  color: var(--text-dim);
  font-size: 10px;
}
.category-items {
  /* visible by default */
}
.category-items.collapsed {
  display: none;
}

.panel-buttons {
  padding: 6px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  border-top: 1px solid var(--border);
}
.panel-buttons .btn {
  width: 100%;
  text-align: center;
}

/* Swing control */
.swing-control {
  padding: 6px 8px;
  border-top: 1px solid var(--border);
  font-size: 12px;
}
.swing-control label {
  color: var(--text-dim);
}
.swing-control input[type="range"] {
  width: 100%;
  accent-color: var(--cyan);
  margin-top: 2px;
}

/* Center: Pattern grid container */
.grid-container {
  flex: 1;
  overflow-y: auto;
  overflow-x: auto;
}

/* Grid */
#pattern-grid {
  display: flex;
  flex-direction: column;
  min-width: fit-content;
}

.grid-row {
  display: flex;
  border-bottom: 1px solid var(--bg-alt);
}
.grid-row.beat-boundary {
  border-top: 1px solid var(--border);
}
.grid-row.grid-header {
  position: sticky;
  top: 0;
  z-index: 10;
  background: var(--header-bg);
  border-bottom: 2px solid var(--border-bright);
}

.grid-cell {
  padding: 2px 8px;
  white-space: nowrap;
  font-size: 13px;
  min-width: 70px;
  text-align: center;
}

.row-header {
  min-width: 35px;
  max-width: 35px;
  color: var(--text-dim);
  text-align: right;
  padding-right: 6px;
  background: var(--bg-dark);
  border-right: 1px solid var(--border);
}
.row-header.playing {
  color: var(--green);
  background: var(--playing-bg);
}

.channel-header {
  color: var(--cyan);
  font-weight: bold;
  cursor: pointer;
  background: var(--header-bg);
}
.channel-header:hover {
  background: var(--btn-hover);
}
.channel-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  line-height: 1.2;
  padding-top: 3px;
  padding-bottom: 2px;
}
.ch-badges {
  display: flex;
  gap: 3px;
  margin-top: 2px;
}
.ch-badge {
  font-size: 9px;
  font-weight: bold;
  width: 14px;
  height: 14px;
  line-height: 14px;
  text-align: center;
  border: 1px solid var(--border);
  color: var(--text-dim);
  cursor: pointer;
}
.ch-badge:hover {
  border-color: var(--border-bright);
}
.ch-m.on {
  color: var(--red);
  border-color: var(--red);
}
.ch-s.on {
  color: var(--bg-dark);
  background: var(--green);
  border-color: var(--green);
}
.channel-header.flash {
  background: var(--flash-bg);
  color: var(--yellow);
}

.note-cell {
  color: var(--text-dim);
  cursor: pointer;
}
.note-cell:hover {
  background: var(--bg-alt);
}
.note-cell.has-note {
  color: var(--note-color);
}
.note-cell.cursor {
  background: var(--cursor-bg);
  color: var(--text-bright);
  box-shadow: inset 0 0 0 1px var(--red);
}
.note-cell.cursor.has-note {
  color: var(--yellow);
}
.note-cell.playing {
  background: var(--playing-bg);
}
.note-cell.playing.has-note {
  color: var(--green);
  text-shadow: 0 0 6px rgba(85, 255, 85, 0.5);
}

/* Right panel: Arrangement */
.arrangement-panel {
  width: 180px;
  min-width: 180px;
  background: var(--bg-dark);
  display: flex;
  flex-direction: column;
  border-left: 2px solid var(--border);
}

/* Pattern pool (top of arrangement) */
.arrangement-pool {
  padding: 4px;
  display: flex;
  flex-wrap: wrap;
  gap: 3px;
  border-bottom: 1px solid var(--border);
  max-height: 80px;
  overflow-y: auto;
}

.pool-item {
  background: var(--bg);
  border: 1px solid var(--border);
  color: var(--cyan);
  font-size: 11px;
  padding: 2px 6px;
  cursor: grab;
  white-space: nowrap;
}
.pool-item:hover {
  background: var(--bg-alt);
  border-color: var(--border-bright);
}
.pool-item.dragging {
  opacity: 0.5;
}

.arrangement-divider {
  height: 0;
}

/* Playlist (main area) */
.arrangement-playlist {
  flex: 1;
  overflow-y: auto;
  padding: 4px;
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.playlist-block {
  background: var(--bg);
  border: 1px solid var(--border);
  padding: 6px 8px;
  cursor: grab;
  position: relative;
  transition: background 0.1s, border-color 0.1s;
}
.playlist-block:hover {
  background: var(--bg-alt);
  border-color: var(--border-bright);
}
.playlist-block.selected {
  background: var(--cursor-bg);
  border-color: var(--yellow);
}
.playlist-block.playing {
  background: var(--playing-bg);
  border-color: var(--green);
}
.playlist-block.dragging {
  opacity: 0.4;
}

.playlist-block .block-pos {
  color: var(--text-dim);
  font-size: 10px;
}
.playlist-block .block-name {
  color: var(--text-bright);
  font-size: 12px;
}
.playlist-block.selected .block-name {
  color: var(--yellow);
}
.playlist-block.playing .block-name {
  color: var(--green);
}
.playlist-block.playing .block-pos {
  color: var(--green);
}

/* Drag-and-drop states */
.playlist-block.drag-over-top {
  border-top: 2px solid var(--drop-color);
  margin-top: -1px;
}
.playlist-block.drag-over-bottom {
  border-bottom: 2px solid var(--drop-color);
  margin-bottom: -1px;
}
.arrangement-playlist.drag-over-empty {
  background: rgba(85, 255, 255, 0.05);
  outline: 1px dashed var(--drop-color);
  outline-offset: -2px;
}

/* Arrangement buttons */
.arrangement-buttons {
  padding: 6px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  border-top: 1px solid var(--border);
}
.arrangement-buttons .btn {
  width: 100%;
  text-align: center;
  font-size: 11px;
}

/* Status bar */
.status-bar {
  background: var(--header-bg);
  padding: 4px 12px;
  font-size: 12px;
  color: var(--text-dim);
  flex-shrink: 0;
  border-top: 2px solid var(--border-bright);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Message bar */
.message-bar {
  position: fixed;
  bottom: 30px;
  left: 50%;
  transform: translateX(-50%);
  padding: 6px 16px;
  font-size: 13px;
  z-index: 100;
  border: 1px solid var(--border);
  transition: opacity 0.3s;
}
.message-bar.hidden {
  display: none;
}
.message-bar.info {
  background: var(--bg-dark);
  color: var(--green);
  border-color: var(--green);
}
.message-bar.warning {
  background: var(--bg-dark);
  color: var(--yellow);
  border-color: var(--yellow);
}
.message-bar.error {
  background: var(--bg-dark);
  color: var(--red);
  border-color: var(--red);
}

/* Load modal */
.modal-overlay {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0, 0, 0, 0.7);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 500;
}
.modal-overlay.hidden {
  display: none;
}
.modal {
  background: var(--modal-bg);
  border: 2px solid var(--border-bright);
  padding: 0;
  min-width: 300px;
  max-width: 450px;
  max-height: 70vh;
}
.modal-title {
  background: var(--header-bg);
  color: var(--cyan);
  padding: 6px 12px;
  font-weight: bold;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.modal-title .btn {
  font-size: 11px;
  padding: 2px 8px;
}
.modal-body {
  padding: 8px;
  max-height: 50vh;
  overflow-y: auto;
}
.load-item {
  display: flex;
  justify-content: space-between;
  padding: 4px 6px;
  border-bottom: 1px solid var(--bg-alt);
}
.load-name {
  color: var(--text-bright);
  cursor: pointer;
}
.load-name:hover {
  color: var(--cyan);
}
.load-delete {
  color: var(--red);
  cursor: pointer;
  font-size: 11px;
}
.load-delete:hover {
  color: var(--yellow);
}

/* Help overlay */
.help-overlay {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0, 0, 0, 0.85);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 600;
}
.help-overlay.hidden {
  display: none;
}
.help-box {
  background: var(--bg);
  border: 2px solid var(--border-bright);
  padding: 20px;
  max-width: 500px;
  width: 90%;
}
.help-box h2 {
  color: var(--cyan);
  font-size: 16px;
  margin-bottom: 12px;
  font-weight: bold;
}
.help-box table {
  width: 100%;
  border-collapse: collapse;
}
.help-box td {
  padding: 3px 8px;
  font-size: 12px;
}
.help-box td:first-child {
  color: var(--yellow);
  white-space: nowrap;
  width: 120px;
}
.help-box td:last-child {
  color: var(--text);
}
.help-close {
  margin-top: 12px;
  text-align: center;
}

/* Hidden file inputs */
.hidden-input {
  display: none;
}

/* Responsive */
@media (max-width: 768px) {
  .instrument-panel {
    width: 150px;
    min-width: 150px;
  }
  .arrangement-panel {
    width: 140px;
    min-width: 140px;
  }
  .grid-cell {
    font-size: 12px;
    padding: 2px 4px;
    min-width: 58px;
  }
  .title-bar {
    font-size: 12px;
    gap: 4px;
  }
  .btn {
    font-size: 11px;
    padding: 2px 6px;
  }
}

/* ── Modern ST3 theme overrides ── */
.modern {
  font-family: 'SF Mono', 'JetBrains Mono', 'Fira Code', 'Cascadia Code', 'Consolas', monospace;
}
.modern body {
  font-family: 'SF Mono', 'JetBrains Mono', 'Fira Code', 'Cascadia Code', 'Consolas', monospace;
}

/* Buttons */
.modern .btn {
  border-radius: 6px;
  transition: background 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}
.modern .btn:hover {
  box-shadow: 0 2px 8px rgba(166, 146, 85, 0.18);
}

/* Title bar */
.modern .title-bar {
  border-bottom: 1px solid var(--border);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.4);
  border-radius: 0;
}
.modern .title-bar input[type="text"],
.modern .title-bar input[type="number"] {
  border-radius: 4px;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.modern .title-bar input:focus {
  box-shadow: 0 0 0 2px rgba(166, 146, 85, 0.25);
}

/* Panels */
.modern .instrument-panel,
.modern .arrangement-panel {
  border-radius: 0;
  box-shadow: 2px 0 12px rgba(0, 0, 0, 0.3);
}
.modern .panel-header {
  border-radius: 0;
}

/* Grid */
.modern .grid-row {
  border-bottom-color: rgba(166, 146, 85, 0.08);
}
.modern .grid-row.beat-boundary {
  border-top-color: rgba(166, 146, 85, 0.2);
}
.modern .note-cell {
  transition: background 0.1s ease;
}
.modern .note-cell.cursor {
  border-radius: 3px;
}

/* Channel badges */
.modern .ch-badge {
  border-radius: 3px;
}

/* Pool / playlist items */
.modern .pool-item {
  border-radius: 4px;
  transition: background 0.15s ease, border-color 0.15s ease;
}
.modern .playlist-block {
  border-radius: 6px;
  transition: background 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}
.modern .playlist-block:hover {
  box-shadow: 0 2px 6px rgba(166, 146, 85, 0.12);
}

/* Modals */
.modern .modal {
  border-radius: 10px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.6);
  border-width: 1px;
  overflow: hidden;
}
.modern .modal-overlay {
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}
.modern .modal-title {
  border-radius: 0;
}

/* Help overlay */
.modern .help-box {
  border-radius: 10px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.6);
  border-width: 1px;
}

/* Message bar */
.modern .message-bar {
  border-radius: 20px;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.4);
}

/* Status bar */
.modern .status-bar {
  border-top: 1px solid var(--border);
  box-shadow: 0 -2px 8px rgba(0, 0, 0, 0.3);
}
.modern .main-content {
  border-bottom: 1px solid var(--border);
}

/* Scrollbar */
.modern ::-webkit-scrollbar-thumb {
  border-radius: 4px;
}
.modern ::-webkit-scrollbar-track {
  border-radius: 4px;
}

/* Instrument items */
.modern .instrument-item {
  border-radius: 4px;
  transition: background 0.1s ease;
}
.modern .instrument-item.selected {
  border-radius: 4px;
}
.modern .category-header {
  border-radius: 4px;
  transition: background 0.1s ease;
}

/* Swing range input */
.modern .swing-control input[type="range"] {
  border-radius: 4px;
}

/* Select dropdowns */
.modern select {
  border-radius: 4px;
}
