:root {
  --bg-0: #0c0d11;
  --bg-1: #141821;
  --bg-2: #1c222d;
  --panel: #1f2530;
  --panel-2: #252c38;
  --stroke: #2c3442;
  --text: #d6dbe6;
  --muted: #8b93a5;
  --accent: #5ff0be;
  --accent-soft: rgba(95, 240, 190, 0.25);
  --blue: #5ff0be;
  --red: #ff5c7a;
  --fader-track: #0f131b;
  --fader-border: #242b36;
  --fader-thumb-border: #1a1f2a;
  --header-height: 88px;
  --transport-shell-bg-1: #1f2531;
  --transport-shell-bg-2: #171c25;
  --transport-shell-border: #313a4a;
  --transport-btn-bg-1: #2a3240;
  --transport-btn-bg-2: #1b212c;
  --transport-btn-border: #3a4354;
  --transport-btn-text: #dfe5f2;
  --transport-btn-hover-border: #55607a;
  --transport-btn-hover-ring: rgba(90, 104, 130, 0.28);
  --transport-play-bg-1: var(--transport-btn-bg-1);
  --transport-play-bg-2: var(--transport-btn-bg-2);
  --transport-play-border: #5ff0be;
  --transport-play-text: var(--transport-btn-text);
  --transport-play-ring: rgba(95, 240, 190, 0.34);
  --transport-record-color: #ff4f64;
  --transport-icon-filter: invert(1);
  --transport-disabled-bg-1: #252b37;
  --transport-disabled-bg-2: #1b2029;
  --transport-disabled-border: #394152;
  --transport-icon-btn-size: 40px;
  --transport-icon-btn-radius: 9px;
  --transport-shell-height: 56px;
  --timeline-shell-bg-1: #1b2230;
  --timeline-shell-bg-2: #121824;
  --timeline-shell-border: #313a4a;
  --timeline-block-bg-1: #2a3447;
  --timeline-block-bg-2: #1a2436;
  --timeline-block-border: #3f4f6c;
  --timeline-block-active-border: #5ff0be;
  --timeline-block-active-glow: rgba(95, 240, 190, 0.22);
  --timeline-cursor: #5ff0be;
  --timeline-bar-a: rgba(236, 243, 255, 0.42);
  --timeline-bar-b: rgba(236, 243, 255, 0.09);
  --timeline-grid-major: rgba(236, 243, 255, 0.2);
  --timeline-grid-minor: rgba(236, 243, 255, 0.08);
  --timeline-grid-major-width: 1px;
  --timeline-grid-minor-width: 1px;
  --vislab-logo-color: rgba(95, 240, 190, 0.94);
  --vislab-logo-glow: rgba(95, 240, 190, 0.32);
  --queue-lane-height: 54px;
  --queue-lane-pad-top: 6px;
  --queue-lane-pad-bottom: 2px;
  --queue-lane-pad-x: 2px;
  --queue-lane-border-top: 1px;
}

* {
  box-sizing: border-box;
}

html,
body {
  height: 100%;
}

body {
  margin: 0;
  font-family: "Rajdhani", "Arial", sans-serif;
  background: radial-gradient(circle at top, #1a1f2a 0%, #0d0f14 50%, #090a0d 100%);
  color: var(--text);
  overflow: hidden;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  background-image:
    linear-gradient(120deg, rgba(255, 255, 255, 0.04) 0%, rgba(255, 255, 255, 0) 60%),
    repeating-linear-gradient(90deg, rgba(255, 255, 255, 0.04) 0 1px, transparent 1px 12px);
  opacity: 0.3;
  pointer-events: none;
}

.vislab-loader {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-0);
  color: var(--text);
  font-family: "Orbitron", "Rajdhani", "Arial", sans-serif;
  font-size: 13px;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  opacity: 1;
  transition: opacity 0.35s ease, visibility 0.35s ease;
}

.vislab-loader-inner {
  display: grid;
  justify-items: center;
  gap: 18px;
}

.vislab-loader-visual-frame {
  width: auto;
  height: auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 0;
  overflow: visible;
  clip-path: none;
  background: transparent;
  border: 0;
  box-shadow: none;
}

.vislab-loader-visual {
  width: min(220px, 34vw);
  height: min(220px, 34vw);
  display: block;
  border-radius: 22px;
  clip-path: inset(0 round 22px);
  filter: drop-shadow(0 0 26px rgba(95, 240, 190, 0.22));
}

body[data-theme="studio"] .vislab-loader-visual-frame {
  background: transparent;
  background-image: none;
  border: 0;
  box-shadow: none;
}

body[data-theme="studio"] .vislab-header-logo-frame {
  background: transparent;
  background-image: none;
  border: 0;
  box-shadow: none;
}

.vislab-loader-label {
  display: block;
}

.vislab-loader.is-hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.vislab-notifications {
  position: fixed;
  top: 18px;
  right: 18px;
  z-index: 10020;
  display: grid;
  gap: 10px;
  width: min(420px, calc(100vw - 24px));
  pointer-events: none;
}

.vislab-notice {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: 10px;
  padding: 12px 14px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-left-width: 4px;
  border-radius: 14px;
  background: rgba(10, 14, 20, 0.94);
  color: #eef2fb;
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.35);
  backdrop-filter: blur(12px);
  transform: translateY(-8px);
  opacity: 0;
  transition: opacity 0.18s ease, transform 0.18s ease;
  pointer-events: auto;
}

.vislab-notice.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.vislab-notice.is-leaving {
  opacity: 0;
  transform: translateY(-8px);
}

.vislab-notice--info {
  border-left-color: #4bb6ff;
}

.vislab-notice--success {
  border-left-color: #57d68d;
}

.vislab-notice--error {
  border-left-color: #ff5c7a;
}

.vislab-notice-body {
  min-width: 0;
  font-size: 14px;
  line-height: 1.35;
  letter-spacing: 0.01em;
}

.vislab-notice-close {
  appearance: none;
  border: 0;
  background: transparent;
  color: inherit;
  width: 24px;
  height: 24px;
  padding: 0;
  font: inherit;
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  opacity: 0.72;
}

.vislab-notice-close:hover {
  opacity: 1;
}

body[data-theme="light"] .vislab-loader {
  background: #f4f6fb;
  color: #11141b;
}

body[data-theme="dark"] {
  --panel: #171c24;
  --panel-2: #1b202a;
  --stroke: #242b36;
  --text: #e1e6f2;
  --muted: #9aa2b6;
  --fader-track: #0f131b;
  --fader-border: #1f2530;
  --fader-thumb-border: #1a1f2a;
  --transport-shell-bg-1: #171c25;
  --transport-shell-bg-2: #11161e;
  --transport-shell-border: #2a3240;
  --transport-btn-bg-1: #232b39;
  --transport-btn-bg-2: #171d27;
  --transport-btn-border: #313a4a;
  --transport-btn-text: #dfe5f2;
  --transport-btn-hover-border: #4f5b73;
  --transport-btn-hover-ring: rgba(83, 97, 123, 0.3);
  --transport-disabled-bg-1: #202733;
  --transport-disabled-bg-2: #161b24;
  --transport-disabled-border: #30394a;
  background: radial-gradient(circle at top, #10131a 0%, #07090d 55%, #040507 100%);
}

body[data-theme="dark"] .vislab-header {
  background: linear-gradient(180deg, #151821, #0f1218);
  border-color: #242b36;
}

body[data-theme="dark"] .hero {
  background: linear-gradient(160deg, rgba(20, 24, 32, 0.96), rgba(7, 9, 12, 0.98));
}

body[data-theme="dark"] .controls-shell {
  background: #171c24;
}

body[data-theme="dark"] .tab-buttons {
  background: #0f131b;
  border-color: #232a36;
}

body[data-theme="dark"] .control {
  background: #11151c;
}

body[data-theme="dark"] select,
body[data-theme="dark"] input[type="url"],
body[data-theme="dark"] input[type="number"],
body[data-theme="dark"] textarea {
  background: #0b0f15;
  border-color: #1f2530;
}

body[data-theme="dark"] .sound-canvas {
  background: #0a0c12;
  border-color: #1b212c;
}

body[data-theme="dark"] .canvas-actions {
  background: #0f1218;
}

body[data-theme="dark"] .theme-toggle {
  background: rgba(9, 11, 15, 0.85);
  border-color: rgba(95, 240, 190, 0.35);
}

body[data-theme="dark"] .lang-select {
  background: #0b0f15;
  border-color: #1f2530;
}

body[data-theme="light"] {
  --panel: #f2f4f8;
  --panel-2: #e7ecf3;
  --stroke: #c7cfdb;
  --text: #11141b;
  --muted: #495161;
  --fader-track: #d8dee8;
  --fader-border: #c7cfdb;
  --fader-thumb-border: #e7ecf3;
  --transport-shell-bg-1: #dbe0e7;
  --transport-shell-bg-2: #c7ced7;
  --transport-shell-border: #aab2bf;
  --transport-btn-bg-1: #f4f6f9;
  --transport-btn-bg-2: #d6dde6;
  --transport-btn-border: #9ea8b8;
  --transport-btn-text: #27303e;
  --transport-btn-hover-border: #79859a;
  --transport-btn-hover-ring: rgba(62, 79, 108, 0.18);
  --transport-play-bg-1: var(--transport-btn-bg-1);
  --transport-play-bg-2: var(--transport-btn-bg-2);
  --transport-play-border: #5ff0be;
  --transport-play-text: var(--transport-btn-text);
  --transport-play-ring: rgba(95, 240, 190, 0.35);
  --transport-record-color: #d93030;
  --transport-icon-filter: invert(0);
  --transport-disabled-bg-1: #eceff3;
  --transport-disabled-bg-2: #d8dee7;
  --transport-disabled-border: #abb4c2;
  --timeline-shell-bg-1: #dde3eb;
  --timeline-shell-bg-2: #cdd4de;
  --timeline-shell-border: #a8b1be;
  --timeline-block-bg-1: #f3f6fb;
  --timeline-block-bg-2: #dce3ed;
  --timeline-block-border: #97a5b8;
  --timeline-block-active-border: #5ff0be;
  --timeline-block-active-glow: rgba(95, 240, 190, 0.2);
  --timeline-cursor: #5ff0be;
  --timeline-bar-a: rgba(39, 55, 84, 0.35);
  --timeline-bar-b: rgba(39, 55, 84, 0.08);
  --timeline-grid-major: rgba(29, 43, 69, 0.28);
  --timeline-grid-minor: rgba(29, 43, 69, 0.12);
  --timeline-grid-major-width: 1px;
  --timeline-grid-minor-width: 1px;
  background: radial-gradient(circle at top, #f9fafc 0%, #e8edf4 55%, #d9dee8 100%);
}

body[data-theme="light"]::before {
  opacity: 0.18;
}

body[data-theme="light"] .vislab-header {
  background: linear-gradient(180deg, #f8f9fb, #e8edf5);
  border-color: #c7cfdb;
}

body[data-theme="light"] .hero {
  background: linear-gradient(160deg, rgba(255, 255, 255, 0.96), rgba(230, 235, 243, 0.96));
}

body[data-theme="light"] .controls-shell {
  background: #e9eef6;
}

body[data-theme="light"] .tab-buttons {
  background: rgba(16, 19, 27, 0.06);
  border-color: rgba(16, 19, 27, 0.15);
}

body[data-theme="light"] .tab-btn.active {
  color: #11141b;
  background: var(--accent-soft);
  border-color: rgba(95, 240, 190, 0.6);
  box-shadow: 0 0 10px rgba(95, 240, 190, 0.18);
}

body[data-theme="light"] .control {
  background: #f7f9fc;
  border-color: #c7cfdb;
  color: #4c5567;
}

body[data-theme="light"] .header-label,
body[data-theme="light"] .mode-label {
  color: #5b6476;
}

body[data-theme="light"] select,
body[data-theme="light"] input[type="url"],
body[data-theme="light"] input[type="number"],
body[data-theme="light"] textarea {
  background: #ffffff;
  border-color: #c7cfdb;
  color: #11141b;
}

body[data-theme="light"] .sound-canvas {
  background: #f1f3f8;
  border-color: #c7cfdb;
}

body[data-theme="light"] .canvas-actions {
  background: #eef2f8;
  border-color: #c7cfdb;
}

body[data-theme="light"] .btn {
  background: linear-gradient(180deg, #f7f8fb 0%, #e3e8f1 100%);
  border-color: #c1c9d6;
  color: #11141b;
}

body[data-theme="light"] .btn.secondary {
  background: linear-gradient(180deg, #f9fafc 0%, #e6ebf3 100%);
}

body[data-theme="light"] .theme-toggle {
  background: #ffffff;
  border-color: #c7cfdb;
  color: #11141b;
}

body[data-theme="light"] .theme-toggle:hover {
  border-color: var(--accent);
}

body[data-theme="light"] .lang-select {
  background: #ffffff;
  border-color: #c7cfdb;
  color: #11141b;
}

body[data-theme="light"] .header-btn {
  background: #ffffff;
  border-color: #c7cfdb;
  color: #11141b;
  box-shadow: none;
}

body[data-theme="light"] .header-btn:hover {
  color: #11141b;
  border-color: var(--accent);
  box-shadow: 0 0 8px rgba(95, 240, 190, 0.18);
}

body[data-theme="light"] .header-btn.is-active {
  color: #11141b;
  border-color: var(--accent);
  box-shadow: 0 0 8px rgba(95, 240, 190, 0.22);
}

body[data-theme="studio"] {
  --studio-radius: 10px;
  --studio-btn-depth: 2px;
  --studio-btn-bg-1: #111824;
  --studio-btn-bg-2: #0b111b;
  --studio-btn-border: #6f788a;
  --studio-btn-border-hover: #9ca6b8;
  --studio-btn-shadow: #59647a;
  --studio-btn-active-border: #5ff0be;
  --header-height: 76px;
  --panel: #0b1018;
  --panel-2: #0f1520;
  --stroke: #6f788a;
  --text: #e6ebf5;
  --muted: #9ba6ba;
  --accent: #5ff0be;
  --accent-soft: rgba(95, 240, 190, 0.24);
  --blue: #5ff0be;
  --red: #ff5f74;
  --fader-track: #090d14;
  --fader-border: #667084;
  --fader-thumb-border: #aeb8cb;
  --transport-shell-bg-1: #0b1018;
  --transport-shell-bg-2: #090d14;
  --transport-shell-border: #667084;
  --transport-btn-bg-1: #111824;
  --transport-btn-bg-2: #0b111b;
  --transport-btn-border: #667084;
  --transport-btn-text: #e6ebf5;
  --transport-btn-hover-border: #97a2b7;
  --transport-btn-hover-ring: rgba(95, 240, 190, 0.26);
  --transport-play-bg-1: #111824;
  --transport-play-bg-2: #0b111b;
  --transport-play-border: #5ff0be;
  --transport-play-text: #e6ebf5;
  --transport-play-ring: rgba(95, 240, 190, 0.3);
  --transport-record-color: #ff5f74;
  --transport-disabled-bg-1: #101620;
  --transport-disabled-bg-2: #0b1018;
  --transport-disabled-border: #5d6677;
  --transport-icon-filter: invert(1);
  --timeline-shell-bg-1: #0c121c;
  --timeline-shell-bg-2: #090f17;
  --timeline-shell-border: #667084;
  --timeline-block-bg-1: #121b28;
  --timeline-block-bg-2: #0c1420;
  --timeline-block-border: #5f6d85;
  --timeline-block-active-border: #5ff0be;
  --timeline-block-active-glow: rgba(95, 240, 190, 0.24);
  --timeline-cursor: #5ff0be;
  --timeline-bar-a: rgba(206, 215, 231, 0.28);
  --timeline-bar-b: rgba(206, 215, 231, 0.08);
  --timeline-grid-major: rgba(150, 160, 178, 0.54);
  --timeline-grid-minor: rgba(206, 215, 231, 0.1);
  --timeline-grid-major-width: 1px;
  --timeline-grid-minor-width: 0.5px;
  background: radial-gradient(circle at top, #111824 0%, #090e15 56%, #06090f 100%);
}

body[data-theme="studio"]::before {
  opacity: 0;
  background: none;
}

body[data-theme="studio"] .vislab-loader {
  background: radial-gradient(circle at top, #111824 0%, #090e15 56%, #06090f 100%);
  color: #e8edf6;
}

body[data-theme="studio"] .vislab-header {
  background: #0b1018;
  border: 0;
  border-radius: var(--studio-radius);
  box-shadow: none;
}

body[data-theme="studio"] .hero {
  gap: 10px;
  padding: 4px 0 0;
  border-radius: 0;
  background: transparent;
  border: 0;
}

body[data-theme="studio"] .controls-shell {
  gap: 6px;
  padding: 2px 0;
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
}

body[data-theme="studio"] .tab-buttons {
  gap: 0;
  padding: 0;
  background: #0b1018;
  border: 1px solid #6f788a;
  border-radius: var(--studio-radius);
}

body[data-theme="studio"] .tab-btn {
  border-radius: var(--studio-radius);
  padding: 6px 8px;
  font-size: 10px;
  letter-spacing: 0.04em;
  border-color: transparent;
  background: transparent;
  box-shadow: none;
  text-transform: none;
}

body[data-theme="studio"] .tab-btn.active {
  color: #f4f7fc;
  background: transparent;
  border-color: transparent;
  box-shadow: none;
}

body[data-theme="studio"] .tab-active-frame {
  display: block;
  top: 0;
  bottom: 0;
  border-radius: var(--studio-radius);
  border-color: #5ff0be;
  background: rgba(95, 240, 190, 0.26);
  box-shadow: none;
}

body[data-theme="studio"] .control {
  background: transparent;
  border: 0;
  border-radius: 0;
  padding: 3px 0;
}

body[data-theme="studio"] select,
body[data-theme="studio"] input[type="url"],
body[data-theme="studio"] input[type="number"],
body[data-theme="studio"] textarea {
  background: #0a1018;
  border-color: #6f788a;
  border-radius: var(--studio-radius);
  padding: 6px 8px;
  color: #e6ebf5;
}

body[data-theme="studio"] .sound-canvas {
  background: #0a1018;
  border-color: #6f788a;
  border-radius: var(--studio-radius);
}

body[data-theme="studio"] .canvas-actions {
  background: transparent;
  border: 0;
  border-radius: 0;
  padding: 4px 0 0;
  gap: 6px;
  box-shadow: none;
}

body[data-theme="studio"] .canvas-shell {
  gap: 6px;
}

body[data-theme="studio"] .controls {
  gap: 6px;
}

body[data-theme="studio"] .tab-panel {
  gap: 6px;
  border: 0;
  border-radius: 0;
  background: transparent;
  padding: 2px 0;
}

body[data-theme="studio"] .tab-panel#tab-core.active {
  gap: 6px;
}

body[data-theme="studio"] .core-section {
  border: 1px solid #6f788a;
  border-radius: var(--studio-radius);
  background: transparent;
  padding: 4px;
  gap: 6px;
}

body[data-theme="studio"] .core-section-head {
  border: 0;
  border-radius: 0;
  background: transparent;
  padding: 3px 2px;
}

body[data-theme="studio"] .core-section-head:hover,
body[data-theme="studio"] .core-section-head:focus-visible {
  border-color: transparent;
  background: transparent;
}

body[data-theme="studio"] .core-custom-empty {
  border: 1px solid #6f788a;
  background: #0b111a;
}

body[data-theme="studio"] .queue-timeline-shell {
  gap: 16px;
  padding: 4px 12px 6px;
  border-radius: 0;
  border: 0;
  background: transparent;
}

body[data-theme="studio"] .queue-timeline-track {
  border: 1px solid #6f788a;
  border-radius: var(--studio-radius);
  padding: 2px 4px;
  background: #0b111a;
}

body[data-theme="studio"] .queue-timeline-lane + .queue-timeline-lane {
  border-top-color: rgba(111, 120, 138, 0.72);
}

body[data-theme="studio"] .queue-timeline-lane::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background-image:
    repeating-linear-gradient(
      90deg,
      var(--timeline-grid-major) 0 var(--timeline-grid-major-width, 1px),
      transparent var(--timeline-grid-major-width, 1px) var(--queue-grid-major-step, 24px)
    ),
    repeating-linear-gradient(
      90deg,
      var(--timeline-grid-minor) 0 var(--timeline-grid-minor-width, 1px),
      transparent var(--timeline-grid-minor-width, 1px) var(--queue-grid-minor-step, 12px)
    );
  background-repeat: repeat;
  background-position: 2px 0, 2px 0;
  background-size: auto 100%;
}

body[data-theme="studio"] .queue-timeline-lane > * {
  z-index: 1;
}

body[data-theme="studio"] .queue-timeline-lane--main > *,
body[data-theme="studio"] .queue-timeline-lane--background > * {
  position: absolute;
}

body[data-theme="studio"] .queue-timeline-lane--text > .queue-timeline-block--text {
  position: absolute !important;
  top: 0 !important;
  bottom: auto !important;
  z-index: 2;
}

body[data-theme="studio"] .queue-timeline-cursor {
  box-shadow: 0 0 10px rgba(95, 240, 190, 0.45);
}

body[data-theme="studio"] .transport-layout {
  gap: 6px;
}

body[data-theme="studio"] .transport-panel {
  min-height: 0;
  padding: 0;
  border-radius: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

body[data-theme="studio"] .transport-panel-right .transport-volume {
  margin-left: 0;
}

body[data-theme="studio"] .transport-bar {
  gap: 6px;
  padding: 0;
  border-radius: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

body[data-theme="studio"] .btn,
body[data-theme="studio"] .header-btn,
body[data-theme="studio"] .theme-toggle {
  border-radius: var(--studio-radius);
  text-transform: none;
  letter-spacing: 0.02em;
  border-color: var(--studio-btn-border);
  background: linear-gradient(180deg, var(--studio-btn-bg-1) 0%, var(--studio-btn-bg-2) 100%);
  box-shadow: var(--studio-btn-shadow) var(--studio-btn-depth) var(--studio-btn-depth) 0 0;
  color: #e6ebf5;
  transition: border-color 0.15s ease, color 0.15s ease, background 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease;
}

body[data-theme="studio"] .header-btn,
body[data-theme="studio"] .theme-toggle,
body[data-theme="studio"] .header-quality-menu-trigger,
body[data-theme="studio"] .header-controls .export-settings-menu-trigger,
body[data-theme="studio"] .header-controls .preferences-menu-trigger {
  border-radius: var(--studio-radius);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body[data-theme="studio"] .header-quality-menu-trigger-title,
body[data-theme="studio"] .export-settings-menu-trigger-label,
body[data-theme="studio"] .preferences-menu-trigger-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #e6ebf5;
}

body[data-theme="studio"] .tab-btn,
body[data-theme="studio"] .core-section,
body[data-theme="studio"] .core-section-head,
body[data-theme="studio"] .transport-input-menu-trigger {
  border-radius: var(--studio-radius);
}

body[data-theme="studio"] .header-links a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 12px;
  border-radius: var(--studio-radius);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: linear-gradient(180deg, var(--studio-btn-bg-1) 0%, var(--studio-btn-bg-2) 100%);
  border: 1px solid var(--studio-btn-border);
  color: #e6ebf5;
  box-shadow: var(--studio-btn-shadow) var(--studio-btn-depth) var(--studio-btn-depth) 0 0;
  transition: border-color 0.15s ease, color 0.15s ease, background 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease;
}

body[data-theme="studio"] .queue-timeline-toolbar .timeline-play-btn,
body[data-theme="studio"] .queue-timeline-block,
body[data-theme="studio"] .queue-timeline-preview,
body[data-theme="studio"] .queue-timeline-bars {
  border-radius: var(--studio-radius);
}

body[data-theme="studio"] .btn:not(.transport-btn):hover,
body[data-theme="studio"] .theme-toggle:hover,
body[data-theme="studio"] button:not(.transport-btn):not(.transport-input-menu-trigger):not(.transport-input-menu-item):not(.transport-input-submenu-item):not(.header-quality-menu-trigger):not(.header-quality-menu-item):not(.header-quality-submenu-item):not(.export-settings-menu-trigger):not(.preferences-menu-trigger):not(.preferences-shortcut-btn):not(.preferences-ui-scale-btn):not(.preferences-menu-reset):not(:disabled):hover,
body[data-theme="studio"] .header-btn:hover {
  border-color: var(--studio-btn-border-hover);
  box-shadow: var(--studio-btn-shadow) var(--studio-btn-depth) var(--studio-btn-depth) 0 0;
  transform: none;
}

/* Keep core section headers static on hover across themes. */
body .tab-panel#tab-core .core-section-head {
  transition: none;
}

body:not([data-theme="studio"]):not([data-theme="minimal"]) .tab-panel#tab-core .core-section-head:hover {
  border-color: transparent;
  background: rgba(255, 255, 255, 0.03);
  box-shadow: none;
  transform: none;
}

body[data-theme="studio"] .tab-panel#tab-core .core-section-head:hover {
  border-color: transparent;
  background: transparent;
  box-shadow: none;
  transform: none;
}

body[data-theme="minimal"] .tab-panel#tab-core .core-section--modes .core-section-head:hover,
body[data-theme="minimal"] .tab-panel#tab-core .core-section--background .core-section-head:hover,
body[data-theme="minimal"] .tab-panel#tab-core .core-section--custom .core-section-head:hover,
body[data-theme="minimal"] .tab-panel#tab-core .core-section--text .core-section-head:hover {
  border-color: transparent;
  background: transparent;
  box-shadow: none;
  transform: none;
}

body[data-theme="studio"] .canvas-actions .transport-bar .btn.transport-btn,
body[data-theme="studio"] .queue-timeline-toolbar .timeline-play-btn {
  border-color: var(--studio-btn-border);
  background: linear-gradient(180deg, var(--studio-btn-bg-1) 0%, var(--studio-btn-bg-2) 100%);
  box-shadow: var(--studio-btn-shadow) var(--studio-btn-depth) var(--studio-btn-depth) 0 0;
}

body[data-theme="studio"] .theme-toggle:hover,
body[data-theme="studio"] .header-btn:hover,
body[data-theme="studio"] .header-links a:hover,
body[data-theme="studio"] .header-links a[aria-current="page"] {
  border-color: var(--studio-btn-border-hover);
  color: #f3f6fc;
  box-shadow: var(--studio-btn-shadow) var(--studio-btn-depth) var(--studio-btn-depth) 0 0;
}

body[data-theme="studio"] .canvas-actions .transport-bar .btn.transport-btn:hover,
body[data-theme="studio"] .queue-timeline-toolbar .timeline-play-btn:hover {
  border-color: var(--studio-btn-border-hover);
  box-shadow: var(--studio-btn-shadow) var(--studio-btn-depth) var(--studio-btn-depth) 0 0;
  transform: none;
}

body[data-theme="studio"] .btn:active,
body[data-theme="studio"] .btn.is-active,
body[data-theme="studio"] .btn[aria-pressed="true"],
body[data-theme="studio"] .header-btn:active,
body[data-theme="studio"] .header-btn.is-active,
body[data-theme="studio"] .theme-toggle:active,
body[data-theme="studio"] .canvas-actions .transport-bar .btn.transport-btn:active,
body[data-theme="studio"] .canvas-actions .transport-bar .btn.transport-btn.is-active,
body[data-theme="studio"] .canvas-actions .transport-bar .btn.transport-btn[aria-pressed="true"],
body[data-theme="studio"] .canvas-actions .transport-bar .btn.transport-play.is-playing,
body[data-theme="studio"] .canvas-actions .transport-bar .btn.transport-record.is-recording,
body[data-theme="studio"] .queue-timeline-toolbar .timeline-play-btn:active,
body[data-theme="studio"] .queue-timeline-toolbar .timeline-play-btn.is-playing,
body[data-theme="studio"] .header-links a:active,
body[data-theme="studio"] .header-links a[aria-current="page"] {
  border-color: var(--studio-btn-active-border);
  box-shadow: 0 0 0 0;
  transform: translate(var(--studio-btn-depth), var(--studio-btn-depth));
}

body[data-theme="minimal"] {
  --panel: #000000;
  --panel-2: #000000;
  --stroke: #ffffff;
  --text: #e2e8f0;
  --muted: #c0c9d8;
  --accent: #5ff0be;
  --accent-soft: rgba(95, 240, 190, 0.16);
  --blue: #5ff0be;
  --red: #ffffff;
  --fader-track: #000000;
  --fader-border: #ffffff;
  --fader-thumb-border: #ffffff;
  --transport-shell-bg-1: #000000;
  --transport-shell-bg-2: #000000;
  --transport-shell-border: #ffffff;
  --transport-btn-bg-1: #000000;
  --transport-btn-bg-2: #000000;
  --transport-btn-border: #ffffff;
  --transport-btn-text: #e2e8f0;
  --transport-btn-hover-border: #ffffff;
  --transport-btn-hover-ring: rgba(255, 255, 255, 0.2);
  --transport-play-bg-1: #000000;
  --transport-play-bg-2: #000000;
  --transport-play-border: #5ff0be;
  --transport-play-text: #e2e8f0;
  --transport-play-ring: rgba(95, 240, 190, 0.2);
  --transport-record-color: #e2e8f0;
  --transport-disabled-bg-1: #000000;
  --transport-disabled-bg-2: #000000;
  --transport-disabled-border: #ffffff;
  --timeline-shell-bg-1: #000000;
  --timeline-shell-bg-2: #000000;
  --timeline-shell-border: #ffffff;
  --timeline-block-bg-1: #000000;
  --timeline-block-bg-2: #000000;
  --timeline-block-border: #ffffff;
  --timeline-block-active-border: #5ff0be;
  --timeline-block-active-glow: rgba(95, 240, 190, 0.2);
  --timeline-cursor: #5ff0be;
  --timeline-bar-a: rgba(255, 255, 255, 0.46);
  --timeline-bar-b: rgba(255, 255, 255, 0.12);
  font-family: "Nunito", "Rajdhani", "Arial", sans-serif;
  background: #000000;
}

body[data-theme="minimal"]::before {
  opacity: 0;
  background: none;
}

body[data-theme="minimal"] .vislab-loader {
  background: #000000;
  color: var(--text);
  letter-spacing: 0.22em;
}

body[data-theme="minimal"] .vislab-header {
  top: 12px;
  left: 24px;
  right: 24px;
  min-height: var(--header-height);
  padding: 0 16px;
  background: #000000;
  border: 2px solid #ffffff;
  border-radius: 12px;
  box-shadow: none;
}

body[data-theme="minimal"] .vislab-title {
  font-family: "Nunito", "Rajdhani", "Arial", sans-serif;
  font-size: 24px;
  font-weight: 800;
  letter-spacing: 0.02em;
}

body[data-theme="minimal"] .header-links {
  gap: 16px;
}

body[data-theme="minimal"] .header-links a {
  border: 2px solid #ffffff;
  border-radius: 10px;
  background: transparent;
  color: var(--text);
  text-transform: none;
  letter-spacing: 0.02em;
  font-size: 12px;
  font-weight: 700;
}

body[data-theme="minimal"] .header-links a:hover,
body[data-theme="minimal"] .header-links a[aria-current="page"] {
  color: var(--text);
  border-color: #ffffff;
  background: transparent;
  box-shadow: none;
  text-decoration: underline;
}

body[data-theme="minimal"] .hero {
  gap: 16px;
  background: transparent;
  border: 0;
  border-radius: 0;
  padding: 0;
  box-shadow: none;
}

body[data-theme="minimal"] .controls-shell,
body[data-theme="minimal"] .tab-buttons,
body[data-theme="minimal"] .control,
body[data-theme="minimal"] .queue-item,
body[data-theme="minimal"] .sound-canvas,
body[data-theme="minimal"] .queue-timeline-shell,
body[data-theme="minimal"] .canvas-actions {
  background: #000000;
  border: 2px solid #ffffff;
  border-radius: 10px;
  box-shadow: none;
}

body[data-theme="minimal"] .header-label,
body[data-theme="minimal"] .mode-label,
body[data-theme="minimal"] .queue-field,
body[data-theme="minimal"] .queue-index,
body[data-theme="minimal"] .queue-empty {
  color: var(--text);
}

body[data-theme="minimal"] select,
body[data-theme="minimal"] input[type="url"],
body[data-theme="minimal"] input[type="number"],
body[data-theme="minimal"] textarea {
  background: #000000;
  border: 2px solid #ffffff;
  color: var(--text);
  border-radius: 10px;
  font-weight: 700;
}

body[data-theme="minimal"] select:focus,
body[data-theme="minimal"] input[type="range"]:focus,
body[data-theme="minimal"] textarea:focus {
  outline: 2px solid #ffffff;
}

body[data-theme="minimal"] input[type="range"] {
  --range-track-height: 12px;
  --range-thumb-size: 22px;
  height: 12px;
  border: 2px solid #ffffff;
  border-radius: 999px;
  background: linear-gradient(
    90deg,
    #ffffff 0%,
    #ffffff var(--fader-fill, 50%),
    #000000 var(--fader-fill, 50%),
    #000000 100%
  );
}

body[data-theme="minimal"] input[type="range"]::-moz-range-track {
  background: #000000;
}

body[data-theme="minimal"] input[type="range"]::-moz-range-progress {
  background: #ffffff;
}

body[data-theme="minimal"] input[type="range"]::-webkit-slider-thumb {
  border-radius: 50%;
  border: 2px solid #ffffff;
  background: #000000;
  box-shadow: none;
}

body[data-theme="minimal"] input[type="range"]::-webkit-slider-thumb:active {
  background: #ffffff;
}

body[data-theme="minimal"] input[type="range"]::-moz-range-thumb {
  border-radius: 50%;
  border: 2px solid #ffffff;
  background: #000000;
}

body[data-theme="minimal"] .header-btn,
body[data-theme="minimal"] .theme-toggle,
body[data-theme="minimal"] .btn,
body[data-theme="minimal"] .tab-btn,
body[data-theme="minimal"] .exit-fullscreen {
  --minimal-border-radius: 10px;
  --minimal-border-width: 2px;
  --minimal-depth: 2px;
  appearance: none;
  position: relative;
  border: 2px solid #ffffff;
  border-radius: 10px;
  background: #000000;
  color: var(--text);
  box-shadow: #ffffff var(--minimal-depth) var(--minimal-depth) 0 0;
  text-transform: none;
  letter-spacing: 0.02em;
  z-index: 2;
}

body[data-theme="minimal"] .header-btn::before,
body[data-theme="minimal"] .theme-toggle::before,
body[data-theme="minimal"] .btn:not(.icon-only)::before,
body[data-theme="minimal"] .tab-btn::before,
body[data-theme="minimal"] .exit-fullscreen::before {
  content: none;
  display: none;
}

body[data-theme="minimal"] .header-btn,
body[data-theme="minimal"] .theme-toggle {
  font-size: 12px;
  font-weight: 700;
}

body[data-theme="minimal"] .btn:hover,
body[data-theme="minimal"] .header-btn:hover,
body[data-theme="minimal"] .theme-toggle:hover,
body[data-theme="minimal"] .tab-btn:hover {
  border-color: #ffffff;
  color: var(--text);
  box-shadow: #ffffff var(--minimal-depth) var(--minimal-depth) 0 0;
  transform: none;
}

body[data-theme="minimal"] .btn:not(.icon-only):hover::before,
body[data-theme="minimal"] .header-btn:hover::before,
body[data-theme="minimal"] .theme-toggle:hover::before,
body[data-theme="minimal"] .tab-btn:hover::before,
body[data-theme="minimal"] .exit-fullscreen:hover::before {
  display: none;
}

body[data-theme="minimal"] .transport-btn:not(.icon-only)::before,
body[data-theme="minimal"] .transport-btn:not(.icon-only):hover::before,
body[data-theme="minimal"] .transport-btn:not(.icon-only):active::before {
  display: none;
}

body[data-theme="minimal"] .transport-bar {
  border: 0;
  background: transparent;
  box-shadow: none;
}

body[data-theme="minimal"] .canvas-actions {
  border: 0;
  background: transparent;
  box-shadow: none;
}

body[data-theme="minimal"] .transport-panel {
  border: 0;
  background: transparent;
  box-shadow: none;
}

body[data-theme="minimal"] .canvas-actions .transport-panel,
body[data-theme="minimal"] .canvas-actions .transport-panel-left,
body[data-theme="minimal"] .canvas-actions .transport-panel-right {
  border: 0;
  background: transparent;
  box-shadow: none;
}

body[data-theme="minimal"] .transport-label {
  color: var(--text);
}

body[data-theme="minimal"] .canvas-actions .transport-bar .btn.transport-btn {
  border-width: 2px;
  box-shadow: #ffffff var(--minimal-depth) var(--minimal-depth) 0 0;
}

body[data-theme="minimal"] .transport-input,
body[data-theme="minimal"] .transport-volume {
  border-width: 2px;
}

body[data-theme="minimal"] .canvas-actions .transport-bar .btn.transport-btn:hover {
  box-shadow: #ffffff var(--minimal-depth) var(--minimal-depth) 0 0;
}

body[data-theme="minimal"] .canvas-actions .transport-bar .btn.transport-btn:disabled {
  opacity: 0.4;
}

body[data-theme="minimal"] .btn:active,
body[data-theme="minimal"] .btn.is-active,
body[data-theme="minimal"] .btn[aria-pressed="true"],
body[data-theme="minimal"] .tab-btn.active,
body[data-theme="minimal"] .header-btn.is-active,
body[data-theme="minimal"] .exit-fullscreen:active {
  box-shadow: 0 0 0 0;
  transform: translate(var(--minimal-depth), var(--minimal-depth));
}

body[data-theme="minimal"] .transport-btn:active,
body[data-theme="minimal"] .transport-btn.is-active,
body[data-theme="minimal"] .transport-btn[aria-pressed="true"] {
  box-shadow: 0 0 0 0;
  transform: translate(var(--minimal-depth), var(--minimal-depth));
}

/* Keep transport/canvas controls on the same "pressed" behavior as tab buttons in minimal mode. */
body[data-theme="minimal"] .canvas-actions .transport-bar .btn.transport-btn:active,
body[data-theme="minimal"] .canvas-actions .transport-bar .btn.transport-btn.is-active,
body[data-theme="minimal"] .canvas-actions .transport-bar .btn.transport-btn[aria-pressed="true"],
body[data-theme="minimal"] .canvas-actions .transport-bar .btn.transport-play.is-playing,
body[data-theme="minimal"] .canvas-actions .transport-bar .btn.transport-record.is-recording,
body[data-theme="minimal"] .queue-timeline-toolbar .timeline-play-btn:active,
body[data-theme="minimal"] .queue-timeline-toolbar .timeline-play-btn.is-playing {
  box-shadow: 0 0 0 0;
  transform: translate(var(--minimal-depth), var(--minimal-depth));
}

body[data-theme="minimal"] .canvas-overlay-actions .canvas-fullscreen-btn,
body[data-theme="minimal"] .canvas-overlay-actions .canvas-fullscreen-btn:hover,
body[data-theme="minimal"] .canvas-overlay-actions .canvas-fullscreen-btn:active {
  border: 0;
  background: transparent;
  box-shadow: none;
}

body[data-theme="minimal"] .canvas-overlay-actions .canvas-fullscreen-btn:active {
  transform: scale(0.94);
}

body[data-theme="minimal"] .btn-primary,
body[data-theme="minimal"] .btn.secondary,
body[data-theme="minimal"] .tab-btn.active {
  background: #000000;
}

body[data-theme="minimal"] .queue-remove {
  color: var(--text);
  border: 1px solid #ffffff;
}

body[data-theme="minimal"] .queue-remove:hover {
  color: var(--text);
  border-color: #ffffff;
}

body[data-theme="minimal"] .queue-timeline-shell {
  border: 0;
  background: transparent;
  box-shadow: none;
  padding-inline: 0;
}

body[data-theme="minimal"] .queue-timeline-track {
  border: 2px dashed rgba(255, 255, 255, 0.78);
  border-radius: 10px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.02)),
    repeating-linear-gradient(90deg, rgba(255, 255, 255, 0.07) 0 1px, transparent 1px 18px);
  padding: 2px 6px;
}

body[data-theme="minimal"] .queue-timeline-lane + .queue-timeline-lane {
  border-top-color: rgba(255, 255, 255, 0.62);
}

body[data-theme="minimal"] .queue-timeline-empty--text,
body[data-theme="minimal"] .queue-timeline-empty--background {
  color: var(--text);
}

body[data-theme="minimal"] .queue-timeline-empty {
  opacity: 0.86;
}

body[data-theme="minimal"] {
  --timeline-grid-major: rgba(255, 255, 255, 0.24);
  --timeline-grid-minor: rgba(255, 255, 255, 0.11);
  --timeline-grid-major-width: 1px;
  --timeline-grid-minor-width: 1px;
}

body[data-theme="minimal"] .queue-timeline-toolbar .timeline-play-btn {
  border-width: 2px;
  border-color: #ffffff;
  background: #000000;
  color: var(--text);
  box-shadow: #ffffff 4px 4px 0 0;
}

body[data-theme="minimal"] .queue-timeline-block {
  border: 1px solid rgba(255, 255, 255, 0.72);
  box-shadow: none;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.03));
}

body[data-theme="minimal"] .queue-timeline-preview {
  opacity: 0.8;
  border: 1px solid rgba(255, 255, 255, 0.45);
}

body[data-theme="minimal"] .queue-transition-slot {
  background: transparent;
}

body[data-theme="minimal"] .queue-transition-slot.has-transition,
body[data-theme="minimal"] .queue-transition-slot.is-drop-target,
body[data-theme="minimal"] .queue-transition-slot.is-selected {
  box-shadow: none;
  background: transparent;
}

body[data-theme="minimal"] .queue-transition-slot .queue-transition-hitarea {
  outline-color: rgba(255, 255, 255, 0.55);
}

body[data-theme="minimal"] .queue-transition-chip {
  border: 2px solid #ffffff;
  background: #000000;
  color: var(--text);
  font-size: 11px;
  border-radius: 4px;
}

body[data-theme="minimal"] .queue-transition-slot.is-selected .queue-transition-chip,
body[data-theme="minimal"] .queue-transition-slot.is-drop-target .queue-transition-chip {
  box-shadow: #ffffff 3px 3px 0 0;
}

body[data-theme="minimal"] .queue-transition-resize-handle {
  border-left: 1px dashed #ffffff;
}

body[data-theme="minimal"] .queue-transition-placeholder {
  color: var(--text);
  font-size: 11px;
  border: 2px dashed #ffffff;
  border-radius: 4px;
  background: #000000;
}

body[data-theme="minimal"] .queue-timeline-block:hover,
body[data-theme="minimal"] .queue-timeline-block:focus-visible,
body[data-theme="minimal"] .queue-timeline-block.is-active {
  box-shadow: none;
  border-color: #ffffff;
}

body[data-theme="minimal"] .queue-timeline-duration,
body[data-theme="minimal"] .queue-timeline-empty {
  color: var(--text);
}

body[data-theme="minimal"] .queue-clip-context-menu {
  border: 2px solid #ffffff;
  background: #000000;
  box-shadow: #ffffff 4px 4px 0 0;
  backdrop-filter: none;
}

body[data-theme="minimal"] .queue-clip-context-field,
body[data-theme="minimal"] .queue-clip-context-title {
  color: var(--text);
}

body[data-theme="minimal"] .queue-clip-context-input,
body[data-theme="minimal"] .queue-clip-context-btn {
  border: 2px solid #ffffff;
  background: #000000;
  color: var(--text);
}

body[data-theme="minimal"] .queue-clip-context-btn:hover,
body[data-theme="minimal"] .queue-clip-context-btn:focus-visible {
  box-shadow: #ffffff 3px 3px 0 0;
}

body[data-theme="minimal"] .queue-transition-picker {
  border: 2px solid #ffffff;
  background: #000000;
  box-shadow: #ffffff 4px 4px 0 0;
}

body[data-theme="minimal"] .queue-transition-picker-title {
  color: var(--text);
}

body[data-theme="minimal"] .queue-transition-picker-btn,
body[data-theme="minimal"] .queue-transition-picker-clear {
  border: 2px solid #ffffff;
  background: #000000;
  color: var(--text);
}

body[data-theme="minimal"] .queue-transition-picker-btn:hover,
body[data-theme="minimal"] .queue-transition-picker-btn:focus-visible,
body[data-theme="minimal"] .queue-transition-picker-btn.is-active,
body[data-theme="minimal"] .queue-transition-picker-clear:hover,
body[data-theme="minimal"] .queue-transition-picker-clear:focus-visible {
  box-shadow: #ffffff 3px 3px 0 0;
}

body[data-theme="minimal"] .queue-timeline-resize {
  background: repeating-linear-gradient(
    0deg,
    rgba(255, 255, 255, 0.8) 0 2px,
    transparent 2px 4px
  );
}

body[data-theme="minimal"] .queue-timeline-cursor {
  box-shadow: 0 0 0 0 rgba(255, 255, 255, 0);
}

body[data-theme="minimal"] .core-section {
  border: 2px solid #ffffff;
  background: #000000;
}

body[data-theme="minimal"] .core-section-title {
  color: var(--text);
}

body[data-theme="minimal"] .core-section-head {
  border: 2px solid #ffffff;
  background: #000000;
  color: var(--text);
}

body[data-theme="minimal"] .core-section-head:hover {
  border-color: #ffffff;
  background: #000000;
}

body[data-theme="minimal"] .core-section-chevron {
  color: var(--text);
}

body[data-theme="minimal"] .core-custom-empty {
  border: 2px solid #ffffff;
  background: #000000;
  color: var(--text);
}

body[data-theme="minimal"] .tab-buttons {
  border: 0;
  background: transparent;
  box-shadow: none;
}

body[data-theme="minimal"] .controls-shell {
  border: 0;
  background: transparent;
  box-shadow: none;
  padding: 0;
}

body[data-theme="minimal"] .core-section--modes .core-section-head,
body[data-theme="minimal"] .core-section--background .core-section-head,
body[data-theme="minimal"] .core-section--custom .core-section-head,
body[data-theme="minimal"] .core-section--text .core-section-head,
body[data-theme="minimal"] .core-section--custom .core-custom-empty {
  border: 0;
  background: transparent;
  box-shadow: none;
}

body[data-theme="minimal"] .core-tile {
  border: 2px solid #ffffff;
  background-color: #000000;
  background-image: var(--core-preview-image);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  color: var(--text);
  box-shadow: #ffffff 3px 3px 0 0;
}

body[data-theme="minimal"] .core-tile:hover,
body[data-theme="minimal"] .core-tile.is-active {
  box-shadow: #ffffff 3px 3px 0 0;
}

body[data-theme="minimal"] .core-tile--random {
  border-color: #ffffff;
}

body[data-theme="minimal"] .preview-off {
  background: rgba(0, 0, 0, 0.85);
}

body[data-theme="minimal"] .td-stream-overlay {
  background: #000000;
}

body[data-theme="minimal"] .exit-fullscreen {
  width: 38px;
  height: 38px;
  font-size: 18px;
}

body[data-theme="minimal"].tooltips-enabled [data-tooltip]::after {
  background: #000000;
  color: var(--text);
  border: 2px solid #ffffff;
  border-radius: 10px;
}

@keyframes vislab-minimal-rotate-hue {
  to {
    filter: hue-rotate(1turn);
  }
}

a {
  color: inherit;
  text-decoration: none;
}

.page {
  height: 100%;
  padding: calc(var(--header-height) + 16px) 24px 20px;
  display: flex;
}

body.legal-page {
  overflow-y: auto;
  background: radial-gradient(circle at top, #121621 0%, #0b0d13 55%, #07080b 100%);
  background-attachment: fixed;
}

.legal-main {
  padding: calc(var(--header-height) + 24px) 24px 80px;
  max-width: 960px;
  margin: 0 auto;
  display: grid;
  gap: 18px;
}

.legal-main h1 {
  margin: 0;
  font-size: clamp(32px, 4vw, 46px);
  letter-spacing: -0.01em;
}

.legal-section {
  display: grid;
  gap: 12px;
  font-size: 15px;
  color: var(--muted);
  line-height: 1.7;
}

.legal-section h2 {
  margin: 0 0 6px 0;
  font-size: 18px;
  color: var(--text);
}

.shortcut-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 6px;
}

.shortcut-list li {
  display: flex;
  align-items: center;
  gap: 10px;
}

.shortcut-list kbd {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 28px;
  padding: 4px 8px;
  border-radius: 8px;
  border: 1px solid var(--stroke);
  background: rgba(15, 19, 27, 0.7);
  color: var(--text);
  font-size: 12px;
  letter-spacing: 0.04em;
}

.vislab-header {
  position: fixed;
  top: 12px;
  left: 24px;
  right: 24px;
  min-height: var(--header-height);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 16px;
  background: linear-gradient(180deg, #202634, #171b25);
  border: 1px solid var(--stroke);
  border-radius: 12px;
  box-shadow: inset 0 0 12px rgba(0, 0, 0, 0.4);
  z-index: 4000;
  gap: 12px;
}

.vislab-title {
  font-family: "Orbitron", "Arial", sans-serif;
  letter-spacing: 2px;
  font-size: 16px;
}

.vislab-brand-mark {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
  color: inherit;
  text-decoration: none;
}

.vislab-brand-mark:visited {
  color: inherit;
}

.vislab-header-logo {
  width: 93px;
  height: 93px;
  display: block;
  flex: 0 0 auto;
  border-radius: 20px !important;
  overflow: hidden;
  clip-path: inset(0 round 20px);
  filter: drop-shadow(0 0 10px rgba(95, 240, 190, 0.26));
}

.vislab-header-logo-frame {
  width: auto;
  height: auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  overflow: visible;
  border-radius: 0;
  clip-path: none;
  background: transparent;
  box-shadow: none;
  isolation: isolate;
}

.header-brand {
  display: flex;
  align-items: center;
  gap: 12px;
  flex: 0 0 auto;
}

.header-controls {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
  row-gap: 8px;
  flex: 1 1 auto;
  min-width: 0;
}

.header-controls > .header-quality {
  order: 10;
}

.header-controls > .export-settings-menu,
.header-controls > #export-settings-menu {
  order: 11;
}

.header-controls > .preferences-menu,
.header-controls > #preferences-menu {
  order: 13;
}

.header-controls > .shortcuts-menu,
.header-controls > #shortcuts-menu {
  order: 12;
}

.header-controls > #settings-session-btn {
  order: 20;
  margin-left: 10px;
}

.header-controls > #popout-btn {
  order: 21;
}

.header-controls > [data-header-role="download-app"] {
  order: 22;
}

.header-controls > .theme-toggle {
  order: 30;
  margin-left: 10px;
}

.header-links {
  display: flex;
  align-items: center;
  gap: 8px;
}

.header-links a {
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid var(--stroke);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
  background: rgba(0, 0, 0, 0.12);
  transition: border-color 0.2s ease, color 0.2s ease, background 0.2s ease;
}

.header-links a:hover {
  color: var(--text);
  border-color: var(--accent);
  background: var(--accent-soft);
}

.header-links a[aria-current="page"] {
  color: var(--text);
  border-color: var(--accent);
  background: var(--accent-soft);
}

.header-btn {
  font-family: inherit;
  padding: 6px 12px;
  border-radius: 10px;
  border: 1px solid rgba(95, 240, 190, 0.45);
  background: rgba(15, 19, 27, 0.8);
  color: var(--text);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 11px;
  transition: border-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}

.header-btn:hover {
  border-color: var(--accent);
  color: #ffe8ff;
  box-shadow: 0 0 10px rgba(95, 240, 190, 0.25);
}

.header-btn.is-active {
  border-color: var(--accent);
  color: #eafff6;
  box-shadow: 0 0 12px rgba(95, 240, 190, 0.35);
}

@media (max-width: 1500px) {
  .header-controls > #settings-session-btn,
  .header-controls > .theme-toggle {
    margin-left: 0;
  }
}

.session-modal {
  position: fixed;
  inset: 0;
  z-index: 17000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.session-modal[hidden] {
  display: none;
}

.session-modal-backdrop {
  position: absolute;
  inset: 0;
  border: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  background: rgba(6, 9, 14, 0.72);
  backdrop-filter: blur(2px);
}

.session-modal-panel {
  position: relative;
  width: min(560px, calc(100vw - 32px));
  border: 1px solid var(--stroke);
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(21, 27, 39, 0.98), rgba(14, 19, 30, 0.98));
  box-shadow: 0 20px 48px rgba(0, 0, 0, 0.46);
  padding: 14px;
  display: grid;
  gap: 14px;
}

.session-modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.session-modal-title {
  margin: 0;
  font-size: 15px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.session-modal-close {
  min-width: 38px;
  min-height: 34px;
  line-height: 1;
  padding: 0;
}

.session-modal-body {
  display: grid;
  gap: 12px;
}

.session-export-btn {
  min-height: 42px;
}

.session-export-name-wrap {
  display: grid;
  gap: 6px;
}

.session-export-name-label {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--muted);
}

.session-export-name {
  min-height: 38px;
  border: 1px solid rgba(139, 147, 165, 0.7);
  border-radius: 10px;
  padding: 0 10px;
  background: rgba(9, 13, 21, 0.72);
  color: var(--text);
  font-family: inherit;
  font-size: 13px;
}

.session-export-name:focus-visible {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 2px rgba(95, 240, 190, 0.2);
}

.session-import-zone {
  border: 1px dashed rgba(139, 147, 165, 0.7);
  border-radius: 12px;
  padding: 14px;
  display: grid;
  gap: 8px;
  background: rgba(9, 13, 21, 0.72);
  transition: border-color 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
}

.session-import-zone:focus-visible {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 2px rgba(95, 240, 190, 0.2);
}

.session-import-zone.is-dragover {
  border-color: var(--accent);
  box-shadow: 0 0 0 2px rgba(95, 240, 190, 0.2);
  background: rgba(18, 24, 36, 0.86);
}

.session-import-title {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.session-import-hint {
  color: var(--muted);
  font-size: 12px;
}

.session-import-pick {
  justify-self: start;
}

.welcome-modal-panel {
  width: min(720px, calc(100vw - 32px));
}

.welcome-modal-body {
  gap: 14px;
}

.welcome-modal-intro {
  margin: 0;
  font-size: 13px;
  line-height: 1.45;
  color: var(--muted);
}

.welcome-choice-list {
  display: grid;
  gap: 10px;
}

.welcome-choice-card {
  min-height: 68px;
  text-transform: none;
  letter-spacing: 0.01em;
  display: grid;
  gap: 4px;
  align-content: center;
  text-align: left;
}

.welcome-choice-title {
  display: block;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--text);
}

.welcome-choice-hint {
  display: block;
  font-size: 12px;
  color: var(--muted);
  letter-spacing: 0.01em;
}

.welcome-import-zone {
  min-height: 94px;
}

.welcome-import-zone.is-busy {
  opacity: 0.7;
  pointer-events: none;
}

.bg-color-modal-panel {
  width: min(360px, calc(100vw - 32px));
}

.bg-color-modal-body {
  display: grid;
  gap: 12px;
}

.vislab-bg-color-picker {
  width: 100%;
  min-height: 44px;
  border-radius: 10px;
  border: 1px solid rgba(139, 147, 165, 0.7);
  background: rgba(9, 13, 21, 0.72);
  padding: 6px;
  cursor: pointer;
}

.bg-color-modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}

.bg-media-modal-panel {
  width: min(440px, calc(100vw - 32px));
}

.bg-media-modal-body {
  display: grid;
  gap: 12px;
}

.bg-media-modal-hint {
  margin: 0;
  font-size: 12px;
  line-height: 1.4;
  color: var(--muted);
}

.vislab-bg-media-input {
  width: 100%;
  min-height: 42px;
  border-radius: 10px;
  border: 1px solid rgba(139, 147, 165, 0.7);
  background: rgba(9, 13, 21, 0.72);
  color: var(--text);
  padding: 8px 10px;
}

.vislab-bg-media-input::file-selector-button {
  margin-right: 10px;
  border-radius: 8px;
  border: 1px solid var(--transport-btn-border);
  background: linear-gradient(180deg, var(--transport-btn-bg-1) 0%, var(--transport-btn-bg-2) 100%);
  color: var(--transport-btn-text);
  font: inherit;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.03em;
  padding: 6px 10px;
  cursor: pointer;
}

.bg-media-modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}

body[data-theme="studio"] .bg-color-modal-panel {
  border-radius: var(--studio-radius);
  border-color: var(--studio-btn-border);
  background: #0c1119;
  box-shadow: 0 14px 28px rgba(0, 0, 0, 0.56);
}

body[data-theme="studio"] .vislab-bg-color-picker {
  border-radius: var(--studio-radius);
  border-color: var(--studio-btn-border);
  background: linear-gradient(180deg, #141b28 0%, #101722 100%);
}

body[data-theme="studio"] .bg-media-modal-panel {
  border-radius: var(--studio-radius);
  border-color: var(--studio-btn-border);
  background: #0c1119;
  box-shadow: 0 14px 28px rgba(0, 0, 0, 0.56);
}

body[data-theme="studio"] .vislab-bg-media-input {
  border-radius: var(--studio-radius);
  border-color: var(--studio-btn-border);
  background: linear-gradient(180deg, #141b28 0%, #101722 100%);
}

body[data-theme="light"] .session-modal-backdrop {
  background: rgba(28, 34, 46, 0.35);
}

body[data-theme="light"] .session-modal-panel {
  background: linear-gradient(180deg, #f7f9fc, #e9eef6);
}

body[data-theme="light"] .session-import-zone {
  background: rgba(249, 251, 255, 0.86);
  border-color: rgba(124, 135, 156, 0.6);
}

body[data-theme="light"] .session-export-name {
  background: rgba(249, 251, 255, 0.86);
  border-color: rgba(124, 135, 156, 0.6);
  color: #11141b;
}

body[data-theme="light"] .welcome-choice-hint,
body[data-theme="light"] .welcome-modal-intro {
  color: #5b6476;
}

body[data-theme="minimal"] .session-modal-backdrop {
  background: rgba(0, 0, 0, 0.82);
  backdrop-filter: none;
}

body[data-theme="minimal"] .session-modal-panel {
  border: 2px solid #ffffff;
  border-radius: 12px;
  background: #000000;
  box-shadow: #ffffff 4px 4px 0 0;
}

body[data-theme="minimal"] .session-import-zone {
  border: 2px dashed #ffffff;
  border-radius: 10px;
  background: #000000;
}

body[data-theme="minimal"] .session-export-name {
  border: 2px solid #ffffff;
  border-radius: 10px;
  background: #000000;
  color: var(--text);
}

body[data-theme="minimal"] .session-import-zone.is-dragover,
body[data-theme="minimal"] .session-import-zone:focus-visible {
  box-shadow: #ffffff 3px 3px 0 0;
}

body[data-theme="minimal"] .session-export-name:focus-visible {
  box-shadow: #ffffff 3px 3px 0 0;
}

body[data-theme="minimal"] .welcome-choice-card {
  border: 2px solid #ffffff;
  background: #000000;
  box-shadow: #ffffff 3px 3px 0 0;
}

body[data-theme="minimal"] .welcome-modal-intro,
body[data-theme="minimal"] .welcome-choice-hint {
  color: var(--text);
}

body.tooltips-enabled [data-tooltip]::after {
  content: attr(data-tooltip);
  position: absolute;
  left: 50%;
  bottom: calc(100% + 10px);
  transform: translateX(-50%) translateY(2px);
  padding: 6px 10px;
  border-radius: 10px;
  background: rgba(12, 14, 18, 0.92);
  color: #e9eef6;
  font-family: inherit;
  font-size: 11px;
  letter-spacing: 0.02em;
  white-space: nowrap;
  text-indent: 0;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.15s ease, transform 0.15s ease, visibility 0s linear 0.15s;
  transition-delay: 0s, 0s, 0s;
  z-index: 200;
}

body[data-theme="light"].tooltips-enabled [data-tooltip]::after {
  background: #f4f6fb;
  color: #11141b;
  border: 1px solid rgba(124, 135, 156, 0.4);
}

body[data-theme-variant="pro-light"].tooltips-enabled [data-tooltip]::after {
  padding: 8px 11px 7px;
  border: 1px solid var(--vislab-ui-stroke);
  border-radius: 10px;
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--vislab-ui-surface-1) 96%, #ffffff) 0%,
    var(--vislab-ui-surface-2) 100%
  );
  color: var(--vislab-ui-text);
  font-family: "Chathura", sans-serif;
  font-size: 14px;
  line-height: 0.95;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  box-shadow: 0 8px 14px rgba(0, 0, 0, 0.2);
}

body.tooltips-enabled [data-tooltip]:hover::after,
body.tooltips-enabled [data-tooltip]:focus-visible::after {
  position: absolute;
  left: 50%;
  bottom: calc(100% + 10px);
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
  transition-delay: 0.65s, 0.65s, 0s;
}

body.tooltips-enabled [data-tooltip]:hover,
body.tooltips-enabled [data-tooltip]:focus-visible {
  position: relative;
}

body.tooltips-enabled .btn:disabled {
  pointer-events: auto;
  cursor: not-allowed;
}

.header-mode {
  display: flex;
  align-items: center;
  gap: 10px;
}

.header-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--muted);
}

.header-lang {
  display: flex;
  align-items: center;
  gap: 8px;
}

.lang-select {
  width: auto;
  min-width: 120px;
  padding: 6px 10px;
  font-size: 11px;
}

.header-quality {
  display: flex;
  flex-wrap: nowrap;
  gap: 10px;
  align-items: center;
}

.quality-group {
  display: flex;
  align-items: center;
  gap: 6px;
  min-width: 90px;
  white-space: nowrap;
  padding-right: 10px;
  border-right: 1px solid var(--stroke);
}

.quality-group:last-child {
  padding-right: 0;
  border-right: 0;
}

.header-quality .header-label {
  font-size: 9px;
  letter-spacing: 0.12em;
  margin: 0;
}

.header-quality select {
  width: 100%;
  min-width: 90px;
  padding: 4px 8px;
  font-size: 10px;
}

.quality-group-native-hidden {
  display: none !important;
}

.header-quality-native-hidden {
  display: none !important;
}

.header-quality-menu {
  position: relative;
  width: auto;
  min-width: 0;
}

.header-quality-menu-trigger {
  width: auto;
  min-width: 0;
  min-height: 0;
  border-radius: 9px;
  border: 1px solid var(--stroke);
  background: linear-gradient(180deg, rgba(8, 14, 24, 0.95) 0%, rgba(5, 10, 18, 0.96) 100%);
  color: var(--text);
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  font-family: inherit;
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  line-height: 1.2;
  text-align: left;
}

.header-quality-menu-trigger-title {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text);
  line-height: 1.2;
}

.header-quality-menu-trigger-chevron {
  font-size: 13px;
  color: var(--muted);
  line-height: 1;
  opacity: 1;
}

.header-quality-menu.is-open .header-quality-menu-trigger {
  border-color: var(--transport-btn-hover-border);
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
  position: relative;
  z-index: 66;
}

.header-quality-menu-trigger:hover,
.header-quality-menu-trigger:focus-visible {
  border-color: var(--transport-btn-hover-border);
  outline: none;
}

.header-quality-menu-panel {
  display: none;
  position: absolute;
  top: calc(100% - 1px);
  left: 0;
  z-index: 65;
  min-width: max(100%, 180px);
  border: 1px solid var(--stroke);
  border-radius: 0 0 10px 10px;
  background: linear-gradient(180deg, rgba(8, 14, 24, 0.98) 0%, rgba(5, 10, 18, 0.98) 100%);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.45);
  padding: 4px;
}

.header-quality-menu.is-open .header-quality-menu-panel {
  display: grid;
  gap: 2px;
}

.header-quality-menu-item {
  display: flex;
  align-items: center;
  width: 100%;
  min-height: 30px;
  border: 1px solid transparent;
  border-radius: 7px;
  background: transparent;
  color: var(--text);
  padding: 6px 10px;
  font-size: 11px;
  text-align: left;
  cursor: pointer;
}

.header-quality-menu-item:hover {
  border-color: rgba(164, 178, 204, 0.45);
  background: rgba(163, 178, 208, 0.12);
}

.header-quality-menu-item.is-group {
  position: relative;
  padding-right: 24px;
  overflow: visible;
}

.header-quality-menu-item.is-group::before {
  content: "";
  position: absolute;
  top: -4px;
  bottom: -4px;
  left: 100%;
  width: 10px;
}

.header-quality-menu-group-label {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.header-quality-menu-item.is-group::after {
  content: "▸";
  position: absolute;
  right: 8px;
  font-size: 13px;
  color: var(--muted);
  line-height: 1;
  opacity: 1;
}

.header-quality-menu-item.is-group.is-disabled {
  opacity: 0.55;
  cursor: default;
}

.header-quality-menu-item.is-group.is-disabled:hover {
  border-color: transparent;
  background: transparent;
}

.header-quality-submenu {
  display: none;
  position: absolute;
  top: -5px;
  left: calc(100% - 1px);
  min-width: 220px;
  border: 1px solid var(--stroke);
  border-radius: 10px;
  background: linear-gradient(180deg, rgba(8, 14, 24, 0.98) 0%, rgba(5, 10, 18, 0.98) 100%);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.45);
  padding: 6px;
  z-index: 66;
}

.header-quality-menu-item.is-group:hover > .header-quality-submenu,
.header-quality-menu-item.is-group:focus-within > .header-quality-submenu {
  display: grid;
  gap: 8px;
}

.header-quality-submenu-section {
  display: grid;
  gap: 5px;
}

.header-quality-submenu-heading {
  margin: 0;
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted);
}

.header-quality-submenu-list {
  display: grid;
  gap: 2px;
}

.header-quality-submenu-item {
  display: block;
  width: 100%;
  min-height: 28px;
  border: 1px solid transparent;
  border-radius: 7px;
  background: transparent;
  color: var(--text);
  padding: 5px 9px;
  font-size: 11px;
  text-align: left;
}

.header-quality-submenu-item:hover:not(:disabled) {
  border-color: rgba(164, 178, 204, 0.45);
  background: rgba(163, 178, 208, 0.12);
}

.header-quality-submenu-item.is-active {
  border-color: rgba(95, 240, 190, 0.56);
  background: rgba(95, 240, 190, 0.2);
}

.header-quality-submenu-item:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.hero {
  flex: 1;
  display: grid;
  grid-template-columns: minmax(320px, 38%) minmax(0, 1fr);
  gap: 18px;
  align-items: stretch;
  background: linear-gradient(160deg, rgba(31, 37, 48, 0.95), rgba(13, 16, 22, 0.95));
  border: 1px solid var(--stroke);
  border-radius: 16px;
  padding: 14px;
  min-height: 0;
}

.hero-sidebar {
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-height: 0;
  height: 100%;
}

.eyebrow {
  margin: 0;
  text-transform: uppercase;
  letter-spacing: 2px;
  font-size: 11px;
  color: var(--muted);
}

h1 {
  margin: 0;
  font-family: "Orbitron", "Arial", sans-serif;
  font-size: 30px;
  letter-spacing: 1px;
}

.intro-text {
  margin: 0;
  color: var(--muted);
  line-height: 1.4;
  font-size: 13px;
}

.controls-shell {
  display: grid;
  grid-template-rows: auto 1fr;
  gap: 8px;
  padding: 10px;
  background: var(--panel-2);
  border: 1px solid var(--stroke);
  border-radius: 12px;
  min-height: 0;
  height: 100%;
}

.tab-buttons {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(0, 1fr));
  gap: 0;
  background: #141923;
  border: 1px solid var(--stroke);
  border-radius: 10px;
  padding: 0;
  position: relative;
  isolation: isolate;
}

.tab-active-frame {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 0;
  border: 1px solid rgba(95, 240, 190, 0.7);
  border-radius: 8px;
  background: var(--accent-soft);
  box-shadow: 0 0 10px rgba(95, 240, 190, 0.2);
  transform: translate3d(0, 0, 0);
  transition: transform 0.24s cubic-bezier(0.22, 0.61, 0.36, 1), width 0.24s cubic-bezier(0.22, 0.61, 0.36, 1);
  pointer-events: none;
  z-index: 1;
  display: none;
}

.tab-active-frame.is-no-anim {
  transition: none;
}

.tab-btn {
  font-family: inherit;
  border: 1px solid transparent;
  background: transparent;
  color: var(--muted);
  border-radius: 8px;
  padding: 6px 4px;
  font-weight: 600;
  text-transform: uppercase;
  font-size: 11px;
  letter-spacing: 1px;
  cursor: pointer;
  transition: border-color 0.2s ease, color 0.2s ease, background 0.2s ease;
  position: relative;
  z-index: 2;
}

.tab-btn.active {
  color: #ffe8ff;
  background: var(--accent-soft);
  border-color: rgba(95, 240, 190, 0.7);
  box-shadow: 0 0 10px rgba(95, 240, 190, 0.2);
}

.controls {
  display: grid;
  gap: 8px;
  height: 100%;
  overflow: hidden;
  min-height: 0;
}

.tab-panel {
  display: none;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  align-content: start;
  align-items: start;
}

.tab-panel.active {
  display: grid;
}

.tab-panel#tab-live.active {
  display: flex;
  flex-direction: column;
  height: 100%;
  min-height: 0;
}

.tab-panel#tab-core.active {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  height: 100%;
  min-height: 0;
  gap: 10px;
}

.tab-panel#tab-style.active {
  display: grid;
  height: 100%;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  overscroll-behavior: contain;
  padding-right: 6px;
}

.tab-panel {
  border: 1px solid var(--stroke);
  border-radius: 10px;
  background: var(--panel);
  padding: 10px;
  align-content: start;
}

.tab-panel .control {
  background: transparent;
  border: 0;
  border-radius: 0;
  padding: 4px 0;
}

body[data-theme="dark"] .tab-panel .control,
body[data-theme="light"] .tab-panel .control,
body[data-theme="minimal"] .tab-panel .control,
body[data-theme="studio"] .tab-panel .control {
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  padding: 4px 0;
}

.core-source-hidden {
  display: none !important;
}

.core-section {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  width: 100%;
  min-height: 0;
  border: 1px solid var(--stroke);
  border-radius: 10px;
  background: #161b24;
  padding: 8px;
  gap: 8px;
  transition: flex-basis 0.2s ease, padding 0.2s ease;
}

.core-section--modes {
  flex: 7 1 0;
}

.core-section--background {
  flex: 3 1 0;
}

.core-section--transitions {
  flex: 2 1 0;
}

.core-section--custom {
  flex: 3 1 0;
}

.core-section--text {
  flex: 3 1 0;
}

.tab-panel#tab-core.active.has-collapsed-section .core-section:not(.is-collapsed) {
  flex: 1 1 auto;
}

.tab-panel#tab-core.active.has-collapsed-section .core-section.is-collapsed {
  flex: 0 0 52px;
}

.core-section.is-collapsed {
  grid-template-rows: auto;
  padding-top: 6px;
  padding-bottom: 6px;
}

.core-section.is-collapsed .core-scroll {
  display: none;
}

.core-section-head {
  appearance: none;
  font: inherit;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  border: 1px solid transparent;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.03);
  color: inherit;
  padding: 6px 8px;
  cursor: pointer;
  text-align: left;
  transition: none;
}

.core-section-head:hover {
  border-color: transparent;
  background: rgba(255, 255, 255, 0.03);
}

.core-section-head:focus-visible {
  outline: 1px solid var(--accent);
  outline-offset: 1px;
}

.core-section-title {
  margin: 0;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
}

.core-section-chevron {
  font-size: 13px;
  color: var(--muted);
  line-height: 1;
}

.tab-panel#tab-core .core-section:not(.is-collapsed) .core-section-title,
.tab-panel#tab-core .core-section:not(.is-collapsed) .core-section-chevron {
  color: #ffffff;
}

.core-scroll {
  width: 100%;
  min-height: 0;
  overflow: auto;
  padding-right: 2px;
}

.core-grid {
  display: grid;
  width: 100%;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  align-content: start;
}

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

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

.core-custom-empty {
  grid-column: 1 / -1;
  border: 1px dashed var(--stroke);
  border-radius: 8px;
  padding: 10px;
  font-size: 11px;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.02);
}

.core-tile {
  aspect-ratio: 16 / 9;
  min-height: 72px;
  position: relative;
  overflow: hidden;
  border-radius: 9px;
  border: 1px solid var(--transport-btn-border);
  background-color: #131a25;
  background-image: var(--core-preview-image);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  color: var(--text);
  padding: 0;
  font-size: 11px;
  font-weight: 700;
  line-height: 1.2;
  text-align: left;
  cursor: pointer;
  transition: border-color 0.18s ease, box-shadow 0.18s ease;
}

.core-tile--mode {
  cursor: grab;
}

.core-tile--transition {
  cursor: grab;
}

.core-tile--text {
  cursor: grab;
}

.core-tile--mode.is-dragging {
  opacity: 0.55;
  border-style: dashed;
}

.core-tile--transition.is-dragging {
  opacity: 0.55;
  border-style: dashed;
}

.core-tile--text.is-dragging {
  opacity: 0.55;
  border-style: dashed;
}

.core-tile::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(8, 12, 18, 0.06) 0%, rgba(8, 12, 18, 0.34) 100%);
  z-index: 1;
  pointer-events: none;
}

.core-tile-label {
  position: absolute;
  left: 8px;
  right: 8px;
  bottom: 7px;
  z-index: 2;
  display: block;
  padding: 4px 6px;
  border-radius: 6px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: #eef4ff;
  background: rgba(6, 10, 16, 0.55);
  text-shadow: 0 1px 1px rgba(0, 0, 0, 0.7);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  pointer-events: none;
}

.core-tile:hover {
  border-color: var(--transport-btn-hover-border);
  box-shadow: none;
}

.core-tile.is-active {
  border-color: var(--accent);
  box-shadow: 0 0 0 1px rgba(95, 240, 190, 0.26);
}

@keyframes core-tile-playing-pulse {
  0%,
  100% {
    box-shadow: 0 0 0 1px rgba(95, 240, 190, 0.28), 0 0 10px rgba(95, 240, 190, 0.14);
  }

  50% {
    box-shadow: 0 0 0 1px rgba(95, 240, 190, 0.55), 0 0 18px rgba(95, 240, 190, 0.34);
  }
}

body:not([data-theme="minimal"]) .core-tile.is-playing {
  border-color: var(--accent);
  animation: core-tile-playing-pulse 2.4s ease-in-out infinite;
}

.core-tile--random {
  border-color: rgba(95, 240, 190, 0.58);
}

.core-tile--random .core-tile-label {
  background: rgba(47, 20, 70, 0.62);
}

.core-tile--preset {
  border-color: rgba(82, 178, 255, 0.56);
}

.core-tile--preset .core-tile-label {
  background: rgba(16, 45, 70, 0.62);
  pointer-events: auto;
  cursor: text;
  user-select: none;
}

.core-tile-remove {
  position: absolute;
  top: 6px;
  right: 6px;
  z-index: 3;
  width: 20px;
  height: 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.38);
  background: rgba(6, 10, 16, 0.7);
  color: rgba(238, 244, 255, 0.9);
  font-size: 14px;
  font-weight: 700;
  line-height: 1;
  opacity: 0;
  transform: scale(0.88);
  pointer-events: none;
  transition: opacity 0.15s ease, transform 0.15s ease, border-color 0.15s ease, background-color 0.15s ease;
}

.core-tile--preset:hover .core-tile-remove,
.core-tile--preset:focus-within .core-tile-remove {
  opacity: 1;
  transform: scale(1);
  pointer-events: auto;
}

.core-tile-remove:hover,
.core-tile-remove:focus-visible {
  border-color: rgba(255, 120, 140, 0.95);
  background: rgba(52, 12, 22, 0.86);
  outline: none;
}

.core-tile--preset .core-tile-label.is-editing {
  user-select: text;
  white-space: normal;
  overflow: visible;
  text-overflow: clip;
  outline: 1px solid rgba(255, 255, 255, 0.6);
  outline-offset: 1px;
  background: rgba(12, 35, 58, 0.85);
}

.tab-panel .control-inline {
  grid-column: 1 / -1;
}

.control {
  display: grid;
  gap: 6px;
  font-size: 12px;
  color: var(--muted);
  background: #161b24;
  border: 1px solid var(--stroke);
  border-radius: 10px;
  padding: 8px 10px;
}

.control.is-disabled {
  opacity: 0.45;
  filter: grayscale(0.6);
}

#tab-style .style-text-controls {
  display: none;
  grid-column: 1 / -1;
  gap: 8px;
}

#tab-style.is-text-edit .style-visual-control {
  display: none !important;
}

#tab-style.is-text-edit .style-text-controls {
  display: grid;
}

.style-text-control {
  grid-column: 1 / -1;
}

.style-text-control > input[type="text"] {
  width: 100%;
  min-height: 34px;
  border: 1px solid var(--stroke);
  border-radius: 8px;
  background: rgba(9, 13, 21, 0.72);
  color: var(--text);
  font: inherit;
  padding: 0 10px;
}

.style-text-control > select {
  width: 100%;
}

.style-text-inline {
  display: grid;
  gap: 8px;
}

.style-text-check-row {
  display: flex;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
}

.style-text-check {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--text);
}

.style-text-check input[type="checkbox"] {
  accent-color: var(--accent);
}

.vislab-text-color {
  width: 100%;
  min-height: 34px;
  border: 1px solid var(--stroke);
  border-radius: 8px;
  background: rgba(9, 13, 21, 0.72);
  padding: 4px;
  cursor: pointer;
}

.queue-panel {
  gap: 10px;
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
  width: 100%;
}

.queue-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}

.queue-head-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.queue-row {
  display: grid;
  grid-template-columns: minmax(170px, 1fr) auto;
  gap: 10px;
  align-items: end;
}

.queue-field {
  display: grid;
  gap: 6px;
  font-size: 11px;
  color: var(--muted);
}

.queue-play {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.queue-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 6px;
  max-height: none;
  overflow: auto;
  flex: 1;
  min-height: 0;
  align-content: start;
}

.queue-item {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 8px;
  padding: 6px 8px;
  height: 34px;
  border-radius: 8px;
  border: 1px solid var(--stroke);
  background: rgba(16, 20, 28, 0.65);
  font-size: 11px;
  color: var(--text);
  cursor: grab;
}

.queue-item.is-active {
  border-color: var(--accent);
  box-shadow: 0 0 8px rgba(95, 240, 190, 0.3);
}

.queue-item.is-dragging {
  opacity: 0.5;
}

.queue-index {
  font-size: 10px;
  color: var(--muted);
}

.queue-label {
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.queue-remove {
  border: 1px solid transparent;
  background: transparent;
  color: var(--muted);
  border-radius: 6px;
  font-size: 12px;
  padding: 2px 6px;
  cursor: pointer;
  transition: border-color 0.2s ease, color 0.2s ease;
}

.queue-remove:hover {
  color: var(--text);
  border-color: var(--accent);
}

.queue-empty {
  font-size: 11px;
  color: var(--muted);
  padding: 6px 4px;
}

.control-inline {
  grid-template-columns: 1fr;
}

.two-col {
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 8px;
}

.two-col .field {
  display: grid;
  gap: 6px;
}

.mode-switch {
  display: inline-flex;
  align-items: center;
  gap: 12px;
}

.mode-label {
  font-weight: 600;
  letter-spacing: 1px;
  color: var(--muted);
  text-transform: uppercase;
  font-size: 11px;
}

.switch {
  position: relative;
  display: inline-block;
  width: 52px;
  height: 26px;
}

.switch input {
  opacity: 0;
  width: 0;
  height: 0;
}

.switch-slider {
  position: absolute;
  inset: 0;
  background: #121620;
  border: 1px solid var(--stroke);
  border-radius: 999px;
  cursor: pointer;
  transition: background 0.2s ease, border 0.2s ease;
}

.switch-slider::before {
  content: "";
  position: absolute;
  height: 20px;
  width: 20px;
  left: 3px;
  top: 2px;
  background: var(--accent);
  border-radius: 50%;
  box-shadow: 0 0 10px rgba(95, 240, 190, 0.5);
  transition: transform 0.2s ease;
}

.switch input:checked + .switch-slider {
  background: rgba(95, 240, 190, 0.2);
  border-color: rgba(95, 240, 190, 0.6);
}

.switch input:checked + .switch-slider::before {
  transform: translateX(26px);
}

.control-inline-actions {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 8px;
  align-items: stretch;
}

#style-reset {
  border-color: rgba(95, 240, 190, 0.65);
}

.stream-list {
  display: grid;
  gap: 8px;
}

.stream-row {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 8px;
  align-items: center;
}

.p5-list {
  display: grid;
  gap: 8px;
}

.p5-row {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 8px;
  align-items: start;
}

.p5-apply {
  min-width: 120px;
  padding: 8px 12px;
}

.p5-remove {
  width: 36px;
  min-width: 36px;
  padding: 0;
  font-size: 16px;
  line-height: 1;
}

.stream-connect {
  min-width: 110px;
  padding: 8px 12px;
}

.stream-remove {
  width: 36px;
  min-width: 36px;
  padding: 0;
  font-size: 16px;
  line-height: 1;
}

.stream-add-row {
  display: none;
  width: 100%;
  min-width: 0;
  padding: 6px 0;
  font-size: 22px;
  line-height: 1;
  font-weight: 700;
  justify-self: stretch;
  display: flex;
  justify-content: center;
  align-items: center;
}

select,
input[type="url"],
input[type="number"],
textarea {
  width: 100%;
  background: #10141c;
  border: 1px solid #242b36;
  border-radius: 10px;
  padding: 7px 10px;
  color: var(--text);
  font-weight: 600;
  font-family: inherit;
}

select:focus-visible,
input[type="range"]:focus-visible,
textarea:focus-visible {
  outline: 1px solid var(--accent);
}

select:focus:not(:focus-visible),
input[type="range"]:focus:not(:focus-visible),
textarea:focus:not(:focus-visible) {
  outline: none;
}

.p5-code {
  min-height: 120px;
  resize: vertical;
  font-family: "Rajdhani", "Arial", sans-serif;
  font-weight: 500;
  font-size: 12px;
  line-height: 1.4;
}

input[type="range"] {
  --range-track-height: 8px;
  --range-thumb-size: 18px;
  appearance: none;
  height: var(--range-track-height);
  padding: 0;
  border: 1px solid var(--fader-border, #242b36);
  border-radius: 999px;
  background: linear-gradient(90deg, var(--accent) 0%, var(--accent) var(--fader-fill, 50%), var(--fader-track, #0f131b) var(--fader-fill, 50%), var(--fader-track, #0f131b) 100%);
}

input[type="range"]::-webkit-slider-runnable-track {
  height: var(--range-track-height);
  border-radius: 999px;
  background: transparent;
}

input[type="range"]::-moz-range-track {
  height: var(--range-track-height);
  border-radius: 999px;
  background: var(--fader-track, #0f131b);
}

input[type="range"]::-moz-range-progress {
  height: var(--range-track-height);
  border-radius: 999px;
  background: var(--accent);
}

input[type="range"]::-webkit-slider-thumb {
  appearance: none;
  width: var(--range-thumb-size);
  height: var(--range-thumb-size);
  margin-top: calc((var(--range-track-height) - var(--range-thumb-size)) / 2);
  border-radius: 4px;
  background: var(--accent);
  box-shadow: 0 0 8px rgba(95, 240, 190, 0.6);
  border: 2px solid var(--fader-thumb-border, #1a1f2a);
}

input[type="range"]::-moz-range-thumb {
  width: var(--range-thumb-size);
  height: var(--range-thumb-size);
  border-radius: 4px;
  background: var(--accent);
  border: 2px solid var(--fader-thumb-border, #1a1f2a);
}

.canvas-shell {
  display: grid;
  grid-template-rows: minmax(0, 1fr) auto auto;
  gap: 10px;
  min-height: 0;
  min-width: 0;
  height: 100%;
}

.sound-canvas {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 0;
  border-radius: 12px;
  overflow: hidden;
  background: #10141c;
  border: 1px solid #242b36;
  box-shadow: inset 0 0 24px rgba(0, 0, 0, 0.4);
}

.sound-canvas canvas {
  position: relative;
  width: 100%;
  height: 100%;
  max-width: none;
  max-height: none;
  object-fit: contain;
  display: block;
  z-index: 1;
}

.sound-canvas.is-preview-off canvas {
  display: none;
}

.sound-canvas.is-preview-off .td-stream-overlay {
  display: none;
}

.td-stream-overlay {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
  display: none;
  align-items: center;
  justify-content: center;
  background: #0b0f15;
  z-index: 2;
}

.td-stream-overlay.is-visible {
  display: flex;
}

.preview-off {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(10, 12, 18, 0.72);
  color: var(--text);
  font-size: 14px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease;
  z-index: 3;
}

.preview-off.is-visible {
  opacity: 1;
}

.td-stream-overlay iframe {
  width: 100%;
  height: 100%;
  border: 0;
}

.td-stream-overlay img,
.td-stream-overlay video {
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  display: block;
}

.sound-canvas:fullscreen,
.sound-canvas:-webkit-full-screen {
  width: 100vw;
  height: 100vh;
  border-radius: 0;
  border: none;
}

.queue-timeline-shell {
  width: 100%;
  max-width: 100%;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  grid-template-rows: minmax(0, 1fr) auto;
  align-items: stretch;
  gap: 16px;
  padding: 8px 10px;
  border: 1px solid var(--timeline-shell-border);
  border-radius: 11px;
  background: linear-gradient(180deg, var(--timeline-shell-bg-1) 0%, var(--timeline-shell-bg-2) 100%);
  min-height: 72px;
  overflow: visible;
  transition: opacity 0.2s ease, filter 0.2s ease;
}

.queue-timeline-shell.is-dimmed {
  opacity: 0.52;
  filter: grayscale(0.34) saturate(0.62);
}

.queue-timeline-shell.is-dimmed .queue-timeline-cursor {
  opacity: 0.35;
}

.queue-timeline-toolbar {
  grid-column: 1;
  grid-row: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  padding-inline: 10px;
  overflow: visible;
}

.queue-timeline-tool-stack {
  --queue-zoom-slider-length: calc(
    var(--queue-lane-height) * 3 +
    var(--queue-lane-border-top) * 2
  );
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: calc(var(--range-thumb-size) + 16px);
  min-width: calc(var(--range-thumb-size) + 16px);
  height: var(--queue-zoom-slider-length);
  min-height: var(--queue-zoom-slider-length);
  overflow: visible;
}

.queue-timeline-toolbar .timeline-play-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: var(--transport-icon-btn-size);
  min-width: var(--transport-icon-btn-size);
  height: var(--transport-icon-btn-size);
  min-height: var(--transport-icon-btn-size);
  padding: 0;
  border-radius: var(--transport-icon-btn-radius);
  border: 1px solid var(--transport-play-border);
  background: linear-gradient(180deg, var(--transport-play-bg-1) 0%, var(--transport-play-bg-2) 100%);
  color: var(--transport-play-text);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.35);
}

.queue-timeline-toolbar .queue-timeline-precision-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: var(--transport-icon-btn-size);
  min-width: var(--transport-icon-btn-size);
  height: var(--transport-icon-btn-size);
  min-height: var(--transport-icon-btn-size);
  padding: 0;
  border-radius: var(--transport-icon-btn-radius);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.04em;
}

.queue-timeline-toolbar .queue-timeline-precision-btn.is-active {
  border-color: var(--transport-play-border);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.35), 0 0 0 1px var(--transport-play-ring);
}

.queue-timeline-zoom-slider {
  position: absolute;
  left: 50%;
  top: 50%;
  width: var(--queue-zoom-slider-length);
  min-width: var(--queue-zoom-slider-length);
  height: var(--range-track-height);
  min-height: var(--range-track-height);
  margin: 0;
  cursor: ns-resize;
  background: transparent;
  touch-action: none;
  transform: translate(-50%, -50%) rotate(-90deg);
  transform-origin: center center;
  z-index: 2;
}

.queue-timeline-toolbar .timeline-play-btn:hover,
.queue-timeline-toolbar .timeline-play-btn.is-playing {
  border-color: var(--transport-play-border);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.35), 0 0 0 1px var(--transport-play-ring);
}

.queue-timeline-toolbar .timeline-play-btn .transport-glyph {
  font-size: 16px;
}

.queue-timeline-shell.is-precision-mode .queue-timeline-block {
  border-radius: 2px;
  padding: 0 9px 0 0;
  gap: 1px;
  border-color: transparent;
  background: transparent;
}

.queue-timeline-shell.is-precision-mode .queue-timeline-block--text {
  top: 0;
  padding: 2px 9px 2px 2px;
  background: linear-gradient(180deg, rgba(70, 45, 101, 0.72) 0%, rgba(30, 31, 62, 0.88) 100%);
  border-color: rgba(218, 185, 255, 0.48);
}

.queue-timeline-shell.is-precision-mode .queue-timeline-name,
.queue-timeline-shell.is-precision-mode .queue-timeline-duration {
  font-size: 9px;
  line-height: 1.05;
}

.queue-timeline-shell.is-precision-mode .queue-timeline-preview {
  left: 0;
  right: 9px;
  top: 0;
  bottom: 0;
  border: 0;
  border-radius: 2px;
  opacity: 0.9;
}

.queue-timeline-shell.is-precision-mode .queue-timeline-preview::after {
  background: none;
}

.queue-timeline-shell.is-precision-mode .queue-timeline-bars {
  left: 0;
  right: 9px;
  top: 0;
  bottom: 0;
  border-radius: 2px;
}

.queue-timeline-shell.is-precision-mode .queue-timeline-lane {
  padding-left: 0;
  padding-right: 0;
  background-position: 0 0, 0 0;
}

.queue-timeline-track {
  grid-column: 2;
  grid-row: 1;
  position: relative;
  flex: 1 1 auto;
  width: auto;
  max-width: none;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
  overflow-x: scroll;
  overflow-y: hidden;
  scrollbar-width: none;
}

.queue-timeline-track::-webkit-scrollbar {
  height: 0;
}

.queue-timeline-track::-webkit-scrollbar-thumb {
  background: transparent;
}

.queue-timeline-track::-webkit-scrollbar-track {
  background: transparent;
}

.queue-timeline-scrollbar {
  grid-column: 2;
  grid-row: 2;
  position: relative;
  width: 100%;
  margin: 1px 0 0;
  height: 12px;
  padding: 1px;
  border: 1px solid var(--timeline-shell-border);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  cursor: pointer;
  user-select: none;
  touch-action: none;
}

.queue-timeline-scrollbar.is-disabled {
  opacity: 0.58;
  cursor: default;
}

.queue-timeline-scrollbar-thumb {
  position: absolute;
  left: 1px;
  top: 1px;
  height: 8px;
  min-width: 28px;
  border-radius: 6px;
  border: 1px solid #5f6878;
  background: #9aa4b5;
  transform: translateX(0);
  box-shadow: none;
  cursor: ew-resize;
  will-change: transform, width;
}

.queue-timeline-ruler {
  position: relative;
  min-height: 12px;
  width: max-content;
  min-width: 100%;
  margin: 0;
  color: var(--timeline-block-border);
  pointer-events: none;
}

.queue-timeline-ruler.is-empty {
  min-height: 6px;
}

.queue-timeline-ruler-tick {
  position: absolute;
  top: 1px;
  bottom: 0;
  width: 0;
  border-left: 1px solid currentColor;
  opacity: 0.45;
}

.queue-timeline-ruler-tick.is-major {
  opacity: 0.9;
}

.queue-timeline-ruler-label {
  position: absolute;
  top: -1px;
  transform: translateX(3px);
  font-size: 9px;
  line-height: 1;
  letter-spacing: 0.04em;
  color: var(--muted);
  white-space: nowrap;
}

.queue-timeline-lane {
  position: relative;
  min-height: var(--queue-lane-height);
  height: var(--queue-lane-height);
  min-width: 100%;
  width: max-content;
  display: block;
  gap: 0;
  padding: var(--queue-lane-pad-top) var(--queue-lane-pad-x) var(--queue-lane-pad-bottom);
  border-top: var(--queue-lane-border-top) solid transparent;
  background-image:
    repeating-linear-gradient(
      90deg,
      var(--timeline-grid-major) 0 var(--timeline-grid-major-width, 1px),
      transparent var(--timeline-grid-major-width, 1px) var(--queue-grid-major-step, 24px)
    ),
    repeating-linear-gradient(
      90deg,
      var(--timeline-grid-minor) 0 var(--timeline-grid-minor-width, 1px),
      transparent var(--timeline-grid-minor-width, 1px) var(--queue-grid-minor-step, 12px)
    );
  background-repeat: repeat;
  background-position: 2px 0, 2px 0;
  background-size: auto 100%;
}

.queue-timeline-lane + .queue-timeline-lane {
  border-top-color: var(--timeline-shell-border);
}

.queue-timeline-lane--text,
.queue-timeline-lane--main,
.queue-timeline-lane--background {
  min-height: var(--queue-lane-height);
  height: var(--queue-lane-height);
  background-color: transparent;
}

.queue-timeline-lane--text {
  display: block;
  order: 1;
  --queue-lane-pad-top: 0px;
  --queue-lane-pad-bottom: 0px;
  --queue-lane-border-top: 0px;
  overflow: hidden;
}

.queue-timeline-lane--main {
  order: 2;
}

.queue-timeline-lane--background {
  order: 3;
}

.queue-timeline-lane > * {
  z-index: 1;
}

.queue-timeline-lane--main > *,
.queue-timeline-lane--background > * {
  position: absolute;
}

.queue-timeline-lane--text > .queue-timeline-block--text {
  position: absolute !important;
  top: 0 !important;
  bottom: auto !important;
  z-index: 2;
}

.queue-timeline-empty {
  align-self: center;
  font-size: 11px;
  color: var(--muted);
  letter-spacing: 0.03em;
}

.queue-timeline-empty--text {
  position: absolute;
  left: 8px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.09em;
  opacity: 0.7;
  margin-left: 0;
}

.queue-timeline-empty--background {
  margin-left: 8px;
}

.queue-timeline-block {
  --queue-resize-hit-width: 18px;
  --queue-resize-grip-width: 6px;
  appearance: none;
  position: absolute;
  height: calc(var(--queue-lane-height) - var(--queue-lane-pad-top) - var(--queue-lane-pad-bottom) - var(--queue-lane-border-top));
  min-height: calc(var(--queue-lane-height) - var(--queue-lane-pad-top) - var(--queue-lane-pad-bottom) - var(--queue-lane-border-top));
  min-width: 1px;
  margin-left: 0;
  margin-right: 0;
  border: 1px solid var(--timeline-block-border);
  border-radius: 8px;
  background: linear-gradient(180deg, var(--timeline-block-bg-1) 0%, var(--timeline-block-bg-2) 100%);
  color: var(--text);
  cursor: pointer;
  display: grid;
  grid-template-rows: 1fr auto;
  align-items: end;
  justify-items: start;
  gap: 3px;
  padding: 6px 20px 6px 8px;
  text-align: left;
  font-family: inherit;
  overflow: hidden;
  transition: border-color 0.18s ease, box-shadow 0.18s ease, margin-left 0.16s ease, margin-right 0.16s ease;
}

.queue-timeline-block--background {
  background: linear-gradient(180deg, rgba(59, 72, 96, 0.5) 0%, rgba(24, 31, 44, 0.86) 100%);
}

.queue-timeline-block--background .queue-timeline-preview {
  opacity: 0.52;
}

.queue-timeline-block--background .queue-timeline-duration {
  color: rgba(214, 219, 230, 0.9);
}

.queue-timeline-block--text {
  position: absolute !important;
  top: 0 !important;
  bottom: auto !important;
  z-index: 2;
  height: calc(var(--queue-lane-height) - var(--queue-lane-border-top));
  min-height: calc(var(--queue-lane-height) - var(--queue-lane-border-top));
  background: linear-gradient(180deg, rgba(70, 45, 101, 0.72) 0%, rgba(30, 31, 62, 0.88) 100%);
  border-color: rgba(205, 155, 255, 0.36);
}

.queue-timeline-block--text .queue-timeline-name {
  color: rgba(244, 228, 255, 0.94);
}

.queue-timeline-text-preview {
  max-width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: rgba(233, 216, 255, 0.78);
}

.queue-timeline-resize--text {
  background: repeating-linear-gradient(
    0deg,
    rgba(230, 208, 255, 0.88) 0 2px,
    transparent 2px 4px
  );
}

.queue-timeline-preview {
  position: absolute;
  left: 8px;
  right: 20px;
  top: 7px;
  bottom: 7px;
  border-radius: 5px;
  background-image: var(--queue-preview-image);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  opacity: 0.72;
  pointer-events: none;
}

.queue-timeline-preview::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background:
    linear-gradient(180deg, rgba(8, 12, 20, 0.08), rgba(8, 12, 20, 0.45)),
    radial-gradient(circle at 18% 20%, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0) 55%);
}

.queue-timeline-preview.is-empty {
  background: linear-gradient(180deg, var(--timeline-block-bg-1) 0%, var(--timeline-block-bg-2) 100%);
}

.queue-timeline-bars {
  position: absolute;
  left: 8px;
  right: 20px;
  top: 7px;
  bottom: 7px;
  border-radius: 5px;
  background:
    repeating-linear-gradient(
      90deg,
      var(--timeline-bar-a) 0 2px,
      var(--timeline-bar-b) 2px 7px
    ),
    linear-gradient(180deg, rgba(95, 240, 190, 0.16), rgba(95, 240, 190, 0.08));
  opacity: 0.72;
  pointer-events: none;
}

.queue-timeline-name,
.queue-timeline-duration {
  position: relative;
  z-index: 1;
}

.queue-timeline-name {
  font-size: 11px;
  font-weight: 700;
  max-width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.queue-timeline-duration {
  font-size: 10px;
  color: var(--muted);
  letter-spacing: 0.04em;
}

.queue-clip-context-menu {
  position: fixed;
  z-index: 20000;
  min-width: 220px;
  max-width: min(92vw, 280px);
  display: grid;
  gap: 8px;
  padding: 10px;
  border: 1px solid var(--stroke);
  border-radius: 10px;
  background: linear-gradient(180deg, rgba(19, 25, 37, 0.98), rgba(13, 18, 28, 0.98));
  box-shadow: 0 10px 28px rgba(4, 8, 14, 0.45);
  backdrop-filter: blur(8px);
  pointer-events: auto;
  isolation: isolate;
}

.queue-clip-context-menu[hidden] {
  display: none !important;
}

.queue-clip-context-backdrop {
  position: fixed;
  inset: 0;
  z-index: 19999;
  background: transparent;
  pointer-events: auto;
}

.queue-clip-context-backdrop[hidden] {
  display: none !important;
}

.queue-clip-context-title {
  font-size: 11px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: 0.02em;
}

.queue-clip-context-field {
  display: grid;
  gap: 5px;
  font-size: 10px;
  font-weight: 700;
  color: var(--muted);
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.queue-clip-context-input {
  width: 100%;
  border: 1px solid var(--stroke);
  border-radius: 8px;
  padding: 6px 8px;
  background: rgba(10, 14, 22, 0.92);
  color: var(--text);
  font-size: 13px;
  font-weight: 700;
  font-family: inherit;
}

.queue-clip-context-input:focus-visible {
  outline: 1px solid var(--accent);
  outline-offset: 1px;
}

.queue-clip-context-actions {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
}

.queue-clip-context-btn {
  appearance: none;
  border: 1px solid var(--transport-btn-border);
  border-radius: 8px;
  background: rgba(19, 26, 39, 0.95);
  color: var(--text);
  font-size: 11px;
  font-weight: 700;
  padding: 6px 8px;
  font-family: inherit;
  cursor: pointer;
  transition: border-color 0.18s ease, background-color 0.18s ease, color 0.18s ease;
}

.queue-clip-context-btn:hover,
.queue-clip-context-btn:focus-visible {
  border-color: var(--transport-btn-hover-border);
  background: rgba(29, 40, 60, 0.95);
  outline: none;
}

.queue-clip-context-btn.is-wide {
  grid-column: 1 / -1;
}

.queue-clip-context-btn.danger {
  grid-column: 1 / -1;
  border-color: rgba(255, 105, 133, 0.45);
}

.queue-clip-context-btn.danger:hover,
.queue-clip-context-btn.danger:focus-visible {
  border-color: rgba(255, 122, 147, 0.75);
  color: #ffd7df;
}

.queue-transition-picker {
  position: fixed;
  z-index: 20000;
  min-width: 220px;
  max-width: min(92vw, 300px);
  display: grid;
  gap: 8px;
  padding: 10px;
  border: 1px solid var(--stroke);
  border-radius: 10px;
  background: linear-gradient(180deg, rgba(19, 25, 37, 0.98), rgba(13, 18, 28, 0.98));
  box-shadow: 0 10px 28px rgba(4, 8, 14, 0.45);
  backdrop-filter: blur(8px);
  pointer-events: auto;
  isolation: isolate;
}

.queue-transition-picker[hidden] {
  display: none !important;
}

.queue-transition-picker-title {
  font-size: 11px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: 0.02em;
}

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

.queue-transition-picker-btn,
.queue-transition-picker-clear {
  appearance: none;
  border: 1px solid var(--transport-btn-border);
  border-radius: 8px;
  background: rgba(19, 26, 39, 0.95);
  color: var(--text);
  font-size: 11px;
  font-weight: 700;
  padding: 7px 8px;
  font-family: inherit;
  cursor: pointer;
  transition: border-color 0.18s ease, background-color 0.18s ease, color 0.18s ease;
}

.queue-transition-picker-btn:hover,
.queue-transition-picker-btn:focus-visible,
.queue-transition-picker-clear:hover,
.queue-transition-picker-clear:focus-visible,
.queue-transition-picker-btn.is-active {
  border-color: var(--transport-btn-hover-border);
  background: rgba(29, 40, 60, 0.95);
  outline: none;
}

.queue-transition-picker-btn.is-active {
  box-shadow: 0 0 0 1px var(--timeline-block-active-glow);
}

.queue-transition-picker-clear {
  width: 100%;
}

.queue-timeline-block:hover,
.queue-timeline-block:focus-visible {
  border-color: var(--timeline-block-active-border);
  box-shadow: 0 0 0 1px var(--timeline-block-active-glow);
  outline: none;
}

.queue-timeline-block.is-active {
  border-color: var(--timeline-block-active-border);
  box-shadow: 0 0 0 1px var(--timeline-block-active-glow);
}

.queue-timeline-block.is-selected {
  border-color: var(--accent);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.22), 0 0 0 1px var(--accent-soft);
}

.queue-timeline-shell.is-editing-clip .queue-timeline-block.is-selected {
  animation: queue-timeline-selected-pulse 1.15s ease-in-out infinite;
}

@keyframes queue-timeline-selected-pulse {
  0%,
  100% {
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.22), 0 0 0 1px var(--accent-soft);
  }

  50% {
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.24), 0 0 0 1px var(--accent);
  }
}

.queue-timeline-block.is-playing .queue-timeline-bars {
  opacity: 0.9;
}

.queue-timeline-block.is-dragging {
  opacity: 0.5;
  border-style: dashed;
}

.queue-timeline-block.drop-before {
  margin-left: 18px;
}

.queue-timeline-block.drop-after {
  margin-right: 18px;
}

.queue-transition-slot {
  position: absolute;
  width: 0;
  min-width: 0;
  height: 0;
  margin: 0;
  padding: 0;
  overflow: visible;
  cursor: pointer;
  z-index: 8;
}

.queue-transition-hitarea {
  position: absolute;
  right: 0;
  top: -10px;
  width: var(--queue-transition-hit-width, 46px);
  height: 34px;
  border-radius: 8px;
  opacity: 0;
  pointer-events: auto;
  z-index: 5;
}

.queue-transition-slot:focus-visible {
  outline: none;
}

.queue-transition-chip,
.queue-transition-placeholder {
  position: absolute;
  top: -10px;
  right: 0;
  width: var(--queue-transition-width, 46px);
  min-width: 46px;
  height: 34px;
  box-sizing: border-box;
  border-radius: 8px;
}

.queue-transition-chip {
  appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px dashed var(--timeline-block-border);
  background: linear-gradient(180deg, rgba(67, 42, 95, 0.82) 0%, rgba(35, 30, 58, 0.82) 100%);
  color: var(--text);
  font-family: inherit;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0;
  text-transform: none;
  padding: 0 12px 0 8px;
  line-height: 1;
  cursor: grab;
  user-select: none;
  z-index: 6;
  opacity: 0.5;
  transition: none;
}

.queue-transition-chip:hover,
.queue-transition-chip:focus-visible {
  border-color: var(--accent);
  opacity: 0.72;
  outline: none;
}

.queue-transition-slot.is-selected .queue-transition-chip {
  opacity: 1;
  border-style: solid;
  border-color: var(--timeline-block-active-border);
  box-shadow: 0 0 0 1px var(--timeline-block-active-glow);
}

.queue-transition-slot.is-drop-target .queue-transition-chip {
  opacity: 1;
  border-style: solid;
  border-color: var(--accent);
  box-shadow: 0 0 0 1px rgba(95, 240, 190, 0.35);
}

.queue-transition-slot.is-empty-transition-slot {
  pointer-events: none;
}

.queue-transition-slot.is-empty-transition-slot .queue-transition-hitarea {
  pointer-events: none;
}

.queue-transition-chip.is-dragging {
  opacity: 0.55;
  border-style: dashed;
}

.queue-transition-resize-handle {
  position: absolute;
  top: 0;
  right: 0;
  width: 10px;
  height: 100%;
  border-left: 1px dashed rgba(255, 255, 255, 0.5);
  cursor: ew-resize;
}

.queue-transition-placeholder {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px dashed var(--timeline-block-border);
  background: rgba(20, 28, 40, 0.45);
  font-size: 12px;
  font-weight: 700;
  color: var(--muted);
  letter-spacing: 0;
  line-height: 1;
  text-align: center;
  opacity: 0.5;
  pointer-events: none;
  user-select: none;
  z-index: 5;
}

.queue-timeline-resize {
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  width: var(--queue-resize-hit-width);
  border-radius: 0 8px 8px 0;
  background: transparent;
  opacity: 0.9;
  cursor: ew-resize;
}

.queue-timeline-resize--background {
  opacity: 0.5;
}

.queue-timeline-resize::before {
  content: "";
  position: absolute;
  right: 5px;
  top: 6px;
  bottom: 6px;
  width: var(--queue-resize-grip-width);
  border-radius: 4px;
  background:
    repeating-linear-gradient(
      0deg,
      rgba(255, 255, 255, 0.45) 0 2px,
      transparent 2px 4px
    );
}

.queue-timeline-cursor {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 12px;
  left: 0;
  transform: translateX(-50%);
  background: transparent;
  pointer-events: auto;
  z-index: 30;
  transition: opacity 0.12s ease;
  cursor: ew-resize;
  touch-action: none;
}

.queue-timeline-cursor::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 0;
  bottom: 0;
  width: 2px;
  transform: translateX(-50%);
  border-radius: 999px;
  background: var(--timeline-cursor);
  box-shadow: 0 0 12px rgba(95, 240, 190, 0.35);
}

.queue-timeline-cursor::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 1px;
  width: 0;
  height: 0;
  transform: translateX(-50%);
  border-left: 7px solid transparent;
  border-right: 7px solid transparent;
  border-top: 10px solid var(--timeline-cursor);
  filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.5));
}

.queue-timeline-cursor.is-hidden {
  opacity: 0;
  pointer-events: none;
}

body.is-resizing-queue-timeline,
body.is-resizing-queue-timeline * {
  cursor: ew-resize !important;
}

body.is-dragging-queue-timeline,
body.is-dragging-queue-timeline * {
  cursor: ew-resize !important;
}

.exit-fullscreen {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 3;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.24);
  background: rgba(16, 20, 28, 0.7);
  color: var(--text);
  font-size: 20px;
  cursor: pointer;
  box-shadow: 0 10px 22px rgba(0, 0, 0, 0.4);
  transition: opacity 0.2s ease, transform 0.16s ease;
}

.canvas-overlay-actions {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 4;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  opacity: 0;
  pointer-events: none;
  transform: translateY(-2px);
  transition: opacity 0.2s ease, transform 0.16s ease;
}

.canvas-popout-btn {
  height: 34px;
  min-width: 118px;
  padding: 0 12px;
  border-radius: 9px;
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.canvas-fullscreen-btn {
  width: 32px;
  min-width: 32px;
  height: 32px;
  padding: 0;
  border-radius: 0;
  border: 0;
  background: transparent;
  color: #fff;
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  transition: color 0.18s ease, transform 0.14s ease, opacity 0.18s ease;
  font-size: 0;
  letter-spacing: 0;
  text-transform: none;
}

.sound-canvas:hover .canvas-overlay-actions,
.sound-canvas:focus-within .canvas-overlay-actions {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

.canvas-fullscreen-btn:hover {
  border-color: transparent;
  background: transparent;
  box-shadow: none;
  color: #ffffff;
  transform: scale(1.08);
}

.canvas-fullscreen-btn:active {
  transform: scale(0.94);
}

.canvas-overlay-actions .canvas-fullscreen-btn.icon-only {
  color: var(--transport-btn-text);
  text-indent: 0;
  overflow: hidden;
}

.canvas-overlay-actions .canvas-fullscreen-btn.icon-only::before {
  display: none;
  background-image: none;
}

.canvas-overlay-actions .canvas-fullscreen-btn .transport-glyph {
  font-size: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}

.sound-canvas:fullscreen .canvas-overlay-actions,
.sound-canvas:-webkit-full-screen .canvas-overlay-actions {
  display: none;
}

.canvas-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 10px;
  background: #141820;
  border: 1px solid var(--stroke);
  border-radius: 10px;
  position: relative;
  z-index: 120;
  justify-content: center;
}

.canvas-actions .btn {
  flex: 1 1 140px;
}

.canvas-actions .btn-play,
.canvas-actions .btn-record {
  flex: 0 0 42px;
}

.transport-layout {
  display: grid;
  grid-template-columns: minmax(180px, 1fr) auto minmax(180px, 1fr);
  align-items: center;
  gap: 10px;
  width: 100%;
}

.transport-panel {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
  min-height: var(--transport-shell-height);
  padding: 7px 10px;
  border-radius: 11px;
  border: 1px solid var(--transport-shell-border);
  background: linear-gradient(180deg, var(--transport-shell-bg-1) 0%, var(--transport-shell-bg-2) 100%);
}

.transport-panel-right {
  justify-content: flex-end;
}

.transport-panel-left {
  position: relative;
  z-index: 90;
}

.transport-label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--transport-btn-text);
  white-space: nowrap;
}

.transport-input {
  width: auto;
  flex: 1 1 auto;
  min-width: 0;
  max-width: 210px;
  padding: 6px 8px;
  font-size: 11px;
}

.transport-input.transport-input-native-hidden {
  display: none;
}

.transport-input-menu {
  position: relative;
  width: 100%;
  flex: 1 1 auto;
  min-width: 0;
  max-width: 210px;
  overflow: visible;
}

.transport-input-menu-trigger {
  width: 100%;
  height: 32px;
  padding: 6px 10px;
  border-radius: 8px;
  border: 1px solid var(--transport-shell-border);
  background: linear-gradient(180deg, rgba(8, 14, 24, 0.95) 0%, rgba(5, 10, 18, 0.96) 100%);
  color: var(--transport-btn-text);
  font-size: 11px;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  text-align: left;
}

#transport-input-menu-trigger-label {
  flex: 1 1 auto;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.transport-input-menu.is-open .transport-input-menu-trigger {
  border-color: var(--transport-btn-hover-border);
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
  position: relative;
  z-index: 61;
}

.transport-input-menu.is-open {
  z-index: 1200;
  isolation: isolate;
}

.transport-input-menu-trigger-chevron {
  flex: 0 0 auto;
  font-size: 13px;
  color: var(--muted);
  line-height: 1;
  opacity: 1;
}

.transport-input-menu-panel {
  display: none;
  position: absolute;
  top: calc(100% - 1px);
  left: 0;
  z-index: 120;
  width: 100%;
  min-width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  overflow: visible;
  border: 1px solid var(--transport-shell-border);
  border-radius: 0 0 10px 10px;
  background: linear-gradient(180deg, rgba(8, 14, 24, 0.98) 0%, rgba(5, 10, 18, 0.98) 100%);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.45);
  padding: 4px;
}

.transport-input-menu.is-open .transport-input-menu-panel {
  display: grid;
  gap: 2px;
}

.core-tempo-select-native-hidden {
  display: none !important;
}

.core-tempo-menu {
  width: 100%;
  max-width: none;
  flex: 1 1 auto;
}

.core-tempo-menu .core-tempo-menu-trigger-label {
  flex: 1 1 auto;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.core-tempo-menu .core-tempo-menu-panel {
  min-width: 100%;
  z-index: 62;
}

.core-tempo-menu.is-disabled .core-tempo-menu-trigger {
  opacity: 0.55;
  pointer-events: none;
}

.transport-input-menu-item,
.transport-input-submenu-item {
  display: block;
  width: 100%;
  min-height: 30px;
  border: 1px solid transparent;
  border-radius: 7px;
  background: transparent;
  color: var(--text);
  padding: 6px 10px;
  font-size: 11px;
  text-align: left;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.transport-input-menu-item:hover,
.transport-input-submenu-item:hover {
  border-color: rgba(164, 178, 204, 0.45);
  background: rgba(163, 178, 208, 0.12);
}

.transport-input-menu-item.is-group {
  position: relative;
  padding-right: 24px;
  display: flex;
  align-items: center;
  overflow: visible;
}

.transport-input-menu-item.is-group::before {
  content: "";
  position: absolute;
  top: -4px;
  bottom: -4px;
  left: 100%;
  width: 10px;
}

.transport-input-menu-group-label {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.transport-input-menu-item.is-group::after {
  content: "▸";
  position: absolute;
  right: 8px;
  font-size: 13px;
  color: var(--muted);
  line-height: 1;
  opacity: 1;
}

.header-quality-menu.is-open .header-quality-menu-trigger-chevron,
.transport-input-menu.is-open .transport-input-menu-trigger-chevron,
.export-settings-menu.is-open .export-settings-menu-trigger-chevron,
.preferences-menu.is-open .preferences-menu-trigger-chevron {
  color: #ffffff;
}

.header-quality-menu-item.is-group:hover::after,
.transport-input-menu-item.is-group:hover::after {
  color: #ffffff;
}

.transport-input-submenu {
  display: none;
  position: absolute;
  top: -5px;
  left: calc(100% - 1px);
  min-width: 220px;
  border: 1px solid var(--transport-shell-border);
  border-radius: 10px;
  background: linear-gradient(180deg, rgba(8, 14, 24, 0.98) 0%, rgba(5, 10, 18, 0.98) 100%);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.45);
  padding: 4px;
  z-index: 121;
}

.transport-input-menu-item.is-group:hover > .transport-input-submenu,
.transport-input-menu-item.is-group:focus-within > .transport-input-submenu {
  display: grid;
  gap: 2px;
}

.transport-input-submenu-item.is-active,
.transport-input-menu-direct.is-active {
  border-color: rgba(95, 240, 190, 0.56);
  background: rgba(95, 240, 190, 0.2);
}

.transport-input-submenu-empty {
  min-height: 30px;
  border-radius: 7px;
  display: flex;
  align-items: center;
  padding: 6px 10px;
  font-size: 11px;
  color: var(--muted);
}

.transport-input-upload {
  display: none;
}

.export-settings-menu {
  position: relative;
  display: inline-flex;
  align-items: center;
}

.header-controls .export-settings-menu-trigger {
  min-width: 0;
  min-height: 0;
  padding: 6px 12px;
  border-radius: 9px;
  border: 1px solid var(--stroke);
  background: linear-gradient(180deg, rgba(8, 14, 24, 0.95) 0%, rgba(5, 10, 18, 0.96) 100%);
  color: var(--text);
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  cursor: pointer;
  font-family: inherit;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 11px;
  line-height: 1.2;
}

.header-controls .export-settings-menu-trigger:hover,
.header-controls .export-settings-menu.is-open .export-settings-menu-trigger {
  border-color: var(--transport-btn-hover-border);
  box-shadow: none;
}

.export-settings-menu.is-open .export-settings-menu-trigger {
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
  position: relative;
  z-index: 81;
}

.export-settings-menu-trigger-label {
  font-weight: 700;
}

.export-settings-menu-trigger-chevron {
  font-size: 13px;
  color: var(--muted);
  line-height: 1;
  opacity: 1;
}

.export-settings-menu-panel {
  display: none;
  position: absolute;
  right: 0;
  top: calc(100% - 1px);
  z-index: 80;
  width: min(260px, 80vw);
  min-width: 100%;
  border: 1px solid var(--transport-shell-border);
  border-radius: 0 0 10px 10px;
  background: linear-gradient(180deg, rgba(8, 14, 24, 0.98) 0%, rgba(5, 10, 18, 0.98) 100%);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.45);
  padding: 8px;
  gap: 6px;
}

.export-settings-menu.is-open .export-settings-menu-panel {
  display: grid;
}

.export-settings-menu-native-hidden {
  display: none !important;
}

.export-settings-menu-row {
  display: grid;
  gap: 4px;
}

.export-settings-menu-row-label {
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted);
}

.export-settings-menu-select {
  width: 100%;
  min-height: 30px;
  border-radius: 7px;
  border: 1px solid var(--transport-shell-border);
  background: rgba(12, 20, 34, 0.92);
  color: var(--text);
  padding: 6px 9px;
  font-size: 11px;
  font-family: inherit;
}

.export-settings-menu-select:focus-visible {
  outline: 1px solid var(--accent);
  outline-offset: 1px;
}

.export-settings-menu-item {
  width: 100%;
}

.export-settings-menu-group-value {
  margin-left: auto;
  padding-right: 8px;
  color: var(--muted);
  font-size: 10px;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  white-space: nowrap;
  pointer-events: none;
}

.preferences-menu {
  position: relative;
  display: inline-flex;
  align-items: center;
}

.shortcuts-menu {
  position: relative;
  display: inline-flex;
  align-items: center;
}

.header-controls .preferences-menu-trigger,
.header-controls .shortcuts-menu-trigger {
  min-width: 0;
  min-height: 0;
  padding: 6px 12px;
  border-radius: 9px;
  border: 1px solid var(--stroke);
  background: linear-gradient(180deg, rgba(8, 14, 24, 0.95) 0%, rgba(5, 10, 18, 0.96) 100%);
  color: var(--text);
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  cursor: pointer;
  font-family: inherit;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 11px;
  line-height: 1.2;
}

.header-controls .preferences-menu-trigger:hover,
.header-controls .preferences-menu.is-open .preferences-menu-trigger,
.header-controls .shortcuts-menu-trigger:hover,
.header-controls .shortcuts-menu.is-open .shortcuts-menu-trigger {
  border-color: var(--transport-btn-hover-border);
  box-shadow: none;
}

.preferences-menu.is-open .preferences-menu-trigger,
.shortcuts-menu.is-open .shortcuts-menu-trigger {
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
  position: relative;
  z-index: 83;
}

.preferences-menu-trigger-label,
.shortcuts-menu-trigger-label {
  font-weight: 700;
}

.preferences-menu-trigger-chevron,
.shortcuts-menu-trigger-chevron {
  font-size: 13px;
  color: var(--muted);
  line-height: 1;
  opacity: 1;
}

.preferences-menu-panel,
.shortcuts-menu-panel {
  display: none;
  position: absolute;
  right: 0;
  top: calc(100% - 1px);
  z-index: 82;
  width: min(320px, 88vw);
  min-width: 100%;
  max-height: min(72vh, 680px);
  overflow-x: hidden;
  overflow-y: auto;
  overscroll-behavior: contain;
  border: 1px solid var(--transport-shell-border);
  border-radius: 0 0 10px 10px;
  background: linear-gradient(180deg, rgba(8, 14, 24, 0.98) 0%, rgba(5, 10, 18, 0.98) 100%);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.45);
  padding: 8px;
  gap: 8px;
}

.preferences-menu.is-open .preferences-menu-panel,
.shortcuts-menu.is-open .shortcuts-menu-panel {
  display: grid;
}

.preferences-menu-section {
  display: grid;
  gap: 6px;
  border: 1px solid rgba(127, 146, 176, 0.28);
  border-radius: 8px;
  padding: 7px;
  background: rgba(17, 26, 42, 0.45);
}

.preferences-menu-subsection {
  display: grid;
  gap: 6px;
}

.preferences-menu-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.preferences-menu-section-title,
.preferences-menu-shortcuts-title {
  margin: 0;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted);
}

.preferences-menu-section-value {
  font-size: 11px;
  color: var(--text);
}

.preferences-ui-scale-buttons {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
}

.preferences-theme-buttons {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.preferences-palette-buttons {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.preferences-color-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.preferences-color-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 6px;
  align-items: start;
}

.preferences-color-label {
  font-size: 10px;
  color: var(--text);
  line-height: 1;
}

.preferences-color-input {
  width: 100%;
  height: 34px;
  padding: 0;
  border: 1px solid var(--transport-shell-border);
  background: transparent;
  cursor: pointer;
}

.preferences-color-input::-webkit-color-swatch-wrapper {
  padding: 0;
}

.preferences-color-input::-webkit-color-swatch,
.preferences-color-input::-moz-color-swatch {
  border: none;
}

.preferences-shortcut-list {
  display: grid;
  gap: 5px;
}

.preferences-shortcut-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 6px;
  align-items: center;
}

.preferences-shortcut-label {
  font-size: 11px;
  color: var(--text);
}

.preferences-shortcut-btn,
.preferences-ui-scale-btn,
.preferences-menu-reset {
  min-height: 28px;
  border-radius: 7px;
  border: 1px solid var(--transport-shell-border);
  background: rgba(12, 20, 34, 0.92);
  color: var(--text);
  font-size: 11px;
  font-family: inherit;
  letter-spacing: 0.02em;
  cursor: pointer;
  padding: 4px 8px;
  text-transform: none;
}

.preferences-menu-reset {
  justify-self: start;
}

.preferences-shortcut-btn:hover,
.preferences-ui-scale-btn:hover,
.preferences-menu-reset:hover {
  border-color: var(--transport-btn-hover-border);
  background: rgba(29, 40, 60, 0.95);
  transform: none;
}

.preferences-ui-scale-btn.is-active {
  border-color: var(--accent);
  box-shadow: 0 0 0 1px var(--accent-soft);
  color: #ffffff;
}

.preferences-shortcut-btn.is-capturing {
  border-color: var(--accent);
  box-shadow: 0 0 0 1px var(--accent-soft);
  color: #ffffff;
}

.transport-volume {
  width: min(220px, 100%);
  min-width: 120px;
}

.transport-panel-right .transport-volume {
  margin-left: auto;
}

.transport-bar {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  width: auto;
  position: relative;
  z-index: 1;
  min-height: var(--transport-shell-height);
  justify-content: center;
  padding: 7px 10px;
  border-radius: 11px;
  border: 1px solid var(--transport-shell-border);
  background: linear-gradient(180deg, var(--transport-shell-bg-1) 0%, var(--transport-shell-bg-2) 100%);
}

.canvas-actions .transport-bar .btn.transport-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 var(--transport-icon-btn-size);
  width: var(--transport-icon-btn-size);
  min-width: var(--transport-icon-btn-size);
  height: var(--transport-icon-btn-size);
  padding: 0;
  border-radius: var(--transport-icon-btn-radius);
  border: 1px solid var(--transport-btn-border);
  background: linear-gradient(180deg, var(--transport-btn-bg-1) 0%, var(--transport-btn-bg-2) 100%);
  color: var(--transport-btn-text);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8);
  text-transform: none;
  letter-spacing: 0;
}

.canvas-actions .transport-bar .btn.transport-btn:hover {
  border-color: var(--transport-btn-hover-border);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9), 0 0 0 1px var(--transport-btn-hover-ring);
  transform: none;
}

.canvas-actions .transport-bar .btn.transport-btn:active {
  transform: translateY(1px);
}

.canvas-actions .transport-bar .btn.transport-play {
  background: linear-gradient(180deg, var(--transport-play-bg-1) 0%, var(--transport-play-bg-2) 100%);
  border-color: var(--transport-play-border);
  color: var(--transport-play-text);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.35);
}

.canvas-actions .transport-bar .btn.transport-play.is-playing,
.canvas-actions .transport-bar .btn.transport-play:hover {
  border-color: var(--transport-play-border);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.35), 0 0 0 1px var(--transport-play-ring);
}

.transport-glyph {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: auto;
  font-size: 18px;
  line-height: 1;
  font-weight: 700;
  text-align: center;
  pointer-events: none;
}

.canvas-actions .transport-bar .btn.transport-play .transport-glyph,
.queue-timeline-toolbar .timeline-play-btn .transport-glyph {
  transform: translateX(1px);
}

.canvas-actions .transport-bar .btn.transport-play.is-playing .transport-glyph,
.queue-timeline-toolbar .timeline-play-btn.is-playing .transport-glyph {
  transform: translateX(0);
}

.transport-record .transport-glyph {
  color: var(--transport-record-color);
}

.transport-record.is-recording .transport-glyph {
  color: var(--accent);
}

.canvas-actions .transport-bar .btn.transport-record {
  margin-left: 8px;
}

.canvas-actions .transport-bar .btn.transport-record.is-recording {
  border-color: var(--accent);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.35), 0 0 0 1px var(--accent-soft), 0 0 14px var(--accent-soft);
  animation: transport-record-pulse 1.15s ease-in-out infinite;
}

.canvas-actions .transport-bar .btn.transport-record.is-recording .transport-glyph svg rect {
  fill: currentColor;
  stroke: none;
}

@keyframes transport-record-pulse {
  0%,
  100% {
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.35), 0 0 0 1px var(--accent-soft), 0 0 10px rgba(95, 240, 190, 0.15);
  }

  50% {
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.35), 0 0 0 1px var(--accent), 0 0 20px rgba(95, 240, 190, 0.48);
  }
}

.sound-canvas.is-recording {
  border-color: var(--accent) !important;
  box-shadow:
    inset 0 0 20px rgba(0, 0, 0, 0.45),
    0 0 0 1px var(--accent-soft),
    0 0 16px var(--accent-soft);
  animation: canvas-record-pulse 1.15s ease-in-out infinite;
}

@keyframes canvas-record-pulse {
  0%,
  100% {
    border-color: var(--accent);
    box-shadow:
      inset 0 0 20px rgba(0, 0, 0, 0.45),
      0 0 0 1px var(--accent-soft),
      0 0 12px var(--accent-soft);
  }

  50% {
    border-color: var(--accent);
    box-shadow:
      inset 0 0 20px rgba(0, 0, 0, 0.45),
      0 0 0 1px var(--accent),
      0 0 24px var(--accent-soft);
  }
}

.canvas-actions .transport-bar .btn.transport-btn.icon-only {
  color: var(--transport-btn-text);
  text-indent: 0;
}

.canvas-actions .transport-bar .btn.transport-btn.icon-only .transport-glyph {
  display: inline-flex;
}

.canvas-overlay-actions .canvas-fullscreen-btn .transport-glyph svg,
.canvas-actions .transport-bar .btn .transport-glyph svg,
.queue-timeline-toolbar .timeline-play-btn .transport-glyph svg {
  width: 18px;
  height: 18px;
  display: block;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.transport-btn .btn-label {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.canvas-actions .transport-bar .btn.transport-btn:disabled {
  background: linear-gradient(180deg, var(--transport-disabled-bg-1) 0%, var(--transport-disabled-bg-2) 100%);
  border-color: var(--transport-disabled-border);
  opacity: 0.55;
}

.btn {
  font-family: inherit;
  height: 42px;
  padding: 8px 10px;
  border-radius: 8px;
  border: 1px solid #2c3442;
  background: linear-gradient(180deg, #242c3a 0%, #161a22 100%);
  color: var(--text);
  text-transform: uppercase;
  font-size: 11px;
  letter-spacing: 1px;
  font-weight: 600;
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.btn.is-active {
  border-color: var(--accent);
  background: linear-gradient(180deg, rgba(95, 240, 190, 0.35) 0%, rgba(95, 240, 190, 0.15) 100%);
  color: #ffe8ff;
}

.btn:hover {
  border-color: var(--accent);
  box-shadow: 0 0 10px rgba(95, 240, 190, 0.25);
  transform: translateY(-1px);
}

.btn:active {
  transform: translateY(0);
}

.btn-primary:not(.transport-play) {
  background: linear-gradient(180deg, rgba(95, 240, 190, 0.4) 0%, rgba(95, 240, 190, 0.1) 100%);
  border-color: rgba(95, 240, 190, 0.6);
  color: #ffe8ff;
}

.btn.secondary {
  background: linear-gradient(180deg, #232a36 0%, #141922 100%);
}

.btn.icon-only {
  position: relative;
  color: transparent;
  text-shadow: none;
  text-indent: -9999px;
  overflow: hidden;
}

body.tooltips-enabled .btn.icon-only {
  overflow: visible;
}

.btn.icon-only::before {
  content: "";
  position: absolute;
  inset: 0;
  background-repeat: no-repeat;
  background-position: center;
  background-size: 20px 20px;
  filter: invert(1);
}

body[data-theme="light"] .btn.icon-only::before {
  filter: invert(0);
}

.canvas-actions .transport-bar .btn.transport-btn.icon-only::before {
  display: none;
  left: 50%;
  top: 50%;
  width: 34px;
  height: 34px;
  inset: auto;
  transform: translate(-50%, -50%);
  background-size: contain;
}

#download-record.icon-only::before {
  background-image: url("icons/download.png");
}

#fullscreen-btn.icon-only::before {
  background-image: url("icons/vollbild.png");
}

#queue-add-canvas.icon-only::before {
  background-image: url("icons/InPlaylistUebernehmen.png");
}

#apply-settings.icon-only::before {
  background-image: url("icons/einstellungenuebernehmen.png");
}

.btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

.btn-play {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  width: 42px;
  min-width: 42px;
  padding: 0;
}

.btn-play .btn-icon {
  position: relative;
  width: 12px;
  height: 12px;
}

.btn-play .btn-icon::before {
  content: "";
  position: absolute;
  left: 2px;
  top: 1px;
  width: 0;
  height: 0;
  border-top: 5px solid transparent;
  border-bottom: 5px solid transparent;
  border-left: 8px solid var(--text);
}

.btn-play.is-playing .btn-icon::before {
  left: 1px;
  top: 0;
  width: 4px;
  height: 12px;
  border: none;
  background: var(--text);
}

.btn-play.is-playing .btn-icon::after {
  content: "";
  position: absolute;
  left: 7px;
  top: 0;
  width: 4px;
  height: 12px;
  background: var(--text);
}

.btn-play .btn-label,
.btn-record .btn-label {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.btn-record {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  min-width: 42px;
  padding: 0;
}

.btn-record .btn-icon {
  width: 12px;
  height: 12px;
  position: relative;
}

.btn-record .btn-icon::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: var(--red);
  box-shadow: 0 0 8px rgba(255, 92, 122, 0.6);
}

.btn-record.is-recording .btn-icon::before {
  border-radius: 2px;
  box-shadow: 0 0 8px rgba(255, 92, 122, 0.5);
}

.theme-toggle {
  padding: 6px 12px;
  border-radius: 10px;
  border: 1px solid rgba(95, 240, 190, 0.45);
  background: rgba(15, 19, 27, 0.8);
  color: var(--text);
  cursor: pointer;
  font: inherit;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 11px;
}

.theme-toggle:hover {
  border-color: var(--accent);
  color: #ffe8ff;
  box-shadow: 0 0 10px rgba(95, 240, 190, 0.25);
}

body:not([data-theme="minimal"]) .btn:not(.transport-btn):hover,
body:not([data-theme="minimal"]) .tab-btn:hover,
body:not([data-theme="minimal"]) .theme-toggle:hover,
body:not([data-theme="minimal"]) button:not(.transport-btn):not(.transport-input-menu-trigger):not(.transport-input-menu-item):not(.transport-input-submenu-item):not(.header-quality-menu-trigger):not(.header-quality-menu-item):not(.header-quality-submenu-item):not(.export-settings-menu-trigger):not(.preferences-menu-trigger):not(.preferences-shortcut-btn):not(.preferences-ui-scale-btn):not(.preferences-menu-reset):not(:disabled):hover,
body:not([data-theme="minimal"]) .header-btn:hover {
  border-color: var(--transport-btn-hover-border);
  box-shadow: none;
  transform: none;
}

body[data-theme="studio"] .btn:not(.transport-btn):hover,
body[data-theme="studio"] .theme-toggle:hover,
body[data-theme="studio"] button:not(.transport-btn):not(.transport-input-menu-trigger):not(.transport-input-menu-item):not(.transport-input-submenu-item):not(.header-quality-menu-trigger):not(.header-quality-menu-item):not(.header-quality-submenu-item):not(.export-settings-menu-trigger):not(.preferences-menu-trigger):not(.preferences-shortcut-btn):not(.preferences-ui-scale-btn):not(.preferences-menu-reset):not(:disabled):hover,
body[data-theme="studio"] .header-btn:hover {
  border-color: var(--studio-btn-border-hover);
  box-shadow: var(--studio-btn-shadow) var(--studio-btn-depth) var(--studio-btn-depth) 0 0;
  transform: none;
}

.pro-only {
  display: none;
}

.pro-enabled .pro-only {
  display: grid;
}

.pro-enabled .header-quality {
  display: flex;
}

.pro-enabled .canvas-actions .pro-only {
  display: inline-flex;
}

.pro-enabled .sound-canvas .pro-only {
  display: inline-flex;
}

#sound-canvas.palette-bw,
#sound-canvas.palette-invert,
#sound-canvas:fullscreen.palette-bw,
#sound-canvas:fullscreen.palette-invert,
#sound-canvas:-webkit-full-screen.palette-bw,
#sound-canvas:-webkit-full-screen.palette-invert {
  border-color: rgba(255, 255, 255, 0.65);
}

#sound-canvas.palette-invert canvas {
  filter: invert(1) hue-rotate(180deg);
}

#sound-canvas.palette-bw canvas {
  filter: grayscale(1) contrast(2) brightness(1.05);
}

#sound-canvas:fullscreen.palette-invert canvas,
#sound-canvas:-webkit-full-screen.palette-invert canvas,
#sound-canvas.palette-invert canvas {
  filter: invert(1) hue-rotate(180deg) !important;
}

#sound-canvas:fullscreen.palette-bw canvas,
#sound-canvas:-webkit-full-screen.palette-bw canvas,
#sound-canvas.palette-bw canvas {
  filter: grayscale(1) contrast(2) brightness(1.05) !important;
}

.hidden {
  opacity: 0;
  pointer-events: none;
}

@media (max-width: 1100px) {
  .page {
    padding: calc(var(--header-height) + 12px) 16px 16px;
  }

  .legal-main {
    padding: calc(var(--header-height) + 20px) 16px 60px;
  }

  .vislab-header {
    left: 16px;
    right: 16px;
  }

  .hero {
    grid-template-columns: 1fr;
    grid-template-rows: 1fr 0.8fr;
    gap: 12px;
  }

  .tab-panel {
    grid-template-columns: 1fr;
  }

  .canvas-actions {
    gap: 6px;
  }

  .queue-timeline-shell {
    min-height: 66px;
    padding: 7px 8px;
  }

  .queue-timeline-lane {
    --queue-lane-height: 48px;
  }

  .canvas-actions .btn {
    flex-basis: 120px;
  }

  .transport-layout {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .transport-panel {
    justify-content: center;
  }

  .transport-panel .transport-input {
    max-width: 100%;
  }

  .transport-panel-right .transport-volume {
    margin-left: 0;
    width: 100%;
    max-width: 260px;
  }

  .transport-bar {
    flex-wrap: wrap;
  }
}

@media (max-width: 720px) {
  :root {
    --header-height: 108px;
    --transport-icon-btn-size: 36px;
    --transport-icon-btn-radius: 8px;
  }

  .hero {
    grid-template-rows: 1fr 0.7fr;
  }

  h1 {
    font-size: 26px;
  }

  .intro-text {
    font-size: 12px;
  }

  .controls-shell {
    padding: 8px;
  }

  .btn {
    font-size: 10px;
  }

  .vislab-header {
    min-height: var(--header-height);
  }

  .header-links a {
    padding: 4px 8px;
    font-size: 9px;
  }

  .queue-row {
    grid-template-columns: 1fr;
  }

  .queue-timeline-shell {
    min-height: 60px;
    padding: 6px 7px;
  }

  .queue-timeline-lane {
    --queue-lane-height: 44px;
    gap: 0;
  }

  .queue-timeline-block {
    min-width: 1px;
    --queue-resize-hit-width: 16px;
    --queue-resize-grip-width: 5px;
    padding: 5px 18px 5px 7px;
  }

  .queue-timeline-name {
    font-size: 10px;
  }

  .queue-timeline-duration {
    font-size: 9px;
  }

  .queue-timeline-resize::before {
    right: 4px;
  }

  .canvas-actions .transport-bar .btn.transport-btn {
    flex: 0 0 var(--transport-icon-btn-size);
    width: var(--transport-icon-btn-size);
    min-width: var(--transport-icon-btn-size);
    height: var(--transport-icon-btn-size);
  }

  .header-controls .export-settings-menu-trigger {
    min-width: 0;
  }

  .header-controls .preferences-menu-trigger {
    min-width: 0;
  }

  .transport-glyph {
    font-size: 16px;
  }

  .canvas-actions .transport-bar .btn.transport-btn.icon-only::before {
    width: 30px;
    height: 30px;
  }
}

@media (max-width: 720px) and (orientation: portrait) {
  .hero {
    grid-template-rows: 1fr 0.95fr;
  }

  .sound-canvas {
    min-height: clamp(260px, 48vh, 520px);
    align-items: stretch;
    justify-content: stretch;
  }

  .sound-canvas canvas {
    width: 100% !important;
    height: 100% !important;
    max-width: none;
    max-height: none;
    object-fit: cover;
  }
}

/* Top tab buttons: hover should only show a subtle gray outline (no 3D effect). */
body .tab-buttons .tab-btn {
  transition: none;
}

body .tab-buttons button.tab-btn:hover {
  border-color: #6f788a;
  background: transparent;
  box-shadow: none;
  transform: none;
}

body .tab-buttons button.tab-btn.active:hover {
  border-color: #6f788a;
  box-shadow: none;
  transform: none;
}

/* Higher specificity override for global button:hover theme rules. */
body:not([data-theme="minimal"]) .tab-buttons button.tab-btn:hover,
body[data-theme="studio"] .tab-buttons button.tab-btn:hover,
body[data-theme="light"] .tab-buttons button.tab-btn:hover,
body[data-theme="dark"] .tab-buttons button.tab-btn:hover {
  border-color: #6f788a;
  background: transparent;
  box-shadow: none;
  transform: none;
}

body:not([data-theme="minimal"]) .tab-buttons button.tab-btn.active:hover,
body[data-theme="studio"] .tab-buttons button.tab-btn.active:hover,
body[data-theme="light"] .tab-buttons button.tab-btn.active:hover,
body[data-theme="dark"] .tab-buttons button.tab-btn.active:hover {
  border-color: #6f788a;
  box-shadow: none;
  transform: none;
}

/* Header top links (Privacy / Imprint): same flat hover behavior. */
body .header-links a:hover,
body .header-links a[aria-current="page"] {
  border-color: #6f788a;
  background: transparent;
  box-shadow: none;
  transform: none;
}

/* Global hard-edge mode: remove all rounded corners */
body *,
body *::before,
body *::after {
  border-radius: 0 !important;
}

/* Pro mode */
body[data-theme="pro"],
body[data-theme="pro-dark"] {
  --panel: var(--vislab-ui-surface-1);
  --panel-2: var(--vislab-ui-surface-2);
  --stroke: var(--vislab-ui-stroke);
  --text: var(--vislab-ui-text);
  --muted: var(--vislab-ui-muted);
  --accent: var(--vislab-ui-accent);
  --accent-soft: var(--vislab-ui-accent-soft);
  --blue: #5ff0be;
  --red: var(--vislab-ui-accent);
  --fader-track: var(--vislab-ui-black);
  --fader-border: var(--vislab-ui-gray-3);
  --fader-thumb-border: var(--vislab-ui-gray-2);
  --transport-shell-bg-1: var(--vislab-ui-surface-1);
  --transport-shell-bg-2: var(--vislab-ui-surface-2);
  --transport-shell-border: var(--vislab-ui-stroke);
  --transport-btn-bg-1: var(--vislab-ui-dark-btn-bg);
  --transport-btn-bg-2: color-mix(in srgb, var(--vislab-ui-dark-btn-bg) 76%, var(--vislab-ui-black));
  --transport-btn-border: var(--vislab-ui-black);
  --transport-btn-text: #eceef0;
  --transport-btn-hover-border: var(--vislab-ui-gray-3);
  --transport-btn-hover-ring: rgba(0, 0, 0, 0.22);
  --transport-play-bg-1: var(--vislab-ui-dark-btn-bg);
  --transport-play-bg-2: color-mix(in srgb, var(--vislab-ui-dark-btn-bg) 76%, var(--vislab-ui-black));
  --transport-play-border: var(--vislab-ui-accent);
  --transport-play-text: #eceef0;
  --transport-play-ring: rgba(0, 0, 0, 0.25);
  --transport-record-color: #ffffff;
  --transport-disabled-bg-1: var(--vislab-ui-gray-2);
  --transport-disabled-bg-2: color-mix(in srgb, var(--vislab-ui-gray-2) 80%, var(--vislab-ui-gray-3));
  --transport-disabled-border: var(--vislab-ui-gray-3);
  --transport-icon-filter: invert(1);
  --timeline-shell-bg-1: color-mix(in srgb, var(--vislab-ui-gray-3) 82%, var(--vislab-ui-black));
  --timeline-shell-bg-2: var(--vislab-ui-black);
  --timeline-shell-border: var(--vislab-ui-gray-3);
  --timeline-block-bg-1: color-mix(in srgb, var(--vislab-ui-gray-3) 78%, var(--vislab-ui-black));
  --timeline-block-bg-2: color-mix(in srgb, var(--vislab-ui-gray-3) 50%, var(--vislab-ui-black));
  --timeline-block-border: var(--vislab-ui-gray-2);
  --timeline-block-active-border: var(--vislab-ui-accent);
  --timeline-block-active-glow: color-mix(in srgb, var(--vislab-ui-accent) 30%, transparent);
  --timeline-cursor: var(--vislab-ui-accent);
  --timeline-bar-a: rgba(234, 239, 248, 0.45);
  --timeline-bar-b: rgba(234, 239, 248, 0.12);
  --timeline-grid-major: rgba(232, 238, 250, 0.46);
  --timeline-grid-minor: rgba(232, 238, 250, 0.2);
  --timeline-grid-major-width: 1px;
  --timeline-grid-minor-width: 1px;
  font-family: "Montserrat", "Rajdhani", Arial, sans-serif;
  background: radial-gradient(circle at top, color-mix(in srgb, var(--vislab-ui-surface-1) 92%, #ffffff) 0%, var(--vislab-ui-surface-1) 52%, var(--vislab-ui-surface-2) 100%);
}

body[data-theme="pro"]::before,
body[data-theme="pro-dark"]::before {
  opacity: 0;
  background: none;
}

body[data-theme="pro"] .vislab-loader,
body[data-theme="pro-dark"] .vislab-loader {
  background: var(--vislab-ui-surface-2);
  color: var(--vislab-ui-text);
}

body[data-theme="pro"] .vislab-header,
body[data-theme="pro-dark"] .vislab-header {
  background: linear-gradient(180deg, color-mix(in srgb, var(--vislab-ui-surface-1) 96%, #ffffff) 0%, var(--vislab-ui-surface-2) 100%);
  border: 0;
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--vislab-ui-surface-1) 90%, #ffffff), 0 10px 20px rgba(0, 0, 0, 0.18);
  border-radius: 12px !important;
}

body[data-theme="pro"] .vislab-title,
body[data-theme="pro-dark"] .vislab-title {
  color: var(--vislab-ui-text);
}

body[data-theme="pro"] .hero,
body[data-theme="pro-dark"] .hero {
  background: linear-gradient(180deg, color-mix(in srgb, var(--vislab-ui-surface-1) 92%, #ffffff) 0%, var(--vislab-ui-surface-2) 100%);
  border: 0;
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--vislab-ui-surface-1) 88%, #ffffff), 0 8px 16px rgba(0, 0, 0, 0.16);
  border-radius: 14px !important;
}

body[data-theme="pro"] .controls-shell,
body[data-theme="pro-dark"] .controls-shell,
body[data-theme="pro"] .tab-panel,
body[data-theme="pro-dark"] .tab-panel,
body[data-theme="pro"] .control,
body[data-theme="pro-dark"] .control {
  border: 0;
  background: transparent;
  box-shadow: none;
}

body[data-theme="pro"] .core-section,
body[data-theme="pro-dark"] .core-section {
  border: 1px solid var(--vislab-ui-stroke);
  background: linear-gradient(180deg, color-mix(in srgb, var(--vislab-ui-surface-1) 94%, #ffffff) 0%, var(--vislab-ui-surface-2) 100%);
  border-radius: 10px !important;
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--vislab-ui-surface-1) 70%, #ffffff);
}

body[data-theme="pro"] .tab-buttons,
body[data-theme="pro-dark"] .tab-buttons {
  background: linear-gradient(180deg, #2f3238 0%, #22252b 100%);
  border-color: #111317;
  border-radius: 8px !important;
}

body[data-theme="pro"] .tab-btn,
body[data-theme="pro-dark"] .tab-btn {
  color: #c9c9c9;
  border-radius: 8px !important;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 700;
}

body[data-theme="pro"] .tab-btn.active,
body[data-theme="pro-dark"] .tab-btn.active {
  color: #ffffff;
  background: linear-gradient(180deg, var(--vislab-ui-accent-light) 0%, var(--vislab-ui-accent-dark) 100%);
  border-color: transparent;
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--vislab-ui-accent-light) 75%, transparent);
}

body[data-theme="pro"] .tab-active-frame,
body[data-theme="pro-dark"] .tab-active-frame {
  border-color: var(--vislab-ui-accent);
  background: var(--vislab-ui-accent-overlay-20);
}

body[data-theme-variant="pro-light"] .tab-buttons {
  position: relative;
  overflow: hidden;
  padding: 1px;
  border: 2px solid #111317;
  border-radius: 12px !important;
  background: linear-gradient(180deg, #2f3238 0%, #22252b 100%);
  box-shadow: 1px 1px 1px rgba(255, 255, 255, 0.14);
}

body[data-theme-variant="pro-light"] .tab-buttons::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  box-shadow:
    inset 0 6px 10px rgba(0, 0, 0, 0.9),
    inset 0 -3px 3px rgba(255, 255, 255, 0.08),
    inset 2px 0 3px rgba(0, 0, 0, 0.5),
    inset -2px 0 2px rgba(255, 255, 255, 0.06),
    inset 0 0 0 1px rgba(0, 0, 0, 0.65);
}

body[data-theme-variant="pro-light"] .tab-btn {
  position: relative;
  z-index: 2;
  box-sizing: border-box;
  height: 100%;
  border-radius: 10px !important;
  border: 2px solid transparent;
  color: #c9c9c9;
  background: transparent;
  transition: none !important;
}

body[data-theme-variant="pro-light"] .tab-btn.active {
  color: #010101 !important;
  border-color: transparent !important;
  background: transparent !important;
  box-shadow: none !important;
}

body[data-theme-variant="pro-light"] .tab-btn.active:hover {
  border-color: transparent !important;
  background: transparent !important;
  box-shadow: none !important;
}

body[data-theme-variant="pro-light"] .tab-active-frame {
  display: block !important;
  z-index: 1;
  pointer-events: auto;
  cursor: ew-resize;
  box-sizing: border-box;
  border: 1px solid #010101;
  border-radius: 9px !important;
  clip-path: inset(0 round 9px);
  background: var(--vislab-ui-accent);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80' viewBox='0 0 80 80'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='80' height='80' filter='url(%23n)' opacity='0.22'/%3E%3C/svg%3E");
  background-size: 80px 80px;
  background-repeat: repeat;
  box-shadow:
    inset 1px 1px 1px color-mix(in srgb, var(--vislab-ui-accent-light) 90%, transparent),
    inset -1px -1px 1px color-mix(in srgb, var(--vislab-ui-accent-dark) 95%, transparent),
    1px 1px 2px rgba(0, 0, 0, 0.6),
    1px 1px 1px rgba(255, 255, 255, 0.35);
}

body[data-theme-variant="pro-light"] .tab-buttons button.tab-btn:hover,
body[data-theme-variant="pro-light"] .tab-buttons button.tab-btn.active:hover,
body[data-theme-variant="pro-light"] .tab-buttons button.tab-btn:focus,
body[data-theme-variant="pro-light"] .tab-buttons button.tab-btn:focus-visible {
  border-color: transparent !important;
  background: transparent !important;
  box-shadow: none !important;
  transform: none !important;
  filter: none !important;
  outline: none !important;
}

body[data-theme="pro"] .core-section-head,
body[data-theme="pro-dark"] .core-section-head {
  border: 0;
  background: transparent;
}

body[data-theme="pro"] .core-section-title,
body[data-theme="pro-dark"] .core-section-title,
body[data-theme="pro"] .core-section-chevron,
body[data-theme="pro-dark"] .core-section-chevron,
body[data-theme="pro"] .header-label,
body[data-theme="pro-dark"] .header-label,
body[data-theme="pro"] .transport-label,
body[data-theme="pro-dark"] .transport-label {
  color: var(--vislab-ui-text);
}

body[data-theme="pro"] .core-tile,
body[data-theme="pro-dark"] .core-tile {
  border-color: var(--vislab-ui-black);
  background-color: var(--vislab-ui-black);
  border-radius: 8px !important;
}

body[data-theme="pro"] .core-tile-label,
body[data-theme="pro-dark"] .core-tile-label {
  background: rgba(10, 12, 16, 0.6);
}

body[data-theme="pro"] select,
body[data-theme="pro-dark"] select,
body[data-theme="pro"] input[type="url"],
body[data-theme="pro-dark"] input[type="url"],
body[data-theme="pro"] input[type="number"],
body[data-theme="pro-dark"] input[type="number"],
body[data-theme="pro"] textarea,
body[data-theme="pro-dark"] textarea,
body[data-theme="pro"] .transport-input,
body[data-theme="pro-dark"] .transport-input {
  background: var(--vislab-ui-light-btn-bg);
  color: var(--vislab-ui-text);
  border-color: var(--vislab-ui-stroke);
  border-radius: 8px !important;
  box-shadow: inset 0 1px 1px color-mix(in srgb, var(--vislab-ui-gray-1) 76%, #ffffff);
}

body[data-theme="pro"] .header-quality-menu-panel,
body[data-theme="pro-dark"] .header-quality-menu-panel,
body[data-theme="pro"] .export-settings-menu-panel,
body[data-theme="pro-dark"] .export-settings-menu-panel,
body[data-theme="pro"] .shortcuts-menu-panel,
body[data-theme="pro-dark"] .shortcuts-menu-panel,
body[data-theme="pro"] .preferences-menu-panel,
body[data-theme="pro-dark"] .preferences-menu-panel,
body[data-theme="pro"] .transport-input-menu-panel,
body[data-theme="pro-dark"] .transport-input-menu-panel,
body[data-theme="pro"] .queue-clip-context-menu,
body[data-theme="pro-dark"] .queue-clip-context-menu,
body[data-theme="pro"] .queue-transition-picker,
body[data-theme="pro-dark"] .queue-transition-picker,
body[data-theme-variant="pro-light"] .queue-clip-context-menu,
body[data-theme-variant="pro-light"] .queue-transition-picker,
body[data-theme-variant="pro-light"] .header-quality-menu-panel,
body[data-theme-variant="pro-light"] .export-settings-menu-panel,
body[data-theme-variant="pro-light"] .preferences-menu-panel,
body[data-theme-variant="pro-light"] .transport-input-menu-panel,
body[data-theme-variant="pro-light"] .core-tempo-menu-panel,
body[data-theme="pro"] .transport-input-submenu,
body[data-theme="pro-dark"] .transport-input-submenu,
body[data-theme-variant="pro-light"] .transport-input-submenu,
body[data-theme="pro"] .header-quality-submenu,
body[data-theme="pro-dark"] .header-quality-submenu,
body[data-theme-variant="pro-light"] .header-quality-submenu,
body[data-theme-variant="pro-light"] .export-settings-submenu {
  background: linear-gradient(180deg, color-mix(in srgb, var(--vislab-ui-surface-1) 96%, #ffffff) 0%, var(--vislab-ui-surface-2) 100%);
  border-color: var(--vislab-ui-stroke);
  box-shadow: 0 8px 14px rgba(0, 0, 0, 0.2);
  border-radius: 10px !important;
}

body[data-theme="pro"] .transport-input-menu.is-open .transport-input-menu-trigger,
body[data-theme="pro-dark"] .transport-input-menu.is-open .transport-input-menu-trigger,
body[data-theme="pro"] .header-quality-menu.is-open .header-quality-menu-trigger,
body[data-theme="pro-dark"] .header-quality-menu.is-open .header-quality-menu-trigger,
body[data-theme="pro"] .export-settings-menu.is-open .export-settings-menu-trigger,
body[data-theme="pro-dark"] .export-settings-menu.is-open .export-settings-menu-trigger,
body[data-theme="pro"] .shortcuts-menu.is-open .shortcuts-menu-trigger,
body[data-theme="pro-dark"] .shortcuts-menu.is-open .shortcuts-menu-trigger,
body[data-theme="pro"] .preferences-menu.is-open .preferences-menu-trigger,
body[data-theme="pro-dark"] .preferences-menu.is-open .preferences-menu-trigger,
body[data-theme-variant="pro-light"] .transport-input-menu.is-open .transport-input-menu-trigger,
body[data-theme-variant="pro-light"] .header-quality-menu.is-open .header-quality-menu-trigger,
body[data-theme-variant="pro-light"] .export-settings-menu.is-open .export-settings-menu-trigger,
body[data-theme-variant="pro-light"] .preferences-menu.is-open .preferences-menu-trigger {
  border-bottom-left-radius: 0 !important;
  border-bottom-right-radius: 0 !important;
}

body[data-theme="pro"] .transport-input-menu.is-open .transport-input-menu-panel,
body[data-theme="pro-dark"] .transport-input-menu.is-open .transport-input-menu-panel,
body[data-theme="pro"] .header-quality-menu.is-open .header-quality-menu-panel,
body[data-theme="pro-dark"] .header-quality-menu.is-open .header-quality-menu-panel,
body[data-theme="pro"] .export-settings-menu.is-open .export-settings-menu-panel,
body[data-theme="pro-dark"] .export-settings-menu.is-open .export-settings-menu-panel,
body[data-theme="pro"] .shortcuts-menu.is-open .shortcuts-menu-panel,
body[data-theme="pro-dark"] .shortcuts-menu.is-open .shortcuts-menu-panel,
body[data-theme="pro"] .preferences-menu.is-open .preferences-menu-panel,
body[data-theme="pro-dark"] .preferences-menu.is-open .preferences-menu-panel,
body[data-theme-variant="pro-light"] .transport-input-menu.is-open .transport-input-menu-panel,
body[data-theme-variant="pro-light"] .header-quality-menu.is-open .header-quality-menu-panel,
body[data-theme-variant="pro-light"] .export-settings-menu.is-open .export-settings-menu-panel,
body[data-theme-variant="pro-light"] .preferences-menu.is-open .preferences-menu-panel {
  top: calc(100% - 1px);
  border-top-left-radius: 0 !important;
  border-top-right-radius: 0 !important;
}

body[data-theme="pro"] .header-quality-menu-item,
body[data-theme="pro-dark"] .header-quality-menu-item,
body[data-theme="pro"] .export-settings-menu-row-label,
body[data-theme="pro-dark"] .export-settings-menu-row-label,
body[data-theme="pro"] .preferences-menu-section-title,
body[data-theme="pro-dark"] .preferences-menu-section-title,
body[data-theme="pro"] .queue-clip-context-title,
body[data-theme="pro-dark"] .queue-clip-context-title,
body[data-theme="pro"] .queue-transition-picker-title,
body[data-theme="pro-dark"] .queue-transition-picker-title,
body[data-theme="pro"] .queue-clip-context-field,
body[data-theme="pro-dark"] .queue-clip-context-field,
body[data-theme="pro"] .transport-input-menu-item,
body[data-theme="pro-dark"] .transport-input-menu-item,
body[data-theme="pro"] .transport-input-submenu-item,
body[data-theme="pro-dark"] .transport-input-submenu-item,
body[data-theme="pro"] .header-quality-submenu-item,
body[data-theme="pro-dark"] .header-quality-submenu-item,
body[data-theme="pro"] .header-quality-submenu-heading,
body[data-theme="pro-dark"] .header-quality-submenu-heading,
body[data-theme-variant="pro-light"] .header-quality-menu-item,
body[data-theme-variant="pro-light"] .export-settings-menu-row-label,
body[data-theme-variant="pro-light"] .preferences-menu-section-title,
body[data-theme-variant="pro-light"] .queue-clip-context-title,
body[data-theme-variant="pro-light"] .queue-transition-picker-title,
body[data-theme-variant="pro-light"] .queue-clip-context-field,
body[data-theme-variant="pro-light"] .transport-input-menu-item,
body[data-theme-variant="pro-light"] .transport-input-submenu-item,
body[data-theme-variant="pro-light"] .core-tempo-menu-item,
body[data-theme-variant="pro-light"] .header-quality-submenu-item,
body[data-theme-variant="pro-light"] .header-quality-submenu-heading {
  color: var(--vislab-ui-text);
}

body[data-theme="pro"] .queue-clip-context-input,
body[data-theme="pro-dark"] .queue-clip-context-input,
body[data-theme-variant="pro-light"] .queue-clip-context-input {
  background: var(--vislab-ui-light-btn-bg);
  color: var(--vislab-ui-text);
  border-color: var(--vislab-ui-stroke);
  box-shadow: inset 0 1px 1px color-mix(in srgb, var(--vislab-ui-gray-1) 76%, #ffffff);
}

body[data-theme="pro"] .queue-clip-context-input:focus-visible,
body[data-theme="pro-dark"] .queue-clip-context-input:focus-visible,
body[data-theme-variant="pro-light"] .queue-clip-context-input:focus-visible {
  outline: none;
  border-color: color-mix(in srgb, var(--vislab-ui-accent-dark) 80%, transparent);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--vislab-ui-accent) 32%, transparent), inset 0 1px 1px rgba(255, 255, 255, 0.75);
}

body[data-theme="pro"] .queue-clip-context-menu,
body[data-theme="pro-dark"] .queue-clip-context-menu,
body[data-theme="pro"] .queue-transition-picker,
body[data-theme="pro-dark"] .queue-transition-picker,
body[data-theme-variant="pro-light"] .queue-clip-context-menu,
body[data-theme-variant="pro-light"] .queue-transition-picker {
  border-width: 2px;
  backdrop-filter: none;
}

body[data-theme="pro"] .header-quality-menu-item:hover,
body[data-theme="pro-dark"] .header-quality-menu-item:hover,
body[data-theme="pro"] .header-quality-submenu-item:hover,
body[data-theme="pro-dark"] .header-quality-submenu-item:hover,
body[data-theme="pro"] .transport-input-menu-item:hover,
body[data-theme="pro-dark"] .transport-input-menu-item:hover,
body[data-theme="pro"] .transport-input-submenu-item:hover,
body[data-theme="pro-dark"] .transport-input-submenu-item:hover,
body[data-theme="pro"] .header-quality-submenu-item:hover,
body[data-theme="pro-dark"] .header-quality-submenu-item:hover,
body[data-theme-variant="pro-light"] .header-quality-menu-item:hover,
body[data-theme-variant="pro-light"] .header-quality-submenu-item:hover,
body[data-theme-variant="pro-light"] .core-tempo-menu-item:hover,
body[data-theme-variant="pro-light"] .transport-input-submenu-item:hover,
body[data-theme-variant="pro-light"] .transport-input-menu-item:hover {
  background: var(--vislab-ui-accent-overlay-18);
  border-color: var(--vislab-ui-accent-border-55);
}

body[data-theme="pro"] .header-quality-submenu-item.is-active,
body[data-theme="pro-dark"] .header-quality-submenu-item.is-active,
body[data-theme-variant="pro-light"] .header-quality-submenu-item.is-active,
body[data-theme-variant="pro-light"] .core-tempo-menu-item.is-active,
body[data-theme="pro"] .transport-input-submenu-item.is-active,
body[data-theme="pro-dark"] .transport-input-submenu-item.is-active,
body[data-theme-variant="pro-light"] .transport-input-submenu-item.is-active,
body[data-theme="pro"] .transport-input-menu-direct.is-active,
body[data-theme="pro-dark"] .transport-input-menu-direct.is-active,
body[data-theme-variant="pro-light"] .transport-input-menu-direct.is-active {
  background: var(--vislab-ui-accent-overlay-20);
  border-color: var(--vislab-ui-accent-border-60);
}

body[data-theme-variant="pro-light"] .preferences-menu-section {
  border-color: var(--vislab-ui-stroke);
  background: linear-gradient(180deg, var(--vislab-ui-surface-2) 0%, color-mix(in srgb, var(--vislab-ui-surface-2) 78%, var(--vislab-ui-gray-3)) 100%);
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--vislab-ui-gray-1) 55%, #ffffff);
}

body[data-theme-variant="pro-light"] .preferences-shortcut-btn,
body[data-theme-variant="pro-light"] .preferences-menu-reset {
  min-width: 58px;
  justify-self: end;
}

body[data-theme-variant="pro-light"] .preferences-shortcut-btn,
body[data-theme-variant="pro-light"] .preferences-shortcut-btn > * {
  color: var(--pro-light-btn-text) !important;
}

body[data-theme-variant="pro-light"] .header-quality-menu-item.is-group::after,
body[data-theme-variant="pro-light"] .transport-input-menu-item.is-group::after {
  color: var(--vislab-ui-muted);
}

body[data-theme-variant="pro-light"] .header-quality-menu-item.is-group:hover::after,
body[data-theme-variant="pro-light"] .transport-input-menu-item.is-group:hover::after {
  color: var(--vislab-ui-accent-dark);
}

body[data-theme="pro"] .sound-canvas,
body[data-theme="pro-dark"] .sound-canvas {
  background: #0f1115;
  border-color: #202328;
  box-shadow: inset 0 0 20px rgba(0, 0, 0, 0.55);
  border-radius: 12px !important;
}

body[data-theme="pro"] .preview-off,
body[data-theme="pro-dark"] .preview-off {
  background: rgba(10, 11, 15, 0.7);
  color: #f0f0f0;
}

body[data-theme="pro"] .welcome-modal .session-modal-backdrop,
body[data-theme="pro-dark"] .welcome-modal .session-modal-backdrop {
  background: rgba(12, 14, 17, 0.46);
  backdrop-filter: blur(1px);
}

body[data-theme="pro"] .welcome-modal .welcome-modal-panel,
body[data-theme="pro-dark"] .welcome-modal .welcome-modal-panel {
  border: 1px solid #9e9e9e;
  background: linear-gradient(180deg, #d8d8d8 0%, #c8c8c8 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.78), 0 18px 34px rgba(0, 0, 0, 0.34);
  border-radius: 12px !important;
  color: #1f1f1f;
}

body[data-theme="pro"] .welcome-modal .session-modal-title,
body[data-theme="pro-dark"] .welcome-modal .session-modal-title {
  color: #242424;
}

body[data-theme="pro"] .welcome-modal .welcome-modal-intro,
body[data-theme="pro-dark"] .welcome-modal .welcome-modal-intro,
body[data-theme="pro"] .welcome-modal .welcome-choice-hint,
body[data-theme="pro-dark"] .welcome-modal .welcome-choice-hint,
body[data-theme="pro"] .welcome-modal .session-import-hint,
body[data-theme="pro-dark"] .welcome-modal .session-import-hint {
  color: #4f4f4f;
}

body[data-theme="pro"] .welcome-modal .welcome-choice-card,
body[data-theme="pro-dark"] .welcome-modal .welcome-choice-card {
  border: 1px solid #171a20 !important;
  background: linear-gradient(180deg, #3f444c 0%, #2a2e35 100%) !important;
  color: #eef1f4 !important;
  box-shadow:
    rgba(0, 0, 0, 0.45) 6px 6px 8px,
    rgba(255, 255, 255, 0.18) 1px 1px 1px 0 inset,
    #1f2229 -2px -2px 6px 0 inset !important;
  border-radius: 10px !important;
}

body[data-theme="pro"] .welcome-modal .welcome-choice-title,
body[data-theme="pro-dark"] .welcome-modal .welcome-choice-title,
body[data-theme="pro"] .welcome-modal .session-import-title,
body[data-theme="pro-dark"] .welcome-modal .session-import-title {
  color: #f3f5f8;
}

body[data-theme="pro"] .welcome-modal .welcome-choice-hint,
body[data-theme="pro-dark"] .welcome-modal .welcome-choice-hint {
  color: #c4cbd7;
}

body[data-theme="pro"] .welcome-modal .welcome-choice-card:hover,
body[data-theme="pro-dark"] .welcome-modal .welcome-choice-card:hover {
  border-color: var(--vislab-ui-accent) !important;
  box-shadow:
    rgba(0, 0, 0, 0.45) 6px 6px 8px,
    color-mix(in srgb, var(--vislab-ui-accent-light) 40%, transparent) 0 0 0 1px inset,
    #1f2229 -2px -2px 6px 0 inset !important;
}

body[data-theme="pro"] .welcome-modal .welcome-import-zone,
body[data-theme="pro-dark"] .welcome-modal .welcome-import-zone {
  border: 1px dashed #8d929b;
  background: linear-gradient(180deg, #343941 0%, #252a31 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

body[data-theme="pro"] .welcome-modal .welcome-import-zone.is-dragover,
body[data-theme="pro-dark"] .welcome-modal .welcome-import-zone.is-dragover,
body[data-theme="pro"] .welcome-modal .welcome-import-zone:focus-visible,
body[data-theme="pro-dark"] .welcome-modal .welcome-import-zone:focus-visible {
  border-color: var(--vislab-ui-accent);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--vislab-ui-accent) 30%, transparent), inset 0 1px 0 color-mix(in srgb, var(--vislab-ui-accent-light) 28%, transparent);
}

body[data-theme="pro"] .welcome-modal .session-import-pick,
body[data-theme="pro-dark"] .welcome-modal .session-import-pick {
  border: 1px solid #171a20 !important;
  background: linear-gradient(180deg, #3f444c 0%, #2a2e35 100%) !important;
  color: #eef1f4 !important;
  box-shadow:
    rgba(0, 0, 0, 0.4) 5px 5px 7px,
    rgba(255, 255, 255, 0.14) 1px 1px 1px 0 inset,
    #1f2229 -2px -2px 6px 0 inset !important;
}

body[data-theme="pro"] #settings-session-modal .session-modal-backdrop,
body[data-theme-variant="pro-light"] #settings-session-modal .session-modal-backdrop {
  background: rgba(12, 14, 17, 0.46);
  backdrop-filter: blur(1px);
}

body[data-theme="pro"] #settings-session-modal .session-modal-panel,
body[data-theme-variant="pro-light"] #settings-session-modal .session-modal-panel {
  border: 1px solid #9e9e9e;
  background: linear-gradient(180deg, #d8d8d8 0%, #c8c8c8 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.78), 0 18px 34px rgba(0, 0, 0, 0.34);
  border-radius: 12px !important;
  color: #1f1f1f;
}

body[data-theme="pro"] #settings-session-modal .session-modal-head,
body[data-theme-variant="pro-light"] #settings-session-modal .session-modal-head {
  border-bottom: 1px solid rgba(0, 0, 0, 0.14);
  padding-bottom: 8px;
}

body[data-theme="pro"] #settings-session-modal .session-modal-title,
body[data-theme-variant="pro-light"] #settings-session-modal .session-modal-title {
  color: #242424;
}

body[data-theme="pro"] #settings-session-modal .session-export-name-label,
body[data-theme-variant="pro-light"] #settings-session-modal .session-export-name-label {
  color: #4f4f4f;
}

body[data-theme="pro"] #settings-session-modal .session-import-hint,
body[data-theme-variant="pro-light"] #settings-session-modal .session-import-hint {
  color: #4f4f4f;
}

body[data-theme="pro"] #settings-session-modal .session-import-title,
body[data-theme-variant="pro-light"] #settings-session-modal .session-import-title {
  color: #222;
}

body[data-theme="pro"] #settings-session-modal .session-export-name,
body[data-theme-variant="pro-light"] #settings-session-modal .session-export-name {
  background: #ececec;
  color: #212121;
  border-color: #999999;
  box-shadow: inset 0 1px 1px rgba(255, 255, 255, 0.8);
}

body[data-theme="pro"] #settings-session-modal .session-import-zone,
body[data-theme-variant="pro-light"] #settings-session-modal .session-import-zone {
  border: 1px dashed #8d929b;
  background: #ececec;
  box-shadow: inset 0 1px 1px rgba(255, 255, 255, 0.6);
}

body[data-theme="pro"] #settings-session-modal .session-export-name:focus-visible,
body[data-theme-variant="pro-light"] #settings-session-modal .session-export-name:focus-visible,
body[data-theme="pro"] #settings-session-modal .session-import-zone.is-dragover,
body[data-theme-variant="pro-light"] #settings-session-modal .session-import-zone.is-dragover,
body[data-theme="pro"] #settings-session-modal .session-import-zone:focus-visible,
body[data-theme-variant="pro-light"] #settings-session-modal .session-import-zone:focus-visible {
  border-color: var(--vislab-ui-accent);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--vislab-ui-accent) 30%, transparent), inset 0 1px 1px color-mix(in srgb, var(--vislab-ui-accent-light) 55%, transparent);
}

body[data-theme="pro"] #settings-session-modal .session-export-btn,
body[data-theme-variant="pro-light"] #settings-session-modal .session-export-btn,
body[data-theme="pro"] #settings-session-modal .session-import-pick,
body[data-theme-variant="pro-light"] #settings-session-modal .session-import-pick {
  border: 1px solid #171a20 !important;
  background: linear-gradient(180deg, #3f444c 0%, #2a2e35 100%) !important;
  color: #eef1f4 !important;
  box-shadow:
    rgba(0, 0, 0, 0.4) 5px 5px 7px,
    rgba(255, 255, 255, 0.14) 1px 1px 1px 0 inset,
    #1f2229 -2px -2px 6px 0 inset !important;
}

body[data-theme="pro"] #settings-session-modal .session-modal-close,
body[data-theme-variant="pro-light"] #settings-session-modal .session-modal-close {
  border: 1px solid #171a20 !important;
  background: linear-gradient(180deg, #3f444c 0%, #2a2e35 100%) !important;
  color: #eef1f4 !important;
  box-shadow:
    rgba(0, 0, 0, 0.4) 5px 5px 7px,
    rgba(255, 255, 255, 0.14) 1px 1px 1px 0 inset,
    #1f2229 -2px -2px 6px 0 inset !important;
}

body[data-theme-variant="pro-light"] #settings-session-modal .session-modal-title,
body[data-theme-variant="pro-light"] #settings-session-modal .session-export-name-label,
body[data-theme-variant="pro-light"] #settings-session-modal .session-import-title,
body[data-theme-variant="pro-light"] #settings-session-modal .session-import-hint,
body[data-theme-variant="pro-light"] #settings-session-modal .session-export-name,
body[data-theme-variant="pro-light"] #settings-session-modal .session-export-btn,
body[data-theme-variant="pro-light"] #settings-session-modal .session-import-pick {
  font-size: 24px !important;
  letter-spacing: 0.02em !important;
  line-height: 1 !important;
}

body[data-theme-variant="pro-light"] #settings-session-modal .session-modal-close {
  font-size: 30px !important;
  line-height: 1 !important;
}

body[data-theme="pro"] .canvas-actions,
body[data-theme="pro-dark"] .canvas-actions {
  background: transparent;
  border: 0;
  box-shadow: none;
  border-radius: 0 !important;
}

body[data-theme="pro"] .transport-panel,
body[data-theme="pro-dark"] .transport-panel {
  border: 0;
  background: transparent;
  box-shadow: none;
  padding: 0;
}

body[data-theme="pro"] .transport-bar,
body[data-theme="pro-dark"] .transport-bar {
  border: 0;
  background: transparent;
  box-shadow: none;
  padding: 0;
}

body[data-theme="pro"] .queue-timeline-shell,
body[data-theme="pro-dark"] .queue-timeline-shell {
  background: transparent;
  border: 0;
  border-radius: 0 !important;
}

body[data-theme="pro"] .queue-timeline-track,
body[data-theme="pro-dark"] .queue-timeline-track {
  border: 1px solid #6a6e75;
  background: linear-gradient(180deg, #25282e, #1a1d23);
  border-radius: 8px !important;
}

body[data-theme="pro"] .queue-timeline-scrollbar,
body[data-theme="pro-dark"] .queue-timeline-scrollbar {
  border-color: #666a71;
  background: rgba(18, 20, 24, 0.52);
}

body[data-theme="pro"] .queue-timeline-scrollbar-thumb,
body[data-theme="pro-dark"] .queue-timeline-scrollbar-thumb {
  border-color: #7a7f88;
  background: #aeb4bf;
}

body[data-theme="pro"] .queue-timeline-block,
body[data-theme="pro-dark"] .queue-timeline-block,
body[data-theme="pro"] .queue-timeline-preview,
body[data-theme="pro-dark"] .queue-timeline-preview,
body[data-theme="pro"] .queue-timeline-bars,
body[data-theme="pro-dark"] .queue-timeline-bars {
  border-radius: 6px !important;
}

body[data-theme="pro"] .queue-timeline-cursor,
body[data-theme="pro-dark"] .queue-timeline-cursor {
  box-shadow: 0 0 10px color-mix(in srgb, var(--vislab-ui-accent) 45%, transparent);
}

body[data-theme="pro"] .queue-timeline-ruler,
body[data-theme="pro-dark"] .queue-timeline-ruler {
  color: rgba(222, 230, 244, 0.75);
}

body[data-theme="pro"] .queue-timeline-ruler-tick,
body[data-theme="pro-dark"] .queue-timeline-ruler-tick {
  opacity: 0.62;
}

body[data-theme="pro"] .queue-timeline-ruler-tick.is-major,
body[data-theme="pro-dark"] .queue-timeline-ruler-tick.is-major {
  opacity: 0.95;
}

body[data-theme="pro"] .queue-timeline-ruler-label,
body[data-theme="pro-dark"] .queue-timeline-ruler-label {
  color: rgba(228, 235, 248, 0.88);
}

body[data-theme="pro"] .btn,
body[data-theme="pro-dark"] .btn,
body[data-theme="pro"] .header-btn,
body[data-theme="pro-dark"] .header-btn,
body[data-theme="pro"] .theme-toggle,
body[data-theme="pro-dark"] .theme-toggle,
body[data-theme="pro"] .header-links a,
body[data-theme="pro-dark"] .header-links a,
body[data-theme="pro"] .transport-input-menu-trigger,
body[data-theme="pro-dark"] .transport-input-menu-trigger,
body[data-theme="pro"] .header-quality-menu-trigger,
body[data-theme="pro-dark"] .header-quality-menu-trigger,
body[data-theme="pro"] .header-controls .export-settings-menu-trigger,
body[data-theme="pro-dark"] .header-controls .export-settings-menu-trigger,
body[data-theme="pro"] .header-controls .shortcuts-menu-trigger,
body[data-theme="pro-dark"] .header-controls .shortcuts-menu-trigger,
body[data-theme="pro"] .header-controls .preferences-menu-trigger,
body[data-theme="pro-dark"] .header-controls .preferences-menu-trigger {
  border: none !important;
  background: #c7c3c0 !important;
  color: #2c2c2c !important;
  box-shadow:
    rgba(0, 0, 0, 0.35) 6px 6px 8px,
    #ffffff 1.5px 1.5px 2px 0 inset,
    #a7a3a0 -3px -3px 7px 0 inset !important;
  border-radius: 10px !important;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-weight: 700;
}

body[data-theme="pro"] .header-quality-menu-trigger-title,
body[data-theme="pro-dark"] .header-quality-menu-trigger-title,
body[data-theme="pro"] .export-settings-menu-trigger-label,
body[data-theme="pro-dark"] .export-settings-menu-trigger-label,
body[data-theme="pro"] .shortcuts-menu-trigger-label,
body[data-theme="pro-dark"] .shortcuts-menu-trigger-label,
body[data-theme="pro"] .preferences-menu-trigger-label,
body[data-theme="pro-dark"] .preferences-menu-trigger-label {
  color: #2c2c2c;
}

body[data-theme="pro"] .header-quality-menu-trigger-chevron,
body[data-theme="pro-dark"] .header-quality-menu-trigger-chevron,
body[data-theme="pro"] .export-settings-menu-trigger-chevron,
body[data-theme="pro-dark"] .export-settings-menu-trigger-chevron,
body[data-theme="pro"] .shortcuts-menu-trigger-chevron,
body[data-theme="pro-dark"] .shortcuts-menu-trigger-chevron,
body[data-theme="pro"] .preferences-menu-trigger-chevron,
body[data-theme="pro-dark"] .preferences-menu-trigger-chevron,
body[data-theme="pro"] .transport-input-menu-trigger-chevron,
body[data-theme="pro-dark"] .transport-input-menu-trigger-chevron {
  color: #4e4e4e;
}

body[data-theme="pro"] .canvas-actions .transport-bar .btn.transport-btn,
body[data-theme="pro-dark"] .canvas-actions .transport-bar .btn.transport-btn,
body[data-theme="pro"] .queue-timeline-toolbar .timeline-play-btn,
body[data-theme="pro-dark"] .queue-timeline-toolbar .timeline-play-btn {
  border: none !important;
  background: linear-gradient(180deg, #42464f 0%, #2d3138 100%) !important;
  color: #f1f3f5 !important;
  box-shadow:
    rgba(0, 0, 0, 0.45) 6px 6px 8px,
    rgba(255, 255, 255, 0.2) 1px 1px 1px 0 inset,
    #1f2229 -2px -2px 6px 0 inset !important;
  border-radius: 10px !important;
}

body[data-theme="pro"] .canvas-actions .transport-bar .btn.transport-record,
body[data-theme="pro-dark"] .canvas-actions .transport-bar .btn.transport-record {
  background: linear-gradient(180deg, #88ffb6 0%, #1eae5b 100%) !important;
  color: #ffffff !important;
  box-shadow:
    rgba(0, 0, 0, 0.45) 6px 6px 8px,
    rgba(220, 255, 233, 0.8) 1px 1px 4px 0 inset,
    #157c43 -2px -2px 4px 0 inset !important;
}

body[data-theme="pro"] .canvas-actions .transport-bar .btn.transport-play.is-playing,
body[data-theme="pro-dark"] .canvas-actions .transport-bar .btn.transport-play.is-playing,
body[data-theme="pro"] .queue-timeline-toolbar .timeline-play-btn.is-playing,
body[data-theme="pro-dark"] .queue-timeline-toolbar .timeline-play-btn.is-playing {
  border: 1px solid var(--vislab-ui-accent) !important;
  box-shadow:
    rgba(0, 0, 0, 0.45) 6px 6px 8px,
    color-mix(in srgb, var(--vislab-ui-accent-light) 55%, transparent) 0 0 0 1px inset !important;
}

body[data-theme="pro"] .btn:hover,
body[data-theme="pro-dark"] .btn:hover,
body[data-theme="pro"] .header-btn:hover,
body[data-theme="pro-dark"] .header-btn:hover,
body[data-theme="pro"] .theme-toggle:hover,
body[data-theme="pro-dark"] .theme-toggle:hover,
body[data-theme="pro"] .header-links a:hover,
body[data-theme="pro-dark"] .header-links a:hover,
body[data-theme="pro"] button:not(:disabled):hover,
body[data-theme="pro-dark"] button:not(:disabled):hover {
  filter: brightness(1.03);
  transform: none;
}

body[data-theme="pro"] .btn:active,
body[data-theme="pro-dark"] .btn:active,
body[data-theme="pro"] .btn.is-active,
body[data-theme="pro-dark"] .btn.is-active,
body[data-theme="pro"] .btn[aria-pressed="true"],
body[data-theme="pro-dark"] .btn[aria-pressed="true"],
body[data-theme="pro"] .header-btn:active,
body[data-theme="pro-dark"] .header-btn:active,
body[data-theme="pro"] .theme-toggle:active,
body[data-theme="pro-dark"] .theme-toggle:active,
body[data-theme="pro"] .header-links a:active,
body[data-theme="pro-dark"] .header-links a:active,
body[data-theme="pro"] .canvas-actions .transport-bar .btn.transport-btn:active,
body[data-theme="pro-dark"] .canvas-actions .transport-bar .btn.transport-btn:active,
body[data-theme="pro"] .queue-timeline-toolbar .timeline-play-btn:active,
body[data-theme="pro-dark"] .queue-timeline-toolbar .timeline-play-btn:active {
  transform: translate(1px, 1px);
  box-shadow:
    rgba(0, 0, 0, 0.15) 0 0 0,
    inset 0.5px 0.5px 4px #000000,
    rgba(0, 0, 0, 0.25) -2px -2px 6px 0 inset !important;
}

body[data-theme-variant="pro-light"],
body[data-theme-variant="pro-light"] * {
  font-family: "Chathura", sans-serif !important;
}

body[data-theme-variant="pro-light"] {
  font-size: 17px;
  line-height: 1.05;
  background: var(--vislab-ui-surface-1) !important;
}

body[data-theme-variant="pro-light"] .vislab-header,
body[data-theme-variant="pro-light"] .hero {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

body[data-theme-variant="pro-light"] .hero {
  padding: 0 !important;
  border-radius: 0 !important;
}

body[data-theme-variant="pro-light"] .vislab-header {
  border-radius: 0 !important;
  padding-left: 0;
  padding-right: 0;
}

body[data-theme-variant="pro-light"] .core-section,
body[data-theme-variant="pro-light"] .preferences-menu-panel,
body[data-theme-variant="pro-light"] .shortcuts-menu-panel,
body[data-theme-variant="pro-light"] .export-settings-menu-panel,
body[data-theme-variant="pro-light"] .header-quality-menu-panel,
body[data-theme-variant="pro-light"] .transport-input-menu-panel,
body[data-theme-variant="pro-light"] .transport-input-submenu,
body[data-theme-variant="pro-light"] .header-quality-submenu,
body[data-theme-variant="pro-light"] .export-settings-submenu,
body[data-theme-variant="pro-light"] .core-tempo-menu-panel,
body[data-theme-variant="pro-light"] .queue-clip-context-menu,
body[data-theme-variant="pro-light"] .queue-transition-picker,
body[data-theme-variant="pro-light"] .welcome-modal .welcome-modal-panel,
body[data-theme-variant="pro-light"] #settings-session-modal .session-modal-panel {
  background: var(--vislab-ui-surface-1) !important;
  background-image: none !important;
}

body[data-theme-variant="pro-light"] .preferences-menu-section,
body[data-theme-variant="pro-light"] .controls-shell,
body[data-theme-variant="pro-light"] .tab-panel,
body[data-theme-variant="pro-light"] .control {
  background: var(--vislab-ui-surface-2) !important;
  background-image: none !important;
}

body[data-theme-variant="pro-light"] .controls-shell {
  padding-top: 0 !important;
}

body[data-theme-variant="pro-light"] .preferences-ui-scale-buttons,
body[data-theme-variant="pro-light"] .preferences-theme-buttons,
body[data-theme-variant="pro-light"] .preferences-palette-buttons {
  background: var(--vislab-ui-track-bg) !important;
  background-image: none !important;
}

body[data-theme-variant="pro-light"] .tab-buttons,
body[data-theme-variant="pro-light"] .welcome-modal .welcome-choice-card,
body[data-theme-variant="pro-light"] .welcome-modal .welcome-import-zone,
body[data-theme-variant="pro-light"] .sound-canvas,
body[data-theme-variant="pro-light"] .preview-off {
  background: var(--vislab-ui-black) !important;
  background-image: none !important;
}

body[data-theme-variant="pro-light"] .vislab-loader {
  font-family: "Chathura", sans-serif !important;
  font-size: 24px !important;
  letter-spacing: 0.04em !important;
  line-height: 1 !important;
}

body[data-theme-variant="pro-light"] .welcome-modal .session-modal-title,
body[data-theme-variant="pro-light"] .welcome-modal .welcome-modal-intro,
body[data-theme-variant="pro-light"] .welcome-modal .welcome-choice-title,
body[data-theme-variant="pro-light"] .welcome-modal .welcome-choice-hint,
body[data-theme-variant="pro-light"] .welcome-modal .session-import-title,
body[data-theme-variant="pro-light"] .welcome-modal .session-import-hint {
  font-size: 24px !important;
  line-height: 1 !important;
  letter-spacing: 0.02em !important;
}

body[data-theme-variant="pro-light"] .btn,
body[data-theme-variant="pro-light"] .header-btn,
body[data-theme-variant="pro-light"] .theme-toggle,
body[data-theme-variant="pro-light"] .header-links a,
body[data-theme-variant="pro-light"] .core-tempo-menu-trigger,
body[data-theme-variant="pro-light"] .transport-input-menu-trigger,
body[data-theme-variant="pro-light"] .header-quality-menu-trigger,
body[data-theme-variant="pro-light"] .header-controls .export-settings-menu-trigger,
body[data-theme-variant="pro-light"] .header-controls .shortcuts-menu-trigger,
body[data-theme-variant="pro-light"] .header-controls .preferences-menu-trigger {
  font-size: 21px !important;
  line-height: 0.95;
  letter-spacing: 0.02em !important;
}

body[data-theme-variant="pro-light"] .header-quality-menu-trigger-title,
body[data-theme-variant="pro-light"] .export-settings-menu-trigger-label,
body[data-theme-variant="pro-light"] .shortcuts-menu-trigger-label,
body[data-theme-variant="pro-light"] .preferences-menu-trigger-label,
body[data-theme-variant="pro-light"] #transport-input-menu-trigger-label {
  font-size: 22px !important;
  line-height: 0.95;
}

body[data-theme-variant="pro-light"] .tab-btn,
body[data-theme-variant="pro-light"] .header-label,
body[data-theme-variant="pro-light"] .transport-label,
body[data-theme-variant="pro-light"] .core-section-title,
body[data-theme-variant="pro-light"] .core-section-chevron,
body[data-theme-variant="pro-light"] .control > span,
body[data-theme-variant="pro-light"] .queue-field > span,
body[data-theme-variant="pro-light"] .queue-head .header-label {
  font-size: 21px !important;
  letter-spacing: 0.02em !important;
  line-height: 0.95;
}

body[data-theme-variant="pro-light"] .transport-input-menu-item,
body[data-theme-variant="pro-light"] .transport-input-submenu-item,
body[data-theme-variant="pro-light"] .header-quality-menu-item,
body[data-theme-variant="pro-light"] .header-quality-submenu-item,
body[data-theme-variant="pro-light"] .export-settings-menu-row-label,
body[data-theme-variant="pro-light"] .export-settings-menu-group-value,
body[data-theme-variant="pro-light"] .queue-clip-context-title,
body[data-theme-variant="pro-light"] .queue-transition-picker-title,
body[data-theme-variant="pro-light"] .queue-clip-context-field,
body[data-theme-variant="pro-light"] .preferences-shortcut-btn,
body[data-theme-variant="pro-light"] .preferences-menu-reset,
body[data-theme-variant="pro-light"] .preferences-menu-section-title,
body[data-theme-variant="pro-light"] .preferences-menu-shortcuts-title,
body[data-theme-variant="pro-light"] .preferences-shortcut-label,
body[data-theme-variant="pro-light"] .preferences-color-label,
body[data-theme-variant="pro-light"] .preferences-menu-section-value {
  font-size: 19px !important;
  line-height: 0.95;
}

body[data-theme-variant="pro-light"] .export-settings-menu-group-value {
  color: #4f4f4f;
  letter-spacing: 0.02em;
}

body[data-theme-variant="pro-light"] .preferences-ui-scale-buttons {
  position: relative;
  overflow: hidden;
  padding: 7px;
  border: 2px solid var(--vislab-ui-track-border);
  border-radius: 9px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--vislab-ui-track-bg) 86%, #232323) 0%, var(--vislab-ui-track-bg) 100%);
  box-shadow: 1px 1px 1px rgba(255, 255, 255, 0.12);
}

body[data-theme-variant="pro-light"] .preferences-ui-scale-buttons::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  box-shadow:
    inset 0 6px 10px rgba(0, 0, 0, 0.92),
    inset 0 -3px 3px rgba(255, 255, 255, 0.08),
    inset 2px 0 3px rgba(0, 0, 0, 0.52),
    inset -2px 0 2px rgba(255, 255, 255, 0.06),
    inset 0 0 0 1px rgba(0, 0, 0, 0.68);
}

body[data-theme-variant="pro-light"] .preferences-theme-buttons,
body[data-theme-variant="pro-light"] .preferences-palette-buttons {
  position: relative;
  overflow: hidden;
  padding: 7px;
  border: 2px solid var(--vislab-ui-track-border);
  border-radius: 9px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--vislab-ui-track-bg) 86%, #232323) 0%, var(--vislab-ui-track-bg) 100%);
  box-shadow: 1px 1px 1px rgba(255, 255, 255, 0.12);
}

body[data-theme-variant="pro-light"] .preferences-theme-buttons::before,
body[data-theme-variant="pro-light"] .preferences-palette-buttons::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  box-shadow:
    inset 0 6px 10px rgba(0, 0, 0, 0.92),
    inset 0 -3px 3px rgba(255, 255, 255, 0.08),
    inset 2px 0 3px rgba(0, 0, 0, 0.52),
    inset -2px 0 2px rgba(255, 255, 255, 0.06),
    inset 0 0 0 1px rgba(0, 0, 0, 0.68);
}

body[data-theme-variant="pro-light"] .preferences-theme-buttons > *,
body[data-theme-variant="pro-light"] .preferences-palette-buttons > * {
  position: relative;
  z-index: 1;
}

body[data-theme-variant="pro-light"] .preferences-color-input {
  width: 100%;
  height: 36px;
  border: 2px solid var(--vislab-ui-track-border) !important;
  border-radius: 8px !important;
  background: var(--vislab-ui-track-bg) !important;
  box-shadow:
    inset 0 2px 3px rgba(0, 0, 0, 0.75),
    1px 1px 1px rgba(255, 255, 255, 0.15) !important;
}

body[data-theme-variant="pro-light"] .preferences-color-label {
  font-size: 15px !important;
  line-height: 0.92 !important;
  text-transform: none !important;
}

body[data-theme-variant="pro-light"] .preferences-ui-scale-buttons > * {
  position: relative;
  z-index: 1;
}

body[data-theme-variant="pro-light"] .preferences-ui-scale-btn {
  --pro-light-btn-bg: var(--vislab-ui-dark-btn-bg);
  --pro-light-btn-bg-active: color-mix(in srgb, var(--vislab-ui-dark-btn-bg) 88%, #000);
  --pro-light-btn-light: var(--vislab-ui-dark-btn-light);
  --pro-light-btn-dark: var(--vislab-ui-dark-btn-dark);
  --pro-light-btn-text: #ffffff;
  border: 2px solid #010101 !important;
  border-radius: 9px !important;
  min-height: 32px;
  background: var(--pro-light-btn-bg) !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80' viewBox='0 0 80 80'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='80' height='80' filter='url(%23n)' opacity='0.22'/%3E%3C/svg%3E") !important;
  background-size: 80px 80px !important;
  background-repeat: repeat !important;
  color: var(--pro-light-btn-text) !important;
  box-shadow:
    inset 1px 1px 1px var(--pro-light-btn-light),
    inset -1px -1px 1px var(--pro-light-btn-dark),
    1px 1px 2px rgba(0, 0, 0, 0.45),
    1px 1px 1px rgba(255, 255, 255, 0.35) !important;
  text-transform: uppercase;
}

body[data-theme-variant="pro-light"] .preferences-ui-scale-btn:hover {
  filter: brightness(1.02);
  transform: none;
}

body[data-theme-variant="pro-light"] .preferences-ui-scale-btn:active {
  transform: scale(0.98);
  background-color: var(--pro-light-btn-bg-active) !important;
  box-shadow:
    inset 0 0 4px #000,
    inset 1px 1px 1px transparent,
    inset -1px -1px 1px transparent,
    1px 1px 2px transparent,
    1px 1px 1px rgba(255, 255, 255, 0.25) !important;
}

body[data-theme-variant="pro-light"] .preferences-ui-scale-btn.is-active,
body[data-theme-variant="pro-light"] .preferences-ui-scale-btn[aria-pressed="true"] {
  --pro-light-btn-bg: var(--vislab-ui-accent);
  --pro-light-btn-bg-active: var(--vislab-ui-accent-active);
  --pro-light-btn-light: var(--vislab-ui-accent-light);
  --pro-light-btn-dark: var(--vislab-ui-accent-dark);
  --pro-light-btn-text: #010101;
  border-color: #010101 !important;
  background: var(--pro-light-btn-bg) !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80' viewBox='0 0 80 80'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='80' height='80' filter='url(%23n)' opacity='0.22'/%3E%3C/svg%3E") !important;
  background-size: 80px 80px !important;
  background-repeat: repeat !important;
  color: var(--pro-light-btn-text) !important;
  box-shadow:
    inset 1px 1px 1px var(--pro-light-btn-light),
    inset -1px -1px 1px var(--pro-light-btn-dark),
    1px 1px 2px rgba(0, 0, 0, 0.45),
    1px 1px 1px rgba(255, 255, 255, 0.3) !important;
}

body[data-theme-variant="pro-light"] .transport-input-menu-item,
body[data-theme-variant="pro-light"] .transport-input-submenu-item,
body[data-theme-variant="pro-light"] .header-quality-menu-item,
body[data-theme-variant="pro-light"] .header-quality-submenu-item {
  min-height: 34px;
}

body[data-theme-variant="pro-light"] .btn,
body[data-theme-variant="pro-light"] .header-btn,
body[data-theme-variant="pro-light"] .theme-toggle,
body[data-theme-variant="pro-light"] .header-links a,
body[data-theme-variant="pro-light"] .core-tempo-menu-trigger,
body[data-theme-variant="pro-light"] .transport-input-menu-trigger,
body[data-theme-variant="pro-light"] .header-quality-menu-trigger,
body[data-theme-variant="pro-light"] .header-controls .export-settings-menu-trigger,
body[data-theme-variant="pro-light"] .header-controls .shortcuts-menu-trigger,
body[data-theme-variant="pro-light"] .header-controls .preferences-menu-trigger,
body[data-theme-variant="pro-light"] .queue-clip-context-btn,
body[data-theme-variant="pro-light"] .queue-transition-picker-btn,
body[data-theme-variant="pro-light"] .queue-transition-picker-clear,
body[data-theme-variant="pro-light"] .preferences-shortcut-btn,
body[data-theme-variant="pro-light"] .preferences-menu-reset {
  --pro-light-btn-bg: var(--vislab-ui-light-btn-bg);
  --pro-light-btn-bg-active: color-mix(in srgb, var(--vislab-ui-light-btn-bg) 88%, #000);
  --pro-light-btn-light: var(--vislab-ui-light-btn-light);
  --pro-light-btn-dark: var(--vislab-ui-light-btn-dark);
  --pro-light-btn-text: var(--vislab-ui-text);
  border: 2px solid #010101 !important;
  border-radius: 9px !important;
  background-color: var(--pro-light-btn-bg) !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80' viewBox='0 0 80 80'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='80' height='80' filter='url(%23n)' opacity='0.22'/%3E%3C/svg%3E") !important;
  background-size: 80px 80px !important;
  background-repeat: repeat !important;
  color: var(--pro-light-btn-text) !important;
  box-shadow:
    inset 1px 1px 1px var(--pro-light-btn-light),
    inset -1px -1px 1px var(--pro-light-btn-dark),
    1px 1px 2px rgba(0, 0, 0, 0.45),
    1px 1px 1px rgba(255, 255, 255, 0.35) !important;
  font-family: "Chathura", sans-serif;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  font-weight: 500;
  transition:
    transform 0.2s cubic-bezier(0.25, 0.5, 0.5, 1),
    background-color 0.2s cubic-bezier(0.25, 0.5, 0.5, 1),
    box-shadow 0.2s cubic-bezier(0.25, 0.5, 0.5, 1),
    filter 0.2s cubic-bezier(0.25, 0.5, 0.5, 1);
}

body[data-theme-variant="pro-light"] .header-controls .header-btn,
body[data-theme-variant="pro-light"] .header-controls .theme-toggle,
body[data-theme-variant="pro-light"] .header-controls .header-quality-menu-trigger,
body[data-theme-variant="pro-light"] .header-controls .export-settings-menu-trigger,
body[data-theme-variant="pro-light"] .header-controls .shortcuts-menu-trigger,
body[data-theme-variant="pro-light"] .header-controls .preferences-menu-trigger {
  min-height: 44px;
}

body[data-theme-variant="pro-light"] #popout-btn.header-btn {
  --pro-light-btn-bg: var(--vislab-ui-dark-btn-bg);
  --pro-light-btn-bg-active: color-mix(in srgb, var(--vislab-ui-dark-btn-bg) 88%, #000);
  --pro-light-btn-light: var(--vislab-ui-dark-btn-light);
  --pro-light-btn-dark: var(--vislab-ui-dark-btn-dark);
  --pro-light-btn-text: #ffffff;
  color: #ffffff !important;
}

body[data-theme-variant="pro-light"] #popout-btn.header-btn:disabled {
  --pro-light-btn-bg: color-mix(in srgb, var(--vislab-ui-dark-btn-bg) 86%, #8a8a8a);
  --pro-light-btn-bg-active: color-mix(in srgb, var(--vislab-ui-dark-btn-bg) 90%, #000);
  --pro-light-btn-light: color-mix(in srgb, var(--vislab-ui-dark-btn-light) 62%, #d4d4d4);
  --pro-light-btn-dark: color-mix(in srgb, var(--vislab-ui-dark-btn-dark) 78%, #20242b);
  --pro-light-btn-text: #ffffff;
  color: #ffffff !important;
  opacity: 0.9 !important;
}

body[data-theme-variant="pro-light"] .header-quality-menu-trigger-title,
body[data-theme-variant="pro-light"] .export-settings-menu-trigger-label,
body[data-theme-variant="pro-light"] .shortcuts-menu-trigger-label,
body[data-theme-variant="pro-light"] .preferences-menu-trigger-label,
body[data-theme-variant="pro-light"] .header-quality-menu-trigger-chevron,
body[data-theme-variant="pro-light"] .export-settings-menu-trigger-chevron,
body[data-theme-variant="pro-light"] .shortcuts-menu-trigger-chevron,
body[data-theme-variant="pro-light"] .preferences-menu-trigger-chevron,
body[data-theme-variant="pro-light"] .transport-input-menu-trigger-chevron {
  color: var(--pro-light-btn-text) !important;
}

body[data-theme-variant="pro-light"] .core-tempo-menu-trigger,
body[data-theme-variant="pro-light"] .transport-input-menu-trigger,
body[data-theme-variant="pro-light"] .header-quality-menu-trigger,
body[data-theme-variant="pro-light"] .header-controls .export-settings-menu-trigger,
body[data-theme-variant="pro-light"] .header-controls .shortcuts-menu-trigger,
body[data-theme-variant="pro-light"] .header-controls .preferences-menu-trigger {
  border-bottom-left-radius: 0 !important;
  border-bottom-right-radius: 0 !important;
}

body[data-theme-variant="pro-light"] .canvas-actions .transport-bar .btn.transport-btn,
body[data-theme-variant="pro-light"] .queue-timeline-toolbar .timeline-play-btn {
  --pro-light-btn-bg: var(--vislab-ui-dark-btn-bg);
  --pro-light-btn-bg-active: color-mix(in srgb, var(--vislab-ui-dark-btn-bg) 88%, #000);
  --pro-light-btn-light: var(--vislab-ui-dark-btn-light);
  --pro-light-btn-dark: var(--vislab-ui-dark-btn-dark);
  --pro-light-btn-text: #ffffff;
  border: 2px solid #010101 !important;
  border-radius: 9px !important;
  background: var(--pro-light-btn-bg) !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80' viewBox='0 0 80 80'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='80' height='80' filter='url(%23n)' opacity='0.22'/%3E%3C/svg%3E") !important;
  background-size: 80px 80px !important;
  background-repeat: repeat !important;
  color: var(--pro-light-btn-text) !important;
  box-shadow:
    inset 1px 1px 1px var(--pro-light-btn-light),
    inset -1px -1px 1px var(--pro-light-btn-dark),
    1px 1px 2px rgba(0, 0, 0, 0.45),
    1px 1px 1px rgba(255, 255, 255, 0.35) !important;
}

body[data-theme-variant="pro-light"] .canvas-actions .transport-bar .btn.transport-record,
body[data-theme-variant="pro-light"] .canvas-actions .transport-bar .btn.transport-play.is-playing,
body[data-theme-variant="pro-light"] .queue-timeline-toolbar .timeline-play-btn.is-playing {
  --pro-light-btn-bg: var(--vislab-ui-accent);
  --pro-light-btn-bg-active: var(--vislab-ui-accent-active);
  --pro-light-btn-light: var(--vislab-ui-accent-light);
  --pro-light-btn-dark: var(--vislab-ui-accent-dark);
  --pro-light-btn-text: #010101;
  background: var(--pro-light-btn-bg) !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80' viewBox='0 0 80 80'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='80' height='80' filter='url(%23n)' opacity='0.22'/%3E%3C/svg%3E") !important;
  background-size: 80px 80px !important;
  background-repeat: repeat !important;
  color: var(--pro-light-btn-text) !important;
  border-color: #010101 !important;
  box-shadow:
    inset 1px 1px 1px var(--pro-light-btn-light),
    inset -1px -1px 1px var(--pro-light-btn-dark),
    1px 1px 2px rgba(0, 0, 0, 0.45),
    1px 1px 1px rgba(255, 255, 255, 0.3) !important;
}

body[data-theme-variant="pro-light"] .btn:hover,
body[data-theme-variant="pro-light"] .header-btn:hover,
body[data-theme-variant="pro-light"] .theme-toggle:hover,
body[data-theme-variant="pro-light"] .header-links a:hover,
body[data-theme-variant="pro-light"] button:not(.tab-btn):not(:disabled):hover {
  filter: brightness(1.02) !important;
  box-shadow:
    inset 1px 1px 1px var(--pro-light-btn-light),
    inset -1px -1px 1px var(--pro-light-btn-dark),
    1px 1px 2px rgba(0, 0, 0, 0.42),
    1px 1px 1px rgba(255, 255, 255, 0.33) !important;
  transform: none !important;
}

body[data-theme-variant="pro-light"] .btn:active,
body[data-theme-variant="pro-light"] .btn.is-active,
body[data-theme-variant="pro-light"] .btn[aria-pressed="true"],
body[data-theme-variant="pro-light"] .header-btn:active,
body[data-theme-variant="pro-light"] .theme-toggle:active,
body[data-theme-variant="pro-light"] .header-links a:active,
body[data-theme-variant="pro-light"] .core-tempo-menu-trigger:active,
body[data-theme-variant="pro-light"] .queue-clip-context-btn:active,
body[data-theme-variant="pro-light"] .queue-transition-picker-btn:active,
body[data-theme-variant="pro-light"] .queue-transition-picker-clear:active,
body[data-theme-variant="pro-light"] .preferences-shortcut-btn:active,
body[data-theme-variant="pro-light"] .preferences-menu-reset:active,
body[data-theme-variant="pro-light"] .canvas-actions .transport-bar .btn.transport-btn:active,
body[data-theme-variant="pro-light"] .queue-timeline-toolbar .timeline-play-btn:active {
  transform: scale(0.98) !important;
  background-color: var(--pro-light-btn-bg-active) !important;
  box-shadow:
    inset 0 0 4px #000,
    inset 1px 1px 1px transparent,
    inset -1px -1px 1px transparent,
    1px 1px 2px transparent,
    1px 1px 1px rgba(255, 255, 255, 0.25) !important;
}

body[data-theme-variant="pro-light"] .btn:disabled,
body[data-theme-variant="pro-light"] .header-btn:disabled,
body[data-theme-variant="pro-light"] .core-tempo-menu-trigger:disabled,
body[data-theme-variant="pro-light"] .queue-clip-context-btn:disabled,
body[data-theme-variant="pro-light"] .queue-transition-picker-btn:disabled,
body[data-theme-variant="pro-light"] .queue-transition-picker-clear:disabled,
body[data-theme-variant="pro-light"] .preferences-shortcut-btn:disabled,
body[data-theme-variant="pro-light"] .preferences-menu-reset:disabled {
  --pro-light-btn-bg: color-mix(in srgb, var(--vislab-ui-dark-btn-bg) 78%, #7c7c7c);
  --pro-light-btn-bg-active: color-mix(in srgb, var(--vislab-ui-dark-btn-bg) 86%, #3f3f3f);
  --pro-light-btn-light: color-mix(in srgb, var(--vislab-ui-dark-btn-light) 56%, #d3d3d3);
  --pro-light-btn-dark: color-mix(in srgb, var(--vislab-ui-dark-btn-dark) 78%, #383838);
  --pro-light-btn-text: #e4e4e4;
  opacity: 0.88 !important;
}

body[data-theme-variant="pro-light"] .preferences-shortcut-btn.is-capturing {
  --pro-light-btn-bg: var(--vislab-ui-accent);
  --pro-light-btn-bg-active: var(--vislab-ui-accent-active);
  --pro-light-btn-light: var(--vislab-ui-accent-light);
  --pro-light-btn-dark: var(--vislab-ui-accent-dark);
  --pro-light-btn-text: #010101;
}

body[data-theme-variant="pro-light"] .queue-transition-picker-btn.is-active {
  --pro-light-btn-bg: var(--vislab-ui-accent);
  --pro-light-btn-bg-active: var(--vislab-ui-accent-active);
  --pro-light-btn-light: var(--vislab-ui-accent-light);
  --pro-light-btn-dark: var(--vislab-ui-accent-dark);
  --pro-light-btn-text: #010101;
}

body[data-theme-variant="pro-light"] .queue-clip-context-btn.danger {
  border-color: #010101 !important;
}

body[data-theme-variant="pro-light"] .queue-clip-context-btn.danger:hover,
body[data-theme-variant="pro-light"] .queue-clip-context-btn.danger:focus-visible,
body[data-theme-variant="pro-light"] .queue-clip-context-btn.danger:focus {
  color: var(--pro-light-btn-text) !important;
  border-color: #010101 !important;
}

body[data-theme-variant="pro-light"] .queue-clip-context-btn,
body[data-theme-variant="pro-light"] .queue-transition-picker-btn,
body[data-theme-variant="pro-light"] .queue-transition-picker-clear {
  font-size: 19px !important;
  line-height: 0.95 !important;
}

body[data-theme-variant="pro-light"] .queue-clip-context-btn:hover,
body[data-theme-variant="pro-light"] .queue-clip-context-btn:focus-visible,
body[data-theme-variant="pro-light"] .queue-clip-context-btn:focus,
body[data-theme-variant="pro-light"] .queue-transition-picker-btn:hover,
body[data-theme-variant="pro-light"] .queue-transition-picker-btn:focus-visible,
body[data-theme-variant="pro-light"] .queue-transition-picker-btn:focus,
body[data-theme-variant="pro-light"] .queue-transition-picker-clear:hover,
body[data-theme-variant="pro-light"] .queue-transition-picker-clear:focus-visible,
body[data-theme-variant="pro-light"] .queue-transition-picker-clear:focus {
  background-color: var(--pro-light-btn-bg) !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80' viewBox='0 0 80 80'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='80' height='80' filter='url(%23n)' opacity='0.22'/%3E%3C/svg%3E") !important;
  background-size: 80px 80px !important;
  background-repeat: repeat !important;
  border-color: #010101 !important;
  color: var(--pro-light-btn-text) !important;
}

body[data-theme-variant="pro-light"] .queue-clip-context-input {
  font-size: 19px !important;
  line-height: 0.95 !important;
}

body[data-theme-variant="pro-light"] .transport-input-menu-trigger:focus-visible,
body[data-theme-variant="pro-light"] .header-quality-menu-trigger:focus-visible,
body[data-theme-variant="pro-light"] .header-controls .export-settings-menu-trigger:focus-visible,
body[data-theme-variant="pro-light"] .header-controls .shortcuts-menu-trigger:focus-visible,
body[data-theme-variant="pro-light"] .header-controls .preferences-menu-trigger:focus-visible,
body[data-theme-variant="pro-light"] .transport-input-menu-trigger:focus,
body[data-theme-variant="pro-light"] .header-quality-menu-trigger:focus,
body[data-theme-variant="pro-light"] .header-controls .export-settings-menu-trigger:focus,
body[data-theme-variant="pro-light"] .header-controls .shortcuts-menu-trigger:focus,
body[data-theme-variant="pro-light"] .header-controls .preferences-menu-trigger:focus,
body[data-theme-variant="pro-light"] .core-tempo-menu-trigger:focus-visible,
body[data-theme-variant="pro-light"] .core-tempo-menu-trigger:focus,
body[data-theme-variant="pro-light"] .queue-clip-context-btn:focus-visible,
body[data-theme-variant="pro-light"] .queue-clip-context-btn:focus,
body[data-theme-variant="pro-light"] .queue-transition-picker-btn:focus-visible,
body[data-theme-variant="pro-light"] .queue-transition-picker-btn:focus,
body[data-theme-variant="pro-light"] .queue-transition-picker-clear:focus-visible,
body[data-theme-variant="pro-light"] .queue-transition-picker-clear:focus,
body[data-theme-variant="pro-light"] .preferences-shortcut-btn:focus-visible,
body[data-theme-variant="pro-light"] .preferences-shortcut-btn:focus,
body[data-theme-variant="pro-light"] .preferences-menu-reset:focus-visible,
body[data-theme-variant="pro-light"] .preferences-menu-reset:focus,
body[data-theme-variant="pro-light"] .header-btn:focus-visible,
body[data-theme-variant="pro-light"] .header-btn:focus,
body[data-theme-variant="pro-light"] .theme-toggle:focus-visible,
body[data-theme-variant="pro-light"] .theme-toggle:focus,
body[data-theme-variant="pro-light"] .header-links a:focus-visible,
body[data-theme-variant="pro-light"] .header-links a:focus {
  outline: none !important;
  box-shadow:
    inset 1px 1px 1px var(--pro-light-btn-light),
    inset -1px -1px 1px var(--pro-light-btn-dark),
    1px 1px 2px rgba(0, 0, 0, 0.45),
    1px 1px 1px rgba(255, 255, 255, 0.35) !important;
}

body[data-theme="pro"] input[type="range"],
body[data-theme="pro-dark"] input[type="range"] {
  border-radius: 999px !important;
}

body[data-theme="pro"] input[type="range"]::-webkit-slider-thumb,
body[data-theme="pro-dark"] input[type="range"]::-webkit-slider-thumb {
  border-radius: 999px !important;
  background: var(--vislab-ui-accent);
  box-shadow: 0 0 0 2px #8a8a8a;
}

body[data-theme="pro"] input[type="range"]::-moz-range-thumb,
body[data-theme="pro-dark"] input[type="range"]::-moz-range-thumb {
  border-radius: 999px !important;
  background: var(--vislab-ui-accent);
  box-shadow: 0 0 0 2px #8a8a8a;
}

/* Pro Light slider styling to match Pro Light buttons */
body[data-theme-variant="pro-light"] input[type="range"] {
  --range-track-height: 10px;
  --range-thumb-size: 22px;
  border: 2px solid var(--vislab-ui-track-border) !important;
  border-radius: 999px !important;
  background:
    linear-gradient(
      90deg,
      var(--vislab-ui-accent) 0%,
      var(--vislab-ui-accent) var(--fader-fill, 50%),
      var(--vislab-ui-track-bg) var(--fader-fill, 50%),
      var(--vislab-ui-track-bg) 100%
    ) !important;
  box-shadow:
    inset 0 2px 4px rgba(0, 0, 0, 0.82),
    inset 0 -1px 1px rgba(255, 255, 255, 0.12),
    1px 1px 1px rgba(255, 255, 255, 0.18) !important;
}

body[data-theme-variant="pro-light"] input[type="range"]::-webkit-slider-runnable-track {
  height: var(--range-track-height);
  border-radius: 999px;
  background: transparent;
}

body[data-theme-variant="pro-light"] input[type="range"]::-moz-range-track {
  height: var(--range-track-height);
  border-radius: 999px;
  background: var(--vislab-ui-track-bg);
}

body[data-theme-variant="pro-light"] input[type="range"]::-moz-range-progress {
  height: var(--range-track-height);
  border-radius: 999px;
  background: var(--vislab-ui-accent);
}

body[data-theme-variant="pro-light"] input[type="range"]::-webkit-slider-thumb {
  appearance: none;
  width: var(--range-thumb-size);
  height: var(--range-thumb-size);
  margin-top: calc((var(--range-track-height) - var(--range-thumb-size)) / 2);
  border: 2px solid var(--vislab-ui-track-border) !important;
  border-radius: 6px !important;
  background-color: var(--vislab-ui-accent) !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80' viewBox='0 0 80 80'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='80' height='80' filter='url(%23n)' opacity='0.22'/%3E%3C/svg%3E") !important;
  background-size: 80px 80px !important;
  box-shadow:
    inset 1px 1px 1px color-mix(in srgb, var(--vislab-ui-accent-light) 95%, transparent),
    inset -1px -1px 1px color-mix(in srgb, var(--vislab-ui-accent-dark) 90%, transparent),
    2px 2px 4px #000,
    0 0 0 1px rgba(255, 255, 255, 0.25) !important;
}

body[data-theme-variant="pro-light"] input[type="range"]::-moz-range-thumb {
  width: var(--range-thumb-size);
  height: var(--range-thumb-size);
  border: 2px solid var(--vislab-ui-track-border) !important;
  border-radius: 6px !important;
  background-color: var(--vislab-ui-accent) !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80' viewBox='0 0 80 80'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='80' height='80' filter='url(%23n)' opacity='0.22'/%3E%3C/svg%3E") !important;
  background-size: 80px 80px !important;
  box-shadow:
    inset 1px 1px 1px color-mix(in srgb, var(--vislab-ui-accent-light) 95%, transparent),
    inset -1px -1px 1px color-mix(in srgb, var(--vislab-ui-accent-dark) 90%, transparent),
    2px 2px 4px #000,
    0 0 0 1px rgba(255, 255, 255, 0.25) !important;
}

body[data-theme-variant="pro-light"] input[type="range"]:hover {
  filter: brightness(1.02);
}

body[data-theme-variant="pro-light"] input[type="range"]::-webkit-slider-thumb:active {
  transform: scale(0.98);
  box-shadow:
    inset 0 0 4px #000,
    inset 1px 1px 1px transparent,
    inset -1px -1px 1px transparent,
    2px 2px 4px transparent !important;
}

/* Pro dark variant */
body[data-theme="pro-dark"] {
  --panel: color-mix(in srgb, var(--vislab-ui-surface-1) 18%, #10151c);
  --panel-2: color-mix(in srgb, var(--vislab-ui-surface-2) 14%, #0d1218);
  --stroke: color-mix(in srgb, var(--vislab-ui-stroke) 46%, #28303b);
  --text: color-mix(in srgb, var(--vislab-ui-text) 32%, #f0f4fb);
  --muted: color-mix(in srgb, var(--vislab-ui-muted) 45%, #c1cad9);
  --fader-track: #141820;
  --fader-border: #4a5260;
  --fader-thumb-border: #5a6270;
  --transport-shell-bg-1: #1f242d;
  --transport-shell-bg-2: #151921;
  --transport-shell-border: #444b57;
  --timeline-shell-bg-1: #1f252e;
  --timeline-shell-bg-2: #131820;
  --timeline-shell-border: #515968;
  --timeline-block-bg-1: #3a404d;
  --timeline-block-bg-2: #262b35;
  --timeline-block-border: #727b8d;
  --timeline-bar-a: rgba(224, 231, 244, 0.5);
  --timeline-bar-b: rgba(224, 231, 244, 0.18);
  --timeline-grid-major: rgba(215, 225, 242, 0.5);
  --timeline-grid-minor: rgba(215, 225, 242, 0.2);
  background: radial-gradient(circle at top, #2a313d 0%, #1b212a 58%, #12161c 100%);
}

body[data-theme="pro-dark"] .vislab-loader {
  background: #11161d;
  color: #ebf0f8;
}

body[data-theme="pro-dark"] .vislab-header {
  background: linear-gradient(180deg, #2b313b 0%, #1e242d 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08), 0 10px 20px rgba(0, 0, 0, 0.38);
}

body[data-theme="pro-dark"] .vislab-title {
  color: #f1f4fa;
}

body[data-theme="pro-dark"] .hero {
  background: linear-gradient(180deg, #232a34 0%, #181e27 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06), 0 8px 16px rgba(0, 0, 0, 0.36);
}

body[data-theme="pro-dark"] .core-section {
  border-color: #474f5d;
  background: linear-gradient(180deg, #262d37 0%, #1a2029 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

body[data-theme="pro-dark"] .core-section-title,
body[data-theme="pro-dark"] .core-section-chevron,
body[data-theme="pro-dark"] .header-label,
body[data-theme="pro-dark"] .transport-label {
  color: #d3dbe8;
}

body[data-theme="pro-dark"] select,
body[data-theme="pro-dark"] input[type="url"],
body[data-theme="pro-dark"] input[type="number"],
body[data-theme="pro-dark"] textarea,
body[data-theme="pro-dark"] .transport-input {
  background: #2b313c;
  color: #e8edf6;
  border-color: #596273;
  box-shadow: inset 0 1px 1px rgba(255, 255, 255, 0.08);
}

body[data-theme="pro-dark"] .header-quality-menu-panel,
body[data-theme="pro-dark"] .export-settings-menu-panel,
body[data-theme="pro-dark"] .preferences-menu-panel,
body[data-theme="pro-dark"] .transport-input-menu-panel,
body[data-theme="pro-dark"] .transport-input-submenu,
body[data-theme="pro-dark"] .header-quality-submenu {
  background: linear-gradient(180deg, #2a313b 0%, #1d232d 100%);
  border-color: #586273;
}

body[data-theme="pro-dark"] .header-quality-menu-item,
body[data-theme="pro-dark"] .export-settings-menu-row-label,
body[data-theme="pro-dark"] .preferences-menu-section-title,
body[data-theme="pro-dark"] .transport-input-menu-item,
body[data-theme="pro-dark"] .transport-input-submenu-item,
body[data-theme="pro-dark"] .header-quality-submenu-item,
body[data-theme="pro-dark"] .header-quality-submenu-heading {
  color: #dce3ef;
}

body[data-theme="pro-dark"] .sound-canvas {
  background: #080b10;
  border-color: #2a313c;
}

body[data-theme="pro-dark"] .queue-timeline-track {
  border-color: #5a6374;
  background: linear-gradient(180deg, #1f2630, #141922);
}

body[data-theme="pro-dark"] .queue-timeline-scrollbar {
  border-color: #5a6374;
  background: rgba(11, 14, 20, 0.72);
}

body[data-theme="pro-dark"] .queue-timeline-scrollbar-thumb {
  border-color: #707a8d;
  background: #8f98a8;
}

body[data-theme="pro-dark"] .btn,
body[data-theme="pro-dark"] .header-btn,
body[data-theme="pro-dark"] .theme-toggle,
body[data-theme="pro-dark"] .header-links a,
body[data-theme="pro-dark"] .transport-input-menu-trigger,
body[data-theme="pro-dark"] .header-quality-menu-trigger,
body[data-theme="pro-dark"] .header-controls .export-settings-menu-trigger,
body[data-theme="pro-dark"] .header-controls .preferences-menu-trigger {
  background: #5a616f !important;
  color: #f4f7fc !important;
  box-shadow:
    rgba(0, 0, 0, 0.5) 6px 6px 8px,
    rgba(255, 255, 255, 0.18) 1.5px 1.5px 2px 0 inset,
    #404653 -3px -3px 7px 0 inset !important;
}

body[data-theme="pro-dark"] .header-quality-menu-trigger-title,
body[data-theme="pro-dark"] .export-settings-menu-trigger-label,
body[data-theme="pro-dark"] .preferences-menu-trigger-label,
body[data-theme="pro-dark"] .header-quality-menu-trigger-chevron,
body[data-theme="pro-dark"] .export-settings-menu-trigger-chevron,
body[data-theme="pro-dark"] .preferences-menu-trigger-chevron,
body[data-theme="pro-dark"] .transport-input-menu-trigger-chevron {
  color: #f4f7fc;
}

body[data-theme="pro-dark"] .welcome-modal .welcome-modal-panel {
  border-color: #5a6270;
  background: linear-gradient(180deg, #2a313b 0%, #1e242d 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12), 0 18px 34px rgba(0, 0, 0, 0.5);
  color: #e8edf6;
}

body[data-theme="pro-dark"] #settings-session-modal .session-modal-backdrop {
  background: rgba(10, 13, 18, 0.62);
  backdrop-filter: blur(1px);
}

body[data-theme="pro-dark"] #settings-session-modal .session-modal-panel {
  border-color: #5a6270;
  background: linear-gradient(180deg, #2a313b 0%, #1e242d 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12), 0 18px 34px rgba(0, 0, 0, 0.5);
  color: #e8edf6;
}

body[data-theme="pro-dark"] #settings-session-modal .session-modal-title {
  color: #f2f5fa;
}

body[data-theme="pro-dark"] #settings-session-modal .session-export-name-label,
body[data-theme="pro-dark"] #settings-session-modal .session-import-hint {
  color: #bfc8d7;
}

body[data-theme="pro-dark"] #settings-session-modal .session-export-name,
body[data-theme="pro-dark"] #settings-session-modal .session-import-zone {
  border-color: #7a8697;
  background: linear-gradient(180deg, #343c48 0%, #252c36 100%);
  color: #edf2fb;
}

body[data-theme="pro-dark"] #settings-session-modal .session-import-zone.is-dragover,
body[data-theme="pro-dark"] #settings-session-modal .session-import-zone:focus-visible,
body[data-theme="pro-dark"] #settings-session-modal .session-export-name:focus-visible {
  border-color: var(--vislab-ui-accent);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--vislab-ui-accent) 28%, transparent), inset 0 1px 1px color-mix(in srgb, var(--vislab-ui-accent-light) 12%, transparent);
}

body[data-theme="pro-dark"] .welcome-modal .session-modal-title {
  color: #f2f5fa;
}

body[data-theme="pro-dark"] .welcome-modal .welcome-modal-intro,
body[data-theme="pro-dark"] .welcome-modal .welcome-choice-hint,
body[data-theme="pro-dark"] .welcome-modal .session-import-hint {
  color: #bfc8d7;
}

/* Pro Light typography normalization:
   - Headings/buttons/menu actions: uppercase
   - Subheadings/descriptions: normal case
*/
body[data-theme-variant="pro-light"] {
  --pro-light-type-title: 31px;
  --pro-light-type-ui: 27px;
  --pro-light-type-copy: 23px;
  --pro-light-type-copy-small: 22px;
}

body[data-theme-variant="pro-light"] .vislab-loader,
body[data-theme-variant="pro-light"] .session-modal-title,
body[data-theme-variant="pro-light"] .welcome-choice-title,
body[data-theme-variant="pro-light"] .session-import-title,
body[data-theme-variant="pro-light"] .btn,
body[data-theme-variant="pro-light"] .header-btn,
body[data-theme-variant="pro-light"] .theme-toggle,
body[data-theme-variant="pro-light"] .header-links a,
body[data-theme-variant="pro-light"] .tab-btn,
body[data-theme-variant="pro-light"] .header-label,
body[data-theme-variant="pro-light"] .transport-label,
body[data-theme-variant="pro-light"] .core-section-title,
body[data-theme-variant="pro-light"] .core-section-chevron,
body[data-theme-variant="pro-light"] .control > span,
body[data-theme-variant="pro-light"] .queue-field > span,
body[data-theme-variant="pro-light"] .queue-head .header-label,
body[data-theme-variant="pro-light"] .transport-input-menu-trigger-title,
body[data-theme-variant="pro-light"] .export-settings-menu-trigger-label,
body[data-theme-variant="pro-light"] .shortcuts-menu-trigger-label,
body[data-theme-variant="pro-light"] .preferences-menu-trigger-label,
body[data-theme-variant="pro-light"] #transport-input-menu-trigger-label,
body[data-theme-variant="pro-light"] .transport-input-menu-item,
body[data-theme-variant="pro-light"] .transport-input-submenu-item,
body[data-theme-variant="pro-light"] .header-quality-menu-item,
body[data-theme-variant="pro-light"] .header-quality-submenu-item,
body[data-theme-variant="pro-light"] .core-tempo-menu-item,
body[data-theme-variant="pro-light"] .header-quality-submenu-heading,
body[data-theme-variant="pro-light"] .queue-clip-context-title,
body[data-theme-variant="pro-light"] .queue-transition-picker-title,
body[data-theme-variant="pro-light"] .queue-clip-context-btn,
body[data-theme-variant="pro-light"] .queue-transition-picker-btn,
body[data-theme-variant="pro-light"] .queue-transition-picker-clear,
body[data-theme-variant="pro-light"] .preferences-menu-section-title,
body[data-theme-variant="pro-light"] .preferences-menu-shortcuts-title,
body[data-theme-variant="pro-light"] .preferences-shortcut-btn,
body[data-theme-variant="pro-light"] .preferences-menu-reset,
body[data-theme-variant="pro-light"] .preferences-ui-scale-btn,
body[data-theme-variant="pro-light"] #settings-session-modal .session-export-btn,
body[data-theme-variant="pro-light"] #settings-session-modal .session-import-pick,
body[data-theme-variant="pro-light"] .welcome-modal .session-import-pick {
  text-transform: uppercase !important;
}

body[data-theme-variant="pro-light"] .welcome-modal .session-modal-title,
body[data-theme-variant="pro-light"] #settings-session-modal .session-modal-title {
  font-size: var(--pro-light-type-title) !important;
  line-height: 0.95 !important;
}

body[data-theme-variant="pro-light"] .btn,
body[data-theme-variant="pro-light"] .header-btn,
body[data-theme-variant="pro-light"] .theme-toggle,
body[data-theme-variant="pro-light"] .header-links a,
body[data-theme-variant="pro-light"] .tab-btn,
body[data-theme-variant="pro-light"] .header-label,
body[data-theme-variant="pro-light"] .transport-label,
body[data-theme-variant="pro-light"] .core-section-title,
body[data-theme-variant="pro-light"] .core-section-chevron,
body[data-theme-variant="pro-light"] .control > span,
body[data-theme-variant="pro-light"] .queue-field > span,
body[data-theme-variant="pro-light"] .queue-head .header-label,
body[data-theme-variant="pro-light"] .transport-input-menu-trigger-title,
body[data-theme-variant="pro-light"] .export-settings-menu-trigger-label,
body[data-theme-variant="pro-light"] .preferences-menu-trigger-label,
body[data-theme-variant="pro-light"] #transport-input-menu-trigger-label,
body[data-theme-variant="pro-light"] .transport-input-menu-item,
body[data-theme-variant="pro-light"] .transport-input-submenu-item,
body[data-theme-variant="pro-light"] .header-quality-menu-item,
body[data-theme-variant="pro-light"] .header-quality-submenu-item,
body[data-theme-variant="pro-light"] .core-tempo-menu-item,
body[data-theme-variant="pro-light"] .header-quality-submenu-heading,
body[data-theme-variant="pro-light"] .queue-clip-context-title,
body[data-theme-variant="pro-light"] .queue-transition-picker-title,
body[data-theme-variant="pro-light"] .queue-clip-context-btn,
body[data-theme-variant="pro-light"] .queue-transition-picker-btn,
body[data-theme-variant="pro-light"] .queue-transition-picker-clear,
body[data-theme-variant="pro-light"] .preferences-menu-section-title,
body[data-theme-variant="pro-light"] .preferences-menu-shortcuts-title,
body[data-theme-variant="pro-light"] .preferences-shortcut-btn,
body[data-theme-variant="pro-light"] .preferences-menu-reset,
body[data-theme-variant="pro-light"] .preferences-ui-scale-btn,
body[data-theme-variant="pro-light"] .welcome-modal .welcome-choice-title,
body[data-theme-variant="pro-light"] .welcome-modal .session-import-title,
body[data-theme-variant="pro-light"] #settings-session-modal .session-import-title,
body[data-theme-variant="pro-light"] #settings-session-modal .session-export-btn,
body[data-theme-variant="pro-light"] #settings-session-modal .session-import-pick,
body[data-theme-variant="pro-light"] .welcome-modal .session-import-pick {
  font-size: var(--pro-light-type-ui) !important;
  line-height: 0.95 !important;
  letter-spacing: 0.02em !important;
}

body[data-theme-variant="pro-light"] .welcome-modal .welcome-modal-intro,
body[data-theme-variant="pro-light"] .welcome-modal .welcome-choice-hint,
body[data-theme-variant="pro-light"] .welcome-modal .session-import-hint,
body[data-theme-variant="pro-light"] #settings-session-modal .session-export-name-label,
body[data-theme-variant="pro-light"] #settings-session-modal .session-import-hint,
body[data-theme-variant="pro-light"] .export-settings-menu-row-label,
body[data-theme-variant="pro-light"] .export-settings-menu-group-value,
body[data-theme-variant="pro-light"] .preferences-menu-section-value,
body[data-theme-variant="pro-light"] .preferences-shortcut-label,
body[data-theme-variant="pro-light"] .queue-clip-context-field {
  text-transform: none !important;
  font-size: var(--pro-light-type-copy) !important;
  line-height: 1.02 !important;
  letter-spacing: 0.01em !important;
}

body[data-theme-variant="pro-light"] #settings-session-modal .session-export-name,
body[data-theme-variant="pro-light"] .queue-clip-context-input,
body[data-theme-variant="pro-light"] input[type="text"],
body[data-theme-variant="pro-light"] input[type="number"],
body[data-theme-variant="pro-light"] input[type="url"],
body[data-theme-variant="pro-light"] textarea {
  text-transform: none !important;
  font-size: var(--pro-light-type-copy-small) !important;
  line-height: 1.05 !important;
}

body[data-theme-variant="pro-light"] .core-tile-label {
  font-size: 20px !important;
  line-height: 0.95 !important;
  letter-spacing: 0.01em !important;
  text-transform: none !important;
  padding: 5px 8px !important;
}

body[data-theme-variant="pro-light"] {
  --pro-light-transport-control-width: 180px;
  --pro-light-header-dropdown-width: calc(var(--pro-light-transport-control-width) * 1.5);
}

body[data-theme-variant="pro-light"] .transport-panel-left .transport-input,
body[data-theme-variant="pro-light"] .transport-panel-left .transport-input-menu,
body[data-theme-variant="pro-light"] .transport-panel-right .transport-volume {
  width: min(var(--pro-light-transport-control-width), 100%) !important;
  flex: 0 0 min(var(--pro-light-transport-control-width), 100%) !important;
  max-width: none !important;
}

body[data-theme-variant="pro-light"] .header-quality-menu,
body[data-theme-variant="pro-light"] .export-settings-menu,
body[data-theme-variant="pro-light"] .shortcuts-menu,
body[data-theme-variant="pro-light"] .preferences-menu {
  width: min(var(--pro-light-header-dropdown-width), 100%) !important;
  flex: 0 0 min(var(--pro-light-header-dropdown-width), 100%) !important;
  max-width: none !important;
}

body[data-theme-variant="pro-light"] #header-quality-menu,
body[data-theme-variant="pro-light"] #export-settings-menu,
body[data-theme-variant="pro-light"] #shortcuts-menu,
body[data-theme-variant="pro-light"] #preferences-menu {
  width: min(var(--pro-light-header-dropdown-width), 100%) !important;
  flex: 0 0 min(var(--pro-light-header-dropdown-width), 100%) !important;
  max-width: none !important;
}

body[data-theme-variant="pro-light"] .header-controls > .header-quality {
  width: min(var(--pro-light-header-dropdown-width), 100%) !important;
  flex: 0 0 min(var(--pro-light-header-dropdown-width), 100%) !important;
  max-width: none !important;
}

body[data-theme-variant="pro-light"] .header-controls > .header-quality .header-quality-menu {
  width: 100% !important;
  flex: 0 0 100% !important;
}

body[data-theme-variant="pro-light"] .transport-panel-right .transport-volume {
  margin-left: 0 !important;
}

body[data-theme-variant="pro-light"] .header-controls {
  gap: 6px;
}

body[data-theme-variant="pro-light"] {
  --pro-light-control-btn-height: 44px;
  --pro-light-header-ui-size: 23px;
  --pro-light-header-btn-height: var(--pro-light-control-btn-height);
  --pro-light-header-btn-pad-top: 0px;
  --pro-light-header-btn-pad-bottom: 0px;
  --pro-light-header-btn-pad-x: 10px;
  --pro-light-header-dropdown-pad-x: 12px;
  --transport-icon-btn-size: var(--pro-light-control-btn-height);
}

body[data-theme-variant="pro-light"] .header-controls .header-btn,
body[data-theme-variant="pro-light"] .header-controls .theme-toggle,
body[data-theme-variant="pro-light"] .header-controls .header-quality-menu-trigger,
body[data-theme-variant="pro-light"] .header-controls .export-settings-menu-trigger,
body[data-theme-variant="pro-light"] .header-controls .shortcuts-menu-trigger,
body[data-theme-variant="pro-light"] .header-controls .preferences-menu-trigger,
body[data-theme-variant="pro-light"] .header-links a {
  font-size: var(--pro-light-header-ui-size) !important;
  line-height: 0.92 !important;
  letter-spacing: 0.02em !important;
  font-weight: 500 !important;
  text-transform: uppercase !important;
  height: var(--pro-light-header-btn-height) !important;
  min-height: var(--pro-light-header-btn-height) !important;
  padding: var(--pro-light-header-btn-pad-top) var(--pro-light-header-btn-pad-x) var(--pro-light-header-btn-pad-bottom) !important;
  display: inline-flex !important;
  align-items: center !important;
  box-sizing: border-box !important;
  white-space: nowrap !important;
}

body[data-theme-variant="pro-light"] .header-controls .header-btn,
body[data-theme-variant="pro-light"] .header-controls .theme-toggle,
body[data-theme-variant="pro-light"] .header-links a {
  justify-content: center !important;
}

body[data-theme-variant="pro-light"] .header-controls .header-quality-menu-trigger,
body[data-theme-variant="pro-light"] .header-controls .export-settings-menu-trigger,
body[data-theme-variant="pro-light"] .header-controls .shortcuts-menu-trigger,
body[data-theme-variant="pro-light"] .header-controls .preferences-menu-trigger {
  width: 100% !important;
  justify-content: space-between !important;
  gap: 8px !important;
  padding-left: var(--pro-light-header-dropdown-pad-x) !important;
  padding-right: var(--pro-light-header-dropdown-pad-x) !important;
}

body[data-theme-variant="pro-light"] .header-controls .header-quality-menu-trigger-title,
body[data-theme-variant="pro-light"] .header-controls .export-settings-menu-trigger-label,
body[data-theme-variant="pro-light"] .header-controls .shortcuts-menu-trigger-label,
body[data-theme-variant="pro-light"] .header-controls .preferences-menu-trigger-label {
  font-size: inherit !important;
  line-height: inherit !important;
  letter-spacing: inherit !important;
  font-weight: inherit !important;
  text-transform: inherit !important;
  display: block !important;
}

body[data-theme-variant="pro-light"] .header-controls .header-quality-menu-trigger-chevron,
body[data-theme-variant="pro-light"] .header-controls .export-settings-menu-trigger-chevron,
body[data-theme-variant="pro-light"] .header-controls .shortcuts-menu-trigger-chevron,
body[data-theme-variant="pro-light"] .header-controls .preferences-menu-trigger-chevron {
  font-size: 0.9em !important;
  line-height: 1 !important;
  align-self: center !important;
}

body[data-theme-variant="pro-light"] .vislab-header-logo-frame {
  width: auto !important;
  height: auto !important;
  border-radius: 0 !important;
  clip-path: none !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

body[data-theme-variant="pro-light"] .vislab-header-logo {
  width: calc((var(--pro-light-header-btn-height) - 2px) * 1.5) !important;
  height: calc((var(--pro-light-header-btn-height) - 2px) * 1.5) !important;
  border-radius: 9px !important;
  clip-path: inset(0 round 9px);
}

body[data-theme-variant="pro-light"] .tab-buttons .tab-btn {
  font-size: var(--pro-light-header-ui-size) !important;
  line-height: 0.92 !important;
  letter-spacing: 0.02em !important;
  font-weight: 500 !important;
  text-transform: uppercase !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  height: var(--pro-light-header-btn-height) !important;
  min-height: var(--pro-light-header-btn-height) !important;
  padding: 0 4px !important;
  box-sizing: border-box !important;
}

body[data-theme-variant="pro-light"] .tab-buttons {
  min-height: var(--pro-light-header-btn-height) !important;
}

body[data-theme-variant="pro-light"] .transport-panel-left .transport-input,
body[data-theme-variant="pro-light"] .transport-panel-left .transport-input-menu {
  height: var(--pro-light-control-btn-height) !important;
  min-height: var(--pro-light-control-btn-height) !important;
}

body[data-theme-variant="pro-light"] .transport-input-menu-trigger,
body[data-theme-variant="pro-light"] .transport-input {
  height: var(--pro-light-control-btn-height) !important;
  min-height: var(--pro-light-control-btn-height) !important;
  padding: 0 10px !important;
  box-sizing: border-box !important;
}

body[data-theme-variant="pro-light"] .transport-input-menu-trigger {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: space-between !important;
}

body[data-theme-variant="pro-light"] .transport-input {
  display: block !important;
}

body[data-theme-variant="pro-light"] .transport-input.transport-input-native-hidden {
  display: none !important;
}

body[data-theme-variant="pro-light"] .transport-input-menu-panel,
body[data-theme-variant="pro-light"] .header-quality-menu-panel,
body[data-theme-variant="pro-light"] .export-settings-menu-panel,
body[data-theme-variant="pro-light"] .shortcuts-menu-panel,
body[data-theme-variant="pro-light"] .preferences-menu-panel {
  width: 100% !important;
  min-width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}

body[data-theme="pro"],
body[data-theme="pro-dark"],
body[data-theme-variant="pro-light"] {
  --vislab-ui-black: rgb(64, 64, 64);
  --vislab-ui-gray-1: rgb(216, 216, 216);
  --vislab-ui-gray-2: rgb(216, 216, 216);
  --vislab-ui-gray-3: rgb(64, 64, 64);
  --vislab-ui-accent: #5ff0be;
  --vislab-ui-accent-active: #5ff0be;
  --vislab-ui-accent-light: var(--vislab-ui-gray-1);
  --vislab-ui-accent-dark: var(--vislab-ui-gray-3);
  --vislab-ui-surface-1: var(--vislab-ui-gray-1);
  --vislab-ui-surface-2: var(--vislab-ui-gray-1);
  --vislab-ui-stroke: var(--vislab-ui-gray-3);
  --vislab-ui-text: var(--vislab-ui-gray-3);
  --vislab-ui-muted: var(--vislab-ui-gray-3);
  --vislab-ui-light-btn-bg: var(--vislab-ui-gray-1);
  --vislab-ui-light-btn-light: var(--vislab-ui-gray-1);
  --vislab-ui-light-btn-dark: var(--vislab-ui-gray-3);
  --vislab-ui-dark-btn-bg: var(--vislab-ui-gray-3);
  --vislab-ui-dark-btn-light: var(--vislab-ui-gray-1);
  --vislab-ui-dark-btn-dark: var(--vislab-ui-gray-3);
  --vislab-ui-track-bg: #000000;
  --vislab-ui-track-border: var(--vislab-ui-gray-3);
  --vislab-ui-accent-soft: rgba(95, 240, 190, 0.22);
  --vislab-ui-accent-overlay-18: rgba(95, 240, 190, 0.18);
  --vislab-ui-accent-overlay-20: rgba(95, 240, 190, 0.2);
  --vislab-ui-accent-border-55: rgba(95, 240, 190, 0.55);
  --vislab-ui-accent-border-60: rgba(95, 240, 190, 0.6);
  --accent: var(--vislab-ui-accent);
  --accent-soft: var(--vislab-ui-accent-soft);
}

body[data-ui-palette="cyan"] {
  --vislab-ui-accent: #6ecbff;
  --vislab-ui-accent-active: #45b8f6;
  --vislab-ui-accent-soft: rgba(110, 203, 255, 0.22);
  --vislab-ui-accent-overlay-18: rgba(110, 203, 255, 0.18);
  --vislab-ui-accent-overlay-20: rgba(110, 203, 255, 0.2);
  --vislab-ui-accent-border-55: rgba(54, 145, 194, 0.55);
  --vislab-ui-accent-border-60: rgba(54, 145, 194, 0.6);
}

body[data-ui-palette="magenta"] {
  --vislab-ui-accent: #ff67d4;
  --vislab-ui-accent-active: #f24bc4;
  --vislab-ui-accent-soft: rgba(255, 103, 212, 0.22);
  --vislab-ui-accent-overlay-18: rgba(255, 103, 212, 0.18);
  --vislab-ui-accent-overlay-20: rgba(255, 103, 212, 0.2);
  --vislab-ui-accent-border-55: rgba(175, 63, 144, 0.55);
  --vislab-ui-accent-border-60: rgba(175, 63, 144, 0.6);
}

body[data-ui-palette="amber"] {
  --vislab-ui-accent: #ffb347;
  --vislab-ui-accent-active: #f39a21;
  --vislab-ui-accent-soft: rgba(255, 179, 71, 0.22);
  --vislab-ui-accent-overlay-18: rgba(255, 179, 71, 0.18);
  --vislab-ui-accent-overlay-20: rgba(255, 179, 71, 0.2);
  --vislab-ui-accent-border-55: rgba(180, 116, 25, 0.55);
  --vislab-ui-accent-border-60: rgba(180, 116, 25, 0.6);
}

body[data-theme-variant="pro-light"] .tab-active-frame {
  background: var(--vislab-ui-accent);
}

body[data-theme-variant="pro-light"] .header-quality-menu-item:hover,
body[data-theme-variant="pro-light"] .header-quality-submenu-item:hover,
body[data-theme-variant="pro-light"] .core-tempo-menu-item:hover,
body[data-theme-variant="pro-light"] .transport-input-submenu-item:hover,
body[data-theme-variant="pro-light"] .transport-input-menu-item:hover {
  background: var(--vislab-ui-accent-overlay-18);
  border-color: var(--vislab-ui-accent-border-55);
}

body[data-theme-variant="pro-light"] .header-quality-submenu-item.is-active,
body[data-theme-variant="pro-light"] .core-tempo-menu-item.is-active,
body[data-theme-variant="pro-light"] .transport-input-submenu-item.is-active,
body[data-theme-variant="pro-light"] .transport-input-menu-direct.is-active {
  background: var(--vislab-ui-accent-overlay-20);
  border-color: var(--vislab-ui-accent-border-60);
}

body[data-theme-variant="pro-light"] .preferences-ui-scale-btn.is-active,
body[data-theme-variant="pro-light"] .preferences-ui-scale-btn[aria-pressed="true"],
body[data-theme-variant="pro-light"] .preferences-shortcut-btn.is-capturing,
body[data-theme-variant="pro-light"] .queue-transition-picker-btn.is-active,
body[data-theme-variant="pro-light"] .canvas-actions .transport-bar .btn.transport-record,
body[data-theme-variant="pro-light"] .canvas-actions .transport-bar .btn.transport-play.is-playing,
body[data-theme-variant="pro-light"] .queue-timeline-toolbar .timeline-play-btn.is-playing {
  --pro-light-btn-bg: var(--vislab-ui-accent);
  --pro-light-btn-bg-active: var(--vislab-ui-accent-active);
  --pro-light-btn-light: var(--vislab-ui-accent-light);
  --pro-light-btn-dark: var(--vislab-ui-accent-dark);
  --pro-light-btn-text: #010101;
}

body[data-theme-variant="pro-light"] input[type="range"] {
  background:
    linear-gradient(
      90deg,
      var(--vislab-ui-accent) 0%,
      var(--vislab-ui-accent) var(--fader-fill, 50%),
      var(--vislab-ui-track-bg) var(--fader-fill, 50%),
      var(--vislab-ui-track-bg) 100%
    ) !important;
}

body[data-theme-variant="pro-light"] input[type="range"]::-moz-range-progress {
  background: var(--vislab-ui-accent);
}

body[data-theme-variant="pro-light"] input[type="range"]::-webkit-slider-thumb,
body[data-theme-variant="pro-light"] input[type="range"]::-moz-range-thumb {
  background-color: var(--vislab-ui-accent) !important;
  box-shadow:
    inset 1px 1px 1px var(--vislab-ui-accent-light),
    inset -1px -1px 1px var(--vislab-ui-accent-dark),
    2px 2px 4px #000,
    0 0 0 1px rgba(255, 255, 255, 0.25) !important;
}

:root {
  --vislab-menu-overlay-z: 35000;
}

.transport-input-menu.is-open,
.header-quality-menu.is-open,
.export-settings-menu.is-open,
.shortcuts-menu.is-open,
.preferences-menu.is-open,
.core-tempo-menu.is-open {
  z-index: var(--vislab-menu-overlay-z) !important;
  isolation: isolate;
}

.transport-input-menu-panel,
.transport-input-submenu,
.header-quality-menu-panel,
.header-quality-submenu,
.export-settings-menu-panel,
.shortcuts-menu-panel,
.preferences-menu-panel,
.export-settings-submenu,
.core-tempo-menu-panel {
  z-index: calc(var(--vislab-menu-overlay-z) + 1) !important;
}

body[data-theme-invert="pro-light"] {
  filter: invert(1) hue-rotate(180deg);
}
