/* ──────────────────────────────────────────────────────────
   1. DESIGN TOKENS  (CSS variables)
   ────────────────────────────────────────────────────────── */
:root {
  /* Core palette */
  --bg-deep:        #0a0905;
  --bg-panel:       #0f0e09;
  --bg-card:        #161410;
  --bg-hover:       #1c1a13;

  /* Gold accent */
  --gold:           #c9a84c;
  --gold-dim:       rgba(201, 168, 76, 0.35);
  --gold-faint:     rgba(201, 168, 76, 0.08);

  /* Text hierarchy */
  --text-primary:   #f0ead8;
  --text-secondary: #c8bfa8;
  --text-muted:     #8a8070;
  --text-dim:       #504840;

  /* Borders */
  --border-subtle:  rgba(201, 168, 76, 0.10);
  --border-medium:  rgba(201, 168, 76, 0.20);

  /* Functional colours */
  --success:  #34c759;
  --error:    #ff453a;
  --info:     #3482f6;
  --warning:  #ff9500;
}


/* ──────────────────────────────────────────────────────────
   2. RESET & BASE
   ────────────────────────────────────────────────────────── */
*, *::before, *::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  scroll-behavior: smooth;
}

body {
  font-family: 'Syne', sans-serif;
  background-color: var(--bg-deep);
  color: var(--text-primary);
  min-height: 100vh;
  line-height: 1.5;
  overflow-x: hidden;
}

/* Noise texture overlay — applied globally on all pages */
body::after {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 9999;
  opacity: 0.025;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='1'/%3E%3C/svg%3E");
  background-size: 200px 200px;
}


/* ──────────────────────────────────────────────────────────
   3. SCROLLBAR
   ────────────────────────────────────────────────────────── */
::-webkit-scrollbar       { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
  background: var(--border-medium);
  border-radius: 3px;
}
::-webkit-scrollbar-thumb:hover { background: var(--gold-dim); }


/* ──────────────────────────────────────────────────────────
   4. TYPOGRAPHY
   ────────────────────────────────────────────────────────── */
h1, h2, h3, h4, h5, h6 {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 300;
  letter-spacing: -0.02em;
  color: var(--text-primary);
}

code, pre, .mono {
  font-family: 'DM Mono', monospace;
  font-size: 0.875em;
}

::selection {
  background: rgba(201, 168, 76, 0.20);
  color: var(--text-primary);
}


/* ──────────────────────────────────────────────────────────
   5. FOCUS RING
   ────────────────────────────────────────────────────────── */
*:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 3px;
  border-radius: 4px;
}

/* Native audio accent */
audio { accent-color: var(--gold); }


/* ──────────────────────────────────────────────────────────
   6. UTILITY CLASSES
   ────────────────────────────────────────────────────────── */
/* Text */
.text-gold     { color: var(--gold); }
.text-muted    { color: var(--text-muted); }
.text-dim      { color: var(--text-dim); }
.text-success  { color: var(--success); }
.text-error    { color: var(--error); }
.text-warning  { color: var(--warning); }

/* Background */
.bg-panel  { background: var(--bg-panel); }
.bg-card   { background: var(--bg-card); }

/* Border */
.border-s  { border: 1px solid var(--border-subtle); }
.border-m  { border: 1px solid var(--border-medium); }

/* Border radius */
.rounded    { border-radius: 12px; }
.rounded-sm { border-radius: 8px; }
.rounded-lg { border-radius: 18px; }

/* Display */
.hidden  { display: none !important; }
.visible { display: block !important; }
.flex    { display: flex; }
.grid    { display: grid; }


/* ──────────────────────────────────────────────────────────
   7. ANIMATIONS & KEYFRAMES
   ────────────────────────────────────────────────────────── */
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes cardIn {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes spin {
  to { transform: rotate(360deg); }
}
@keyframes pulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.4; }
}
@keyframes glow {
  0%, 100% { box-shadow: 0 0 12px rgba(201,168,76,0.20); }
  50%       { box-shadow: 0 0 28px rgba(201,168,76,0.45); }
}
@keyframes shimmer {
  0%   { background-position: -200% center; }
  100% { background-position:  200% center; }
}
@keyframes recordSpin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}

.animate-fade-in { animation: fadeIn 0.4s ease both; }
.animate-fade-up { animation: fadeUp 0.5s ease both; }
.animate-glow    { animation: glow  2.5s ease-in-out infinite; }


/* ──────────────────────────────────────────────────────────
   8. SHIMMER LOADING STATE
   ────────────────────────────────────────────────────────── */
.shimmer {
  background: linear-gradient(
    90deg,
    var(--bg-card) 25%,
    rgba(201,168,76,0.10) 50%,
    var(--bg-card) 75%
  );
  background-size: 200% auto;
  animation: shimmer 1.5s linear infinite;
}


/* ──────────────────────────────────────────────────────────
   9. VINYL ICON DECORATION
   ────────────────────────────────────────────────────────── */
.vinyl-icon {
  width: 56px; height: 56px;
  border-radius: 50%;
  background:
    radial-gradient(circle at center,
      #1a1a12 20%, #0f0e09 21%,
      #1a1a12 35%, #141208 36%, #1a1a12 50%),
    conic-gradient(
      #1a1a12 0deg, #242218 90deg,
      #1a1a12 180deg, #201e14 270deg, #1a1a12 360deg);
  border: 1px solid rgba(201,168,76,0.15);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.vinyl-icon::before {
  content: '';
  width: 14px; height: 14px;
  border-radius: 50%;
  background: radial-gradient(circle, var(--gold) 30%, #a07832 100%);
  box-shadow: 0 0 8px rgba(201,168,76,0.40);
}


/* ──────────────────────────────────────────────────────────
   10. TOAST NOTIFICATION  (global, all pages)
   ────────────────────────────────────────────────────────── */
.toast {
  position: fixed;
  bottom: 32px; right: 32px;
  z-index: 9000;
  padding: 14px 20px;
  background: var(--bg-card);
  border: 1px solid var(--border-medium);
  border-radius: 12px;
  font-family: 'DM Mono', monospace;
  font-size: 12px; letter-spacing: 0.06em;
  color: var(--text-secondary);
  box-shadow: 0 20px 60px rgba(0,0,0,0.50);
  animation: fadeIn 0.3s ease;
  max-width: 320px;
  pointer-events: none;
}
.toast.success { border-color: rgba(52,199,89,0.30);  color: var(--success); }
.toast.error   { border-color: rgba(255,69,58,0.30);  color: var(--error);   }
.toast.warning { border-color: rgba(255,149,0,0.30);  color: var(--warning); }


/* ──────────────────────────────────────────────────────────
   11. NAVBAR  (shared across studio.php, daw.php, dashboard)
   ────────────────────────────────────────────────────────── */
.navbar {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  height: 64px;
  background: rgba(10,9,5,0.88);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--border-subtle);
  display: flex; align-items: center;
  padding: 0 32px;
}

/* Logo */
.nav-logo {
  display: flex; align-items: center;
  gap: 10px; text-decoration: none;
  margin-right: 40px; flex-shrink: 0;
}
.nav-logo-icon {
  width: 34px; height: 34px;
  background: linear-gradient(135deg, #c9a84c, #a07832);
  border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
}
.nav-logo-icon svg { width: 18px; height: 18px; }
.nav-logo-name {
  font-size: 17px; font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--text-primary);
}
.nav-logo-name span { color: var(--gold); }

/* Nav tabs */
.nav-tabs { display: flex; gap: 4px; flex: 1; }
.nav-tab {
  padding: 7px 18px; border-radius: 8px;
  border: none; background: none;
  font-family: 'Syne', sans-serif;
  font-size: 13px; font-weight: 600; letter-spacing: 0.04em;
  color: var(--text-muted); cursor: pointer;
  transition: all 0.25s ease;
  display: flex; align-items: center; gap: 8px;
  text-decoration: none;
}
.nav-tab svg { width: 15px; height: 15px; opacity: 0.7; }
.nav-tab:hover       { color: var(--text-primary); background: rgba(255,255,255,0.05); }
.nav-tab.active      { color: var(--gold); background: rgba(201,168,76,0.10); }
.nav-tab.active svg  { opacity: 1; }

/* DAW tab — teal accent */
.nav-tab.daw-tab             { color: var(--text-muted); }
.nav-tab.daw-tab:hover       { color: #5eead4; background: rgba(94,234,212,0.07); }
.nav-tab.daw-tab.active      { color: #5eead4; background: rgba(94,234,212,0.10); }

/* Right side of navbar */
.nav-right {
  display: flex; align-items: center;
  gap: 16px; margin-left: auto;
}
.nav-status {
  display: flex; align-items: center; gap: 8px;
  font-family: 'DM Mono', monospace;
  font-size: 11px; color: var(--text-muted);
}
.nav-status-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--success);
  box-shadow: 0 0 6px rgba(52,199,89,0.50);
  animation: pulse 2s ease-in-out infinite;
}
.nav-username {
  font-family: 'DM Mono', monospace;
  font-size: 12px; color: var(--text-secondary);
  padding: 5px 12px;
  border: 1px solid var(--border-subtle);
  border-radius: 20px; letter-spacing: 0.05em;
}
.nav-logout {
  padding: 7px 16px; background: none;
  border: 1px solid rgba(255,69,58,0.25);
  border-radius: 8px;
  font-family: 'Syne', sans-serif;
  font-size: 12px; font-weight: 600;
  color: rgba(255,69,58,0.70);
  cursor: pointer; transition: all 0.25s ease;
  letter-spacing: 0.04em; text-decoration: none;
}
.nav-logout:hover {
  background: rgba(255,69,58,0.10);
  border-color: rgba(255,69,58,0.50);
  color: var(--error);
}

 /* ═══════════════════════════════════════════
    12.   LAYOUT
    ═══════════════════════════════════════════ */
    .studio-layout {
      display: grid;
      grid-template-rows: auto 1fr;
      min-height: 100vh;
      padding-top: 58px; /* height of global-nav */
    }

    /* ── Studio body ── */
    .studio-body {
      display: grid;
      grid-template-columns: 240px 1fr;
      height: calc(100vh - 58px);
      overflow: hidden;
    }

/* ──────────────────────────────────────────────────────────
   13. SIDEBAR
   ────────────────────────────────────────────────────────── */
.sidebar {
      background: var(--bg-panel);
      border-right: 1px solid var(--border-subtle);
      display: flex;
      flex-direction: column;
      padding: 28px 0;
      overflow-y: auto;
    }
    .sidebar-section-label {
      font-family: 'DM Mono', monospace;
      font-size: 10px;
      letter-spacing: 0.15em;
      color: var(--text-dim);
      text-transform: uppercase;
      padding: 0 24px;
      margin-bottom: 12px;
    }
    .sidebar-tab {
      display: flex;
      align-items: center;
      gap: 12px;
      padding: 12px 24px;
      cursor: pointer;
      transition: background 0.18s, color 0.18s;
      border: none;
      background: none;
      width: 100%;
      text-align: left;
      border-left: 2px solid transparent;
      position: relative;
    }
    .sidebar-tab:hover { background: var(--bg-hover); }
    .sidebar-tab.active {
      background: var(--gold-faint);
      border-left-color: var(--gold);
    }
    .sidebar-tab.active .tab-label { color: var(--gold); }
    .tab-icon {
      width: 32px; height: 32px;
      border-radius: 8px;
      background: var(--bg-card);
      border: 1px solid var(--border-subtle);
      display: flex; align-items: center; justify-content: center;
      flex-shrink: 0;
      transition: border-color 0.18s, background 0.18s;
    }
    .sidebar-tab.active .tab-icon {
      background: var(--gold-faint);
      border-color: var(--gold-dim);
    }
    .tab-icon svg {
      width: 15px; height: 15px;
      stroke: var(--text-muted); fill: none;
      stroke-width: 1.5; stroke-linecap: round; stroke-linejoin: round;
      transition: stroke 0.18s;
    }
    .sidebar-tab.active .tab-icon svg { stroke: var(--gold); }
    .tab-label {
      font-family: 'Syne', sans-serif;
      font-size: 13px; font-weight: 500;
      color: var(--text-secondary);
      transition: color 0.18s;
    }
    .tab-badge {
      margin-left: auto;
      font-family: 'DM Mono', monospace;
      font-size: 10px;
      padding: 2px 7px;
      border-radius: 20px;
      background: var(--gold-faint);
      color: var(--gold);
      border: 1px solid var(--gold-dim);
      letter-spacing: 0.04em;
    }
    .sidebar-divider {
      height: 1px;
      background: var(--border-subtle);
      margin: 20px 24px;
    }

/* Preset cards */
.preset-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.preset-card {
  padding: 12px 14px;
  background: var(--bg-card);
  border: 1px solid var(--border-subtle);
  border-radius: 10px; cursor: pointer;
  transition: all 0.25s ease;
}
.preset-card:hover {
  border-color: var(--gold-dim);
  background: var(--bg-hover);
  transform: translateY(-2px);
}
.preset-card-genre {
  font-size: 11px; font-weight: 700; letter-spacing: 0.06em;
  color: var(--gold); text-transform: uppercase; margin-bottom: 4px;
}
.preset-card-desc {
  font-family: 'DM Mono', monospace;
  font-size: 10px; color: var(--text-dim); line-height: 1.5;
}

/* Mode switcher */
.mode-switcher {
  display: flex; background: var(--bg-deep);
  border-radius: 10px; padding: 4px; gap: 3px;
  border: 1px solid var(--border-subtle);
}
.mode-btn {
  flex: 1; padding: 8px 6px; background: none;
  border: none; border-radius: 7px;
  font-family: 'Syne', sans-serif;
  font-size: 11px; font-weight: 600; letter-spacing: 0.04em;
  color: var(--text-dim); cursor: pointer;
  transition: all 0.25s ease; white-space: nowrap;
}
.mode-btn.active {
  background: var(--bg-card); color: var(--gold);
  box-shadow: 0 2px 8px rgba(0,0,0,0.30);
}

/* Vocal sub-tabs */
.vocal-tabs {
  display: flex; gap: 4px; margin-bottom: 16px;
  background: var(--bg-deep); padding: 4px;
  border-radius: 8px; border: 1px solid var(--border-subtle);
}
.vocal-tab {
  flex: 1; padding: 8px 4px; text-align: center;
  font-family: 'Syne', sans-serif;
  font-size: 11px; font-weight: 600; letter-spacing: 0.04em;
  color: var(--text-dim); cursor: pointer;
  border-radius: 6px; transition: all 0.2s ease;
}
.vocal-tab.active {
  background: var(--bg-card); color: var(--gold);
  box-shadow: 0 2px 6px rgba(0,0,0,0.20);
}


/* ──────────────────────────────────────────────────────────
   14. FORM ELEMENTS  (shared: login, studio, dashboard)
   ────────────────────────────────────────────────────────── */
.form-group  { margin-bottom: 16px; }
.form-label  {
  display: block;
  font-family: 'DM Mono', monospace;
  font-size: 10px; font-weight: 500;
  letter-spacing: 0.12em; color: var(--text-muted);
  text-transform: uppercase; margin-bottom: 7px;
}
.form-input,
.form-select,
.form-textarea {
  width: 100%;
  background: var(--bg-deep);
  border: 1px solid var(--border-subtle);
  border-radius: 9px; padding: 11px 14px;
  font-family: 'Syne', sans-serif;
  font-size: 13px; color: var(--text-primary);
  outline: none; transition: all 0.25s ease;
}
.form-textarea {
  resize: vertical; min-height: 90px; line-height: 1.6;
}
.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(201,168,76,0.08);
}
.form-input::placeholder,
.form-textarea::placeholder { color: var(--text-dim); }
.form-select option { background: #1a1a0f; }

/* Range slider */
.range-wrapper { display: flex; align-items: center; gap: 12px; }
.form-range {
  flex: 1; -webkit-appearance: none;
  height: 4px; border-radius: 2px;
  background: var(--border-subtle); outline: none;
}
.form-range::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 16px; height: 16px; border-radius: 50%;
  background: var(--gold); cursor: pointer;
  box-shadow: 0 0 6px rgba(201,168,76,0.40);
}
.range-val {
  font-family: 'DM Mono', monospace;
  font-size: 12px; color: var(--gold);
  min-width: 36px; text-align: right;
}


/* ──────────────────────────────────────────────────────────
   15. MODEL SELECTOR
   ────────────────────────────────────────────────────────── */
.model-selector {
  display: grid; grid-template-columns: repeat(3,1fr);
  gap: 6px; margin-bottom: 4px;
}
.model-opt { position: relative; cursor: pointer; }
.model-opt input[type="radio"] { position: absolute; opacity: 0; width: 0; height: 0; }
.model-opt-label {
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 4px; padding: 10px 6px;
  background: var(--bg-deep); border: 1px solid var(--border-subtle);
  border-radius: 9px; cursor: pointer;
  transition: all 0.2s ease; text-align: center;
}
.model-opt input:checked + .model-opt-label {
  border-color: var(--gold);
  background: rgba(201,168,76,0.08);
  box-shadow: 0 0 0 1px rgba(201,168,76,0.20);
}
.model-opt-label:hover { border-color: var(--gold-dim); background: var(--bg-hover); }
.model-opt-name {
  font-family: 'Syne', sans-serif;
  font-size: 11px; font-weight: 700; letter-spacing: 0.06em;
  color: var(--text-secondary); text-transform: uppercase;
}
.model-opt input:checked + .model-opt-label .model-opt-name { color: var(--gold); }
.model-opt-vram {
  font-family: 'DM Mono', monospace;
  font-size: 9px; color: var(--text-dim); letter-spacing: 0.04em;
}
.model-opt input:checked + .model-opt-label .model-opt-vram { color: rgba(201,168,76,0.50); }


/* ──────────────────────────────────────────────────────────
   16. ADVANCED TOGGLE PANEL
   ────────────────────────────────────────────────────────── */
.adv-toggle {
  display: flex; align-items: center; justify-content: space-between;
  padding: 9px 12px; background: var(--bg-deep);
  border: 1px solid var(--border-subtle); border-radius: 8px;
  cursor: pointer; transition: all 0.2s ease; user-select: none;
}
.adv-toggle:hover { border-color: var(--gold-dim); }
.adv-toggle-label {
  font-family: 'DM Mono', monospace;
  font-size: 10px; font-weight: 500;
  letter-spacing: 0.1em; color: var(--text-muted);
  text-transform: uppercase;
}
.adv-toggle-arrow {
  width: 14px; height: 14px; color: var(--text-dim);
  transition: transform 0.25s ease; flex-shrink: 0;
}
.adv-toggle.open .adv-toggle-arrow  { transform: rotate(180deg); }
.adv-toggle.open .adv-toggle-label  { color: var(--gold); }

.adv-params {
  display: none; padding: 16px 14px;
  background: var(--bg-deep); border: 1px solid var(--border-subtle);
  border-top: none; border-radius: 0 0 8px 8px; margin-bottom: 16px;
}
.adv-params.open { display: block; }

.param-hint {
  font-family: 'DM Mono', monospace;
  font-size: 9px; color: var(--text-dim);
  letter-spacing: 0.04em; margin-top: 4px; line-height: 1.5;
}

/* VRAM warning */
.vram-warning {
  display: none; padding: 8px 12px;
  background: rgba(255,149,0,0.06);
  border: 1px solid rgba(255,149,0,0.20);
  border-radius: 8px;
  font-family: 'DM Mono', monospace;
  font-size: 10px; color: rgba(255,149,0,0.80);
  letter-spacing: 0.04em; line-height: 1.6; margin-top: 8px;
}
.vram-warning.visible { display: block; }


/* ──────────────────────────────────────────────────────────
   17. UPLOAD AREA
   ────────────────────────────────────────────────────────── */
.upload-area {
  border: 1.5px dashed var(--border-subtle);
  border-radius: 10px; padding: 20px; text-align: center;
  cursor: pointer; transition: all 0.25s ease;
  font-family: 'DM Mono', monospace;
  font-size: 11px; color: var(--text-dim);
  letter-spacing: 0.06em; background: var(--bg-deep);
}
.upload-area:hover {
  border-color: var(--gold-dim);
  background: rgba(201,168,76,0.04);
  color: var(--text-muted);
}
.upload-area.has-file {
  border-color: rgba(52,199,89,0.40);
  background: rgba(52,199,89,0.04);
  color: var(--success);
}


/* ──────────────────────────────────────────────────────────
   18. PANEL COMPONENT
   ────────────────────────────────────────────────────────── */
    /* ── Main Panel ── */
   .main-panel {
      overflow-y: auto;
      padding: 40px 48px;
      background: var(--bg-deep);
    }

    /* ── Tab Panes ── */
    .tab-pane { display: none; animation: fadeUp 0.35s ease both; }
    .tab-pane.active { display: block; }

    /* ── Section header ── */
    .section-header {
      margin-bottom: 32px;
      padding-bottom: 20px;
      border-bottom: 1px solid var(--border-subtle);
    }
    .section-eyebrow {
      font-family: 'DM Mono', monospace;
      font-size: 10px; letter-spacing: 0.18em;
      color: var(--gold); text-transform: uppercase; margin-bottom: 8px;
    }
    .section-title {
      font-family: 'Cormorant Garamond', serif;
      font-size: 2.2rem; font-weight: 300;
      letter-spacing: -0.02em; color: var(--text-primary); line-height: 1.1;
    }
    .section-desc {
      font-size: 13px; color: var(--text-muted); margin-top: 6px;
      font-family: 'DM Mono', monospace; letter-spacing: 0.03em;
    }

    /* ── Cards ── */
    .card {
      background: var(--bg-card);
      border: 1px solid var(--border-subtle);
      border-radius: 16px; padding: 28px; margin-bottom: 20px;
      transition: border-color 0.2s;
    }
    .card:hover { border-color: var(--border-medium); }
    .card-title {
      font-family: 'Cormorant Garamond', serif;
      font-size: 1.1rem; font-weight: 400;
      color: var(--text-primary); margin-bottom: 20px;
      display: flex; align-items: center; gap: 8px;
    }
    .card-title::before {
      content: ''; width: 3px; height: 16px;
      background: var(--gold); border-radius: 2px; opacity: 0.7;
    }

    /* ── Form elements ── */
    .form-group { margin-bottom: 18px; }
    .form-label {
      display: block; font-family: 'DM Mono', monospace;
      font-size: 11px; letter-spacing: 0.1em;
      color: var(--text-muted); text-transform: uppercase; margin-bottom: 8px;
    }
    .form-input, .form-select, .form-textarea {
      width: 100%; background: var(--bg-panel);
      border: 1px solid var(--border-subtle); border-radius: 10px;
      padding: 12px 16px; color: var(--text-primary);
      font-family: 'Syne', sans-serif; font-size: 14px;
      transition: border-color 0.2s, box-shadow 0.2s; appearance: none;
    }
    .form-input:focus, .form-select:focus, .form-textarea:focus {
      outline: none; border-color: var(--gold-dim);
      box-shadow: 0 0 0 3px var(--gold-faint);
    }
    .form-input::placeholder, .form-textarea::placeholder { color: var(--text-dim); }
    .form-textarea { resize: vertical; min-height: 90px; line-height: 1.6; }
    .form-select {
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238a8070' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
      background-repeat: no-repeat; background-position: right 14px center;
      padding-right: 36px; cursor: pointer;
    }
    .form-select option { background: var(--bg-card); }

    /* ── Range slider ── */
    .range-row { display: flex; align-items: center; gap: 14px; }
    .form-range {
      -webkit-appearance: none; flex: 1; height: 3px;
      background: var(--border-subtle); border-radius: 2px; cursor: pointer;
    }
    .form-range::-webkit-slider-thumb {
      -webkit-appearance: none; width: 16px; height: 16px;
      border-radius: 50%; background: var(--gold);
      box-shadow: 0 0 8px var(--gold-dim); cursor: pointer; transition: transform 0.15s;
    }
    .form-range::-webkit-slider-thumb:hover { transform: scale(1.2); }
    .range-value {
      font-family: 'DM Mono', monospace; font-size: 12px;
      color: var(--gold); min-width: 38px; text-align: right;
    }

    /* ── Grid helpers ── */
    .grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
    .grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px; }

/* ──────────────────────────────────────────────────────────
   19. BUTTONS
   ────────────────────────────────────────────────────────── */
     /* ── Buttons ── */
    .btn {
      display: inline-flex; align-items: center; justify-content: center;
      gap: 8px; font-family: 'DM Mono', monospace; font-size: 12px;
      letter-spacing: 0.08em; text-transform: uppercase; border: none;
      border-radius: 10px; padding: 13px 24px; cursor: pointer;
      transition: all 0.2s; white-space: nowrap; text-decoration: none;
    }
    .btn-primary { background: var(--gold); color: #0a0905; font-weight: 600; }
    .btn-primary:hover {
      background: #d4b560;
      box-shadow: 0 8px 24px rgba(201,168,76,0.3);
      transform: translateY(-1px);
    }
    .btn-primary:active { transform: translateY(0); }
    .btn-ghost {
      background: transparent; color: var(--text-secondary);
      border: 1px solid var(--border-subtle);
    }
    .btn-ghost:hover {
      border-color: var(--border-medium); color: var(--text-primary);
      background: var(--bg-hover);
    }
    .btn-gold-outline {
      background: transparent; color: var(--gold); border: 1px solid var(--gold-dim);
    }
    .btn-gold-outline:hover { background: var(--gold-faint); border-color: var(--gold); }
    .btn-danger {
      background: transparent; color: var(--error);
      border: 1px solid rgba(255,69,58,0.25);
    }
    .btn-danger:hover { background: rgba(255,69,58,0.08); }
    .btn:disabled {
      opacity: 0.4; cursor: not-allowed;
      transform: none !important; box-shadow: none !important;
    }
    .btn-full { width: 100%; }
    .btn-sm { padding: 8px 16px; font-size: 11px; }


/* ──────────────────────────────────────────────────────────
   20. SPINNER
   ────────────────────────────────────────────────────────── */
.spinner {
  display: none;
  width: 18px; height: 18px;
  border: 2px solid rgba(10,9,5,0.30);
  border-top-color: #0a0905;
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}
.spinner.visible { display: inline-block; }


/* ──────────────────────────────────────────────────────────
   21. AUDIO RESULT CARD
   ────────────────────────────────────────────────────────── */
.audio-result {
  display: none;
  background: var(--bg-deep); border: 1px solid var(--border-subtle);
  border-radius: 12px; padding: 20px; margin-top: 16px;
}
.audio-result.visible { display: block; }

.audio-result-label {
  font-family: 'DM Mono', monospace;
  font-size: 10px; letter-spacing: 0.12em; color: var(--gold);
  text-transform: uppercase; margin-bottom: 12px;
}
.result-params { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 12px; }
.result-param-chip {
  font-family: 'DM Mono', monospace;
  font-size: 9px; letter-spacing: 0.08em; color: var(--text-dim);
  padding: 3px 8px; border: 1px solid var(--border-subtle);
  border-radius: 20px; background: var(--bg-card);
}
.result-param-chip span { color: var(--text-muted); }
.audio-player {
  width: 100%; height: 40px; border-radius: 8px;
  filter: hue-rotate(40deg) brightness(0.90);
}
.audio-actions { display: flex; gap: 8px; margin-top: 12px; }


/* ──────────────────────────────────────────────────────────
   22. LYRICS OUTPUT
   ────────────────────────────────────────────────────────── */
.lyrics-output {
  display: none;
  background: var(--bg-deep); border: 1px solid var(--border-subtle);
  border-radius: 12px; padding: 20px; margin-top: 16px;
  font-family: 'Cormorant Garamond', serif;
  font-size: 16px; font-weight: 300;
  line-height: 2; color: var(--text-secondary);
  white-space: pre-wrap; max-height: 360px; overflow-y: auto;
}
.lyrics-output.visible { display: block; }


/* ──────────────────────────────────────────────────────────
   23. STATUS BAR
   ────────────────────────────────────────────────────────── */
.status-bar {
  padding: 10px 24px; background: var(--bg-deep);
  border-top: 1px solid var(--border-subtle);
  font-family: 'DM Mono', monospace;
  font-size: 11px; color: var(--text-dim); letter-spacing: 0.06em;
}
.status-bar.loading { color: var(--gold); }
.status-bar.success { color: var(--success); }
.status-bar.error   { color: var(--error); }

/* ──────────────────────────────────────────────────────────
   24. PROGRESS BAR
   ────────────────────────────────────────────────────────── */
   /* ── Progress bar ── */
    .progress-wrap {
      height: 3px; background: var(--border-subtle);
      border-radius: 2px; margin-top: 16px; overflow: hidden; display: none;
    }
    .progress-wrap.visible { display: block; }
    .progress-bar {
      height: 100%;
      background: linear-gradient(90deg, var(--gold-dim), var(--gold));
      border-radius: 2px; width: 0%; transition: width 0.4s ease;
    }

    /* ── Result panel ── */
    .result-panel {
      background: var(--bg-panel); border: 1px solid var(--border-subtle);
      border-radius: 14px; padding: 24px; margin-top: 20px;
      display: none; animation: fadeIn 0.4s ease both;
    }
    .result-panel.visible { display: block; }
    .result-header {
      display: flex; align-items: center;
      justify-content: space-between; margin-bottom: 16px;
    }
    .result-title {
      font-family: 'Cormorant Garamond', serif;
      font-size: 1rem; font-weight: 300; color: var(--text-primary);
    }
    .result-meta {
      font-family: 'DM Mono', monospace;
      font-size: 10px; color: var(--text-dim); letter-spacing: 0.08em;
    }
    .result-audio { width: 100%; margin-top: 12px; height: 40px; border-radius: 8px; }
    .result-actions { display: flex; gap: 10px; margin-top: 14px; flex-wrap: wrap; }

    /* ── Waveform ── */
    .waveform {
      display: flex; align-items: center; justify-content: center;
      gap: 3px; height: 40px; padding: 0 4px;
    }
    .waveform-bar {
      width: 3px; border-radius: 2px;
      background: var(--gold-dim); transform-origin: center; animation: none;
    }
    @keyframes waveAnim {
      0%, 100% { transform: scaleY(0.3); }
      50%       { transform: scaleY(1); }
    }
    .waveform.playing .waveform-bar {
      animation: waveAnim 0.8s ease-in-out infinite;
    }

    /* ── Lyrics display ── */
    .lyrics-display {
      background: var(--bg-deep); border: 1px solid var(--border-subtle);
      border-radius: 12px; padding: 28px 32px; margin-top: 16px;
      font-family: 'Cormorant Garamond', serif;
      font-size: 1rem; font-weight: 300; line-height: 2;
      color: var(--text-primary); letter-spacing: 0.01em;
      white-space: pre-wrap; display: none; animation: fadeIn 0.4s ease;
    }
    .lyrics-display.visible { display: block; }
    .lyrics-section-label {
      font-family: 'DM Mono', monospace;
      font-size: 10px; letter-spacing: 0.15em;
      color: var(--gold); text-transform: uppercase;
    }

    /* ── Sheet Music panel ── */
    .sheet-panel {
      background: var(--bg-panel); border: 1px solid var(--border-subtle);
      border-radius: 16px; padding: 28px; margin-top: 20px;
      display: none; animation: fadeIn 0.4s ease both;
    }
    .sheet-panel.visible { display: block; }
    .sheet-header {
      display: flex; align-items: center;
      justify-content: space-between; margin-bottom: 20px;
    }
    .sheet-title {
      font-family: 'Cormorant Garamond', serif;
      font-size: 1.1rem; font-weight: 300; color: var(--text-primary);
    }
    .sheet-subtitle {
      font-family: 'DM Mono', monospace;
      font-size: 10px; letter-spacing: 0.1em;
      color: var(--text-dim); margin-top: 2px;
    }
    .sheet-key-info { display: flex; gap: 16px; margin-top: 16px; flex-wrap: wrap; }
    .key-chip {
      font-family: 'DM Mono', monospace; font-size: 11px;
      padding: 5px 12px; border-radius: 20px;
      background: var(--gold-faint); border: 1px solid var(--gold-dim);
      color: var(--gold); letter-spacing: 0.06em;
    }

    /* ── Upload zone ── */
    .upload-zone {
      border: 2px dashed var(--border-medium); border-radius: 16px;
      padding: 52px 24px; text-align: center; cursor: pointer;
      transition: border-color 0.2s, background 0.2s; position: relative;
    }
    .upload-zone:hover, .upload-zone.dragover {
      border-color: var(--gold-dim); background: var(--gold-faint);
    }
    .upload-zone input[type="file"] {
      position: absolute; inset: 0; opacity: 0; cursor: pointer;
    }
    .upload-icon {
      width: 48px; height: 48px; border-radius: 12px;
      background: var(--bg-card); border: 1px solid var(--border-medium);
      display: flex; align-items: center; justify-content: center;
      margin: 0 auto 16px;
    }
    .upload-icon svg {
      width: 22px; height: 22px; stroke: var(--gold); fill: none;
      stroke-width: 1.5; stroke-linecap: round;
    }
    .upload-label {
      font-family: 'Cormorant Garamond', serif;
      font-size: 1.1rem; font-weight: 300; color: var(--text-primary); margin-bottom: 6px;
    }
    .upload-hint {
      font-family: 'DM Mono', monospace;
      font-size: 11px; color: var(--text-dim); letter-spacing: 0.06em;
    }

    /* ── Status line ── */
    .status-line {
      font-family: 'DM Mono', monospace; font-size: 11px;
      letter-spacing: 0.06em; color: var(--text-muted);
      margin-top: 12px; min-height: 18px; transition: color 0.2s;
    }
    .status-line.ok   { color: var(--success); }
    .status-line.err  { color: var(--error); }
    .status-line.warn { color: var(--gold); }

    /* ── Spinner ── */
    @keyframes spin { to { transform: rotate(360deg); } }
    .spinner {
      width: 14px; height: 14px;
      border: 2px solid var(--border-medium);
      border-top-color: var(--gold); border-radius: 50%;
      animation: spin 0.7s linear infinite; display: inline-block;
    }

    /* ── Mixer track row ── */
    .mix-track {
      display: flex; align-items: center; gap: 14px;
      padding: 16px 20px; background: var(--bg-deep);
      border: 1px solid var(--border-subtle); border-radius: 12px;
      margin-bottom: 12px; transition: border-color 0.2s;
    }
    .mix-track:hover { border-color: var(--border-medium); }
    .track-label {
      font-family: 'DM Mono', monospace; font-size: 11px;
      letter-spacing: 0.08em; color: var(--text-muted);
      text-transform: uppercase; width: 56px; flex-shrink: 0;
    }
    .track-input {
      flex: 1; background: var(--bg-panel);
      border: 1px solid var(--border-subtle); border-radius: 8px;
      padding: 9px 14px; color: var(--text-primary);
      font-family: 'DM Mono', monospace; font-size: 12px;
    }
    .track-input:focus { outline: none; border-color: var(--gold-dim); }
    .track-vol-label {
      font-family: 'DM Mono', monospace; font-size: 10px;
      color: var(--text-dim); width: 24px; text-align: center;
    }
    .track-volume {
      width: 80px; -webkit-appearance: none;
      height: 2px; background: var(--border-subtle);
      border-radius: 2px; cursor: pointer;
    }
    .track-volume::-webkit-slider-thumb {
      -webkit-appearance: none; width: 12px; height: 12px;
      border-radius: 50%; background: var(--gold); cursor: pointer;
    }

    /* ══════════════════════════════════════════════
       RESPONSIVE
    ══════════════════════════════════════════════ */
    @media (max-width: 860px) {
      .gnav-links { display: none; }
      .gnav-hamburger { display: flex; }
      .gnav-status { display: none; }
      .studio-body { grid-template-columns: 1fr; }
      .sidebar {
        flex-direction: row; overflow-x: auto; padding: 0;
        border-right: none; border-bottom: 1px solid var(--border-subtle); height: auto;
      }
      .sidebar-tab {
        border-left: none; border-bottom: 2px solid transparent;
        flex-direction: column; gap: 4px; padding: 12px 16px; min-width: 80px;
      }
      .sidebar-tab.active { border-bottom-color: var(--gold); border-left: none; }
      .sidebar-section-label, .sidebar-divider, .tab-badge { display: none; }
      .tab-label { font-size: 11px; }
      .main-panel { padding: 24px 20px; height: auto; }
      .grid-2, .grid-3 { grid-template-columns: 1fr; }
      .section-title { font-size: 1.7rem; }
    }
    @media (max-width: 480px) {
      .global-nav { padding: 0 16px; }
      .gnav-username { display: none; }
    }

    /* ══════════════════════════════════════════════════════════
       GLOBAL NAVBAR
    ══════════════════════════════════════════════════════════ */
    .global-nav {
      position: fixed;
      top: 0; left: 0; right: 0;
      z-index: 2000;
      height: 58px;
      background: rgba(10, 9, 5, 0.92);
      backdrop-filter: blur(24px);
      -webkit-backdrop-filter: blur(24px);
      border-bottom: 1px solid var(--border-subtle);
      display: flex;
      align-items: center;
      padding: 0 32px;
      gap: 0;
    }

    /* ── Brand ── */
    .gnav-brand {
      display: flex;
      align-items: center;
      gap: 10px;
      text-decoration: none;
      margin-right: 36px;
      flex-shrink: 0;
    }
    .gnav-brand-icon {
      width: 30px; height: 30px;
      background: linear-gradient(135deg, var(--gold), #a07832);
      border-radius: 8px;
      display: flex; align-items: center; justify-content: center;
    }
    .gnav-brand-icon svg {
      width: 16px; height: 16px;
      stroke: #0a0905; fill: none;
      stroke-width: 2; stroke-linecap: round;
    }
    .gnav-brand-text {
      font-family: 'Cormorant Garamond', serif;
      font-size: 1.2rem;
      font-weight: 400;
      letter-spacing: 0.05em;
      color: var(--text-primary);
    }
    .gnav-brand-text span { color: var(--gold); }

    /* ── Nav links ── */
    .gnav-links {
      display: flex;
      align-items: center;
      gap: 2px;
      flex: 1;
    }
    .gnav-link {
      display: flex;
      align-items: center;
      gap: 7px;
      padding: 6px 14px;
      border-radius: 8px;
      font-family: 'Syne', sans-serif;
      font-size: 12px;
      font-weight: 600;
      letter-spacing: 0.04em;
      color: var(--text-muted);
      text-decoration: none;
      transition: all 0.2s ease;
      white-space: nowrap;
      border: 1px solid transparent;
    }
    .gnav-link svg {
      width: 14px; height: 14px;
      stroke: currentColor; fill: none;
      stroke-width: 1.8; stroke-linecap: round;
      flex-shrink: 0; opacity: 0.7;
      transition: opacity 0.2s;
    }
    .gnav-link:hover {
      color: var(--text-primary);
      background: rgba(255,255,255,0.05);
    }
    .gnav-link:hover svg { opacity: 1; }

    /* Active state — gold */
    .gnav-link.active {
      color: var(--gold);
      background: rgba(201,168,76,0.09);
      border-color: rgba(201,168,76,0.15);
    }
    .gnav-link.active svg { opacity: 1; }

    /* DAW — teal accent */
    .gnav-link.daw:hover   { color: #5eead4; background: rgba(94,234,212,0.07); }
    .gnav-link.daw.active  { color: #5eead4; background: rgba(94,234,212,0.09); border-color: rgba(94,234,212,0.18); }

    /* Public — blue accent */
    .gnav-link.public:hover  { color: var(--info); background: rgba(52,130,246,0.07); }
    .gnav-link.public.active { color: var(--info); background: rgba(52,130,246,0.09); border-color: rgba(52,130,246,0.18); }

    /* ── Right side ── */
    .gnav-right {
      display: flex;
      align-items: center;
      gap: 12px;
      margin-left: auto;
      flex-shrink: 0;
    }

    /* Live status pill */
    .gnav-status {
      display: flex;
      align-items: center;
      gap: 6px;
      font-family: 'DM Mono', monospace;
      font-size: 10px;
      letter-spacing: 0.06em;
      color: var(--text-dim);
      padding: 4px 10px;
      border: 1px solid var(--border-subtle);
      border-radius: 20px;
    }
    .gnav-status-dot {
      width: 6px; height: 6px;
      border-radius: 50%;
      background: var(--success);
      box-shadow: 0 0 6px rgba(52,199,89,0.5);
      animation: pulse 2s ease-in-out infinite;
    }

    /* Profile button */
    .gnav-profile-btn {
      display: flex;
      align-items: center;
      gap: 9px;
      padding: 4px 12px 4px 4px;
      border-radius: 24px;
      border: 1px solid var(--border-subtle);
      background: var(--bg-card);
      cursor: pointer;
      transition: all 0.2s;
      position: relative;
    }
    .gnav-profile-btn:hover {
      border-color: var(--gold-dim);
      background: var(--bg-hover);
    }
    .gnav-avatar {
      width: 28px; height: 28px;
      border-radius: 50%;
      background: linear-gradient(135deg, var(--gold), #7a5c1e);
      display: flex; align-items: center; justify-content: center;
      font-family: 'Syne', sans-serif;
      font-size: 11px; font-weight: 700;
      color: #0a0905;
      flex-shrink: 0;
      letter-spacing: 0.02em;
    }
    .gnav-username {
      font-family: 'DM Mono', monospace;
      font-size: 11px;
      letter-spacing: 0.06em;
      color: var(--text-secondary);
      max-width: 100px;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
    }
    .gnav-chevron {
      width: 10px; height: 10px;
      stroke: var(--text-dim); fill: none;
      stroke-width: 2; stroke-linecap: round;
      transition: transform 0.2s;
      flex-shrink: 0;
    }
    .gnav-profile-btn.open .gnav-chevron { transform: rotate(180deg); }

    /* ── Profile Dropdown ── */
    .gnav-dropdown {
      position: absolute;
      top: calc(100% + 10px);
      right: 0;
      width: 240px;
      background: var(--bg-panel);
      border: 1px solid var(--border-medium);
      border-radius: 14px;
      box-shadow: 0 24px 60px rgba(0,0,0,0.55);
      overflow: hidden;
      opacity: 0;
      transform: translateY(-8px) scale(0.97);
      pointer-events: none;
      transition: opacity 0.2s ease, transform 0.2s ease;
      z-index: 3000;
    }
    .gnav-dropdown.open {
      opacity: 1;
      transform: translateY(0) scale(1);
      pointer-events: all;
    }
    .gnav-dropdown-header {
      padding: 16px 18px 12px;
      border-bottom: 1px solid var(--border-subtle);
    }
    .gnav-dropdown-name {
      font-family: 'Cormorant Garamond', serif;
      font-size: 1.05rem;
      font-weight: 400;
      color: var(--text-primary);
      margin-bottom: 2px;
    }
    .gnav-dropdown-role {
      font-family: 'DM Mono', monospace;
      font-size: 10px;
      letter-spacing: 0.1em;
      color: var(--gold);
      text-transform: uppercase;
    }
    .gnav-dropdown-body { padding: 8px; }
    .gnav-dropdown-item {
      display: flex;
      align-items: center;
      gap: 10px;
      padding: 9px 12px;
      border-radius: 8px;
      font-family: 'Syne', sans-serif;
      font-size: 12px;
      font-weight: 500;
      color: var(--text-secondary);
      text-decoration: none;
      cursor: pointer;
      background: none;
      border: none;
      width: 100%;
      text-align: left;
      transition: all 0.18s;
    }
    .gnav-dropdown-item svg {
      width: 14px; height: 14px;
      stroke: var(--text-muted); fill: none;
      stroke-width: 1.8; stroke-linecap: round;
      flex-shrink: 0;
      transition: stroke 0.18s;
    }
    .gnav-dropdown-item:hover {
      background: var(--bg-hover);
      color: var(--text-primary);
    }
    .gnav-dropdown-item:hover svg { stroke: var(--gold); }
    .gnav-dropdown-item.danger      { color: rgba(255,69,58,0.7); }
    .gnav-dropdown-item.danger svg  { stroke: rgba(255,69,58,0.6); }
    .gnav-dropdown-item.danger:hover {
      background: rgba(255,69,58,0.08);
      color: var(--error);
    }
    .gnav-dropdown-item.danger:hover svg { stroke: var(--error); }
    .gnav-dropdown-divider {
      height: 1px;
      background: var(--border-subtle);
      margin: 6px 8px;
    }

    /* ── Mobile hamburger ── */
    .gnav-hamburger {
      display: none;
      flex-direction: column;
      gap: 5px;
      padding: 8px;
      background: none;
      border: none;
      cursor: pointer;
      margin-left: 8px;
    }
    .gnav-hamburger span {
      display: block;
      width: 20px; height: 1.5px;
      background: var(--text-muted);
      border-radius: 1px;
      transition: all 0.2s;
    }

    /* ── Mobile drawer ── */
    .gnav-mobile-drawer {
      display: none;
      position: fixed;
      top: 58px; left: 0; right: 0;
      background: var(--bg-panel);
      border-bottom: 1px solid var(--border-subtle);
      padding: 12px 16px 20px;
      z-index: 1999;
      flex-direction: column;
      gap: 4px;
      animation: fadeIn 0.2s ease;
    }
    .gnav-mobile-drawer.open { display: flex; }
    .gnav-mobile-drawer .gnav-link {
      width: 100%;
      padding: 11px 14px;
      font-size: 13px;
    }

    /* ── DASHBOARD ── */
    /* ══ LAYOUT ══ */
    body{padding-top:58px;background:var(--bg-deep)}
    .dash-wrap{max-width:1280px;margin:0 auto;padding:48px 40px}
     /* ══ HERO ══ */
    .dash-hero{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:48px;padding-bottom:32px;border-bottom:1px solid var(--border-subtle);flex-wrap:wrap;gap:24px}
    .dash-greeting-sub{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:.16em;color:var(--gold);text-transform:uppercase;margin-bottom:8px}
    .dash-greeting-title{font-family:'Cormorant Garamond',serif;font-size:3rem;font-weight:300;color:var(--text-primary);line-height:1.05;letter-spacing:-.02em}
    .dash-greeting-title span{color:var(--gold);font-style:italic}
    .dash-greeting-desc{font-family:'DM Mono',monospace;font-size:12px;color:var(--text-muted);margin-top:8px;letter-spacing:.04em}
    .dash-cta-group{display:flex;gap:12px;flex-wrap:wrap}

    /* ══ STATS ══ */
    .stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:40px}
    .stat-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:16px;padding:24px;transition:border-color .2s,transform .2s;cursor:default}
    .stat-card:hover{border-color:var(--border-medium);transform:translateY(-2px)}
    .stat-icon{width:40px;height:40px;border-radius:10px;background:var(--gold-faint);border:1px solid var(--gold-dim);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
    .stat-icon svg{width:18px;height:18px;stroke:var(--gold);fill:none;stroke-width:1.5;stroke-linecap:round}
    .stat-value{font-family:'Cormorant Garamond',serif;font-size:2.4rem;font-weight:300;color:var(--text-primary);line-height:1;margin-bottom:6px}
    .stat-label{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.12em;color:var(--text-dim);text-transform:uppercase}

    /* ══ SECTION HEADERS ══ */
    .section-eyebrow{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.18em;color:var(--gold);text-transform:uppercase;margin-bottom:6px}
    .section-title{font-family:'Cormorant Garamond',serif;font-size:1.8rem;font-weight:300;color:var(--text-primary);margin-bottom:20px;letter-spacing:-.01em}
    .section-header-row{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}
    .section-header-row .section-title{margin-bottom:0}

    /* ══ FEATURED BANNER ══ */
    .featured-banner{background:linear-gradient(135deg,#1a160c 0%,#2a1f08 50%,#1a1208 100%);border:1px solid var(--gold-dim);border-radius:20px;padding:48px;margin-bottom:40px;position:relative;overflow:hidden}
    .featured-banner::before{content:'';position:absolute;top:-60px;right:-60px;width:240px;height:240px;background:radial-gradient(circle,rgba(201,168,76,.15),transparent 70%);border-radius:50%}
    .featured-banner::after{content:'';position:absolute;bottom:-40px;left:20%;width:180px;height:180px;background:radial-gradient(circle,rgba(201,168,76,.08),transparent 70%);border-radius:50%}
    .featured-tag{display:inline-flex;align-items:center;gap:6px;font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);background:rgba(201,168,76,.1);border:1px solid var(--gold-dim);border-radius:20px;padding:4px 12px;margin-bottom:20px}
    .featured-tag span{width:6px;height:6px;border-radius:50%;background:var(--gold);box-shadow:0 0 6px rgba(201,168,76,.6);animation:pulse 2s ease-in-out infinite}
    .featured-title{font-family:'Cormorant Garamond',serif;font-size:2.4rem;font-weight:300;color:var(--text-primary);line-height:1.1;letter-spacing:-.02em;margin-bottom:12px;position:relative}
    .featured-desc{font-family:'DM Mono',monospace;font-size:12px;color:var(--text-muted);letter-spacing:.04em;max-width:480px;line-height:1.8;margin-bottom:28px;position:relative}
    .featured-actions{display:flex;gap:12px;flex-wrap:wrap;position:relative}

    /* ══ EVENTS GRID ══ */
    .events-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:40px}

    /* ── Event card ── */
    .event-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:18px;overflow:hidden;transition:border-color .25s,transform .25s,box-shadow .25s;display:flex;flex-direction:column}
    .event-card:hover{border-color:var(--gold-dim);transform:translateY(-3px);box-shadow:0 16px 40px rgba(0,0,0,.25)}

    /* Cover image area */
    .event-cover{width:100%;height:150px;position:relative;overflow:hidden;flex-shrink:0}
    .event-cover img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
    .event-card:hover .event-cover img{transform:scale(1.05)}
    .event-cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
    .event-cover-placeholder::before{content:'';position:absolute;inset:0;background:inherit}
    .event-cover-pattern{position:absolute;inset:0;opacity:.12;background-image:radial-gradient(circle,currentColor 1px,transparent 1px);background-size:20px 20px}

    /* Type accent bar */
    .event-accent{position:absolute;top:0;left:0;right:0;height:3px}
    .event-card.type-collab .event-accent{background:linear-gradient(90deg,var(--gold),#a07832)}
    .event-card.type-challenge .event-accent{background:linear-gradient(90deg,#5eead4,#2dd4bf)}
    .event-card.type-showcase .event-accent{background:linear-gradient(90deg,var(--info),#3b82f6)}

    /* Cover gradients for placeholder */
    .event-card.type-collab .event-cover-placeholder{background:linear-gradient(135deg,#1a160c,#2a1f08);color:var(--gold)}
    .event-card.type-challenge .event-cover-placeholder{background:linear-gradient(135deg,#0a1a1a,#0f2a24);color:#5eead4}
    .event-card.type-showcase .event-cover-placeholder{background:linear-gradient(135deg,#080e1a,#0f1828);color:var(--info)}

    .event-cover-icon{position:relative;z-index:1;opacity:.35}
    .event-cover-icon svg{width:52px;height:52px;stroke:currentColor;fill:none;stroke-width:1;stroke-linecap:round}

    .event-cover-badge{position:absolute;bottom:10px;left:12px;z-index:2}

    /* Card body */
    .event-body{padding:18px 20px;flex:1;display:flex;flex-direction:column;gap:10px}
    .event-type-badge{display:inline-flex;align-items:center;gap:5px;font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:3px 10px;border-radius:20px;width:fit-content}
    .event-type-badge.collab{color:var(--gold);background:var(--gold-faint);border:1px solid var(--gold-dim)}
    .event-type-badge.challenge{color:#5eead4;background:rgba(94,234,212,.08);border:1px solid rgba(94,234,212,.2)}
    .event-type-badge.showcase{color:var(--info);background:rgba(52,130,246,.08);border:1px solid rgba(52,130,246,.2)}
    .event-title{font-family:'Cormorant Garamond',serif;font-size:1.15rem;font-weight:300;color:var(--text-primary);line-height:1.3}
    .event-desc{font-family:'DM Mono',monospace;font-size:11px;color:var(--text-muted);letter-spacing:.03em;line-height:1.7;flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}

    /* Event meta row */
    .event-meta-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:12px 0;border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle)}
    .event-meta-item{display:flex;align-items:center;gap:7px}
    .event-meta-item svg{width:11px;height:11px;stroke:var(--text-dim);fill:none;stroke-width:2;stroke-linecap:round;flex-shrink:0}
    .event-meta-label{font-family:'DM Mono',monospace;font-size:10px;color:var(--text-dim);letter-spacing:.04em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
    .event-meta-label span{color:var(--text-secondary)}

    /* Event footer */
    .event-footer{display:flex;align-items:center;justify-content:space-between;gap:10px}
    .event-participants-count{display:flex;align-items:center;gap:6px;font-family:'DM Mono',monospace;font-size:11px;color:var(--text-dim);letter-spacing:.05em}
    .event-participants-count svg{width:13px;height:13px;stroke:var(--text-dim);fill:none;stroke-width:2;stroke-linecap:round}
    .event-creator{font-family:'DM Mono',monospace;font-size:10px;color:var(--text-dim);letter-spacing:.04em}

    /* Join button states */
    .join-btn{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase;border:none;border-radius:8px;padding:8px 16px;cursor:pointer;transition:all .2s;white-space:nowrap;flex-shrink:0}
    .join-btn.not-joined{background:transparent;color:var(--gold);border:1px solid var(--gold-dim)}
    .join-btn.not-joined:hover{background:var(--gold-faint);border-color:var(--gold)}
    .join-btn.joined{background:rgba(52,199,89,.1);color:var(--success);border:1px solid rgba(52,199,89,.25);cursor:default}
    .join-btn.loading{opacity:.6;cursor:not-allowed}

    /* ══ ACTIVITY LIST ══ */
    .activity-list{display:flex;flex-direction:column;gap:10px}
    .activity-item{display:flex;align-items:center;gap:16px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:12px;padding:16px 20px;transition:border-color .2s}
    .activity-item:hover{border-color:var(--border-medium)}
    .activity-type-icon{width:36px;height:36px;border-radius:8px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
    .activity-type-icon.music{background:var(--gold-faint);border:1px solid var(--gold-dim)}
    .activity-type-icon.vocals{background:rgba(94,234,212,.08);border:1px solid rgba(94,234,212,.2)}
    .activity-type-icon.lyrics{background:rgba(52,130,246,.08);border:1px solid rgba(52,130,246,.2)}
    .activity-type-icon.mix{background:rgba(175,82,222,.08);border:1px solid rgba(175,82,222,.2)}
    .activity-type-icon svg{width:16px;height:16px;fill:none;stroke-width:1.5;stroke-linecap:round}
    .activity-type-icon.music svg{stroke:var(--gold)}
    .activity-type-icon.vocals svg{stroke:#5eead4}
    .activity-type-icon.lyrics svg{stroke:var(--info)}
    .activity-type-icon.mix svg{stroke:#af52de}
    .activity-info{flex:1;min-width:0}
    .activity-prompt{font-family:'Syne',sans-serif;font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:3px}
    .activity-sub{font-family:'DM Mono',monospace;font-size:10px;color:var(--text-dim);letter-spacing:.06em}
    .activity-actions{display:flex;gap:8px;flex-shrink:0}

    /* ══ BUTTONS ══ */
    .btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:'DM Mono',monospace;font-size:12px;letter-spacing:.08em;text-transform:uppercase;border:none;border-radius:10px;padding:13px 24px;cursor:pointer;transition:all .2s;white-space:nowrap;text-decoration:none}
    .btn-primary{background:var(--gold);color:#0a0905;font-weight:600}
    .btn-primary:hover{background:#d4b560;box-shadow:0 8px 24px rgba(201,168,76,.3);transform:translateY(-1px)}
    .btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border-subtle)}
    .btn-ghost:hover{border-color:var(--border-medium);color:var(--text-primary);background:var(--bg-hover)}
    .btn-gold-outline{background:transparent;color:var(--gold);border:1px solid var(--gold-dim)}
    .btn-gold-outline:hover{background:var(--gold-faint);border-color:var(--gold)}
    .btn-sm{padding:8px 16px;font-size:11px}
    .btn svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round}

    /* ══ MODAL ══ */
    .modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(10px);z-index:9000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s ease;padding:20px}
    .modal-overlay.open{opacity:1;pointer-events:all}
    .modal{background:var(--bg-panel);border:1px solid var(--border-medium);border-radius:24px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;transform:translateY(20px) scale(.97);transition:transform .3s ease;box-shadow:0 40px 100px rgba(0,0,0,.7)}
    .modal-overlay.open .modal{transform:translateY(0) scale(1)}

    /* Modal header */
    .modal-header{padding:32px 36px 0;display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
    .modal-title-block{}
    .modal-eyebrow{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.16em;color:var(--gold);text-transform:uppercase;margin-bottom:6px}
    .modal-title{font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:300;color:var(--text-primary);letter-spacing:-.01em}
    .modal-close{width:32px;height:32px;border-radius:8px;background:var(--bg-deep);border:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .18s;flex-shrink:0;margin-top:4px}
    .modal-close:hover{background:var(--bg-hover);border-color:var(--border-medium)}
    .modal-close svg{width:14px;height:14px;stroke:var(--text-muted);fill:none;stroke-width:2;stroke-linecap:round}

    /* Modal body */
    .modal-body{padding:28px 36px 36px}
    .form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
    .form-group{margin-bottom:20px}
    .form-group:last-child{margin-bottom:0}
    .form-label{display:flex;align-items:center;gap:7px;font-family:'DM Mono',monospace;font-size:11px;letter-spacing:.1em;color:var(--text-muted);text-transform:uppercase;margin-bottom:8px}
    .form-label svg{width:11px;height:11px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;opacity:.7}
    .form-label .required{color:var(--gold);font-size:13px;line-height:1}
    .form-input,.form-select,.form-textarea{width:100%;background:var(--bg-deep);border:1px solid var(--border-subtle);border-radius:10px;padding:12px 16px;color:var(--text-primary);font-family:'Syne',sans-serif;font-size:14px;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}
    .form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--gold-dim);box-shadow:0 0 0 3px var(--gold-faint)}
    .form-input::placeholder{color:var(--text-dim)}
    .form-textarea{resize:vertical;min-height:90px;line-height:1.6}
    .form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238a8070' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px;cursor:pointer}

    /* Image upload */
    .image-upload-zone{width:100%;border:2px dashed var(--border-subtle);border-radius:12px;padding:28px 20px;text-align:center;cursor:pointer;transition:all .2s;position:relative;overflow:hidden;background:var(--bg-deep)}
    .image-upload-zone:hover{border-color:var(--gold-dim);background:var(--gold-faint)}
    .image-upload-zone.has-image{border-style:solid;border-color:var(--gold-dim);padding:0}
    .image-upload-zone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;z-index:2}
    .image-upload-icon{width:44px;height:44px;border-radius:10px;background:rgba(201,168,76,.1);border:1px solid var(--gold-dim);display:flex;align-items:center;justify-content:center;margin:0 auto 12px}
    .image-upload-icon svg{width:20px;height:20px;stroke:var(--gold);fill:none;stroke-width:1.5;stroke-linecap:round}
    .image-upload-text{font-family:'DM Mono',monospace;font-size:12px;color:var(--text-muted);letter-spacing:.06em;margin-bottom:4px}
    .image-upload-sub{font-family:'DM Mono',monospace;font-size:10px;color:var(--text-dim);letter-spacing:.04em}
    .image-preview{width:100%;height:180px;object-fit:cover;border-radius:10px;display:none}
    .image-preview.visible{display:block}
    .image-preview-remove{position:absolute;top:10px;right:10px;z-index:3;width:28px;height:28px;background:rgba(0,0,0,.7);border:1px solid rgba(255,255,255,.15);border-radius:6px;display:none;align-items:center;justify-content:center;cursor:pointer;transition:all .18s}
    .image-preview-remove.visible{display:flex}
    .image-preview-remove:hover{background:rgba(255,69,58,.7)}
    .image-preview-remove svg{width:12px;height:12px;stroke:white;fill:none;stroke-width:2;stroke-linecap:round}

    /* Form divider */
    .form-section-divider{height:1px;background:var(--border-subtle);margin:24px 0;position:relative}
    .form-section-divider span{position:absolute;top:50%;left:0;transform:translateY(-50%);font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.12em;color:var(--text-dim);text-transform:uppercase;background:var(--bg-panel);padding-right:12px}

    /* Modal footer */
    .modal-footer{display:flex;gap:12px;justify-content:flex-end;padding:20px 36px 28px;border-top:1px solid var(--border-subtle)}

    /* ══ TOAST ══ */
    .status-toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(12px);background:var(--bg-panel);border:1px solid var(--border-medium);border-radius:12px;padding:14px 24px;font-family:'DM Mono',monospace;font-size:12px;color:var(--text-primary);letter-spacing:.06em;box-shadow:0 16px 48px rgba(0,0,0,.5);opacity:0;transition:all .3s;z-index:9999;pointer-events:none;white-space:nowrap}
    .status-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
    .status-toast.success{border-color:var(--success);color:var(--success)}
    .status-toast.error{border-color:var(--error);color:var(--error)}

    /* ══ RESPONSIVE ══ */
    @media(max-width:1024px){.stat-grid{grid-template-columns:repeat(2,1fr)}.events-grid{grid-template-columns:repeat(2,1fr)}}
    @media(max-width:860px){.gnav-links{display:none}.gnav-hamburger{display:flex}.gnav-status{display:none}.dash-wrap{padding:32px 20px}.dash-greeting-title{font-size:2.2rem}.featured-banner{padding:32px 24px}.featured-title{font-size:1.8rem}.form-row{grid-template-columns:1fr}}
    @media(max-width:600px){.stat-grid{grid-template-columns:1fr 1fr}.events-grid{grid-template-columns:1fr}.modal-header,.modal-body,.modal-footer{padding-left:20px;padding-right:20px}}
    @media(max-width:480px){.global-nav{padding:0 16px}.gnav-username{display:none}}

    /* ══ LIBRARY ══ */
    /* ══ PAGE ══ */
    body { padding-top: 58px; background: var(--bg-deep); }
    .lib-wrap { max-width: 1200px; margin: 0 auto; padding: 48px 40px; }
    /* ── Hero ── */
    .lib-hero {
      display: flex; align-items: flex-end;
      justify-content: space-between;
      margin-bottom: 40px;
      padding-bottom: 28px;
      border-bottom: 1px solid var(--border-subtle);
      flex-wrap: wrap; gap: 20px;
    }
    .lib-title-eyebrow {
      font-family: 'DM Mono', monospace; font-size: 10px;
      letter-spacing: .18em; color: var(--gold);
      text-transform: uppercase; margin-bottom: 6px;
    }
    .lib-title {
      font-family: 'Cormorant Garamond', serif;
      font-size: 2.6rem; font-weight: 300;
      color: var(--text-primary); letter-spacing: -.02em; line-height: 1.05;
    }
    .lib-subtitle {
      font-family: 'DM Mono', monospace; font-size: 11px;
      color: var(--text-muted); letter-spacing: .04em; margin-top: 6px;
    }
    /* ── Search & Filter bar ── */
    .lib-controls {
      display: flex; align-items: center;
      gap: 12px; margin-bottom: 32px;
      flex-wrap: wrap;
    }
    .lib-search-wrap {
      display: flex; align-items: center;
      background: var(--bg-card);
      border: 1px solid var(--border-subtle);
      border-radius: 10px;
      padding: 0 14px;
      flex: 1; min-width: 200px; max-width: 360px;
      gap: 10px; transition: border-color .2s;
    }
    .lib-search-wrap:focus-within { border-color: var(--gold-dim); }
    .lib-search-wrap svg {
      width: 14px; height: 14px; stroke: var(--text-dim);
      fill: none; stroke-width: 2; stroke-linecap: round; flex-shrink: 0;
    }
    .lib-search {
      flex: 1; background: none; border: none;
      font-family: 'Syne', sans-serif; font-size: 13px;
      color: var(--text-primary); padding: 11px 0;
    }
    .lib-search:focus { outline: none; }
    .lib-search::placeholder { color: var(--text-dim); }
    .filter-tabs {
      display: flex; align-items: center;
      background: var(--bg-card);
      border: 1px solid var(--border-subtle);
      border-radius: 10px; padding: 4px; gap: 2px;
    }
    .filter-tab {
      display: flex; align-items: center; gap: 5px;
      padding: 6px 14px; border-radius: 7px;
      font-family: 'DM Mono', monospace; font-size: 11px;
      letter-spacing: .06em; color: var(--text-muted);
      text-decoration: none; transition: all .18s;
      white-space: nowrap; border: 1px solid transparent;
    }
    .filter-tab:hover { color: var(--text-primary); background: var(--bg-hover); }
    .filter-tab.active { color: var(--gold); background: var(--gold-faint); border-color: var(--gold-dim); }
    .filter-tab .count {
      font-size: 9px; background: var(--bg-deep);
      border: 1px solid var(--border-subtle);
      border-radius: 10px; padding: 1px 6px;
      color: var(--text-dim);
    }
    .filter-tab.active .count { background: var(--gold-faint); color: var(--gold); border-color: var(--gold-dim); }

    /* ── View toggle ── */
    .view-toggle {
      display: flex; align-items: center;
      gap: 4px; background: var(--bg-card);
      border: 1px solid var(--border-subtle);
      border-radius: 8px; padding: 4px;
    }
    .view-btn {
      width: 30px; height: 30px; border-radius: 5px;
      background: none; border: none; cursor: pointer;
      display: flex; align-items: center; justify-content: center;
      color: var(--text-dim); transition: all .18s;
    }
    .view-btn:hover { color: var(--text-primary); }
    .view-btn.active { background: var(--gold-faint); color: var(--gold); }
    .view-btn svg { width: 14px; height: 14px; stroke: currentColor; fill: none; stroke-width: 1.8; }

    /* ── Grid view ── */
    .lib-grid {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
      gap: 20px;
    }
    .lib-card {
      background: var(--bg-card);
      border: 1px solid var(--border-subtle);
      border-radius: 16px; overflow: hidden;
      transition: border-color .2s, transform .2s;
    }
    .lib-card:hover { border-color: var(--border-medium); transform: translateY(-2px); }
    .lib-card-cover {
      height: 120px;
      display: flex; align-items: center; justify-content: center;
      position: relative; overflow: hidden;
    }
    .lib-card-cover-waves {
      display: flex; align-items: center; gap: 3px; height: 60px;
    }
    .cover-wave-bar {
      width: 3px; border-radius: 2px;
    }
    .lib-card-body { padding: 20px; }
    .lib-card-type {
      display: inline-flex; align-items: center; gap: 4px;
      font-family: 'DM Mono', monospace; font-size: 9px;
      letter-spacing: .1em; text-transform: uppercase;
      padding: 2px 8px; border-radius: 20px;
      margin-bottom: 10px;
    }
    .lib-card-type.music   { color: var(--gold);  background: var(--gold-faint);  border: 1px solid var(--gold-dim); }
    .lib-card-type.vocals  { color: #5eead4; background: rgba(94,234,212,.08); border: 1px solid rgba(94,234,212,.2); }
    .lib-card-type.lyrics  { color: var(--info);  background: rgba(52,130,246,.08); border: 1px solid rgba(52,130,246,.2); }
    .lib-card-type.mix     { color: #af52de; background: rgba(175,82,222,.08);  border: 1px solid rgba(175,82,222,.2); }
    .lib-card-title {
      font-family: 'Cormorant Garamond', serif;
      font-size: 1.05rem; font-weight: 300;
      color: var(--text-primary); margin-bottom: 6px;
      line-height: 1.4;
      display: -webkit-box; -webkit-line-clamp: 2;
      -webkit-box-orient: vertical; overflow: hidden;
    }
    .lib-card-meta {
      font-family: 'DM Mono', monospace; font-size: 10px;
      color: var(--text-dim); letter-spacing: .06em;
      margin-bottom: 16px;
    }
    .lib-card-actions {
      display: flex; gap: 8px; flex-wrap: wrap;
    }

    /* ── List view ── */
    .lib-list { display: flex; flex-direction: column; gap: 8px; }
    .lib-list-item {
      display: flex; align-items: center; gap: 16px;
      background: var(--bg-card);
      border: 1px solid var(--border-subtle);
      border-radius: 12px; padding: 16px 20px;
      transition: border-color .2s;
    }
    .lib-list-item:hover { border-color: var(--border-medium); }
    .lib-list-icon {
      width: 40px; height: 40px; border-radius: 10px;
      flex-shrink: 0; display: flex; align-items: center; justify-content: center;
    }
    .lib-list-icon svg { width: 18px; height: 18px; fill: none; stroke-width: 1.5; stroke-linecap: round; }
    .lib-list-icon.music  { background: var(--gold-faint); border: 1px solid var(--gold-dim); }
    .lib-list-icon.music svg  { stroke: var(--gold); }
    .lib-list-icon.vocals { background: rgba(94,234,212,.08); border: 1px solid rgba(94,234,212,.2); }
    .lib-list-icon.vocals svg { stroke: #5eead4; }
    .lib-list-icon.lyrics { background: rgba(52,130,246,.08); border: 1px solid rgba(52,130,246,.2); }
    .lib-list-icon.lyrics svg { stroke: var(--info); }
    .lib-list-icon.mix    { background: rgba(175,82,222,.08); border: 1px solid rgba(175,82,222,.2); }
    .lib-list-icon.mix svg    { stroke: #af52de; }
    .lib-list-info { flex: 1; min-width: 0; }
    .lib-list-title {
      font-family: 'Syne', sans-serif; font-size: 13px; font-weight: 500;
      color: var(--text-primary); white-space: nowrap;
      overflow: hidden; text-overflow: ellipsis; margin-bottom: 3px;
    }
    .lib-list-meta {
      font-family: 'DM Mono', monospace; font-size: 10px;
      color: var(--text-dim); letter-spacing: .06em;
    }
    .lib-list-actions { display: flex; gap: 8px; flex-shrink: 0; }

    /* ── Empty state ── */
    .lib-empty {
      text-align: center; padding: 80px 40px;
      border: 2px dashed var(--border-subtle);
      border-radius: 20px;
    }
    .lib-empty-icon {
      width: 64px; height: 64px; border-radius: 16px;
      background: var(--bg-card); border: 1px solid var(--border-medium);
      display: flex; align-items: center; justify-content: center;
      margin: 0 auto 20px;
    }
    .lib-empty-icon svg { width: 28px; height: 28px; stroke: var(--text-dim); fill: none; stroke-width: 1.5; }
    .lib-empty-title {
      font-family: 'Cormorant Garamond', serif;
      font-size: 1.5rem; font-weight: 300; color: var(--text-secondary);
      margin-bottom: 8px;
    }
    .lib-empty-desc {
      font-family: 'DM Mono', monospace; font-size: 11px;
      color: var(--text-dim); letter-spacing: .05em;
      margin-bottom: 24px;
    }

    /* ── Share modal ── */
    .modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(8px);z-index:9000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s}
    .modal-overlay.open{opacity:1;pointer-events:all}
    .modal{background:var(--bg-panel);border:1px solid var(--border-medium);border-radius:20px;padding:40px;width:100%;max-width:480px;transform:translateY(16px) scale(.97);transition:transform .25s;box-shadow:0 32px 80px rgba(0,0,0,.6)}
    .modal-overlay.open .modal{transform:translateY(0) scale(1)}
    .modal-title{font-family:'Cormorant Garamond',serif;font-size:1.6rem;font-weight:300;color:var(--text-primary);margin-bottom:8px}
    .modal-sub{font-family:'DM Mono',monospace;font-size:11px;color:var(--text-muted);letter-spacing:.05em;margin-bottom:24px}
    .form-group{margin-bottom:16px}
    .form-label{display:block;font-family:'DM Mono',monospace;font-size:11px;letter-spacing:.1em;color:var(--text-muted);text-transform:uppercase;margin-bottom:8px}
    .form-input,.form-textarea{width:100%;background:var(--bg-deep);border:1px solid var(--border-subtle);border-radius:10px;padding:12px 16px;color:var(--text-primary);font-family:'Syne',sans-serif;font-size:14px;box-sizing:border-box;transition:border-color .2s}
    .form-input:focus,.form-textarea:focus{outline:none;border-color:var(--gold-dim);box-shadow:0 0 0 3px var(--gold-faint)}
    .form-textarea{resize:vertical;min-height:70px;line-height:1.6}
    .modal-footer{display:flex;gap:12px;margin-top:24px;justify-content:flex-end}

    /* Shared buttons */
    .btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;font-family:'DM Mono',monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase;border:none;border-radius:9px;padding:10px 20px;cursor:pointer;transition:all .2s;white-space:nowrap;text-decoration:none}
    .btn-primary{background:var(--gold);color:#0a0905;font-weight:600}
    .btn-primary:hover{background:#d4b560;box-shadow:0 6px 20px rgba(201,168,76,.3);transform:translateY(-1px)}
    .btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border-subtle)}
    .btn-ghost:hover{border-color:var(--border-medium);color:var(--text-primary);background:var(--bg-hover)}
    .btn-gold-outline{background:transparent;color:var(--gold);border:1px solid var(--gold-dim)}
    .btn-gold-outline:hover{background:var(--gold-faint)}
    .btn-danger{background:transparent;color:var(--error);border:1px solid rgba(255,69,58,.25)}
    .btn-danger:hover{background:rgba(255,69,58,.08)}
    .btn-sm{padding:7px 14px;font-size:10px}
    .btn svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round}
    .status-toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(12px);background:var(--bg-panel);border:1px solid var(--border-medium);border-radius:10px;padding:12px 22px;font-family:'DM Mono',monospace;font-size:11px;color:var(--text-primary);letter-spacing:.06em;box-shadow:0 12px 40px rgba(0,0,0,.5);opacity:0;transition:all .3s;z-index:9999;pointer-events:none}
    .status-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
    .status-toast.success{border-color:var(--success);color:var(--success)}
    .status-toast.error{border-color:var(--error);color:var(--error)}

    @media (max-width:860px){.gnav-links{display:none}.gnav-hamburger{display:flex}.gnav-status{display:none}.lib-wrap{padding:32px 20px}.filter-tabs{display:grid;grid-template-columns:repeat(3,1fr);width:100%}}
    @media (max-width:480px){.global-nav{padding:0 16px}.gnav-username{display:none}.lib-grid{grid-template-columns:1fr}}

    /* ── Lyrics card content ── */
    .card-lyrics-body {
        padding: 14px 18px;
        flex: 1;
        overflow: hidden;
}
    .card-lyrics-text {
        font-family: 'Cormorant Garamond', serif;
        font-size: 0.88rem;
        line-height: 1.7;
        color: var(--text-secondary);
        max-height: 120px;
        overflow-y: auto;
        white-space: pre-wrap;
  /* Fade bottom overflow */
        -webkit-mask-image: linear-gradient(to bottom, black 60%, transparent 100%);
        mask-image: linear-gradient(to bottom, black 60%, transparent 100%);
        scrollbar-width: thin;
        scrollbar-color: var(--border-medium) transparent;
}
    .card-lyrics-empty {
        font-family: 'DM Mono', monospace;
        font-size: 11px;
        color: var(--text-dim);
        letter-spacing: .05em;
        font-style: italic;
}

   /* ── Lyrics preview ── */
    .lib-card-lyrics {
      font-family: 'Cormorant Garamond', serif;
      font-size: 0.82rem;
      line-height: 1.7;
      color: var(--text-secondary, #aaa);
      margin: 8px 0 10px;
      max-height: 80px;
      overflow: hidden;
      position: relative;
      -webkit-mask-image: linear-gradient(to bottom, black 40%, transparent 100%);
              mask-image: linear-gradient(to bottom, black 40%, transparent 100%);
      white-space: pre-wrap;
      word-break: break-word;
    }

    /* ── Ensure buttons are always clickable ── */
    .lib-card { position: relative; }
    .lib-card-cover { pointer-events: none; }
    .lib-card-body  { position: relative; z-index: 2; }
    .lib-card-actions,
    .lib-list-actions { position: relative; z-index: 10; pointer-events: all; }
    .lib-card-actions button,
    .lib-card-actions a,
    .lib-list-actions button,
    .lib-list-actions a { pointer-events: all; cursor: pointer; }

     /* PUBLIC */
      /* ══ PAGE ══ */
    body { padding-top: 58px; background: var(--bg-deep); }
    .pub-wrap { max-width: 1200px; margin: 0 auto; padding: 48px 40px; }

    /* ── Hero ── */
    .pub-hero {
      display: flex; align-items: flex-end;
      justify-content: space-between;
      margin-bottom: 40px;
      padding-bottom: 28px;
      border-bottom: 1px solid var(--border-subtle);
      flex-wrap: wrap; gap: 20px;
    }
    .pub-title-eyebrow {
      font-family: 'DM Mono', monospace; font-size: 10px;
      letter-spacing: .18em; color: var(--info);
      text-transform: uppercase; margin-bottom: 6px;
    }
    .pub-title {
      font-family: 'Cormorant Garamond', serif;
      font-size: 2.6rem; font-weight: 300;
      color: var(--text-primary); letter-spacing: -.02em; line-height: 1.05;
    }
    .pub-subtitle {
      font-family: 'DM Mono', monospace; font-size: 11px;
      color: var(--text-muted); letter-spacing: .04em; margin-top: 6px;
    }
    .pub-live-badge {
      display: inline-flex; align-items: center; gap: 6px;
      font-family: 'DM Mono', monospace; font-size: 10px;
      letter-spacing: .08em; color: var(--success);
      border: 1px solid rgba(52,199,89,.25);
      background: rgba(52,199,89,.08);
      padding: 4px 12px; border-radius: 20px;
    }
    .pub-live-dot {
      width: 6px; height: 6px; border-radius: 50%;
      background: var(--success);
      box-shadow: 0 0 6px rgba(52,199,89,.5);
      animation: pulse 2s ease-in-out infinite;
    }

    /* ── Controls ── */
    .pub-controls {
      display: flex; align-items: center;
      gap: 12px; margin-bottom: 32px; flex-wrap: wrap;
    }
    .pub-search-wrap {
      display: flex; align-items: center;
      background: var(--bg-card); border: 1px solid var(--border-subtle);
      border-radius: 10px; padding: 0 14px;
      flex: 1; min-width: 200px; max-width: 340px;
      gap: 10px; transition: border-color .2s;
    }
    .pub-search-wrap:focus-within { border-color: rgba(52,130,246,.4); }
    .pub-search-wrap svg { width:14px;height:14px;stroke:var(--text-dim);fill:none;stroke-width:2;stroke-linecap:round;flex-shrink:0 }
    .pub-search {
      flex:1; background:none; border:none;
      font-family:'Syne',sans-serif; font-size:13px;
      color:var(--text-primary); padding:11px 0;
    }
    .pub-search:focus { outline:none; }
    .pub-search::placeholder { color:var(--text-dim); }

    .filter-tabs {
      display:flex; align-items:center;
      background:var(--bg-card); border:1px solid var(--border-subtle);
      border-radius:10px; padding:4px; gap:2px;
    }
    .filter-tab {
      display:flex; align-items:center; gap:5px;
      padding:6px 14px; border-radius:7px;
      font-family:'DM Mono',monospace; font-size:11px;
      letter-spacing:.06em; color:var(--text-muted);
      text-decoration:none; transition:all .18s;
      white-space:nowrap; border:1px solid transparent;
    }
    .filter-tab:hover { color:var(--text-primary); background:var(--bg-hover); }
    .filter-tab.active { color:var(--info); background:rgba(52,130,246,.08); border-color:rgba(52,130,246,.2); }
    .filter-tab .count {
      font-size:9px; background:var(--bg-deep);
      border:1px solid var(--border-subtle);
      border-radius:10px; padding:1px 6px; color:var(--text-dim);
    }
    .filter-tab.active .count { background:rgba(52,130,246,.1); color:var(--info); border-color:rgba(52,130,246,.2); }

    .sort-select {
      background:var(--bg-card); border:1px solid var(--border-subtle);
      border-radius:10px; padding:9px 14px;
      font-family:'DM Mono',monospace; font-size:11px;
      letter-spacing:.06em; color:var(--text-secondary);
      cursor:pointer; transition:border-color .2s;
    }
    .sort-select:focus { outline:none; border-color:rgba(52,130,246,.4); }

    /* ── Grid ── */
    .pub-grid {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
      gap: 22px;
    }

    /* ── Card ── */
    .pub-card {
      background: var(--bg-card);
      border: 1px solid var(--border-subtle);
      border-radius: 18px; overflow: hidden;
      transition: border-color .25s, transform .25s, box-shadow .25s;
      display: flex; flex-direction: column;
    }
    .pub-card:hover {
      border-color: var(--border-medium);
      transform: translateY(-3px);
      box-shadow: 0 12px 40px rgba(0,0,0,.3);
    }

    /* card cover */
    .pub-card-cover {
      height: 110px;
      display: flex; align-items: center; justify-content: center;
      position: relative; overflow: hidden; flex-shrink: 0;
    }
    .pub-card-cover-waves {
      display: flex; align-items: center; gap: 3px; height: 56px;
    }
    .cover-wave-bar { width: 3px; border-radius: 2px; }

    /* card user row */
    .pub-card-user {
      display: flex; align-items: center; gap: 10px;
      padding: 14px 18px 0;
    }
    .pub-card-avatar {
      width: 32px; height: 32px; border-radius: 50%; flex-shrink: 0;
      display: flex; align-items: center; justify-content: center;
      font-family: 'Syne', sans-serif; font-size: 12px;
      font-weight: 700; color: #0a0905;
      background: linear-gradient(135deg, var(--gold), #7a5c1e);
    }
    .pub-card-avatar img { width:100%; height:100%; border-radius:50%; object-fit:cover; }
    .pub-card-user-name {
      font-family: 'Syne', sans-serif; font-size: 13px;
      font-weight: 600; color: var(--text-primary); flex: 1;
    }
    .pub-card-date {
      font-family: 'DM Mono', monospace; font-size: 10px;
      color: var(--text-dim); letter-spacing: .04em;
    }

    /* card body */
    .pub-card-body { padding: 14px 18px 0; flex: 1; }
    .pub-card-type {
      display: inline-flex; align-items: center;
      font-family: 'DM Mono', monospace; font-size: 9px;
      letter-spacing: .1em; text-transform: uppercase;
      padding: 2px 8px; border-radius: 20px;
      margin-bottom: 8px;
    }
    .pub-card-type.music  { color:var(--gold);  background:var(--gold-faint);  border:1px solid var(--gold-dim); }
    .pub-card-type.vocals { color:#5eead4; background:rgba(94,234,212,.08); border:1px solid rgba(94,234,212,.2); }
    .pub-card-type.lyrics { color:var(--info);  background:rgba(52,130,246,.08); border:1px solid rgba(52,130,246,.2); }
    .pub-card-type.mix    { color:#af52de; background:rgba(175,82,222,.08);  border:1px solid rgba(175,82,222,.2); }

    .pub-card-caption {
      font-family: 'Cormorant Garamond', serif;
      font-size: 1.0rem; font-weight: 400;
      color: var(--text-primary); line-height: 1.5;
      margin-bottom: 6px;
      display: -webkit-box; -webkit-line-clamp: 2;
      -webkit-box-orient: vertical; overflow: hidden;
    }
    .pub-card-tags {
      font-family: 'DM Mono', monospace; font-size: 10px;
      color: var(--text-dim); letter-spacing: .04em;
      margin-bottom: 10px;
    }

    /* audio player */
    .pub-card-audio {
      padding: 10px 18px 0;
    }
    .pub-card-audio audio {
      width: 100%; height: 36px;
      border-radius: 8px;
      accent-color: var(--info);
    }

    /* card footer */
    .pub-card-footer {
      display: flex; align-items: center; gap: 10px;
      padding: 12px 18px 16px;
      border-top: 1px solid var(--border-subtle);
      margin-top: 12px;
    }
    .btn-like {
      display: inline-flex; align-items: center; gap: 5px;
      background: none; border: 1px solid var(--border-subtle);
      border-radius: 8px; padding: 6px 12px;
      font-family: 'DM Mono', monospace; font-size: 11px;
      color: var(--text-muted); cursor: pointer;
      transition: all .2s; letter-spacing: .04em;
    }
    .btn-like:hover { border-color: rgba(255,59,48,.4); color: #ff3b30; background: rgba(255,59,48,.06); }
    .btn-like.liked { border-color: rgba(255,59,48,.4); color: #ff3b30; background: rgba(255,59,48,.08); }
    .pub-card-stat {
      display: inline-flex; align-items: center; gap: 4px;
      font-family: 'DM Mono', monospace; font-size: 10px;
      color: var(--text-dim); letter-spacing: .04em;
    }
    .pub-card-stat svg { width:11px;height:11px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round; }

    /* ── Empty state ── */
    .pub-empty {
      text-align: center; padding: 80px 40px;
      border: 2px dashed var(--border-subtle);
      border-radius: 20px; grid-column: 1/-1;
    }
    .pub-empty-icon {
      width:64px;height:64px;border-radius:16px;
      background:var(--bg-card);border:1px solid var(--border-medium);
      display:flex;align-items:center;justify-content:center;
      margin:0 auto 20px;
    }
    .pub-empty-icon svg { width:28px;height:28px;stroke:var(--text-dim);fill:none;stroke-width:1.5; }
    .pub-empty-title {
      font-family:'Cormorant Garamond',serif;
      font-size:1.5rem;font-weight:300;color:var(--text-secondary);margin-bottom:8px;
    }
    .pub-empty-desc {
      font-family:'DM Mono',monospace;font-size:11px;
      color:var(--text-dim);letter-spacing:.05em;margin-bottom:24px;
    }

    /* ── Pagination ── */
    .pub-pagination {
      display: flex; align-items: center; justify-content: center;
      gap: 6px; margin-top: 48px; flex-wrap: wrap;
    }
    .pub-page-btn {
      display: inline-flex; align-items: center; justify-content: center;
      min-width: 36px; height: 36px; border-radius: 8px;
      font-family: 'DM Mono', monospace; font-size: 12px;
      text-decoration: none; transition: all .18s;
      border: 1px solid var(--border-subtle);
      color: var(--text-secondary); background: var(--bg-card);
      padding: 0 10px;
    }
    .pub-page-btn:hover { border-color: var(--border-medium); color: var(--text-primary); }
    .pub-page-btn.active { background: rgba(52,130,246,.12); border-color: rgba(52,130,246,.3); color: var(--info); }
    .pub-page-btn.disabled { opacity: .35; pointer-events: none; }

    /* Shared buttons */
    .btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;font-family:'DM Mono',monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase;border:none;border-radius:9px;padding:10px 20px;cursor:pointer;transition:all .2s;white-space:nowrap;text-decoration:none}
    .btn-primary{background:var(--gold);color:#0a0905;font-weight:600}
    .btn-primary:hover{background:#d4b560;box-shadow:0 6px 20px rgba(201,168,76,.3);transform:translateY(-1px)}
    .btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border-subtle)}
    .btn-ghost:hover{border-color:var(--border-medium);color:var(--text-primary);background:var(--bg-hover)}
    .btn svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round}
    .status-toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(12px);background:var(--bg-panel);border:1px solid var(--border-medium);border-radius:10px;padding:12px 22px;font-family:'DM Mono',monospace;font-size:11px;color:var(--text-primary);letter-spacing:.06em;box-shadow:0 12px 40px rgba(0,0,0,.5);opacity:0;transition:all .3s;z-index:9999;pointer-events:none}
    .status-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
    .status-toast.success{border-color:var(--success);color:var(--success)}
    .status-toast.error{border-color:var(--error);color:var(--error)}

    /* Mini player */
    #mini-player{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(80px);background:var(--bg-panel);border:1px solid rgba(52,130,246,.35);border-radius:14px;padding:16px 24px;display:flex;align-items:center;gap:16px;box-shadow:0 16px 48px rgba(0,0,0,.5);z-index:4000;min-width:320px;transition:transform .3s ease;pointer-events:none;opacity:0}

    @keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.5} }
    @media(max-width:860px){.gnav-links{display:none}.gnav-hamburger{display:flex}.gnav-status{display:none}.pub-wrap{padding:32px 20px}.filter-tabs{display:grid;grid-template-columns:repeat(3,1fr);width:100%}}
    @media(max-width:480px){.global-nav{padding:0 16px}.gnav-username{display:none}.pub-grid{grid-template-columns:1fr}}

    /* DAW */
    /* ── DAW Shell ── */
  .daw-shell {
    display: grid;
    grid-template-rows: var(--daw-transport-h) 1fr;
    height: calc(100vh - var(--daw-header-h));
    overflow: hidden;
  }

  /* ══════════════════════════════
     TRANSPORT BAR
  ══════════════════════════════ */
  .daw-transport {
    background: var(--bg-panel);
    border-bottom: 1px solid var(--border-subtle);
    display: flex;
    align-items: center;
    gap: 0;
    padding: 0;
    z-index: 100;
    flex-shrink: 0;
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: none;
  }
  .daw-transport::-webkit-scrollbar { display: none; }

  .transport-section {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 0 14px;
    height: 100%;
    flex-shrink: 0;
  }
  .transport-section + .transport-section {
    border-left: 1px solid var(--border-subtle);
  }

  .t-btn {
    width: 34px; height: 34px;
    border-radius: 8px;
    border: 1px solid var(--border-subtle);
    background: var(--bg-card);
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: all 0.18s;
    flex-shrink: 0;
    -webkit-tap-highlight-color: transparent;
  }
  .t-btn svg { width: 14px; height: 14px; fill: none; stroke: var(--text-muted); stroke-width: 2; stroke-linecap: round; }
  .t-btn:hover, .t-btn:active { border-color: var(--teal-dim); background: var(--teal-faint); }
  .t-btn:hover svg, .t-btn:active svg { stroke: var(--teal); }
  .t-btn.play-btn.playing { border-color: var(--teal-dim); background: var(--teal-faint); }
  .t-btn.play-btn.playing svg { stroke: var(--teal); }
  .t-btn.rec-btn { border-color: rgba(255,69,58,0.25); }
  .t-btn.rec-btn svg { stroke: rgba(255,69,58,0.6); fill: rgba(255,69,58,0.15); }
  .t-btn.rec-btn.recording { border-color: rgba(255,69,58,0.5); background: rgba(255,69,58,0.1); animation: recPulse 1s ease-in-out infinite; }
  .t-btn.rec-btn.recording svg { stroke: var(--error); fill: var(--error); }
  @keyframes recPulse { 0%,100%{opacity:1} 50%{opacity:0.5} }

  .t-time {
    font-family: 'DM Mono', monospace;
    font-size: 1.15rem;
    letter-spacing: 0.06em;
    color: var(--teal);
    background: var(--bg-deep);
    border: 1px solid var(--border-subtle);
    border-radius: 8px;
    padding: 5px 10px;
    min-width: 96px;
    text-align: center;
    user-select: none;
  }
  .t-bpm-wrap { display: flex; align-items: center; gap: 6px; }
  .t-bpm-label {
    font-family: 'DM Mono', monospace;
    font-size: 9px; letter-spacing: 0.1em;
    color: var(--text-dim); text-transform: uppercase;
  }
  .t-bpm-input {
    width: 50px; text-align: center;
    background: var(--bg-deep);
    border: 1px solid var(--border-subtle);
    border-radius: 7px;
    font-family: 'DM Mono', monospace;
    font-size: 14px; color: var(--text-primary);
    padding: 5px 6px;
  }
  .t-bpm-input:focus { outline: none; border-color: var(--teal-dim); }
  .t-sig {
    font-family: 'DM Mono', monospace;
    font-size: 13px; color: var(--text-muted);
    background: var(--bg-deep);
    border: 1px solid var(--border-subtle);
    border-radius: 7px;
    padding: 5px 10px;
  }
  .t-master-wrap { display: flex; align-items: center; gap: 8px; }
  .t-master-label {
    font-family: 'DM Mono', monospace;
    font-size: 9px; letter-spacing: 0.1em;
    color: var(--text-dim); text-transform: uppercase;
    white-space: nowrap;
  }
  .t-master-slider {
    width: 70px; -webkit-appearance: none;
    height: 3px; background: var(--border-subtle);
    border-radius: 2px; cursor: pointer;
  }
  .t-master-slider::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 14px; height: 14px; border-radius: 50%;
    background: var(--teal); cursor: pointer;
    box-shadow: 0 0 6px var(--teal-dim);
  }
  .t-master-val {
    font-family: 'DM Mono', monospace;
    font-size: 11px; color: var(--teal); min-width: 24px;
  }
  .t-project-name {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1rem; font-weight: 300;
    color: var(--text-secondary);
    background: none; border: none;
    border-bottom: 1px solid transparent;
    transition: border-color 0.2s;
    padding: 2px 4px; min-width: 100px; max-width: 160px;
  }
  .t-project-name:focus { outline: none; border-bottom-color: var(--teal-dim); color: var(--text-primary); }
  .t-save-btn {
    display: flex; align-items: center; gap: 6px;
    padding: 7px 12px; border-radius: 8px;
    font-family: 'DM Mono', monospace;
    font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase;
    cursor: pointer; transition: all 0.18s; white-space: nowrap;
    background: var(--teal-faint); color: var(--teal);
    border: 1px solid var(--teal-dim);
    -webkit-tap-highlight-color: transparent;
  }
  .t-save-btn:hover { background: rgba(94,234,212,0.14); }
  .t-save-btn svg { width: 12px; height: 12px; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; }
  .t-export-btn {
    display: flex; align-items: center; gap: 6px;
    padding: 7px 12px; border-radius: 8px;
    font-family: 'DM Mono', monospace;
    font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase;
    cursor: pointer; transition: all 0.18s; white-space: nowrap;
    background: var(--gold-faint); color: var(--gold);
    border: 1px solid var(--gold-dim);
    -webkit-tap-highlight-color: transparent;
  }
  .t-export-btn:hover { background: rgba(201,168,76,0.14); }
  .t-export-btn svg { width: 12px; height: 12px; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; }
  .zoom-controls { display: flex; align-items: center; gap: 4px; }
  .zoom-btn {
    width: 30px; height: 30px; border-radius: 6px;
    background: var(--bg-card); border: 1px solid var(--border-subtle);
    cursor: pointer; display: flex; align-items: center; justify-content: center;
    font-family: 'DM Mono', monospace; font-size: 16px;
    color: var(--text-muted); transition: all 0.15s; line-height: 1;
    -webkit-tap-highlight-color: transparent;
  }
  .zoom-btn:hover, .zoom-btn:active { border-color: var(--teal-dim); color: var(--teal); }
  .zoom-val {
    font-family: 'DM Mono', monospace; font-size: 10px;
    color: var(--text-dim); min-width: 30px; text-align: center;
  }

  /* ══════════════════════════════
     DAW BODY
  ══════════════════════════════ */
  .daw-body {
    display: grid;
    grid-template-columns: var(--daw-lib-w) 1fr var(--daw-mixer-w);
    overflow: hidden;
    height: 100%;
  }

  /* ══════════════════════════════
     LIBRARY SIDEBAR
  ══════════════════════════════ */
  .daw-library {
    background: var(--bg-panel);
    border-right: 1px solid var(--border-subtle);
    display: flex; flex-direction: column;
    overflow: hidden;
  }
  .daw-lib-header {
    padding: 16px 16px 12px;
    border-bottom: 1px solid var(--border-subtle);
    flex-shrink: 0;
  }
  .daw-lib-eyebrow {
    font-family: 'DM Mono', monospace;
    font-size: 9px; letter-spacing: 0.15em;
    color: var(--teal); text-transform: uppercase;
    margin-bottom: 4px;
  }
  .daw-lib-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.1rem; font-weight: 300;
    color: var(--text-primary);
  }
  .daw-lib-search {
    display: flex; align-items: center; gap: 8px;
    background: var(--bg-deep); border: 1px solid var(--border-subtle);
    border-radius: 8px; padding: 0 10px;
    margin: 10px 16px 0;
  }
  .daw-lib-search svg { width: 12px; height: 12px; stroke: var(--text-dim); fill: none; stroke-width: 2; flex-shrink: 0; }
  .daw-lib-search input {
    flex: 1; background: none; border: none;
    font-family: 'Syne', sans-serif; font-size: 12px;
    color: var(--text-primary); padding: 8px 0;
  }
  .daw-lib-search input:focus { outline: none; }
  .daw-lib-search input::placeholder { color: var(--text-dim); }
  .daw-lib-list { flex: 1; overflow-y: auto; padding: 8px 8px; }
  .daw-lib-item {
    display: flex; align-items: center; gap: 10px;
    padding: 8px 10px; border-radius: 8px;
    cursor: grab; transition: background 0.15s;
    border: 1px solid transparent;
    margin-bottom: 2px;
    user-select: none;
    -webkit-tap-highlight-color: transparent;
  }
  .daw-lib-item:hover, .daw-lib-item:active { background: var(--bg-hover); border-color: var(--border-subtle); }
  .daw-lib-item.dragging { background: var(--teal-faint); border-color: var(--teal-dim); opacity: 0.7; }
  .daw-lib-icon {
    width: 28px; height: 28px; border-radius: 6px;
    flex-shrink: 0; display: flex; align-items: center; justify-content: center;
  }
  .daw-lib-icon svg { width: 13px; height: 13px; fill: none; stroke-width: 1.5; stroke-linecap: round; }
  .daw-lib-icon.music  { background: var(--gold-faint); border: 1px solid var(--gold-dim); }
  .daw-lib-icon.music svg  { stroke: var(--gold); }
  .daw-lib-icon.vocals { background: rgba(94,234,212,.08); border: 1px solid rgba(94,234,212,.2); }
  .daw-lib-icon.vocals svg { stroke: var(--teal); }
  .daw-lib-icon.mix    { background: rgba(175,82,222,.08); border: 1px solid rgba(175,82,222,.2); }
  .daw-lib-icon.mix svg    { stroke: #af52de; }
  .daw-lib-info { flex: 1; min-width: 0; }
  .daw-lib-name {
    font-family: 'Syne', sans-serif; font-size: 11px;
    font-weight: 500; color: var(--text-secondary);
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  }
  .daw-lib-meta {
    font-family: 'DM Mono', monospace; font-size: 9px;
    color: var(--text-dim); letter-spacing: 0.04em; text-transform: uppercase;
  }
  .daw-lib-add-btn {
    width: 28px; height: 28px; border-radius: 6px;
    background: none; border: 1px solid var(--border-subtle);
    cursor: pointer; display: flex; align-items: center; justify-content: center;
    transition: all 0.15s; flex-shrink: 0; color: var(--text-dim);
    font-size: 18px; line-height: 1;
    -webkit-tap-highlight-color: transparent;
  }
  .daw-lib-add-btn:hover, .daw-lib-add-btn:active {
    background: var(--teal-faint); border-color: var(--teal-dim); color: var(--teal);
  }
  .daw-lib-section-label {
    font-family: 'DM Mono', monospace;
    font-size: 9px; letter-spacing: 0.14em; color: var(--text-dim);
    text-transform: uppercase; padding: 12px 10px 6px;
  }
  .daw-project-item {
    display: flex; align-items: center; gap: 8px;
    padding: 7px 10px; border-radius: 7px; cursor: pointer;
    transition: background 0.15s; margin-bottom: 2px;
    text-decoration: none;
  }
  .daw-project-item:hover { background: var(--bg-hover); }
  .daw-project-item svg { width: 12px; height: 12px; stroke: var(--text-dim); fill: none; stroke-width: 2; flex-shrink: 0; }
  .daw-project-name {
    font-family: 'Syne', sans-serif; font-size: 11px;
    color: var(--text-muted); white-space: nowrap;
    overflow: hidden; text-overflow: ellipsis; flex: 1;
  }
  .daw-project-date {
    font-family: 'DM Mono', monospace; font-size: 9px;
    color: var(--text-dim); flex-shrink: 0;
  }

  /* ══════════════════════════════
     ARRANGEMENT (CENTER)
  ══════════════════════════════ */
  .daw-arrangement {
    display: flex; flex-direction: column;
    overflow: hidden; background: var(--bg-deep);
    position: relative;
  }

  /* ── Ruler: fixed-height, scrolls horizontally in sync ── */
  .daw-ruler {
    height: var(--daw-ruler-h);
    background: var(--bg-panel);
    border-bottom: 1px solid var(--border-subtle);
    position: relative; flex-shrink: 0;
    overflow: hidden;           /* ← clips ruler to visible area */
  }
  /* ruler-canvas is wider than container — positioned via JS scroll */
  .ruler-canvas {
    position: absolute;
    left: 0; top: 0;
    height: 100%;
    display: block;
    /* width set by JS to match timeline min-width */
  }
  /* Playhead sits in ruler, tracks-wrap uses transform */
  .playhead {
    position: absolute; top: 0;
    height: calc(100vh); /* full page height */
    width: 2px; background: var(--teal);
    box-shadow: 0 0 8px var(--teal-dim);
    z-index: 50; pointer-events: none;
    left: 0;
    transform: translateX(0);
  }
  .playhead::before {
    content: '▼';
    position: absolute; top: 0; left: 50%;
    transform: translateX(-50%);
    font-size: 10px; color: var(--teal); line-height: 1;
  }

  /* ── Tracks scroll container ── */
  .daw-tracks-wrap {
    flex: 1;
    overflow: auto;       /* ← both axes scroll */
    position: relative;
    -webkit-overflow-scrolling: touch;
  }
  .daw-tracks-wrap::-webkit-scrollbar { width: 6px; height: 6px; }
  .daw-tracks-wrap::-webkit-scrollbar-thumb { background: var(--border-medium); border-radius: 3px; }

  /* ── Inner container: grows to fit all clips ── */
  .daw-tracks-inner {
    position: relative;
    min-height: 100%;
    /* min-width set dynamically by JS — at least --timeline-min */
    min-width: var(--timeline-min);
  }

  /* ── Track row ── */
  .daw-track {
    display: flex;          /* flex instead of grid for sticky head */
    height: var(--daw-track-h);
    border-bottom: 1px solid var(--border-subtle);
    transition: background 0.15s;
    position: relative;
  }
  .daw-track:hover { background: rgba(255,255,255,0.01); }
  .daw-track.drop-target { background: var(--teal-faint); }

  /* ── Track head: STICKY LEFT ── */
  .track-head {
    width: var(--track-head-w);
    min-width: var(--track-head-w);
    background: var(--bg-panel);
    border-right: 1px solid var(--border-subtle);
    display: flex; align-items: center; gap: 6px;
    padding: 0 10px;
    flex-shrink: 0;

    /* ✅ Sticky so it stays visible while lane scrolls */
    position: sticky;
    left: 0;
    z-index: 10;
  }
  .track-color-bar {
    width: 3px; height: 36px; border-radius: 2px; flex-shrink: 0;
  }
  .track-name-input {
    flex: 1; background: none; border: none;
    font-family: 'Syne', sans-serif; font-size: 11px;
    font-weight: 600; color: var(--text-secondary);
    min-width: 0; padding: 0;
  }
  .track-name-input:focus { outline: none; color: var(--text-primary); }
  .track-controls {
    display: flex; align-items: center; gap: 3px; flex-shrink: 0;
  }
  .track-ctrl-btn {
    width: 22px; height: 22px; border-radius: 5px;
    background: var(--bg-deep); border: 1px solid var(--border-subtle);
    cursor: pointer; display: flex; align-items: center; justify-content: center;
    font-family: 'DM Mono', monospace; font-size: 9px; font-weight: 700;
    letter-spacing: 0.04em; transition: all 0.15s;
    -webkit-tap-highlight-color: transparent;
  }
  .track-ctrl-btn.mute { color: var(--text-dim); }
  .track-ctrl-btn.mute.active { background: rgba(255,149,0,0.15); border-color: rgba(255,149,0,0.4); color: var(--warning); }
  .track-ctrl-btn.solo { color: var(--text-dim); }
  .track-ctrl-btn.solo.active { background: var(--teal-faint); border-color: var(--teal-dim); color: var(--teal); }
  .track-ctrl-btn.del { color: var(--text-dim); font-size: 14px; }
  .track-ctrl-btn.del:hover { background: rgba(255,69,58,0.1); border-color: rgba(255,69,58,0.3); color: var(--error); }
  .track-vol-mini {
    width: 40px; -webkit-appearance: none;
    height: 2px; background: var(--border-subtle);
    border-radius: 2px; cursor: pointer;
  }
  .track-vol-mini::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 10px; height: 10px; border-radius: 50%;
    background: var(--text-muted); cursor: pointer;
  }

  /* ── Track lane: FULL TIMELINE WIDTH ── */
  .track-lane {
    flex: 1;
    position: relative;
    overflow: visible;      /* ✅ clips extend beyond visible area */
    min-width: 0;
    background: repeating-linear-gradient(
      90deg,
      transparent,
      transparent calc(var(--beat-w, 40px) * 4 - 1px),
      var(--border-subtle) calc(var(--beat-w, 40px) * 4)
    );
    cursor: crosshair;
  }
  .track-lane::after {
    content: '';
    position: absolute; inset: 0;
    background: repeating-linear-gradient(
      90deg,
      transparent,
      transparent calc(var(--beat-w, 40px) - 1px),
      rgba(201,168,76,0.025) var(--beat-w, 40px)
    );
    pointer-events: none;
  }

  /* ── Clip ── */
  .clip {
    position: absolute; top: 5px; bottom: 5px;
    border-radius: 6px;
    display: flex; align-items: flex-start;
    padding: 4px 8px;
    overflow: hidden; cursor: move;
    border: 1px solid transparent;
    transition: border-color 0.15s, box-shadow 0.15s;
    user-select: none;
    min-width: 40px;
    touch-action: none;   /* ✅ enable touch drag */
  }
  .clip:hover { border-color: rgba(255,255,255,0.2); box-shadow: 0 4px 16px rgba(0,0,0,0.4); }
  .clip.selected { border-color: rgba(255,255,255,0.4) !important; box-shadow: 0 0 0 2px rgba(94,234,212,0.3); }
  .clip-label {
    position: relative; z-index: 2;
    font-family: 'DM Mono', monospace;
    font-size: 9px; letter-spacing: 0.06em;
    font-weight: 500; white-space: nowrap;
    overflow: hidden; text-overflow: ellipsis;
    color: rgba(255,255,255,0.9);
    text-shadow: 0 1px 3px rgba(0,0,0,0.8);
    line-height: 1.2;
    max-width: 100%;
    pointer-events: none;
  }
  .clip-resize-handle {
    position: absolute; right: 0; top: 0; bottom: 0;
    width: 10px; cursor: ew-resize;
    background: transparent; z-index: 3;
    touch-action: none;
  }

  .track-lane-hint {
    position: absolute; inset: 0;
    display: flex; align-items: center; justify-content: center;
    font-family: 'DM Mono', monospace; font-size: 10px;
    color: var(--text-dim); letter-spacing: 0.08em;
    pointer-events: none; opacity: 0; transition: opacity 0.2s;
  }
  .daw-track:hover .track-lane-hint:not(.has-clips) { opacity: 1; }

  /* Add track row */
  .add-track-row {
    display: flex; gap: 8px;
    padding: 12px;
    /* This row also needs the sticky head space */
    padding-left: var(--track-head-w);
  }
  .add-track-btn {
    display: flex; align-items: center; gap: 6px;
    padding: 8px 16px; border-radius: 8px;
    background: var(--bg-card); border: 1px solid var(--border-subtle);
    font-family: 'DM Mono', monospace; font-size: 10px;
    letter-spacing: 0.08em; text-transform: uppercase;
    color: var(--text-muted); cursor: pointer;
    transition: all 0.18s;
    -webkit-tap-highlight-color: transparent;
  }
  .add-track-btn:hover, .add-track-btn:active { border-color: var(--teal-dim); color: var(--teal); background: var(--teal-faint); }
  .add-track-btn svg { width: 12px; height: 12px; stroke: currentColor; fill: none; stroke-width: 2.5; stroke-linecap: round; }

  /* ══════════════════════════════
     MIXER SIDEBAR
  ══════════════════════════════ */
  .daw-mixer {
    background: var(--bg-panel);
    border-left: 1px solid var(--border-subtle);
    display: flex; flex-direction: column;
    overflow: hidden;
  }
  .daw-mixer-tabs {
    display: flex; border-bottom: 1px solid var(--border-subtle); flex-shrink: 0;
  }
  .mixer-tab {
    flex: 1; padding: 10px 4px; text-align: center;
    font-family: 'DM Mono', monospace;
    font-size: 9px; letter-spacing: 0.1em; text-transform: uppercase;
    color: var(--text-dim); cursor: pointer;
    border-bottom: 2px solid transparent;
    transition: all 0.18s; background: none;
    border-top: none; border-left: none; border-right: none;
    -webkit-tap-highlight-color: transparent;
  }
  .mixer-tab:hover { color: var(--text-muted); }
  .mixer-tab.active { color: var(--teal); border-bottom-color: var(--teal); }
  .mixer-panel { flex: 1; overflow-y: auto; }
  .mixer-panel::-webkit-scrollbar { width: 3px; }
  .mixer-pane { display: none; padding: 14px; }
  .mixer-pane.active { display: block; }

  .channel-strip {
    background: var(--bg-card);
    border: 1px solid var(--border-subtle);
    border-radius: 10px; padding: 12px;
    margin-bottom: 8px; transition: border-color 0.18s;
  }
  .channel-strip:hover { border-color: var(--border-medium); }
  .channel-name {
    font-family: 'Syne', sans-serif;
    font-size: 10px; font-weight: 600; letter-spacing: 0.04em;
    color: var(--text-secondary); margin-bottom: 10px;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  }
  .channel-fader-wrap { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
  .channel-fader-label {
    font-family: 'DM Mono', monospace; font-size: 9px;
    color: var(--text-dim); letter-spacing: 0.06em;
    width: 16px; text-align: center; flex-shrink: 0;
  }
  .channel-fader {
    flex: 1; -webkit-appearance: none;
    height: 3px; background: var(--border-subtle); border-radius: 2px; cursor: pointer;
  }
  .channel-fader::-webkit-slider-thumb {
    -webkit-appearance: none; width: 14px; height: 14px;
    border-radius: 50%; background: var(--teal);
    cursor: pointer; box-shadow: 0 0 6px var(--teal-dim);
  }
  .channel-fader-val {
    font-family: 'DM Mono', monospace; font-size: 9px;
    color: var(--teal); min-width: 28px; text-align: right;
  }
  .channel-vu { display: flex; gap: 2px; margin-bottom: 8px; height: 6px; }
  .vu-seg { flex: 1; border-radius: 1px; background: var(--border-subtle); transition: background 0.08s; }
  .vu-seg.active.green  { background: var(--success); }
  .vu-seg.active.yellow { background: var(--warning); }
  .vu-seg.active.red    { background: var(--error); }
  .channel-pan-wrap { display: flex; align-items: center; gap: 6px; }
  .channel-pan-label {
    font-family: 'DM Mono', monospace; font-size: 9px;
    color: var(--text-dim); letter-spacing: 0.06em;
    width: 24px; text-align: center;
  }
  .channel-pan {
    flex: 1; -webkit-appearance: none;
    height: 2px; background: var(--border-subtle); border-radius: 2px; cursor: pointer;
  }
  .channel-pan::-webkit-slider-thumb {
    -webkit-appearance: none; width: 12px; height: 12px;
    border-radius: 50%; background: var(--text-muted); cursor: pointer;
  }
  .channel-pan-val {
    font-family: 'DM Mono', monospace; font-size: 9px;
    color: var(--text-muted); min-width: 24px; text-align: right;
  }
  .channel-footer { display: flex; gap: 4px; margin-top: 10px; }
  .ch-btn {
    flex: 1; padding: 5px; border-radius: 5px;
    font-family: 'DM Mono', monospace;
    font-size: 8px; letter-spacing: 0.06em; text-transform: uppercase;
    cursor: pointer; border: 1px solid var(--border-subtle);
    background: var(--bg-deep); color: var(--text-dim); transition: all 0.15s;
    -webkit-tap-highlight-color: transparent;
  }
  .ch-btn.mute.active { background: rgba(255,149,0,0.12); border-color: rgba(255,149,0,0.35); color: var(--warning); }
  .ch-btn.solo.active { background: var(--teal-faint); border-color: var(--teal-dim); color: var(--teal); }

  .fx-section-label {
    font-family: 'DM Mono', monospace; font-size: 9px;
    letter-spacing: 0.12em; color: var(--gold);
    text-transform: uppercase; margin-bottom: 10px;
  }
  .fx-rack {
    background: var(--bg-deep); border: 1px solid var(--border-subtle);
    border-radius: 10px; padding: 12px; margin-bottom: 12px;
  }
  .fx-name { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
  .fx-title { font-family: 'Syne', sans-serif; font-size: 11px; font-weight: 600; color: var(--text-secondary); }
  .fx-toggle {
    width: 28px; height: 16px; border-radius: 8px;
    background: var(--border-subtle); border: none; cursor: pointer;
    position: relative; transition: background 0.2s;
    -webkit-tap-highlight-color: transparent;
  }
  .fx-toggle::after {
    content: ''; position: absolute; top: 2px; left: 2px;
    width: 12px; height: 12px; border-radius: 50%;
    background: var(--text-dim); transition: all 0.2s;
  }
  .fx-toggle.on { background: var(--teal-dim); }
  .fx-toggle.on::after { left: calc(100% - 14px); background: var(--teal); }
  .fx-param { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
  .fx-param-label {
    font-family: 'DM Mono', monospace; font-size: 9px;
    color: var(--text-dim); letter-spacing: 0.06em; width: 48px; flex-shrink: 0;
  }
  .fx-param-slider {
    flex: 1; -webkit-appearance: none;
    height: 2px; background: var(--border-subtle); border-radius: 2px; cursor: pointer;
  }
  .fx-param-slider::-webkit-slider-thumb {
    -webkit-appearance: none; width: 12px; height: 12px;
    border-radius: 50%; background: var(--gold); cursor: pointer;
  }
  .fx-param-val {
    font-family: 'DM Mono', monospace; font-size: 9px;
    color: var(--gold); min-width: 28px; text-align: right;
  }
  .eq-display {
    height: 60px; border-radius: 6px;
    background: var(--bg-card); border: 1px solid var(--border-subtle);
    margin-bottom: 10px; overflow: hidden;
  }
  #eq-canvas { width: 100%; height: 100%; display: block; }

  /* ══════════════════════════════
     TOAST
  ══════════════════════════════ */
  .status-toast {
    position: fixed; bottom: 80px; left: 50%;
    transform: translateX(-50%) translateY(12px);
    background: var(--bg-panel); border: 1px solid var(--border-medium);
    border-radius: 10px; padding: 12px 22px;
    font-family: 'DM Mono', monospace; font-size: 11px;
    color: var(--text-primary); letter-spacing: 0.06em;
    box-shadow: 0 12px 40px rgba(0,0,0,.5);
    opacity: 0; transition: all .3s; z-index: 9999;
    pointer-events: none; white-space: nowrap;
  }
  .status-toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }
  .status-toast.success { border-color: var(--success); color: var(--success); }
  .status-toast.error   { border-color: var(--error); color: var(--error); }
  .status-toast.teal    { border-color: var(--teal-dim); color: var(--teal); }

  /* ══════════════════════════════
     MODAL
  ══════════════════════════════ */
  .modal-overlay {
    position: fixed; inset: 0;
    background: rgba(0,0,0,.75); backdrop-filter: blur(10px);
    z-index: 9000; display: flex; align-items: center; justify-content: center;
    opacity: 0; pointer-events: none; transition: opacity .25s; padding: 16px;
  }
  .modal-overlay.open { opacity: 1; pointer-events: all; }
  .modal {
    background: var(--bg-panel); border: 1px solid var(--border-medium);
    border-radius: 20px; padding: 28px; width: 100%; max-width: 440px;
    transform: translateY(16px) scale(.97);
    transition: transform .25s; box-shadow: 0 32px 80px rgba(0,0,0,.6);
  }
  .modal-overlay.open .modal { transform: translateY(0) scale(1); }
  .modal-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.5rem; font-weight: 300;
    color: var(--text-primary); margin-bottom: 20px;
  }
  .modal-footer { display: flex; gap: 10px; margin-top: 24px; justify-content: flex-end; }

  /* ══════════════════════════════
     MOBILE LIBRARY BOTTOM SHEET
  ══════════════════════════════ */
  .mobile-lib-btn {
    display: none;
    position: fixed; bottom: 20px; left: 20px;
    z-index: 500;
    width: 52px; height: 52px; border-radius: 50%;
    background: var(--teal-faint); border: 1px solid var(--teal-dim);
    color: var(--teal); cursor: pointer;
    align-items: center; justify-content: center;
    box-shadow: 0 4px 20px rgba(0,0,0,0.4);
    -webkit-tap-highlight-color: transparent;
    transition: all 0.2s;
  }
  .mobile-lib-btn svg { width: 20px; height: 20px; stroke: currentColor; fill: none; stroke-width: 1.5; }
  .mobile-lib-btn:active { transform: scale(0.92); }

  .mobile-lib-sheet {
    display: none;
    position: fixed; bottom: 0; left: 0; right: 0;
    z-index: 800;
    background: var(--bg-panel); border-top: 1px solid var(--border-medium);
    border-radius: 20px 20px 0 0;
    max-height: 70vh;
    flex-direction: column;
    transform: translateY(100%);
    transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1);
    box-shadow: 0 -8px 40px rgba(0,0,0,0.5);
    padding-bottom: env(safe-area-inset-bottom, 16px);
  }
  .mobile-lib-sheet.open { transform: translateY(0); }
  .mobile-lib-sheet-handle {
    width: 36px; height: 4px; border-radius: 2px;
    background: var(--border-medium);
    margin: 12px auto 0;
    flex-shrink: 0;
  }
  .mobile-lib-sheet-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 12px 20px; flex-shrink: 0;
    border-bottom: 1px solid var(--border-subtle);
  }
  .mobile-lib-sheet-title {
    font-family: 'Cormorant Garamond', serif; font-size: 1.1rem;
    font-weight: 300; color: var(--text-primary);
  }
  .mobile-lib-sheet-close {
    width: 32px; height: 32px; border-radius: 50%;
    background: var(--bg-card); border: 1px solid var(--border-subtle);
    cursor: pointer; display: flex; align-items: center; justify-content: center;
    font-size: 16px; color: var(--text-muted);
    -webkit-tap-highlight-color: transparent;
  }
  .mobile-lib-sheet-content {
    flex: 1; overflow-y: auto; padding: 8px;
    -webkit-overflow-scrolling: touch;
  }
  .sheet-overlay {
    display: none;
    position: fixed; inset: 0;
    background: rgba(0,0,0,0.5);
    z-index: 799;
  }
  .sheet-overlay.open { display: block; }

  /* ══════════════════════════════
     RESPONSIVE
  ══════════════════════════════ */
  @media (max-width: 1100px) {
    :root { --daw-mixer-w: 180px; --daw-lib-w: 220px; }
  }

  @media (max-width: 860px) {
    :root { --daw-transport-h: 100px; }
    .daw-library { display: none; }
    .daw-body { grid-template-columns: 1fr var(--daw-mixer-w); }
    .gnav-links { display: none; }
    .gnav-hamburger { display: flex; }
    .gnav-status { display: none; }
    .mobile-lib-btn { display: flex; }
    .mobile-lib-sheet { display: flex; }

    /* Transport wraps to 2 rows */
    .daw-transport {
      flex-wrap: wrap;
      height: auto;
      padding: 6px 0;
      gap: 0;
      align-items: center;
    }
    .transport-section {
      padding: 4px 10px;
      height: 44px;
    }
    /* Hide BPM/sig/master on very small screens */
    .transport-section.hide-mobile { display: none; }
    /* Project name row goes full width */
    .transport-section.project-row {
      width: 100%;
      border-left: none;
      border-top: 1px solid var(--border-subtle);
      padding: 4px 10px;
      justify-content: flex-end;
    }
    .t-time { font-size: 1rem; min-width: 80px; padding: 4px 8px; }
    .t-project-name { max-width: 120px; min-width: 80px; font-size: 0.85rem; }
  }

  @media (max-width: 600px) {
    :root { --daw-transport-h: 100px; --track-head-w: 120px; }
    .daw-mixer { display: none; }
    .daw-body { grid-template-columns: 1fr; }
    .daw-transport { flex-wrap: wrap; }
    /* Hide extra transport items */
    .transport-section.hide-small { display: none; }
    .t-time { font-size: 0.9rem; min-width: 72px; }
  }

  @media (max-width: 400px) {
    :root { --track-head-w: 100px; }
    .track-vol-mini { display: none; }
    .t-save-btn span, .t-export-btn span { display: none; }
  }