:root {
  --bg-dark: #0f172a;
  --bg-glass: rgba(30, 41, 59, 0.7);
  --border-glass: rgba(255, 255, 255, 0.1);
  --primary: #3b82f6;
  --primary-hover: #2563eb;
  --secondary: #8b5cf6;
  --secondary-hover: #7c3aed;
  --text-main: #f8fafc;
  --text-muted: #94a3b8;
  --glow-orange: rgba(249, 115, 22, 0.2);
  --glow-green: rgba(34, 197, 94, 0.2);
  --glow-red: rgba(239, 68, 68, 0.2);
  --gradient-bg: linear-gradient(135deg, #0f172a 0%, #171131 100%);
  --input-bg: rgba(15, 23, 42, 0.6);
  --input-color: white;
  --success: #22c55e;
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 16px;
}

/* Base Body Application */
* { box-sizing: border-box; margin: 0; padding: 0; }
body {
  font-family: 'Outfit', sans-serif;
  background: var(--gradient-bg);
  color: var(--text-main);
  min-height: 100vh;
  margin: 0;
  font-size: 15px;
  line-height: 1.6;
  transition: background 0.3s ease, color 0.3s ease;
}

body {
  display: flex;
  flex-direction: column;
}

/* Glass Panels and Structural Classes */
.glass-panel {
  background: var(--bg-glass);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-md);
  padding: 1.5rem;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08), 0 8px 32px 0 rgba(0, 0, 0, 0.22);
  transition: all 0.3s ease;
}

.glass-panel.compact,
.glass-panel--compact {
  padding: 1.2rem 2rem;
}

.glass-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.2rem 2.5rem;
  background: rgba(15, 23, 42, 0.85);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--border-glass);
  position: sticky;
  top: 0;
  z-index: 1000;
}

.glass-header h1 {
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--text-main);
  background: linear-gradient(to right, #60a5fa, #c084fc);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.dashboard-content {
  padding: 2.5rem;
  max-width: 1500px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 2rem;
}
.max-w-1200 { max-width: 1200px; margin: 0 auto; }

main,
.dashboard-content,
.command-center {
  width: 100%;
}

.erp-school-frame {
  width: min(1320px, calc(100% - 32px));
  margin: 12px auto 0;
  padding: 12px 16px;
  border: 1px solid var(--border-glass);
  border-radius: 14px;
  background:
    radial-gradient(circle at top left, rgba(96, 165, 250, 0.18), transparent 34%),
    linear-gradient(135deg, rgba(15, 23, 42, 0.92), rgba(23, 17, 49, 0.88));
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.18);
}

.erp-school-frame--home {
  margin-bottom: 10px;
}

.erp-school-frame__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.erp-school-frame__brand {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.erp-school-frame__logo {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  font-size: 1.35rem;
  font-weight: 700;
  color: #fff;
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.95), rgba(139, 92, 246, 0.92));
  border: 1px solid rgba(255, 255, 255, 0.16);
  overflow: hidden;
}

.erp-school-frame__logo--image {
  background: rgba(255, 255, 255, 0.95);
}

.erp-school-frame__logo--image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.erp-school-frame__identity {
  min-width: 0;
}

.erp-school-frame__eyebrow {
  margin: 0 0 2px;
  font-size: 0.66rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.erp-school-frame__name {
  margin: 0;
  font-size: clamp(1.08rem, 2.2vw, 1.55rem);
  line-height: 1.15;
  color: var(--text-main);
}

.erp-school-frame__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 12px;
  margin-top: 5px;
  color: var(--text-muted);
  font-size: 0.88rem;
}

.erp-school-frame__side {
  display: flex;
  align-items: center;
  gap: 7px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.erp-school-frame__pill,
.erp-school-frame__session {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 32px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.06);
  color: var(--text-main);
}

.erp-school-frame__pill {
  background: rgba(59, 130, 246, 0.16);
  color: #dbeafe;
}

.erp-global-offline-sync {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  max-width: min(100%, 520px);
  padding: 4px;
  border: 1px solid rgba(148, 163, 184, 0.22);
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.72);
  color: #e2e8f0;
  box-shadow: 0 12px 30px rgba(15, 23, 42, 0.2);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.erp-global-offline-sync--floating {
  position: sticky;
  top: 8px;
  z-index: 1200;
  width: fit-content;
  margin: 8px 12px 0 auto;
}

.erp-global-offline-sync__toggle,
.erp-global-offline-sync__icon {
  border: 0;
  min-height: 30px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  border-radius: 999px;
  cursor: pointer;
  color: #e0f2fe;
  background: rgba(37, 99, 235, 0.22);
  font: inherit;
  font-weight: 800;
  transition: transform 0.18s ease, background 0.18s ease, opacity 0.18s ease;
}

.erp-global-offline-sync__toggle {
  padding: 0 9px 0 7px;
}

.erp-global-offline-sync__icon {
  width: 30px;
  padding: 0;
}

.erp-global-offline-sync__toggle:hover,
.erp-global-offline-sync__icon:hover {
  transform: translateY(-1px);
  background: rgba(37, 99, 235, 0.32);
}

.erp-global-offline-sync__icon:disabled {
  cursor: wait;
  opacity: 0.62;
}

.erp-global-offline-sync__dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: #22c55e;
  box-shadow: 0 0 0 4px rgba(34, 197, 94, 0.16);
}

.erp-global-offline-sync.is-off .erp-global-offline-sync__dot {
  background: #94a3b8;
  box-shadow: 0 0 0 4px rgba(148, 163, 184, 0.16);
}

.erp-global-offline-sync.is-syncing .erp-global-offline-sync__icon i {
  animation: erp-sync-spin 0.85s linear infinite;
}

.erp-global-offline-sync__clear {
  color: #fee2e2;
  background: rgba(244, 63, 94, 0.16);
}

.erp-global-offline-sync__status {
  max-width: 190px;
  padding: 0 6px 0 2px;
  color: #cbd5e1;
  font-size: 0.72rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

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

.erp-company-footer {
  margin-top: auto;
  width: 100%;
  padding: 18px 16px max(92px, calc(env(safe-area-inset-bottom) + 42px));
  position: relative;
  z-index: 20;
}

.erp-company-footer__inner {
  width: min(1320px, 100%);
  margin: 0 auto;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  color: #cbd5e1;
  font-size: 0.88rem;
  text-align: center;
  background: rgba(15, 23, 42, 0.92);
  border: 1px solid rgba(148, 163, 184, 0.22);
  border-radius: 14px;
  box-shadow: 0 14px 36px rgba(15, 23, 42, 0.22);
  padding: 12px 18px;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.erp-company-footer__company {
  color: #ffffff;
  font-weight: 700;
}

.erp-company-footer__support {
  color: #60a5fa;
  font-weight: 800;
  text-decoration: none;
  transition: all 0.2s ease;
}

.erp-company-footer__support:hover {
  color: #93c5fd;
  text-decoration: underline;
}

.erp-company-footer__divider {
  opacity: 0.6;
}

@media (max-width: 720px) {
  .erp-company-footer {
    padding: 14px 10px max(84px, calc(env(safe-area-inset-bottom) + 36px));
  }

  .erp-company-footer__inner {
    gap: 6px;
    padding: 12px;
    font-size: 0.82rem;
  }

  .erp-school-frame {
    width: min(1320px, calc(100% - 20px));
    padding: 16px;
  }

  .erp-school-frame__brand {
    align-items: flex-start;
  }

  .erp-school-frame__logo {
    width: 56px;
    height: 56px;
    border-radius: 16px;
  }

  .erp-school-frame__side {
    justify-content: flex-start;
  }
}

.erp-page-topbar {
  width: min(1320px, calc(100% - 32px));
  margin: 12px auto 18px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 20px;
  align-items: center;
  padding: 0 2px;
}

.erp-page-brand {
  display: flex;
  align-items: center;
  gap: 14px;
  min-width: 0;
}

.erp-page-brand__badge {
  width: 58px;
  height: 58px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, rgba(14, 116, 144, 0.16), rgba(37, 99, 235, 0.2));
  color: #5eead4;
  font-size: 1.55rem;
  border: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.18);
  flex-shrink: 0;
}

.erp-page-brand__copy h1 {
  margin: 0;
  font-family: 'Outfit', sans-serif;
  font-size: clamp(1.5rem, 3vw, 2rem);
  line-height: 1.08;
  color: var(--text-main);
}

.erp-page-brand__copy p {
  margin: 4px 0 0;
  color: var(--text-muted);
  line-height: 1.5;
  font-size: 0.95rem;
}

.erp-page-topbar__actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.erp-nav-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 42px;
  padding: 10px 14px;
  border-radius: 12px;
  text-decoration: none;
  color: var(--text-main);
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.14);
  transition: transform 0.2s ease, background 0.2s ease, border-color 0.2s ease;
}

.erp-nav-chip:hover {
  transform: translateY(-1px);
  background: rgba(59, 130, 246, 0.16);
  border-color: rgba(96, 165, 250, 0.38);
}

.erp-backlink-row {
  width: min(1320px, calc(100% - 32px));
  margin: 12px auto 0;
  display: flex;
  justify-content: flex-end;
}

.erp-topbar-select {
  min-width: 180px;
  min-height: 42px;
  padding: 10px 14px;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.08);
  color: var(--text-main);
  font: inherit;
}

.erp-topbar-select option {
  color: #0f172a;
}

.cw-school-strip {
  width: min(1600px, calc(100% - 48px));
  margin: 0.75rem auto 0.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.55rem 0.75rem;
  border: 1px solid var(--border-glass);
  border-radius: 18px;
  background:
    radial-gradient(circle at top left, rgba(59, 130, 246, 0.14), transparent 34%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(239, 246, 255, 0.86));
  box-shadow: 0 12px 30px rgba(15, 23, 42, 0.08);
  color: #172033;
}

.cw-school-brand {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.cw-school-logo {
  width: 46px;
  height: 46px;
  border-radius: 15px;
  display: grid;
  place-items: center;
  overflow: hidden;
  flex-shrink: 0;
  background: linear-gradient(135deg, var(--primary), color-mix(in srgb, var(--primary) 32%, white 68%));
  color: #fff;
  font-weight: 900;
  letter-spacing: 0.02em;
  box-shadow: 0 10px 22px rgba(59, 130, 246, 0.18);
}

.cw-school-logo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  background: #fff;
}

.cw-school-brand p,
.cw-school-brand h2,
.cw-school-brand span {
  margin: 0;
}

.cw-school-brand p {
  color: var(--primary);
  font-size: 0.66rem;
  font-weight: 900;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.cw-school-brand h2 {
  color: #172033;
  font-size: 1rem;
  line-height: 1.15;
}

.cw-school-brand span {
  display: block;
  max-width: 760px;
  color: #64748b;
  font-size: 0.78rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.cw-school-actions {
  flex-shrink: 0;
}

.erp-page-purpose {
  width: min(1600px, calc(100% - 48px));
  margin: 0.5rem auto 1rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.75rem 1rem;
  border: 1px solid var(--border-glass);
  border-radius: 16px;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.92), rgba(248, 250, 252, 0.84));
  color: #172033;
}

.erp-page-purpose h1 {
  margin: 0;
  color: #172033;
  font-size: 1.25rem;
  line-height: 1.15;
}

.erp-page-purpose p {
  margin: 0.2rem 0 0;
  color: #64748b;
  font-size: 0.88rem;
  line-height: 1.35;
}

.erp-page-purpose__actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.65rem;
  flex-wrap: wrap;
}

@media (max-width: 860px) {
  .erp-page-topbar {
    width: min(1320px, calc(100% - 20px));
    grid-template-columns: 1fr;
    margin-top: 10px;
  }

  .erp-page-topbar__actions {
    justify-content: flex-start;
  }

  .erp-backlink-row {
    width: min(1320px, calc(100% - 20px));
    justify-content: flex-start;
  }

  .cw-school-strip,
  .erp-page-purpose {
    width: min(1600px, calc(100% - 20px));
  }

  .cw-school-strip,
  .erp-page-purpose {
    align-items: flex-start;
    flex-direction: column;
  }

  .cw-school-actions,
  .erp-page-purpose__actions {
    width: 100%;
    justify-content: flex-start;
  }
}

/* Interactive Buttons */
button {
  padding: 0.85rem 1.75rem;
  border: none;
  border-radius: var(--radius-sm);
  font-family: inherit;
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  cursor: pointer;
  transition: all 0.2s ease;
}

a {
  transition: all 0.2s ease;
}

.btn-primary,
.primary-btn,
.action-btn:not(.secondary):not(.danger):not(.btn-danger),
.btn-login {
  background: linear-gradient(135deg, var(--primary) 0%, var(--primary-hover) 100%) !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: 8px !important;
  box-shadow: 0 10px 28px rgba(59, 130, 246, 0.35) !important;
  position: relative;
  overflow: hidden;
  min-width: 100px;
}

.btn-primary:after,
.primary-btn:after,
.action-btn:not(.secondary):not(.danger):not(.btn-danger):after,
.btn-login:after {
  content: '';
  position: absolute;
  top: 0; left: -100%;
  width: 50%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
  transition: 0.5s;
  pointer-events: none;
}

.btn-primary:hover:not(:disabled):after,
.primary-btn:hover:not(:disabled):after,
.action-btn:not(.secondary):not(.danger):not(.btn-danger):hover:not(:disabled):after,
.btn-login:hover:not(:disabled):after {
  left: 100%;
}

.btn-primary:hover:not(:disabled),
.primary-btn:hover:not(:disabled),
.action-btn:not(.secondary):not(.danger):not(.btn-danger):hover:not(:disabled),
.btn-login:hover:not(:disabled) {
  transform: translateY(-3px);
  box-shadow: 0 14px 36px rgba(59, 130, 246, 0.45) !important;
  filter: saturate(1.08);
}

.btn-primary:disabled { opacity: 0.6; cursor: not-allowed; }

.btn-primary:active:not(:disabled),
.btn-outline:active:not(:disabled),
button:active:not(:disabled) {
  transform: translateY(0);
}

.btn-success,
.btn-payment,
.btn-complete,
.action-btn.success,
.action-btn.payment,
.action-btn.completed,
.action-btn.pay-fee-btn {
  background: linear-gradient(135deg, #10b981 0%, #059669 100%) !important;
  color: #ffffff !important;
  border-color: transparent !important;
  box-shadow: 0 10px 24px rgba(16, 185, 129, 0.28) !important;
}

.btn-danger,
.btn-delete,
.danger-btn,
.delete-btn,
.action-btn.danger,
.action-btn.delete {
  background: linear-gradient(135deg, #ef4444 0%, #b91c1c 100%) !important;
  color: #ffffff !important;
  border-color: transparent !important;
  box-shadow: 0 10px 24px rgba(239, 68, 68, 0.28) !important;
}

.export-actions,
.erp-export-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.65rem;
  flex-wrap: wrap;
}

.export-btn,
.erp-export-btn {
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.72rem 1rem;
  border-radius: 0.8rem;
  border: 1px solid rgba(148, 163, 184, 0.28) !important;
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%) !important;
  color: #0f172a !important;
  font-size: 0.9rem;
  font-weight: 800;
  line-height: 1.1;
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.08) !important;
}

.export-btn:hover,
.erp-export-btn:hover {
  transform: translateY(-2px);
  border-color: rgba(59, 130, 246, 0.38) !important;
  color: #1d4ed8 !important;
  box-shadow: 0 14px 28px rgba(59, 130, 246, 0.14) !important;
}

.export-btn i,
.erp-export-btn i {
  color: #2563eb;
  font-size: 1rem;
}

.density-toggle-group,
.erp-density-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.25rem;
  border-radius: 999px;
  border: 1px solid rgba(148, 163, 184, 0.3);
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.06);
}

.density-toggle-group button,
.erp-density-toggle button {
  min-height: 32px;
  padding: 0.45rem 0.75rem;
  border-radius: 999px;
  background: transparent;
  color: #475569;
  font-size: 0.78rem;
  font-weight: 900;
  box-shadow: none;
}

.density-toggle-group button.active,
.density-toggle-group button[aria-pressed="true"],
.erp-density-toggle button.active,
.erp-density-toggle button[aria-pressed="true"] {
  background: linear-gradient(135deg, var(--primary) 0%, var(--primary-hover) 100%);
  color: #ffffff;
  box-shadow: 0 8px 18px rgba(59, 130, 246, 0.25);
}

body.table-density-compact table th,
body.table-density-compact table td,
[data-table-density="compact"] table th,
[data-table-density="compact"] table td {
  padding: 0.45rem 0.65rem !important;
  font-size: 0.82rem !important;
  line-height: 1.25;
}

body.table-density-comfortable table th,
body.table-density-comfortable table td,
[data-table-density="comfortable"] table th,
[data-table-density="comfortable"] table td {
  padding: 0.75rem 1rem;
}

.btn-outline {
  background: transparent;
  border: 1px solid rgba(255,255,255,0.2);
  color: var(--text-main);
  padding: 0.6rem 1.2rem;
  min-width: 100px;
  border-radius: 8px;
  transition: all 0.2s ease;
}

.btn-outline:hover {
  border-color: var(--primary);
  background: rgba(59, 130, 246, 0.15);
}

/* Inputs and Forms */
.input-group {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  margin-bottom: 1.25rem;
}
.input-group label {
  font-size: 0.875rem;
  color: var(--text-muted);
  font-weight: 500;
}

select, input:not([type="radio"]):not([type="checkbox"]), .input-element {
  background: var(--input-bg);
  border: 1px solid var(--border-glass);
  color: var(--input-color);
  padding: 0.75rem 1rem;
  border-radius: var(--radius-sm);
  font-family: inherit;
  font-size: 1rem;
  outline: none;
  transition: border-color 0.18s ease, box-shadow 0.18s ease;
  width: 100%;
  box-sizing: border-box;
}

select:focus, input:not([type="radio"]):not([type="checkbox"]):focus, .input-element:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.40);
  background: var(--input-bg);
}

select {
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.85rem center;
  background-size: 1rem;
  padding-right: 2.5rem;
}

::placeholder {
  color: var(--text-muted);
  opacity: 0.6;
}

input:disabled,
select:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.divider { border: none; border-top: 1px solid var(--border-glass); margin: 1.5rem 0; }

/* Theming Setup */
body.theme-light {
  --bg-dark: #f8fafc;
  --bg-glass: rgba(255, 255, 255, 0.85);
  --border-glass: rgba(0, 0, 0, 0.1);
  --primary: #2563eb;
  --text-main: #1e293b;
  --text-muted: #64748b;
  --gradient-bg: linear-gradient(135deg, #f1f5f9 0%, #e2e8f0 100%);
  --input-bg: rgba(255, 255, 255, 0.8);
  --input-color: #1e293b;
}

body.theme-ocean {
  --bg-dark: #082f49;
  --bg-glass: rgba(12, 74, 110, 0.75);
  --border-glass: rgba(56, 189, 248, 0.2);
  --primary: #0ea5e9;
  --text-main: #f0f9ff;
  --text-muted: #bae6fd;
  --gradient-bg: linear-gradient(135deg, #0c4a6e 0%, #082f49 100%);
  --input-bg: rgba(8, 47, 73, 0.6);
  --input-color: #f0f9ff;
}

body.theme-neo-tactile {
  --bg-dark: #0a101b;
  --bg-glass: rgba(18, 28, 43, 0.78);
  --border-glass: rgba(137, 196, 255, 0.18);
  --primary: #4f7cff;
  --primary-hover: #77d8ff;
  --secondary: #86f6ff;
  --secondary-hover: #b7fbff;
  --text-main: #edf6ff;
  --text-muted: #a9bdd3;
  --gradient-bg:
    radial-gradient(circle at 20% 18%, rgba(170, 225, 255, 0.18), transparent 28%),
    radial-gradient(circle at 82% 78%, rgba(102, 244, 255, 0.14), transparent 22%),
    linear-gradient(135deg, #0a101b 0%, #131b28 36%, #09111d 100%);
  --input-bg: rgba(34, 45, 62, 0.78);
  --input-color: #f8fcff;
  --glow-orange: rgba(79, 124, 255, 0.18);
  --glow-green: rgba(134, 246, 255, 0.22);
  --glow-red: rgba(127, 166, 255, 0.2);
}

body.theme-ember-graphite {
  --bg-dark: #1a1917;
  --bg-glass: rgba(34, 32, 29, 0.86);
  --border-glass: rgba(255, 191, 104, 0.18);
  --primary: #efab5d;
  --primary-hover: #ffd089;
  --secondary: #d6a35d;
  --secondary-hover: #f8c679;
  --text-main: #f5e7d3;
  --text-muted: #bca58a;
  --gradient-bg:
    radial-gradient(circle at 15% 14%, rgba(255, 196, 112, 0.12), transparent 26%),
    linear-gradient(135deg, #161514 0%, #24211d 45%, #121110 100%);
  --input-bg: rgba(28, 28, 27, 0.82);
  --input-color: #fff5e7;
  --glow-orange: rgba(239, 171, 93, 0.2);
  --glow-green: rgba(201, 161, 91, 0.14);
  --glow-red: rgba(255, 166, 77, 0.18);
}

body.theme-harvest-pulse {
  --bg-dark: #171d1d;
  --bg-glass: rgba(37, 45, 47, 0.84);
  --border-glass: rgba(206, 224, 170, 0.16);
  --primary: #ffb83f;
  --primary-hover: #ff9147;
  --secondary: #7de07c;
  --secondary-hover: #49d67f;
  --text-main: #eef6eb;
  --text-muted: #b8c6bb;
  --gradient-bg:
    radial-gradient(circle at 50% 18%, rgba(255, 184, 63, 0.11), transparent 22%),
    linear-gradient(135deg, #1a2121 0%, #242b2a 50%, #151919 100%);
  --input-bg: rgba(28, 35, 35, 0.84);
  --input-color: #f7fff2;
  --glow-orange: rgba(255, 184, 63, 0.22);
  --glow-green: rgba(89, 214, 120, 0.2);
  --glow-red: rgba(255, 116, 92, 0.2);
}

body.theme-aurora-bloom {
  --bg-dark: #cab2f1;
  --bg-glass: rgba(255, 255, 255, 0.58);
  --border-glass: rgba(173, 139, 255, 0.2);
  --primary: #8b5cf6;
  --primary-hover: #ec87c0;
  --secondary: #f5b56e;
  --secondary-hover: #ffcc8e;
  --text-main: #44316f;
  --text-muted: #7e6aab;
  --gradient-bg:
    radial-gradient(circle at 18% 24%, rgba(255, 206, 165, 0.42), transparent 25%),
    radial-gradient(circle at 84% 20%, rgba(171, 126, 255, 0.35), transparent 30%),
    linear-gradient(135deg, #c7afea 0%, #a686e2 50%, #b69af0 100%);
  --input-bg: rgba(255, 255, 255, 0.7);
  --input-color: #4c2d83;
  --glow-orange: rgba(245, 181, 110, 0.24);
  --glow-green: rgba(196, 154, 255, 0.18);
  --glow-red: rgba(236, 135, 192, 0.18);
}

body.theme-arctic-breeze {
  --bg-dark: #b7f2f6;
  --bg-glass: rgba(255, 255, 255, 0.6);
  --border-glass: rgba(77, 197, 223, 0.2);
  --primary: #23c6de;
  --primary-hover: #49e0ef;
  --secondary: #5de0ff;
  --secondary-hover: #7febff;
  --text-main: #12556a;
  --text-muted: #5d8fa0;
  --gradient-bg:
    radial-gradient(circle at 12% 12%, rgba(255, 255, 255, 0.45), transparent 24%),
    radial-gradient(circle at 80% 25%, rgba(69, 224, 239, 0.24), transparent 26%),
    linear-gradient(135deg, #95dff0 0%, #c9f9fb 48%, #9cebef 100%);
  --input-bg: rgba(255, 255, 255, 0.72);
  --input-color: #0f5d73;
  --glow-orange: rgba(255, 152, 113, 0.16);
  --glow-green: rgba(86, 232, 222, 0.2);
  --glow-red: rgba(255, 139, 114, 0.18);
}

/* User Header Profiles and actions */
.user-profile .avatar {
  background: var(--border-glass);
  padding: 0.5rem 1rem;
  border-radius: 20px;
  font-size: 0.9rem;
  color: var(--text-muted);
}
.header-actions { display: flex; gap: 1rem; align-items: center; }
.theme-select { padding: 0.5rem 1rem; border-radius: var(--radius-sm); background: var(--bg-glass); border: 1px solid var(--border-glass); color: var(--text-main); }

body.erp-secondary-page .top-nav,
body.erp-secondary-page .glass-header {
  justify-content: space-between;
}

body.erp-secondary-page .header-actions:empty,
body.erp-secondary-page .nav-links:empty,
body.erp-secondary-page nav:empty {
  display: none !important;
}

/* Compact ERP Page Header Standard
   Keeps page navigation to 2-4 visual lines: brand/actions first, page title second.
   This intentionally trims oversized module banners across older pages. */
.top-nav,
.glass-header,
.faculty-topbar,
.topbar {
  min-height: auto !important;
  padding: 10px 18px !important;
  margin-bottom: 10px !important;
  gap: 10px !important;
  align-items: center !important;
}

.top-nav .logo-area,
.glass-header .logo-area,
.faculty-topbar .logo-area,
.topbar .logo-area,
.topbar .title,
.glass-header h1 {
  min-width: 0 !important;
}

.top-nav .logo-area,
.faculty-topbar,
.topbar {
  flex-wrap: wrap !important;
}

.top-nav .logo-area i,
.glass-header h1 i,
.topbar .title i,
.faculty-topbar i {
  font-size: 1.35rem !important;
}

.top-nav .logo-area h2,
.glass-header h1,
.topbar h1,
.topbar .title h1,
.faculty-topbar h1,
.faculty-topbar h2 {
  font-size: clamp(1.2rem, 2vw, 1.65rem) !important;
  line-height: 1.08 !important;
  margin: 0 !important;
}

.top-nav .logo-area p,
.topbar .title p,
.faculty-topbar p,
.glass-header p {
  margin: 3px 0 0 !important;
  font-size: 0.82rem !important;
  line-height: 1.35 !important;
}

.top-nav .actions,
.glass-header .header-actions,
.topbar .actions,
.faculty-topbar .actions,
.topbar-right {
  gap: 8px !important;
  align-items: center !important;
  flex-wrap: wrap !important;
}

.top-nav .nav-link,
.glass-header .nav-link,
.topbar .nav-link,
.faculty-topbar .nav-link,
.erp-nav-chip {
  min-height: 34px !important;
  padding: 7px 11px !important;
  border-radius: 10px !important;
  font-size: 0.86rem !important;
}

.ops-hero,
.controls-hero,
.faculty-hero,
.mega-hero,
.ai3d-hero,
.hero,
.hero-card,
.exam-hero,
.dt-hero,
.grades-hero,
.logs-hero,
.portal-hero {
  margin-top: 8px !important;
  margin-bottom: 12px !important;
  padding: 14px 18px !important;
}

.ops-hero h1,
.controls-hero h1,
.faculty-hero h1,
.faculty-hero h2,
.mega-hero h1,
.ai3d-hero h1,
.hero h1,
.hero-title,
.exam-hero h1,
.dt-hero h1,
.grades-hero h1,
.logs-hero h1 {
  font-size: clamp(1.45rem, 3vw, 2.15rem) !important;
  line-height: 1.05 !important;
  margin: 4px 0 6px !important;
}

.ops-hero p,
.controls-hero p,
.faculty-hero p,
.mega-hero p,
.ai3d-hero p,
.hero p,
.hero-desc,
.exam-hero p,
.dt-hero p,
.grades-hero p,
.logs-hero p {
  font-size: 0.88rem !important;
  line-height: 1.45 !important;
  margin-top: 4px !important;
}

@media (max-width: 720px) {
  .top-nav,
  .glass-header,
  .faculty-topbar,
  .topbar {
    padding: 10px 12px !important;
    align-items: flex-start !important;
  }

  .top-nav .actions,
  .glass-header .header-actions,
  .topbar .actions,
  .faculty-topbar .actions,
  .topbar-right {
    width: 100% !important;
    justify-content: flex-start !important;
  }
}

/* Global Toast Element */
#toast-container {
  position: fixed;
  bottom: 70px;
  right: 20px;
  z-index: 10000;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.toast {
  padding: 1rem 1.5rem;
  border-radius: var(--radius-sm);
  background: var(--bg-glass);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  color: var(--text-main);
  border-left: 4px solid var(--primary);
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
  animation: slideIn 0.3s ease forwards;
  min-width: 250px;
  font-weight: 500;
}
.toast.success { border-color: var(--success); }
.toast.error { border-color: #ef4444; }
.toast.warning { border-color: #f59e0b; }

@keyframes slideIn {
  from { transform: translateX(100%); opacity: 0; }
  to { transform: translateX(0); opacity: 1; }
}

@keyframes fadeOut {
  to { transform: translateY(10px); opacity: 0; }
}

/* Theme FAB Button Styles */
.theme-fab-wrap {
  position: fixed;
  right: 20px;
  bottom: 20px;
  z-index: 1200;
}

.erp-theme-fab .theme-fab-btn {
  min-width: 116px;
  width: auto;
  height: 48px;
  padding: 0 18px;
  gap: 8px;
  border-radius: 999px;
  justify-content: flex-start;
}

.erp-theme-fab .theme-fab-btn i {
  font-size: 1.05rem;
}

.erp-theme-fab .theme-fab-btn span {
  font-size: 0.95rem;
  font-weight: 700;
}

.theme-fab-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.95), rgba(14, 165, 233, 0.9));
  color: white;
  box-shadow: 0 12px 24px rgba(14, 165, 233, 0.28);
  cursor: pointer;
  border: none;
  transition: all 0.3s ease;
}

.theme-fab-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 32px rgba(14, 165, 233, 0.4);
}

.theme-fab-btn span {
  font-size: 0.95rem;
  font-weight: 700;
  line-height: 1;
}

.theme-fab-panel {
  position: absolute;
  right: 0;
  bottom: 60px;
  min-width: 220px;
  padding: 12px;
  border-radius: 14px;
  background: rgba(15, 23, 42, 0.96);
  border: 1px solid var(--border-glass);
  box-shadow: 0 18px 36px rgba(2, 6, 23, 0.3);
  transition: all 0.3s ease;
}

.theme-fab-panel label {
  display: block;
  margin-bottom: 8px;
  color: var(--text-muted);
  font-size: 0.8rem;
  font-weight: 600;
}

.theme-fab-panel.hidden {
  display: none;
}

.theme-select {
  width: 100%;
  min-height: 42px;
  padding: 10px 12px;
  border-radius: var(--radius-sm);
  background: var(--input-bg);
  color: var(--text-main);
  border: 1px solid var(--border-glass);
  font-size: 0.9rem;
  cursor: pointer;
}

.erp-auto-backlink,
.erp-auto-backlink.nav-link,
.erp-auto-backlink.nav-chip,
.erp-auto-backlink.btn,
.erp-auto-backlink.btn-outline {
  color: #eff6ff !important;
  background: linear-gradient(135deg, rgba(37, 99, 235, 0.96), rgba(59, 130, 246, 0.88)) !important;
  border: 1px solid rgba(191, 219, 254, 0.3) !important;
  box-shadow: 0 12px 24px rgba(37, 99, 235, 0.22) !important;
  font-weight: 800 !important;
  text-decoration: none !important;
}

.erp-auto-backlink i,
.erp-auto-backlink.nav-link i,
.erp-auto-backlink.nav-chip i,
.erp-auto-backlink.btn i,
.erp-auto-backlink.btn-outline i {
  color: inherit !important;
}

.theme-select:hover,
.theme-select:focus {
  border-color: var(--primary);
  outline: none;
}

.erp-breadcrumbs {
  width: min(1200px, calc(100% - 32px));
  margin: 0.85rem auto 0.35rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
  padding: 0.72rem 0.95rem;
  border: 1px solid rgba(148, 163, 184, 0.24);
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--text-muted);
  box-shadow: none;
  font-family: Inter, Outfit, sans-serif;
  font-size: 0.9rem;
}

.erp-breadcrumbs a {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  color: var(--primary);
  text-decoration: none;
  font-weight: 800;
}

.erp-breadcrumbs strong {
  color: var(--text-main);
  font-weight: 800;
}

.erp-breadcrumbs__sep {
  color: #94a3b8;
}

.erp-back-to-top {
  position: fixed;
  right: 20px;
  bottom: 84px;
  z-index: 1190;
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  border: 0;
  border-radius: 999px;
  background: linear-gradient(135deg, #2563eb, #0f9f6e);
  color: #fff;
  box-shadow: 0 16px 30px rgba(37, 99, 235, 0.28);
  cursor: pointer;
  opacity: 0;
  pointer-events: none;
  transform: translateY(12px);
  transition: opacity 0.2s ease, transform 0.2s ease;
}

.erp-back-to-top.is-visible {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

.erp-back-to-top i {
  font-size: 1.25rem;
}

.erp-session-warning {
  position: fixed;
  left: 50%;
  bottom: 22px;
  z-index: 1300;
  width: min(560px, calc(100% - 28px));
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 0.9rem;
  padding: 0.9rem;
  border: 1px solid rgba(217, 119, 6, 0.35);
  border-radius: var(--radius-sm);
  background: #fff7ed;
  color: #431407;
  box-shadow: 0 20px 44px rgba(67, 20, 7, 0.18);
  font-family: Inter, Outfit, sans-serif;
  opacity: 0;
  pointer-events: none;
  transform: translate(-50%, 16px);
  transition: opacity 0.2s ease, transform 0.2s ease;
}

.erp-session-warning.is-visible {
  opacity: 1;
  pointer-events: auto;
  transform: translate(-50%, 0);
}

.erp-session-warning__icon {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: var(--radius-sm);
  background: rgba(217, 119, 6, 0.13);
  color: #b45309;
  font-size: 1.35rem;
}

.erp-session-warning__body {
  display: grid;
  gap: 0.2rem;
}

.erp-session-warning__body strong {
  font-size: 0.98rem;
}

.erp-session-warning__body span {
  color: #7c2d12;
  font-size: 0.88rem;
}

.erp-session-warning__actions {
  display: flex;
  gap: 0.5rem;
}

.erp-session-warning__actions button {
  min-height: 36px;
  padding: 0 0.8rem;
  border: 1px solid rgba(180, 83, 9, 0.24);
  border-radius: var(--radius-sm);
  background: #fff;
  color: #7c2d12;
  font-weight: 800;
  cursor: pointer;
}

.erp-session-warning__actions button:first-child {
  background: #d97706;
  color: #fff;
  border-color: #d97706;
}

.erp-table-empty-state {
  display: none;
  place-items: center;
  gap: 0.45rem;
  margin: 0.85rem 0;
  padding: 1.4rem;
  border: 1px dashed rgba(148, 163, 184, 0.4);
  border-radius: var(--radius-sm);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(248, 250, 252, 0.92)),
    #fff;
  color: #475569;
  text-align: center;
  font-family: Inter, Outfit, sans-serif;
}

.erp-table-empty-state.is-visible {
  display: grid;
}

.erp-table-empty-state__art {
  width: 80px;
  height: 60px;
  display: grid;
  place-items: center;
  border-radius: var(--radius-sm);
  background:
    linear-gradient(135deg, rgba(37, 99, 235, 0.12), rgba(15, 159, 110, 0.12)),
    #f8fafc;
  color: #2563eb;
  font-size: 1.9rem;
}

.erp-table-empty-state strong {
  color: #0f172a;
  font-size: 0.98rem;
}

.erp-table-empty-state span {
  max-width: 360px;
  color: #64748b;
  font-size: 0.88rem;
  line-height: 1.45;
}

/* Spinner / Loader element */
.spinner-inline {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  width: 1.2rem;
  height: 1.2rem;
  border: 2px solid var(--border-glass);
  border-radius: 50%;
  border-top-color: var(--primary);
  animation: spin 1s ease-in-out infinite;
  vertical-align: middle;
  margin-left: 0.5rem;
}

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

.student-ux-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  margin: 1rem 0;
  padding: 1rem 1.2rem;
}

.student-ux-search {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex: 1 1 480px;
  min-width: 280px;
}

.student-ux-input-wrap {
  position: relative;
  flex: 1 1 auto;
}

.student-ux-input-wrap i {
  position: absolute;
  top: 50%;
  left: 0.95rem;
  transform: translateY(-50%);
  color: var(--text-muted);
  font-size: 1rem;
  pointer-events: none;
}

.student-ux-input {
  padding-left: 2.65rem;
}

.student-ux-actions {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  flex-wrap: wrap;
}

.student-ux-meta {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  flex-wrap: wrap;
}

.student-ux-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.5rem 0.85rem;
  border-radius: 999px;
  background: rgba(59, 130, 246, 0.14);
  border: 1px solid rgba(59, 130, 246, 0.16);
  color: var(--text-main);
  font-size: 0.86rem;
  font-weight: 600;
}

.student-ux-chip i {
  color: var(--primary);
}

@media (max-width: 768px) {
  .erp-breadcrumbs {
    width: min(100% - 20px, 1200px);
    font-size: 0.82rem;
  }

  .erp-session-warning {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .erp-session-warning__actions {
    grid-column: 1 / -1;
    width: 100%;
  }

  .erp-session-warning__actions button {
    flex: 1 1 0;
  }

  .student-ux-bar {
    padding: 0.9rem 1rem;
  }

  .student-ux-search,
  .student-ux-actions,
  .student-ux-meta {
    width: 100%;
  }
}

/* Shared UI polish overrides */
html {
  scrollbar-width: thin;
  scrollbar-color: var(--border-glass) transparent;
}

*::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}

*::-webkit-scrollbar-track {
  background: transparent;
}

*::-webkit-scrollbar-thumb {
  background: var(--border-glass);
  border-radius: 999px;
}

th,
td {
  padding: 0.7rem 1rem;
}

tbody tr:hover td {
  background: rgba(59, 130, 246, 0.06);
}

a:hover:not(.btn):not(.btn-primary):not(.btn-outline):not(.nav-link):not(.nav-chip):not(.erp-nav-chip):not(.erp-auto-backlink),
.erp-breadcrumbs a:hover {
  text-decoration: underline;
}

button,
.btn,
.btn-primary,
.btn-outline,
.nav-link,
.nav-chip,
.erp-nav-chip,
.theme-fab-btn {
  letter-spacing: 0.03em;
}

.badge,
.status-badge,
.status-chip,
.chip-success,
.badge-success,
.success-badge,
[class*="badge"][class*="success"],
[class*="status"][class*="success"] {
  --status-success: var(--success);
}

.badge.success,
.badge-success,
.status-badge.success,
.status-chip.success,
.chip-success,
.success-badge {
  background-color: color-mix(in srgb, var(--success) 18%, transparent);
  border-color: color-mix(in srgb, var(--success) 35%, transparent);
  color: var(--success);
}

input:focus,
select:focus,
textarea:focus,
.input-element:focus {
  box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.40);
}

input,
select,
textarea,
.input-element {
  transition: border-color 0.18s ease, box-shadow 0.18s ease;
}

input:disabled,
select:disabled,
textarea:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

h1 {
  color: var(--text-main);
}

/* Requested cross-page polish */
h1,
h2,
h3,
h4,
h5,
h6,
.hero-title,
.page-title,
.grid-header h2,
.panel-header h3 {
  letter-spacing: 0.3px;
}

p,
li,
td,
th,
label,
small,
.helper-text,
.text-neutral,
.text-muted {
  line-height: 1.6;
}

button,
.btn,
.btn-primary,
.btn-secondary,
.btn-outline,
.primary-btn,
.secondary-btn,
.action-btn,
.nav-link,
.nav-chip,
.erp-nav-chip,
.theme-fab-btn,
input[type="button"],
input[type="submit"],
input[type="reset"] {
  border-radius: 8px !important;
  transition: all 0.2s ease;
}

.btn-secondary,
.secondary-btn,
.action-btn.secondary,
.btn-outline {
  background: rgba(255, 255, 255, 0.08) !important;
  border: 1px solid rgba(148, 163, 184, 0.28) !important;
  color: var(--text-main) !important;
  box-shadow: none !important;
}

.btn-secondary:hover:not(:disabled),
.secondary-btn:hover:not(:disabled),
.action-btn.secondary:hover:not(:disabled),
.btn-outline:hover:not(:disabled) {
  background: rgba(59, 130, 246, 0.14) !important;
  border-color: rgba(59, 130, 246, 0.42) !important;
  color: #dbeafe !important;
}

.card,
.stat-card,
.control-box,
.input-group,
.receipt-card,
.receipt-note-box,
.receipt-summary-box,
.student-header,
.sidebar,
.dues-panel,
.history-panel,
.erp-topmenu__panel,
.erp-topmenu__link,
.fee-school-topline {
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
}

.alert,
.info-box,
.notice,
.helper-box,
.error-msg,
.fee-sms-group,
.fee-year-lock,
.erp-session-warning {
  border-left: 4px solid var(--primary);
}

.error-msg,
.alert-danger,
.toast.error {
  border-left-color: #ef4444;
}

.alert-success,
.toast.success {
  border-left-color: var(--success);
}

table th,
.ag-header-cell,
.ag-header-cell-text {
  font-weight: 600 !important;
}

table tbody tr:nth-child(even) td {
  background-color: rgba(148, 163, 184, 0.055);
}

table tbody tr:hover td {
  background-color: rgba(59, 130, 246, 0.09);
}

tr.total-row td,
tr.balance-row td,
tr.grand-total td,
tfoot tr td,
.total-row,
.balance-row,
.grand-total {
  background: rgba(59, 130, 246, 0.12) !important;
  border-top: 1px solid rgba(59, 130, 246, 0.32) !important;
  font-weight: 700;
}

td.amount,
th.amount,
td.currency,
th.currency,
td.numeric,
th.numeric,
td[data-type="amount"],
th[data-type="amount"],
.amount-cell,
.currency-cell,
.numeric-cell,
.ag-cell[col-id*="Amount"],
.ag-cell[col-id*="amount"],
.ag-cell[col-id*="Paid"],
.ag-cell[col-id*="Balance"],
.ag-cell[col-id*="Remaining"],
.ag-cell[col-id*="Total"],
.ag-cell[col-id*="Concession"],
.ag-cell[col-id="PayingAmount"],
.ag-cell[col-id="grandTotalPaid"],
.ag-cell[col-id="grandRemaining"],
.ag-cell[col-id="paidAmount"],
.ag-cell[col-id="remaining"] {
  text-align: right !important;
  justify-content: flex-end !important;
  font-variant-numeric: tabular-nums;
}

input:focus-visible,
select:focus-visible,
textarea:focus-visible,
.input-element:focus-visible {
  outline: 2px solid rgba(59, 130, 246, 0.55);
  outline-offset: 2px;
}

.erp-field-section,
.filter-grid,
.scope-controls,
.form-section {
  border-radius: 8px;
}

.erp-search-wrap {
  position: relative;
  display: block;
  width: 100%;
}

.erp-search-wrap input[type="search"],
.erp-search-wrap input[type="text"] {
  padding-right: 2.6rem !important;
}

.erp-search-clear {
  position: absolute;
  top: 50%;
  right: 0.45rem;
  width: 30px;
  height: 30px;
  min-width: 30px;
  padding: 0;
  display: none;
  place-items: center;
  border: 0;
  border-radius: 8px !important;
  background: rgba(148, 163, 184, 0.16);
  color: var(--text-muted);
  transform: translateY(-50%);
  box-shadow: none !important;
}

.erp-search-wrap.has-value .erp-search-clear {
  display: grid;
}

.erp-search-clear:hover {
  background: rgba(239, 68, 68, 0.14);
  color: #fecaca;
}

.nav-link.active,
.nav-link.is-active,
.nav-chip.active,
.nav-chip.is-active,
.erp-nav-chip.active,
.erp-nav-chip.is-active,
.erp-topmenu__tab.is-active,
.erp-topmenu__link.is-active {
  color: #e0f2fe !important;
  border-color: rgba(56, 189, 248, 0.42) !important;
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 5px;
}

.erp-loading-skeleton {
  position: relative;
  overflow: hidden;
  min-height: 48px;
  border-radius: 8px;
  background: rgba(148, 163, 184, 0.12);
}

.erp-loading-skeleton::after {
  content: '';
  position: absolute;
  inset: 0;
  transform: translateX(-100%);
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.16), transparent);
  animation: erpSkeletonSweep 1.2s ease-in-out infinite;
}

@keyframes erpSkeletonSweep {
  to { transform: translateX(100%); }
}

/* Shared page-header readability guard.
   Many module pages load local CSS after common.css; keep the common header
   and page-purpose bands readable on light ERP workspaces. */
.cw-school-strip.erp-page-topbar {
  background:
    radial-gradient(circle at top left, rgba(59, 130, 246, 0.14), transparent 34%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(239, 246, 255, 0.9)) !important;
  color: #172033 !important;
  border-color: rgba(148, 163, 184, 0.26) !important;
}

.cw-school-strip.erp-page-topbar .cw-school-brand h2,
.cw-school-strip.erp-page-topbar .cw-school-brand h2 *,
.erp-page-purpose h1,
.erp-page-purpose h1 * {
  color: #172033 !important;
  -webkit-text-fill-color: #172033 !important;
}

.cw-school-strip.erp-page-topbar .cw-school-brand p,
.cw-school-strip.erp-page-topbar .cw-school-brand p * {
  color: #2563eb !important;
  -webkit-text-fill-color: #2563eb !important;
}

.cw-school-strip.erp-page-topbar .cw-school-brand span,
.cw-school-strip.erp-page-topbar .cw-school-brand span *,
.erp-page-purpose p,
.erp-page-purpose p * {
  color: #64748b !important;
  -webkit-text-fill-color: #64748b !important;
}

.erp-page-purpose {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(248, 250, 252, 0.86)) !important;
  color: #172033 !important;
  border-color: rgba(148, 163, 184, 0.24) !important;
}

button:disabled,
.btn:disabled,
.btn-outline:disabled,
.btn-secondary:disabled {
  color: #64748b;
  -webkit-text-fill-color: #64748b;
}
