:root,
[data-theme="light"] {
  --bg: #f0f2f5;
  --surface: #fff;
  --border: #dde1e8;
  --text: #1c2333;
  --muted: #6b7280;
  --accent: #2563eb;
  --accent-hover: #1d4ed8;
  --input-bg: #fff;
  --log-bg: #f8f9fb;
  --shadow: 0 1px 4px rgba(0, 0, 0, 0.06);
  --ok: #059669;
  --err: #dc2626;
  --run: #2563eb;
}

[data-theme="dark"] {
  --bg: #0e1014;
  --surface: #181b22;
  --border: #2d3340;
  --text: #e8eaef;
  --muted: #9aa3b2;
  --accent: #5b8def;
  --accent-hover: #4a7de0;
  --input-bg: #12151c;
  --log-bg: #12151c;
  --shadow: none;
  --ok: #34d399;
  --err: #f87171;
  --run: #5b8def;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: system-ui, -apple-system, "Segoe UI", sans-serif;
  font-size: 14px;
  background: var(--bg);
  color: var(--text);
  line-height: 1.45;
}

.wrap {
  max-width: 1320px;
  margin: 0 auto;
  padding: 1rem 1.25rem 2rem;
}

.top-actions {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  flex-shrink: 0;
}

.top-admin-link {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  height: 38px;
  padding: 0 0.8rem;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--surface);
  color: var(--text);
  text-decoration: none;
  font-size: 0.8125rem;
  font-weight: 500;
  line-height: 1;
  box-shadow: var(--shadow);
  transition: border-color 0.15s, background 0.15s, color 0.15s, box-shadow 0.15s;
}

.top-admin-link:hover {
  border-color: color-mix(in srgb, var(--accent) 50%, var(--border));
  color: var(--accent);
  background: color-mix(in srgb, var(--accent) 7%, var(--surface));
}

.top-admin-link:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--accent) 55%, transparent);
  outline-offset: 2px;
}

.top-admin-link-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.15rem;
  height: 1.15rem;
  font-size: 0.95rem;
  color: var(--accent);
  flex-shrink: 0;
}

.top-admin-link-text {
  white-space: nowrap;
}

.top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid var(--border);
}

.top h1 { margin: 0; font-size: 1.35rem; font-weight: 600; }
.sub { margin: 0.2rem 0 0; font-size: 0.88rem; color: var(--muted); }

.icon-btn {
  width: 38px;
  height: 38px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--surface);
  color: var(--text);
  font-size: 1rem;
  cursor: pointer;
}
.icon-btn:hover { border-color: var(--accent); }

/* —— 3 cột ngang —— */
.grid-wide {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) minmax(300px, 1.05fr) minmax(300px, 1.2fr);
  gap: 1rem;
  align-items: stretch;
}

@media (max-width: 1024px) {
  .grid-wide {
    grid-template-columns: 1fr 1fr;
  }
  .col-results { grid-column: 1 / -1; }
}

@media (max-width: 640px) {
  .grid-wide {
    grid-template-columns: 1fr;
    align-items: start;
  }
  .panel {
    min-height: 0;
    height: auto;
    flex: 0 0 auto;
  }
}

.panel {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 1rem 1.1rem;
  box-shadow: var(--shadow);
  height: 100%;
  min-height: 460px;
  display: flex;
  flex-direction: column;
}

.batch-run-opts {
  flex-shrink: 0;
  margin: 0.45rem 0 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 0.75rem;
  align-items: flex-end;
}

.batch-parallel-opt,
.render-target-opt {
  margin: 0;
}

.batch-parallel-opt.hidden {
  display: none;
}

.render-target-hint {
  margin: 0.15rem 0 0;
  font-size: 0.72rem;
  line-height: 1.25;
}

.render-target-badge {
  align-self: center;
  font-size: 0.65rem;
  font-weight: 600;
  padding: 0.1rem 0.35rem;
  border-radius: 4px;
  letter-spacing: 0.02em;
  white-space: nowrap;
  line-height: 1.2;
}

.render-target-badge.is-wasm {
  background: color-mix(in srgb, #2d8a4e 12%, var(--surface));
  color: #2d8a4e;
  border: 1px solid color-mix(in srgb, #2d8a4e 28%, transparent);
}

.mode-render-browser .tab.tab--blocked {
  opacity: 0.42;
  pointer-events: none;
  cursor: not-allowed;
}

.mode-render-browser .batch-run-opts .render-target-opt select {
  border-color: color-mix(in srgb, #2d8a4e 45%, var(--border));
}

.mode-render-server .batch-run-opts .render-target-opt select {
  border-color: color-mix(in srgb, var(--accent) 45%, var(--border));
}

.col-input .input-actions {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin: 0.35rem 0 0.35rem;
}

.col-input .queue-panel {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  margin-top: 0.15rem;
}

.queue-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  margin-bottom: 0.35rem;
}

.queue-title {
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--muted);
}

.queue-count {
  font-size: 0.75rem;
  color: var(--muted);
  margin-right: auto;
}

.queue-reset {
  flex-shrink: 0;
  padding: 0.2rem 0.55rem;
  font-size: 0.75rem;
}

.queue-box {
  flex: 1;
  min-height: 128px;
  max-height: min(42vh, 320px);
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--input-bg);
  overflow: hidden;
}

.queue-box.is-empty {
  border-style: dashed;
  background: color-mix(in srgb, var(--bg) 55%, var(--input-bg));
}

.col-input .file-list {
  list-style: none;
  margin: 0;
  padding: 0.45rem 0.65rem 0.55rem;
  max-height: min(42vh, 320px);
  overflow-y: auto;
  font-size: 0.8rem;
}

.col-input .input-actions .btn.block {
  margin-top: 0;
}

.col-settings .settings-folds {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
}

.opts-render-core {
  gap: 0.28rem;
}

.opts-render-core .opt {
  display: grid;
  grid-template-columns: minmax(5.5rem, 6.4rem) minmax(0, 1fr);
  align-items: center;
  column-gap: 0.4rem;
  row-gap: 0.1rem;
}

.opts-render-core .opt span {
  font-size: 0.65rem;
  line-height: 1.2;
}

.opts-render-core .opt select {
  padding: 0.28rem 0.38rem;
  font-size: 0.82rem;
  min-width: 0;
}

.opts-render-core .opt .field-hint {
  grid-column: 2;
  margin: 0;
  font-size: 0.72rem;
  line-height: 1.3;
}

.blur80-opts {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 0.85rem;
  padding: 0.35rem 0.5rem;
  margin-left: 0.15rem;
  border-left: 2px solid var(--border, #e4e4e7);
  font-size: 0.8rem;
}

.blur80-opts.hidden {
  display: none;
}

.blur80-opt {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  cursor: pointer;
}

.music-block {
  margin-top: 0.65rem;
  padding-top: 0.55rem;
  border-top: 1px solid var(--border, #e4e4e7);
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}

.proxy-block-render {
  margin-bottom: 0;
}

/* (undo) setting-toggle-block wrappers removed from HTML */

.render-proxy-options {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  padding-left: 0.15rem;
}

.render-proxy-options[hidden] {
  display: none !important;
}

.render-proxy-mode {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 0.85rem;
  font-size: 0.82rem;
}

.render-proxy-mode-opt {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  cursor: pointer;
}

.render-proxy-panel {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}

.render-proxy-panel.hidden {
  display: none !important;
}

.render-proxy-field {
  width: 100%;
}

.render-proxy-field .field-input-dense {
  width: 100%;
  box-sizing: border-box;
}

#btnRenderProxyRefresh {
  align-self: flex-start;
}

#renderProxyRotateStatus {
  margin: 0;
  font-size: 0.76rem;
}

.music-file-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.6rem;
  font-size: 0.82rem;
}

.music-options {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}

.music-options[hidden] {
  display: none !important;
}

.audioeq-options[hidden] {
  display: none !important;
}

.pulse-options[hidden] {
  display: none !important;
}

.colorfx-options[hidden] {
  display: none !important;
}

.colorfx-options .check-row {
  margin-bottom: 0.35rem;
}

.colorfx-options .fx-grid {
  margin-top: 0.15rem;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.28rem 0.45rem;
  font-size: 0.78rem;
}

.colorfx-options .fx-grid label {
  gap: 0.28rem;
  min-width: 0;
}

.toggle-details {
  margin-top: 0.55rem;
  padding-top: 0.55rem;
  border-top: 1px solid var(--border);
}

.music-file-name {
  font-size: 0.78rem;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  cursor: pointer;
}

.volume-sliders {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.vol-slider {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  font-size: 0.82rem;
}

.vol-slider-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 0.5rem;
}

.vol-slider-head output {
  font-variant-numeric: tabular-nums;
  font-size: 0.78rem;
  color: var(--muted, #71717a);
  min-width: 2.5rem;
  text-align: right;
}

.vol-slider input[type="range"] {
  width: 100%;
  accent-color: var(--accent, #2563eb);
}

/* Tốc độ kiểu CapCut: slider + số */
.capcut-speed {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  width: 100%;
  min-width: 0;
}

.capcut-speed-label {
  font-size: 0.76rem;
  font-weight: 600;
  color: var(--muted, #71717a);
}

.capcut-speed-row {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  width: 100%;
}

.capcut-speed-range,
.set-flex-range {
  flex: 1 1 5rem;
  min-width: 5rem;
  width: 100%;
  position: relative;
  z-index: 1;
  accent-color: var(--accent, #2563eb);
  height: 1.35rem;
  cursor: pointer;
  touch-action: pan-x;
}

.capcut-speed-num,
.set-flex-num,
.render-num-input,
.render-pitch-num,
.render-pulse-num {
  flex-shrink: 0;
  min-width: 4.5rem;
  width: 4.75rem;
  padding: 0.28rem 0.35rem;
  font-size: 0.82rem;
  font-variant-numeric: tabular-nums;
  text-align: center;
  border: 1px solid var(--border, #e4e4e7);
  border-radius: 6px;
  background: var(--input-bg, #fff);
  -moz-appearance: textfield;
  appearance: textfield;
}

/* Ô số gõ tay (type=text) + ẩn spinner nếu còn input type=number khác */
.render-num-stepper input,
.capcut-speed-num,
.set-flex-num,
.render-num-input,
.render-pitch-num,
.render-pulse-num,
.col-settings .opt input[type="number"] {
  -moz-appearance: textfield;
  appearance: textfield;
}

.render-num-stepper input::-webkit-inner-spin-button,
.render-num-stepper input::-webkit-outer-spin-button,
.capcut-speed-num::-webkit-inner-spin-button,
.capcut-speed-num::-webkit-outer-spin-button,
.set-flex-num::-webkit-inner-spin-button,
.set-flex-num::-webkit-outer-spin-button,
.render-num-input::-webkit-inner-spin-button,
.render-num-input::-webkit-outer-spin-button,
.render-pitch-num::-webkit-inner-spin-button,
.render-pitch-num::-webkit-outer-spin-button,
.render-pulse-num::-webkit-inner-spin-button,
.render-pulse-num::-webkit-outer-spin-button,
.col-settings .opt input[type="number"]::-webkit-inner-spin-button,
.col-settings .opt input[type="number"]::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.render-num-stepper {
  display: inline-flex;
  align-items: stretch;
  flex-shrink: 0;
  border: 1px solid var(--border, #e4e4e7);
  border-radius: 6px;
  background: var(--input-bg, #fff);
  overflow: hidden;
}

.render-num-stepper .render-num-input,
.render-num-stepper .capcut-speed-num,
.render-num-stepper .set-flex-num,
.render-num-stepper .render-pitch-num,
.render-num-stepper .render-pulse-num {
  width: 4.5rem;
  min-width: 4.5rem;
  border: none;
  border-radius: 0;
  margin: 0;
  -moz-appearance: textfield;
  appearance: textfield;
}

.render-num-stepper--sm .render-num-input,
.render-num-stepper--sm .capcut-speed-num,
.render-num-stepper--sm .set-flex-num,
.render-num-stepper--sm .render-pitch-num,
.render-num-stepper--sm .render-pulse-num {
  width: 3.1rem;
  min-width: 3.1rem;
  padding: 0.18rem 0.2rem;
  font-size: 0.78rem;
}

.render-num-step {
  flex: 0 0 1.65rem;
  padding: 0;
  border: none;
  border-left: 1px solid var(--border, #e4e4e7);
  background: var(--log-bg, #f4f4f5);
  color: var(--text, #18181b);
  font-size: 0.95rem;
  line-height: 1;
  cursor: pointer;
}

.render-num-stepper--sm .render-num-step {
  flex: 0 0 1.28rem;
  font-size: 0.8rem;
}

.render-num-stepper .render-num-step:first-child {
  border-left: none;
  border-right: 1px solid var(--border, #e4e4e7);
}

.render-num-step:hover:not(:disabled) {
  background: color-mix(in srgb, var(--accent, #2563eb) 12%, var(--log-bg, #f4f4f5));
  color: var(--accent, #2563eb);
}

.render-num-step:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

/* Trang render: tốc độ + cao độ — label trái, slider phải */
.opts-render-speed-pitch,
.opts-render-pulse {
  display: flex;
  flex-direction: column;
  gap: 0.28rem;
}

.opts-render-speed-pitch .opt,
.opts-render-pulse .opt {
  margin: 0;
  display: grid;
  grid-template-columns: minmax(5.5rem, 6.4rem) minmax(0, 1fr);
  align-items: center;
  column-gap: 0.4rem;
}

.opts-render-speed-pitch .opt span,
.opts-render-pulse .opt span {
  font-size: 0.65rem;
  line-height: 1.2;
}

.opts-render-speed-pitch .capcut-speed,
.opts-render-pulse .capcut-speed {
  width: 100%;
  min-width: 0;
  gap: 0;
}

.opts-render-speed-pitch .capcut-speed-row,
.opts-render-pulse .capcut-speed-row {
  gap: 0.35rem;
}

.opts-render-speed-pitch .capcut-speed-range,
.opts-render-pulse .capcut-speed-range {
  height: 1.15rem;
  min-width: 3.5rem;
}

#renderFold .fold-body > .toggle-details:has(.opts-render-speed-pitch) {
  margin-top: 0.35rem;
  padding-top: 0.35rem;
}

.col-results {
  min-height: 0;
  overflow: hidden;
}

.col-results .results-head {
  flex-shrink: 0;
}

/* Cùng chiều cao panel với cột 1–2: job + log chia phần còn lại, cuộn trong khung */
.results-stack {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  overflow: hidden;
}

.batch-progress-wrap {
  flex-shrink: 0;
  padding: 0.45rem 0.55rem;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--surface);
}

.batch-progress-wrap.hidden {
  display: none !important;
}

.batch-progress-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  margin-bottom: 0.35rem;
  font-size: 0.78rem;
  color: var(--muted);
}

.batch-progress-pct {
  font-variant-numeric: tabular-nums;
  font-weight: 600;
  color: var(--text);
}

.batch-progress-track,
.job-progress-track {
  height: 0.45rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--border) 65%, transparent);
  overflow: hidden;
}

.batch-progress-fill,
.job-progress-fill {
  height: 100%;
  width: 0%;
  border-radius: inherit;
  background: var(--accent);
  transition: width 0.2s ease;
}

.job-progress-wrap {
  margin-top: 0.28rem;
}

.job-progress-wrap[hidden] {
  display: none !important;
}

.progress-ui-options[hidden] {
  display: none !important;
}

.progress-ui-options {
  margin-top: 0.3rem;
  padding: 0.32rem 0.42rem;
  border: 1px dashed var(--border);
  border-radius: 8px;
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  width: 100%;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  gap: 0.28rem;
}

.progress-ui-options.is-progress-off {
  opacity: 0.72;
}

.progress-ui-row {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  min-width: 0;
}

.progress-ui-row .progress-icon-picker {
  flex: 1 1 auto;
  min-width: 0;
  margin-top: 0;
  padding-top: 0;
}

.progress-icon-picker-label {
  margin: 0;
  font-size: 0.68rem;
  font-weight: 600;
  color: var(--muted, #71717a);
  line-height: 1.15;
}

.progress-ui-row .progress-icon-picker-label {
  flex: 0 0 3.6rem;
}

.voice-sep-options .voice-sep-row .progress-icon-picker-label {
  flex: 0 0 auto;
  white-space: nowrap;
}

.voice-sep-options .voice-sep-modes {
  margin: 0;
  flex: 1 1 auto;
  min-width: 0;
  gap: 0.35rem 0.65rem;
  font-size: 0.8rem;
}

.progress-icon-picker-hint {
  margin: 0.4rem 0 0;
}

.progress-ui-options .checks-sub {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem 0.75rem;
  margin-top: 0.35rem;
}

.progress-icon-picker {
  display: flex;
  flex-wrap: nowrap;
  gap: 0.28rem;
  width: 100%;
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: thin;
}

.progress-icon-picker.is-disabled {
  opacity: 0.55;
  pointer-events: none;
}

.progress-icon-pick {
  display: flex;
  flex: 0 0 auto;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  padding: 2px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--surface);
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
}

.progress-icon-pick:hover:not(:disabled) {
  border-color: var(--accent);
}

.progress-icon-pick.is-selected {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 10%, var(--surface));
}

.progress-bar-pick {
  min-width: 46px;
  width: 46px;
}

.progress-bar-pick img {
  width: 42px;
  height: auto;
  object-fit: contain;
  pointer-events: none;
}

.bg-music-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.5rem;
}

.bg-music-head-label {
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--muted, #71717a);
  flex: 0 0 auto;
}

.bg-music-presets {
  display: flex;
  flex-wrap: wrap;
  gap: 0.28rem;
  flex: 1 1 auto;
  min-width: 0;
}

.bg-music-preset-pick {
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: 0.2rem;
  padding: 0.2rem 0.42rem;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: var(--surface);
  cursor: pointer;
  font-size: 0.68rem;
  line-height: 1.15;
  color: var(--text);
  white-space: nowrap;
  transition: border-color 0.15s, background 0.15s;
}

.bg-music-preset-pick:hover:not(:disabled) {
  border-color: var(--accent);
}

.bg-music-preset-pick.is-selected {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 10%, var(--surface));
}

.bg-music-preset-emoji {
  font-size: 0.82rem;
  line-height: 1;
}

.bg-music-preset-label {
  font-weight: 600;
}

.bg-music-saved {
  display: flex;
  flex-direction: column;
  gap: 0.28rem;
}

.bg-music-saved-label {
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--muted, #71717a);
}

.bg-music-saved-slot {
  min-height: 2.1rem;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--surface);
  padding: 0.3rem 0.4rem;
}

.bg-music-saved-empty {
  margin: 0;
  padding: 0.2rem 0.15rem;
  font-size: 0.72rem;
  color: var(--muted, #71717a);
}

.bg-music-saved-file {
  display: flex;
  align-items: center;
  gap: 0.35rem;
}

.bg-music-saved-pick {
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  gap: 0.35rem;
  min-width: 0;
  padding: 0.15rem 0.35rem;
  border: 1px solid transparent;
  border-radius: 6px;
  background: transparent;
  cursor: pointer;
  text-align: left;
  font: inherit;
  color: var(--text);
}

.bg-music-saved-pick:hover:not(:disabled) {
  border-color: var(--border);
  background: color-mix(in srgb, var(--accent) 6%, var(--surface));
}

.bg-music-saved-pick.is-selected {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 10%, var(--surface));
}

.bg-music-saved-pick:disabled {
  opacity: 0.45;
  cursor: default;
}

.bg-music-saved-icon {
  flex: 0 0 auto;
  font-size: 0.9rem;
  line-height: 1;
}

.bg-music-saved-name {
  flex: 1 1 auto;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 0.74rem;
  font-weight: 600;
}

.bg-music-saved-meta {
  flex: 0 0 auto;
  font-size: 0.66rem;
  color: var(--muted, #71717a);
  font-variant-numeric: tabular-nums;
}

.bg-music-saved-clear {
  flex: 0 0 auto;
  width: 1.55rem;
  height: 1.55rem;
  padding: 0;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--surface);
  color: var(--muted, #71717a);
  font-size: 0.72rem;
  line-height: 1;
  cursor: pointer;
}

.bg-music-saved-clear:hover {
  border-color: #e57373;
  color: #c62828;
}

.bg-music-add {
  display: flex;
  align-items: center;
  gap: 0.35rem 0.45rem;
  padding: 0.32rem 0.45rem;
  border: 1px dashed color-mix(in srgb, var(--border) 85%, var(--accent));
  border-radius: 8px;
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  font-size: 0.72rem;
  min-height: 1.85rem;
}

.bg-music-add.is-dragover {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 8%, var(--surface));
}

.bg-music-add-icon {
  flex: 0 0 auto;
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--accent);
  line-height: 1;
}

.bg-music-add-text {
  flex: 1 1 auto;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  cursor: pointer;
  color: var(--muted, #71717a);
}

.bg-music-add-text.has-file {
  color: var(--text);
  font-weight: 500;
}

.bg-music-add-btn {
  flex: 0 0 auto;
  padding: 0.18rem 0.55rem;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--surface);
  font-size: 0.68rem;
  font-weight: 600;
  color: var(--text);
  cursor: pointer;
}

.bg-music-add-btn:hover {
  border-color: var(--accent);
  color: var(--accent);
}

.volume-sliders--compact {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.35rem 0.65rem;
}

@media (max-width: 520px) {
  .volume-sliders--compact {
    grid-template-columns: 1fr;
  }
}

.progress-icon-pick img {
  display: block;
  width: 26px;
  height: 26px;
  object-fit: contain;
  pointer-events: none;
}

.progress-icon-upload {
  border-style: dashed;
  color: var(--muted);
}

.progress-icon-upload:hover:not(:disabled) {
  border-style: dashed;
  background: color-mix(in srgb, var(--accent) 8%, var(--surface));
}

.progress-icon-upload.is-selected {
  border-style: solid;
}

.progress-icon-upload-label {
  font-size: 1rem;
  font-weight: 600;
  line-height: 1;
  pointer-events: none;
}

.progress-icon-saved {
  border-color: color-mix(in srgb, var(--accent) 55%, var(--border));
}

.progress-icon-saved-label {
  font-size: 0.95rem;
  line-height: 1;
  color: var(--muted);
  pointer-events: none;
}

@media (max-width: 640px) {
  .progress-icon-picker {
    flex-wrap: wrap;
    overflow-x: visible;
  }
}

.job-status-spinner {
  display: inline-block;
  width: 0.85rem;
  height: 0.85rem;
  margin-right: 0.35rem;
  flex-shrink: 0;
  border: 2px solid color-mix(in srgb, var(--accent) 35%, transparent);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: job-spinner-spin 0.75s linear infinite;
  vertical-align: middle;
}

@keyframes job-spinner-spin {
  to { transform: rotate(360deg); }
}

.job-row-running .job-status-spinner,
.job-row-fetching .job-status-spinner,
.job-row-queued .job-status-spinner {
  border-top-color: var(--accent);
}

.col-results .results-jobs-panel {
  flex: 3 1 0;
  min-height: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.results-jobs-box {
  flex: 1;
  min-height: 0;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--log-bg);
  overflow: hidden;
}

.results-jobs-box.is-empty {
  border-style: dashed;
  background: color-mix(in srgb, var(--bg) 55%, var(--log-bg));
}

.results-jobs-box .jobs-list {
  height: 100%;
  max-height: none;
  border: none;
  border-radius: 0;
  background: transparent;
}

.panel-title {
  margin: 0 0 0.65rem;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--muted);
}

.pane-hint {
  margin: 0 0 0.65rem;
  font-size: 0.82rem;
  color: var(--muted);
}

.kind-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem 0.75rem;
  margin-bottom: 0.65rem;
}

.kind-opt {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.86rem;
  cursor: pointer;
}

.kind-opt[hidden] {
  display: none !important;
}

.kind-opt input:disabled {
  cursor: not-allowed;
  opacity: 0.45;
}

.block-input {
  width: 100%;
  padding: 0.5rem 0.65rem;
  margin-bottom: 0.65rem;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--input-bg);
  color: var(--text);
  font: inherit;
}

.channel-opts { margin-bottom: 0.5rem; }

.tabs {
  display: flex;
  gap: 0.3rem;
  margin-bottom: 0.65rem;
  padding: 0.2rem;
  background: var(--bg);
  border-radius: 8px;
}
.tab {
  flex: 1;
  padding: 0.4rem 0.5rem;
  border: none;
  border-radius: 6px;
  background: transparent;
  color: var(--muted);
  font: inherit;
  font-size: 0.85rem;
  font-weight: 500;
  cursor: pointer;
}
.tab.active {
  background: var(--surface);
  color: var(--text);
  box-shadow: var(--shadow);
}
.pane.hidden { display: none; }

#urlInput {
  width: 100%;
  min-height: 160px;
  padding: 0.55rem;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--input-bg);
  color: var(--text);
  font: inherit;
  resize: vertical;
}

.dropzone {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.25rem;
  padding: 2rem 1rem;
  border: 1.5px dashed var(--border);
  border-radius: 10px;
  cursor: pointer;
  text-align: center;
  min-height: 140px;
  justify-content: center;
}
.dropzone:hover,
.dropzone.dragover {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 5%, transparent);
}
.dropzone input[type="file"] {
  position: absolute;
  width: 0;
  height: 0;
  opacity: 0;
}
.drop-title { font-weight: 500; }
.drop-hint { font-size: 0.8rem; color: var(--muted); }

.file-list li {
  padding: 0.2rem 0;
  line-height: 1.35;
  word-break: break-all;
}

.file-list li.queue-summary {
  font-weight: 500;
  color: var(--text);
  padding-bottom: 0.35rem;
  margin-bottom: 0.2rem;
  border-bottom: 1px solid var(--border);
}

.file-list li.queue-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.3rem;
  min-height: 108px;
  padding: 0.85rem 1rem;
  text-align: center;
  color: var(--muted);
  list-style: none;
}

.queue-empty-icon {
  width: 2.25rem;
  height: 2.25rem;
  border: 2px dashed var(--border);
  border-radius: 8px;
  opacity: 0.85;
}

.queue-empty-msg {
  font-size: 0.84rem;
  color: var(--text);
  font-weight: 500;
}

.queue-empty-hint {
  font-size: 0.78rem;
  line-height: 1.4;
  max-width: 18rem;
}
.muted { color: var(--muted); }

/* —— Nhóm Video dài / Hiệu ứng (căn đều, trung tính) —— */
.settings-folds {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  width: 100%;
}

.fold-card {
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--surface);
  box-shadow: var(--shadow);
  overflow: hidden;
}

.fold-card > summary {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin: 0;
  padding: 0.65rem 0.85rem;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  color: var(--text);
  cursor: pointer;
  list-style: none;
  user-select: none;
  background: var(--bg);
  border-bottom: 1px solid var(--border);
  transition: background 0.15s;
}

.fold-card > summary::-webkit-details-marker,
.fold-card > summary::marker {
  display: none;
  content: '';
}

.fold-card > summary::before {
  content: '';
  flex-shrink: 0;
  width: 0.45rem;
  height: 0.45rem;
  margin-right: 0.1rem;
  border-right: 2px solid var(--muted);
  border-bottom: 2px solid var(--muted);
  transform: rotate(-45deg);
  transition: transform 0.15s ease;
}

.fold-card[open] > summary::before {
  transform: rotate(45deg);
}

.fold-card > summary:hover {
  background: color-mix(in srgb, var(--text) 4%, var(--bg));
}

.fold-body {
  padding: 0.65rem 0.85rem 0.85rem;
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}

.fold-body .checks {
  margin: 0;
}

.fold-body .opts {
  margin: 0;
}

.long-video-fields {
  margin: 0;
}

.long-video-sliders {
  display: flex;
  flex-direction: column;
  gap: 0.28rem;
  margin-top: 0.2rem;
}

.long-video-sliders .set-flex-slider {
  display: grid;
  grid-template-columns: minmax(5.2rem, 6.6rem) minmax(0, 1fr);
  align-items: center;
  column-gap: 0.4rem;
}

.long-video-sliders .set-flex-label {
  font-size: 0.65rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.03em;
  line-height: 1.2;
  grid-column: 1;
  grid-row: 1;
}

.long-video-sliders .set-flex-row {
  display: flex;
  align-items: center;
  gap: 0.3rem;
  flex-wrap: nowrap;
  min-width: 0;
  grid-column: 2;
  grid-row: 1;
}

.long-video-sliders .set-flex-range {
  flex: 1 1 auto;
  min-width: 2.5rem;
  height: 1.15rem;
  max-width: 100%;
  accent-color: var(--accent);
}

.long-video-sliders .set-flex-slider[data-flex-field="longVideoPartSeconds"] .set-flex-out,
.long-video-sliders .set-flex-slider[data-flex-field="longVideoMaxParts"] .set-flex-out {
  display: none;
}

.long-video-sliders .set-flex-out {
  min-width: 3.2rem;
  font-size: 0.72rem;
  color: var(--muted);
  text-align: right;
  flex: 0 0 auto;
}

.long-video-sliders .set-flex-reset {
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--surface);
  color: var(--muted);
  padding: 0.14rem 0.3rem;
  cursor: pointer;
  font-size: 0.78rem;
  flex: 0 0 auto;
  line-height: 1;
}

.long-video-sliders .set-flex-reset:hover:not(:disabled) {
  border-color: var(--accent);
  color: var(--accent);
}

.long-video-fields .check-row {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.82rem;
  margin: 0;
  cursor: pointer;
}

.field-hint {
  margin: 0.5rem 0 0;
  font-size: 0.8rem;
  color: var(--muted);
  line-height: 1.4;
}

.opt .field-hint {
  display: block;
  margin: 0.2rem 0 0;
  font-size: 0.78rem;
  line-height: 1.35;
  font-weight: normal;
}

.job-parts {
  font-size: 0.72rem;
  color: var(--muted);
}

.opts {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.5rem;
}
.opts-2 { grid-template-columns: 1fr 1fr; }

.opt {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}
.opt span {
  font-size: 0.7rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.opt input,
.opt select {
  padding: 0.45rem 0.5rem;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--input-bg);
  color: var(--text);
  font: inherit;
}

.checks {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem 1rem;
  margin: 0.6rem 0;
  font-size: 0.85rem;
}
.checks label {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  cursor: pointer;
}

.fx-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.4rem 0.75rem;
}

.btn {
  border: none;
  border-radius: 8px;
  padding: 0.55rem 1rem;
  font: inherit;
  font-weight: 500;
  cursor: pointer;
  white-space: nowrap;
}
.btn-sm { padding: 0.35rem 0.75rem; font-size: 0.8rem; }
.btn.primary { background: var(--accent); color: #fff; }
.btn.primary:hover:not(:disabled) { background: var(--accent-hover); }
.btn.secondary {
  background: var(--surface);
  color: var(--accent);
  border: 1px solid var(--accent);
}
.btn.secondary:hover:not(:disabled) {
  background: color-mix(in srgb, var(--accent) 8%, transparent);
}
.btn.ghost {
  background: transparent;
  color: var(--accent);
  border: 1px solid var(--border);
  padding: 0.3rem 0.6rem;
  font-size: 0.78rem;
}
.btn.ghost:hover { border-color: var(--accent); }
.btn.block { width: 100%; margin-top: 0.75rem; }
.btn:disabled { opacity: 0.5; cursor: not-allowed; }

/* —— Kết quả —— */
.results-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem 0.75rem;
  margin-bottom: 0.65rem;
}
.results-head .panel-title { margin: 0; flex: 1; min-width: 80px; }
.results-head .status { margin: 0; font-size: 0.82rem; flex: 2; min-width: 160px; }

.jobs-list {
  list-style: none;
  margin: 0;
  padding: 0;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  scrollbar-gutter: stable;
}

.jobs-list li {
  display: grid;
  grid-template-columns: 2.35rem minmax(0, 1fr) auto auto;
  gap: 0.45rem 0.5rem;
  align-items: center;
  padding: 0.55rem 0.65rem 0.55rem 0.5rem;
  border-bottom: 1px solid var(--border);
  font-size: 0.82rem;
}

.job-index {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 2.35rem;
  height: 1.65rem;
  font-size: 0.75rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--muted);
  background: color-mix(in srgb, var(--border) 55%, transparent);
  border-radius: 6px;
  flex-shrink: 0;
}

.job-info {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.1rem;
}

.job-actions {
  display: flex;
  gap: 0.3rem;
  flex-shrink: 0;
}
.jobs-list li:last-child { border-bottom: none; }

.jobs-list li.jobs-summary {
  display: block;
  grid-column: 1 / -1;
  padding: 0.45rem 0.7rem;
  font-size: 0.78rem;
  line-height: 1.4;
  font-weight: 500;
  color: var(--text);
  border-bottom: 1px solid var(--border);
  background: color-mix(in srgb, var(--accent) 6%, var(--log-bg));
}

.jobs-list li.jobs-empty,
.jobs-list > li:not(:has(.job-index)):not(.jobs-summary) {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 4.5rem;
  grid-column: 1 / -1;
  grid-template-columns: none;
  text-align: center;
  white-space: normal;
  word-break: normal;
  writing-mode: horizontal-tb;
  border-bottom: none;
}

.job-name {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
}

.badge {
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  padding: 0.15rem 0.45rem;
  border-radius: 4px;
  flex-shrink: 0;
  white-space: nowrap;
  writing-mode: horizontal-tb;
}
.jobs-list li.job-row-done {
  opacity: 0.72;
}
.jobs-list li.job-row-done .job-index {
  color: var(--ok);
  background: color-mix(in srgb, var(--ok) 12%, transparent);
}
.jobs-list li.job-row-running {
  background: color-mix(in srgb, var(--run) 8%, transparent);
  opacity: 1;
}
.jobs-list li.job-row-running .job-index {
  color: var(--run);
  background: color-mix(in srgb, var(--run) 18%, transparent);
}
.jobs-list li.job-row-queued {
  opacity: 1;
}
.jobs-list li.job-row-queued .badge.queued {
  font-weight: 600;
}

.badge.done { background: color-mix(in srgb, var(--ok) 15%, transparent); color: var(--ok); }
.badge.error { background: color-mix(in srgb, var(--err) 15%, transparent); color: var(--err); }
.badge.running { background: color-mix(in srgb, var(--run) 15%, transparent); color: var(--run); min-width: 2.5rem; text-align: center; }
.badge.queued { background: var(--border); color: var(--muted); }
.badge.fetching { background: color-mix(in srgb, var(--run) 12%, transparent); color: var(--run); min-width: 2.5rem; text-align: center; font-weight: 600; }
.jobs-list li.job-row-fetching { opacity: 1; }
.jobs-list li.job-row-fetching .job-index {
  color: var(--run);
  background: color-mix(in srgb, var(--run) 14%, transparent);
}
.badge.paused { background: color-mix(in srgb, var(--warn, #c90) 12%, transparent); color: var(--warn, #b8860b); font-style: italic; }
.badge.cancelled { background: var(--border); color: var(--muted); font-style: italic; }

.job-actions .job-ctrl {
  font-size: 0.72rem;
  padding: 0.2rem 0.45rem;
}
.job-actions .job-ctrl.danger {
  color: var(--err);
}

/* Log gập: một khung, cao theo nội dung (chỉ giới hạn khi log dài) */
.log-fold {
  flex: 0 0 auto;
  margin: 0;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--log-bg);
  overflow: hidden;
}

.log-fold[open] {
  flex: 0 1 auto;
  min-height: 0;
  max-height: min(34vh, 16rem);
  display: flex;
  flex-direction: column;
}

.log-fold > summary {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  margin: 0;
  padding: 0.4rem 0.65rem;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--muted);
  cursor: pointer;
  list-style: none;
  user-select: none;
  background: transparent;
  border: none;
  box-shadow: none;
}

.log-fold > summary::-webkit-details-marker,
.log-fold > summary::marker {
  display: none;
  content: '';
}

.log-fold > summary::before {
  content: '';
  flex-shrink: 0;
  width: 0.4rem;
  height: 0.4rem;
  border-right: 2px solid var(--muted);
  border-bottom: 2px solid var(--muted);
  transform: rotate(-45deg);
  transition: transform 0.15s ease;
}

.log-fold[open] > summary::before {
  transform: rotate(45deg);
}

.log-fold[open] > summary {
  color: var(--text);
  border-bottom: 1px solid var(--border);
}

.log-fold > summary:hover {
  color: var(--text);
}

.log-fold summary.log-summary-live {
  color: var(--text);
}

.log-fold summary.log-summary-live::after {
  content: ' ●';
  color: var(--run);
  font-size: 0.65em;
  vertical-align: super;
}

.log-fold > .log {
  flex: 1 1 auto;
  margin: 0;
  padding: 0.45rem 0.65rem;
  min-height: 0;
  max-height: min(28vh, 13rem);
  overflow: auto;
  white-space: pre-wrap;
  word-break: break-word;
  font-size: 0.72rem;
  line-height: 1.45;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  color: var(--text);
  background: transparent;
  border: none;
  border-radius: 0;
  box-shadow: none;
}
.modal {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}
.modal.hidden { display: none; }
.modal-backdrop {
  position: absolute;
  inset: 0;
  z-index: 0;
  background: rgba(0, 0, 0, 0.55);
}
.modal-box {
  position: relative;
  z-index: 1;
  width: min(420px, 100%);
  max-height: 90vh;
  background: var(--surface);
  border-radius: 12px;
  border: 1px solid var(--border);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  pointer-events: auto;
}
.modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  padding: 0.5rem 0.65rem;
  border-bottom: 1px solid var(--border);
}
.modal-title {
  font-size: 0.82rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.modal-box video {
  display: block;
  width: 100%;
  max-height: calc(90vh - 120px);
  background: #000;
  flex: 1 1 auto;
  min-height: 0;
}

.preview-controls {
  padding: 0.45rem 0.65rem 0.55rem;
  border-top: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  flex-shrink: 0;
}

.preview-seek {
  width: 100%;
  margin: 0;
  accent-color: var(--accent);
  height: 1.2rem;
  cursor: pointer;
  touch-action: pan-x;
}

.preview-controls-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.preview-play-btn {
  flex: 0 0 auto;
  width: 2rem;
  height: 2rem;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--surface);
  color: var(--text);
  font-size: 0.85rem;
  line-height: 1;
  cursor: pointer;
}

.preview-play-btn:hover {
  border-color: var(--accent);
  color: var(--accent);
}

.preview-time {
  font-size: 0.78rem;
  font-variant-numeric: tabular-nums;
  color: var(--muted);
}

.render-auth-body {
  padding: 0.85rem 1rem 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.render-auth-lead {
  margin: 0;
  font-size: 0.82rem;
  line-height: 1.45;
  color: var(--muted);
}

.render-auth-lead a {
  color: var(--accent);
  text-decoration: none;
}

.render-auth-lead a:hover { text-decoration: underline; }

.render-auth-field {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  font-size: 0.78rem;
  color: var(--muted);
}

.render-auth-field input {
  width: 100%;
  padding: 0.5rem 0.65rem;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: var(--bg);
  color: var(--text);
  font-size: 0.9rem;
}

.render-auth-actions {
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.render-auth-body .msg-error {
  margin: 0;
  font-size: 0.8rem;
  color: #c62828;
}

.log {
  padding: 0.5rem;
  overflow: auto;
  font-size: 0.72rem;
  line-height: 1.35;
  white-space: pre-wrap;
  background: var(--log-bg);
  border: 1px solid var(--border);
  border-radius: 6px;
}

/* —— Mobile / màn hẹp —— */
@media (max-width: 1024px) {
  .grid-wide {
    align-items: start;
  }
  .panel {
    height: auto;
    min-height: 0;
  }
  /* iPad/medium: đảm bảo khung job có chiều cao tối thiểu (không bị co về 0). */
  .col-results .results-jobs-panel {
    min-height: 12rem;
  }
  .results-jobs-box {
    min-height: 10rem;
  }
}

@media (max-width: 640px) {
  .wrap {
    padding: 0.65rem 0.75rem 1.25rem;
  }

  .top {
    margin-bottom: 0.75rem;
    padding-bottom: 0.55rem;
  }

  .top h1 {
    font-size: 1.1rem;
  }

  .sub {
    font-size: 0.8rem;
  }

  .top-admin-link {
    width: 36px;
    height: 36px;
    padding: 0;
    justify-content: center;
    font-size: 0.78rem;
  }

  .top-admin-link-text {
    display: none;
  }

  .panel {
    padding: 0.75rem 0.85rem;
  }

  .tabs {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }

  .tabs::-webkit-scrollbar {
    display: none;
  }

  .tab {
    flex: 0 0 auto;
    min-width: 4.5rem;
    padding: 0.4rem 0.65rem;
    font-size: 0.8rem;
  }

  #urlInput {
    min-height: 120px;
  }

  .batch-run-opts {
    flex-direction: column;
    align-items: stretch;
    gap: 0.45rem;
  }

  .batch-run-opts .opt {
    width: 100%;
  }

  .opts-2,
  .fx-grid {
    grid-template-columns: 1fr;
  }

  .colorfx-options .fx-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .col-settings .settings-folds {
    flex: 0 0 auto;
    min-height: 0;
    overflow: visible;
  }

  .settings-folds .fold-card:not([open]) {
    flex: 0 0 auto;
  }

  .settings-folds .fold-card[open] {
    flex: 0 1 auto;
  }

  .fold-card > summary {
    padding: 0.5rem 0.65rem;
    font-size: 0.8rem;
  }

  .fold-body {
    padding: 0.5rem 0.65rem 0.65rem;
  }

  .music-file-row {
    flex-wrap: wrap;
  }

  .col-results.panel {
    min-height: 0;
    overflow: visible;
  }

  .results-stack {
    flex: 1 1 auto;
    min-height: 0;
    overflow: visible;
  }

  .col-results .results-jobs-panel {
    flex: 1 1 auto;
    min-height: 10rem;
    max-height: none;
  }

  .results-jobs-box {
    min-height: 9rem;
    max-height: min(52vh, 28rem);
  }

  .results-jobs-box .jobs-list {
    max-height: min(50vh, 26rem);
  }

  .results-head {
    gap: 0.35rem 0.5rem;
  }

  .results-head .status {
    flex: 1 1 100%;
    min-width: 0;
    font-size: 0.78rem;
  }

  .results-head .btn-sm {
    flex-shrink: 0;
  }

  .jobs-list li.job-row {
    grid-template-columns: 2rem minmax(0, 1fr) auto;
    grid-template-areas:
      "idx info badge"
      "idx actions actions";
    gap: 0.3rem 0.4rem;
    align-items: start;
    padding: 0.5rem 0.45rem 0.5rem 0.4rem;
    font-size: 0.78rem;
  }

  .jobs-list li.job-row:not(:has(.job-actions)) {
    grid-template-areas: "idx info badge";
  }

  .jobs-list li.job-row .job-index {
    grid-area: idx;
    min-width: 2rem;
    width: 2rem;
    height: 1.5rem;
    font-size: 0.7rem;
  }

  .jobs-list li.job-row .job-info {
    grid-area: info;
  }

  .jobs-list li.job-row .badge {
    grid-area: badge;
    align-self: start;
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    font-size: 0.65rem;
    padding: 0.12rem 0.35rem;
  }

  .jobs-list li.job-row .job-actions {
    grid-area: actions;
    flex-wrap: wrap;
    width: 100%;
    gap: 0.25rem;
  }

  .job-actions .btn.ghost {
    padding: 0.22rem 0.4rem;
    font-size: 0.7rem;
  }

  .job-name {
    white-space: normal;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    line-height: 1.3;
  }

  .job-parts {
    font-size: 0.68rem;
  }

  .log-fold[open] {
    max-height: min(38vh, 14rem);
  }

  .log-fold > .log {
    max-height: min(32vh, 11rem);
  }

  .modal {
    padding: 0.5rem;
  }
}
