/* =========================================================
   Mocca Studio — Minimalist Professional Dark Theme
   Accent: #f0f0f0 (clean white/neutral)
   ========================================================= */

:root {
  --bg:           #080808;
  --surface:      #0d0d0d;
  --surface-2:    #121212;
  --surface-3:    #181818;
  --border:       #222222;
  --border-dim:   #1a1a1a;
  --accent:       #f0f0f0;
  --accent-mid:   #a0a0a0;
  --accent-glow:  rgba(255, 255, 255, 0.05);
  --accent-ring:  rgba(255, 255, 255, 0.10);
  --text:         #ebebeb;
  --text-2:       #888888;
  --text-3:       #484848;
  --success:      #22c55e;
  --warning:      #e8a045;
  --error:        #ef4444;
  --info:         #3b82f6;
  --r:            8px;
  --r-lg:         12px;
  --shadow:       0 8px 32px rgba(0,0,0,.6);
  --font:         'Inter', system-ui, -apple-system, sans-serif;
  --font-head:    'Space Grotesk', system-ui, sans-serif;
  --font-mono:    'JetBrains Mono', 'Fira Code', monospace;
  --nav-h:        56px;
}

/* ── Light Mode ───────────────────────────────────────────────────────────── */
[data-theme="light"] {
  --bg:           #f5f5f5;
  --surface:      #ffffff;
  --surface-2:    #f0f0f0;
  --surface-3:    #e8e8e8;
  --border:       #d0d0d0;
  --border-dim:   #e0e0e0;
  --accent:       #111111;
  --accent-mid:   #555555;
  --accent-glow:  rgba(0, 0, 0, 0.05);
  --accent-ring:  rgba(0, 0, 0, 0.10);
  --text:         #111111;
  --text-2:       #555555;
  --text-3:       #999999;
  --shadow:       0 8px 32px rgba(0,0,0,.12);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font);
  font-size: 14px;
  line-height: 1.6;
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
}

a { color: var(--accent); text-decoration: none; transition: opacity .15s; }
a:hover { opacity: .8; }
strong { font-weight: 600; }
code {
  font-family: var(--font-mono);
  font-size: .875em;
  color: var(--accent);
  background: var(--accent-glow);
  padding: .1em .35em;
  border-radius: 4px;
}

::-webkit-scrollbar { width: 4px; height: 4px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--border); border-radius: 2px; }
::-webkit-scrollbar-thumb:hover { background: var(--text-3); }

/* ── Navbar ───────────────────────────────────────────────────────────────── */
.navbar {
  position: sticky;
  top: 0;
  z-index: 200;
  height: var(--nav-h);
  background: rgba(8, 8, 9, .92);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border-dim);
}

.nav-inner {
  max-width: 1280px;
  margin: 0 auto;
  height: 100%;
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0 1.25rem;
}

.nav-logo {
  display: flex;
  align-items: center;
  gap: .5rem;
  text-decoration: none;
  flex-shrink: 0;
}

.logo-mark {
  width: 28px;
  height: 28px;
  background: var(--accent);
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.logo-mark svg { display: block; }

.logo-text {
  font-family: var(--font-head);
  font-weight: 700;
  font-size: .9rem;
  letter-spacing: .06em;
  color: var(--text);
}

.logo-text span { color: var(--text-2); }

.nav-center {
  display: flex;
  align-items: center;
  gap: .15rem;
  flex: 1;
}

.nav-link {
  padding: .375rem .7rem;
  border-radius: 6px;
  font-size: .825rem;
  font-weight: 500;
  color: var(--text-2);
  transition: color .15s, background .15s;
}

.nav-link:hover { color: var(--text); background: var(--surface-3); }
.nav-link.active { color: var(--accent); }
.nav-link.nav-admin { color: var(--error); }

.nav-right {
  display: flex;
  align-items: center;
  gap: .6rem;
  margin-left: auto;
}

/* Language toggle */
.lang-toggle {
  background: var(--surface-3);
  border: 1px solid var(--border);
  color: var(--text-2);
  padding: .3rem .6rem;
  border-radius: 6px;
  font-size: .75rem;
  font-weight: 600;
  letter-spacing: .04em;
  cursor: pointer;
  transition: all .15s;
  font-family: var(--font-mono);
}

.lang-toggle:hover { color: var(--accent); border-color: var(--accent-ring); }

/* User menu */
.user-menu { position: relative; }

.user-btn {
  display: flex;
  align-items: center;
  gap: .5rem;
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: .3rem .7rem .3rem .4rem;
  color: var(--text);
  cursor: pointer;
  font-size: .825rem;
  font-weight: 500;
  transition: border-color .15s;
}

.user-btn:hover { border-color: var(--accent-ring); }

.user-avatar {
  width: 22px;
  height: 22px;
  border-radius: 5px;
  background: var(--accent);
  color: #111;
  font-weight: 700;
  font-size: .7rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-family: var(--font-mono);
}

/* ── Roblox Connection Status Pill ──────────────────────────────────────── */
.roblox-status-pill {
  display: flex;
  align-items: center;
  gap: .35rem;
  padding: .28rem .65rem;
  border-radius: 20px;
  border: 1px solid var(--border);
  background: var(--surface-2);
  color: var(--text-3);
  font-size: .72rem;
  font-weight: 500;
  text-decoration: none;
  transition: all .15s;
  white-space: nowrap;
}
.roblox-status-pill:hover { border-color: var(--border); opacity: .8; }
.roblox-status-pill.connected { border-color: rgba(34,197,94,.3); background: rgba(34,197,94,.07); color: #22c55e; }
.roblox-status-pill.connected:hover { opacity: .85; }
.roblox-dot {
  width: 6px; height: 6px; border-radius: 50%; background: var(--text-3); flex-shrink: 0;
}
.roblox-status-pill.connected .roblox-dot { background: #22c55e; box-shadow: 0 0 4px #22c55e; }

.admin-av { background: var(--error) !important; color: #fff !important; }
.chevron { color: var(--text-3); font-size: .65rem; }

.badge-plan {
  background: var(--accent-glow);
  color: var(--accent);
  border: 1px solid var(--accent-ring);
  border-radius: 4px;
  font-size: .65rem;
  font-weight: 700;
  padding: .1rem .35rem;
  letter-spacing: .04em;
  text-transform: uppercase;
  font-family: var(--font-mono);
}

.user-dropdown {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  min-width: 175px;
  box-shadow: var(--shadow);
  display: none;
  overflow: hidden;
}

.user-menu.open .user-dropdown { display: block; }

.dropdown-item {
  display: block;
  padding: .55rem 1rem;
  color: var(--text-2);
  font-size: .825rem;
  transition: background .1s, color .1s;
}

.dropdown-item:hover { background: var(--surface-3); color: var(--text); }
.dropdown-divider { height: 1px; background: var(--border); }
.dropdown-logout { color: var(--error) !important; }
.dropdown-logout:hover { background: rgba(239,68,68,.06) !important; }

/* ── Buttons ──────────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .4rem;
  padding: .5rem 1.1rem;
  border-radius: var(--r);
  font-family: var(--font);
  font-size: .825rem;
  font-weight: 500;
  cursor: pointer;
  border: 1px solid transparent;
  transition: all .15s;
  white-space: nowrap;
  text-decoration: none;
  line-height: 1;
  -webkit-appearance: none;
}

.btn:disabled { opacity: .45; cursor: not-allowed; }

.btn-primary {
  background: var(--accent);
  color: #111;
  border-color: var(--accent);
  font-weight: 600;
}
.btn-primary:hover:not(:disabled) {
  background: #ffffff;
  color: #111;
  box-shadow: 0 0 0 3px var(--accent-ring);
  opacity: 1;
}

.btn-ghost {
  background: transparent;
  color: var(--text-2);
  border-color: var(--border);
}
.btn-ghost:hover:not(:disabled) { background: var(--surface-3); color: var(--text); opacity: 1; }

.btn-outline {
  background: transparent;
  color: var(--accent);
  border-color: var(--accent-ring);
}
.btn-outline:hover:not(:disabled) { background: var(--accent-glow); opacity: 1; }

.btn-danger { background: transparent; color: var(--error); border-color: rgba(239,68,68,.3); }
.btn-danger:hover:not(:disabled) { background: rgba(239,68,68,.08); opacity: 1; }
.btn-success { background: transparent; color: var(--success); border-color: rgba(34,197,94,.3); }
.btn-success:hover:not(:disabled) { background: rgba(34,197,94,.08); opacity: 1; }

.btn-sm { padding: .3rem .7rem; font-size: .775rem; }
.btn-lg { padding: .65rem 1.5rem; font-size: .925rem; }
.btn-block { width: 100%; }

.btn-icon {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--text-3);
  font-size: .875rem;
  padding: .25rem .35rem;
  border-radius: 5px;
  transition: color .15s, background .15s;
  line-height: 1;
}
.btn-icon:hover { color: var(--text); background: var(--surface-3); }
.btn-icon.btn-danger:hover { color: var(--error); background: rgba(239,68,68,.08); }

/* ── Forms ────────────────────────────────────────────────────────────────── */
.form-group { display: flex; flex-direction: column; gap: .35rem; }

.form-row-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

@media (max-width: 600px) { .form-row-2 { grid-template-columns: 1fr; } }

label {
  font-size: .8rem;
  font-weight: 500;
  color: var(--text-2);
}

.form-input {
  background: var(--surface-3);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: .6rem .85rem;
  color: var(--text);
  font-family: var(--font);
  font-size: .875rem;
  transition: border-color .15s, box-shadow .15s;
  width: 100%;
  outline: none;
  -webkit-appearance: none;
}

.form-input:focus {
  border-color: var(--accent-ring);
  box-shadow: 0 0 0 3px rgba(255,255,255,.04);
}

.form-input::placeholder { color: var(--text-3); }
select.form-input { cursor: pointer; }
textarea.form-input { resize: vertical; min-height: 72px; }

.form-hint { font-size: .75rem; color: var(--text-3); }
.form-hint.success { color: var(--success); }

.input-wrap { position: relative; }
.input-wrap .form-input { padding-right: 2.5rem; }
.input-eye {
  position: absolute;
  right: .75rem; top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  cursor: pointer;
  color: var(--text-3);
  font-size: .8rem;
  line-height: 1;
  transition: color .15s;
}
.input-eye:hover { color: var(--text-2); }

.checkbox-label {
  display: flex;
  align-items: center;
  gap: .45rem;
  cursor: pointer;
  font-size: .825rem;
  color: var(--text-2);
  user-select: none;
}

.checkbox-label input { accent-color: var(--accent); width: 14px; height: 14px; }

.file-input-wrap input[type=file] {
  background: var(--surface-3);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: .5rem .75rem;
  color: var(--text-2);
  font-size: .825rem;
  width: 100%;
  cursor: pointer;
}

.search-form { display: flex; gap: .5rem; align-items: center; }
.flex-1 { flex: 1; }

/* ── Alert ────────────────────────────────────────────────────────────────── */
.alert {
  padding: .7rem 1rem;
  border-radius: var(--r);
  font-size: .825rem;
  margin-bottom: .75rem;
  display: flex;
  align-items: flex-start;
  gap: .5rem;
}

.alert-error {
  background: rgba(239,68,68,.07);
  border: 1px solid rgba(239,68,68,.2);
  color: #fca5a5;
}

.alert-success {
  background: rgba(34,197,94,.07);
  border: 1px solid rgba(34,197,94,.2);
  color: #86efac;
}

/* ── Toast ────────────────────────────────────────────────────────────────── */
.toast-container {
  position: fixed;
  bottom: 1.25rem;
  right: 1.25rem;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  gap: .5rem;
  max-width: 320px;
}

.toast {
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: .7rem 1rem;
  color: var(--text);
  font-size: .825rem;
  box-shadow: var(--shadow);
  display: flex;
  align-items: center;
  gap: .6rem;
  animation: toastIn .2s ease;
}

.toast-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}

.toast.success .toast-dot { background: var(--success); }
.toast.error   .toast-dot { background: var(--error); }
.toast.info    .toast-dot { background: var(--info); }
.toast.warning .toast-dot { background: var(--warning); }
.toast.success { border-color: rgba(34,197,94,.2); }
.toast.error   { border-color: rgba(239,68,68,.2); }

@keyframes toastIn {
  from { transform: translateX(12px); opacity: 0; }
  to   { transform: translateX(0);    opacity: 1; }
}

/* ── Panel ────────────────────────────────────────────────────────────────── */
.panel {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  margin-bottom: .75rem;
}

.panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: .75rem;
  padding: .9rem 1.1rem;
  border-bottom: 1px solid var(--border-dim);
}

/* External link style */
.link-external {
  color: var(--accent);
  text-decoration: none;
  border-bottom: 1px solid var(--accent-ring);
  transition: border-color .15s;
  font-size: inherit;
}
.link-external:hover { border-color: var(--accent); opacity: 1; }

.panel-title {
  font-family: var(--font-head);
  font-size: .9rem;
  font-weight: 600;
  letter-spacing: .01em;
}

.panel-desc {
  color: var(--text-3);
  font-size: .775rem;
  margin-top: .15rem;
}

.settings-form {
  padding: 1.1rem;
  display: flex;
  flex-direction: column;
  gap: .9rem;
}

/* ── Dashboard Layout ─────────────────────────────────────────────────────── */
.dashboard-layout {
  display: flex;
  min-height: calc(100vh - var(--nav-h));
}

.sidebar {
  width: 200px;
  flex-shrink: 0;
  background: var(--surface);
  border-right: 1px solid var(--border-dim);
  display: flex;
  flex-direction: column;
  position: sticky;
  top: var(--nav-h);
  height: calc(100vh - var(--nav-h));
  overflow-y: auto;
}

.sidebar-nav {
  padding: .75rem .6rem;
  display: flex;
  flex-direction: column;
  gap: .15rem;
  flex: 1;
}

.sidebar-link {
  display: flex;
  align-items: center;
  gap: .6rem;
  padding: .5rem .75rem;
  border-radius: var(--r);
  color: var(--text-2);
  font-size: .825rem;
  font-weight: 500;
  transition: background .1s, color .1s;
}

.sidebar-link:hover { background: var(--surface-3); color: var(--text); opacity: 1; }
.sidebar-link.active { background: var(--accent-glow); color: var(--accent); }

.slink-icon {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* SVG icons in sidebar */
.slink-icon svg { width: 15px; height: 15px; stroke: currentColor; fill: none; stroke-width: 1.6; }

.sidebar-divider { height: 1px; background: var(--border-dim); margin: .4rem .6rem; }

.badge-count {
  background: var(--error);
  color: #fff;
  border-radius: 999px;
  font-size: .65rem;
  padding: .1rem .35rem;
  margin-left: auto;
  font-weight: 700;
  font-family: var(--font-mono);
}

.sidebar-user {
  padding: .75rem .6rem;
  border-top: 1px solid var(--border-dim);
  display: flex;
  align-items: center;
  gap: .6rem;
}

.su-avatar {
  width: 28px;
  height: 28px;
  border-radius: 6px;
  background: var(--accent);
  color: #111;
  font-weight: 700;
  font-size: .75rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-family: var(--font-mono);
}

.su-info { display: flex; flex-direction: column; gap: .1rem; min-width: 0; overflow: hidden; }
.su-name { font-weight: 600; font-size: .8rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.su-plan { font-size: .7rem; color: var(--text-3); }

.dash-main { flex: 1; padding: 1.1rem; min-width: 0; }

/* ── Stats Bar ────────────────────────────────────────────────────────────── */
.stats-bar {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  display: flex;
  align-items: center;
  padding: .65rem 1.1rem;
  gap: .15rem;
  margin-bottom: .75rem;
  flex-wrap: wrap;
}

.sbar-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: .35rem .85rem;
  border-right: 1px solid var(--border-dim);
}

.sbar-item:last-of-type { border-right: none; }

.sbar-val {
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: 1rem;
  color: var(--accent);
  line-height: 1;
}

.sbar-label {
  font-size: .62rem;
  color: var(--text-3);
  letter-spacing: .06em;
  margin-top: .2rem;
  text-transform: uppercase;
}

.sbar-edit {
  margin-left: auto;
  font-size: .75rem;
  color: var(--text-3);
  padding: .35rem .6rem;
  border-radius: 5px;
  transition: all .15s;
}

.sbar-edit:hover { color: var(--accent); background: var(--accent-glow); opacity: 1; }

/* ── Banners ──────────────────────────────────────────────────────────────── */
/* ── Announcement Banner ────────────────────────────────────────────────── */
.announcement-banner {
  border-radius: var(--r-lg);
  padding: .6rem 1rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  margin-bottom: .65rem;
  font-size: .82rem;
  font-weight: 500;
  border: 1px solid transparent;
}
.announcement-inner { display: flex; align-items: center; gap: .5rem; flex: 1; }
.announcement-close {
  background: transparent; border: none; cursor: pointer;
  color: inherit; opacity: .6; padding: .2rem; flex-shrink: 0;
  display: flex; align-items: center;
}
.announcement-close:hover { opacity: 1; }
.announcement-info    { background: rgba(99,102,241,.1);  border-color: rgba(99,102,241,.2); color: #818cf8; }
.announcement-warning { background: rgba(245,158,11,.1);  border-color: rgba(245,158,11,.2); color: #f59e0b; }
.announcement-success { background: rgba(34,197,94,.1);   border-color: rgba(34,197,94,.2);  color: #22c55e; }
.announcement-danger  { background: rgba(239,68,68,.1);   border-color: rgba(239,68,68,.2);  color: #ef4444; }

.banner {
  border-radius: var(--r-lg);
  padding: .6rem 1rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  margin-bottom: .75rem;
  font-size: .825rem;
  flex-wrap: wrap;
}

.banner-left { display: flex; align-items: center; gap: .6rem; }

.banner-icon {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}

.banner-free {
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.08);
}

.banner-free .banner-icon { background: var(--accent-mid); }

.banner-pro {
  background: rgba(34,197,94,.05);
  border: 1px solid rgba(34,197,94,.15);
}

.banner-pro .banner-icon { background: var(--success); }

.banner-warn {
  background: rgba(245,158,11,.05);
  border: 1px solid rgba(245,158,11,.15);
}

.banner-warn .banner-icon { background: var(--warning); }
.banner strong { font-weight: 600; }
.dim { color: var(--text-3); }

/* ── Tabs ─────────────────────────────────────────────────────────────────── */
.tab-group, .filter-tabs { display: flex; gap: .2rem; }

.tab {
  padding: .35rem .75rem;
  border-radius: 6px;
  font-size: .775rem;
  font-weight: 500;
  color: var(--text-2);
  background: transparent;
  border: 1px solid transparent;
  cursor: pointer;
  transition: all .15s;
}

.tab:hover { color: var(--text); background: var(--surface-3); }
.tab.active {
  color: var(--accent);
  background: var(--accent-glow);
  border-color: var(--accent-ring);
}

.tab-content { display: none; }
.tab-content.active { display: block; }

/* ── Converter ────────────────────────────────────────────────────────────── */
.converter-form {
  padding: 1rem;
  display: flex;
  flex-direction: column;
  gap: .65rem;
}

.url-row {
  display: flex;
  gap: .5rem;
  align-items: stretch;
}

.platform-select {
  background: var(--surface-3);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: .6rem .75rem;
  color: var(--text);
  font-size: .825rem;
  cursor: pointer;
  outline: none;
  transition: border-color .15s;
  flex-shrink: 0;
  -webkit-appearance: none;
  appearance: none;
  padding-right: 1.5rem;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%235a5550'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right .5rem center;
}

.platform-select:focus { border-color: var(--accent-ring); }

.converter-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: .775rem;
  color: var(--text-3);
  flex-wrap: wrap;
  gap: .5rem;
}

.converter-meta a { color: var(--accent); font-size: .775rem; }

/* Dropzone */
.dropzone {
  border: 1px dashed var(--border);
  border-radius: var(--r-lg);
  padding: 2rem 1rem;
  text-align: center;
  cursor: pointer;
  transition: border-color .15s, background .15s;
}

.dropzone:hover, .dropzone.drag-over {
  border-color: var(--accent-ring);
  background: var(--accent-glow);
}

.dz-title {
  font-size: .875rem;
  color: var(--text-2);
  margin-bottom: .35rem;
}

.dz-sub {
  font-size: .75rem;
  color: var(--text-3);
}

.file-selected {
  display: flex;
  align-items: center;
  gap: .6rem;
  padding: .7rem .9rem;
  background: var(--surface-3);
  border: 1px solid var(--border);
  border-radius: var(--r);
}

.file-selected-name {
  flex: 1;
  font-size: .825rem;
  color: var(--text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* ── Jobs Table ───────────────────────────────────────────────────────────── */
.jobs-table {
  width: 100%;
  border-collapse: collapse;
}

.jobs-table th {
  text-align: left;
  padding: .55rem 1rem;
  font-size: .7rem;
  font-weight: 600;
  color: var(--text-3);
  letter-spacing: .06em;
  text-transform: uppercase;
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
}

.jobs-table td {
  padding: .6rem 1rem;
  border-bottom: 1px solid var(--border-dim);
  font-size: .825rem;
  vertical-align: middle;
}

.jobs-table tr:last-child td { border-bottom: none; }
.jobs-table tbody tr:hover td { background: rgba(255,255,255,.015); }
.job-title { max-width: 240px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.job-time {
  color: var(--text-3);
  white-space: nowrap;
  font-size: .75rem;
  font-family: var(--font-mono);
}

.job-files { display: flex; flex-wrap: wrap; gap: .3rem; }

.file-dl {
  display: inline-flex;
  align-items: center;
  gap: .25rem;
  background: var(--surface-3);
  border: 1px solid var(--border);
  border-radius: 5px;
  padding: .18rem .5rem;
  font-size: .73rem;
  color: var(--text-2);
  transition: border-color .15s, color .15s;
  max-width: 150px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-family: var(--font-mono);
}

.file-dl:hover { border-color: var(--accent-ring); color: var(--accent); opacity: 1; }

.asset-id {
  display: inline-flex;
  align-items: center;
  gap: .25rem;
  background: var(--accent-glow);
  border: 1px solid var(--accent-ring);
  border-radius: 5px;
  padding: .18rem .5rem;
  font-size: .73rem;
  color: var(--accent);
  cursor: pointer;
  font-family: var(--font-mono);
  transition: background .15s;
}

.asset-id:hover { background: rgba(255,255,255,.12); }

.action-cell { display: flex; gap: .35rem; align-items: center; flex-wrap: wrap; }
.mono { font-family: var(--font-mono); }

/* Status Badges */
.status-badge {
  display: inline-block;
  padding: .15rem .5rem;
  border-radius: 4px;
  font-size: .7rem;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  font-family: var(--font-mono);
  white-space: nowrap;
}

.status-pending    { background: rgba(59,130,246,.08);  color: #93c5fd; border: 1px solid rgba(59,130,246,.18); }
.status-processing { background: rgba(245,158,11,.08);  color: #fcd34d; border: 1px solid rgba(245,158,11,.18); }
.status-done       { background: rgba(34,197,94,.08);   color: #86efac; border: 1px solid rgba(34,197,94,.18); }
.status-failed     { background: rgba(239,68,68,.08);   color: #fca5a5; border: 1px solid rgba(239,68,68,.18); }
.status-approved   { background: rgba(34,197,94,.08);   color: #86efac; border: 1px solid rgba(34,197,94,.18); }
.status-rejected   { background: rgba(239,68,68,.08);   color: #fca5a5; border: 1px solid rgba(239,68,68,.18); }

/* Platform Badges */
.platform-badge {
  display: inline-block;
  padding: .1rem .4rem;
  border-radius: 4px;
  font-size: .65rem;
  font-weight: 700;
  margin-right: .3rem;
  text-transform: uppercase;
  letter-spacing: .04em;
  font-family: var(--font-mono);
}

.youtube    { background: rgba(255,0,0,.1);    color: #f87171; }
.soundcloud { background: rgba(255,85,0,.1);   color: #fb923c; }
.upload     { background: rgba(255,255,255,.06); color: var(--accent-mid); }

/* ── Empty State ──────────────────────────────────────────────────────────── */
.empty-state {
  text-align: center;
  padding: 2.5rem 1rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .85rem;
}

.empty-icon {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  background: var(--surface-3);
  border: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
}

.empty-icon svg { width: 18px; height: 18px; stroke: var(--text-3); fill: none; stroke-width: 1.5; }
.empty-state p { color: var(--text-3); font-size: .825rem; }

/* Pagination */
.pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .75rem;
  padding: .85rem;
  border-top: 1px solid var(--border-dim);
}

.page-info { color: var(--text-3); font-size: .775rem; font-family: var(--font-mono); }

/* ── Admin Stats Grid ─────────────────────────────────────────────────────── */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(165px, 1fr));
  gap: .65rem;
  margin-bottom: .75rem;
}

.stat-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 1rem;
  display: flex;
  flex-direction: column;
  gap: .35rem;
  position: relative;
}

.stat-card.stat-warning { border-color: rgba(245,158,11,.18); }
.stat-card.stat-success { border-color: rgba(34,197,94,.18); }

.stat-number {
  font-family: var(--font-mono);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--text);
  line-height: 1;
}

.stat-label { font-size: .72rem; color: var(--text-3); text-transform: uppercase; letter-spacing: .05em; }

.stat-action {
  position: absolute;
  bottom: .75rem;
  right: .85rem;
  font-size: .72rem;
  color: var(--accent);
}

.admin-split { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; }
@media (max-width: 900px) { .admin-split { grid-template-columns: 1fr; } }

/* ── Pricing Admin Cards ─────────────────────────────────────────────────── */
.pricing-admin-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: .65rem;
  margin-bottom: 1.1rem;
}
@media (max-width: 960px) { .pricing-admin-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .pricing-admin-grid { grid-template-columns: 1fr; } }

.pricing-admin-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: .9rem;
  display: flex;
  flex-direction: column;
  gap: .55rem;
  position: relative;
  overflow: hidden;
  transition: border-color .15s;
}
.pricing-admin-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  border-radius: var(--r-lg) var(--r-lg) 0 0;
}
.pricing-admin-free::before   { background: var(--text-3); }
.pricing-admin-bypass::before { background: #f59e0b; }
.pricing-admin-weekly::before { background: #6366f1; }
.pricing-admin-monthly::before{ background: #22c55e; }

.pricing-admin-card:hover { border-color: var(--border-bright); }

.pac-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: .2rem;
}

.pac-badge {
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: .18rem .5rem;
  border-radius: 4px;
}
.pac-badge-free    { background: rgba(140,140,162,.12); color: var(--text-2); }
.pac-badge-bypass  { background: rgba(245,158,11,.12);  color: #f59e0b; }
.pac-badge-weekly  { background: rgba(99,102,241,.12);  color: #818cf8; }
.pac-badge-monthly { background: rgba(34,197,94,.12);   color: #22c55e; }

.pac-duration { font-size: .68rem; color: var(--text-3); }

.pac-body { flex: 1; }

.pac-input-wrap {
  display: flex;
  align-items: center;
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--r);
  overflow: hidden;
  height: 34px;
}
.pac-prefix, .pac-unit {
  padding: 0 .5rem;
  font-size: .72rem;
  color: var(--text-3);
  background: var(--surface);
  border-right: 1px solid var(--border);
  height: 100%;
  display: flex;
  align-items: center;
  white-space: nowrap;
}
.pac-unit { border-right: none; border-left: 1px solid var(--border); }

.pac-input {
  border: none !important;
  background: transparent !important;
  flex: 1;
  min-width: 0;
  height: 100%;
  padding: 0 .6rem;
  font-size: .8rem;
  color: var(--text);
}
.pac-input:focus { outline: none; box-shadow: none; }

.pac-hint {
  font-size: .68rem;
  color: var(--text-3);
  margin: 0;
  line-height: 1.4;
}

.admin-page-header {
  display: flex;
  align-items: center;
  gap: .85rem;
  margin-bottom: 1rem;
}

.admin-page-header h1 {
  font-family: var(--font-head);
  font-size: 1.2rem;
  font-weight: 700;
}

.admin-tag {
  background: var(--accent-glow);
  border: 1px solid var(--accent-ring);
  color: var(--accent);
  padding: .2rem .55rem;
  border-radius: 5px;
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  font-family: var(--font-mono);
}

/* ── Settings ─────────────────────────────────────────────────────────────── */
.settings-main { max-width: 700px; }

.info-box {
  background: var(--surface-3);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: .9rem;
  font-size: .8rem;
  color: var(--text-2);
}

.info-box ol { margin-left: 1.1rem; display: flex; flex-direction: column; gap: .25rem; margin-top: .4rem; }

.info-grid { padding: .9rem 1.1rem; display: flex; flex-direction: column; }

.info-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: .55rem 0;
  border-bottom: 1px solid var(--border-dim);
}

.info-row:last-child { border-bottom: none; }
.info-label { color: var(--text-3); font-size: .8rem; }
.info-val { font-size: .85rem; }

/* ── Modal ────────────────────────────────────────────────────────────────── */
.modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.65);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  z-index: 200;
}

.modal {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 201;
  width: min(92vw, 440px);
}

.modal-box {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  box-shadow: var(--shadow);
}

.modal-box h2 { font-family: var(--font-head); font-size: 1rem; }
.modal-box p { color: var(--text-2); font-size: .825rem; line-height: 1.65; }
.modal-actions { display: flex; gap: .6rem; justify-content: flex-end; }
.hidden { display: none !important; }

/* ── Payment Page ─────────────────────────────────────────────────────────── */
.page-container {
  max-width: 1080px;
  margin: 0 auto;
  padding: 1.5rem;
}

.page-container.narrow { max-width: 860px; }

.page-header {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1.25rem;
}

.page-header h1 { font-family: var(--font-head); font-size: 1.2rem; }

.back-link {
  color: var(--text-3);
  font-size: .8rem;
}

.back-link:hover { color: var(--text-2); opacity: 1; }

.sub-layout {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: .75rem;
  align-items: start;
}

@media (max-width: 700px) { .sub-layout { grid-template-columns: 1fr; } }

.sub-summary { padding: 1.1rem; }

.plan-selected { margin-bottom: 1rem; }

.plan-tag {
  display: inline-block;
  background: var(--accent-glow);
  border: 1px solid var(--accent-ring);
  color: var(--accent);
  border-radius: 5px;
  padding: .2rem .6rem;
  font-size: .7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: .5rem;
  font-family: var(--font-mono);
}

.plan-price-big {
  font-family: var(--font-mono);
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--text);
  margin-bottom: .15rem;
}

.plan-features {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: .4rem;
  font-size: .8rem;
  color: var(--text-2);
}

.plan-features li {
  padding: .3rem 0;
  border-bottom: 1px solid var(--border-dim);
  display: flex;
  align-items: center;
  gap: .45rem;
}

.plan-features li:last-child { border-bottom: none; }
.plan-features .dim { opacity: .35; }

.plan-check {
  display: inline-block;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: rgba(34,197,94,.12);
  border: 1px solid rgba(34,197,94,.25);
  flex-shrink: 0;
  position: relative;
}

.plan-check::after {
  content: '';
  position: absolute;
  left: 3px; top: 5px;
  width: 5px; height: 3px;
  border-left: 1.5px solid var(--success);
  border-bottom: 1.5px solid var(--success);
  transform: rotate(-45deg);
}

.sub-other { margin-top: .85rem; display: flex; flex-direction: column; gap: .35rem; }
.sub-other p { font-size: .75rem; color: var(--text-3); }
.plan-switch-link { font-size: .775rem; color: var(--text-2); }
.plan-switch-link:hover { color: var(--accent); opacity: 1; }

.sub-form-panel { padding: 1.1rem; }
.sub-desc { color: var(--text-2); font-size: .825rem; margin-bottom: .85rem; }

.banks-list { display: flex; flex-direction: column; gap: .45rem; margin-bottom: .85rem; }

.bank-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--surface-3);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: .75rem .9rem;
  cursor: pointer;
  transition: border-color .15s;
}

.bank-card:hover { border-color: var(--accent-ring); }
.bank-card.selected { border-color: var(--accent-ring); background: var(--accent-glow); }

.bank-info { display: flex; flex-direction: column; gap: .2rem; }
.bank-info strong { font-size: .85rem; }
.bank-number { display: flex; align-items: center; gap: .4rem; font-family: var(--font-mono); font-size: .82rem; color: var(--text); }
.bank-name-acc { font-size: .72rem; color: var(--text-3); }

.bank-select-dot {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  border: 1.5px solid var(--border);
  transition: all .15s;
  flex-shrink: 0;
}

.bank-card.selected .bank-select-dot {
  background: var(--accent);
  border-color: var(--accent);
}

.copy-btn {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--text-3);
  font-size: .75rem;
  padding: .15rem;
  border-radius: 4px;
  transition: color .15s;
  font-family: var(--font-mono);
}

.copy-btn:hover { color: var(--accent); }

.amount-reminder {
  display: flex;
  align-items: center;
  gap: .65rem;
  background: var(--accent-glow);
  border: 1px solid var(--accent-ring);
  border-radius: var(--r);
  padding: .65rem .9rem;
  font-size: .825rem;
  margin-bottom: .85rem;
}

.amount-reminder strong {
  font-family: var(--font-mono);
  font-size: .95rem;
  color: var(--accent);
}

/* ── Landing Page ─────────────────────────────────────────────────────────── */
.landing-page { overflow-x: hidden; }
.container { max-width: 1160px; margin: 0 auto; padding: 0 1.5rem; }

/* Hero */
.hero {
  position: relative;
  min-height: 94vh;
  display: flex;
  align-items: center;
  padding: 5rem 0 4rem;
  overflow: hidden;
}

.hero-grid {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(var(--border-dim) 1px, transparent 1px),
    linear-gradient(90deg, var(--border-dim) 1px, transparent 1px);
  background-size: 52px 52px;
  mask-image: radial-gradient(ellipse 80% 70% at 50% 50%, black, transparent);
  opacity: .35;
}

.hero-glow {
  position: absolute;
  top: 25%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 700px;
  height: 500px;
  background: radial-gradient(ellipse, rgba(255,255,255,.04) 0%, transparent 65%);
  pointer-events: none;
}

.hero-split {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  align-items: center;
}

@media (max-width: 768px) {
  .hero-split { grid-template-columns: 1fr; }
  .hero-visual { display: none; }
}

.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-size: .75rem;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 1.25rem;
  font-family: var(--font-mono);
}

.hero-eyebrow-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--accent);
}

.hero-title {
  font-family: var(--font-head);
  font-size: clamp(2rem, 4.5vw, 3.2rem);
  font-weight: 700;
  line-height: 1.12;
  margin-bottom: 1.1rem;
  color: var(--text);
  letter-spacing: -.01em;
}

.hero-accent { color: var(--accent); }

.hero-desc {
  font-size: .95rem;
  color: var(--text-2);
  max-width: 440px;
  margin-bottom: 2rem;
  line-height: 1.75;
}

.hero-actions { display: flex; gap: .75rem; flex-wrap: wrap; margin-bottom: 2.5rem; }

.hero-kv {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  flex-wrap: wrap;
}

.hero-kv-item { display: flex; flex-direction: column; gap: .15rem; }
.hero-kv-num { font-family: var(--font-mono); font-weight: 600; color: var(--text); font-size: .95rem; }
.hero-kv-label { font-size: .7rem; color: var(--text-3); text-transform: uppercase; letter-spacing: .06em; }
.hero-kv-sep { width: 1px; height: 28px; background: var(--border); }

/* Hero Visual — terminal-like card */
.hero-visual {
  display: flex;
  justify-content: center;
}

.terminal-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  width: 100%;
  max-width: 380px;
  box-shadow: var(--shadow);
}

.terminal-header {
  display: flex;
  align-items: center;
  gap: .4rem;
  padding: .7rem .9rem;
  background: var(--surface-2);
  border-bottom: 1px solid var(--border);
}

.t-dot { width: 8px; height: 8px; border-radius: 50%; }
.t-dot-r { background: rgba(239,68,68,.6); }
.t-dot-y { background: rgba(245,158,11,.6); }
.t-dot-g { background: rgba(34,197,94,.6); }
.t-title { margin-left: auto; margin-right: auto; font-size: .72rem; color: var(--text-3); font-family: var(--font-mono); }

.terminal-body {
  padding: 1rem;
  font-family: var(--font-mono);
  font-size: .77rem;
  line-height: 1.75;
}

.t-line { display: flex; gap: .5rem; }
.t-prompt { color: var(--accent); flex-shrink: 0; }
.t-cmd { color: var(--text-2); }
.t-out { color: var(--text-3); padding-left: 1rem; }
.t-success { color: var(--success); padding-left: 1rem; }
.t-accent { color: var(--accent); padding-left: 1rem; }
.t-cursor { display: inline-block; width: 7px; height: 13px; background: var(--accent); opacity: .8; animation: blink 1s step-end infinite; vertical-align: -2px; }
@keyframes blink { 0%, 100% { opacity: .8; } 50% { opacity: 0; } }

/* Sections */
.section { padding: 5rem 0; }
.section-alt { background: var(--surface); border-top: 1px solid var(--border-dim); border-bottom: 1px solid var(--border-dim); }

.section-header { margin-bottom: 2.75rem; }
.section-header.center { text-align: center; }
.section-header.center .section-desc { margin: 0 auto; max-width: 500px; }

.section-eyebrow {
  display: inline-block;
  color: var(--accent);
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  margin-bottom: .65rem;
  font-family: var(--font-mono);
}

.section-title {
  font-family: var(--font-head);
  font-size: clamp(1.4rem, 3vw, 2rem);
  font-weight: 700;
  margin-bottom: .6rem;
  letter-spacing: -.01em;
}

.section-desc { color: var(--text-2); font-size: .875rem; line-height: 1.75; }

/* Features Grid */
.features-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: .65rem;
}

.feature-card {
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 1.25rem;
  transition: border-color .2s;
}

.feature-card:hover { border-color: rgba(255,255,255,.12); }

.feature-num {
  font-family: var(--font-mono);
  font-size: .7rem;
  color: var(--text-3);
  margin-bottom: .75rem;
  letter-spacing: .05em;
}

.feature-card h3 {
  font-family: var(--font-head);
  font-size: .875rem;
  font-weight: 600;
  margin-bottom: .4rem;
}

.feature-card p { color: var(--text-2); font-size: .8rem; line-height: 1.65; }

/* Steps */
.steps-grid {
  display: grid;
  grid-template-columns: 1fr auto 1fr auto 1fr;
  gap: .5rem;
  align-items: center;
}

@media (max-width: 700px) {
  .steps-grid { grid-template-columns: 1fr; }
  .step-arrow { transform: rotate(90deg); margin: .5rem auto; display: block; width: fit-content; }
}

.step-card {
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 1.25rem;
}

.step-num {
  font-family: var(--font-mono);
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--accent);
  opacity: .4;
  margin-bottom: .6rem;
  line-height: 1;
}

.step-card h3 { font-size: .875rem; font-weight: 600; margin-bottom: .4rem; }
.step-card p { color: var(--text-2); font-size: .8rem; line-height: 1.65; }
.step-arrow { text-align: center; color: var(--text-3); font-size: .9rem; letter-spacing: -.05em; }

/* Pricing */
.pricing-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
  gap: .65rem;
  margin-bottom: 1.25rem;
}

.pricing-card {
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 1.35rem;
  position: relative;
  transition: border-color .2s;
}

.pricing-card:hover { border-color: rgba(255,255,255,.12); }

.pricing-featured {
  border-color: rgba(255,255,255,.12);
  background: linear-gradient(160deg, var(--surface-2) 0%, rgba(255,255,255,.02) 100%);
}

.plan-badge {
  position: absolute;
  top: 0; right: 1rem;
  background: var(--accent);
  color: #111;
  font-size: .65rem;
  font-weight: 700;
  padding: .25rem .65rem;
  border-radius: 0 0 5px 5px;
  letter-spacing: .06em;
  text-transform: uppercase;
  font-family: var(--font-mono);
}

.plan-header { margin-bottom: 1.1rem; }
.plan-name { display: block; font-family: var(--font-head); font-weight: 700; font-size: .9rem; margin-bottom: .5rem; }
.plan-price { display: flex; align-items: baseline; gap: .4rem; flex-wrap: wrap; margin-bottom: .35rem; }
.price-amount { font-family: var(--font-mono); font-size: 1.3rem; font-weight: 700; color: var(--text); }
.price-period { font-size: .75rem; color: var(--text-3); }
.plan-desc { font-size: .775rem; color: var(--text-3); }

.pricing-note { text-align: center; color: var(--text-3); font-size: .8rem; }

/* Footer */
.footer {
  padding: 2.5rem 0;
  border-top: 1px solid var(--border-dim);
}

.footer-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
}

.footer-brand { display: flex; align-items: center; gap: .5rem; }
.footer-links { display: flex; gap: 1.25rem; }
.footer-links a { color: var(--text-3); font-size: .8rem; }
.footer-links a:hover { color: var(--text-2); opacity: 1; }
.footer-copy { color: var(--text-3); font-size: .75rem; font-family: var(--font-mono); }

/* ── Auth ─────────────────────────────────────────────────────────────────── */
.auth-page {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 1fr 1fr;
}

@media (max-width: 700px) {
  .auth-page { grid-template-columns: 1fr; }
  .auth-side { display: none; }
}

.auth-side {
  background: var(--surface);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 2rem;
  position: relative;
  overflow: hidden;
}

.auth-side-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(var(--border-dim) 1px, transparent 1px),
    linear-gradient(90deg, var(--border-dim) 1px, transparent 1px);
  background-size: 48px 48px;
  opacity: .3;
  pointer-events: none;
}

.auth-side-content {
  position: relative;
  margin: auto;
  max-width: 360px;
}

.auth-side-title {
  font-family: var(--font-head);
  font-size: 1.5rem;
  font-weight: 700;
  margin-bottom: .75rem;
}

.auth-side-desc {
  color: var(--text-2);
  font-size: .875rem;
  line-height: 1.75;
  margin-bottom: 1.5rem;
}

.auth-feature-list { display: flex; flex-direction: column; gap: .6rem; }

.auth-feature-item {
  display: flex;
  align-items: center;
  gap: .65rem;
  font-size: .825rem;
  color: var(--text-2);
}

.auth-feature-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--accent);
  flex-shrink: 0;
}

.auth-main {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 2rem;
  position: relative;
  background: var(--bg);
}

.auth-container {
  width: 100%;
  max-width: 360px;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.auth-logo {
  display: flex;
  align-items: center;
  gap: .5rem;
  text-decoration: none;
}

.auth-card {
  width: 100%;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 1.75rem;
  box-shadow: 0 4px 24px rgba(0,0,0,.35);
}

.auth-header { margin-bottom: 1.5rem; }
.auth-header h1 { font-family: var(--font-head); font-size: 1.25rem; margin-bottom: .35rem; }
.auth-header p { color: var(--text-3); font-size: .825rem; }

.auth-form { display: flex; flex-direction: column; gap: .85rem; }
.auth-switch { text-align: center; font-size: .8rem; color: var(--text-3); }
.auth-switch a { color: var(--accent); }
.auth-lang { display: flex; justify-content: center; }
.form-row { display: flex; justify-content: space-between; align-items: center; }

/* Fallback for single-column auth layout */
.auth-page.single-col {
  grid-template-columns: 1fr;
  align-items: center;
  background: var(--bg);
}

/* ── Mobile Responsive ────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .sidebar { display: none; }
  .dash-main { padding: .75rem; }
  .url-row { flex-wrap: wrap; }
  .stats-grid { grid-template-columns: 1fr 1fr; }
  .stats-bar { gap: 0; }
  .sbar-item { padding: .35rem .6rem; }
  .navbar .nav-center { display: none; }
  .hero { min-height: auto; padding: 2.5rem 0 2rem; }
  .features-grid { grid-template-columns: 1fr 1fr; }
  .pricing-grid { grid-template-columns: 1fr 1fr; }
  .hero-kv { gap: 1rem; }
}

@media (max-width: 480px) {
  .features-grid { grid-template-columns: 1fr; }
  .pricing-grid { grid-template-columns: 1fr; }
  .stats-grid { grid-template-columns: 1fr; }
  .auth-card { padding: 1.25rem; }
  .dash-main { padding: .5rem; }
  .jobs-table { font-size: .75rem; }
  .jobs-table th, .jobs-table td { padding: .5rem .6rem; }
  .panel-header { padding: .75rem .85rem; }
}

/* Mobile nav — hamburger */
.mobile-menu-btn {
  display: none;
  background: none;
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: .35rem .5rem;
  cursor: pointer;
  color: var(--text-2);
  margin-left: auto;
}

@media (max-width: 768px) {
  .mobile-menu-btn { display: flex; align-items: center; }
}

/* ── Progress Bar ─────────────────────────────────────────────────────────── */
.job-progress {
  width: 100%;
  height: 3px;
  background: var(--border);
  border-radius: 2px;
  margin-top: 4px;
  overflow: hidden;
}
.job-progress-bar {
  height: 100%;
  background: var(--accent);
  border-radius: 2px;
  transition: width .4s ease;
}
.job-progress-bar.done { background: var(--success); }

/* ── Bulk select toolbar ──────────────────────────────────────────────────── */
.bulk-toolbar {
  display: none;
  align-items: center;
  gap: .6rem;
  padding: .5rem .75rem;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--r);
  margin-bottom: .5rem;
  font-size: .8rem;
}
.bulk-toolbar.show { display: flex; }
.bulk-count { color: var(--text-2); }

/* ── Inline script block ─────────────────────────────────────────────────── */
.script-inline { margin-top: .4rem; }
.script-inline .code-block { max-height: 220px; font-size: .68rem; }

/* ── Audio preview player ─────────────────────────────────────────────────── */
.audio-preview-wrap {
  margin-top: 6px;
}
.audio-preview-wrap audio {
  width: 100%;
  height: 28px;
  accent-color: var(--accent);
  border-radius: 4px;
}
.btn-play {
  background: none;
  border: 1px solid var(--border);
  border-radius: 4px;
  color: var(--text-2);
  cursor: pointer;
  font-size: .72rem;
  padding: 2px 7px;
  margin-left: 4px;
  transition: border-color .15s, color .15s;
}
.btn-play:hover { border-color: var(--accent); color: var(--accent); }

/* ── Job checkbox ─────────────────────────────────────────────────────────── */
.job-check-cell { width: 28px; padding-right: 0 !important; }
.job-check { accent-color: var(--accent); width: 14px; height: 14px; cursor: pointer; }

/* Mobile sidebar overlay */
.sidebar-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.6);
  z-index: 99;
}

.sidebar-overlay.open { display: block; }

@media (max-width: 768px) {
  .sidebar {
    display: flex;
    position: fixed;
    left: -220px;
    top: var(--nav-h);
    height: calc(100vh - var(--nav-h));
    z-index: 100;
    transition: left .25s ease;
    border-right: 1px solid var(--border);
  }

  .sidebar.open { left: 0; }
}

/* ── Preset rows ─────────────────────────────────────────── */
.preset-row { display:flex;align-items:center;gap:.5rem;padding:.4rem 0;border-bottom:1px solid var(--border-dim); }
.preset-row:last-child { border-bottom:none; }
.preset-name { font-size:.85rem;font-weight:500;flex:0 0 auto; }
.preset-meta { font-size:.75rem;flex:1; }
