/* =========================================================
   Auth pages — login, password reset
   ========================================================= */

.auth-body {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: var(--surface-canvas);
  padding: 24px 16px;
}

/* Floating flash above the card */
.auth-flash {
  position: fixed;
  top: 16px;
  left: 50%;
  transform: translateX(-50%);
  min-width: 280px;
  max-width: 480px;
  padding: 10px 16px;
  border-radius: var(--r-md);
  font-size: var(--text-sm);
  font-weight: 500;
  z-index: 100;
  text-align: center;
}
.auth-flash--notice { background: var(--success-100); color: var(--success-700); }
.auth-flash--alert  { background: var(--danger-100);  color: var(--danger-700);  }

/* Card */
.auth-card {
  width: 100%;
  max-width: 400px;
  background: var(--surface-card);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: 36px 32px;
  box-shadow: var(--shadow-md);
}

/* Brand */
.auth-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 28px;
}
.auth-brand__logo {
  width: 36px;
  height: 36px;
  background: var(--surface-nav);
  color: var(--nav-accent);
  border-radius: var(--r-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: var(--text-lg);
}
.auth-brand__title {
  font-weight: 700;
  font-size: var(--text-lg);
  color: var(--ink-900);
  line-height: 1;
  white-space: nowrap;
}

/* Heading */
.auth-heading {
  font-size: var(--text-xl);
  font-weight: 600;
  color: var(--ink-900);
  margin-bottom: 6px;
  line-height: var(--lh-snug);
}
.auth-subtext {
  font-size: var(--text-sm);
  color: var(--ink-500);
  margin-bottom: 20px;
}

/* Form */
.auth-form {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: 20px;
}
.auth-field {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.auth-field--row {
  flex-direction: row;
  align-items: center;
  gap: 8px;
}
.auth-label {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--ink-700);
}
.auth-label--inline {
  font-weight: 400;
  color: var(--ink-600);
  cursor: pointer;
  user-select: none;
}
.auth-label-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}
.auth-input {
  height: 36px;
  padding: 0 10px;
  border: 1px solid var(--border-strong);
  border-radius: var(--r-md);
  font-size: var(--text-base);
  font-family: var(--font-sans);
  color: var(--ink-900);
  background: var(--paper-elev);
  outline: none;
  transition: border-color var(--dur-fast), box-shadow var(--dur-fast);
}
.auth-input:focus {
  border-color: var(--accent-600);
  box-shadow: var(--shadow-focus);
}
.auth-checkbox {
  width: 15px;
  height: 15px;
  accent-color: var(--accent-600);
  cursor: pointer;
}
.auth-btn {
  height: 38px;
  background: var(--surface-nav);
  color: #fff;
  border: none;
  border-radius: var(--r-md);
  font-size: var(--text-base);
  font-weight: 600;
  font-family: var(--font-sans);
  cursor: pointer;
  transition: background var(--dur-fast);
  margin-top: 4px;
}
.auth-btn:hover { background: var(--surface-nav-elev); }
.auth-btn:active { background: var(--surface-nav-hover); }

/* Field-level error */
.auth-input--error {
  border-color: var(--danger-500) !important;
  background: #fff8f8;
}
.auth-input--error:focus {
  box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.18) !important;
}
.auth-field-error {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: var(--text-xs);
  font-weight: 500;
  color: var(--danger-700);
  margin-top: 2px;
}

/* Inline alert inside the card */
.auth-alert {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  background: var(--danger-100);
  color: var(--danger-700);
  border: 1px solid #fca5a5;
  border-radius: var(--r-md);
  padding: 10px 12px;
  font-size: var(--text-sm);
  font-weight: 500;
  margin-top: 4px;
}

/* Links */
.auth-link {
  color: var(--accent-700);
  font-size: var(--text-sm);
  text-decoration: none;
}
.auth-link:hover { text-decoration: underline; }
.auth-link--sm { font-size: var(--text-xs); }

.auth-footer {
  margin-top: 20px;
  text-align: center;
  font-size: var(--text-sm);
  color: var(--ink-500);
}

/* ---- Search bar ---- */
.admin-search-bar {
  padding: 10px 20px;
  background: var(--paper-elev);
  border-bottom: 1px solid var(--border-subtle);
}
.admin-search-bar__input-wrap {
  position: relative;
  width: 100%;
}
.admin-search-bar__icon {
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--ink-400);
  pointer-events: none;
}
.admin-search-bar__input {
  width: 100%;
  height: 34px;
  padding: 0 32px 0 32px;
  border: 1px solid var(--border-strong);
  border-radius: var(--r-md);
  font-size: var(--text-base);
  font-family: var(--font-sans);
  color: var(--ink-900);
  background: var(--surface-muted);
  outline: none;
  transition: border-color var(--dur-fast), background var(--dur-fast);
}
.admin-search-bar__input:focus {
  border-color: var(--accent-600);
  background: var(--paper-elev);
  box-shadow: var(--shadow-focus);
}
.admin-search-bar__clear {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--ink-400);
  display: flex;
  align-items: center;
  padding: 2px;
  border-radius: var(--r-sm);
}
.admin-search-bar__clear:hover { color: var(--ink-700); }

.admin-search-result-hint {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  font-size: var(--text-sm);
  color: var(--ink-500);
  border-bottom: 1px solid var(--border-subtle);
  background: var(--accent-50);
}

/* ---- Admin user table additions ---- */
.data-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-base);
}
.data-table th {
  text-align: left;
  padding: 8px 12px;
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--ink-400);
  border-bottom: 1px solid var(--border);
}
.data-table td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--border-subtle);
  color: var(--ink-800);
  vertical-align: middle;
}
.data-table tbody tr:last-child td { border-bottom: none; }
.data-table tbody tr:hover td { background: var(--surface-muted); }
.row--muted td { color: var(--ink-400); }
.td--actions { text-align: right; white-space: nowrap; }

/* Badges */
.badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: 99px;
  font-size: var(--text-xs);
  font-weight: 500;
}
.badge--success { background: var(--success-100); color: var(--success-700); }
.badge--danger  { background: var(--danger-100);  color: var(--danger-700);  }
.badge--warn    { background: var(--accent-100);  color: var(--accent-700);  }
.badge--neutral { background: var(--ink-100);     color: var(--ink-500);     }

/* Buttons — ghost and danger-ghost variants used in table */
.btn--danger-ghost {
  color: var(--danger-700);
  background: transparent;
  border: 1px solid var(--danger-700);
}
.btn--danger-ghost:hover { background: var(--danger-100); }

/* bgedit__ additions for admin form */
.bgedit__hint {
  font-size: var(--text-xs);
  color: var(--ink-400);
  margin-top: 2px;
}
.bgedit__hint--inline { margin-left: 6px; }
.bgedit__row--check {
  flex-direction: row;
  align-items: flex-start;
  gap: 8px;
}
.bgedit__checkbox {
  width: 15px;
  height: 15px;
  margin-top: 2px;
  accent-color: var(--accent-600);
  cursor: pointer;
}
.bgedit__label--inline {
  font-weight: 400;
  cursor: pointer;
}

/* =========================================================
   Admin — User Management pages
   ========================================================= */

/* Page wrapper */
.admin-page {
  padding: 0;
}

/* Page header */
.admin-page__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 12px 20px;
  background: var(--paper-elev);
  border-bottom: 1px solid var(--border-subtle);
}
.admin-page__header-left { flex: 1; min-width: 0; }
.admin-page__eyebrow {
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-400);
  margin-bottom: 4px;
}
.admin-page__title {
  font-size: var(--text-2xl);
  font-weight: 700;
  color: var(--ink-900);
  letter-spacing: -0.02em;
  margin: 0 0 3px;
  line-height: 1.15;
}
.admin-page__sub {
  font-size: var(--text-sm);
  color: var(--ink-500);
  margin: 0;
}

/* Stats strip */
.admin-stats {
  display: flex;
  border-bottom: 1px solid var(--border-subtle);
  background: var(--paper-elev);
}
.admin-stat {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding: 14px 20px;
  border-right: 1px solid var(--border-subtle);
  gap: 2px;
}
.admin-stat:last-child { border-right: none; }
.admin-stat__val {
  font-size: var(--text-2xl);
  font-weight: 700;
  color: var(--ink-900);
  line-height: 1.1;
  letter-spacing: -0.02em;
}
.admin-stat__lbl {
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--ink-400);
}

/* Table card */
.admin-table-card {
  margin: 20px;
  background: var(--paper-elev);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

/* Table */
.admin-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-base);
}
.admin-table thead tr {
  background: var(--surface-muted);
}
.admin-table th {
  text-align: left;
  padding: 9px 16px;
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--ink-400);
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
}
.admin-table td {
  padding: 13px 16px;
  border-bottom: 1px solid var(--border-subtle);
  color: var(--ink-800);
  vertical-align: middle;
}
.admin-table tbody tr:last-child td { border-bottom: none; }
.admin-table tbody tr:hover td { background: var(--surface-muted); }
.admin-table__row--muted td { opacity: 0.5; }
.admin-table__date {
  font-size: var(--text-sm);
  color: var(--ink-500);
  white-space: nowrap;
}
.admin-table__actions { text-align: right; white-space: nowrap; }
.admin-table__empty {
  text-align: center;
  padding: 48px 16px !important;
  color: var(--ink-400);
  font-size: var(--text-sm);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}

/* User cell — avatar + name + email */
.admin-user-cell {
  display: flex;
  align-items: center;
  gap: 12px;
}
.admin-avatar {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--text-sm);
  font-weight: 700;
  flex-shrink: 0;
  letter-spacing: -0.01em;
}
.admin-avatar--admin {
  background: linear-gradient(135deg, #b45309, #78350f);
  color: #fff;
}
.admin-avatar--user {
  background: linear-gradient(135deg, var(--surface-nav), var(--surface-nav-hover));
  color: rgba(207,219,234,0.9);
}
.admin-user-cell__info { min-width: 0; }
.admin-user-cell__name {
  font-weight: 600;
  color: var(--ink-900);
  font-size: var(--text-base);
  white-space: nowrap;
}
.admin-user-cell__email {
  font-size: var(--text-sm);
  color: var(--ink-500);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Action group */
.admin-action-group {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.admin-you-tag {
  font-size: var(--text-xs);
  color: var(--ink-400);
  padding: 3px 8px;
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  font-weight: 500;
}

/* Permission toggle row */
.admin-perm-row {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 14px 16px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  cursor: pointer;
  transition: border-color var(--dur-fast), background var(--dur-fast);
  background: var(--paper-elev);
}
.admin-perm-row:hover { border-color: var(--accent-600); background: var(--accent-50); }
.admin-perm-row__check {
  width: 16px;
  height: 16px;
  margin-top: 2px;
  accent-color: var(--accent-600);
  cursor: pointer;
  flex-shrink: 0;
}
.admin-perm-row__body { flex: 1; min-width: 0; }
.admin-perm-row__title {
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--ink-900);
}
.admin-perm-row__desc {
  font-size: var(--text-sm);
  color: var(--ink-500);
  margin-top: 2px;
  line-height: 1.5;
}
.admin-perm-row__badge {
  font-size: var(--text-xs);
  font-weight: 600;
  padding: 3px 9px;
  border-radius: 20px;
  background: var(--accent-100);
  color: var(--accent-700);
  white-space: nowrap;
  flex-shrink: 0;
}

/* bgedit section additions for admin form */
.bgedit__section {
  background: var(--paper-elev);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 20px;
  margin-bottom: 16px;
  box-shadow: var(--shadow-xs);
}
.bgedit__section-head {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 18px;
}
.bgedit__section-icon {
  width: 32px;
  height: 32px;
  border-radius: var(--r-md);
  background: var(--surface-muted);
  border: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ink-600);
  flex-shrink: 0;
}
.bgedit__section-title {
  font-size: var(--text-md);
  font-weight: 600;
  color: var(--ink-900);
}
.bgedit__section-sub {
  font-size: var(--text-sm);
  color: var(--ink-500);
  margin-top: 1px;
}
