@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@600;700;800&family=Inter:wght@400;500;600&display=swap');

:root {
  --bg: #2b1a11;
  --panel: #111a2f;
  --panel-strong: #0d1529;
  --border: #1f2a44;
  --text: #e5ecff;
  --muted: #8ea3c7;
  --accent: #7c5bff;
  --accent-2: #6dd3ff;
  --accent-3: #2ed17a;
  --role-drum: #7c5bff;
  --role-bass: #2ed17a;
  --role-harmony: #6dd3ff;
  --role-melody: #ff9f43;
  --shadow: 0 18px 40px rgba(0, 0, 0, 0.4);
  --radius: 14px;
  --pad: 16px;
  font-family: "Inter", "Segoe UI", system-ui, sans-serif;
  background: var(--bg);
  color: var(--text);
}

* { box-sizing: border-box; }
[hidden] { display: none !important; }
h1, h2, h3, .brand strong { font-family: "Manrope", "Inter", "Segoe UI", system-ui, sans-serif; letter-spacing: -0.01em; }
body { margin: 0; background: var(--bg); color: var(--text); line-height: 1.4; position: relative; overflow-x: hidden; }
h1, h2, h3, .brand strong { font-family: "Manrope", "Inter", "Segoe UI", system-ui, sans-serif; letter-spacing: -0.01em; }
body::before {
  content:'';
  position: fixed;
  inset: 0;
  background:
    repeating-linear-gradient(90deg, rgba(255,255,255,0.02) 0, rgba(255,255,255,0.02) 2px, transparent 2px, transparent 18px),
    repeating-linear-gradient(0deg, rgba(0,0,0,0.06) 0, rgba(0,0,0,0.06) 1px, transparent 1px, transparent 20px),
    radial-gradient(circle at 30% 20%, rgba(255,255,255,0.06), transparent 35%),
    radial-gradient(circle at 70% 80%, rgba(0,0,0,0.12), transparent 45%),
    linear-gradient(135deg, #3a2417, #2b1a11 40%, #23130c);
  opacity: 0.4;
  pointer-events: none;
  z-index: -1;
  mix-blend-mode: soft-light;
}
body::after {
  content:'';
  position: fixed;
  inset: 0;
  background: radial-gradient(120% 80% at 20% 20%, rgba(0,0,0,0.3), transparent 55%), radial-gradient(120% 80% at 80% 80%, rgba(0,0,0,0.28), transparent 55%), linear-gradient(180deg, rgba(255,255,255,0.08) 0%, transparent 18%);
  pointer-events:none;
  z-index:-1;
}
a { color: inherit; }

.topbar { display: flex; justify-content: space-between; align-items: center; padding: 16px 20px; border-bottom: 1px solid rgba(255,255,255,0.04); background: linear-gradient(135deg, rgba(12,19,35,0.9), rgba(10,15,28,0.92)); backdrop-filter: blur(16px); position: sticky; top:0; z-index:10; box-shadow: 0 14px 32px rgba(0,0,0,0.4), inset 0 1px 0 rgba(255,255,255,0.05); }
.topbar::after { content:''; position:absolute; left:0; right:0; bottom:-6px; height:6px; background: linear-gradient(90deg, rgba(255,255,255,0.12), rgba(255,255,255,0)); opacity:0.5; }
.brand { display:flex; flex-direction:column; gap:4px; }
.eyebrow { text-transform: uppercase; letter-spacing: 0.08em; color: var(--muted); font-size: 12px; margin:0; }
.status-chips { display:flex; gap:10px; align-items:center; }
.chip { padding:6px 10px; border-radius: 999px; border:1px solid var(--border); background: var(--panel); font-size:12px; }
.chip.ok { border-color: var(--accent-3); color: #9ef3c4; }
.status-banner { margin: 0 18px 0; padding: 10px 14px; background: linear-gradient(120deg, rgba(34,193,195,0.12), rgba(45,110,195,0.12)); border:1px solid rgba(109,211,255,0.25); color: #9ed9ff; border-radius: 12px; box-shadow: 0 10px 24px rgba(0,0,0,0.28); font-size: 13px; letter-spacing: 0.01em; transform: translateY(0); transition: opacity 180ms ease, transform 180ms ease; }
.status-banner.hidden { opacity:0; transform: translateY(-6px); pointer-events:none; }
.status-banner.success { background: linear-gradient(120deg, rgba(46,209,122,0.12), rgba(109,211,255,0.08)); border-color: rgba(46,209,122,0.35); color: #b5f5d2; }
.status-banner.warn { background: linear-gradient(120deg, rgba(255,183,77,0.12), rgba(255,123,156,0.08)); border-color: rgba(255,183,77,0.45); color: #ffd8a3; }
.status-banner.error, .status-banner.err { background: linear-gradient(120deg, rgba(255,123,156,0.16), rgba(255,99,132,0.12)); border-color: rgba(255,123,156,0.45); color: #ffc6d8; }
.candidate-debug { margin-top:8px; padding:8px 10px; border:1px dashed var(--border); border-radius:10px; background: rgba(255,255,255,0.02); }
.candidate-debug details { color: var(--muted); font-size:12px; }
.debug-grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)); gap:6px; margin:6px 0; }
.debug-grid div { padding:4px 6px; background: rgba(255,255,255,0.03); border-radius:6px; border:1px solid rgba(255,255,255,0.05); }
.debug-reasons { font-size:12px; color: var(--muted); margin-top:4px; }

.layout { display:grid; grid-template-columns: 320px 140px minmax(0, 1fr); gap:24px; padding:24px; }
.column { display:flex; flex-direction:column; gap:18px; }
.column-spine { position: relative; }
.column-center { display:none; }
.panel { background: var(--panel); border:1px solid var(--border); border-radius: var(--radius); padding: var(--pad); box-shadow: var(--shadow); }
.panel { box-shadow: 0 18px 38px rgba(0,0,0,0.42), 0 0 0 1px rgba(255,255,255,0.04), inset 0 1px 0 rgba(255,255,255,0.03); position: relative; overflow:hidden; }
.panel::before { content:''; position:absolute; inset:1px; border-radius: calc(var(--radius) - 2px); pointer-events:none; background: linear-gradient(145deg, rgba(255,190,140,0.04), rgba(255,255,255,0)); mix-blend-mode: screen; }
.panel::after { content:''; position:absolute; inset:0; border-radius: var(--radius); pointer-events:none; background:
  radial-gradient(circle at 12px 12px, rgba(0,0,0,0.45), transparent 14px),
  radial-gradient(circle at calc(100% - 12px) 12px, rgba(0,0,0,0.45), transparent 14px),
  radial-gradient(circle at 12px calc(100% - 12px), rgba(0,0,0,0.45), transparent 14px),
  radial-gradient(circle at calc(100% - 12px) calc(100% - 12px), rgba(0,0,0,0.45), transparent 14px);
  opacity:0.2;
}
.panel-heading { display:flex; justify-content: space-between; gap:12px; align-items:flex-start; }
.panel-heading h2, .panel-heading h3 { margin:0; }
.subtext { color: var(--muted); margin:4px 0 0; }
.panel-heading { position: relative; padding-top:4px; align-items:center; }
.panel-heading.flush { padding-top:0; margin-bottom:4px; }
.workbench-header { display:flex; align-items:flex-start; gap:12px; flex-wrap:wrap; position: relative; z-index: 2; }
.workbench-header .pattern-panel { flex: 1 1 320px; min-width: 260px; container-type: inline-size; }
.workbench-header .reference-inline { flex: 1 1 360px; min-width: 280px; }

.spine-panel { position: sticky; top: 86px; background: linear-gradient(150deg, rgba(16,24,44,0.9), rgba(11,17,31,0.92)); box-shadow: 0 16px 32px rgba(0,0,0,0.38), inset 0 1px 0 rgba(255,255,255,0.04); }
.spine-stats { display:grid; gap:10px; margin-top:8px; }
.stat-chip { display:flex; justify-content:space-between; align-items:center; padding:10px 12px; border:1px solid var(--border); border-radius:12px; background: rgba(255,255,255,0.03); box-shadow: inset 0 0 0 1px rgba(255,255,255,0.02); }
.stat-chip .label { color: var(--muted); font-size:12px; text-transform:uppercase; letter-spacing:0.08em; }
.stat-chip .value { font-weight:700; font-size:16px; color: var(--accent-2); }
.spine-actions { display:flex; flex-direction:column; gap:8px; margin-top:12px; }
.spine-actions .ghost { width:100%; justify-content:center; }

.pill-switch { display:inline-flex; padding:4px; background: var(--panel-strong); border-radius:999px; border:1px solid var(--border); }
.pill { border:none; background:transparent; color:var(--muted); padding:8px 14px; border-radius:999px; cursor:pointer; }
.pill.active { background: linear-gradient(120deg, var(--accent-2), var(--accent)); color: #050910; font-weight:700; }

.stack { display:flex; flex-direction:column; gap:12px; }
.field { display:flex; flex-direction:column; gap:6px; color:var(--muted); font-size:14px; }
input, select, textarea { padding:10px 12px; border-radius:10px; border:1px solid var(--border); background: var(--panel-strong); color: var(--text); }
.input-row { display:flex; gap:8px; align-items:center; }
.dropzone { position:relative; border:1px dashed var(--border); border-radius:12px; padding:18px; text-align:center; background: rgba(255,255,255,0.02); color: var(--muted); cursor:pointer; }
.dropzone strong { display:block; color:var(--text); margin-bottom:6px; }
.dropzone input[type=file] { position:absolute; inset:0; opacity:0; cursor:pointer; z-index:2; }
.dropzone-reference { background: radial-gradient(circle at 30% 30%, rgba(109,211,255,0.08), rgba(0,0,0,0.45)); border:1px dashed rgba(109,211,255,0.4); box-shadow: 0 12px 22px rgba(0,0,0,0.35), inset 0 1px 0 rgba(255,255,255,0.04); }
.drop-icon { font-size:28px; color:#9ed9ff; margin-bottom:6px; }
.dropzone-reference { background: radial-gradient(circle at 30% 30%, rgba(109,211,255,0.08), rgba(0,0,0,0.45)); border:1px dashed rgba(109,211,255,0.4); box-shadow: 0 12px 22px rgba(0,0,0,0.35), inset 0 1px 0 rgba(255,255,255,0.04); }
.drop-icon { font-size:28px; color:#9ed9ff; margin-bottom:6px; }

.role-grid { display:grid; grid-template-columns:1fr; gap:10px; }
.role-grid label { display:flex; align-items:center; gap:8px; color: var(--muted); }

.reference-panel { position: relative; }
[data-reference-mode] .reference-mini-bar { position: sticky; top: 86px; z-index: 3; }
.reference-mini-bar { display:flex; justify-content:space-between; align-items:center; padding:10px 12px; margin-bottom:10px; border-radius:12px; border:1px solid rgba(109,211,255,0.25); background: linear-gradient(120deg, rgba(109,211,255,0.08), rgba(124,91,255,0.08)); box-shadow: 0 10px 24px rgba(0,0,0,0.24); }
.reference-mini-bar .mini-label { text-transform:uppercase; letter-spacing:0.08em; font-size:11px; color: var(--muted); }
.reference-mini-bar .mini-values { display:flex; gap:6px; align-items:center; font-weight:700; color: #eaf3ff; }
.reference-mini-bar .dot { opacity:0.6; }
[data-reference-pane] { display: none; }
[data-reference-mode="hum"] [data-reference-pane="hum"],
[data-reference-mode="loop"] [data-reference-pane="loop"],
[data-reference-mode="instruments"] [data-reference-pane="instruments"] { display: block; }
.reference-pane { margin-top: 10px; padding: 12px; border-radius: 14px; border:1px solid var(--border); background: radial-gradient(circle at top, rgba(18,24,44,0.95), rgba(8,10,20,0.95)); box-shadow: inset 0 0 0 1px rgba(255,255,255,0.02); }
.reference-pane-instruments { overflow: auto; max-height: var(--reference-upload-pane-height, 340px); }
.loop-lab-controls { display:grid; gap:10px; margin-top:12px; }
.loop-lab-controls .field { margin:0; }
.loop-preview-audio { width:100%; margin:8px 0; border-radius:10px; }
.loop-detect-status { font-size: 13px; color: var(--muted); }
.loop-detect-hints { font-size:12px; color: var(--muted); }
.loop-detect-debug { display:none; }
.waveform-wrap { margin-top:6px; display:flex; flex-direction:column; gap:6px; }
.waveform-label { font-size:13px; color: var(--muted); }
.waveform-box { min-height:70px; border:1px dashed var(--border); border-radius:10px; padding:8px; background: rgba(255,255,255,0.03); }
.waveform-box.inline { min-height:50px; margin-top:10px; }
.waveform-box canvas { width:100%; height:60px; display:block; }
#upload-waveform:empty { display:none; }

.toolbar { display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
.inline-field { display:flex; align-items:center; gap:6px; color:var(--muted); }

.tracks { display:flex; flex-direction:row; flex-wrap:nowrap; gap:8px; overflow-x:auto; align-items:stretch; }
.track { flex:1 1 22%; min-width:240px; }
.track { background: linear-gradient(145deg, rgba(14,20,35,0.95), rgba(10,16,28,0.92)); border:1px solid var(--border); border-radius:14px; padding:14px; position: relative; overflow:hidden; box-shadow: 0 14px 30px rgba(0,0,0,0.35), inset 0 1px 0 rgba(255,255,255,0.02); animation: floatIn 260ms ease both; }
.track-title-wrap { display:flex; align-items:flex-start; justify-content:space-between; gap:10px; width:100%; }
.track-header-actions { display:flex; align-items:center; gap:8px; flex:0 0 auto; }
.track-enable-toggle {
  flex: 0 0 auto;
  min-width: 46px;
  height: 26px;
  padding: 0 9px;
  border-radius: 999px;
  border: 1px solid rgba(109, 211, 255, 0.35);
  background: linear-gradient(135deg, rgba(109,211,255,0.2), rgba(46,209,122,0.16));
  color: #eaf6ff;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.02em;
  cursor: pointer;
  transition: transform 120ms ease, box-shadow 120ms ease, border-color 120ms ease, background 120ms ease, color 120ms ease, opacity 120ms ease;
  box-shadow: 0 8px 18px rgba(0,0,0,0.28), inset 0 1px 0 rgba(255,255,255,0.06);
}
.track-enable-toggle:hover,
.track-enable-toggle:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(109, 211, 255, 0.55);
  box-shadow: 0 12px 22px rgba(0,0,0,0.34), inset 0 1px 0 rgba(255,255,255,0.08);
}
.track-enable-toggle.is-off {
  border-color: rgba(255,255,255,0.14);
  background: linear-gradient(135deg, rgba(255,255,255,0.06), rgba(0,0,0,0.32));
  color: rgba(229,236,255,0.72);
}
.track-mute-toggle {
  flex: 0 0 auto;
  width: 26px;
  height: 26px;
  padding: 0;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.16);
  background: linear-gradient(135deg, rgba(255,255,255,0.08), rgba(0,0,0,0.3));
  color: #eef5ff;
  font-size: 12px;
  line-height: 1;
  cursor: pointer;
  transition: transform 120ms ease, box-shadow 120ms ease, border-color 120ms ease, background 120ms ease, opacity 120ms ease;
  box-shadow: 0 8px 18px rgba(0,0,0,0.25), inset 0 1px 0 rgba(255,255,255,0.06);
}
.track-mute-toggle:hover,
.track-mute-toggle:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(109,211,255,0.42);
  box-shadow: 0 12px 22px rgba(0,0,0,0.32), inset 0 1px 0 rgba(255,255,255,0.08);
}
.track-mute-toggle.is-muted,
.track-mute-toggle[aria-pressed="true"] {
  border-color: rgba(255,120,120,0.46);
  background: linear-gradient(135deg, rgba(255,120,120,0.2), rgba(66,18,18,0.4));
  color: #ffe3e3;
}
.track-mute-toggle:disabled {
  opacity: 0.42;
  cursor: not-allowed;
  transform: none;
  box-shadow: 0 6px 14px rgba(0,0,0,0.18);
}
.track.track-disabled {
  opacity: 0.62;
  filter: saturate(0.56);
}
.track.track-disabled .track-drop {
  border-color: rgba(255,255,255,0.12);
  background-image: none;
  background-color: rgba(255,255,255,0.015);
}
.track.track-disabled .track-title,
.track.track-disabled .track-role {
  color: rgba(229,236,255,0.72);
}
.track.track-disabled .channel-row {
  opacity: 0.78;
}
.track.track-disabled .track-lock-icon,
.track.track-disabled .track-lock-info,
.track.track-disabled .track-plus,
.track.track-disabled .track-clear-x {
  opacity: 0.45;
}
.track-lock-icon { width:26px; height:26px; border-radius:999px; border:1px solid rgba(255,255,255,0.1); background: radial-gradient(circle at 30% 30%, rgba(255,255,255,0.1), rgba(0,0,0,0.5)); color:#f2f2f2; cursor:pointer; box-shadow: inset 0 1px 2px rgba(255,255,255,0.08), 0 6px 14px rgba(0,0,0,0.3); transition: transform 100ms ease, box-shadow 120ms ease, border-color 120ms ease; font-size:13px; }
.track-lock-icon:hover { box-shadow: inset 0 1px 2px rgba(255,255,255,0.14), 0 8px 16px rgba(0,0,0,0.35); }
.track-lock-icon.locked { background: radial-gradient(circle at 30% 30%, rgba(255,80,80,0.22), rgba(70,10,10,0.7)); border-color: rgba(255,120,120,0.4); box-shadow: inset 0 1px 2px rgba(255,200,200,0.18), 0 8px 16px rgba(0,0,0,0.4); color: #ffd8d8; }
.track.track-locked { opacity:0.62; filter:saturate(0.5); }
.track::before { content:''; position:absolute; inset:0; border-radius:14px; pointer-events:none; box-shadow: inset 0 0 0 1px rgba(255,255,255,0.02); }
.track-header { display:flex; justify-content:space-between; gap:10px; padding:0 0 6px 0; min-height:0; border-bottom:1px solid rgba(255,255,255,0.03); }
.track-title { font-weight:700; }
.track-role { color:var(--muted); font-size:13px; display:block; }
.track[data-role="drum"] .track-header { border-bottom-color: rgba(124,91,255,0.35); }
.track[data-role="bass"] .track-header { border-bottom-color: rgba(46,209,122,0.35); }
.track[data-role="harmony"] .track-header { border-bottom-color: rgba(109,211,255,0.35); }
.track[data-role="melody"] .track-header { border-bottom-color: rgba(255,159,67,0.35); }
.track[data-role="drum"] .track-title { color: var(--role-drum); }
.track[data-role="bass"] .track-title { color: var(--role-bass); }
.track[data-role="harmony"] .track-title { color: var(--role-harmony); }
.track[data-role="melody"] .track-title { color: var(--role-melody); }
.track-actions { display:flex; gap:6px; flex-wrap:wrap; }
.track .track-actions { display:none; }
.track.filled-track { box-shadow: 0 16px 36px rgba(0,0,0,0.45), 0 0 0 1px rgba(124,91,255,0.18); }
.track.filled-track::before { box-shadow: inset 0 0 0 1px rgba(124,91,255,0.18); }
.track.filled-track .track-actions { display:flex; }
.track-actions .prev-track,
.track-actions .next-track { margin-left: auto; }
.track-title-wrap { display:flex; align-items:flex-start; justify-content:flex-start; gap:10px; width:100%; min-width:0; }
.track-control-strip {
  display:flex;
  align-items:center;
  gap:6px;
  flex-wrap:nowrap;
  margin:8px 0 10px;
  min-width:0;
}
.track-control-strip > * {
  flex:0 0 auto;
}
.track-ref-controls { margin:8px 0; display:flex; flex-direction:column; gap:6px; }
.track-ref-buttons { display:flex; gap:6px; flex-wrap:wrap; }
.track-ref-controls label { display:none; }
.track-reference-slider { display:none; }
.track-fx-toggles { display:none; }
.track-transform { display:none; }
.track-drop { position: relative; margin-top:0; padding:14px; border:1px dashed rgba(124,91,255,0.35); border-radius:12px; color:var(--muted); background: radial-gradient(circle at 20% 20%, rgba(124,91,255,0.08), rgba(255,255,255,0.01)), rgba(255,255,255,0.02); min-height:64px; display:flex; align-items:center; justify-content:center; text-align:center; background-size: 160px 160px; background-repeat: repeat; }
.track-drop::after { content:'Auto-fill best match'; position:absolute; bottom:8px; right:12px; font-size:11px; color: rgba(255,255,255,0.55); }
.track[data-role="drum"] .track-drop { border-color: rgba(124,91,255,0.5); background-image: radial-gradient(circle at 10% 20%, rgba(124,91,255,0.08), transparent 28%), repeating-linear-gradient(45deg, rgba(124,91,255,0.05), rgba(124,91,255,0.05) 6px, transparent 6px, transparent 18px); }
.track[data-role="bass"] .track-drop { border-color: rgba(46,209,122,0.5); background-image: radial-gradient(circle at 15% 30%, rgba(46,209,122,0.08), transparent 28%), repeating-linear-gradient(135deg, rgba(46,209,122,0.05), rgba(46,209,122,0.05) 6px, transparent 6px, transparent 18px); }
.track[data-role="harmony"] .track-drop { border-color: rgba(109,211,255,0.5); background-image: radial-gradient(circle at 18% 25%, rgba(109,211,255,0.08), transparent 28%), repeating-linear-gradient(90deg, rgba(109,211,255,0.05), rgba(109,211,255,0.05) 6px, transparent 6px, transparent 18px); }
.track[data-role="melody"] .track-drop { border-color: rgba(255,159,67,0.5); background-image: radial-gradient(circle at 18% 25%, rgba(255,159,67,0.08), transparent 28%), repeating-linear-gradient(120deg, rgba(255,159,67,0.05), rgba(255,159,67,0.05) 6px, transparent 6px, transparent 18px); }
.track-plus { background: linear-gradient(135deg, rgba(109,211,255,0.9), rgba(124,91,255,0.9)); color:#061021; width:26px; height:26px; border-radius:999px; border:none; position:static; font-size:16px; font-weight:800; box-shadow: 0 8px 16px rgba(0,0,0,0.28), 0 0 0 1px rgba(255,255,255,0.08); transition: transform 120ms ease, box-shadow 120ms ease; display:inline-flex; align-items:center; justify-content:center; padding:0; }
.track[data-role="drum"] .track-plus { background: linear-gradient(135deg, rgba(124,91,255,0.95), rgba(109,211,255,0.85)); }
.track[data-role="bass"] .track-plus { background: linear-gradient(135deg, rgba(46,209,122,0.95), rgba(109,211,255,0.75)); }
.track[data-role="harmony"] .track-plus { background: linear-gradient(135deg, rgba(109,211,255,0.95), rgba(124,91,255,0.8)); }
.track[data-role="melody"] .track-plus { background: linear-gradient(135deg, rgba(255,159,67,0.95), rgba(124,91,255,0.7)); }
.track-plus:hover,
.track-plus:focus-visible { transform: translateY(-1px) scale(1.03); box-shadow: 0 16px 28px rgba(0,0,0,0.4), 0 0 0 1px rgba(255,255,255,0.12); }
.track-plus:active { transform: translateY(0); }
.track.filled-track .track-plus { display:none; }
.track-clear-x { display:none; align-items:center; justify-content:center; width:26px; height:26px; border-radius:999px; border:1px solid rgba(255,255,255,0.12); background: radial-gradient(circle at 30% 30%, rgba(255,255,255,0.12), rgba(0,0,0,0.55)); color: rgba(255,255,255,0.9); position:static; font-size:16px; line-height:1; cursor:pointer; box-shadow: 0 8px 16px rgba(0,0,0,0.28), 0 0 0 1px rgba(255,255,255,0.06); transition: transform 120ms ease, box-shadow 120ms ease, border-color 120ms ease, background 120ms ease; z-index: 4; padding:0; }
.track.filled-track .track-clear-x { display:flex; }
.track-clear-x:hover,
.track-clear-x:focus-visible { transform: translateY(-1px) scale(1.03); border-color: rgba(255,80,80,0.55); box-shadow: 0 16px 28px rgba(0,0,0,0.4), 0 0 0 1px rgba(255,80,80,0.18); background: radial-gradient(circle at 30% 30%, rgba(255,120,120,0.22), rgba(70,10,10,0.7)); }
.track-clear-x:active { transform: translateY(0); }
.fx-tags { display:flex; flex-wrap:wrap; gap:6px; font-size:11px; margin:6px 0; color: var(--muted); }
.fx-tags span { border:1px solid rgba(255,255,255,0.08); border-radius:999px; padding:3px 8px; background: rgba(255,255,255,0.03); }
.fit-badge { margin-top:4px; font-size:11px; line-height:1.2; color: var(--muted); }
.fit-badge.warning { color:#ff9f43; }
.track-warning { margin-top:6px; padding:6px 10px; border-radius:8px; background: rgba(255,159,67,0.1); border:1px solid rgba(255,159,67,0.35); color:#ffb366; font-size:12px; }
.track-warning.err { background: rgba(255,123,156,0.12); border-color: rgba(255,123,156,0.45); color:#ff9bb4; }
.track-warning .inline-actions { display:flex; gap:6px; margin-top:4px; }
.track-warning .inline-actions button { border:1px solid rgba(255,255,255,0.2); background: rgba(255,255,255,0.04); color: var(--text); border-radius:8px; padding:4px 8px; font-size:11px; }
.track-alt-controls { display:flex; align-items:center; gap:8px; margin-top:10px; padding-top:8px; border-top:1px solid rgba(255,255,255,0.08); }
.track-alt-controls.track-alt-empty { opacity:0.58; }
.track-controls { display:flex; align-items:center; gap:8px; flex-wrap:wrap; margin-top:6px; }
.track-controls label { display:flex; align-items:center; gap:6px; font-size:12px; min-width:0; }
.track-controls input[type="range"] {
  -webkit-appearance: none;
  appearance: none;
  width: 120px;
  min-width: 120px;
  height: 18px;
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
}
.track-controls input[type="range"]::-webkit-slider-runnable-track {
  height: 6px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(109,211,255,0.45), rgba(124,91,255,0.28));
}
.track-controls input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 16px;
  height: 16px;
  margin-top: -5px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.18);
  background: linear-gradient(180deg, #f8fbff, #c7d7ff);
  box-shadow: 0 6px 14px rgba(0,0,0,0.28);
}
.track-controls input[type="range"]::-moz-range-track {
  height: 6px;
  border-radius: 999px;
  border: 0;
  background: linear-gradient(90deg, rgba(109,211,255,0.45), rgba(124,91,255,0.28));
}
.track-controls input[type="range"]::-moz-range-thumb {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.18);
  background: linear-gradient(180deg, #f8fbff, #c7d7ff);
  box-shadow: 0 6px 14px rgba(0,0,0,0.28);
}
.track-controls input[type="range"]::-moz-range-progress {
  height: 6px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(109,211,255,0.6), rgba(124,91,255,0.38));
}
.track-controls input[type="range"]:focus-visible {
  outline: none;
}
.track-drop.filled,
.track-slot.filled {
  display: block;
  text-align: left;
  align-items: stretch;
  justify-content: flex-start;
  min-width: 0;
  overflow: hidden;
}
.track-drop.filled::after,
.track-slot.filled::after {
  display: none;
}
.channel-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 8px;
  width: 100%;
  min-width: 0;
}
.channel-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
  flex-wrap: wrap;
  min-width: 0;
}
.channel-title-stack { display:flex; flex-direction:column; align-items:flex-start; gap:2px; }
.channel-title-stack {
  flex: 1 1 180px;
  min-width: 0;
  max-width: 100%;
}
.channel-title {
  display: block;
  width: 100%;
  min-width: 0;
  max-width: 100%;
  font-weight: 700;
  line-height: 1.25;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.channel-instrument-family.subtext { margin:2px 0 0; font-size:12px; }
.channel-instrument-family.subtext {
  width: 100%;
  min-width: 0;
  max-width: 100%;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.channel-tags {
  display: flex;
  flex: 1 1 100%;
  gap: 6px;
  flex-wrap: wrap;
  min-width: 0;
  max-width: 100%;
}
.channel-tag {
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.channel-waveform {
  display: block;
  width: 100% !important;
  max-width: 100%;
  min-width: 0;
  height: 60px;
}
.track-audio-status {
  min-width: 0;
  max-width: 100%;
  font-size: 12px;
  line-height: 1.35;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.thumb-button { border:1px solid var(--border); border-radius:12px; padding:6px 10px; background: rgba(255,255,255,0.03); color: var(--text); cursor:pointer; }
.thumb-button:disabled { opacity:0.5; cursor:not-allowed; }
.thumb-button.is-selected { border-color: rgba(109,211,255,0.55); background: rgba(109,211,255,0.16); color:#dff7ff; }
.track-play { min-width: 88px; }
.track-play.is-playing { background: rgba(109,211,255,0.2); border-color: rgba(109,211,255,0.55); color: #dff7ff; }
.badge { border:1px solid var(--border); border-radius:999px; padding:4px 8px; font-size:11px; color: var(--muted); background: rgba(255,255,255,0.05); }
.badge.warn { border-color: #ff9f43; color:#ff9f43; }
.badge.ok { border-color: #7ce7a6; color:#7ce7a6; }

.track { position: relative; }
.badge.err { border-color: #ff7b9c; color:#ff7b9c; }

.timing-panel { background: linear-gradient(140deg, rgba(10,16,28,0.9), rgba(8,12,22,0.9)); border: 1px solid #1f293f; border-radius: 14px; padding: 0.7rem 1rem; margin: 0; box-shadow: 0 14px 28px rgba(0,0,0,0.35); position: relative; overflow:hidden; }
.timing-panel::before { content:''; position:absolute; inset:0; pointer-events:none; box-shadow: inset 0 0 0 1px rgba(109,211,255,0.12); border-radius:14px; background: radial-gradient(circle at 50% 20%, rgba(109,211,255,0.07), transparent 40%); }
.timing-header { display:flex; justify-content:space-between; align-items:center; gap:1rem; flex-wrap:wrap; color:var(--muted); }
.timing-primary { color: var(--text); font-weight:700; }
.timing-subtext { color: var(--muted); font-size:0.9rem; }
.metronome-toggle { display:flex; align-items:center; gap:0.35rem; color:var(--muted); }
.timing-grid { position:relative; margin-top:0.85rem; border:1px dashed #2a344f; border-radius:12px; padding:0.5rem; display:grid; grid-auto-flow:column; grid-auto-columns:minmax(0, 1fr); gap:0.4rem; overflow:visible; width:100%; min-width:0; }
.timing-bar { min-width:0; border-radius:9px; border:1px solid #313f66; padding:0.32rem; display:grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap:0.22rem; background: rgba(11,17,31,0.85); }
.timing-beat { min-width:0; border-radius:6px; border:1px dashed #3c4b7a; text-align:center; font-size:clamp(0.62rem, 0.85vw, 0.85rem); line-height:1; padding:0.22rem 0; color: #aab6ff; background: rgba(15,23,42,0.8); }
.timing-playhead { position:absolute; top:0; bottom:0; width:2px; background: #6dd3ff; box-shadow: 0 0 14px rgba(109,211,255,0.65); pointer-events:none; display:none; }
.timing-playhead.pulse { animation: playheadPulse 1.1s ease-in-out infinite; }
@keyframes playheadPulse {
  0% { box-shadow: 0 0 10px rgba(109,211,255,0.4); opacity:0.8; }
  50% { box-shadow: 0 0 18px rgba(109,211,255,0.9); opacity:1; }
  100% { box-shadow: 0 0 10px rgba(109,211,255,0.4); opacity:0.8; }
}

.pattern-block { margin-top:14px; }
.pattern-grid { width: 100%; min-width: 0; background: rgba(5,7,13,0.85); border: 1px solid #1f293f; border-radius: 12px; padding: 1rem; display: flex; flex-direction: column; gap: 0.75rem; }
.pattern-toolbar {
  display:grid;
  grid-template-columns: minmax(168px, 182px) minmax(0, 1fr) minmax(0, 1fr);
  grid-template-rows: auto auto auto;
  gap:10px;
  align-items:stretch;
  min-width:0;
}
.pattern-hero-actions,
.pattern-toolbar-main {
  display: contents;
}
.pattern-hero-actions {
  min-width:0;
}
.pattern-toolbar-main {
  min-width: 0;
}
.pattern-header-meta { display:flex; align-items:center; gap:14px; min-width:0; flex-wrap:wrap; }
.pattern-header-meta .inline-field { color: var(--text); font-weight:700; margin:0; }
.pattern-header-meta .value { color: var(--accent-2); }
.pattern-hero-actions > .ghost { min-width:0; height:100%; min-height:46px; width:100%; justify-content:center; padding:0.55rem 0.85rem; border-radius:16px; font-size:0.95rem; font-weight:900; letter-spacing:0.01em; background: linear-gradient(135deg, rgba(49,224,148,0.24), rgba(42,120,255,0.18)); border: 1px solid rgba(109,211,255,0.26); box-shadow: 0 14px 30px rgba(0,0,0,0.3), inset 0 1px 0 rgba(255,255,255,0.05); }
.pattern-hero-actions #workbench-play { grid-column: 1; grid-row: 1; }
.pattern-hero-actions #random-arrange { grid-column: 1; grid-row: 2; }
.pattern-hero-actions .random-hero {
  white-space: normal;
  font-size: 0.82rem;
  letter-spacing: 0;
  line-height: 1.15;
}
.pattern-hero-actions #workbench-play.is-stop { border-color: rgba(255,123,156,0.45); background: linear-gradient(135deg, rgba(255,123,156,0.18), rgba(255,74,104,0.14)); color: #ffd4df; }
.pattern-hero-actions #random-arrange.ghost { background: linear-gradient(135deg, rgba(46,209,122,0.24), rgba(74,222,128,0.18)); border-color: rgba(46,209,122,0.28); }
.pattern-toolbar > * { min-width: 0; }
.pattern-toolbar-main .action-with-info {
  width:100%;
  display:grid;
  grid-template-columns:minmax(0, 1fr) 34px;
  align-items:stretch;
  gap:8px;
  min-width:0;
}
.pattern-toolbar-main .action-with-info > .ghost,
.pattern-toolbar-main .action-with-info > button:not(.info-icon) { width:100%; min-width:0; }
.pattern-toolbar-main .anchor-id-jump {
  display:grid;
  grid-template-columns:minmax(0, 1fr) auto;
  align-items:center;
  gap:0.45rem;
  padding:0.35rem 0.4rem;
  border:1px solid rgba(109,211,255,0.18);
  border-radius:18px;
  background: rgba(4,7,15,0.55);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.03);
  min-width:0;
}
.pattern-toolbar-main .anchor-id-jump input {
  width:100%;
  min-width:0;
  height:100%;
  padding:0.65rem 0.8rem;
  border-radius:14px;
  border:1px solid #27314f;
  background: #04070f;
  color: var(--text);
}
.pattern-toolbar-main .anchor-id-jump button {
  min-width:64px;
  padding:0.65rem 0.85rem;
  border-radius:14px;
}
.pattern-grid button:not(.ghost):not(.info-icon) { background: linear-gradient(120deg,#6a5af9,#ff4ecd); border: none; color: white; padding: 0.5rem 1.1rem; border-radius: 999px; cursor: pointer; font-weight: 700; box-shadow: 0 12px 32px rgba(0,0,0,0.38); }
.pattern-grid button:not(.ghost):not(.info-icon):disabled { opacity: 0.4; cursor: not-allowed; }
.pattern-toolbar-main #download-mix.ghost {
  background: linear-gradient(120deg, rgba(64,223,140,0.88), rgba(31,159,255,0.82));
  border: none;
  color: #04140c;
  font-weight: 800;
  box-shadow: 0 12px 28px rgba(0,0,0,0.25);
}
.pattern-toolbar-main #download-mix.ghost:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}
.pattern-toolbar-main #send-to-editor.ghost {
  background: linear-gradient(120deg, rgba(56,189,248,0.9), rgba(96,165,250,0.84));
  border: none;
  color: #03121a;
  font-weight: 800;
  box-shadow: 0 12px 28px rgba(0,0,0,0.25);
}
.pattern-toolbar-main #send-to-editor.ghost:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}
.pattern-toolbar-main #regenerate-arrangement.ghost,
.pattern-toolbar-main #download-mix.ghost,
.pattern-toolbar-main #send-to-editor.ghost,
.pattern-mode-toggle {
  height: 100%;
  min-height: 46px;
  padding: 0.65rem 0.8rem;
  width: 100%;
  justify-content: center;
  white-space: normal;
  line-height: 1.15;
  text-align: center;
  word-break: keep-all;
}
.pattern-mode-group {
  grid-column: 2 / 4;
  grid-row: 1;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
  min-width: 0;
  justify-content: center;
}
.pattern-send-button { grid-column: 3; grid-row: 2; }
.pattern-download-slot { grid-column: 2; grid-row: 2; }
.pattern-regen-slot { grid-column: 3; grid-row: 3; }
.pattern-anchor-slot { grid-column: 1 / 3; grid-row: 3; }
.pattern-download-slot {
  position: relative;
}
.pattern-grid .pattern-mode-toggle {
  border: 1px solid rgba(109,211,255,0.18) !important;
  background: linear-gradient(180deg, rgba(11,16,30,0.92), rgba(7,11,22,0.92)) !important;
  color: #aebcdd !important;
  font-weight: 800;
  font-size: 0.76rem;
  letter-spacing: 0.01em;
  white-space: normal;
  word-break: normal;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.03);
  opacity: 0.82;
  transition: background 140ms ease, border-color 140ms ease, box-shadow 140ms ease, color 140ms ease, opacity 140ms ease, transform 140ms ease;
}
.pattern-grid .pattern-mode-toggle.is-selected,
.pattern-grid .pattern-mode-toggle[aria-pressed="true"] {
  background: linear-gradient(135deg, rgba(46,209,122,0.72), rgba(56,189,248,0.56)) !important;
  border-color: rgba(155,247,198,0.92) !important;
  color: #f7fffb !important;
  text-shadow: 0 1px 0 rgba(0,0,0,0.2);
  opacity: 1;
  transform: translateY(-1px);
  box-shadow:
    0 0 0 1px rgba(155,247,198,0.18),
    0 16px 34px rgba(0,0,0,0.28),
    inset 0 1px 0 rgba(255,255,255,0.12);
}
.pattern-grid .pattern-mode-toggle:focus-visible,
.pattern-grid .pattern-mode-toggle:hover {
  border-color: rgba(109,211,255,0.34);
  color: #deebff;
  opacity: 1;
}

#export-progress {
  width: 100%;
  height: 10px;
  border-radius: 999px;
  overflow: hidden;
}
#export-progress::-webkit-progress-bar {
  background: rgba(255,255,255,0.06);
}
#export-progress::-webkit-progress-value {
  background: linear-gradient(120deg, rgba(64,223,140,0.95), rgba(124,91,255,0.9));
}
.pattern-timeline { position: relative; border: 1px dashed #313f66; border-radius: 10px; padding: 0.5rem; min-height: 120px; display: grid; gap: 0.4rem; }
.pattern-timeline[hidden],
#pattern-grid-status[hidden] { display: none !important; }
.pattern-row { border: 1px solid rgba(92,124,250,0.3); border-radius: 8px; padding: 0.35rem; min-height: 50px; position: relative; background: rgba(8,12,22,0.7); }
.pattern-row.highlighted { border-color: rgba(255,183,77,0.9); box-shadow: 0 0 12px rgba(255,183,77,0.3); }
.pattern-row-title { font-size: 0.8rem; color: #c0cdff; margin-bottom: 0.25rem; }
.pattern-row-grid { display: grid; gap: 0.2rem; height: 36px; align-items: stretch; }
.pattern-row.pattern-row-muted {
  border-color: rgba(180, 190, 220, 0.22);
  background: rgba(12, 16, 26, 0.58);
}
.pattern-row.pattern-row-muted .pattern-row-title {
  color: rgba(192, 205, 255, 0.62);
}
.pattern-cell {
  --pattern-fill-ratio: 0;
  border: 1px dashed rgba(255,255,255,0.1);
  border-radius: 4px;
  background: rgba(5,7,13,0.55);
  cursor: pointer;
  position: relative;
  overflow: hidden;
}
.pattern-cell::before {
  content: "";
  position: absolute;
  inset: 0;
  width: calc(var(--pattern-fill-ratio, 0) * 100%);
  background: linear-gradient(180deg, rgba(132,164,255,0.9), rgba(92,124,250,0.48));
  opacity: 0.95;
  pointer-events: none;
}
.pattern-cell.active { border-color: rgba(92,124,250,0.95); }
.pattern-cell.partial { border-color: rgba(92,124,250,0.7); }
.pattern-row.pattern-bypassed .pattern-row-title { color: rgba(192,205,255,0.78); }
.pattern-cell.bypassed { cursor: not-allowed; opacity: 0.82; }
.pattern-cell.bypassed::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 4px;
  background: linear-gradient(135deg, rgba(255,255,255,0.02), rgba(0,0,0,0.08));
  pointer-events: none;
}
.pattern-cell.bar-start { margin-left: 0.28rem; }
.pattern-cell.bar-start:first-child { margin-left: 0; }
.pattern-cell.bar-end { box-shadow: inset -1px 0 0 rgba(255,255,255,0.06); }
.pattern-cell.current {
  box-shadow: 0 0 10px rgba(255,255,255,0.35), inset 0 0 0 1px rgba(255,255,255,0.28);
}
.pattern-row.pattern-row-muted .pattern-cell {
  border-color: rgba(255,255,255,0.08);
  background: rgba(6, 8, 14, 0.42);
}
.pattern-row.pattern-row-muted .pattern-cell::before {
  background: linear-gradient(180deg, rgba(148, 156, 182, 0.56), rgba(105, 112, 140, 0.34));
  opacity: 0.82;
}
.pattern-row.pattern-row-muted .pattern-cell.current {
  box-shadow: 0 0 8px rgba(220,220,220,0.18), inset 0 0 0 1px rgba(255,255,255,0.16);
}

.timing-compact { margin: 0; padding: 0.45rem 0.9rem; min-width: 260px; max-width: 340px; }
.timing-compact .timing-grid { margin-top: 0.5rem; }
.timing-compact .timing-header { gap: 0.6rem; }
.timing-header.centered { justify-content:center; text-align:center; }

.reference-inline { background: linear-gradient(140deg, rgba(12,18,30,0.92), rgba(8,12,22,0.92)); border:1px solid rgba(109,211,255,0.2); border-radius:12px; padding:8px 10px; display:flex; flex-direction:column; gap:4px; width:100%; box-shadow: 0 14px 28px rgba(0,0,0,0.38), inset 0 1px 0 rgba(255,255,255,0.03); align-self:flex-start; }
.reference-inline .panel-heading { padding-top:0; align-items:center; }
.reference-inline .panel-heading.reference-heading {
  display:grid;
  grid-template-columns:minmax(0, 1fr) auto auto;
  align-items:center;
  gap:10px;
}
.reference-inline .panel-heading.reference-heading > * { min-width:0; }
.reference-heading-copy { min-width:0; }
.reference-heading-copy .subtext { white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.reference-heading-meta { display:flex; align-items:center; gap:14px; color: var(--text); font-weight:700; white-space:nowrap; }
.reference-heading-meta .value { color: var(--accent-2); }
.reference-inline .panel-heading.reference-heading .pill-switch { justify-self:end; align-self:center; }
@container (max-width: 700px) {
  .pattern-toolbar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-rows: auto auto auto auto;
  }
  .pattern-hero-actions #workbench-play {
    grid-column: 1;
    grid-row: 1;
  }
  .pattern-hero-actions #random-arrange {
    grid-column: 2;
    grid-row: 1;
  }
  .pattern-mode-group {
    grid-column: 1 / -1;
    grid-row: 2;
  }
  .pattern-download-slot {
    grid-column: 1;
    grid-row: 3;
  }
  .pattern-send-button {
    grid-column: 2;
    grid-row: 3;
  }
  .pattern-anchor-slot {
    grid-column: 1;
    grid-row: 4;
  }
  .pattern-regen-slot {
    grid-column: 2;
    grid-row: 4;
  }
}
@container (max-width: 520px) {
  .pattern-toolbar {
    grid-template-columns: 1fr;
    grid-template-rows: none;
  }
  .pattern-hero-actions #workbench-play,
  .pattern-hero-actions #random-arrange,
  .pattern-mode-group,
  .pattern-download-slot,
  .pattern-send-button,
  .pattern-anchor-slot,
  .pattern-regen-slot {
    grid-column: 1;
    grid-row: auto;
  }
  .pattern-mode-group {
    grid-template-columns: 1fr;
  }
  .pattern-toolbar-main .anchor-id-jump {
    grid-template-columns: 1fr;
  }
  .pattern-toolbar-main .anchor-id-jump button {
    width: 100%;
  }
}
@media (max-width: 1180px) {
  .reference-inline .panel-heading.reference-heading {
    grid-template-columns: 1fr;
  }
}
.reference-inline .pill-switch { align-self:flex-start; }
.reference-inline .pill-switch .pill { min-width: 0; }
.reference-inline .reference-pane { margin:0; }
.reference-inline .reference-pane .stack { gap:6px; }
.reference-inline .waveform-box { height:32px; }
.reference-inline .dropzone { margin-top:6px; }
.reference-inline .progress-strip { margin:6px 0; }
.reference-inline .analysis { display:flex; gap:10px; flex-wrap:wrap; }
.reference-inline .panel-heading { margin-bottom:4px; }
.reference-inline #reference-status { margin: 0; min-height: 0; }
.reference-inline #reference-status:empty { display: none; }
.reference-inline #reference-analysis:empty { display: none; }
.hum-inline { display:flex; align-items:center; gap:8px; }
.hum-inline .waveform-wrap { flex:1; margin-top:0; gap:4px; }
.hum-inline .waveform-wrap .waveform-box { width:100%; }
.reference-inline .instruments-embed { margin:0; padding:0; background: transparent; border:none; box-shadow:none; }
.reference-inline .instruments-embed .panel-heading { padding-top:0; flex-wrap:wrap; justify-content:flex-start; }
.reference-inline .instruments-embed .instrument-tabs { justify-content:flex-start; overflow-x:auto; padding-bottom:4px; }
.reference-inline .instruments-embed .instrument-content { margin-top: 8px; }
.reference-inline .instruments-embed .instrument-row { flex-wrap: wrap; }
.reference-inline .instruments-embed .instrument-actions { justify-content:flex-start; flex-wrap:wrap; }
.reference-inline .instruments-embed .meter-bar { width: 100px; }
.reference-inline .instruments-embed .piano-shell { margin-top: 8px; padding: 10px; border-radius: 14px; overflow-x: auto; }
.reference-inline .instruments-embed .piano-row { padding: 4px 6px; border-radius: 10px; }
.reference-inline .instruments-embed .piano-key { width: 42px; height: 90px; font-size: 13px; }
.reference-inline .instruments-embed .pads-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.reference-inline .instruments-embed .voice-gallery { grid-template-columns: 1fr; }
.reference-inline .instruments-embed .voice-card { padding: 8px; border-radius: 12px; }
.reference-inline .instruments-embed .voice-hero { width: 52px; height: 52px; border-radius: 10px; }
.reference-inline .instruments-embed .sequencer-header { flex-direction: column; align-items: flex-start; }
.reference-inline .instruments-embed .sequencer-grid { overflow-x: auto; }
.reference-inline .instruments-embed .seq-steps { min-width: 480px; }

#workbench-actions { flex-direction:row; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px; padding:0; min-height:0; }
.footer-toolbar { display:flex; gap:10px; align-items:center; }
.footer-toolbar .inline-field { color: var(--muted); }
.pattern-empty { margin: 0; color: #b7c3ff; font-size: 0.9rem; text-align: center; padding: 1rem 0; }

.timing-inline { margin-top:6px; display:grid; grid-template-columns:minmax(0, auto) minmax(0, 1fr); align-items:center; gap:10px 14px; background: rgba(8,12,22,0.9); border:1px solid #1f293f; border-radius:10px; padding:8px 10px; min-width:0; }
.timing-inline .timing-info { min-width:0; }
.timing-inline .timing-grid { margin-top:0; }
@media (max-width: 980px) {
  .timing-inline {
    grid-template-columns: 1fr;
    align-items: stretch;
  }
  .timing-inline .timing-info {
    text-align: center;
  }
}
@media (max-width: 640px) {
  .timing-inline {
    gap:8px;
    padding:8px;
  }
  .timing-grid {
    gap:0.25rem;
    padding:0.35rem;
  }
  .timing-bar {
    padding:0.24rem;
    gap:0.16rem;
  }
  .timing-beat {
    font-size:clamp(0.54rem, 2.2vw, 0.72rem);
    padding:0.16rem 0;
  }
}
.pattern-visual { display:none; }

.cta-row { display:flex; gap:10px; justify-content:flex-end; margin-top:12px; }
.cta { border:none; cursor:pointer; padding:12px 16px; border-radius:12px; font-weight:700; color:#060b15; box-shadow: var(--shadow); }
.cta.primary { background: linear-gradient(120deg, var(--accent-2), var(--accent)); }
.header-cta { box-shadow: 0 12px 28px rgba(124,91,255,0.35); }
.cta.secondary { background: linear-gradient(120deg, #1f9fff, #7b5bff); color:#060b15; }
.cta.success { background: linear-gradient(120deg, #40df8c, #7bffb2); color:#04140c; }
.ghost { background: rgba(255,255,255,0.04); border:1px solid var(--border); color: var(--text); border-radius:10px; padding:10px 12px; cursor:pointer; }
.mini { padding:8px 10px; font-size:13px; }
.ghost:active { transform: translateY(1px) scale(0.995); box-shadow: inset 0 1px 2px rgba(0,0,0,0.35); }
.recording-active { background: linear-gradient(120deg, #ff6b6b, #ff3b3b); color: #1a0202; border-color: #ff8f8f; box-shadow: 0 8px 18px rgba(255,59,59,0.3); }
.track-controls,
.tuning-controls {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(128px, 1fr));
  gap: 8px;
  min-width: 0;
}
.track-controls > *,
.tuning-controls > * {
  min-width: 0;
}
.track-controls .track-play {
  width: 100%;
  min-width: 0;
}
.track-controls label,
.tuning-controls label {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 6px;
  width: 100%;
  min-width: 0;
}
.track-controls input[type="range"] {
  width: 100%;
  min-width: 0;
}
.tuning-controls input[type="number"] {
  width: 100%;
  min-width: 0;
  padding: 0.35rem 0.45rem;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(4,7,15,0.72);
  color: var(--text);
}
@media (max-width: 720px) {
  .track-controls,
  .tuning-controls {
    grid-template-columns: 1fr;
  }
  .channel-header {
    flex-direction: column;
    align-items: stretch;
  }
  .channel-tags {
    flex-basis: auto;
  }
}

@media (max-width: 820px) {
  .workbench-header .pattern-panel,
  .workbench-header .reference-inline {
    flex-basis: 100%;
    min-width: 0;
  }
}

@media (max-width: 640px) {
  .gemini-panel,
  .workbench-shell {
    margin: 12px;
  }
  .gemini-sidebar,
  .workbench-shell-body {
    padding: 12px;
  }
  .pattern-grid {
    padding: 0.85rem;
  }
  .pattern-hero-actions > .ghost,
  .pattern-toolbar-main #regenerate-arrangement.ghost,
  .pattern-toolbar-main #download-mix.ghost,
  .pattern-toolbar-main #send-to-editor.ghost,
  .pattern-mode-toggle {
    min-height: 42px;
    font-size: 0.88rem;
  }
  .pattern-toolbar-main .action-with-info {
    grid-template-columns: minmax(0, 1fr) 30px;
    gap: 6px;
  }
  .reference-inline .panel-heading.reference-heading {
    gap: 8px;
  }
  .reference-heading-copy .subtext {
    white-space: normal;
    overflow: visible;
    text-overflow: initial;
  }
  .reference-heading-meta {
    flex-wrap: wrap;
    gap: 8px 12px;
    white-space: normal;
  }
  .reference-inline .panel-heading.reference-heading .pill-switch {
    width: 100%;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 4px;
  }
  .reference-inline .panel-heading.reference-heading .pill-switch .pill {
    width: 100%;
    padding: 8px 10px;
  }
  .track-control-strip {
    flex-wrap: wrap;
    gap: 8px;
  }
  .track {
    min-width: min(240px, calc(100vw - 56px));
  }
}

@media (max-width: 480px) {
  .reference-inline .panel-heading.reference-heading .pill-switch {
    grid-template-columns: 1fr;
    border-radius: 16px;
  }
  .pattern-hero-actions > .ghost,
  .pattern-toolbar-main #regenerate-arrangement.ghost,
  .pattern-toolbar-main #download-mix.ghost,
  .pattern-toolbar-main #send-to-editor.ghost,
  .pattern-mode-toggle {
    font-size: 0.84rem;
  }
}

#gemini-play, #gemini-stop, #gemini-copy, #gemini-paste,
#workbench-play, #workbench-stop,
.lock-track, .prev-track, .next-track, .like-track, .dislike-track {
  position: relative;
  padding-inline: 10px 12px;
}
#gemini-play::before, #workbench-play::before { content:'▶'; margin-right:6px; }
#workbench-play.is-stop::before { content:'■'; }
#gemini-stop::before, #workbench-stop::before { content:'■'; margin-right:6px; }
#gemini-copy::before { content:'⧉'; margin-right:6px; }
#gemini-paste::before { content:'⧠'; margin-right:6px; }
.lock-track::before { content:'🔒'; margin-right:4px; }
.prev-track::before { content:'‹'; margin-right:4px; }
.next-track::before { content:'›'; margin-right:4px; }
.like-track::before { content:'👍'; margin-right:4px; }
.dislike-track::before { content:'👎'; margin-right:4px; }

.suggested-list { display:grid; gap:12px; }
.suggested-card { border:1px solid var(--border); border-radius:12px; padding:12px; background: var(--panel-strong); }
.suggested-card { animation: floatIn 240ms ease both; }
.suggested-card:nth-child(1) { animation-delay: 30ms; }
.suggested-card:nth-child(2) { animation-delay: 60ms; }
.suggested-card:nth-child(3) { animation-delay: 90ms; }
.suggested-card:nth-child(4) { animation-delay: 120ms; }
.suggested-card:nth-child(5) { animation-delay: 150ms; }
.card-head { display:flex; justify-content:space-between; align-items:center; }
.card-meta { color:var(--muted); margin:6px 0 0; font-size:13px; }
.tag { background: rgba(109,211,255,0.16); border:1px solid var(--accent-2); color: var(--accent-2); padding:4px 8px; border-radius:999px; font-size:12px; }
.wave-placeholder { height:32px; background: linear-gradient(90deg, rgba(255,255,255,0.08) 0%, rgba(255,255,255,0.02) 100%); border-radius:8px; margin-top:10px; }
.match-why { display:flex; flex-wrap:wrap; gap:6px; margin-top:8px; font-size:12px; color: var(--muted); }
.match-why .chip { padding:4px 8px; border-radius:999px; border:1px solid var(--border); background: rgba(255,255,255,0.04); }
.empty-state { color:var(--muted); text-align:center; padding:12px; border:1px dashed var(--border); border-radius:10px; }

.status-line { margin:10px 0; color:var(--muted); font-size:13px; min-height:18px; }
.status-line:empty { display:none; }
.status-line.ok { color:#80f2b0; }
.status-line.warn { color:var(--accent-2); }
.status-line.err { color:#ff7b9c; }
.gemini-status { color: var(--muted); font-size:12px; }

.gemini-panel,
.workbench-shell { margin: 18px 18px 18px; display:grid; grid-template-columns: 1fr; grid-template-rows: auto auto; gap:12px; border:1px solid var(--border); border-radius: var(--radius); background: linear-gradient(145deg, rgba(10,15,28,0.96), rgba(8,13,22,0.96)); box-shadow: 0 18px 40px rgba(0,0,0,0.5), inset 0 1px 0 rgba(255,255,255,0.05); position: relative; overflow: hidden; min-width:0; width:100%; }
.gemini-panel::before,
.workbench-shell::before { content:''; position:absolute; inset:0; border-radius: var(--radius); pointer-events:none; box-shadow: inset 0 0 0 1px rgba(109,211,255,0.18); }
.gemini-panel::after,
.workbench-shell::after { content:''; position:absolute; left:0; right:0; top:0; height:4px; background: linear-gradient(90deg, rgba(109,211,255,0.45), rgba(124,91,255,0.35), rgba(46,209,122,0.35)); opacity:0.9; }
.gemini-sidebar,
.workbench-shell-body { grid-row:2; grid-column:1; padding:14px 16px; border-top:1px solid var(--border); background: var(--panel-strong); display:flex; flex-direction:column; gap:14px; border-right:none; min-width:0; width:100%; }
.sidebar-section { display:flex; flex-direction:column; gap:8px; }
.loop-thumb { display:none; }
.workbench-mini { gap:12px; }
.mini-header { display:flex; justify-content:space-between; align-items:center; gap:8px; }
.mini-chips { display:flex; gap:6px; flex-wrap:wrap; }
.mini-tracks { display:grid; gap:10px; }
.mini-track-card { border:1px solid var(--border); border-radius:10px; padding:10px; background: rgba(255,255,255,0.03); box-shadow: inset 0 1px 0 rgba(255,255,255,0.02); display:grid; gap:4px; position: relative; }
.mini-track-card .title { font-weight:700; font-size:14px; }
.mini-track-card .meta { font-size:12px; color: var(--muted); display:flex; gap:6px; flex-wrap:wrap; }
.mini-track-card .fit { font-size:11px; color: var(--muted); }
.mini-track-card .play-dot { width:8px; height:8px; border-radius:50%; background: rgba(124,91,255,0.6); box-shadow: 0 0 8px rgba(124,91,255,0.8); position:absolute; top:10px; right:10px; opacity:0.8; }
.mini-track-card[data-role="bass"] .play-dot { background: rgba(46,209,122,0.8); box-shadow: 0 0 8px rgba(46,209,122,0.9); }
.mini-track-card[data-role="harmony"] .play-dot { background: rgba(109,211,255,0.8); box-shadow: 0 0 8px rgba(109,211,255,0.9); }
.mini-track-card[data-role="melody"] .play-dot { background: rgba(255,159,67,0.8); box-shadow: 0 0 8px rgba(255,159,67,0.9); }
.inline-actions { flex-direction:row; flex-wrap:wrap; gap:8px; }
.gemini-iframe-wrap { grid-row:1; grid-column:1; display:flex; flex-direction:column; border-radius:12px; overflow:visible; position: relative; background: rgba(8,13,22,0.9); min-width:0; width:100%; max-width:100%; align-self:start; }
.iframe-toolbar { display:none; }
iframe { flex:0 0 auto; min-height:120px; height:120px; border:none; background: #0b1529; box-shadow: inset 0 10px 30px rgba(0,0,0,0.4); width:100%; max-width:100%; min-width:0; display:block; }

/* Global loading indicator (top-right) */
.global-loading {
  position: fixed;
  top: 14px;
  right: 14px;
  z-index: 1000;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(8,12,22,0.92);
  box-shadow: 0 16px 32px rgba(0,0,0,0.45), inset 0 1px 0 rgba(255,255,255,0.06);
  color: rgba(255,255,255,0.92);
  font-size: 13px;
  backdrop-filter: blur(12px);
}
.global-loading.hidden { display: none; }
.global-loading .spinner {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,0.22);
  border-top-color: rgba(109,211,255,0.9);
  animation: spin 0.9s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* Small info icon */
.action-with-info { display: inline-flex; align-items: center; gap: 6px; }
.info-icon {
  width: 28px;
  height: 28px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.16);
  background: rgba(255,255,255,0.04);
  color: transparent;
  font-size: 0;
  line-height: 0;
  cursor: help;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.05);
  transition: transform 120ms ease, border-color 120ms ease, background 120ms ease;
}
.info-icon::before {
  content: '';
  width: 16px;
  height: 16px;
  background-image: url('../20070430232847!Information_icon.svg');
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  opacity: 0.95;
  filter: drop-shadow(0 1px 2px rgba(0,0,0,0.5));
}
.info-icon:hover,
.info-icon:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(109,211,255,0.35);
  background: rgba(109,211,255,0.08);
}
.info-icon[data-tooltip]::after {
  content: attr(data-tooltip);
  position: absolute;
  top: 50%;
  left: calc(100% + 10px);
  transform: translateY(-50%) translateX(6px);
  opacity: 0;
  pointer-events: none;
  min-width: 220px;
  max-width: 320px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(8,12,22,0.96);
  color: rgba(255,255,255,0.92);
  font-size: 12px;
  line-height: 1.35;
  box-shadow: 0 18px 36px rgba(0,0,0,0.55), inset 0 1px 0 rgba(255,255,255,0.06);
  backdrop-filter: blur(10px);
  transition: opacity 120ms ease, transform 120ms ease;
  z-index: 1001;
}
.info-icon[data-tooltip-side="left"]::after {
  left: auto;
  right: calc(100% + 10px);
  transform: translateY(-50%) translateX(-6px);
}
.info-icon:hover[data-tooltip]::after,
.info-icon:focus-visible[data-tooltip]::after {
  opacity: 1;
  transform: translateY(-50%) translateX(0);
}
.info-icon:hover[data-tooltip-side="left"]::after,
.info-icon:focus-visible[data-tooltip-side="left"]::after {
  transform: translateY(-50%) translateX(0);
}

/* Track control strip */
.track-lock-icon,
.track-lock-info {
  position: static;
  display: none;
  align-items: center;
  justify-content: center;
}
.track-lock-info {
  width: 22px;
  height: 22px;
  min-width: 22px;
  min-height: 22px;
  font-size: 11px;
  padding: 0;
}
.track.filled-track .track-lock-icon,
.track.filled-track .track-lock-info { display: inline-flex; }

/* Regenerate call-to-action */
.regen-button {
  border-color: rgba(109,211,255,0.26);
  background: linear-gradient(120deg, rgba(109,211,255,0.12), rgba(124,91,255,0.12));
  box-shadow: 0 12px 28px rgba(0,0,0,0.35), inset 0 1px 0 rgba(255,255,255,0.05);
  font-weight: 800;
}
.regen-button.attention-pulse {
  animation: regenPulse 1.6s ease-in-out infinite;
}
@keyframes regenPulse {
  0%, 100% { transform: translateY(0); box-shadow: 0 12px 28px rgba(0,0,0,0.35), inset 0 1px 0 rgba(255,255,255,0.05); }
  50% { transform: translateY(-1px); box-shadow: 0 18px 34px rgba(0,0,0,0.42), 0 0 0 1px rgba(109,211,255,0.18); }
}

.mix-waveform-panel {
  border-top: 1px solid rgba(255,255,255,0.06);
  padding: 12px 14px 14px;
  background: linear-gradient(180deg, rgba(8,13,22,0.92), rgba(9,15,26,0.98));
  display: flex;
  flex-direction: column;
  gap: 8px;
  position: relative;
}
.mix-waveform-panel::before {
  content:'';
  position:absolute;
  inset: 0;
  background:
    radial-gradient(circle at 16% 20%, rgba(109,211,255,0.08), transparent 45%),
    radial-gradient(circle at 86% 0%, rgba(124,91,255,0.12), transparent 50%);
  opacity: 0.7;
  pointer-events: none;
}
.mix-waveform-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 11px;
  color: var(--muted);
  position: relative;
  z-index: 1;
}
.mix-waveform-meta {
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid rgba(109,211,255,0.28);
  color: #bfeaff;
  background: rgba(109,211,255,0.1);
  font-size: 11px;
  letter-spacing: 0.02em;
  text-transform: none;
}
.mix-waveform-meta.live {
  border-color: rgba(46,209,122,0.45);
  color: #bff3d6;
  background: rgba(46,209,122,0.12);
}
.mix-waveform-canvas {
  position: relative;
  border-radius: 12px;
  border: 1px solid rgba(109,211,255,0.2);
  padding: 8px;
  background: radial-gradient(circle at 40% 40%, rgba(109,211,255,0.1), rgba(9,14,25,0.92));
  overflow: hidden;
  z-index: 1;
}
.mix-waveform-canvas::before {
  content:'';
  position: absolute;
  inset: 0;
  background:
    repeating-linear-gradient(90deg, rgba(255,255,255,0.05) 0, rgba(255,255,255,0.05) 1px, transparent 1px, transparent 16px),
    repeating-linear-gradient(0deg, rgba(255,255,255,0.03) 0, rgba(255,255,255,0.03) 1px, transparent 1px, transparent 12px);
  opacity: 0.25;
  pointer-events: none;
}
.mix-waveform-canvas canvas {
  width: 100%;
  height: 90px;
  display: block;
  position: relative;
  z-index: 1;
}
.mix-waveform-panel.is-live .mix-waveform-canvas {
  border-color: rgba(109,211,255,0.4);
  box-shadow: 0 0 18px rgba(109,211,255,0.12), inset 0 0 14px rgba(124,91,255,0.18);
}

#toast-container {
  position: fixed;
  top: 12px;
  right: 12px;
  z-index: 1000;
  display: flex;
  flex-direction: column;
  gap: 8px;
  pointer-events: none;
}
.toast {
  min-width: 240px;
  max-width: 320px;
  padding: 10px 12px;
  border-radius: 10px;
  background: rgba(20, 23, 32, 0.92);
  color: var(--text);
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.35);
  font-size: 13px;
  pointer-events: auto;
}
.toast.info { border-color: #5eb0ff; }
.toast.success { border-color: #6ad28f; }
.toast.error { border-color: #ff7a7a; }
.toast .toast-title { font-weight: 600; display: block; margin-bottom: 4px; }
.instruments-panel {
  margin: 20px 18px;
  background: linear-gradient(135deg, #3b261a, #2a1a11 45%, #1b120c);
  border: 1px solid rgba(255, 255, 255, 0.06);
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.45);
  border-radius: 16px;
  padding: 16px;
}
.instrument-tabs { display: flex; gap: 8px; margin-top: 8px; justify-content: center; }
.instrument-tabs .tab { padding: 8px 12px; border: 1px solid #3a4b6a; background: #152038; color: var(--text); cursor: pointer; border-radius: 999px; }
.instrument-tabs .tab.active { background: var(--accent-3); color: #081511; border-color: var(--accent-3); }
.instrument-content { margin-top: 12px; }
.instrument-pane { display: none; }
.instrument-pane.active { display: block; }
.instrument-pane.slide-out-left { animation: slideOutLeft 280ms ease forwards; }
.instrument-pane.slide-in-right { animation: slideInRight 320ms ease forwards; }
.piano-shell { margin-top: 12px; padding: 14px; border-radius: 18px; background: radial-gradient(circle at 20% 20%, rgba(255,255,255,0.06), transparent 45%), linear-gradient(135deg, #3b261a, #2a1a11 55%, #1b120c); box-shadow: inset 0 2px 0 rgba(255,255,255,0.05), inset 0 -4px 10px rgba(0,0,0,0.5), 0 14px 28px rgba(0,0,0,0.4); border:1px solid rgba(255,255,255,0.08); }
.piano-rows { display:flex; flex-direction:column; gap:8px; user-select:none; }
.piano-row { display:flex; gap:4px; justify-content:center; padding:6px 8px; border-radius:12px; background: linear-gradient(180deg, rgba(0,0,0,0.4), rgba(0,0,0,0.7)); box-shadow: inset 0 1px 0 rgba(255,255,255,0.04); }
.piano-key { position: relative; width: 42px; height: 90px; border: 1px solid #3a4b6a; border-radius: 8px; background: #f7f9ff; color: #111; cursor: pointer; font-weight: 700; font-size: 13px; display:flex; align-items:center; justify-content:center; padding:0; transition: transform 80ms ease, box-shadow 80ms ease; }
.piano-key.black { background: #f7f9ff; color: #111; height: 90px; box-shadow: inset 0 -2px 0 rgba(0,0,0,0.05); }
.piano-key.active,
.piano-key.held,
.piano-key.flash { box-shadow: inset 0 0 0 2px var(--accent-3), 0 0 10px rgba(46,209,122,0.4); transform: translateY(1px); }
.pads-grid { display: grid; grid-template-columns: repeat(4, minmax(100px, 1fr)); gap: 8px; margin-top: 8px; }
.pad-btn { padding: 16px; border: 1px solid #3a4b6a; border-radius: 10px; background: #152038; color: var(--text); cursor: pointer; text-align: left; box-shadow: 0 4px 16px rgba(0,0,0,0.25); }
.pad-btn.active,
.pad-btn.held { border-color: var(--accent-3); box-shadow: 0 0 0 2px rgba(46,209,122,0.2); }
.sequencer-header { display: flex; justify-content: space-between; align-items: center; gap: 12px; margin-bottom: 8px; }
.seq-row { display: flex; align-items: center; gap: 8px; margin-bottom: 4px; }
.seq-row-label { width: 70px; font-size: 12px; color: var(--muted); }
.seq-row-controls { display:flex; align-items:center; gap:6px; margin-right:6px; }
.seq-row-controls .seq-mute,
.seq-row-controls .seq-solo { padding:6px 8px; border-radius:8px; border:1px solid var(--border); background: rgba(255,255,255,0.04); color: var(--text); cursor:pointer; }
.seq-row-controls .seq-vel { width: 90px; }
.seq-steps { display: grid; grid-template-columns: repeat(16, 1fr); gap: 4px; flex: 1; }
.seq-step { height: 22px; border: 1px solid #3a4b6a; border-radius: 3px; background: #0f182b; cursor: pointer; }
.seq-step.active { background: var(--accent-3); border-color: var(--accent-3); }
.seq-step.playing { outline: 2px solid #ffa500; }
.instrument-row { display: flex; align-items: center; gap: 12px; margin-top: 8px; }
.instrument-actions { display: flex; align-items: center; gap: 8px; justify-content: center; width: 100%; }
.cta-record {
  padding: 12px 24px;
  background: radial-gradient(circle at 30% 30%, #2b2b30, #17171b 55%, #0f0f12);
  color: #fff;
  border: 1px solid #444;
  border-radius: 999px;
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.35) inset, 0 8px 18px rgba(0, 0, 0, 0.45);
  cursor: pointer;
  font-weight: 700;
  letter-spacing: 0.5px;
  transition: transform 120ms ease, box-shadow 120ms ease;
}
.cta-record.recording {
  background: radial-gradient(circle at 30% 30%, #ff8585, #d31919 55%, #8b0b0b);
  border: 1px solid #ffb3b3;
  box-shadow: 0 0 20px rgba(211, 25, 25, 0.4), 0 0 8px rgba(255, 133, 133, 0.35) inset, 0 10px 24px rgba(0,0,0,0.35);
}
.cta-record:hover {
  box-shadow: 0 0 30px rgba(255, 80, 80, 0.6), 0 0 10px rgba(255, 160, 160, 0.4) inset;
  transform: translateY(-1px);
}
.cta-record:active {
  transform: translateY(1px);
  box-shadow: 0 0 16px rgba(211, 25, 25, 0.5) inset;
}
.fx-panel { margin-top: 12px; background: rgba(0,0,0,0.18); border: 1px solid rgba(255,255,255,0.05); border-radius: 10px; padding: 10px; }
.fx-row { display:flex; flex-wrap:wrap; gap:10px; align-items:center; }
.meter-bar { width: 120px; height: 8px; background: #0f182b; border:1px solid #3a4b6a; border-radius: 6px; overflow:hidden; position: relative; }
.meter-fill { position:absolute; inset:0; background: linear-gradient(90deg, #2ed17a, #ff9f43, #ff6b6b); width:0%; transition: width 80ms ease; }

/* Piano voice gallery */
.voice-gallery { display:grid; grid-template-columns: repeat(auto-fit, minmax(200px,1fr)); gap:12px; margin-top:10px; }
.voice-card { position:relative; border:1px solid rgba(255,255,255,0.08); border-radius:14px; padding:10px; background: linear-gradient(140deg, rgba(12,18,30,0.75), rgba(8,12,22,0.9)); color: var(--text); cursor:pointer; box-shadow: 0 12px 24px rgba(0,0,0,0.3), inset 0 1px 0 rgba(255,255,255,0.04); display:flex; align-items:center; gap:10px; transition: transform 120ms ease, box-shadow 140ms ease, border-color 140ms ease; }
.voice-card:hover { transform: translateY(-2px); box-shadow: 0 16px 28px rgba(0,0,0,0.35); }
.voice-card.active { border-color: rgba(109,211,255,0.6); box-shadow: 0 16px 30px rgba(109,211,255,0.2), inset 0 1px 0 rgba(255,255,255,0.08); }
.voice-hero { width:70px; height:70px; border-radius:12px; background: linear-gradient(135deg, rgba(255,255,255,0.12), rgba(0,0,0,0.25)); box-shadow: inset 0 1px 0 rgba(255,255,255,0.06), 0 10px 18px rgba(0,0,0,0.35); }
.voice-hero.grand { background: radial-gradient(circle at 30% 30%, rgba(255,230,180,0.35), rgba(60,30,10,0.9)); }
.voice-hero.electric { background: linear-gradient(135deg, #4ac8ff, #7c5bff); box-shadow: inset 0 1px 0 rgba(255,255,255,0.08), 0 12px 24px rgba(0,0,0,0.35); }
.voice-hero.synth { background: linear-gradient(135deg, #ff5fa2, #6dd3ff); box-shadow: inset 0 1px 0 rgba(255,255,255,0.1), 0 12px 24px rgba(0,0,0,0.35); position: relative; }
.voice-hero.synth::after { content:'💋'; position:absolute; right:6px; bottom:6px; font-size:18px; opacity:0.9; }
.voice-meta { display:flex; flex-direction:column; gap:2px; }
.voice-meta strong { font-size:15px; }
.voice-meta span { font-size:12px; color: var(--muted); }

@keyframes slideOutLeft {
  0% { transform: translateX(0); opacity:1; }
  100% { transform: translateX(-40px); opacity:0; }
}
@keyframes slideInRight {
  0% { transform: translateX(40px); opacity:0; }
  100% { transform: translateX(0); opacity:1; }
}

.progress-strip {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
  margin: 8px 0 12px;
}
.progress-step {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 8px;
  border-radius: 10px;
  background: rgba(255,255,255,0.03);
  color: var(--muted);
  border: 1px solid transparent;
}
.progress-step .dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: rgba(255,255,255,0.16);
}
.progress-step.active {
  border-color: rgba(94, 176, 255, 0.8);
  color: var(--text);
}
.progress-step.active .dot {
  background: #5eb0ff;
  box-shadow: 0 0 0 4px rgba(94, 176, 255, 0.2);
}
.progress-step.completed {
  border-color: rgba(106, 210, 143, 0.7);
  color: var(--text);
}
.progress-step.completed .dot {
  background: #6ad28f;
  box-shadow: 0 0 0 4px rgba(106, 210, 143, 0.2);
}

.hidden { display:none; }

@media (max-width: 1200px) {
  .layout { grid-template-columns: 1fr; }
  .gemini-panel,
  .workbench-shell { grid-template-columns: 1fr; grid-template-rows: auto auto; }
  .gemini-sidebar,
  .workbench-shell-body { border-right:none; border-top:1px solid var(--border); }
}
.tracks .track:nth-child(1) { animation-delay: 40ms; }
.tracks .track:nth-child(2) { animation-delay: 80ms; }
.tracks .track:nth-child(3) { animation-delay: 120ms; }
.tracks .track:nth-child(4) { animation-delay: 160ms; }
.tracks .track:nth-child(5) { animation-delay: 200ms; }
.tracks .track:nth-child(6) { animation-delay: 240ms; }
.toolbar { background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(0,0,0,0.08)); border-radius:10px; padding:8px 10px; box-shadow: inset 0 1px 0 rgba(255,255,255,0.02); }
.fx-tags { display:flex; flex-wrap:wrap; gap:6px; font-size:11px; margin:6px 0; color: var(--muted); }
.fx-tags span { border:1px solid rgba(255,255,255,0.08); border-radius:999px; padding:3px 8px; background: rgba(255,255,255,0.03); }
.fit-badge { margin-top:4px; font-size:11px; line-height:1.2; color: var(--muted); }
.fit-badge.warning { color:#ff9f43; }

@keyframes floatIn {
  from { opacity:0; transform: translateY(10px); }
  to { opacity:1; transform: translateY(0); }
}
