/* =============================================================================
 * admin.css — styles specific to the admin panel (reuses ../css/styles.css
 * for theme tokens, fonts, buttons, cards and inputs).
 * ========================================================================== */

.admin-body { background: var(--bg); }

.admin-topbar {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  background: linear-gradient(180deg, var(--color-navy-2), var(--color-navy));
  color: #fff; padding: 14px 24px; position: sticky; top: 0; z-index: 20;
}
.admin-title { font-weight: 700; font-size: 1.1rem; }
.admin-title .brand-en { color: #B9BBF0; font-size: .85rem; }
.admin-actions { margin-inline-start: auto; display: flex; gap: 8px; }
.admin-actions .btn-ghost-sm { width: auto; padding: 8px 14px; text-decoration: none; display: inline-flex; align-items: center; }

.admin-main { padding: 24px; max-width: 1200px; margin-inline: auto; }

.admin-toolbar { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.admin-toolbar .section-title { margin: 24px 0 14px; }
#user-search { max-width: 320px; }

/* ---- users table ---- */
.table-wrap { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); overflow-x: auto; }
.users-table { width: 100%; border-collapse: collapse; font-size: .9rem; min-width: 900px; }
.users-table thead th {
  position: sticky; top: 0; background: var(--surface-2); text-align: start;
  padding: 12px 10px; font-weight: 700; color: var(--text-muted); border-bottom: 2px solid var(--border); white-space: nowrap;
}
.users-table tbody td { padding: 10px; border-bottom: 1px solid var(--border); vertical-align: middle; }
.users-table tbody tr:hover { background: var(--surface-2); }
.users-table .email-cell { font-family: var(--font-en); direction: ltr; font-weight: 600; color: var(--color-primary); }
.users-table .mono { font-family: var(--font-en); direction: ltr; }
.users-table input.cell-input {
  width: 110px; padding: 6px 8px; font-size: .85rem; border: 1px solid var(--border);
  border-radius: 8px; font-family: var(--font-ar);
}
.users-table input.cell-input.ltr { font-family: var(--font-en); }
.users-table select.cell-select {
  padding: 6px 8px; font-size: .85rem; border: 1px solid var(--border); border-radius: 8px;
  font-family: var(--font-ar); background: var(--surface); cursor: pointer;
}
.xp-pill { background: #EEF0FA; color: var(--color-primary); font-weight: 700; padding: 2px 9px; border-radius: 999px; font-variant-numeric: tabular-nums; }
.progress-mini { white-space: nowrap; font-size: .82rem; color: var(--text-muted); }

.row-actions { display: flex; gap: 4px; white-space: nowrap; }
.icon-btn {
  border: 1px solid var(--border); background: var(--surface); border-radius: 8px; cursor: pointer;
  padding: 6px 8px; font-size: .85rem; transition: all var(--t-fast);
}
.icon-btn:hover { transform: translateY(-1px); border-color: var(--color-primary); }
.icon-btn.save:hover   { background: var(--color-success-soft); border-color: var(--color-success); }
.icon-btn.reset:hover  { background: var(--color-warning-soft); border-color: var(--color-warning); }
.icon-btn.del:hover    { background: var(--color-mismatch-soft); border-color: var(--color-mismatch); }

.last-active { color: var(--text-muted); font-size: .82rem; white-space: nowrap; }

@media (max-width: 600px) {
  .admin-main { padding: 16px; }
  .admin-title .brand-en { display: none; }
}
