:root {
  --bg-1: #0b1020;
  --bg-2: #131a33;
  --bg-3: #1b2244;
  --accent: #6366f1;
  --accent-hover: #4f46e5;
  --accent-soft: rgba(99, 102, 241, .18);
  --text: #e6e9f2;
  --text-muted: #94a3b8;
  --text-dim: #64748b;
  --card: #ffffff;
  --card-text: #0f172a;
  --border: #e2e8f0;
  --border-strong: #cbd5e1;
  --error: #b91c1c;
  --error-bg: #fef2f2;
  --error-border: #fecaca;
  --success: #15803d;
  --success-bg: #f0fdf4;
  --success-border: #bbf7d0;
  --warn: #b45309;
  --warn-bg: #fffbeb;
  --warn-border: #fde68a;
}

* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
               "Helvetica Neue", Arial, "Noto Sans", sans-serif;
  color: var(--text);
  background: var(--bg-1);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

a { color: inherit; }
code { font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; }

/* ============ AUTH ============ */
body.auth {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 24px;
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(99,102,241,.45), transparent 60%),
    radial-gradient(900px 500px at -10% 110%, rgba(56,189,248,.30), transparent 60%),
    linear-gradient(180deg, var(--bg-1), var(--bg-2));
}

.card {
  width: 100%;
  max-width: 410px;
  background: var(--card);
  color: var(--card-text);
  border-radius: 18px;
  padding: 36px 32px 32px;
  box-shadow: 0 20px 60px rgba(0,0,0,.45), 0 1px 0 rgba(255,255,255,.6) inset;
  animation: rise .4s ease-out;
}
@keyframes rise { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }

.card .logo { font-weight: 800; font-size: 22px; letter-spacing: -.02em; color: var(--accent); margin-bottom: 22px; }
.card .logo span { color: var(--card-text); margin-left: 2px; }
.card h1 { font-size: 26px; margin: 0 0 4px; letter-spacing: -.01em; }
.card .lead { margin: 0 0 22px; color: var(--text-dim); font-size: 14px; }
.card form { display: grid; gap: 14px; }
.card label { display: grid; gap: 6px; font-size: 14px; }
.card label span { color: #475569; font-weight: 500; }
.card input {
  height: 46px; padding: 0 14px; border: 1px solid var(--border); border-radius: 10px;
  font: inherit; font-size: 15px; color: var(--card-text); background: #f8fafc;
  transition: border-color .15s, box-shadow .15s, background .15s;
}
.card input:hover { background: #f1f5f9; }
.card input:focus { outline: none; background: #fff; border-color: var(--accent); box-shadow: 0 0 0 4px var(--accent-soft); }
.card button {
  margin-top: 6px; height: 46px; border: 0; border-radius: 10px;
  background: var(--accent); color: #fff; font-weight: 600; font-size: 15px;
  cursor: pointer; transition: background .15s, transform .05s;
  box-shadow: 0 6px 16px rgba(99,102,241,.35);
}
.card button:hover  { background: var(--accent-hover); }
.card button:active { transform: translateY(1px); }
.card .alert {
  padding: 10px 12px; border-radius: 10px;
  background: var(--error-bg); color: var(--error); border: 1px solid var(--error-border);
  font-size: 14px; margin-bottom: 14px;
}

/* ============ APP SHELL ============ */
body.app { background: var(--bg-1); color: var(--text); }

.topbar {
  display: flex; align-items: center; gap: 28px;
  padding: 12px 24px;
  background: var(--bg-2);
  border-bottom: 1px solid rgba(255,255,255,.05);
  position: sticky; top: 0; z-index: 10;
}
.topbar .brand {
  font-weight: 800; letter-spacing: -.01em; color: var(--accent);
  text-decoration: none; font-size: 18px;
}
.topbar .brand span { color: var(--text); margin-left: 2px; }

.topbar .nav { display: flex; gap: 4px; flex: 1; }
.topbar .nav a {
  padding: 7px 12px; border-radius: 8px; font-size: 14px;
  color: var(--text-muted); text-decoration: none;
  transition: background .12s, color .12s;
}
.topbar .nav a:hover { color: var(--text); background: rgba(255,255,255,.05); }
.topbar .nav a.active { color: var(--text); background: rgba(99,102,241,.18); }

.topbar .user { display: flex; align-items: center; gap: 12px; color: var(--text-muted); font-size: 14px; }
.topbar .user .who { color: var(--text); display: inline-flex; align-items: center; gap: 6px; }
.topbar .user .role {
  font-size: 11px; text-transform: uppercase; letter-spacing: .05em;
  padding: 2px 6px; border-radius: 4px; background: var(--accent-soft); color: #c7d2fe;
}

.btn-ghost {
  display: inline-flex; align-items: center; padding: 7px 12px;
  border-radius: 8px; color: var(--text); text-decoration: none;
  border: 1px solid rgba(255,255,255,.1); background: transparent;
  font-size: 14px; cursor: pointer;
  transition: background .12s, border-color .12s;
}
.btn-ghost:hover { background: rgba(255,255,255,.06); border-color: rgba(255,255,255,.18); }
.btn-ghost[disabled], .btn-primary[disabled] { opacity: .5; pointer-events: none; }

.btn-primary {
  display: inline-flex; align-items: center; padding: 8px 14px;
  border: 0; border-radius: 8px; background: var(--accent); color: #fff;
  font-weight: 600; font-size: 14px; cursor: pointer; text-decoration: none;
  transition: background .12s, transform .05s;
}
.btn-primary:hover { background: var(--accent-hover); }
.btn-primary:active { transform: translateY(1px); }

.btn-warn {
  display: inline-flex; align-items: center; padding: 8px 14px;
  border: 0; border-radius: 8px; background: #d97706; color: #fff;
  font-weight: 600; font-size: 14px; cursor: pointer;
  transition: background .12s;
}
.btn-warn:hover { background: #b45309; }

.btn-danger {
  display: inline-flex; align-items: center; padding: 8px 14px;
  border: 0; border-radius: 8px; background: #dc2626; color: #fff;
  font-weight: 600; font-size: 14px; cursor: pointer;
  transition: background .12s;
}
.btn-danger:hover { background: #b91c1c; }

.container { max-width: 1080px; margin: 32px auto; padding: 0 24px; }

.page-head {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 24px; margin-bottom: 24px;
}
.page-head h1 { margin: 0; font-size: 28px; letter-spacing: -.01em; }
.page-head .page-head-text { display: flex; flex-direction: column; gap: 4px; }
.page-head .actions { display: flex; gap: 8px; }
.back {
  font-size: 13px; color: var(--text-muted); text-decoration: none;
  display: inline-flex; align-items: center; margin-bottom: 4px;
}
.back:hover { color: var(--text); }

.muted { color: var(--text-muted); }
.ta-right { text-align: right; }

/* ============ EMPTY STATE ============ */
.empty {
  background: var(--bg-2); border: 1px dashed rgba(255,255,255,.08);
  border-radius: 14px; padding: 64px 24px; text-align: center;
}
.empty h2 { margin: 0 0 6px; font-size: 20px; }
.empty p  { margin: 0 0 18px; color: var(--text-muted); }

/* ============ TABLE ============ */
.card-list { background: var(--bg-2); border-radius: 14px; overflow: hidden; }
table.data { width: 100%; border-collapse: collapse; }
table.data thead th {
  text-align: left; padding: 12px 16px; font-size: 12px; font-weight: 600;
  letter-spacing: .04em; text-transform: uppercase; color: var(--text-muted);
  background: var(--bg-3); border-bottom: 1px solid rgba(255,255,255,.05);
}
table.data tbody td {
  padding: 14px 16px; border-bottom: 1px solid rgba(255,255,255,.04);
  font-size: 14px; vertical-align: middle;
}
table.data tbody tr:last-child td { border-bottom: 0; }
table.data tbody tr:hover { background: rgba(255,255,255,.02); }
.row-link { color: var(--text); text-decoration: none; font-weight: 500; }
.row-link:hover { color: #c7d2fe; }

.badge {
  display: inline-block; padding: 3px 8px; border-radius: 999px;
  font-size: 11px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase;
  background: rgba(255,255,255,.06); color: var(--text-muted); border: 1px solid rgba(255,255,255,.06);
}
.badge.st-draft      { color: #fcd34d; background: rgba(252,211,77,.1); border-color: rgba(252,211,77,.2); }
.badge.st-generating { color: #93c5fd; background: rgba(147,197,253,.1); border-color: rgba(147,197,253,.2); }
.badge.st-ready      { color: #86efac; background: rgba(134,239,172,.1); border-color: rgba(134,239,172,.2); }
.badge.st-error      { color: #fca5a5; background: rgba(252,165,165,.1); border-color: rgba(252,165,165,.2); }
.badge.role-admin    { color: #c7d2fe; background: var(--accent-soft); border-color: rgba(99,102,241,.3); }
.badge.role-user     { color: var(--text-muted); }

/* ============ FORMS ============ */
.form-card {
  background: var(--bg-2); border: 1px solid rgba(255,255,255,.04);
  border-radius: 14px; padding: 24px; max-width: 560px;
  display: grid; gap: 18px; margin-bottom: 18px;
}
.form-card.subtle { background: transparent; border: 1px solid rgba(255,255,255,.06); }
.form-card.danger { border-color: rgba(220,38,38,.25); }
.form-card h3 { margin: 0 0 -4px; font-size: 16px; }
.form-card label { display: grid; gap: 6px; font-size: 14px; color: var(--text); }
.form-card label > span { color: var(--text-muted); font-size: 13px; }
.form-card input[type=text],
.form-card input[type=number],
.form-card input[type=password],
.form-card select {
  height: 42px; padding: 0 12px; border-radius: 8px;
  border: 1px solid rgba(255,255,255,.1); background: var(--bg-1);
  color: var(--text); font: inherit; font-size: 14px;
  transition: border-color .12s, box-shadow .12s;
}
.form-card input:focus, .form-card select:focus {
  outline: none; border-color: var(--accent); box-shadow: 0 0 0 4px var(--accent-soft);
}
.form-card input[disabled], .form-card select[disabled] { opacity: .5; }
.form-card .hint { color: var(--text-dim); font-size: 12px; }
.form-card .hint code {
  background: rgba(255,255,255,.06); padding: 1px 4px; border-radius: 4px; font-size: 11px;
}

.form-card .alert {
  padding: 10px 12px; border-radius: 10px;
  background: rgba(220,38,38,.08); color: #fca5a5;
  border: 1px solid rgba(220,38,38,.25); font-size: 14px;
}

.form-actions { display: flex; gap: 8px; justify-content: flex-end; margin-top: 4px; }

.radio-group {
  border: 1px solid rgba(255,255,255,.08); border-radius: 10px;
  padding: 12px 14px; display: grid; gap: 8px; margin: 0;
}
.radio-group legend { padding: 0 6px; color: var(--text-muted); font-size: 12px; text-transform: uppercase; letter-spacing: .04em; }
.radio { display: inline-flex; align-items: center; gap: 8px; cursor: pointer; font-size: 14px; }
.radio input { accent-color: var(--accent); }

.checkbox { display: inline-flex; align-items: center; gap: 8px; font-size: 14px; cursor: pointer; }
.checkbox input { accent-color: var(--accent); }

.quota-row { display: grid; gap: 10px; }
.quota-input { display: flex; gap: 8px; }
.quota-input input[type=number] { flex: 1; }
.quota-input select { width: 90px; }

/* ============ BANNER ============ */
.banner {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; padding: 14px 16px; border-radius: 12px; margin-bottom: 18px;
  font-size: 14px;
}
.banner.success { background: var(--success-bg); color: var(--success); border: 1px solid var(--success-border); }
.banner.info    { background: rgba(147,197,253,.1); color: #93c5fd; border: 1px solid rgba(147,197,253,.2); }
.banner code { padding: 2px 6px; background: rgba(0,0,0,.06); border-radius: 4px; }
.banner .big-secret {
  font-size: 16px; font-weight: 600; padding: 4px 10px;
  background: rgba(0,0,0,.08); border-radius: 6px; user-select: all;
}

/* ============ PROJECT PAGE ============ */
.card-section {
  background: var(--bg-2); border: 1px solid rgba(255,255,255,.04);
  border-radius: 14px; padding: 24px; margin-bottom: 18px;
}
.card-section h2 { margin: 0 0 8px; font-size: 18px; letter-spacing: -.01em; }

dl.kv { display: grid; grid-template-columns: max-content 1fr; gap: 6px 24px; margin: 0; font-size: 14px; }
dl.kv dt { color: var(--text-muted); }
dl.kv dd { margin: 0; }

.section-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 14px; gap: 16px; }
.section-head h2 { margin: 0; }
.section-meta { font-size: 13px; }
.ta-center { text-align: center; }

/* ============ DROPZONE ============ */
.dropzone {
  position: relative; margin-bottom: 16px;
  border: 1.5px dashed rgba(255,255,255,.14);
  border-radius: 12px;
  background: rgba(255,255,255,.02);
  padding: 28px 24px;
  text-align: center;
  transition: background .15s, border-color .15s;
  cursor: default;
}
.dropzone.drag {
  border-color: var(--accent);
  background: rgba(99,102,241,.08);
}
.dropzone .dz-title { font-size: 15px; color: var(--text); }
.dropzone .dz-hint  { font-size: 13px; color: var(--text-muted); margin-top: 4px; }
.dropzone .link {
  background: none; border: 0; color: var(--accent); cursor: pointer;
  padding: 0; font: inherit; font-size: inherit; text-decoration: underline;
}
.dropzone .link:hover { color: #818cf8; }

/* ============ INLINE EDITABLE TITLE ============ */
h1.editable-title {
  outline: none;
  border-bottom: 2px solid transparent;
  transition: border-color .15s, background .15s;
  padding: 2px 4px; margin: 0 -4px;
  border-radius: 4px;
  cursor: text;
}
h1.editable-title:hover { background: rgba(255,255,255,.04); }
h1.editable-title:focus {
  background: rgba(255,255,255,.06);
  border-bottom-color: var(--accent);
}

/* ============ TRACKS LIST ============ */
.tracks { display: flex; flex-direction: column; gap: 8px; }

.track {
  position: relative;
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015));
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 12px;
  font-size: 14px;
  user-select: none;
  overflow: hidden;
  transition: background .15s, border-color .15s, transform .08s;
}
.track:hover {
  background: linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.02));
  border-color: rgba(255,255,255,.1);
}
.track.dragging { opacity: .35; transform: scale(.985); }
.track.uploading {
  background: linear-gradient(180deg, rgba(99,102,241,.08), rgba(99,102,241,.04));
  border-color: rgba(99,102,241,.28);
}
.track.error {
  background: linear-gradient(180deg, rgba(220,38,38,.09), rgba(220,38,38,.04));
  border-color: rgba(220,38,38,.32);
}
.track.expanded { border-color: rgba(99,102,241,.35); }

.track-row {
  display: grid;
  grid-template-columns: 16px 60px 1fr auto 36px 22px;
  align-items: center;
  gap: 16px;
  padding: 12px 14px 12px 8px;
  cursor: pointer;
}
.track-row .drag-handle {
  color: var(--text-dim); cursor: grab; text-align: center;
  font-size: 14px; line-height: 1; letter-spacing: -2px;
  opacity: 0; transition: opacity .12s;
}
.track:hover .track-row .drag-handle { opacity: 1; }
.track-row .drag-handle:active { cursor: grabbing; }
.t-expand {
  color: var(--text-dim); font-size: 14px;
  transition: transform .2s, color .15s;
  text-align: center;
  user-select: none;
}
.track:hover .t-expand { color: var(--text); }
.track.expanded .t-expand { transform: rotate(180deg); color: var(--accent); }

.t-num {
  width: 60px; height: 60px;
  display: grid; place-items: center;
  background:
    radial-gradient(circle at 30% 25%, rgba(99,102,241,.28), transparent 65%),
    rgba(99,102,241,.08);
  border: 1px solid rgba(99,102,241,.28);
  border-radius: 12px;
  font-weight: 700; font-size: 24px;
  letter-spacing: -.02em;
  font-variant-numeric: tabular-nums;
  color: #c7d2fe;
  box-shadow: 0 1px 0 rgba(255,255,255,.05) inset, 0 4px 12px rgba(99,102,241,.12);
}
.track.uploading .t-num {
  color: var(--text-dim);
  background: rgba(255,255,255,.04);
  border-color: rgba(255,255,255,.1);
  box-shadow: none;
  animation: num-pulse 1.6s ease-in-out infinite;
}
.track.error .t-num {
  color: #fca5a5;
  background: rgba(220,38,38,.08);
  border-color: rgba(220,38,38,.28);
  box-shadow: none;
}
@keyframes num-pulse {
  0%, 100% { opacity: 1; }
  50%      { opacity: .55; }
}

.t-info { min-width: 0; display: flex; flex-direction: column; gap: 4px; }
.t-title {
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  color: var(--text); font-weight: 600; font-size: 15px; letter-spacing: -.005em;
}
.t-file {
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  color: var(--text-muted); font-size: 12px;
}

.t-spec { text-align: right; font-variant-numeric: tabular-nums; min-width: 160px; }
.t-duration { color: var(--text); font-weight: 600; font-size: 15px; letter-spacing: -.005em; }
.t-format   { font-size: 12px; margin-top: 3px; }

.badge.converted {
  margin-left: 6px;
  color: #fbbf24; background: rgba(251,191,36,.1); border-color: rgba(251,191,36,.28);
}

.t-delete {
  width: 32px; height: 32px; border-radius: 8px;
  border: 0; background: transparent; color: var(--text-muted);
  font-size: 20px; line-height: 1; cursor: pointer;
  transition: background .12s, color .12s;
}
.t-delete:hover:not([disabled]) { background: rgba(220,38,38,.12); color: #fca5a5; }
.t-delete[disabled] { opacity: .3; cursor: default; }

.t-pct {
  display: inline-block; min-width: 42px; text-align: right;
  font-variant-numeric: tabular-nums;
  color: var(--accent); font-weight: 700; font-size: 15px; letter-spacing: -.005em;
}

/* ----- pasek postępu na dole kafelka ----- */
.t-progress {
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 4px;
  background: rgba(255,255,255,.05);
  pointer-events: none;
  overflow: hidden;
}
.t-progress > span {
  display: block; height: 100%; width: 0;
  background: linear-gradient(90deg, #6366f1 0%, #a78bfa 50%, #6366f1 100%);
  background-size: 200% 100%;
  animation: progress-shimmer 1.6s linear infinite;
  box-shadow: 0 0 10px rgba(99,102,241,.6), 0 0 4px rgba(167,139,250,.6);
  transition: width .12s linear;
}
@keyframes progress-shimmer {
  0%   { background-position: 0% 0; }
  100% { background-position: -200% 0; }
}

/* indeterminate — gdy serwer konwertuje */
.t-progress.indeterminate { background: rgba(99,102,241,.12); }
.t-progress.indeterminate > span {
  width: 35%;
  animation: progress-indet 1.2s cubic-bezier(.4,0,.2,1) infinite,
             progress-shimmer 1.6s linear infinite;
}
@keyframes progress-indet {
  0%   { transform: translateX(-100%); }
  100% { transform: translateX(286%); }
}

.banner.error {
  display: block; padding: 10px 14px; border-radius: 10px;
  background: rgba(220,38,38,.08); color: #fca5a5;
  border: 1px solid rgba(220,38,38,.25); font-size: 14px; margin-bottom: 10px;
}

/* ============ EXPAND PANEL (per‑track meta) ============ */
.expand-panel {
  display: none;
  padding: 4px 16px 16px 16px;
  border-top: 1px solid rgba(99,102,241,.18);
  background: rgba(0,0,0,.12);
  animation: expand-in .2s ease-out;
}
.track.expanded .expand-panel { display: block; }
@keyframes expand-in {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ============ META GRID (album + track) ============ */
.meta-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  margin-top: 12px;
}
.meta-grid.two-col {
  grid-template-columns: 1fr 1fr;
}
@media (max-width: 760px) {
  .meta-grid.two-col { grid-template-columns: 1fr; }
}

.meta-row {
  display: grid;
  grid-template-columns: 140px 1fr auto;
  align-items: center;
  gap: 10px;
}
.meta-row.meta-half { grid-column: span 1; }
.meta-row.meta-flags {
  grid-column: 1 / -1;
  display: flex; gap: 24px;
  padding-left: 150px;
}
.meta-row .meta-label {
  color: var(--text-muted);
  font-size: 13px;
  text-align: right;
}

.meta-row > input[type="text"],
.meta-row > input[type="number"],
.meta-row > select,
.meta-row .frames-input > input[type="number"] {
  height: 36px;
  padding: 0 10px;
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(0,0,0,.25);
  color: var(--text);
  font: inherit; font-size: 14px;
  transition: border-color .12s, box-shadow .12s, background .12s;
}
.meta-row .mono { font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; }
.meta-row > input:focus,
.meta-row > select:focus,
.meta-row .frames-input > input:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
  background: rgba(0,0,0,.4);
}
.meta-row > input.saving,
.meta-row .frames-input > input.saving { border-color: rgba(99,102,241,.5); }
.meta-row > input.saved,
.meta-row .frames-input > input.saved {
  border-color: rgba(134,239,172,.5);
  box-shadow: 0 0 0 3px rgba(134,239,172,.15);
}
.meta-row > input.error,
.meta-row .frames-input > input.error {
  border-color: rgba(252,165,165,.55);
  box-shadow: 0 0 0 3px rgba(220,38,38,.12);
}

.frames-input {
  display: grid;
  grid-template-columns: 110px auto auto;
  align-items: center; gap: 10px;
}
.frames-preview {
  color: var(--text-muted);
  font-size: 13px;
  font-variant-numeric: tabular-nums;
}

.bulk-btn {
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.04);
  color: var(--text-muted);
  padding: 6px 10px;
  border-radius: 6px;
  font-size: 12px;
  cursor: pointer;
  white-space: nowrap;
  transition: background .12s, color .12s, border-color .12s;
}
.bulk-btn:hover {
  color: var(--text);
  background: rgba(99,102,241,.12);
  border-color: rgba(99,102,241,.32);
}
.bulk-btn.ok {
  color: #86efac;
  background: rgba(134,239,172,.1);
  border-color: rgba(134,239,172,.4);
}

/* ============ CD-TEXT live sanitize hints ============ */
input.cdtext-ok,
[contenteditable="true"].cdtext-ok {
  border-color: rgba(134,239,172,.55) !important;
  box-shadow: 0 0 0 3px rgba(134,239,172,.15) !important;
  transition: border-color .25s, box-shadow .25s;
}
input.cdtext-warn,
[contenteditable="true"].cdtext-warn {
  border-color: rgba(251,191,36,.65) !important;
  box-shadow: 0 0 0 3px rgba(251,191,36,.18) !important;
  transition: border-color .25s, box-shadow .25s;
}
.banner.warn {
  display: block; padding: 10px 14px; border-radius: 10px;
  background: rgba(251,191,36,.08); color: #fbbf24;
  border: 1px solid rgba(251,191,36,.32); font-size: 14px; margin-bottom: 10px;
}
h1.editable-title.cdtext-ok   { border-bottom-color: rgba(134,239,172,.7); }
h1.editable-title.cdtext-warn { border-bottom-color: rgba(251,191,36,.85); }

.banner.info {
  display: block; padding: 10px 14px; border-radius: 10px;
  background: rgba(99,102,241,.08); color: #a5b4fc;
  border: 1px solid rgba(99,102,241,.32); font-size: 14px; margin-bottom: 10px;
}

/* ============ LANG TOGGLE (top bar + login) ============ */
.lang-toggle {
  display: flex; gap: 4px; align-items: center;
  margin-right: 10px;
}
.lang-flag {
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  border-radius: 6px;
  padding: 4px 6px;
  cursor: pointer;
  display: inline-flex; align-items: center;
  opacity: .55;
  transition: opacity .15s, border-color .15s, background .15s, transform .05s;
  line-height: 0;
}
.lang-flag:hover { opacity: .9; background: rgba(255,255,255,.06); }
.lang-flag.active {
  opacity: 1;
  border-color: rgba(99,102,241,.6);
  background: rgba(99,102,241,.12);
  cursor: default;
}
.lang-flag svg { display: block; border-radius: 2px; box-shadow: 0 0 0 1px rgba(0,0,0,.2); }

.lang-toggle.lang-toggle-floating {
  position: fixed; right: 22px; top: 22px;
  background: rgba(15,23,42,.6); padding: 6px;
  border-radius: 10px; backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.1);
}

/* ============ ADMIN: USER FORM ============ */
.user-form {
  background: var(--bg-2);
  border: 1px solid rgba(255,255,255,.04);
  border-radius: 16px;
  padding: 28px;
  max-width: 720px;
  display: grid; gap: 24px;
  margin-bottom: 18px;
}
.user-form .alert {
  padding: 10px 12px; border-radius: 10px;
  background: rgba(220,38,38,.08); color: #fca5a5;
  border: 1px solid rgba(220,38,38,.25); font-size: 14px;
}
.user-form-section { display: grid; gap: 10px; }
.user-label {
  font-size: 12px; font-weight: 600;
  letter-spacing: .04em; text-transform: uppercase;
  color: var(--text-muted);
}
.user-input {
  height: 42px; padding: 0 12px;
  border: 1px solid rgba(255,255,255,.08);
  background: var(--bg-1); color: var(--text);
  border-radius: 8px; font: inherit; font-size: 14px;
  transition: border-color .12s, box-shadow .12s;
}
.user-input:focus {
  outline: none; border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

/* role toggle */
.role-toggle {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
}
.role-toggle input[type="radio"] { position: absolute; opacity: 0; pointer-events: none; }
.role-toggle .role-card {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 16px;
  border: 1.5px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.02);
  border-radius: 12px;
  cursor: pointer;
  transition: border-color .12s, background .12s, transform .05s;
  user-select: none;
}
.role-toggle .role-card:hover { background: rgba(255,255,255,.04); border-color: rgba(255,255,255,.14); }
.role-toggle input[type="radio"]:checked + .role-card {
  border-color: rgba(99,102,241,.7);
  background: linear-gradient(180deg, rgba(99,102,241,.16), rgba(99,102,241,.06));
  box-shadow: 0 0 0 3px rgba(99,102,241,.18);
}
.role-toggle .role-card.is-disabled { opacity: .45; cursor: not-allowed; }
.role-toggle .role-svg { color: var(--accent); }
.role-toggle .role-card.is-disabled .role-svg { color: var(--text-dim); }
.role-toggle .role-name { font-weight: 600; color: var(--text); font-size: 15px; }

/* quota presets */
.quota-presets {
  display: flex; flex-wrap: wrap; gap: 6px;
}
.quota-presets .preset {
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  color: var(--text);
  padding: 8px 14px;
  border-radius: 999px;
  font-size: 13px; font-weight: 500;
  cursor: pointer;
  transition: background .12s, border-color .12s, color .12s;
}
.quota-presets .preset:hover {
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.16);
}
.quota-presets .preset.active {
  background: rgba(99,102,241,.18);
  border-color: rgba(99,102,241,.55);
  color: #c7d2fe;
}
.quota-custom { display: flex; align-items: center; gap: 8px; }
.quota-custom input[type=number] { flex: 0 0 120px; }
.quota-custom select { width: 80px; }
.quota-summary { font-size: 13px; }

/* ============ DDP GENERATE PROGRESS ============ */
.ddp-progress {
  margin-top: 12px;
  display: flex; flex-direction: column; gap: 6px;
  min-width: 240px;
}
.ddp-bar {
  width: 100%; height: 6px;
  background: rgba(255,255,255,.06);
  border-radius: 999px;
  overflow: hidden;
}
.ddp-bar > span {
  display: block; height: 100%; width: 0;
  background: linear-gradient(90deg, var(--accent), #a78bfa);
  box-shadow: 0 0 8px rgba(99,102,241,.45);
  transition: width .25s linear;
}
.ddp-msg { font-size: 13px; }
#ddp-actions { display: flex; flex-direction: column; align-items: flex-end; gap: 6px; }
#ddp-actions > * { display: inline-flex; align-items: center; }
.email-link { color: var(--text-muted); text-decoration: none; }
.email-link:hover { color: var(--text); text-decoration: underline; }


.checkbox { display: inline-flex; align-items: center; gap: 8px; font-size: 14px; cursor: pointer; }
.checkbox input { accent-color: var(--accent); }

.small { font-size: 12px; }

