/**
 * Dashboard High Contrast – Unfold-inspired
 * High-contrast design for ALL dashboards: readability, structure, dark-mode compatible.
 * Applied to: backend (#dashboard-layout), parent, teacher, finance, analytics,
 * payroll, EMIS, requests, compliance – via #dashboard-layout, [data-dashboard-page],
 * and dashboard wrapper classes.
 */

/* All dashboard content wrappers (for selector reuse in comments) */
/* #dashboard-layout, [data-dashboard-page], .parent-dashboard, .teacher-shell,
   .finance-dashboard-widgets, .analytics-dashboard-widgets, .payroll-dashboard-widgets,
   .emis-dashboard-widgets, .compliance-dashboard */

/* ===== No shadows – flat, clean cards ===== */
#dashboard-layout .card,
#dashboard-layout .modular-card,
#dashboard-layout .dashboard-chart-card,
[data-dashboard-page] .card,
[data-dashboard-page] .modular-card,
[data-dashboard-page] .dashboard-chart-card,
.finance-dashboard-widgets .card,
.analytics-dashboard-widgets .card,
.payroll-dashboard-widgets .card,
.emis-dashboard-widgets .card,
.compliance-dashboard .card,
.parent-dashboard .card,
.teacher-shell .card,
.backend-quick-actions-card,
body.portal-backend .card.modular-card,
body.portal-backend #dashboard-layout .card {
  box-shadow: none !important;
}

/* ===== No gaps – tight, gapless layout ===== */
body.portal-backend #dashboard-layout,
body.portal-backend-dark #dashboard-layout,
body.portal-backend-light #dashboard-layout,
[data-dashboard-page] .finance-dashboard-widgets,
[data-dashboard-page] .analytics-dashboard-widgets,
[data-dashboard-page] .payroll-dashboard-widgets,
[data-dashboard-page] .emis-dashboard-widgets,
.compliance-dashboard,
.parent-dashboard,
.teacher-shell {
  --bs-gutter-x: 0.5rem;
  --bs-gutter-y: 0.5rem;
}
body.portal-backend #dashboard-layout .row,
body.portal-backend-dark #dashboard-layout .row,
body.portal-backend-light #dashboard-layout .row,
[data-dashboard-page] .row,
.finance-dashboard-widgets .row,
.analytics-dashboard-widgets .row,
.payroll-dashboard-widgets .row,
.emis-dashboard-widgets .row,
.compliance-dashboard .row,
.parent-dashboard .row,
.teacher-shell .row {
  margin-bottom: var(--dashboard-gap-md, 1rem);
}
#dashboard-layout.dashboard-layout-compact .row {
  margin-bottom: 0.5rem;
}
body.portal-backend #dashboard-layout .row .card,
body.portal-backend #dashboard-layout .row [class*="col-"] .card,
body.portal-backend-dark #dashboard-layout .row .card,
body.portal-backend-light #dashboard-layout .row .card,
[data-dashboard-page] .row .card,
[data-dashboard-page] .row [class*="col-"] .card {
  margin-bottom: 0 !important;
}
body.portal-backend .backend-quick-actions-card,
body.portal-backend #dashboard-layout .card.mb-4,
body.portal-backend #dashboard-layout .card.mb-3,
body.portal-backend #dashboard-layout .card.mb-2 {
  margin-bottom: 0.5rem !important;
}

/* ===== KPI row – compact, high-contrast ===== */
.backend-kpi-row .backend-kpi-card {
  border: 1px solid;
}
body.portal-backend-light .backend-kpi-row .backend-kpi-card {
  border-color: #e2e8f0;
  background: var(--admin-content-bg);
}
body.portal-backend-dark .backend-kpi-row .backend-kpi-card {
  border-color: #334155;
  background: #1e293b;
}
.backend-kpi-row .backend-kpi-card .card-body {
  padding: 0.5rem 0.75rem !important;
}

/* ===== KPI blocks (Finance overview, etc.) ===== */
.dashboard-kpi-block {
  padding: 0.5rem 0;
  border-radius: 8px;
}
.dashboard-kpi-label {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  opacity: 0.9;
}
.dashboard-kpi-value {
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.3;
}

/* Light theme: high-contrast text */
:root:not([data-theme="dark"]) .dashboard-kpi-label,
html[data-bs-theme="light"] .dashboard-kpi-label,
body.portal-backend-light .dashboard-kpi-label {
  color: #1e293b;
}
:root:not([data-theme="dark"]) .dashboard-kpi-value,
html[data-bs-theme="light"] .dashboard-kpi-value,
body.portal-backend-light .dashboard-kpi-value {
  color: #0f172a;
}

/* Dark theme: high-contrast text */
[data-theme="dark"] .dashboard-kpi-label,
html[data-bs-theme="dark"] .dashboard-kpi-label,
body.portal-backend-dark .dashboard-kpi-label {
  color: #e2e8f0;
}
[data-theme="dark"] .dashboard-kpi-value,
html[data-bs-theme="dark"] .dashboard-kpi-value,
body.portal-backend-dark .dashboard-kpi-value {
  color: #f8fafc;
}

/* ===== Dashboard cards – high-contrast borders and backgrounds (all dashboards) ===== */
.dashboard-high-contrast-card,
#dashboard-layout .card,
.dashboard-layout-unified .card,
[data-dashboard-page] .card,
.finance-dashboard-widgets .card,
.analytics-dashboard-widgets .card,
.payroll-dashboard-widgets .card,
.emis-dashboard-widgets .card,
.compliance-dashboard .card,
.parent-dashboard .card,
.teacher-shell .card {
  border-width: 1px;
}
:root:not([data-theme="dark"]) .dashboard-high-contrast-card,
:root:not([data-theme="dark"]) #dashboard-layout .card,
:root:not([data-theme="dark"]) [data-dashboard-page] .card,
html[data-bs-theme="light"] #dashboard-layout .card,
html[data-bs-theme="light"] [data-dashboard-page] .card,
body.portal-backend-light #dashboard-layout .card,
body.portal-backend-light .finance-dashboard-widgets .card,
body.portal-backend-light .analytics-dashboard-widgets .card,
body.portal-backend-light .payroll-dashboard-widgets .card,
body.portal-backend-light .emis-dashboard-widgets .card,
body.portal-backend-light .compliance-dashboard .card,
body.portal-backend-light .parent-dashboard .card,
body.portal-backend-light .teacher-shell .card {
  background: var(--admin-content-bg);
  border-color: #cbd5e1;
  color: var(--admin-content-text);
}
[data-theme="dark"] .dashboard-high-contrast-card,
[data-theme="dark"] #dashboard-layout .card,
[data-theme="dark"] [data-dashboard-page] .card,
html[data-bs-theme="dark"] #dashboard-layout .card,
html[data-bs-theme="dark"] [data-dashboard-page] .card,
body.portal-backend-dark #dashboard-layout .card,
body.portal-backend-dark .finance-dashboard-widgets .card,
body.portal-backend-dark .analytics-dashboard-widgets .card,
body.portal-backend-dark .payroll-dashboard-widgets .card,
body.portal-backend-dark .emis-dashboard-widgets .card,
body.portal-backend-dark .compliance-dashboard .card,
body.portal-backend-dark .parent-dashboard .card,
body.portal-backend-dark .teacher-shell .card {
  background: #1e293b;
  border-color: #334155;
  color: #f8fafc;
}

/* Typography hierarchy (A4): page → section → card → body → caption (all dashboards) */
#dashboard-layout .page-title,
#dashboard-layout h1.dashboard-title,
[data-dashboard-page] .page-title,
[data-dashboard-page] h1.dashboard-title,
[data-dashboard-page] h2 {
  font-size: var(--dashboard-title-size, 1.5rem);
  font-weight: 700;
}
#dashboard-layout .section-title,
#dashboard-layout .dashboard-section-title,
[data-dashboard-page] .section-title,
[data-dashboard-page] .dashboard-section-title {
  font-size: var(--dashboard-section-size, 1.125rem);
  font-weight: 600;
}
#dashboard-layout .card-title h5,
#dashboard-layout .card-title h6,
#dashboard-layout .card .card-body h5,
#dashboard-layout .card .card-body h6,
[data-dashboard-page] .card-title,
[data-dashboard-page] .card .card-body h5,
[data-dashboard-page] .card .card-body h6,
.finance-dashboard-widgets .card-title,
.analytics-dashboard-widgets .card-title,
.payroll-dashboard-widgets .card-title,
.emis-dashboard-widgets .card-title,
.compliance-dashboard .card-title,
.parent-dashboard .card-title,
.teacher-shell .card-title {
  font-size: var(--dashboard-card-title-size, 1rem);
  font-weight: 700;
}
body.portal-backend-light #dashboard-layout .card-title,
body.portal-backend-light #dashboard-layout .card .card-body h5,
body.portal-backend-light #dashboard-layout .card .card-body h6,
html[data-bs-theme="light"] [data-dashboard-page] .card-title,
html[data-bs-theme="light"] [data-dashboard-page] .card .card-body h5,
html[data-bs-theme="light"] [data-dashboard-page] .card .card-body h6,
body.portal-backend-light [data-dashboard-page] .card-title {
  color: #0f172a !important;
}
body.portal-backend-dark #dashboard-layout .card-title,
body.portal-backend-dark #dashboard-layout .card .card-body h5,
body.portal-backend-dark #dashboard-layout .card .card-body h6,
html[data-bs-theme="dark"] [data-dashboard-page] .card-title,
html[data-bs-theme="dark"] [data-dashboard-page] .card .card-body h5,
html[data-bs-theme="dark"] [data-dashboard-page] .card .card-body h6,
body.portal-backend-dark [data-dashboard-page] .card-title {
  color: #f8fafc !important;
}

/* Muted text – readable but secondary (all dashboards) */
body.portal-backend-light #dashboard-layout .text-muted,
body.portal-backend-light #dashboard-layout .small.text-muted,
body.portal-backend-light [data-dashboard-page] .text-muted,
body.portal-backend-light [data-dashboard-page] .small.text-muted,
html[data-bs-theme="light"] [data-dashboard-page] .text-muted,
html[data-bs-theme="light"] [data-dashboard-page] .small.text-muted {
  color: #475569 !important;
}
body.portal-backend-dark #dashboard-layout .text-muted,
body.portal-backend-dark #dashboard-layout .small.text-muted,
body.portal-backend-dark [data-dashboard-page] .text-muted,
body.portal-backend-dark [data-dashboard-page] .small.text-muted,
html[data-bs-theme="dark"] [data-dashboard-page] .text-muted,
html[data-bs-theme="dark"] [data-dashboard-page] .small.text-muted {
  color: #94a3b8 !important;
}

/* ===== Chart wrapper – high-contrast axis/legend ===== */
body.portal-backend-light .dashboard-chart-wrapper,
body.portal-backend-light .dashboard-chart-card {
  --chart-text: #1e293b;
  --chart-grid: rgba(30, 41, 59, 0.15);
}
body.portal-backend-dark .dashboard-chart-wrapper,
body.portal-backend-dark .dashboard-chart-card {
  --chart-text: #e2e8f0;
  --chart-grid: rgba(226, 232, 240, 0.2);
}

/* ===== Badges & pills – high contrast ===== */
#dashboard-layout .badge,
#dashboard-layout .portal-pill {
  font-weight: 600;
}
body.portal-backend-light #dashboard-layout .badge.bg-light {
  background: #f1f5f9 !important;
  color: #0f172a !important;
}
body.portal-backend-dark #dashboard-layout .badge.bg-light {
  background: #334155 !important;
  color: #f8fafc !important;
}

/* ===== Copilot accordion – compact, high contrast ===== */
.backend-copilot-accordion .accordion-item {
  border: 1px solid;
}
body.portal-backend-light .backend-copilot-accordion .accordion-item {
  background: var(--admin-content-bg);
  border-color: #e2e8f0;
}
body.portal-backend-dark .backend-copilot-accordion .accordion-item {
  background: #1e293b;
  border-color: #334155;
}
.backend-copilot-accordion .accordion-button {
  font-weight: 600;
}
.backend-copilot-accordion .accordion-button:not(.collapsed) {
  background: transparent;
}
body.portal-backend-light .backend-copilot-accordion .accordion-button {
  color: #0f172a;
  background: #f8fafc;
}
body.portal-backend-dark .backend-copilot-accordion .accordion-button {
  color: #f8fafc;
  background: #0f172a;
}
body.portal-backend-dark .backend-copilot-accordion .accordion-button::after {
  filter: invert(1);
}

/* ===== Progress bars – high contrast (all dashboards) ===== */
#dashboard-layout .progress,
[data-dashboard-page] .progress,
.finance-dashboard-widgets .progress,
.analytics-dashboard-widgets .progress,
.payroll-dashboard-widgets .progress,
.emis-dashboard-widgets .progress,
.compliance-dashboard .progress,
.parent-dashboard .progress,
.teacher-shell .progress {
  background: rgba(0, 0, 0, 0.1);
  border-radius: 999px;
}
body.portal-backend-dark #dashboard-layout .progress,
body.portal-backend-dark [data-dashboard-page] .progress,
html[data-bs-theme="dark"] [data-dashboard-page] .progress {
  background: rgba(255, 255, 255, 0.1);
}

/* ===== Card titles – prevent truncation (all dashboards) ===== */
#dashboard-layout .card-title h5,
#dashboard-layout .card-title h6,
#dashboard-layout .card .card-body h5,
#dashboard-layout .card .card-body h6,
[data-dashboard-page] .card-title,
[data-dashboard-page] .card .card-body h5,
[data-dashboard-page] .card .card-body h6,
.finance-dashboard-widgets .card-title,
.analytics-dashboard-widgets .card-title,
.payroll-dashboard-widgets .card-title,
.emis-dashboard-widgets .card-title,
.compliance-dashboard .card-title,
.parent-dashboard .card-title,
.teacher-shell .card-title {
  overflow: visible;
  text-overflow: clip;
  white-space: normal;
}

/* ===== Meta tags (e.g. "Receivables vs paid") ===== */
.meta-tag {
  font-weight: 600;
  letter-spacing: 0.03em;
}
body.portal-backend-light .meta-tag {
  color: #475569;
}
body.portal-backend-dark .meta-tag {
  color: #94a3b8;
}
