:root {
  --sa-bg: #f3f6fb;
  --sa-surface: #ffffff;
  --sa-surface-soft: #f8fbff;
  --sa-border: rgba(15, 23, 42, 0.08);
  --sa-text: #0f172a;
  --sa-muted: #64748b;
  --sa-primary: #0f4c81;
  --sa-primary-2: #1d7fd6;
  --sa-accent: #f59e0b;
  --sa-success: #16a34a;
  --sa-danger: #dc2626;
  --sa-shadow: 0 18px 40px rgba(15, 23, 42, 0.08);
  --sa-radius: 22px;
}

html, body {
  background: radial-gradient(circle at top, #ffffff 0%, var(--sa-bg) 48%, #edf2f8 100%);
  color: var(--sa-text);
  font-family: "IBM Plex Sans", system-ui, sans-serif;
}

.sa-body {
  min-height: 100vh;
}

.sa-shell {
  min-height: 100vh;
}

.sa-sidebar {
  width: 290px;
  background: linear-gradient(180deg, #08243d 0%, #0e3558 52%, #0a2742 100%);
  color: #e6eef8;
  border-right: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 24px 0 48px rgba(8, 36, 61, 0.16);
}

.sa-brand {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 24px 24px 18px;
}

.sa-brand-mark {
  width: 50px;
  height: 50px;
  border-radius: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #f59e0b 0%, #fb7185 100%);
  color: #08111d;
  font-size: 1.35rem;
}

.sa-brand-title {
  font-family: "Space Grotesk", sans-serif;
  font-size: 1.15rem;
  font-weight: 700;
  margin: 0;
}

.sa-brand-subtitle {
  color: rgba(230, 238, 248, 0.72);
  font-size: 0.88rem;
  margin: 0;
}

.sa-shell-user {
  margin: 0 20px 20px;
  padding: 16px 18px;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.sa-shell-user-name {
  display: block;
  font-weight: 600;
  color: #fff;
}

.sa-shell-user-meta {
  color: rgba(230, 238, 248, 0.76);
  font-size: 0.9rem;
}

.sa-nav {
  padding: 0 14px 20px;
}

.sa-nav .nav-link {
  border-radius: 18px;
  color: rgba(230, 238, 248, 0.88);
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  font-weight: 500;
}

.sa-nav .nav-link ion-icon {
  font-size: 1.15rem;
}

.sa-nav .nav-link:hover,
.sa-nav .nav-link:focus {
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
}

.sa-nav .nav-link.active {
  background: linear-gradient(135deg, rgba(29, 127, 214, 0.22) 0%, rgba(245, 158, 11, 0.18) 100%);
  color: #fff;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08);
}

.sa-main {
  min-width: 0;
}

.sa-topbar {
  padding: 26px 28px 8px;
}

.sa-topbar-card {
  background: rgba(255, 255, 255, 0.72);
  backdrop-filter: blur(16px);
  border: 1px solid rgba(255, 255, 255, 0.7);
  box-shadow: var(--sa-shadow);
  border-radius: 24px;
  padding: 18px 22px;
}

.sa-page-title {
  font-family: "Space Grotesk", sans-serif;
  font-size: clamp(1.55rem, 2vw, 2.15rem);
  font-weight: 700;
  margin: 0;
}

.sa-page-subtitle {
  color: var(--sa-muted);
  margin: 6px 0 0;
}

.sa-content {
  padding: 0 28px 28px;
}

.sa-panel {
  background: linear-gradient(180deg, var(--sa-surface) 0%, var(--sa-surface-soft) 100%);
  border: 1px solid var(--sa-border);
  border-radius: var(--sa-radius);
  box-shadow: var(--sa-shadow);
}

.sa-panel-header {
  padding: 20px 22px 0;
}

.sa-panel-body {
  padding: 20px 22px 22px;
}

.sa-kpi-card {
  height: 100%;
  padding: 18px;
  border-radius: 20px;
  border: 1px solid var(--sa-border);
  background: #fff;
  box-shadow: 0 14px 30px rgba(15, 23, 42, 0.05);
}

.sa-kpi-icon {
  width: 44px;
  height: 44px;
  border-radius: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(29, 127, 214, 0.12);
  color: var(--sa-primary-2);
  font-size: 1.25rem;
}

.sa-kpi-label {
  color: var(--sa-muted);
  font-size: 0.92rem;
  margin-top: 14px;
}

.sa-kpi-value {
  font-family: "Space Grotesk", sans-serif;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1;
  margin-top: 6px;
}

.sa-filter-card {
  padding: 18px;
  border-radius: 20px;
  border: 1px solid var(--sa-border);
  background: #fff;
}

.sa-action-stack {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.sa-token-card {
  border: 1px solid var(--sa-border);
  border-radius: 18px;
  padding: 14px 16px;
  background: #fff;
}

.sa-table thead th {
  color: var(--sa-muted);
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  border-bottom-width: 1px;
}

.sa-table td,
.sa-table th {
  vertical-align: middle;
}

.sa-table-user {
  min-width: 210px;
}

.sa-mini-title {
  font-size: 0.92rem;
  font-weight: 600;
  margin: 0;
}

.sa-mini-meta {
  color: var(--sa-muted);
  font-size: 0.88rem;
}

.sa-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border-radius: 999px;
  padding: 0.35rem 0.72rem;
  font-size: 0.78rem;
  font-weight: 600;
}

.sa-pill.status-active,
.sa-pill.role-global_admin {
  background: rgba(22, 163, 74, 0.12);
  color: #0f7a34;
}

.sa-pill.status-blocked {
  background: rgba(220, 38, 38, 0.12);
  color: #b91c1c;
}

.sa-pill.status-deleted {
  background: rgba(100, 116, 139, 0.12);
  color: #475569;
}

.sa-pill.role-admin {
  background: rgba(29, 127, 214, 0.12);
  color: #145d9b;
}

.sa-pill.role-player {
  background: rgba(148, 163, 184, 0.16);
  color: #475569;
}

.sa-audit-item {
  border: 1px solid var(--sa-border);
  border-radius: 18px;
  padding: 16px;
  background: #fff;
}

.sa-audit-meta {
  color: var(--sa-muted);
  font-size: 0.9rem;
}

.sa-empty {
  padding: 30px 18px;
  text-align: center;
  color: var(--sa-muted);
}

.sa-offcanvas {
  background: linear-gradient(180deg, #08243d 0%, #0e3558 52%, #0a2742 100%);
  color: #e6eef8;
}

.sa-offcanvas .btn-close {
  filter: invert(1);
}

@media (max-width: 991.98px) {
  .sa-topbar,
  .sa-content {
    padding-left: 16px;
    padding-right: 16px;
  }

  .sa-topbar-card {
    padding: 16px 18px;
  }
}
