/* ============================================
   LOTTACASH — Admin Panel Styles
   ============================================ */

/* ---------- Loading / denied gate states ---------- */
.admin-state-card {
  max-width: 480px;
  margin: var(--sp-16, 4rem) auto;
  text-align: center;
  background: var(--c-surface);
  border: 1px solid var(--c-border-soft);
  border-radius: var(--r-xl, 1.25rem);
  padding: var(--sp-10, 2.5rem) var(--sp-6, 1.5rem);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-3);
}

.admin-state-card[hidden] {
  display: none;
}

.admin-state-card__icon {
  font-size: 2.5rem;
}

.admin-state-card h1 {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  color: var(--c-text);
  margin: 0;
}

.admin-state-card p {
  color: var(--c-text-muted);
  font-size: var(--text-sm);
  margin: 0 0 var(--sp-2);
}

.spinner {
  width: 32px;
  height: 32px;
  border: 3px solid var(--c-border-soft);
  border-top-color: var(--c-primary);
  border-radius: 50%;
  animation: lc-spin 0.8s linear infinite;
}

@keyframes lc-spin {
  to { transform: rotate(360deg); }
}

/* ---------- Header ---------- */
.admin-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--sp-4);
  margin: var(--sp-6) 0 var(--sp-6);
  flex-wrap: wrap;
}

.admin-header__eyebrow {
  font-size: var(--text-sm);
  color: var(--c-gold-light);
  font-weight: 600;
  letter-spacing: 0.04em;
  margin: 0 0 var(--sp-1);
}

.admin-header__title {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  color: var(--c-text);
  margin: 0;
}

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

/* ---------- Tabs panels ---------- */
.admin-panel {
  margin-top: var(--sp-5);
}

.admin-subheading {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  color: var(--c-text);
  margin: var(--sp-6) 0 var(--sp-3);
}

/* ---------- Filter chips ---------- */
.admin-filter-group {
  display: flex;
  gap: var(--sp-2);
  flex-wrap: wrap;
}

.chip {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-1);
  padding: var(--sp-1) var(--sp-3);
  border-radius: var(--r-full, 999px);
  font-size: var(--text-xs);
  font-weight: 600;
  border: 1.5px solid var(--c-border-soft);
  background: var(--c-surface-2);
  color: var(--c-text-muted);
  cursor: pointer;
  transition: background var(--duration-fast), color var(--duration-fast), border-color var(--duration-fast);
  white-space: nowrap;
}

.chip:hover {
  border-color: var(--c-primary);
  color: var(--c-text);
}

.chip--filter.active {
  background: var(--c-primary);
  border-color: var(--c-primary);
  color: #fff;
}

/* ---------- Tables ---------- */
.admin-table-wrap {
  overflow-x: auto;
  margin-top: var(--sp-4);
  border-radius: var(--r-lg);
  border: 1px solid var(--c-border-soft);
}

.admin-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
  min-width: 640px;
}

.admin-table th,
.admin-table td {
  padding: var(--sp-3) var(--sp-4);
  text-align: left;
  white-space: nowrap;
}

.admin-table th {
  background: var(--c-surface-2);
  color: var(--c-text-muted);
  font-weight: 600;
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  position: sticky;
  top: 0;
}

.admin-table tbody tr {
  border-top: 1px solid var(--c-border-soft);
  transition: background var(--duration-fast);
}

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

.admin-table td {
  color: var(--c-text);
}

.admin-table__empty {
  text-align: center !important;
  color: var(--c-text-muted);
  padding: var(--sp-8) var(--sp-4) !important;
  white-space: normal;
}

.admin-table td.admin-table__message {
  white-space: normal;
  max-width: 320px;
}

/* ---------- Status badges ---------- */
.status-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-1);
  padding: 2px var(--sp-2);
  border-radius: var(--r-full, 999px);
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: capitalize;
  white-space: nowrap;
}

.status-badge--pending    { background: rgba(245, 158, 11, 0.15); color: var(--c-gold-light); }
.status-badge--processing { background: var(--c-primary-glow);    color: var(--c-primary-light); }
.status-badge--paid       { background: var(--c-success-bg);      color: var(--c-success); }
.status-badge--rejected   { background: var(--c-error-bg);        color: var(--c-error); }

/* ---------- Row action buttons ---------- */
.admin-row-actions {
  display: flex;
  gap: var(--sp-2);
  flex-wrap: wrap;
}

/* ---------- Search form ---------- */
.admin-search-form {
  display: flex;
  gap: var(--sp-3);
  align-items: flex-end;
  flex-wrap: wrap;
  margin-top: var(--sp-4);
}

/* ---------- User detail ---------- */
.admin-detail-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: var(--sp-4);
  margin-top: var(--sp-4);
}

.admin-detail-label {
  font-size: var(--text-xs);
  color: var(--c-text-muted);
  margin: 0 0 2px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.admin-detail-value {
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--c-text);
  margin: 0;
}

.admin-detail-value--mono {
  font-family: monospace;
  font-size: var(--text-sm);
  word-break: break-all;
}

.admin-adjust-form {
  display: flex;
  gap: var(--sp-3);
  align-items: flex-end;
  flex-wrap: wrap;
  margin-top: var(--sp-6);
  padding-top: var(--sp-6);
  border-top: 1px solid var(--c-border-soft);
}

#user-detail-card {
  margin-top: var(--sp-5);
}

@media (max-width: 640px) {
  .admin-header {
    flex-direction: column;
    align-items: flex-start;
  }
}
