:root {
  --school-success: var(--color-emerald-500);
  --school-warning: var(--color-amber-500);
  --school-danger: var(--color-red-500);

  --dashboard-theme-primary: var(--school-primary);
  --dashboard-theme-accent: var(--school-accent);
  --dashboard-theme-success: var(--school-success, var(--color-emerald-500));
  --dashboard-theme-warning: var(--school-warning, var(--color-amber-500));
  --dashboard-theme-danger: var(--school-danger, var(--color-red-500));

  --dashboard-surface: rgba(255, 255, 255, 0.93);
  --dashboard-surface: color-mix(in srgb, var(--color-base-0) 88%, var(--dashboard-theme-primary) 12%); /* theme-locked-allow: decorative-tint-mix */
  --dashboard-surface-soft: rgba(255, 255, 255, 0.82);
  --dashboard-surface-soft: color-mix(in srgb, var(--color-base-0) 84%, var(--dashboard-theme-primary) 16%); /* theme-locked-allow: decorative-tint-mix */
  --dashboard-border: rgba(99, 115, 129, 0.28);
  --dashboard-border: color-mix(in srgb, var(--dashboard-theme-primary) 24%, color-mix(in oklab, var(--color-primary-300) 30%, var(--color-base-100)) 76%); /* theme-locked-allow: decorative-tint-mix */
  --dashboard-shadow: 0 16px 34px rgba(26, 22, 18, 0.12);
  --dashboard-shadow-soft: 0 10px 22px rgba(26, 22, 18, 0.09);

  --dashboard-text-strong: var(--color-base-900); /* theme-locked-allow: manual-review */
  --dashboard-text-muted: var(--color-base-600); /* theme-locked-allow: manual-review */
  --dashboard-glow-a: color-mix(in srgb, var(--dashboard-theme-primary) 28%, transparent);
  --dashboard-glow-b: color-mix(in srgb, var(--dashboard-theme-accent) 24%, transparent);
}

html[data-theme="dark"],
html[data-bs-theme="dark"],
body.portal-backend-dark {
  --dashboard-surface: rgba(26, 22, 18, 0.82);
  --dashboard-surface-soft: rgba(26, 22, 18, 0.7);
  --dashboard-border: color-mix(in srgb, var(--dashboard-theme-primary) 36%, var(--color-base-700) 64%); /* theme-locked-allow: decorative-tint-mix */
  --dashboard-shadow: 0 18px 40px rgba(2, 8, 23, 0.6);
  --dashboard-shadow-soft: 0 12px 24px rgba(2, 8, 23, 0.45);
  --dashboard-text-strong: var(--color-base-200); /* theme-locked-allow: manual-review */
  --dashboard-text-muted: var(--color-base-400); /* theme-locked-allow: manual-review */
}

body[data-dashboard-page] {
  background:
    radial-gradient(1150px 460px at 96% -24%, var(--dashboard-glow-a), transparent 58%),
    radial-gradient(980px 420px at 2% -20%, var(--dashboard-glow-b), transparent 55%),
    linear-gradient(
      180deg,
      color-mix(in srgb, color-mix(in oklab, var(--color-sky-400) 4%, var(--color-base-0)) 86%, var(--dashboard-theme-primary) 14%),
      color-mix(in srgb, color-mix(in oklab, var(--color-sky-400) 5%, var(--color-base-0)) 88%, var(--dashboard-theme-accent) 12%)
    );
}

body[data-dashboard-page] .card,
body[data-dashboard-page] .card-glass,
body[data-dashboard-page] .modular-card,
body[data-dashboard-page] .dashboard-chart-card,
body[data-dashboard-page] .parent-glance-card,
body[data-dashboard-page] .child-card,
body[data-dashboard-page] .parent-sidebar-card,
body[data-dashboard-page] .tdm-panel,
body[data-dashboard-page] .tdm-class-card,
body[data-dashboard-page] .backend-quick-actions-card,
body[data-dashboard-page] .backend-kpi-card,
body[data-dashboard-page] .backend-right-sidebar .card,
body[data-dashboard-page] #dashboard-layout .card {
  background: var(--dashboard-surface);
  border-color: var(--dashboard-border);
  box-shadow: var(--dashboard-shadow-soft);
  min-width: 0;
  overflow: hidden;
}

body[data-dashboard-page] .card .card-body,
body[data-dashboard-page] .table-responsive,
body[data-dashboard-page] .row > [class*="col-"] {
  min-width: 0;
}

body[data-dashboard-page] .card-title,
body[data-dashboard-page] .dashboard-kpi-label,
body[data-dashboard-page] .section-title,
body[data-dashboard-page] .small,
body[data-dashboard-page] .text-muted,
body[data-dashboard-page] .table td,
body[data-dashboard-page] .table th {
  overflow-wrap: anywhere;
  word-break: break-word;
}

body[data-dashboard-page] .dashboard-kpi-value {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

body[data-dashboard-page] .card-title,
body[data-dashboard-page] h1,
body[data-dashboard-page] h2,
body[data-dashboard-page] h3,
body[data-dashboard-page] h4,
body[data-dashboard-page] .dashboard-kpi-value,
body[data-dashboard-page] .section-title {
  color: var(--dashboard-text-strong);
}

body[data-dashboard-page] .text-muted,
body[data-dashboard-page] .small.text-muted,
body[data-dashboard-page] .dashboard-kpi-label,
body[data-dashboard-page] .dashboard-eyebrow {
  color: var(--dashboard-text-muted) !important;
}

body[data-dashboard-page] .btn-primary,
body[data-dashboard-page] .btn-gradient-pill {
  background: linear-gradient(135deg, var(--dashboard-theme-primary), var(--dashboard-theme-accent));
  border-color: color-mix(in srgb, var(--dashboard-theme-primary) 70%, var(--color-base-900) 30%); /* theme-locked-allow: decorative-tint-mix */
}

body[data-dashboard-page] .btn-outline-primary {
  color: var(--dashboard-theme-primary);
  border-color: color-mix(in srgb, var(--dashboard-theme-primary) 56%, var(--color-base-400) 44%); /* theme-locked-allow: decorative-tint-mix */
}

body[data-dashboard-page="parent"] .parent-dashboard {
  --parent-glance-messages-bg: color-mix(in srgb, var(--dashboard-theme-primary) 16%, var(--color-base-0) 84%); /* theme-locked-allow: decorative-tint-mix */
  --parent-glance-messages-border: color-mix(in srgb, var(--dashboard-theme-primary) 30%, var(--color-base-300) 70%); /* theme-locked-allow: decorative-tint-mix */
  --parent-glance-followup-bg: color-mix(in srgb, var(--dashboard-theme-warning) 14%, var(--color-base-0) 86%); /* theme-locked-allow: decorative-tint-mix */
  --parent-glance-followup-border: color-mix(in srgb, var(--dashboard-theme-warning) 32%, var(--color-base-300) 68%); /* theme-locked-allow: decorative-tint-mix */
  --parent-glance-outstanding-bg: color-mix(in srgb, var(--dashboard-theme-danger) 14%, var(--color-base-0) 86%); /* theme-locked-allow: decorative-tint-mix */
  --parent-glance-outstanding-border: color-mix(in srgb, var(--dashboard-theme-danger) 32%, var(--color-base-300) 68%); /* theme-locked-allow: decorative-tint-mix */
  --parent-glance-good-bg: color-mix(in srgb, var(--dashboard-theme-accent) 14%, var(--color-base-0) 86%); /* theme-locked-allow: decorative-tint-mix */
  --parent-glance-good-border: color-mix(in srgb, var(--dashboard-theme-accent) 30%, var(--color-base-300) 70%); /* theme-locked-allow: decorative-tint-mix */
  background:
    radial-gradient(
      860px 360px at 96% -16%,
      color-mix(in srgb, var(--dashboard-theme-primary) 26%, transparent),
      transparent 58%
    ),
    radial-gradient(
      760px 320px at 0% -20%,
      color-mix(in srgb, var(--dashboard-theme-accent) 22%, transparent),
      transparent 56%
    ),
    linear-gradient(
      180deg,
      color-mix(in srgb, color-mix(in oklab, var(--color-sky-400) 3%, var(--color-base-0)) 86%, var(--dashboard-theme-primary) 14%),
      color-mix(in srgb, color-mix(in oklab, var(--color-sky-400) 5%, var(--color-base-0)) 88%, var(--dashboard-theme-accent) 12%)
    );
}

body[data-dashboard-page="parent"] .parent-dashboard-header,
body[data-dashboard-page="parent"] .parent-workflow-strip {
  background: linear-gradient(120deg, var(--dashboard-surface), var(--dashboard-surface-soft));
  border-color: var(--dashboard-border);
  box-shadow: var(--dashboard-shadow);
}

body[data-dashboard-page="parent"] .parent-glance-card,
body[data-dashboard-page="parent"] .summary-tile,
body[data-dashboard-page="parent"] .parent-sidebar-card {
  background: var(--dashboard-surface);
  border: 1px solid var(--dashboard-border);
}

body[data-dashboard-page="parent"] .parent-glance-card--messages {
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--dashboard-theme-primary) 20%, var(--color-base-0) 80%),
    var(--dashboard-surface)
  );
}

body[data-dashboard-page="parent"] .parent-glance-card--followup {
  background: linear-gradient( /* theme-locked-allow: decorative-tint-mix */
    135deg,
    color-mix(in srgb, var(--dashboard-theme-warning) 18%, var(--color-base-0) 82%),
    var(--dashboard-surface)
  );
}

body[data-dashboard-page="parent"] .parent-glance-card--fees {
  background: linear-gradient( /* theme-locked-allow: decorative-tint-mix */
    135deg,
    color-mix(in srgb, var(--dashboard-theme-danger) 16%, var(--color-base-0) 84%),
    var(--dashboard-surface)
  );
}

body[data-dashboard-page="parent"] .parent-glance-card--attendance {
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--dashboard-theme-accent) 18%, var(--color-base-0) 82%),
    var(--dashboard-surface)
  );
}

/* Parent dashboard fallback harmonization for legacy card classes */
body[data-dashboard-page="parent"] .metric-card,
body[data-dashboard-page="parent"] .activity-section,
body[data-dashboard-page="parent"] .announcements-card,
body[data-dashboard-page="parent"] .gauge-card,
body[data-dashboard-page="parent"] .quick-tools-box,
body[data-dashboard-page="parent"] .tool-item,
body[data-dashboard-page="parent"] .contact-box,
body[data-dashboard-page="parent"] .summary-tile,
body[data-dashboard-page="parent"] .fee-status-card .small-tile,
body[data-dashboard-page="parent"] .stat-chip {
  background: var(--dashboard-surface);
  border: 1px solid var(--dashboard-border);
  box-shadow: var(--dashboard-shadow-soft);
}

body[data-dashboard-page="parent"] .section-title,
body[data-dashboard-page="parent"] .quick-tools-title {
  border-bottom-color: color-mix(in srgb, var(--dashboard-theme-primary) 20%, color-mix(in oklab, var(--color-primary-300) 30%, var(--color-base-100)) 80%); /* theme-locked-allow: decorative-tint-mix */
}

body[data-dashboard-page="parent"] .summary-label,
body[data-dashboard-page="parent"] .metric-title,
body[data-dashboard-page="parent"] .metric-desc,
body[data-dashboard-page="parent"] .child-info p,
body[data-dashboard-page="parent"] .child-metric-label,
body[data-dashboard-page="parent"] .activity-meta,
body[data-dashboard-page="parent"] .announcement-meta,
body[data-dashboard-page="parent"] .contact-title {
  color: var(--dashboard-text-muted);
}

body[data-dashboard-page="parent"] .summary-value,
body[data-dashboard-page="parent"] .summary-meta .summary-value,
body[data-dashboard-page="parent"] .activity-title,
body[data-dashboard-page="parent"] .donut span {
  color: var(--dashboard-text-strong);
}

body[data-dashboard-page="parent"] .donut::after {
  background: var(--dashboard-surface);
}

body[data-dashboard-page="parent"] .timeline::before {
  background: color-mix(in srgb, var(--dashboard-theme-primary) 30%, color-mix(in oklab, var(--color-primary-300) 30%, var(--color-base-100)) 70%); /* theme-locked-allow: decorative-tint-mix */
}

body[data-dashboard-page="parent"] .timeline-item::before {
  background: linear-gradient(135deg, var(--dashboard-theme-primary), var(--dashboard-theme-accent));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--dashboard-theme-primary) 18%, transparent);
}

body[data-dashboard-page="parent"] .tool-item:hover {
  background: color-mix(in srgb, var(--dashboard-theme-primary) 12%, var(--dashboard-surface) 88%);
}

body[data-dashboard-page="parent"] .btn-gradient {
  background: linear-gradient(135deg, var(--dashboard-theme-primary), var(--dashboard-theme-accent));
  box-shadow: 0 8px 18px color-mix(in srgb, var(--dashboard-theme-primary) 28%, transparent);
}

body[data-dashboard-page="teacher"] .tdm-bg {
  background:
    radial-gradient(
      980px 420px at 95% -14%,
      color-mix(in srgb, var(--dashboard-theme-primary) 28%, transparent),
      transparent 56%
    ),
    radial-gradient(
      780px 340px at 0% -20%,
      color-mix(in srgb, var(--dashboard-theme-accent) 25%, transparent),
      transparent 54%
    ),
    linear-gradient(
      180deg,
      color-mix(in srgb, color-mix(in oklab, var(--color-primary-300) 5%, var(--color-base-0)) 84%, var(--dashboard-theme-primary) 16%),
      color-mix(in srgb, color-mix(in oklab, var(--color-sky-400) 4%, var(--color-base-0)) 87%, var(--dashboard-theme-accent) 13%)
    );
}

body[data-dashboard-page="teacher"] .tdm-hero,
body[data-dashboard-page="teacher"] .tdm-panel,
body[data-dashboard-page="teacher"] .tdm-class-card,
body[data-dashboard-page="teacher"] .tdm-task,
body[data-dashboard-page="teacher"] .tdm-mini,
body[data-dashboard-page="teacher"] .tdm-compact-card {
  border-color: var(--dashboard-border);
  box-shadow: var(--dashboard-shadow-soft);
}

body[data-dashboard-page="teacher"] .chip,
body[data-dashboard-page="teacher"] .btn-soft,
body[data-dashboard-page="teacher"] .tdm-badge-tile {
  border-color: color-mix(in srgb, var(--dashboard-theme-primary) 38%, var(--color-base-300) 62%); /* theme-locked-allow: decorative-tint-mix */
  color: color-mix(in srgb, var(--dashboard-theme-primary) 70%, var(--color-base-900) 30%); /* theme-locked-allow: decorative-tint-mix */
  background: color-mix(in srgb, var(--dashboard-theme-primary) 10%, var(--color-base-0) 90%); /* theme-locked-allow: decorative-tint-mix */
}

body[data-dashboard-page="teacher"] .chip-accent {
  border-color: color-mix(in srgb, var(--dashboard-theme-accent) 45%, var(--color-base-300) 55%); /* theme-locked-allow: decorative-tint-mix */
  color: color-mix(in srgb, var(--dashboard-theme-accent) 72%, var(--color-base-900) 28%); /* theme-locked-allow: decorative-tint-mix */
  background: color-mix(in srgb, var(--dashboard-theme-accent) 14%, var(--color-base-0) 86%); /* theme-locked-allow: decorative-tint-mix */
}

body[data-dashboard-page="teacher"] .tdm-stat.purple {
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--dashboard-theme-primary) 76%, var(--color-indigo-900) 24%),
    color-mix(in srgb, var(--dashboard-theme-accent) 48%, var(--color-indigo-600) 52%)
  );
}

body[data-dashboard-page="teacher"] .tdm-stat.blue {
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--dashboard-theme-primary) 58%, var(--color-sky-500) 42%),
    color-mix(in srgb, var(--dashboard-theme-primary) 44%, var(--color-sky-400) 56%)
  );
}

body[data-dashboard-page="teacher"] .tdm-stat.teal {
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--dashboard-theme-accent) 72%, var(--color-teal-500) 28%),
    color-mix(in srgb, var(--dashboard-theme-primary) 40%, var(--color-cyan-500) 60%)
  );
}

body[data-dashboard-page="teacher"] .tdm-stat.orange {
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--dashboard-theme-warning) 74%, var(--color-orange-500) 26%),
    color-mix(in srgb, var(--dashboard-theme-danger) 52%, var(--color-orange-400) 48%)
  );
}

body[data-dashboard-page="teacher"] .tdm-progress-fill {
  background: linear-gradient(90deg, var(--dashboard-theme-primary), var(--dashboard-theme-accent));
}

body[data-dashboard-page="backend"] {
  background:
    radial-gradient(
      1200px 430px at 95% -22%,
      color-mix(in srgb, var(--dashboard-theme-primary) 30%, transparent),
      transparent 58%
    ),
    radial-gradient(
      960px 360px at 3% -18%,
      color-mix(in srgb, var(--dashboard-theme-accent) 26%, transparent),
      transparent 56%
    ),
    linear-gradient(
      180deg,
      color-mix(in srgb, color-mix(in oklab, var(--color-primary-300) 4%, var(--color-base-0)) 86%, var(--dashboard-theme-primary) 14%),
      color-mix(in srgb, color-mix(in oklab, var(--color-sky-400) 6%, var(--color-base-0)) 88%, var(--dashboard-theme-accent) 12%)
    );
}

body[data-dashboard-page="backend"] .backend-welcome-section {
  background: linear-gradient(130deg, var(--dashboard-surface), var(--dashboard-surface-soft));
  border: 1px solid var(--dashboard-border);
  box-shadow: var(--dashboard-shadow);
}

body[data-dashboard-page="backend"] .backend-quick-action-btn {
  border-width: 1px;
  border-color: color-mix(in srgb, var(--dashboard-theme-primary) 45%, var(--color-base-400) 55%); /* theme-locked-allow: decorative-tint-mix */
  color: color-mix(in srgb, var(--dashboard-theme-primary) 76%, var(--color-base-900) 24%); /* theme-locked-allow: decorative-tint-mix */
  background: color-mix(in srgb, var(--dashboard-theme-primary) 8%, var(--color-base-0) 92%); /* theme-locked-allow: decorative-tint-mix */
}

body[data-dashboard-page="backend"] .backend-quick-action-btn:hover,
body[data-dashboard-page="backend"] .backend-quick-action-btn:focus-visible {
  color: var(--text-on-brand, var(--color-base-0));
  border-color: color-mix(in srgb, var(--dashboard-theme-primary) 72%, var(--color-base-900) 28%); /* theme-locked-allow: decorative-tint-mix */
  background: linear-gradient(135deg, var(--dashboard-theme-primary), var(--dashboard-theme-accent));
  box-shadow: 0 10px 20px color-mix(in srgb, var(--dashboard-theme-primary) 30%, transparent);
}

body[data-dashboard-page="backend"] .backend-command-center-row {
  margin-top: 0.5rem;
}

body[data-dashboard-page="backend"] .backend-command-sidebar .sidebar-sticky {
  top: 88px;
}

@media (min-width: 1200px) {
  body[data-dashboard-page="backend"] .backend-command-center-row {
    align-items: stretch;
  }

  body[data-dashboard-page="backend"] .backend-command-main {
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
  }

  body[data-dashboard-page="backend"] .backend-command-main #dashboard-layout {
    flex: 1;
  }
}

body.dashboard-preset-soft-glass[data-dashboard-page] {
  --dashboard-surface: color-mix(in srgb, var(--color-base-0) 84%, var(--dashboard-theme-primary) 16%); /* theme-locked-allow: decorative-tint-mix */
  --dashboard-surface-soft: color-mix(in srgb, var(--color-base-0) 80%, var(--dashboard-theme-accent) 20%); /* theme-locked-allow: decorative-tint-mix */
}

body.dashboard-preset-crisp-professional[data-dashboard-page] {
  --dashboard-surface: var(--color-base-0); /* theme-locked-allow: manual-review */
  --dashboard-surface-soft: color-mix(in srgb, var(--color-base-0) 92%, var(--dashboard-theme-primary) 8%); /* theme-locked-allow: decorative-tint-mix */
  --dashboard-border: color-mix(in srgb, var(--dashboard-theme-primary) 16%, var(--color-base-300) 84%); /* theme-locked-allow: decorative-tint-mix */
}

body.dashboard-preset-high-contrast[data-dashboard-page] {
  --dashboard-surface: var(--color-base-900); /* theme-locked-allow: manual-review */
  --dashboard-surface-soft: var(--color-base-800); /* theme-locked-allow: manual-review */
  --dashboard-border: var(--color-primary-400); /* theme-locked-allow: brand-token */
  --dashboard-text-strong: var(--color-base-50); /* theme-locked-allow: manual-review */
  --dashboard-text-muted: var(--color-base-300); /* theme-locked-allow: manual-review */
}

body.dashboard-preset-high-contrast[data-dashboard-page] .btn-outline-primary,
body.dashboard-preset-high-contrast[data-dashboard-page] .backend-quick-action-btn {
  color: var(--text-tertiary, var(--color-base-50));
  border-color: var(--color-primary-400); /* theme-locked-allow: brand-token */
  background: rgba(30, 64, 175, 0.25); /* off-token-allow: rgba-decorative */
}

.profile-shell { width: 100%; }

.profile-shell .profile-header {
  background: linear-gradient(
    125deg,
    color-mix(in srgb, var(--dashboard-theme-primary) 18%, var(--color-base-0) 82%),
    color-mix(in srgb, var(--dashboard-theme-accent) 14%, var(--color-base-0) 86%)
  );
  border: 1px solid var(--dashboard-border);
  border-radius: 18px;
  box-shadow: var(--dashboard-shadow-soft);
  padding: 1rem 1.1rem;
}

.profile-shell .card {
  border-radius: 16px;
  border: 1px solid var(--dashboard-border);
  background: var(--dashboard-surface);
  box-shadow: var(--dashboard-shadow-soft);
}

.profile-shell .profile-avatar-wrap {
  width: 56px;
  height: 56px;
  border-radius: 16px;
  overflow: hidden;
  background: color-mix(in srgb, var(--dashboard-theme-primary) 16%, var(--color-base-0) 84%); /* theme-locked-allow: decorative-tint-mix */
  color: color-mix(in srgb, var(--dashboard-theme-primary) 72%, var(--color-base-900) 28%); /* theme-locked-allow: decorative-tint-mix */
  display: flex;
  align-items: center;
  justify-content: center;
}

.profile-shell .profile-chip {
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--dashboard-theme-primary) 32%, var(--color-base-300) 68%); /* theme-locked-allow: decorative-tint-mix */
  background: color-mix(in srgb, var(--dashboard-theme-primary) 10%, var(--color-base-0) 90%); /* theme-locked-allow: decorative-tint-mix */
  color: color-mix(in srgb, var(--dashboard-theme-primary) 72%, var(--color-base-900) 28%); /* theme-locked-allow: decorative-tint-mix */
}

@media (max-width: 1199px) {
  body[data-dashboard-page="parent"] .parent-sidebar-col .sidebar-sticky,
  body[data-dashboard-page="backend"] .backend-command-sidebar .sidebar-sticky {
    position: static;
    top: auto;
  }
}

@media (max-width: 991px) {
  body[data-dashboard-page="teacher"] .tdm-main-grid {
    grid-template-columns: 1fr;
  }
}

/* ---------- Compact density pass (all dashboards) ---------- */
body[data-dashboard-page] #main-content {
  padding-top: 0.7rem !important;
  padding-bottom: 0.9rem !important;
}

body[data-dashboard-page] .container-fluid,
body[data-dashboard-page] .container-lg {
  max-width: none;
  width: 100%;
  padding-left: 0.72rem;
  padding-right: 0.72rem;
}

body[data-dashboard-page] .card .card-body {
  padding: 0.72rem 0.84rem;
}

body[data-dashboard-page] .row {
  --bs-gutter-x: 0.82rem;
  --bs-gutter-y: 0.82rem;
}

body[data-dashboard-page] .section-title,
body[data-dashboard-page] .dashboard-section-title {
  margin-bottom: 0.52rem !important;
}

/* Parent dashboard compact + balanced */
body[data-dashboard-page="parent"] .parent-dashboard .container-lg {
  padding-top: 0.72rem !important;
  padding-bottom: 0.72rem !important;
}

body[data-dashboard-page="parent"] .parent-dashboard-header {
  padding: 0.82rem 0.92rem;
  margin-bottom: 0.72rem;
}

body[data-dashboard-page="parent"] .parent-workflow-strip {
  margin-top: 0.62rem;
  margin-bottom: 0.72rem;
}

body[data-dashboard-page="parent"] .parent-workflow-strip .card-body,
body[data-dashboard-page="parent"] .child-card .card-body,
body[data-dashboard-page="parent"] .parent-sidebar-card .card-body {
  padding: 0.72rem 0.82rem;
}

body[data-dashboard-page="parent"] .parent-content-row {
  --bs-gutter-x: 0.78rem;
  --bs-gutter-y: 0.78rem;
}

body[data-dashboard-page="parent"] .portal-feed-scroll {
  max-height: 286px;
}

/* Teacher dashboard compact + two-column command feel */
body[data-dashboard-page="teacher"] .tdm-bg {
  padding: 10px 0 18px;
}

body[data-dashboard-page="teacher"] .tdm-shell {
  max-width: none;
  width: 100%;
}

body[data-dashboard-page="teacher"] .tdm-hero {
  padding: 12px 14px;
  margin-bottom: 10px;
}

body[data-dashboard-page="teacher"] .tdm-overview-grid,
body[data-dashboard-page="teacher"] .tdm-main-grid {
  gap: 10px;
  margin-bottom: 10px;
}

body[data-dashboard-page="teacher"] .tdm-panel,
body[data-dashboard-page="teacher"] .tdm-class-card {
  padding: 11px;
}

body[data-dashboard-page="teacher"] .tdm-task {
  padding: 8px 10px;
}

/* Backend command center compact + reduced empty areas */
body[data-dashboard-page="backend"] .container-fluid {
  max-width: none;
  width: 100%;
}

body[data-dashboard-page="backend"] .backend-welcome-section {
  padding: 0.78rem 0.92rem 0.84rem;
  margin-bottom: 0.62rem;
}

body[data-dashboard-page="backend"] .backend-welcome-action-row {
  gap: 0.42rem !important;
}

body[data-dashboard-page="backend"] .backend-quick-actions-card .card-body,
body[data-dashboard-page="backend"] .backend-kpi-card .card-body,
body[data-dashboard-page="backend"] #dashboard-layout .card-body,
body[data-dashboard-page="backend"] .backend-right-sidebar .card-body {
  padding: 0.66rem 0.78rem !important;
}

body[data-dashboard-page="backend"] .backend-quick-actions-grid {
  gap: 0.3rem;
}

body[data-dashboard-page="backend"] .backend-command-center-row {
  margin-top: 0.36rem;
}

body[data-dashboard-page="backend"] #dashboard-layout > .row {
  --bs-gutter-x: 0.72rem;
  --bs-gutter-y: 0.72rem;
}

body[data-dashboard-page="backend"] .backend-command-sidebar .sidebar-sticky {
  top: 84px;
}

/* Mobile compact */
@media (max-width: 767px) {
  body[data-dashboard-page] .container-fluid,
  body[data-dashboard-page] .container-lg {
    padding-left: 0.62rem;
    padding-right: 0.62rem;
  }

  body[data-dashboard-page] .card .card-body {
    padding: 0.66rem 0.72rem;
  }

  body[data-dashboard-page="parent"] .parent-dashboard-header {
    padding: 0.72rem 0.78rem;
  }

  body[data-dashboard-page="teacher"] .tdm-hero {
    padding: 10px 11px;
  }

  body[data-dashboard-page="backend"] .backend-welcome-section {
    padding: 0.7rem 0.78rem 0.76rem;
  }
}

/* ---------- Fallback + final compact polish ---------- */
html[data-dashboard-page] body,
body.dashboard-page-parent,
body.dashboard-page-teacher,
body.dashboard-page-backend {
  background:
    radial-gradient(1150px 460px at 96% -24%, var(--dashboard-glow-a), transparent 58%),
    radial-gradient(980px 420px at 2% -20%, var(--dashboard-glow-b), transparent 55%),
    linear-gradient(
      180deg,
      color-mix(in srgb, color-mix(in oklab, var(--color-sky-400) 4%, var(--color-base-0)) 86%, var(--dashboard-theme-primary) 14%),
      color-mix(in srgb, color-mix(in oklab, var(--color-sky-400) 5%, var(--color-base-0)) 88%, var(--dashboard-theme-accent) 12%)
    );
}

html[data-dashboard-page] body .card,
body.dashboard-page-parent .card,
body.dashboard-page-teacher .card,
body.dashboard-page-backend .card {
  border-color: var(--dashboard-border);
}

html[data-dashboard-page] body.dashboard-preset-soft-glass,
body.dashboard-preset-soft-glass.dashboard-page-parent,
body.dashboard-preset-soft-glass.dashboard-page-teacher,
body.dashboard-preset-soft-glass.dashboard-page-backend {
  --dashboard-surface: color-mix(in srgb, var(--color-base-0) 84%, var(--dashboard-theme-primary) 16%); /* theme-locked-allow: decorative-tint-mix */
  --dashboard-surface-soft: color-mix(in srgb, var(--color-base-0) 80%, var(--dashboard-theme-accent) 20%); /* theme-locked-allow: decorative-tint-mix */
}

html[data-dashboard-page] body.dashboard-preset-crisp-professional,
body.dashboard-preset-crisp-professional.dashboard-page-parent,
body.dashboard-preset-crisp-professional.dashboard-page-teacher,
body.dashboard-preset-crisp-professional.dashboard-page-backend {
  --dashboard-surface: var(--color-base-0); /* theme-locked-allow: manual-review */
  --dashboard-surface-soft: color-mix(in srgb, var(--color-base-0) 92%, var(--dashboard-theme-primary) 8%); /* theme-locked-allow: decorative-tint-mix */
  --dashboard-border: color-mix(in srgb, var(--dashboard-theme-primary) 16%, var(--color-base-300) 84%); /* theme-locked-allow: decorative-tint-mix */
}

html[data-dashboard-page] body.dashboard-preset-high-contrast,
body.dashboard-preset-high-contrast.dashboard-page-parent,
body.dashboard-preset-high-contrast.dashboard-page-teacher,
body.dashboard-preset-high-contrast.dashboard-page-backend {
  --dashboard-surface: var(--color-base-900); /* theme-locked-allow: manual-review */
  --dashboard-surface-soft: var(--color-base-800); /* theme-locked-allow: manual-review */
  --dashboard-border: var(--color-primary-400); /* theme-locked-allow: brand-token */
  --dashboard-text-strong: var(--color-base-50); /* theme-locked-allow: manual-review */
  --dashboard-text-muted: var(--color-base-300); /* theme-locked-allow: manual-review */
}

html[data-dashboard-page="parent"] body .parent-dashboard,
body.dashboard-page-parent .parent-dashboard {
  min-height: auto;
}

html[data-dashboard-page="parent"] body .parent-glance-grid,
body.dashboard-page-parent .parent-glance-grid {
  gap: 0.65rem;
}

html[data-dashboard-page="parent"] body .parent-glance-card,
body.dashboard-page-parent .parent-glance-card {
  min-height: 86px;
  padding: 0.62rem 0.72rem;
}

html[data-dashboard-page="parent"] body .parent-children-grid,
body.dashboard-page-parent .parent-children-grid {
  row-gap: 0.7rem;
}

html[data-dashboard-page="parent"] body .child-card .card-body,
body.dashboard-page-parent .child-card .card-body {
  padding: 0.68rem 0.76rem;
}

html[data-dashboard-page="parent"] body .parent-sidebar-cards,
body.dashboard-page-parent .parent-sidebar-cards {
  display: grid;
  gap: 0.55rem;
}

html[data-dashboard-page="parent"] body .parent-sidebar-card,
body.dashboard-page-parent .parent-sidebar-card {
  margin-bottom: 0 !important;
}

html[data-dashboard-page="parent"] body .portal-feed-scroll,
body.dashboard-page-parent .portal-feed-scroll {
  max-height: 260px;
}

html[data-dashboard-page="teacher"] body .tdm-main-grid,
body.dashboard-page-teacher .tdm-main-grid {
  gap: 0.6rem;
}

@media (min-width: 1200px) {
  html[data-dashboard-page="teacher"] body .tdm-main-grid,
  body.dashboard-page-teacher .tdm-main-grid {
    grid-template-columns: minmax(0, 1.75fr) minmax(310px, 1fr);
  }
}

html[data-dashboard-page="teacher"] body .tdm-task-list,
body.dashboard-page-teacher .tdm-task-list {
  max-height: 320px;
  overflow-y: auto;
}

html[data-dashboard-page="teacher"] body .tdm-panel-head h3,
body.dashboard-page-teacher .tdm-panel-head h3 {
  line-height: 1.2;
}

html[data-dashboard-page="backend"] body .backend-command-center-row,
body.dashboard-page-backend .backend-command-center-row {
  --bs-gutter-x: 0.66rem;
  --bs-gutter-y: 0.66rem;
}

html[data-dashboard-page="backend"] body .backend-command-main #dashboard-layout > .row.mb-4,
body.dashboard-page-backend .backend-command-main #dashboard-layout > .row.mb-4 {
  margin-bottom: 0.55rem !important;
}

html[data-dashboard-page="backend"] body .backend-right-sidebar .card,
body.dashboard-page-backend .backend-right-sidebar .card {
  margin-bottom: 0.5rem;
}

html[data-dashboard-page="backend"] body .backend-right-sidebar .card:last-child,
body.dashboard-page-backend .backend-right-sidebar .card:last-child {
  margin-bottom: 0;
}

html[data-dashboard-page="backend"] body .backend-quick-actions-grid,
body.dashboard-page-backend .backend-quick-actions-grid {
  gap: 0.26rem;
}

/* ========== Dashboard polish layer (consolidated from retired files 2026-05-12) ========== */
/* Migrated load-bearing rules from:
   - dashboard-crisp-polish.css (nav active states, main-content bg, list groups)
   - dashboard-high-contrast.css (KPI row, typography hierarchy, progress bars, chart bindings, meta-tag)
   - dashboard-premium-compact.css (parent-glance hover, tdm-stat radius, backend-quick-action-btn,
     card-glass, backend-welcome-section sizing, header typography)
   All values route through design-tokens.css. Preset skins, dashboard-kpi-block, and
   backend-copilot-accordion were dead code and discarded. */

/* ----- Dashboard typography hierarchy (page / section / card) ----- */
body[data-dashboard-page] .page-title,
body[data-dashboard-page] h1.dashboard-title,
body[data-dashboard-page] h2 {
  font-size: var(--dashboard-title-size, 1.5rem);
  font-weight: 700;
}

body[data-dashboard-page] .section-title,
body[data-dashboard-page] .dashboard-section-title {
  font-size: var(--dashboard-section-size, 1.125rem);
  font-weight: 600;
}

body[data-dashboard-page] .card-title,
body[data-dashboard-page] .card .card-body h5,
body[data-dashboard-page] .card .card-body h6 {
  font-size: var(--dashboard-card-title-size, 1rem);
  font-weight: 700;
  overflow: visible;
  text-overflow: clip;
  white-space: normal;
}

/* ----- Main content surface (light / dark theme via tokens) ----- */
body[data-dashboard-page] #main-content,
body[data-dashboard-page] .portal-main-col,
body[data-dashboard-page] .page-wrap {
  min-height: 0;
  background: color-mix(in srgb, var(--admin-content-bg) 92%, var(--dashboard-theme-primary) 8%);
}

/* ----- KPI row + values: compact, high-contrast (no .dashboard-kpi-block which is dead) ----- */
.backend-kpi-row .backend-kpi-card {
  border: 1px solid var(--dashboard-border);
  background: var(--admin-content-bg);
}

.backend-kpi-row .backend-kpi-card .card-body {
  padding: 0.5rem 0.75rem;
}

.backend-kpi-card .backend-kpi-value,
body[data-dashboard-page] .dashboard-kpi-value {
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--admin-content-text);
}

body[data-dashboard-page="backend"] .backend-kpi-grid-2col .dashboard-kpi-value {
  font-size: var(--type-size-body-l);
}

/* ----- Progress bar polish (compact pill) ----- */
body[data-dashboard-page] .progress {
  background: color-mix(in srgb, var(--admin-content-text) 10%, transparent);
  border-radius: 999px;
}

/* ----- Chart wrapper bindings (theme-aware via existing chart tokens) ----- */
body[data-dashboard-page] .dashboard-chart-wrapper,
body[data-dashboard-page] .dashboard-chart-card {
  --chart-text: var(--admin-content-text);
  --chart-grid: color-mix(in srgb, var(--admin-content-text) 15%, transparent);
}

body[data-dashboard-page] .dashboard-chart-card,
body[data-dashboard-page] .dashboard-chart-wrapper {
  border-radius: var(--token-radius-md);
}

body[data-dashboard-page] .dashboard-chart-card .card-body {
  padding: 1rem 1.25rem;
}

/* ----- Meta tag (eyebrow chips like "Receivables vs paid") ----- */
body[data-dashboard-page] .meta-tag {
  font-weight: 600;
  letter-spacing: 0.03em;
  color: var(--dashboard-text-muted);
}

/* ----- Sidebar nav-pill active state (portal sidebar) ----- */
body[data-dashboard-page] .portal-sidebar-wrapper .nav-link.nav-pill.active,
body[data-dashboard-page] .partial-sidebar .nav-link.nav-pill.active,
body[data-dashboard-page] .sidebar .nav-link.nav-pill.active {
  font-weight: 600;
  background: color-mix(in srgb, var(--school-primary) 14%, transparent);
  color: var(--school-primary);
  border-left: 3px solid var(--school-primary);
  padding-left: calc(0.875rem - 3px);
}

/* ----- Tab nav active state ----- */
body[data-dashboard-page] .nav-tabs .nav-link.active,
body[data-dashboard-page] .nav-pills .nav-link.active {
  font-weight: 600;
  color: var(--school-primary);
  border-bottom-color: var(--school-primary);
}

/* ----- List-group items: clear separation (parent inbox, partnerships, etc) ----- */
body[data-dashboard-page] .list-group-item {
  border-radius: var(--token-radius-sm);
  margin-bottom: 0.35rem;
  padding: 0.75rem 1rem;
  background: var(--admin-content-bg);
  border-color: var(--dashboard-border);
  color: var(--admin-content-text);
}

/* ----- Theme & Experience page: keep studio cards tokenized ----- */
.theme-experience-page .card,
body.app-siteconfig.model-sitesettings.change-form .card {
  border-radius: var(--token-radius-md);
  border-color: var(--dashboard-border);
}

.theme-experience-page h1,
.theme-experience-page h2,
.theme-experience-page h3,
body.app-siteconfig.model-sitesettings.change-form h1,
body.app-siteconfig.model-sitesettings.change-form h2,
body.app-siteconfig.model-sitesettings.change-form h3 {
  color: var(--admin-content-text);
}

/* ----- Parent dashboard: glance card hover lift + min-height (from premium-compact) ----- */
body[data-dashboard-page="parent"] .parent-glance-card {
  border-radius: var(--token-radius-md);
  min-height: 105px;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

body[data-dashboard-page="parent"] .parent-glance-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--apple-elev-2);
}

body[data-dashboard-page="parent"] .parent-dashboard-header {
  border-radius: var(--token-radius-lg);
}

body[data-dashboard-page="parent"] .parent-dashboard-header h1 {
  font-size: clamp(1.45rem, 2.2vw, 2.05rem);
}

body[data-dashboard-page="parent"] .dashboard-actions .btn,
body[data-dashboard-page="parent"] .dashboard-actions .form-select {
  border-radius: 999px;
  min-height: 38px;
}

body[data-dashboard-page="parent"] .parent-glance-section,
body[data-dashboard-page="parent"] .parent-workflow-strip,
body[data-dashboard-page="parent"] .child-card,
body[data-dashboard-page="parent"] .parent-sidebar-card,
body[data-dashboard-page="parent"] .metrics-section .card {
  border-radius: var(--token-radius-md);
}

body[data-dashboard-page="parent"] .parent-sidebar-col .sidebar-sticky {
  position: sticky;
  top: 92px;
}

/* ----- Teacher dashboard: tdm-stat radius + card-glass (from premium-compact) ----- */
body[data-dashboard-page="teacher"] .card-glass {
  border-radius: var(--token-radius-md);
  box-shadow: var(--apple-elev-2);
  border: 1px solid var(--dashboard-border);
  backdrop-filter: blur(8px);
}

body[data-dashboard-page="teacher"] .tdm-stat {
  border-radius: var(--token-radius-sm);
  padding: 12px;
}

body[data-dashboard-page="teacher"] .tdm-hero__text h1 {
  font-size: clamp(1.35rem, 2.2vw, 1.9rem);
}

body[data-dashboard-page="teacher"] .tdm-workflow-panel .btn,
body[data-dashboard-page="teacher"] .tdm-panel .btn {
  border-radius: 10px;
}

body[data-dashboard-page="teacher"] .tdm-task {
  border-radius: 10px;
}

/* ----- Backend dashboard: welcome heading + quick action button polish ----- */
body[data-dashboard-page="backend"] .backend-welcome-section {
  border-radius: var(--token-radius-lg);
}

body[data-dashboard-page="backend"] .backend-welcome-section h2 {
  font-size: clamp(1.35rem, 2.1vw, 2rem);
  margin-bottom: 0.15rem;
}

body[data-dashboard-page="backend"] .backend-welcome-section > p {
  margin-bottom: 0.55rem;
}

body[data-dashboard-page="backend"] .backend-welcome-action-row .btn {
  border-radius: 999px;
  min-height: 34px;
}

body[data-dashboard-page="backend"] .backend-quick-actions-card,
body[data-dashboard-page="backend"] .backend-kpi-card,
body[data-dashboard-page="backend"] .backend-operations-row .card,
body[data-dashboard-page="backend"] .backend-right-sidebar .card,
body[data-dashboard-page="backend"] #dashboard-layout .card {
  border-radius: var(--token-radius-md);
  border: 1px solid var(--dashboard-border);
  box-shadow: var(--apple-elev-1);
}

body[data-dashboard-page="backend"] .backend-quick-action-btn {
  border-radius: 10px;
  min-height: 34px;
  font-weight: 600;
}

body[data-dashboard-page="backend"] .backend-command-sidebar .sidebar-sticky {
  position: sticky;
}

/* ----- Mobile compact for retired premium-compact targets ----- */
@media (max-width: 767px) {
  body[data-dashboard-page="parent"] .parent-dashboard .container-lg,
  body[data-dashboard-page="teacher"] .tdm-shell,
  body[data-dashboard-page="backend"] .container-fluid {
    padding-left: 0.65rem;
    padding-right: 0.65rem;
  }
}
