/* ==========================================================================
   Admin Panel Pages
   ========================================================================== */

/* ---- Admin Layout ---- */
.admin-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: var(--spacing-md);
}

/* ---- Partner Cards ---- */
.partner-card {
  display: flex;
  flex-direction: column;
  background: var(--card-bg);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  box-shadow: var(--card-shadow);
  overflow: hidden;
  transition: all var(--transition);
}

.partner-card:hover {
  box-shadow: var(--card-shadow-hover);
}

.partner-card-header {
  display: flex;
  align-items: center;
  gap: var(--spacing-md);
  padding: var(--spacing-lg);
}

.partner-card-avatar {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: var(--radius-md);
  background: var(--bg-tertiary);
  font-size: 20px;
  font-weight: 700;
  color: var(--accent-blue);
  flex-shrink: 0;
}

.partner-card-info {
  flex: 1;
  min-width: 0;
}

.partner-card-name {
  font-size: 16px;
  font-weight: 600;
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.partner-card-type {
  font-size: 13px;
  color: var(--text-secondary);
}

.partner-card-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid var(--border-color);
}

.partner-card-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: var(--spacing-md);
  text-align: center;
}

.partner-card-stat + .partner-card-stat {
  border-left: 1px solid var(--border-color);
}

.partner-card-stat-value {
  font-size: 18px;
  font-weight: 700;
  color: var(--text-primary);
}

.partner-card-stat-label {
  font-size: 11px;
  color: var(--text-tertiary);
  margin-top: 2px;
}

/* ---- Admin Stats ---- */
.admin-stats-row {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--spacing-md);
  margin-bottom: var(--spacing-xl);
}

@media (max-width: 1200px) {
  .admin-stats-row {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 768px) {
  .admin-stats-row {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ---- User Management Table Overrides ---- */
.user-role-badge {
  padding: 3px 10px;
  font-size: 12px;
  font-weight: 600;
  border-radius: var(--radius-full);
}

.user-role-badge.admin {
  background: rgba(0, 113, 227, 0.1);
  color: var(--accent-blue);
}

.user-role-badge.partner {
  background: rgba(52, 199, 89, 0.1);
  color: var(--status-green);
}

.user-role-badge.viewer {
  background: var(--bg-tertiary);
  color: var(--text-secondary);
}

/* ---- Settings Sections ---- */
.settings-section {
  padding: var(--spacing-xl);
  background: var(--card-bg);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  margin-bottom: var(--spacing-md);
}

.settings-section-title {
  font-size: 18px;
  font-weight: 600;
  margin-bottom: var(--spacing-xs);
}

.settings-section-desc {
  font-size: 14px;
  color: var(--text-secondary);
  margin-bottom: var(--spacing-lg);
}

.settings-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-md) 0;
  border-bottom: 1px solid var(--border-color);
}

.settings-row:last-child {
  border-bottom: none;
}

.settings-row-label {
  font-size: 14px;
  font-weight: 500;
  color: var(--text-primary);
}

.settings-row-hint {
  font-size: 12px;
  color: var(--text-tertiary);
  margin-top: 2px;
}

/* ---- Activity Log ---- */
.activity-log {
  display: flex;
  flex-direction: column;
}

.activity-log-item {
  display: flex;
  align-items: flex-start;
  gap: var(--spacing-md);
  padding: var(--spacing-md) 0;
  border-bottom: 1px solid var(--border-color);
}

.activity-log-item:last-child {
  border-bottom: none;
}

.activity-log-time {
  font-size: 12px;
  font-family: var(--font-mono);
  color: var(--text-tertiary);
  white-space: nowrap;
  min-width: 70px;
}

.activity-log-text {
  font-size: 14px;
  color: var(--text-primary);
}

.activity-log-text strong {
  font-weight: 600;
}

/* ---- Impersonation Banner ---- */
.impersonation-banner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-md);
  padding: 8px var(--spacing-lg);
  background: var(--status-yellow);
  color: #1D1D1F;
  font-size: 13px;
  font-weight: 600;
  position: sticky;
  top: 0;
  z-index: 9999;
}

.impersonation-banner .btn {
  padding: 4px 12px;
  font-size: 12px;
}
