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

    body {
      font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
      background-color: var(--bg);
      background-image:
        radial-gradient(
          900px 600px at 85% -10%,
          rgba(13,148,136,0.06) 0%,
          rgba(13,148,136,0) 70%
        ),
        radial-gradient(
          800px 540px at -10% 105%,
          rgba(13,148,136,0.04) 0%,
          rgba(13,148,136,0) 70%
        );
      background-attachment: fixed;
      color: var(--text);
      line-height: 1.55;
      -webkit-font-smoothing: antialiased;
      -moz-osx-font-smoothing: grayscale;
      font-feature-settings: 'cv11', 'ss01', 'ss03';
    }
    [data-theme="dark"] body {
      background-image:
        radial-gradient(
          900px 600px at 85% -10%,
          rgba(45,212,191,0.10) 0%,
          rgba(45,212,191,0) 70%
        ),
        radial-gradient(
          800px 540px at -10% 105%,
          rgba(45,212,191,0.06) 0%,
          rgba(45,212,191,0) 70%
        );
    }

    .wrap {
      max-width: 1280px;
      margin: 0 auto;
      padding: 0 16px 64px;
    }

    /* NAV BAR */
    .navbar {
      position: sticky;
      top: 0;
      z-index: 100;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 10px 14px;
      min-height: 64px;
      padding: 10px 18px;
      background: color-mix(in oklab, var(--surface) 86%, transparent);
      backdrop-filter: saturate(180%) blur(12px);
      -webkit-backdrop-filter: saturate(180%) blur(12px);
      border-bottom: 1px solid var(--border);
      flex-wrap: nowrap;
    }
    .nav-left {
      display: flex;
      align-items: center;
      gap: 10px;
      flex: 0 1 auto;
      min-width: 0;
    }
    .nav-logo {
      width: 30px;
      height: 30px;
      border-radius: 8px;
      object-fit: contain;
      flex-shrink: 0;
      padding: 3px;
      background: linear-gradient(135deg, color-mix(in oklab, var(--accent) 18%, transparent), color-mix(in oklab, var(--accent) 6%, transparent));
      border: 1px solid color-mix(in oklab, var(--accent) 18%, var(--border));
    }
    .nav-title {
      font-family: 'Space Grotesk', 'Inter', sans-serif;
      font-size: 16px;
      font-weight: 700;
      color: var(--text);
      white-space: nowrap;
      letter-spacing: -0.015em;
    }
    .nav-center {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      flex: 1 1 auto;
      min-width: 0;
      order: 0;
      flex-wrap: nowrap;
    }
    .nav-tabs-wrap {
      flex: 1 1 auto;
      min-width: 0;
      display: flex;
      justify-content: center;
    }
    .nav-tabs {
      display: inline-flex;
      align-items: center;
      gap: 2px;
      padding: 4px;
      background: var(--surface-soft);
      border: 1px solid var(--border);
      border-radius: var(--radius);
      max-width: 100%;
      overflow-x: auto;
      scrollbar-width: thin;
    }
    .nav-tabs button {
      all: unset;
      cursor: pointer;
      padding: 7px 16px;
      font-size: 12.5px;
      font-weight: 500;
      color: var(--text-secondary);
      border-radius: 7px;
      letter-spacing: -0.005em;
      transition: color 150ms ease, background 150ms ease, box-shadow 150ms ease;
      white-space: nowrap;
    }
    .nav-tabs button:hover { color: var(--text); background: color-mix(in oklab, var(--surface) 60%, transparent); }
    .nav-tabs button.active {
      background: var(--surface);
      color: var(--text);
      font-weight: 600;
      box-shadow: var(--shadow-sm);
    }
    .nav-right {
      display: flex;
      align-items: center;
      gap: 8px;
      margin-left: 0;
      flex: 0 0 auto;
    }
    .nav-league {
      display: inline-flex;
      align-items: center;
      flex-wrap: wrap;
      gap: 8px;
      padding: 4px 8px;
      border: 1px solid var(--border);
      border-radius: 10px;
      background: var(--bg);
      flex: 1 1 420px;
      min-width: min(100%, 280px);
    }
    .nav-league-label {
      font-size: 12px;
      color: var(--text-secondary);
      font-weight: 600;
      white-space: nowrap;
    }
    .nav-league select {
      width: auto;
      min-width: 74px;
      height: 34px;
      padding: 0 28px 0 10px;
      font-size: 12.5px;
    }
    .nav-league-stats {
      display: inline-flex;
      align-items: center;
      flex-wrap: wrap;
      gap: 6px;
      min-width: 0;
    }
    .nav-league-chip {
      height: 32px;
      font-size: 11.5px;
      font-weight: 600;
      color: var(--text);
      max-width: 300px;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }
    #themeToggleBtn {
      all: unset;
      cursor: pointer;
      width: 36px;
      height: 36px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      border-radius: 8px;
      font-size: 18px;
      color: var(--text-secondary);
      transition: color 150ms ease, background 150ms ease;
    }
    #themeToggleBtn:hover {
      background: var(--accent-soft);
      color: var(--text);
    }
    .nav-logout {
      font-size: 13px;
      font-weight: 600;
      color: var(--text-secondary);
      text-decoration: none;
      padding: 6px 12px;
      border-radius: 8px;
      transition: color 150ms ease, background 150ms ease;
    }
    .nav-logout:hover {
      background: var(--danger-soft);
      color: var(--danger);
    }
    .nav-account {
      font-size: 12px;
      color: var(--text-muted);
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
      max-width: 220px;
      padding-left: 12px;
      margin-left: 4px;
      border-left: 1px solid var(--border);
    }
    .nav-account:empty,
    .nav-account.is-placeholder { display: none; }

    /* HAMBURGER MENU (hidden by default, kept for JS) */
    .menu-shell { position: relative; display: none; }
    .menu-toggle {
      all: unset;
      cursor: pointer;
      width: 36px;
      height: 36px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      border-radius: 8px;
      font-size: 18px;
      color: var(--text-secondary);
    }
    .menu-panel {
      position: absolute;
      right: 0;
      top: calc(100% + 8px);
      z-index: 50;
      min-width: 180px;
      padding: 6px;
      background: var(--surface);
      border: 1px solid var(--border);
      border-radius: 10px;
      display: grid;
      gap: 2px;
    }
    .menu-panel[hidden] { display: none; }
    .menu-panel button {
      all: unset;
      cursor: pointer;
      padding: 8px 12px;
      border-radius: 6px;
      font-size: 13px;
      font-weight: 500;
      color: var(--text-secondary);
    }
    .menu-panel button.active {
      background: var(--accent-soft);
      color: var(--accent);
    }

    /* AUTH */
    .auth-banner {
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 32px 16px;
    }
    .login {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      height: 38px;
      padding: 0 16px;
      border-radius: 10px;
      background: var(--text);
      color: var(--bg);
      font-weight: 600;
      font-size: 13px;
      text-decoration: none;
      letter-spacing: -0.01em;
      transition: transform 150ms ease, box-shadow 150ms ease, background 150ms ease;
      box-shadow: var(--shadow-sm);
    }
    .login:hover {
      transform: translateY(-1px);
      box-shadow: var(--shadow-md);
    }

    /* LANDING */
    .landing-shell {
      display: grid;
      grid-template-columns: minmax(0, 1.35fr) minmax(0, 1fr);
      gap: 20px;
      margin-top: 40px;
      align-items: stretch;
    }
    .landing-card {
      background: var(--surface);
      border: 1px solid var(--border);
      border-radius: var(--radius-xl);
      padding: 40px;
      box-shadow: var(--shadow-md);
    }
    .landing-hero {
      position: relative;
      overflow: hidden;
      isolation: isolate;
      background: var(--surface);
    }
    .landing-hero::before {
      content: '';
      position: absolute;
      inset: 0;
      background:
        radial-gradient(circle at 92% -10%, var(--accent-glow), transparent 48%),
        radial-gradient(circle at -10% 100%, color-mix(in oklab, var(--accent) 14%, transparent), transparent 50%);
      opacity: 0.9;
      z-index: -1;
      pointer-events: none;
    }
    .landing-hero::after {
      content: '';
      position: absolute;
      inset: 0;
      background-image:
        linear-gradient(to right, color-mix(in oklab, var(--text) 4%, transparent) 1px, transparent 1px),
        linear-gradient(to bottom, color-mix(in oklab, var(--text) 4%, transparent) 1px, transparent 1px);
      background-size: 32px 32px;
      mask-image: radial-gradient(circle at 30% 30%, black, transparent 70%);
      -webkit-mask-image: radial-gradient(circle at 30% 30%, black, transparent 70%);
      opacity: 0.55;
      z-index: -1;
      pointer-events: none;
    }
    .landing-eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 6px 12px 6px 8px;
      border-radius: 999px;
      border: 1px solid var(--border);
      background: var(--surface);
      font-size: 11.5px;
      letter-spacing: 0.04em;
      color: var(--text-secondary);
      margin-bottom: 22px;
      font-weight: 600;
      box-shadow: var(--shadow-sm);
    }
    .landing-eyebrow::before {
      content: '';
      width: 7px;
      height: 7px;
      border-radius: 999px;
      background: var(--accent);
      box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 22%, transparent);
      flex-shrink: 0;
    }
    .landing-title {
      font-family: 'Space Grotesk', 'Inter', sans-serif;
      font-size: clamp(36px, 4.6vw, 56px);
      line-height: 1.05;
      letter-spacing: -0.035em;
      margin-bottom: 18px;
      font-weight: 600;
      background: linear-gradient(180deg, var(--text) 0%, color-mix(in oklab, var(--text) 78%, var(--text-secondary)) 100%);
      -webkit-background-clip: text;
      background-clip: text;
      -webkit-text-fill-color: transparent;
      color: transparent;
    }
    .landing-title-accent {
      background: linear-gradient(135deg, var(--accent) 0%, color-mix(in oklab, var(--accent) 60%, var(--text)) 100%);
      -webkit-background-clip: text;
      background-clip: text;
      -webkit-text-fill-color: transparent;
      color: transparent;
    }
    .landing-subtitle {
      font-size: 17px;
      color: var(--text-secondary);
      margin-bottom: 28px;
      line-height: 1.6;
      max-width: 56ch;
      letter-spacing: -0.005em;
    }
    .landing-proof-row {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-bottom: 28px;
    }
    .landing-proof-chip {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      height: 30px;
      padding: 0 12px;
      border-radius: 999px;
      border: 1px solid var(--border);
      background: color-mix(in oklab, var(--surface) 70%, transparent);
      font-size: 12.5px;
      color: var(--text-secondary);
      font-weight: 500;
      white-space: nowrap;
      letter-spacing: -0.005em;
    }
    .landing-proof-chip::before {
      content: '';
      width: 5px;
      height: 5px;
      border-radius: 999px;
      background: var(--accent);
      flex-shrink: 0;
    }
    .landing-cta-row {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
      margin-bottom: 14px;
    }
    .landing-login-btn {
      height: 50px;
      padding: 0 26px;
      border-radius: 12px;
      background: var(--text);
      color: var(--bg);
      font-weight: 600;
      font-size: 14.5px;
      letter-spacing: -0.01em;
      text-decoration: none;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 10px;
      box-shadow: var(--shadow-md);
      transition: transform 150ms ease, box-shadow 150ms ease;
    }
    .landing-login-btn::after {
      content: '→';
      font-size: 18px;
      transition: transform 200ms ease;
    }
    .landing-login-btn:hover {
      transform: translateY(-1px);
      box-shadow: var(--shadow-lg);
    }
    .landing-login-btn:hover::after {
      transform: translateX(3px);
    }
    .landing-muted-link {
      height: 50px;
      padding: 0 22px;
      border-radius: 12px;
      border: 1px solid var(--border);
      color: var(--text);
      text-decoration: none;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      background: var(--surface);
      font-size: 13.5px;
      font-weight: 500;
      letter-spacing: -0.005em;
      transition: border-color 150ms ease, background 150ms ease;
    }
    .landing-muted-link:hover {
      border-color: var(--border-strong);
      background: var(--surface-soft);
    }
    .landing-cta-note {
      font-size: 12.5px;
      color: var(--text-muted);
      margin-bottom: 36px;
      display: inline-flex;
      align-items: center;
      gap: 6px;
    }
    .landing-cta-note::before {
      content: '';
      width: 14px;
      height: 14px;
      border-radius: 999px;
      border: 1px solid var(--border-strong);
      background:
        radial-gradient(circle, var(--accent) 30%, transparent 32%);
      flex-shrink: 0;
    }
    .landing-points {
      display: grid;
      gap: 18px;
      padding-top: 28px;
      border-top: 1px solid var(--border);
    }
    .landing-point {
      display: grid;
      grid-template-columns: 24px minmax(0, 1fr);
      gap: 14px;
      align-items: start;
    }
    .landing-point-dot {
      width: 24px;
      height: 24px;
      border-radius: 8px;
      margin-top: 1px;
      background: color-mix(in oklab, var(--accent) 14%, var(--surface));
      color: var(--accent);
      font-size: 13px;
      font-weight: 700;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--accent) 24%, transparent);
    }
    .landing-point-title {
      font-size: 14.5px;
      font-weight: 600;
      margin-bottom: 4px;
      letter-spacing: -0.01em;
      color: var(--text);
    }
    .landing-point-text {
      font-size: 13.5px;
      color: var(--text-secondary);
      line-height: 1.55;
    }
    .landing-list {
      display: grid;
      gap: 8px;
    }
    .landing-list-item {
      border: 1px solid var(--border);
      border-radius: var(--radius-md);
      background: var(--surface);
      padding: 16px 18px;
      display: grid;
      grid-template-columns: 32px minmax(0, 1fr);
      gap: 14px;
      align-items: start;
      transition: transform 150ms ease, box-shadow 150ms ease, border-color 150ms ease, background 150ms ease;
      position: relative;
    }
    .landing-list-item::before {
      content: '';
      width: 28px;
      height: 28px;
      border-radius: 8px;
      background-color: color-mix(in oklab, var(--accent) 14%, var(--surface));
      box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--accent) 24%, transparent);
      background-image: url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none' stroke='%230d9488' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='4,11 8,15 16,6'/%3E%3C/svg%3E");
      background-size: 18px 18px;
      background-position: center;
      background-repeat: no-repeat;
    }
    [data-theme="dark"] .landing-list-item::before {
      background-image: url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none' stroke='%232dd4bf' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='4,11 8,15 16,6'/%3E%3C/svg%3E");
    }
    .landing-list-item:hover {
      transform: translateY(-1px);
      border-color: color-mix(in oklab, var(--accent) 30%, var(--border));
      box-shadow: var(--shadow-md);
    }
    .landing-list-item strong {
      display: block;
      font-size: 14px;
      margin-bottom: 4px;
      font-weight: 600;
      letter-spacing: -0.01em;
      color: var(--text);
    }
    .landing-list-item span {
      font-size: 13px;
      color: var(--text-secondary);
      line-height: 1.5;
    }
    .landing-aside-head {
      margin-bottom: 18px;
    }
    .landing-aside-head .section-tag { margin-bottom: 8px; }
    .landing-aside-head h2 {
      font-family: 'Space Grotesk', 'Inter', sans-serif;
      font-size: 22px;
      font-weight: 600;
      letter-spacing: -0.02em;
      line-height: 1.2;
    }

    /* TYPOGRAPHY */
    h2 {
      font-size: 17px;
      font-weight: 650;
      color: var(--text);
      letter-spacing: -0.01em;
    }
    p, .muted {
      font-size: 13px;
      color: var(--text-secondary);
      line-height: 1.6;
    }
    label {
      display: block;
      margin-bottom: 6px;
      font-size: 11px;
      font-weight: 600;
      color: var(--text-secondary);
      letter-spacing: 0.03em;
    }
    .label-inline-help {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 16px;
      height: 16px;
      margin-left: 4px;
      border-radius: 999px;
      border: 1px solid var(--border);
      font-size: 10px;
      color: var(--text-muted);
      cursor: help;
    }
    .section-tag {
      font-size: 11px;
      font-weight: 600;
      letter-spacing: 0.06em;
      text-transform: uppercase;
      color: var(--text-muted);
      margin-bottom: 4px;
    }
    .mono {
      font-family: 'SF Mono', 'Fira Code', 'Consolas', monospace;
      font-size: 12px;
    }

    /* CARDS */
    .card {
      background: var(--surface);
      border: 1px solid var(--border);
      border-radius: var(--radius-lg);
      padding: 22px;
      box-shadow: var(--shadow-float), var(--card-edge-highlight);
      transition: border-color 160ms ease, box-shadow 200ms ease, transform 200ms ease;
    }
    .panel-header {
      margin-bottom: 16px;
    }
    .panel-header h2 {
      font-family: 'Space Grotesk', 'Inter', sans-serif;
      font-size: 18px;
      font-weight: 600;
      letter-spacing: -0.015em;
      line-height: 1.25;
    }
    .panel-copy h2 {
      font-family: 'Space Grotesk', 'Inter', sans-serif;
      font-size: 18px;
      font-weight: 600;
      letter-spacing: -0.015em;
    }

    /* FORMS */
    select, input, textarea {
      width: 100%;
      height: 40px;
      padding: 9px 12px;
      border: 1px solid var(--border);
      border-radius: var(--radius);
      background: var(--surface);
      color: var(--text);
      font-size: 13.5px;
      font-family: inherit;
      letter-spacing: -0.005em;
      outline: none;
      box-shadow: var(--shadow-sm);
      transition: border-color 150ms ease, box-shadow 150ms ease, background 150ms ease;
    }
    select:hover, input:hover, textarea:hover {
      border-color: var(--border-strong);
    }
    select:focus, input:focus, textarea:focus {
      border-color: var(--accent);
      box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 18%, transparent);
    }
    select {
      appearance: none;
      padding-right: 36px;
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2378716c' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
      background-repeat: no-repeat;
      background-position: right 12px center;
    }
    textarea {
      height: auto;
      min-height: 100px;
      resize: vertical;
    }
    input[type="range"] {
      padding: 0;
      border: 0;
      height: auto;
      background: transparent;
      accent-color: var(--accent);
    }
    input[type="checkbox"] {
      width: 18px;
      height: 18px;
      accent-color: var(--accent);
      flex-shrink: 0;
    }
    input[type="number"] { width: 100%; }

    /* BUTTONS */
    button {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 6px;
      height: 40px;
      padding: 0 14px;
      border: 1px solid color-mix(in oklab, var(--border) 78%, #ffffff 22%);
      border-radius: 12px;
      background: color-mix(in oklab, var(--surface) 92%, var(--bg) 8%);
      color: var(--text);
      font-size: 13px;
      font-weight: 600;
      font-family: inherit;
      letter-spacing: 0.01em;
      cursor: pointer;
      box-shadow: 0 6px 14px rgba(0,0,0,0.18), inset 0 1px 0 rgba(255,255,255,0.06);
      transition: border-color 160ms ease, color 160ms ease, background 160ms ease, box-shadow 160ms ease, transform 120ms ease;
      backdrop-filter: blur(8px);
    }
    button:hover {
      border-color: color-mix(in oklab, var(--border-strong) 72%, var(--accent) 28%);
      background: color-mix(in oklab, var(--surface-soft) 90%, var(--accent) 10%);
      box-shadow: 0 10px 18px rgba(0,0,0,0.22), inset 0 1px 0 rgba(255,255,255,0.08);
      transform: translateY(-1px);
    }
    button:active {
      transform: translateY(0);
      box-shadow: 0 4px 10px rgba(0,0,0,0.24), inset 0 1px 0 rgba(255,255,255,0.04);
    }
    button:focus-visible {
      outline: 2px solid var(--accent);
      outline-offset: 2px;
    }
    button:disabled {
      opacity: 0.45;
      cursor: not-allowed;
      box-shadow: none;
    }
    button.primary {
      background: color-mix(in oklab, var(--text) 92%, var(--bg) 8%) !important;
      color: var(--bg) !important;
      border-color: color-mix(in oklab, var(--text) 84%, #ffffff 16%) !important;
      font-weight: 600;
    }
    button.primary:hover {
      background: color-mix(in oklab, var(--text) 82%, var(--bg) 18%) !important;
      border-color: color-mix(in oklab, var(--text) 72%, #ffffff 28%) !important;
    }
    button.accent {
      background: linear-gradient(135deg, color-mix(in oklab, var(--accent) 90%, #ff47c8 10%), color-mix(in oklab, var(--accent-strong) 92%, #2a1440 8%)) !important;
      color: #fff !important;
      border-color: color-mix(in oklab, var(--accent) 70%, #ffffff 30%) !important;
      font-weight: 600;
    }
    button.accent:hover {
      background: linear-gradient(135deg, color-mix(in oklab, var(--accent-hover) 88%, #ff69cf 12%), color-mix(in oklab, var(--accent-strong) 88%, #3b1b58 12%)) !important;
      border-color: color-mix(in oklab, var(--accent-hover) 72%, #ffffff 28%) !important;
    }
    button.danger {
      color: var(--danger);
      border-color: color-mix(in oklab, var(--danger) 30%, var(--border));
      background: var(--danger-soft);
    }
    button.danger:hover {
      border-color: var(--danger);
      background: color-mix(in oklab, var(--danger) 14%, var(--surface));
    }
    button.ghost {
      background: transparent;
      border-color: transparent;
      box-shadow: none;
      color: var(--text-secondary);
    }
    button.ghost:hover {
      background: var(--surface-soft);
      color: var(--text);
    }
    button.tiny {
      height: 32px;
      padding: 0 13px;
      font-size: 12px;
      font-weight: 600;
      gap: 4px;
      border-radius: 11px;
      border-color: color-mix(in oklab, var(--border) 70%, var(--accent) 30%);
      background: color-mix(in oklab, var(--surface) 86%, var(--accent) 14%);
    }

    /* START / STOP */
    #startBtn {
      width: 100%;
      height: 50px;
      font-size: 15px;
      font-weight: 600;
      letter-spacing: -0.01em;
      background: linear-gradient(135deg, var(--accent), var(--accent-strong)) !important;
      color: #fff !important;
      border-color: color-mix(in oklab, var(--accent) 45%, var(--border)) !important;
      box-shadow: 0 16px 28px color-mix(in oklab, var(--accent) 28%, transparent), var(--shadow-md);
    }
    #startBtn:hover {
      background: linear-gradient(135deg, color-mix(in oklab, var(--accent) 90%, #fff), var(--accent-strong)) !important;
      border-color: color-mix(in oklab, var(--accent) 62%, var(--border)) !important;
      box-shadow: var(--shadow-lg);
    }
    #startBtn.listening {
      background: linear-gradient(135deg, #dc2626, #991b1b) !important;
      border-color: color-mix(in oklab, var(--danger) 58%, var(--border)) !important;
      color: #fff !important;
      box-shadow: 0 18px 34px rgba(220,38,38,0.32), var(--shadow-md);
      animation: pulse-listen 2s ease-in-out infinite;
    }
    #startBtn.listening:hover {
      background: linear-gradient(135deg, #ef4444, #b91c1c) !important;
      border-color: #b91c1c !important;
    }
    @keyframes pulse-listen {
      0%, 100% { box-shadow: 0 0 0 0 color-mix(in oklab, var(--danger) 32%, transparent), var(--shadow-md); }
      50% { box-shadow: 0 0 0 8px transparent, var(--shadow-md); }
    }

    /* CONFIG ROW */
    .config-row {
      display: flex;
      gap: 12px;
    }
    .voices-config-inline {
      display: flex;
      flex-wrap: wrap;
      gap: 12px;
      align-items: end;
      margin: 0 0 14px;
    }
    .voices-config-control {
      flex: 1 1 280px;
      min-width: 220px;
    }
    .fish-browse-search button {
      min-width: 100px;
    }
    .fish-browse-helper {
      margin-top: 8px;
      font-size: 12px;
      line-height: 1.35;
    }
    .voices-config-lock {
      display: grid;
      gap: 6px;
      min-width: 180px;
      max-width: 220px;
    }
    .voices-provider-pill {
      min-height: 40px;
      display: flex;
      align-items: center;
      padding: 0 12px;
      border-radius: var(--radius);
      border: 1px solid color-mix(in oklab, var(--border) 65%, var(--accent) 35%);
      background: color-mix(in oklab, var(--accent) 8%, var(--surface) 92%);
      color: var(--text-secondary);
      font-weight: 600;
      letter-spacing: 0.01em;
    }

    /* LAYOUT */
    .page-content {
      margin-top: 24px;
    }
    .studio-app {
      display: grid;
      gap: 16px;
    }
    #studioView {
      position: relative;
      display: grid;
      gap: 16px;
    }

    /* LIVE VIEW */
    .live-topbar {
      display: grid;
      grid-template-columns: 1fr 1fr auto;
      gap: 12px;
      align-items: end;
    }
    .live-columns {
      display: grid;
      grid-template-columns: 320px minmax(0, 1fr);
      gap: 16px;
      align-items: stretch;
    }
    .live-sidebar {
      display: grid;
      gap: 16px;
      position: sticky;
      top: 72px;
    }
    .live-feeds {
      display: grid;
      gap: 16px;
    }
    .live-columns > .live-sidebar,
    .live-columns > .live-feeds {
      align-self: stretch;
    }
    .live-columns > .live-sidebar > .card,
    .live-columns > .live-feeds > .card {
      height: 100%;
    }
    .live-commenters {
      position: static;
      width: min(100%, 360px);
      margin: 16px 0 0 auto;
      z-index: 1;
    }
    .live-commenters[hidden] {
      display: none !important;
    }
    .live-commenter-tiles {
      display: grid;
      gap: 8px;
      max-height: min(360px, calc(100vh - 140px));
      overflow: auto;
      padding: 2px;
    }
    .live-commenter-tiles::-webkit-scrollbar { width: 6px; }
    .live-commenter-tiles::-webkit-scrollbar-thumb { background: var(--border-strong); border-radius: 999px; }
    .live-commenter-tiles::-webkit-scrollbar-track { background: transparent; }

    /* FIELD TOGGLE (checkbox + label inline) */
    .field-toggle {
      display: flex;
      align-items: center;
      gap: 10px;
      min-height: 40px;
      padding: 10px 14px;
      border-radius: var(--radius);
      border: 1px solid var(--border);
      background: var(--surface);
      box-shadow: var(--shadow-sm);
      transition: border-color 150ms ease, background 150ms ease;
    }
    .field-toggle:hover {
      border-color: var(--border-strong);
    }
    .field-toggle:has(input:checked) {
      border-color: color-mix(in oklab, var(--accent) 38%, var(--border));
      background: color-mix(in oklab, var(--accent) 5%, var(--surface));
    }
    .field-toggle .muted { margin: 0; }

    /* CONTROLS GRID */
    .controls {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 12px;
    }

    /* ACTION ROW */
    .action-row {
      display: flex;
      gap: 8px;
    }
    .action-row button {
      flex: 1;
    }
    .action-cluster {
      display: grid;
      gap: 8px;
      margin-bottom: 8px;
    }

    .row {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      align-items: center;
    }
    .search-row {
      display: flex;
      gap: 8px;
      align-items: center;
    }
    .search-row input { flex: 1; }
    .search-row select { flex: 1; }

    .section-divider {
      height: 1px;
      margin: 16px 0;
      background: var(--border);
    }

    /* FEEDS */
    .feed {
      border: 1px solid var(--border);
      border-radius: var(--radius-md);
      background: var(--surface-soft);
      overflow: auto;
      height: 420px;
      max-height: 420px;
      box-shadow: inset 0 1px 0 var(--border);
    }
    .feed::-webkit-scrollbar { width: 6px; }
    .feed::-webkit-scrollbar-thumb { background: var(--border-strong); border-radius: 999px; }
    .feed::-webkit-scrollbar-track { background: transparent; }
    .feed:empty::before {
      content: 'Comments, gifts, and follow activity will appear here once listening starts.';
      display: block;
      padding: 18px 16px;
      color: var(--text-muted);
      font-size: 13px;
      line-height: 1.5;
    }

    /* LIST */
    .list {
      border: 1px solid var(--border);
      border-radius: var(--radius-md);
      background: var(--surface);
      overflow: auto;
      max-height: 320px;
    }
    .list::-webkit-scrollbar { width: 6px; }
    .list::-webkit-scrollbar-thumb { background: var(--border-strong); border-radius: 999px; }
    .list::-webkit-scrollbar-track { background: transparent; }
    #voiceProfileList { max-height: min(58vh, 620px); }

    /* FEED ITEMS */
    .item, .list-item, .voice-row, .sound-row {
      display: grid;
      gap: 4px;
      padding: 12px 16px;
      border-bottom: 1px solid var(--border);
      transition: background 150ms ease;
    }
    .item:last-child, .list-item:last-child, .voice-row:last-child, .sound-row:last-child {
      border-bottom: 0;
    }
    .item:hover, .list-item:hover, .voice-row:hover, .sound-row:hover {
      background: var(--accent-soft);
    }
    .item .head {
      font-size: 12px;
      color: var(--text-muted);
    }
    .item .text {
      font-size: 14px;
      color: var(--text);
      word-break: break-word;
    }
    .item.gift {
      background: var(--gold-soft);
    }
    .item.system {
      background: var(--accent-soft);
    }
    .item.system.error {
      background: var(--danger-soft);
    }
    .item.system.error .text {
      color: var(--danger);
    }
    .voice-row .actions {
      display: flex;
      flex-wrap: wrap;
      gap: 6px;
    }
    .voice-row .voice-status {
      font-size: 12px;
      color: var(--text-muted);
    }
    .voice-row .voice-status.inactive {
      color: var(--danger);
    }
    .commenter-row {
      display: grid;
      grid-template-columns: minmax(0, 1fr);
      gap: 6px;
      padding: 8px 10px;
      border: 1px solid var(--border);
      border-radius: 10px;
      background: var(--surface);
      box-shadow: 0 6px 12px rgba(0,0,0,0.1);
    }
    .commenter-row-top {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 8px;
    }
    .commenter-row-name {
      font-size: 13px;
      font-weight: 600;
      color: var(--text);
      min-width: 0;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }
    .commenter-row-last-seen {
      font-size: 10px;
      color: var(--text-muted);
      white-space: nowrap;
      flex-shrink: 0;
    }
    .commenter-row-bottom {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 8px;
      min-width: 0;
    }
    .commenter-row-meta {
      font-size: 11px;
      color: var(--text-muted);
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
      min-width: 0;
      flex: 1;
    }
    .commenter-row-actions {
      display: flex;
      align-items: center;
      gap: 6px;
      flex-shrink: 0;
    }
    .commenter-mute-btn {
      height: 28px;
      padding: 0 8px;
      font-size: 11px;
      font-weight: 600;
    }
    .commenter-tt-toggle {
      display: inline-flex;
      align-items: center;
      gap: 4px;
      font-size: 11px;
      color: var(--text-secondary);
      border: 1px solid var(--border);
      border-radius: 7px;
      height: 28px;
      padding: 0 8px;
      background: color-mix(in oklab, var(--surface) 94%, var(--bg) 6%);
    }
    .commenter-tt-toggle input {
      width: auto;
      margin: 0;
    }
    .commenter-list-meta {
      margin: -6px 0 10px;
      font-size: 12px;
    }

    /* PILL / CHIP */
    .pill {
      display: inline-flex;
      align-items: center;
      height: 22px;
      padding: 0 8px;
      border-radius: 999px;
      border: 1px solid var(--border);
      font-size: 11px;
      font-weight: 500;
      color: var(--text-muted);
      margin-left: 4px;
    }
    .pill.sf {
      color: var(--gold);
      border-color: var(--gold);
      background: var(--gold-soft);
    }
    .chip {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      height: 28px;
      padding: 0 11px;
      border-radius: 999px;
      border: 1px solid var(--border);
      font-size: 12px;
      font-weight: 500;
      letter-spacing: -0.005em;
      color: var(--text-secondary);
      background: var(--surface);
      box-shadow: var(--shadow-sm);
    }
    .chip.live {
      border-color: var(--accent);
      color: var(--accent);
      background: var(--accent-soft);
    }
    .chip.gift {
      border-color: var(--gold);
      color: var(--gold);
      background: var(--gold-soft);
    }
    .chip.backend-browser { border-color: #6b7280; color: #6b7280; }
    .chip.backend-openai { border-color: var(--accent); color: var(--accent); }
    .chip.backend-elevenlabs { border-color: #3b82f6; color: #3b82f6; }
    .chip.backend-cartesia { border-color: #8b5cf6; color: #8b5cf6; }
    .chip.backend-fish { border-color: #3b82f6; color: #3b82f6; }
    .chip.metric-chip {
      height: 30px;
      font-weight: 600;
      color: var(--text);
      background: color-mix(in oklab, var(--surface) 95%, white 5%);
    }

    /* APP STATUS */
    .app-status-bar {
      display: grid;
      gap: 10px;
      padding: 14px 18px;
      border: 1px solid var(--border);
      border-radius: var(--radius-lg);
      background: var(--surface);
      box-shadow: var(--shadow-sm);
    }
    .status-chip-group,
    .status-metrics {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      align-items: center;
    }

    /* SUBPANEL */
    .subpanel {
      border: 1px solid var(--border);
      border-radius: var(--radius-md);
      padding: 18px;
      background: var(--surface-soft);
    }
    .subpanel + .subpanel { margin-top: 16px; }

    /* GIFT CONFIG */
    .gift-config-grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 12px;
    }
    .mapping-top {
      display: grid;
      grid-template-columns: 48px 1fr;
      gap: 10px;
      align-items: center;
    }
    .gift-thumb {
      width: 48px;
      height: 48px;
      border-radius: 8px;
      border: 1px solid var(--border);
      object-fit: cover;
      display: block;
      background: var(--bg);
    }
    .gift-thumb.fallback {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      font-size: 20px;
    }

    /* VOICE ADD ROW */
    .voice-add-row {
      display: flex;
      gap: 8px;
      align-items: center;
    }
    .voice-add-row input { flex: 1; }
    .voice-add-row input[type="number"] { flex: 0 0 80px; }
    .fish-voice-browser-pager {
      align-items: center;
    }
    .fish-voice-browser-pager button {
      height: 42px;
      border-radius: 14px;
      font-size: 14px;
      font-weight: 600;
      letter-spacing: 0;
      background: color-mix(in oklab, var(--surface) 88%, var(--accent) 12%);
      border-color: color-mix(in oklab, var(--border) 64%, var(--accent) 36%);
      box-shadow: 0 8px 18px rgba(0,0,0,0.2), inset 0 1px 0 rgba(255,255,255,0.07);
    }
    .fish-voice-browser-pager button:hover {
      background: color-mix(in oklab, var(--surface-soft) 82%, var(--accent) 18%);
      border-color: color-mix(in oklab, var(--border-strong) 62%, var(--accent) 38%);
    }
    .fish-voice-browser-pager button:disabled {
      background: color-mix(in oklab, var(--surface) 95%, var(--bg) 5%);
      border-color: var(--border);
    }
    .fish-voice-browser-pager button {
      min-width: 96px;
    }
    .voice-guide {
      margin-bottom: 14px;
      border: 1px solid var(--border);
      border-radius: 10px;
      background: color-mix(in oklab, var(--surface) 94%, var(--accent-soft) 6%);
      padding: 0;
    }
    .voice-guide summary {
      display: flex;
      align-items: center;
      gap: 8px;
      padding: 10px 12px;
      font-size: 12px;
      font-weight: 600;
      color: var(--text-muted);
      cursor: pointer;
      user-select: none;
      list-style: none;
      transition: color 150ms ease;
    }
    .voice-guide summary::-webkit-details-marker { display: none; }
    .voice-guide summary::after {
      content: ">";
      display: inline-block;
      margin-left: auto;
      font-size: 11px;
      font-weight: 700;
      color: var(--text-muted);
      transition: transform 150ms ease;
    }
    .voice-guide[open] summary::after {
      transform: rotate(90deg);
    }
    .voice-guide summary:hover { color: var(--text-secondary); }
    .voice-guide ol {
      margin: 0;
      padding: 0 12px 10px 30px;
      display: grid;
      gap: 3px;
    }
    .voice-guide li {
      color: var(--text-muted);
      font-size: 12.5px;
      line-height: 1.35;
    }
    .fish-clone-panel {
      margin-top: 10px;
      border: 1px solid var(--border);
      border-radius: 10px;
      padding: 10px;
      background: var(--bg);
      display: grid;
      gap: 8px;
    }
    .fish-clone-recorder-row {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      align-items: center;
    }
    .fish-clone-recorder-list {
      max-height: 220px;
    }
    .fish-clone-recorder-list audio {
      width: 100%;
      margin-top: 4px;
    }
    .fish-clone-status-row {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      align-items: center;
    }
    .fish-clone-chip {
      display: inline-flex;
      align-items: center;
      border: 1px solid var(--border);
      border-radius: 999px;
      padding: 2px 8px;
      font-size: 11px;
      color: var(--text-muted);
      background: var(--surface);
    }
    .fish-clone-chip.state-trained {
      border-color: var(--ok);
      color: var(--ok);
      background: color-mix(in oklab, var(--ok) 14%, var(--surface) 86%);
    }
    .fish-clone-chip.state-training,
    .fish-clone-chip.state-created {
      border-color: var(--accent);
      color: var(--accent);
      background: color-mix(in oklab, var(--accent) 14%, var(--surface) 86%);
    }
    .fish-clone-chip.state-failed {
      border-color: var(--danger);
      color: var(--danger);
      background: color-mix(in oklab, var(--danger) 14%, var(--surface) 86%);
    }
    .fish-voice-status-badge {
      display: inline-flex;
      align-items: center;
      border: 1px solid var(--border);
      border-radius: 999px;
      padding: 1px 7px;
      font-size: 11px;
      color: var(--text-muted);
      background: var(--surface);
      margin-left: 6px;
    }
    .fish-voice-status-badge.state-trained {
      border-color: var(--ok);
      color: var(--ok);
    }
    .fish-voice-status-badge.state-training,
    .fish-voice-status-badge.state-created {
      border-color: var(--accent);
      color: var(--accent);
    }
    .fish-voice-status-badge.state-failed {
      border-color: var(--danger);
      color: var(--danger);
    }
    #fishVoiceBrowseList {
      max-height: 260px;
      padding: 8px;
      background: var(--bg);
    }
    #fishVoiceBrowseList .voice-row {
      border: 1px solid var(--border);
      border-radius: 10px;
      margin-bottom: 8px;
      background: var(--surface);
    }
    #fishVoiceBrowseList .voice-row:last-child {
      margin-bottom: 0;
    }
    #fishVoiceBrowseList .voice-row.voice-row--fish-browse {
      gap: 8px;
      padding: 12px 14px;
    }
    .voice-browse-top {
      display: grid;
      grid-template-columns: minmax(0, 1fr) auto;
      gap: 10px;
      align-items: start;
    }
    .voice-browse-title-wrap {
      min-width: 0;
    }
    .voice-browse-title-line {
      display: flex;
      flex-wrap: wrap;
      align-items: center;
      gap: 6px;
    }
    .voice-browse-title {
      min-width: 0;
      font-size: 15px;
      line-height: 1.3;
      letter-spacing: 0;
      overflow-wrap: break-word;
    }
    .voice-browse-author {
      margin-top: 2px;
      line-height: 1.3;
      overflow-wrap: break-word;
    }
    .voice-browse-actions {
      justify-content: flex-end;
      margin-top: 0;
      margin-left: auto;
    }
    .voice-browse-meta {
      display: flex;
      flex-wrap: wrap;
      gap: 6px 8px;
      font-size: 12px;
      line-height: 1.35;
    }
    .voice-browse-meta > span {
      display: inline-flex;
      align-items: center;
      padding: 3px 8px;
      border-radius: 999px;
      border: 1px solid color-mix(in oklab, var(--border) 68%, var(--accent) 32%);
      background: color-mix(in oklab, var(--surface) 75%, var(--accent) 25%);
    }
    .voice-browse-preview {
      font-size: 12px;
      line-height: 1.4;
      display: -webkit-box;
      -webkit-line-clamp: 2;
      -webkit-box-orient: vertical;
      overflow: hidden;
    }
    .voice-browse-tags {
      font-size: 12px;
      line-height: 1.35;
      overflow-wrap: anywhere;
    }

    /* GIFT COMPACT ROW */
    .gift-compact-row {
      display: flex;
      gap: 8px;
      align-items: center;
      flex-wrap: wrap;
    }
    .gift-follow-inline .gift-compact-row > * {
      min-width: 0;
    }
    /* FOLLOW SOUND GRID */
    .follow-sound-grid {
      display: flex;
      gap: 12px;
      align-items: flex-end;
      flex-wrap: wrap;
    }
    .follow-sound-field {
      flex: 1;
      min-width: 140px;
    }
    .follow-sound-field label {
      margin-bottom: 4px;
    }
    .follow-sound-actions {
      min-width: auto;
    }
    /* COLLAPSIBLE SECTIONS */
    .collapse-card { padding: 0; }
    .collapse-card[open] {
      border-color: color-mix(in oklab, var(--border) 70%, var(--accent) 30%);
    }
    .collapse-summary {
      display: flex;
      align-items: center;
      padding: 18px 22px;
      font-size: 14px;
      font-weight: 600;
      letter-spacing: -0.01em;
      color: var(--text);
      cursor: pointer;
      user-select: none;
      list-style: none;
      transition: color 150ms ease, background 150ms ease;
      border-radius: var(--radius-lg);
    }
    .collapse-summary::-webkit-details-marker { display: none; }
    .collapse-summary::before {
      content: "";
      display: inline-block;
      width: 6px;
      height: 6px;
      margin-right: 12px;
      border-right: 2px solid var(--text-muted);
      border-bottom: 2px solid var(--text-muted);
      transform: rotate(-45deg);
      transition: transform 150ms ease;
      flex-shrink: 0;
    }
    details[open] > .collapse-summary::before {
      transform: rotate(45deg);
    }
    .collapse-summary:hover {
      color: var(--text);
      background: var(--bg);
    }
    .collapse-body {
      padding: 0 22px 22px;
    }

    .metric-note { font-size: 12px; color: var(--text-secondary); }

    .section-note { margin: 0 0 12px; }
    .onboarding-auto-hint {
      margin-top: 8px;
      padding: 10px 12px;
      border: 1px solid var(--border);
      border-radius: 10px;
      background: var(--surface-soft);
      color: var(--text-secondary);
      font-size: 13px;
      line-height: 1.4;
    }
    .onboarding-checklist {
      list-style: none;
      display: grid;
      gap: 8px;
      margin: 0 0 14px;
      padding: 0;
    }
    .onboarding-check-item {
      display: flex;
      align-items: center;
      gap: 8px;
      font-size: 13px;
      color: var(--text-secondary);
      border: 1px solid var(--border);
      border-radius: 10px;
      padding: 9px 11px;
      background: var(--surface-soft);
    }
    .onboarding-check-item::before {
      content: '';
      width: 9px;
      height: 9px;
      border-radius: 999px;
      background: var(--text-muted);
      opacity: 0.7;
      flex: 0 0 9px;
    }
    .onboarding-check-item.is-active {
      border-color: color-mix(in oklab, var(--accent) 50%, var(--border));
      color: var(--text);
    }
    .onboarding-check-item.is-active::before {
      background: var(--accent);
    }
    .onboarding-check-item.is-complete {
      border-color: color-mix(in oklab, var(--success) 50%, var(--border));
      color: color-mix(in oklab, var(--success) 72%, var(--text));
    }
    .onboarding-check-item.is-complete::before {
      background: var(--success);
    }

    .sound-lab-grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 12px;
      align-items: start;
    }
    .studio-form-grid {
      grid-template-columns: repeat(2, 1fr);
    }
    .gift-map-grid {
      grid-template-columns: repeat(2, 1fr);
    }

    /* ANALYTICS */
    .analytics-view {
      display: grid;
      gap: 16px;
    }
    .analytics-toolbar {
      display: flex;
      align-items: flex-end;
      justify-content: space-between;
      gap: 16px;
    }
    .analytics-league-card {
      display: grid;
      gap: 10px;
      padding: 14px 16px;
    }
    .analytics-league-row {
      display: flex;
      align-items: center;
      gap: 10px;
      flex-wrap: wrap;
    }
    .analytics-league-select-wrap {
      display: flex;
      align-items: center;
      gap: 8px;
      flex: 0 0 auto;
    }
    .analytics-league-select-wrap select {
      width: auto;
      min-width: 84px;
    }
    .analytics-league-row .nav-league-stats {
      flex: 1 1 460px;
    }
    .analytics-range { width: 160px; }
    .analytics-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 12px;
    }
    .analytics-kpi {
      display: grid;
      gap: 6px;
      padding: 20px;
      border: 1px solid var(--border);
      border-radius: var(--radius-lg);
      background: var(--surface);
      box-shadow: var(--shadow-sm);
      position: relative;
      overflow: hidden;
      transition: border-color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
    }
    .analytics-kpi:hover {
      border-color: var(--border-strong);
      box-shadow: var(--shadow-md);
      transform: translateY(-1px);
    }
    .analytics-kpi-value-row {
      display: flex;
      align-items: baseline;
      gap: 8px;
      flex-wrap: wrap;
    }
    .analytics-kpi-value {
      font-size: clamp(22px, 2vw, 30px);
      font-weight: 700;
      letter-spacing: -0.02em;
      color: var(--text);
    }
    .analytics-kpi-trend {
      display: inline-flex;
      align-items: center;
      gap: 2px;
      padding: 1px 7px;
      border-radius: 999px;
      font-size: 11px;
      font-weight: 700;
      letter-spacing: -0.01em;
      white-space: nowrap;
      line-height: 1.6;
    }
    .analytics-kpi-trend.up {
      color: #166534;
      background: rgba(22, 163, 74, 0.1);
    }
    .analytics-kpi-trend.down {
      color: #991b1b;
      background: rgba(220, 38, 38, 0.08);
    }
    .analytics-kpi-trend.neutral {
      color: var(--text-muted);
      background: var(--bg);
    }
    [data-theme="dark"] .analytics-kpi-trend.up {
      color: #4ade80;
      background: rgba(74, 222, 128, 0.12);
    }
    [data-theme="dark"] .analytics-kpi-trend.down {
      color: #fca5a5;
      background: rgba(252, 165, 165, 0.1);
    }
    .analytics-kpi-note {
      font-size: 12px;
      color: var(--text-secondary);
      line-height: 1.45;
    }
    .analytics-charts {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 16px;
    }
    .chart-card, .analytics-table-card {
      display: grid;
      gap: 16px;
      padding: 22px;
      border: 1px solid var(--border);
      border-radius: var(--radius-lg);
      background: var(--surface);
      box-shadow: var(--shadow-sm);
    }
    .chart-header {
      display: flex;
      align-items: flex-start;
      justify-content: space-between;
      gap: 12px;
    }
    .chart-title {
      font-family: 'Space Grotesk', 'Inter', sans-serif;
      font-size: 16px;
      font-weight: 650;
      color: var(--text);
    }
    .chart-subtitle {
      margin-top: 4px;
      font-size: 12.5px;
      color: var(--text-secondary);
      line-height: 1.45;
    }
    .chart-svg {
      display: block;
      width: 100%;
      height: 240px;
      border: 1px solid var(--border);
      border-radius: 8px;
      background: var(--bg);
    }
    .chart-shell { position: relative; }
    .chart-tooltip {
      position: absolute;
      z-index: 10;
      min-width: 140px;
      max-width: 220px;
      padding: 10px 12px;
      border: 1px solid var(--border);
      border-radius: 8px;
      background: var(--surface);
      box-shadow: 0 8px 24px rgba(0,0,0,0.12);
      font-size: 12px;
      color: var(--text);
      pointer-events: none;
      opacity: 0;
      transform: translateY(4px);
      transition: opacity 120ms ease, transform 120ms ease;
    }
    .chart-tooltip.visible { opacity: 1; transform: translateY(0); }
    .chart-tooltip-title { margin-bottom: 4px; font-weight: 600; color: var(--text); }
    .chart-tooltip-row {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      margin-top: 4px;
      color: var(--text-secondary);
    }
    .chart-tooltip-dot {
      width: 8px;
      height: 8px;
      border-radius: 999px;
      margin-right: 6px;
      display: inline-block;
      vertical-align: middle;
    }
    .chart-empty {
      display: flex;
      align-items: center;
      justify-content: center;
      min-height: 200px;
      border: 1px solid var(--border);
      border-radius: 8px;
      background: var(--bg);
      color: var(--text-muted);
      font-size: 13px;
    }
    .analytics-secondary-grid {
      display: grid;
      grid-template-columns: 1.1fr 1fr 0.9fr;
      gap: 16px;
    }
    .analytics-custom-builder {
      display: grid;
      gap: 14px;
    }
    .analytics-custom-controls {
      display: grid;
      grid-template-columns: minmax(0, 1fr) 170px auto;
      gap: 10px;
      align-items: end;
    }
    .analytics-custom-controls input,
    .analytics-custom-controls select {
      width: 100%;
    }
    .analytics-custom-prompt-wrap {
      position: relative;
    }
    .analytics-custom-typeahead {
      position: absolute;
      left: 0;
      right: 0;
      top: calc(100% + 6px);
      z-index: 20;
      border: 1px solid var(--border);
      border-radius: 10px;
      background: var(--surface);
      box-shadow: var(--shadow);
      max-height: 260px;
      overflow: auto;
      padding: 4px;
      display: grid;
      gap: 2px;
    }
    .analytics-custom-typeahead[hidden] {
      display: none;
    }
    .analytics-custom-typeahead-item {
      border: 0;
      background: transparent;
      color: var(--text);
      text-align: left;
      border-radius: 8px;
      padding: 8px 10px;
      display: grid;
      grid-template-columns: minmax(0, 1fr) auto;
      gap: 8px;
      align-items: center;
      cursor: pointer;
    }
    .analytics-custom-typeahead-item:hover,
    .analytics-custom-typeahead-item.active {
      background: var(--bg);
    }
    .analytics-custom-typeahead-main {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      min-width: 0;
    }
    .analytics-custom-typeahead-thumb {
      width: 20px;
      height: 20px;
      border-radius: 5px;
      object-fit: cover;
      border: 1px solid var(--border);
      flex: 0 0 auto;
      background: var(--bg);
    }
    .analytics-custom-typeahead-label {
      color: var(--text);
      font-weight: 600;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
    }
    .analytics-custom-typeahead-meta {
      color: var(--text-muted);
      font-size: 11px;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
    }
    .analytics-custom-typeahead-token {
      color: var(--accent);
      font-size: 11px;
      font-weight: 700;
      white-space: nowrap;
    }
    .analytics-custom-suggestions {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
    }
    .analytics-custom-suggestions .tiny {
      border-radius: 999px;
      padding-inline: 12px;
      font-size: 12px;
    }
    .analytics-custom-ai {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      font-size: 12px;
      color: var(--text-secondary);
      margin-top: 2px;
    }
    .analytics-custom-ai input[type="checkbox"] {
      width: 16px;
      height: 16px;
      margin: 0;
    }
    .analytics-custom-plan {
      border: 1px dashed var(--border);
      border-radius: 8px;
      background: var(--bg);
      padding: 10px 12px;
      font-size: 12px;
      line-height: 1.45;
      color: var(--text-secondary);
    }
    .analytics-custom-output {
      border: 1px solid var(--border);
      border-radius: 10px;
      background: var(--surface);
      min-height: 220px;
      padding: 12px;
    }
    .analytics-custom-bars {
      display: grid;
      gap: 10px;
    }
    .analytics-custom-bar-row {
      display: grid;
      grid-template-columns: minmax(130px, 200px) minmax(0, 1fr) auto;
      gap: 10px;
      align-items: center;
    }
    .analytics-custom-bar-label {
      font-size: 12px;
      color: var(--text-secondary);
      font-weight: 600;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }
    .analytics-custom-bar-stack {
      display: grid;
      gap: 6px;
    }
    .analytics-custom-bar-track {
      height: 9px;
      border-radius: 999px;
      background: var(--bg);
      overflow: hidden;
    }
    .analytics-custom-bar-fill {
      height: 100%;
      border-radius: 999px;
      min-width: 2px;
    }
    .analytics-custom-bar-fill.secondary {
      opacity: 0.82;
    }
    .analytics-custom-bar-value {
      font-size: 12px;
      color: var(--text);
      font-weight: 700;
      font-variant-numeric: tabular-nums;
      text-align: right;
      white-space: nowrap;
    }
    .analytics-custom-table {
      border: 1px solid var(--border);
      border-radius: 8px;
      overflow: hidden;
    }
    .analytics-custom-table-head,
    .analytics-custom-table-row {
      display: grid;
      gap: 10px;
      align-items: center;
      padding: 9px 12px;
      border-bottom: 1px solid var(--border);
      grid-template-columns: minmax(120px, 1fr) repeat(var(--analytics-custom-col-count, 1), minmax(90px, auto));
      font-size: 12px;
    }
    .analytics-custom-table-head {
      font-size: 11px;
      letter-spacing: 0.04em;
      text-transform: uppercase;
      color: var(--text-muted);
      background: var(--bg);
      font-weight: 700;
    }
    .analytics-custom-table-row:last-child {
      border-bottom: 0;
    }
    .analytics-custom-table-label {
      color: var(--text);
      font-weight: 600;
      min-width: 0;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
    }
    .analytics-custom-table-label.allow-wrap {
      white-space: normal;
      overflow: visible;
      text-overflow: clip;
      word-break: break-word;
      line-height: 1.35;
    }
    .analytics-custom-label-with-thumb {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      max-width: 100%;
      min-width: 0;
    }
    .analytics-custom-label-thumb {
      width: 24px;
      height: 24px;
      border-radius: 6px;
      object-fit: cover;
      border: 1px solid var(--border);
      background: var(--bg);
      flex: 0 0 auto;
    }
    .analytics-custom-label-text {
      min-width: 0;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
    }
    .analytics-custom-table-label.allow-wrap .analytics-custom-label-text {
      white-space: normal;
      overflow: visible;
      text-overflow: clip;
      word-break: break-word;
    }
    .analytics-custom-table-cell {
      color: var(--text-secondary);
      text-align: right;
      font-variant-numeric: tabular-nums;
    }
    .insight-card {
      display: grid;
      gap: 12px;
      padding: 22px;
      border: 1px solid var(--border);
      border-radius: var(--radius-lg);
      background: var(--surface);
      box-shadow: var(--shadow-sm);
    }
    .insight-value {
      font-size: 28px;
      font-weight: 700;
      letter-spacing: -0.02em;
      color: var(--text);
    }
    .insight-note {
      font-size: 13px;
      color: var(--text-secondary);
      line-height: 1.5;
    }
    .best-times-grid {
      display: grid;
      grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
      gap: 16px;
    }
    .best-times-description {
      margin: 4px 0 14px;
      font-size: 13px;
      color: var(--text-secondary);
      line-height: 1.45;
    }
    .best-times-panel-label {
      display: block;
      margin-bottom: 8px;
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 0.06em;
      text-transform: uppercase;
      color: var(--text-muted);
    }
    .best-times-list {
      border: 1px solid var(--border);
      border-radius: 8px;
      overflow: auto;
      background: var(--surface);
      padding: 8px;
      display: grid;
      gap: 8px;
    }
    .best-time-row {
      display: grid;
      grid-template-columns: 30px minmax(0, 1fr) auto;
      align-items: center;
      gap: 10px;
      padding: 10px 12px;
      border: 1px solid var(--border);
      border-radius: 8px;
      background: var(--bg);
    }
    .best-time-row:hover { border-color: var(--border-strong); }
    .best-time-rank {
      width: 28px;
      height: 28px;
      border-radius: 8px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      font-size: 12px;
      font-weight: 700;
      color: var(--text-secondary);
      background: var(--surface);
      border: 1px solid var(--border);
    }
    .best-time-title { font-weight: 700; color: var(--text); font-size: 14px; }
    .best-time-window {
      margin-top: 2px;
      font-size: 12px;
      color: var(--accent);
      font-weight: 600;
    }
    .best-time-meta { margin-top: 3px; font-size: 12px; color: var(--text-secondary); line-height: 1.4; }
    .confidence-chip {
      display: inline-flex;
      align-items: center;
      height: 24px;
      padding: 0 8px;
      border-radius: 999px;
      border: 1px solid var(--border);
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 0.02em;
      white-space: nowrap;
      color: var(--text-secondary);
      background: var(--surface);
    }
    .confidence-chip.high {
      color: #166534;
      border-color: rgba(22, 101, 52, 0.3);
      background: rgba(22, 163, 74, 0.12);
    }
    .confidence-chip.medium {
      color: #92400e;
      border-color: rgba(146, 64, 14, 0.3);
      background: rgba(245, 158, 11, 0.16);
    }
    .confidence-chip.low {
      color: #1f2937;
      border-color: rgba(31, 41, 55, 0.24);
      background: rgba(148, 163, 184, 0.14);
    }
    .best-day-cards {
      border: 1px solid var(--border);
      border-radius: 8px;
      background: var(--surface);
      padding: 8px;
      display: grid;
      gap: 8px;
    }
    .best-day-card {
      border: 1px solid var(--border);
      border-radius: 8px;
      background: var(--bg);
      padding: 10px 12px;
      display: grid;
      gap: 4px;
    }
    .best-day-card.best {
      border-color: rgba(18,108,97,0.35);
      box-shadow: inset 0 0 0 1px rgba(18,108,97,0.12);
    }
    .best-day-head {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 8px;
    }
    .best-day-name {
      font-size: 13px;
      font-weight: 700;
      color: var(--text);
    }
    .best-day-viewers {
      font-size: 12px;
      color: var(--text-secondary);
    }
    .best-day-window {
      font-size: 13px;
      color: var(--accent);
      font-weight: 600;
    }
    .best-day-meta {
      font-size: 12px;
      color: var(--text-secondary);
    }
    .best-day-windows {
      margin-top: 6px;
      display: grid;
      gap: 6px;
    }
    .best-day-window-row {
      display: grid;
      grid-template-columns: 24px minmax(0, 1fr) auto;
      align-items: start;
      gap: 8px;
      border: 1px solid var(--border);
      border-radius: 8px;
      padding: 8px 10px;
      background: var(--surface);
    }
    .best-day-window-rank {
      width: 20px;
      height: 20px;
      border-radius: 999px;
      border: 1px solid var(--border);
      background: var(--bg);
      color: var(--text-secondary);
      font-size: 11px;
      font-weight: 700;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      margin-top: 1px;
    }
    .best-day-window-title {
      font-size: 13px;
      font-weight: 700;
      color: var(--text);
    }
    .best-day-window-reason {
      margin-top: 2px;
      font-size: 12px;
      color: var(--text-secondary);
      line-height: 1.4;
    }
    .retention-bars { display: grid; gap: 8px; }
    .retention-bar {
      display: grid;
      grid-template-columns: 72px minmax(0, 1fr) auto;
      gap: 10px;
      align-items: center;
    }
    .retention-bar-track {
      height: 10px;
      border-radius: 999px;
      background: var(--bg);
      overflow: hidden;
    }
    .retention-bar-fill {
      height: 100%;
      background: var(--accent);
      border-radius: 999px;
    }
    .leaderboard-grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 16px;
    }
    .leaderboard-list, .analytics-table {
      border: 1px solid var(--border);
      border-radius: 8px;
      overflow: hidden;
      background: var(--surface);
    }
    .leaderboard-row, .analytics-table-row {
      display: grid;
      gap: 10px;
      align-items: center;
      padding: 11px 14px;
      border-bottom: 1px solid var(--border);
    }
    .leaderboard-row { grid-template-columns: 32px minmax(0, 1fr) auto; }
    .analytics-table-row {
      grid-template-columns: 100px minmax(0, 1fr) repeat(5, minmax(64px, auto));
      font-size: 12.5px;
    }
    .leaderboard-row:last-child, .analytics-table-row:last-child { border-bottom: 0; }
    .leaderboard-rank {
      width: 26px;
      height: 26px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      border-radius: 6px;
      background: var(--bg);
      font-size: 12px;
      font-weight: 700;
      color: var(--text-secondary);
    }
    .leaderboard-name, .analytics-session-label {
      min-width: 0;
      font-weight: 600;
      color: var(--text);
      font-size: 13px;
    }
    .leaderboard-meta {
      color: var(--text-muted);
      font-size: 12px;
    }
    .analytics-table-head {
      display: grid;
      grid-template-columns: 100px minmax(0, 1fr) repeat(5, minmax(64px, auto));
      gap: 10px;
      padding: 10px 14px;
      border-bottom: 1px solid var(--border);
      background: var(--bg);
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 0.06em;
      text-transform: uppercase;
      color: var(--text-muted);
    }
    .analytics-empty {
      padding: 20px 16px;
      color: var(--text-muted);
      font-size: 13px;
    }

    /* Chart crosshair & dot highlights */
    .chart-crosshair-line {
      pointer-events: none;
      transition: opacity 80ms ease;
    }
    .chart-highlight-dot {
      pointer-events: none;
      transition: opacity 80ms ease;
    }

    /* Retention bar color variants */
    .retention-bar-fill.rt-0 { background: #ef4444; }
    .retention-bar-fill.rt-1 { background: #f59e0b; }
    .retention-bar-fill.rt-2 { background: #eab308; }
    .retention-bar-fill.rt-3 { background: #22c55e; }
    .retention-bar-fill.rt-4 { background: var(--accent); }
    .retention-bar-count {
      font-size: 11px;
      color: var(--text-muted);
      font-variant-numeric: tabular-nums;
    }
    .retention-bar {
      transition: transform 100ms ease;
    }
    .retention-bar:hover {
      transform: translateX(2px);
    }

    /* Leaderboard medal ranks */
    .leaderboard-rank.gold {
      background: #fef3c7;
      color: #92400e;
      border: 1px solid rgba(180, 83, 9, 0.25);
      font-weight: 800;
    }
    .leaderboard-rank.silver {
      background: #f1f5f9;
      color: #475569;
      border: 1px solid rgba(100, 116, 139, 0.25);
      font-weight: 800;
    }
    .leaderboard-rank.bronze {
      background: #fff7ed;
      color: #9a3412;
      border: 1px solid rgba(194, 65, 12, 0.2);
      font-weight: 800;
    }
    [data-theme="dark"] .leaderboard-rank.gold {
      background: rgba(251, 191, 36, 0.15);
      color: #fbbf24;
      border-color: rgba(251, 191, 36, 0.3);
    }
    [data-theme="dark"] .leaderboard-rank.silver {
      background: rgba(148, 163, 184, 0.12);
      color: #94a3b8;
      border-color: rgba(148, 163, 184, 0.25);
    }
    [data-theme="dark"] .leaderboard-rank.bronze {
      background: rgba(251, 146, 60, 0.12);
      color: #fb923c;
      border-color: rgba(251, 146, 60, 0.25);
    }

    /* Session row enhancements */
    .analytics-table-row {
      transition: background 100ms ease;
    }
    .analytics-table-row:hover {
      background: var(--accent-soft);
    }
    .analytics-table-row.session-best {
      background: rgba(13, 148, 136, 0.05);
    }
    .session-best-badge {
      display: inline-flex;
      align-items: center;
      gap: 3px;
      padding: 1px 6px;
      border-radius: 999px;
      font-size: 10px;
      font-weight: 700;
      color: #166534;
      background: rgba(22, 163, 74, 0.1);
      letter-spacing: 0.02em;
      text-transform: uppercase;
      margin-left: 6px;
    }
    [data-theme="dark"] .session-best-badge {
      color: #4ade80;
      background: rgba(74, 222, 128, 0.12);
    }

    /* Period tab buttons */
    .analytics-period-tabs {
      display: flex;
      border: 1px solid var(--border);
      border-radius: 10px;
      overflow: hidden;
      background: var(--bg);
    }
    .analytics-period-tab {
      padding: 7px 16px;
      border: none;
      background: transparent;
      color: var(--text-secondary);
      font-family: inherit;
      font-size: 12.5px;
      font-weight: 600;
      cursor: pointer;
      transition: all 120ms ease;
      position: relative;
    }
    .analytics-period-tab:not(:last-child)::after {
      content: '';
      position: absolute;
      right: 0;
      top: 20%;
      height: 60%;
      width: 1px;
      background: var(--border);
    }
    .analytics-period-tab.active {
      background: var(--accent);
      color: white;
    }
    .analytics-period-tab.active::after { display: none; }
    .analytics-period-tab:hover:not(.active) {
      background: var(--surface);
      color: var(--text);
    }

    /* Comparison summary strip */
    .analytics-comparison {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
      gap: 2px;
      border: 1px solid var(--border);
      border-radius: 12px;
      overflow: hidden;
      background: var(--border);
    }
    .analytics-comparison-item {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      padding: 12px 14px;
      font-size: 12.5px;
      color: var(--text-secondary);
      background: var(--surface);
    }
    .analytics-comparison-label {
      font-weight: 500;
    }
    .analytics-comparison-change {
      font-weight: 700;
      font-variant-numeric: tabular-nums;
    }
    .analytics-comparison-change.up { color: #16a34a; }
    .analytics-comparison-change.down { color: #dc2626; }
    .analytics-comparison-change.neutral { color: var(--text-muted); }
    [data-theme="dark"] .analytics-comparison-change.up { color: #4ade80; }
    [data-theme="dark"] .analytics-comparison-change.down { color: #fca5a5; }

    /* Chart legend pills */
    .chart-legend {
      display: flex;
      flex-wrap: wrap;
      gap: 12px;
      margin-top: 10px;
    }
    .chart-legend-item {
      display: flex;
      align-items: center;
      gap: 6px;
      font-size: 12px;
      color: var(--text-secondary);
    }
    .chart-legend-dot {
      width: 10px;
      height: 3px;
      border-radius: 2px;
    }

    .kpi {
      display: flex;
      flex-wrap: wrap;
      gap: 6px;
      justify-content: flex-end;
    }

    /* Panel header shared */
    .panel-header {
      margin-bottom: 16px;
    }
    .panel-header h2 {
      font-family: 'Space Grotesk', 'Inter', sans-serif;
      font-size: 24px;
      letter-spacing: -0.02em;
      line-height: 1.1;
    }
    .panel-copy { min-width: 0; }
    .panel-copy p { margin-top: 4px; }
    #studioView > .live-topbar {
      margin-bottom: 0 !important;
    }
    #studioView > .card {
      margin-top: 0 !important;
    }

    @media (min-width: 1025px) {
      #studioView {
        grid-template-columns: 1fr;
        grid-template-areas:
          'top'
          'main'
          'overrides';
        align-items: start;
      }
      #studioView.has-commenters-dock {
        grid-template-columns: minmax(0, 1fr) clamp(220px, 24vw, 280px);
        grid-template-areas:
          'top top'
          'main commenters'
          'overrides overrides';
      }
      #studioView > .live-topbar { grid-area: top; }
      #studioView > .live-columns {
        grid-area: main;
        min-width: 0;
      }
      #studioView > .live-commenters {
        grid-area: commenters;
        position: sticky;
        top: 88px;
        width: clamp(220px, 24vw, 280px);
        margin-top: 0;
        align-self: start;
        justify-self: end;
      }
      #studioView > .card { grid-area: overrides; }
    }

    @media (max-width: 1024px) {
      #studioView {
        grid-template-columns: 1fr;
        grid-template-areas:
          'top'
          'main'
          'commenters'
          'overrides';
      }
      #studioView > .live-topbar { grid-area: top; }
      #studioView > .live-columns { grid-area: main; }
      #studioView > .live-commenters { grid-area: commenters; }
      #studioView > .card { grid-area: overrides; }
    }

    #appPanel {
      gap: 18px;
    }
    #studioView .card:first-child {
      box-shadow: var(--shadow-float), var(--card-edge-highlight);
    }
    .live-columns {
      grid-template-columns: minmax(280px, 330px) minmax(0, 1fr);
      gap: 18px;
      align-items: stretch;
    }
    .live-sidebar .card {
      border-radius: 14px;
    }
    #settingsView {
      display: block;
    }
    .settings-columns {
      display: grid;
      grid-template-columns: 240px minmax(0, 1fr);
      gap: 16px;
      align-items: start;
    }
    .settings-sidebar {
      position: sticky;
      top: 80px;
      display: grid;
      gap: 10px;
      padding: 16px;
    }
    .settings-sidebar h3 {
      margin: 0;
      font-size: 18px;
      font-family: 'Space Grotesk', 'Inter', sans-serif;
      letter-spacing: -0.01em;
    }
    .settings-nav {
      display: grid;
      gap: 8px;
      margin-top: 4px;
    }
    .settings-nav-btn {
      width: 100%;
      justify-content: flex-start;
      text-align: left;
      height: 38px;
      font-size: 13px;
      border-radius: 10px;
      border-color: color-mix(in oklab, var(--border) 76%, var(--accent) 24%);
      background: color-mix(in oklab, var(--surface) 94%, var(--bg) 6%);
    }
    .settings-nav-btn.active {
      border-color: color-mix(in oklab, var(--accent) 65%, var(--border) 35%);
      background: color-mix(in oklab, var(--surface-soft) 76%, var(--accent) 24%);
      color: var(--text);
    }
    .settings-main {
      min-width: 0;
      display: grid;
      gap: 16px;
    }
    .settings-panel {
      display: none;
    }
    .settings-panel.is-active {
      display: block;
    }
    .settings-panel--utility {
      display: none !important;
    }
    #settingsView .card,
    #settingsView details.card {
      border-radius: 14px;
      border-color: color-mix(in oklab, var(--border) 92%, var(--accent) 8%);
      box-shadow: var(--shadow-float), var(--card-edge-highlight);
    }
    #settingsView h2 {
      font-family: 'Space Grotesk', 'Inter', sans-serif;
      font-size: 22px;
      letter-spacing: -0.015em;
      margin-bottom: 4px !important;
    }
    #settingsView .card-desc {
      font-size: 13px;
      color: var(--text-muted);
      margin: 0 0 16px;
      line-height: 1.5;
    }
    #settingsView .sub-section {
      margin-top: 20px;
      padding-top: 20px;
      border-top: 1px solid var(--border);
    }
    #settingsView .sub-section:first-child {
      margin-top: 0;
      padding-top: 0;
      border-top: none;
    }
    #settingsView .sub-label {
      font-size: 12px;
      font-weight: 600;
      color: var(--text-secondary);
      letter-spacing: 0.02em;
      margin-bottom: 10px;
      display: flex;
      align-items: center;
      gap: 8px;
    }
    #settingsView .sub-label::before {
      content: '';
      width: 3px;
      height: 14px;
      border-radius: 2px;
      background: var(--accent);
      flex-shrink: 0;
    }
    #voiceProfileList {
      padding: 8px;
      background: var(--bg);
    }
    #voiceProfileList .voice-row {
      border: 1px solid var(--border);
      border-radius: 10px;
      margin-bottom: 8px;
      background: var(--surface);
    }
    #voiceProfileList .voice-row:last-child {
      margin-bottom: 0;
    }
    #voiceProfileList .voice-row.voice-row--profile {
      gap: 10px;
      padding: 14px 16px;
      display: grid;
      grid-template-columns: minmax(0, 1fr) auto;
      align-items: center;
    }
    .voice-profile-main {
      min-width: 0;
      display: grid;
      gap: 6px;
    }
    .voice-profile-head {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      align-items: baseline;
      min-width: 0;
    }
    .voice-profile-head strong {
      min-width: 0;
      font-size: 16px;
      line-height: 1.25;
      letter-spacing: 0;
      overflow-wrap: break-word;
    }
    .voice-profile-meta {
      display: flex;
      flex-wrap: wrap;
      gap: 10px 14px;
      align-items: center;
    }
    .voice-profile-status-group {
      display: flex;
      align-items: center;
      gap: 6px;
      min-width: 0;
    }
    .voice-profile-status-group .voice-status {
      font-size: 14px;
      font-weight: 600;
    }
    .voice-profile-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      justify-content: flex-end;
    }
    .voice-profile-actions > * {
      width: auto;
      justify-content: flex-start;
    }
    .voice-profile-actions .field-toggle {
      min-height: 36px;
      padding: 6px 10px;
      gap: 6px;
    }
    #giftMappingList,
    #followSoundMappingCard {
      background: var(--bg);
      padding: 8px;
    }
    #giftMappingList .list-item,
    #followSoundMappingCard .list-item {
      border: 1px solid var(--border);
      border-radius: 10px;
      background: var(--surface);
      margin-bottom: 8px;
    }
    #giftMappingList .list-item:last-child,
    #followSoundMappingCard .list-item:last-child {
      margin-bottom: 0;
    }
    .gift-sound-setup {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 10px;
    }
    .gift-sound-step {
      border: 1px solid var(--border);
      background: color-mix(in oklab, var(--bg) 50%, var(--surface) 50%);
      border-radius: 10px;
      padding: 12px;
      display: flex;
      flex-direction: column;
      min-height: 100%;
    }
    .gift-sound-step .section-tag {
      color: var(--accent);
      margin-bottom: 6px;
    }
    .gift-sound-step select {
      width: 100%;
    }
    #soundLibrarySelectionMeta {
      min-height: 20px;
      line-height: 1.35;
    }

    /* FOOTER */
    .site-footer {
      max-width: 1100px;
      margin: 80px auto 0;
      padding: 32px 16px 48px;
      border-top: 1px solid var(--border);
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 16px;
      flex-wrap: wrap;
    }
    .site-footer-brand {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      color: var(--text-secondary);
      font-size: 13px;
      font-weight: 500;
    }
    .site-footer-brand img {
      width: 22px;
      height: 22px;
      border-radius: 6px;
      padding: 2px;
      background: linear-gradient(135deg, color-mix(in oklab, var(--accent) 18%, transparent), transparent);
      border: 1px solid var(--border);
    }
    .site-footer-links {
      display: inline-flex;
      align-items: center;
      gap: 22px;
      flex-wrap: wrap;
    }
    .site-footer-links a {
      color: var(--text-secondary);
      font-size: 13px;
      text-decoration: none;
      font-weight: 500;
      transition: color 150ms ease;
    }
    .site-footer-links a:hover { color: var(--text); }
    .site-footer-meta {
      font-size: 12.5px;
      color: var(--text-muted);
    }

    /* LIVE PAGE — Ask TT compact strip */
    .ask-tt-card {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 18px;
      padding: 14px 18px;
    }
    .ask-tt-info {
      display: flex;
      align-items: center;
      gap: 14px;
      min-width: 0;
    }
    .ask-tt-icon {
      width: 40px;
      height: 40px;
      flex-shrink: 0;
      border-radius: 12px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      background: color-mix(in oklab, var(--accent) 12%, var(--surface));
      color: var(--accent);
      box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--accent) 22%, transparent);
    }
    .ask-tt-icon svg { width: 20px; height: 20px; }
    .ask-tt-text { min-width: 0; }
    .ask-tt-title {
      font-family: 'Space Grotesk', 'Inter', sans-serif;
      font-size: 15px;
      font-weight: 600;
      letter-spacing: -0.01em;
      color: var(--text);
      line-height: 1.2;
    }
    .ask-tt-sub {
      font-size: 12.5px;
      color: var(--text-secondary);
      margin-top: 2px;
      line-height: 1.4;
    }
    #askTtVoiceBtn {
      flex-shrink: 0;
      height: 42px;
      padding: 0 18px;
      background: var(--text);
      color: var(--bg);
      border-color: var(--text);
      font-weight: 600;
      gap: 8px;
    }
    #askTtVoiceBtn:hover {
      background: color-mix(in oklab, var(--text) 88%, var(--bg));
      border-color: color-mix(in oklab, var(--text) 88%, var(--bg));
      box-shadow: var(--shadow-md);
    }
    #askTtVoiceBtn::before {
      content: '';
      width: 14px;
      height: 14px;
      border-radius: 999px;
      background: var(--accent);
      box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 22%, transparent);
    }

    /* LIVE STATUS BANNER (top of Voice Console) */
    .live-status-banner {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 10px;
      padding: 10px 12px;
      margin: 0 0 14px;
      border-radius: var(--radius);
      border: 1px solid var(--border);
      background: var(--surface-soft);
      font-size: 12.5px;
      font-weight: 500;
      color: var(--text-secondary);
    }
    .live-status-banner.is-live {
      border-color: color-mix(in oklab, var(--accent) 32%, var(--border));
      background: color-mix(in oklab, var(--accent) 6%, var(--surface));
      color: var(--text);
    }
    .live-status-dot {
      width: 8px;
      height: 8px;
      border-radius: 999px;
      background: var(--text-muted);
      flex-shrink: 0;
    }
    .live-status-banner.is-live .live-status-dot {
      background: var(--accent);
      box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 24%, transparent);
      animation: live-pulse 1.6s ease-in-out infinite;
    }
    @keyframes live-pulse {
      0%, 100% { box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 24%, transparent); }
      50% { box-shadow: 0 0 0 6px color-mix(in oklab, var(--accent) 0%, transparent); }
    }
    .live-status-left {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      min-width: 0;
    }
    .live-status-meta {
      font-variant-numeric: tabular-nums;
      font-size: 12px;
      color: var(--text-muted);
    }

    /* CONSOLE rows */
    .console-row {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 10px;
      padding: 10px 0;
      border-bottom: 1px solid var(--border);
    }
    .console-row:last-of-type { border-bottom: 0; }
    .console-row-label {
      font-size: 13px;
      font-weight: 500;
      color: var(--text);
      letter-spacing: -0.005em;
    }
    .console-row-sub {
      font-size: 12px;
      color: var(--text-muted);
      margin-top: 2px;
      line-height: 1.4;
    }
    .console-row-text { min-width: 0; flex: 1; }
    .console-row-control {
      flex-shrink: 0;
      display: inline-flex;
      align-items: center;
      gap: 8px;
    }

    /* iOS-style switch */
    .switch {
      position: relative;
      width: 38px;
      height: 22px;
      flex-shrink: 0;
      cursor: pointer;
      display: inline-block;
    }
    .switch input {
      position: absolute;
      opacity: 0;
      width: 100%;
      height: 100%;
      margin: 0;
      cursor: pointer;
    }
    .switch-track {
      position: absolute;
      inset: 0;
      border-radius: 999px;
      background: var(--border-strong);
      transition: background 180ms ease;
    }
    .switch-track::after {
      content: '';
      position: absolute;
      top: 2px;
      left: 2px;
      width: 18px;
      height: 18px;
      border-radius: 999px;
      background: #fff;
      box-shadow: var(--shadow-sm);
      transition: transform 180ms ease;
    }
    .switch input:checked ~ .switch-track {
      background: var(--accent);
    }
    .switch input:checked ~ .switch-track::after {
      transform: translateX(16px);
    }
    .switch input:focus-visible ~ .switch-track {
      box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 24%, transparent);
    }

    /* Volume row inline */
    .volume-row { padding: 14px 0 12px; }
    .volume-row .console-row-label {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 8px;
    }
    .volume-row #masterVolumeText {
      font-size: 12px;
      font-weight: 500;
      color: var(--text-secondary);
      font-variant-numeric: tabular-nums;
    }
    .volume-row input[type="range"] {
      width: 100%;
      margin-top: 8px;
    }

    /* Inline number stepper */
    .number-stepper {
      display: inline-flex;
      align-items: center;
      gap: 0;
      border: 1px solid var(--border);
      border-radius: var(--radius);
      background: var(--surface);
      box-shadow: var(--shadow-sm);
      overflow: hidden;
    }
    .number-stepper input {
      width: 56px;
      height: 36px;
      border: 0;
      box-shadow: none;
      text-align: center;
      font-weight: 600;
      font-variant-numeric: tabular-nums;
      background: transparent;
      padding: 0;
      border-radius: 0;
    }
    .number-stepper input:focus { box-shadow: none; }

    /* FEED items v2 — avatars + accents */
    .feed { padding: 6px; }
    .feed:empty::before {
      content: 'Comments, gifts, and follows will glow up here once you start listening.';
      display: block;
      padding: 28px 22px;
      color: var(--text-muted);
      font-size: 13.5px;
      line-height: 1.55;
      text-align: center;
    }
    .feed .item, .feed .list-item {
      grid-template-columns: 32px minmax(0, 1fr);
      gap: 10px;
      padding: 12px 14px;
      border-bottom: 0;
      border-radius: var(--radius);
      align-items: start;
      position: relative;
    }
    .feed .item + .item, .feed .list-item + .list-item {
      margin-top: 2px;
    }
    .feed .item:hover, .feed .list-item:hover {
      background: var(--surface);
    }
    .item .head, .list-item .head {
      grid-column: 2;
      font-size: 11.5px;
      color: var(--text-muted);
      font-weight: 500;
    }
    .item .head strong { color: var(--text); font-weight: 600; }
    .item .text {
      grid-column: 2;
      font-size: 14px;
      color: var(--text);
      word-break: break-word;
      line-height: 1.45;
    }
    .item::before {
      content: attr(data-initial);
      grid-row: 1 / span 2;
      width: 32px;
      height: 32px;
      border-radius: 999px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      background: color-mix(in oklab, var(--text) 8%, var(--surface));
      color: var(--text-secondary);
      font-size: 12px;
      font-weight: 700;
      letter-spacing: -0.02em;
      flex-shrink: 0;
    }
    .item.gift {
      background: var(--gold-soft);
      box-shadow: inset 3px 0 0 var(--gold);
    }
    .item.gift::before {
      background: color-mix(in oklab, var(--gold) 18%, var(--surface));
      color: var(--gold);
    }
    .item.follow {
      background: color-mix(in oklab, var(--accent) 5%, var(--surface));
      box-shadow: inset 3px 0 0 var(--accent);
    }
    .item.follow::before {
      background: color-mix(in oklab, var(--accent) 16%, var(--surface));
      color: var(--accent);
    }
    .item.system {
      background: color-mix(in oklab, var(--text) 4%, var(--surface));
      box-shadow: inset 3px 0 0 var(--text-muted);
    }
    .item.system::before {
      background: color-mix(in oklab, var(--text) 10%, var(--surface));
      color: var(--text-secondary);
    }
    .item.system.error {
      background: var(--danger-soft);
      box-shadow: inset 3px 0 0 var(--danger);
    }
    .item.system.error::before { color: var(--danger); }
    .item.system.error .text { color: var(--danger); }

    /* COMMENTER tile refinements */
    .live-commenters {
      width: min(100%, 360px);
      max-width: 360px;
    }
    .commenter-row {
      padding: 10px 12px;
      box-shadow: var(--shadow-sm);
      transition: border-color 150ms ease, transform 150ms ease, box-shadow 150ms ease;
    }
    .commenter-row:hover {
      border-color: var(--border-strong);
      transform: translateX(-2px);
      box-shadow: var(--shadow-md);
    }
    .commenter-row-name {
      font-size: 13px;
    }
    .commenter-mute-btn {
      height: 26px;
      padding: 0 10px;
      font-size: 11px;
      border-radius: 7px;
    }

    /* RESPONSIVE */
    @media (max-width: 1360px) {
      .nav-account {
        display: none;
      }
      .nav-tabs button {
        padding: 7px 12px;
        font-size: 12px;
      }
      .nav-league-chip {
        max-width: 220px;
      }
    }
    @media (max-width: 1024px) {
      .navbar { flex-wrap: wrap; }
      .nav-left { flex: 1 1 auto; }
      .nav-center {
        flex: 1 1 100%;
        order: 3;
        justify-content: flex-start;
        flex-wrap: wrap;
      }
      .nav-tabs-wrap {
        justify-content: flex-start;
      }
      .landing-shell { grid-template-columns: 1fr; }
      .live-columns { grid-template-columns: 1fr; }
      .live-sidebar { position: static; }
      .live-commenters {
        position: static;
        width: auto;
        margin-top: 16px;
      }
      .settings-columns { grid-template-columns: 1fr; }
      .settings-sidebar { position: static; top: auto; }
      .settings-nav { grid-template-columns: repeat(2, minmax(0, 1fr)); }
      .settings-nav-btn { justify-content: center; text-align: center; }
      .analytics-grid { grid-template-columns: repeat(2, 1fr); }
      .analytics-charts { grid-template-columns: 1fr; }
      .analytics-secondary-grid { grid-template-columns: 1fr; }
      .analytics-custom-controls {
        grid-template-columns: 1fr;
      }
      .best-times-grid { grid-template-columns: 1fr; }
      .leaderboard-grid { grid-template-columns: 1fr; }
      .analytics-comparison { grid-template-columns: repeat(3, 1fr); }
      .analytics-toolbar { flex-direction: column; align-items: stretch; }
      .analytics-period-tabs { justify-content: center; }
      .analytics-league-row { align-items: flex-start; }
      .analytics-league-select-wrap { width: 100%; }
      .analytics-league-row .nav-league-stats { width: 100%; }
      .gift-sound-setup { grid-template-columns: 1fr; }
      .follow-sound-grid { flex-direction: column; align-items: stretch; }
      .follow-sound-field { min-width: 0; }
      .follow-sound-actions { align-self: stretch; }
      .follow-sound-actions label { display: none; }
      .follow-sound-actions > div { flex-direction: column; }
    }
    @media (max-width: 768px) {
      .navbar {
        gap: 8px;
        min-height: 56px;
        padding: 8px 12px;
      }
      .nav-center {
        width: 100%;
        justify-content: flex-start;
        flex-wrap: wrap;
        gap: 6px;
      }
      .nav-tabs {
        width: 100%;
        justify-content: flex-start;
      }
      .nav-tabs button {
        flex: 0 0 auto;
        text-align: left;
        padding: 8px 8px;
        font-size: 11.5px;
      }
      .nav-title { font-size: 14px; }
      .nav-right {
        width: auto;
        justify-content: flex-end;
        flex-wrap: nowrap;
        margin-left: auto;
      }
      .nav-league {
        width: 100%;
        justify-content: flex-start;
        align-items: flex-start;
      }
      .nav-league-stats {
        width: 100%;
      }
      .nav-league-chip {
        max-width: none;
      }
      .nav-logout {
        font-size: 12px;
        padding: 6px 8px;
      }
      .card {
        padding: 16px;
        border-radius: 12px;
      }
      select, input, textarea,
      button {
        height: 40px;
      }
      .nav-account { display: none; }
      .landing-card { padding: 18px; border-radius: 14px; }
      .landing-subtitle { font-size: 15px; }
      .landing-proof-chip { font-size: 11px; }
      .app-status-bar {
        padding: 12px;
        border-radius: 12px;
      }
      .status-metrics {
        display: grid;
        grid-template-columns: 1fr 1fr;
        width: 100%;
      }
      .status-metrics .chip.metric-chip {
        justify-content: flex-start;
      }
      .panel-header h2 {
        font-size: 20px;
      }
      .analytics-kpi {
        padding: 14px;
      }
      .analytics-kpi-value {
        font-size: 22px;
      }
      .chart-card, .analytics-table-card {
        padding: 16px;
      }
      .live-topbar { grid-template-columns: 1fr; }
      .controls { grid-template-columns: 1fr; }
      .gift-config-grid { grid-template-columns: 1fr; }
      .sound-lab-grid { grid-template-columns: 1fr; }
      .action-row { flex-direction: column; }
      .overview-strip { grid-template-columns: repeat(2, 1fr); }
      .analytics-grid { grid-template-columns: 1fr; }
      .analytics-toolbar { flex-direction: column; align-items: stretch; }
      .analytics-range { width: 100%; }
      .analytics-custom-bar-row {
        grid-template-columns: 1fr;
      }
      .analytics-custom-bar-value {
        text-align: left;
      }
      .feed { height: 340px; max-height: 340px; }
      #voiceProfileList { max-height: 420px; }
      .search-row { flex-direction: column; }
      .voices-config-inline {
        flex-direction: column;
        align-items: stretch;
      }
      .voices-config-control,
      .voices-config-lock {
        min-width: 0;
        max-width: none;
      }
      .voice-browse-top {
        display: block;
      }
      .voice-browse-actions {
        justify-content: flex-start;
        margin-left: 0;
      }
      .voice-profile-meta {
        display: grid;
        grid-template-columns: 1fr;
      }
      #voiceProfileList .voice-row.voice-row--profile {
        grid-template-columns: 1fr;
        align-items: stretch;
      }
      .voice-profile-actions {
        display: flex;
        flex-wrap: wrap;
        justify-content: flex-start;
      }
      .voice-add-row,
      .fish-clone-recorder-row {
        flex-direction: column;
        align-items: stretch;
      }
      .voice-add-row input[type="number"] {
        flex: 1 1 auto;
      }
      .gift-compact-row > select,
      #giftSelect,
      #soundPresetSelect,
      #followSoundPresetSelect {
        width: 100% !important;
      }
    }
    @media (max-width: 480px) {
      .overview-strip { grid-template-columns: 1fr; }
      .status-metrics {
        grid-template-columns: 1fr;
      }
    }

    /* DISCORD SETTINGS */
    .discord-overview-grid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 12px;
    }
    .discord-layout {
      display: grid;
      grid-template-columns: minmax(260px, 340px) minmax(0, 1fr);
      gap: 14px;
      align-items: start;
      margin-top: 12px;
    }
    .discord-sidebar-card {
      border: 1px solid var(--border);
      border-radius: 14px;
      background: rgba(22, 24, 31, 0.86);
      box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
      padding: 12px;
    }
    [data-theme="light"] .discord-sidebar-card {
      background: rgba(246, 248, 252, 0.95);
    }
    .discord-sidebar-head {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 8px;
      margin-bottom: 10px;
    }
    .discord-sidebar-head h3 {
      font-size: 18px;
      line-height: 1.2;
      letter-spacing: -0.01em;
    }
    .discord-create-stack {
      display: grid;
      gap: 8px;
      margin-bottom: 12px;
    }
    .discord-create-row {
      display: grid;
      gap: 6px;
      grid-template-columns: 1fr auto;
      align-items: center;
    }
    .discord-create-row input,
    .discord-create-row select {
      min-height: 36px;
    }
    .discord-create-row button {
      min-height: 36px;
      white-space: nowrap;
    }
    .discord-channel-tree {
      border: 1px solid var(--border);
      border-radius: 12px;
      background: rgba(12, 14, 20, 0.6);
      min-height: 420px;
      max-height: 640px;
      overflow: auto;
      padding: 8px;
      display: grid;
      gap: 10px;
    }
    [data-theme="light"] .discord-channel-tree {
      background: rgba(248, 250, 255, 0.9);
    }
    .discord-tree-empty {
      color: var(--text-muted);
      font-size: 13px;
      padding: 8px;
    }
    .discord-tree-group {
      display: grid;
      gap: 4px;
    }
    .discord-tree-category-row {
      display: grid;
      grid-template-columns: minmax(0, 1fr) auto;
      gap: 6px;
      align-items: center;
    }
    .discord-tree-category {
      width: 100%;
      border: 0;
      background: transparent;
      color: var(--text-secondary);
      font-size: 12px;
      font-weight: 700;
      letter-spacing: 0.03em;
      text-transform: uppercase;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 8px;
      padding: 4px 6px;
      border-radius: 8px;
      text-align: left;
    }
    .discord-tree-row-actions {
      display: inline-flex;
      align-items: center;
      gap: 4px;
    }
    .discord-tree-add-btn {
      all: unset;
      cursor: pointer;
      width: 24px;
      height: 24px;
      border-radius: 6px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      color: var(--text-secondary);
      border: 1px solid transparent;
      transition: background 120ms ease, border-color 120ms ease, color 120ms ease;
      font-size: 16px;
      line-height: 1;
    }
    .discord-tree-add-btn:hover {
      background: rgba(124, 129, 138, 0.16);
      border-color: var(--border);
      color: var(--text);
    }
    .discord-tree-edit-btn {
      all: unset;
      cursor: pointer;
      width: 24px;
      height: 24px;
      border-radius: 6px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      color: var(--text-secondary);
      border: 1px solid transparent;
      transition: background 120ms ease, border-color 120ms ease, color 120ms ease;
      font-size: 13px;
      line-height: 1;
    }
    .discord-tree-edit-btn:hover {
      background: rgba(124, 129, 138, 0.16);
      border-color: var(--border);
      color: var(--text);
    }
    .discord-tree-item {
      width: 100%;
      border: 0;
      background: transparent;
      color: var(--text-secondary);
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 10px;
      padding: 6px 8px;
      border-radius: 8px;
      text-align: left;
    }
    .discord-tree-item-main {
      min-width: 0;
      display: flex;
      align-items: center;
      gap: 8px;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
    }
    .discord-tree-item-kind {
      font-size: 10px;
      text-transform: uppercase;
      letter-spacing: 0.04em;
      border-radius: 999px;
      border: 1px solid var(--border);
      padding: 2px 6px;
      color: var(--text-muted);
      flex-shrink: 0;
    }
    .discord-tree-item-kind.--announcement {
      color: var(--gold);
      border-color: var(--gold);
      background: var(--gold-soft);
    }
    .discord-tree-subsection {
      color: var(--text-muted);
      font-size: 11px;
      letter-spacing: 0.04em;
      text-transform: uppercase;
      padding: 2px 6px;
    }
    .discord-main-stack {
      display: grid;
      gap: 12px;
      align-content: start;
    }
    .discord-editor-grid {
      display: grid;
      gap: 12px;
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .discord-editor-note {
      padding: 10px 12px;
      border: 1px dashed var(--border);
      border-radius: 10px;
      color: var(--text-muted);
      font-size: 13px;
      background: var(--bg);
    }
    .discord-kind-chip {
      display: inline-flex;
      align-items: center;
      padding: 4px 10px;
      border-radius: 999px;
      border: 1px solid var(--border);
      background: var(--bg);
      color: var(--text-secondary);
      font-size: 12px;
      font-weight: 600;
      width: fit-content;
    }
    .discord-kind-chip.--announcement {
      color: var(--gold);
      border-color: var(--gold);
      background: var(--gold-soft);
    }
    .discord-mapping-grid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 10px 12px;
    }
    .discord-action-row {
      display: flex;
      align-items: center;
      justify-content: flex-end;
      gap: 8px;
      margin-top: 12px;
      flex-wrap: wrap;
    }
    .discord-modal {
      position: fixed;
      inset: 0;
      z-index: 1200;
      display: grid;
      place-items: center;
      padding: 16px;
    }
    .discord-modal[hidden] {
      display: none;
    }
    .discord-modal-backdrop {
      position: absolute;
      inset: 0;
      background: rgba(0, 0, 0, 0.46);
      backdrop-filter: blur(2px);
    }
    .discord-modal-card {
      position: relative;
      width: min(520px, 100%);
      border: 1px solid var(--border);
      border-radius: 14px;
      background: var(--surface);
      padding: 14px;
      box-shadow: 0 24px 54px rgba(0,0,0,0.35);
      display: grid;
      gap: 10px;
    }
    .discord-modal-head {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 8px;
    }
    .discord-modal-head h4 {
      font-size: 18px;
      letter-spacing: -0.01em;
    }
    .discord-modal-close {
      all: unset;
      cursor: pointer;
      width: 28px;
      height: 28px;
      border-radius: 8px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      color: var(--text-secondary);
    }
    .discord-modal-close:hover {
      background: var(--bg);
      color: var(--text);
    }
    .discord-modal-grid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 10px;
    }
    .discord-modal-grid .full {
      grid-column: 1 / -1;
    }
    @media (max-width: 980px) {
      .discord-layout {
        grid-template-columns: 1fr;
      }
      .discord-channel-tree {
        min-height: 320px;
        max-height: 400px;
      }
    }
    @media (max-width: 760px) {
      .discord-overview-grid,
      .discord-editor-grid,
      .discord-mapping-grid {
        grid-template-columns: 1fr;
      }
      .discord-create-row {
        grid-template-columns: 1fr;
      }
      .discord-action-row {
        justify-content: stretch;
      }
      .discord-action-row button {
        width: 100%;
      }
      .discord-modal-grid {
        grid-template-columns: 1fr;
      }
    }
