/* ─── Admin layout ────────────────────────────────────────────────── */
.admin-wrap {
  max-width: 960px;
  margin: 0 auto;
  padding: var(--sp-8) var(--sp-6);
}

.admin-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--sp-8);
  padding-bottom: var(--sp-5);
  border-bottom: 1px solid var(--border);
}

.admin-header h1 {
  font-size: 22px;
  color: var(--primary);
}

/* ─── Login card ──────────────────────────────────────────────────── */
.login-card {
  max-width: 380px;
  margin: var(--sp-12) auto;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-8);
}

.login-card h1 {
  font-size: 22px;
  color: var(--primary);
  margin-bottom: var(--sp-2);
}

.login-card p {
  color: var(--ink-muted);
  font-size: 13px;
  margin: 0 0 var(--sp-6);
}

/* ─── Formulaires ─────────────────────────────────────────────────── */
.form-group {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  margin-bottom: var(--sp-4);
}

.form-label {
  font-size: 12px;
  font-weight: 500;
  color: var(--ink-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.form-input, .form-select {
  padding: var(--sp-3) var(--sp-4);
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 13px;
  outline: none;
  transition: border-color var(--t-fast);
  width: 100%;
}
.form-input:focus, .form-select:focus { border-color: var(--accent); }

.form-error {
  padding: var(--sp-3) var(--sp-4);
  background: rgba(239, 68, 68, 0.1);
  border: 1px solid rgba(239, 68, 68, 0.3);
  border-radius: var(--r-sm);
  color: var(--error);
  font-size: 13px;
  margin-bottom: var(--sp-4);
}

/* ─── Dashboard stats ─────────────────────────────────────────────── */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: var(--sp-4);
  margin-bottom: var(--sp-8);
}

.stat-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: var(--sp-5);
}

.stat-card__value {
  font-family: var(--font-heading);
  font-size: 32px;
  font-weight: 700;
  color: var(--primary);
  line-height: 1;
}

.stat-card__label {
  font-size: 12px;
  color: var(--ink-muted);
  margin-top: var(--sp-1);
}

/* ─── Galaxy list table ───────────────────────────────────────────── */
.admin-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}

.admin-table th {
  text-align: left;
  padding: var(--sp-2) var(--sp-4);
  font-family: var(--font-heading);
  font-size: 11px;
  font-weight: 600;
  color: var(--ink-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border-bottom: 1px solid var(--border);
}

.admin-table td {
  padding: var(--sp-3) var(--sp-4);
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
}

.admin-table tr:hover td { background: var(--surface-2); }

.admin-table .id-cell {
  font-family: var(--font-heading);
  font-weight: 600;
  color: var(--primary);
}

/* ─── Upload zone ─────────────────────────────────────────────────── */
.upload-section {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-6);
  margin-bottom: var(--sp-6);
}

.upload-section h2 {
  font-size: 16px;
  color: var(--ink);
  margin-bottom: var(--sp-5);
}

.drop-zone {
  border: 2px dashed var(--border-hover);
  border-radius: var(--r);
  padding: var(--sp-10) var(--sp-6);
  text-align: center;
  cursor: pointer;
  transition: border-color var(--t), background var(--t);
  user-select: none;
}
.drop-zone:hover, .drop-zone.drag-over {
  border-color: var(--primary);
  background: var(--primary-dim);
}

.drop-zone__icon {
  width: 48px;
  height: 48px;
  margin: 0 auto var(--sp-3);
  color: var(--ink-muted);
}
.drop-zone:hover .drop-zone__icon,
.drop-zone.drag-over .drop-zone__icon { color: var(--primary); }

.drop-zone__text {
  font-family: var(--font-heading);
  font-size: 15px;
  color: var(--ink);
  margin-bottom: var(--sp-1);
}
.drop-zone__sub { font-size: 12px; color: var(--ink-muted); }

/* ─── File queue ──────────────────────────────────────────────────── */
.file-queue {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  margin-top: var(--sp-4);
}

.file-item {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--sp-3);
  align-items: center;
  padding: var(--sp-3) var(--sp-4);
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
}

.file-item__name {
  font-size: 12px;
  color: var(--ink);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.file-item__size { font-size: 11px; color: var(--ink-muted); }

.progress-bar {
  width: 100%;
  height: 4px;
  background: var(--border);
  border-radius: 2px;
  overflow: hidden;
  margin-top: var(--sp-1);
  grid-column: 1 / -1;
}

.progress-bar__fill {
  height: 100%;
  background: var(--primary);
  transition: width var(--t);
  border-radius: 2px;
}

.file-item--done .progress-bar__fill  { background: var(--success); }
.file-item--error .progress-bar__fill { background: var(--error); }

.file-item__status {
  font-size: 11px;
  padding: 2px 8px;
  border-radius: var(--r-xl);
  white-space: nowrap;
}
.status-pending  { background: rgba(122,139,176,0.15); color: var(--ink-muted); }
.status-uploading{ background: var(--accent-dim); color: var(--accent); }
.status-done     { background: rgba(16,185,129,0.15); color: var(--success); }
.status-error    { background: rgba(239,68,68,0.15);  color: var(--error); }
