:root {
  --ink: #172033;
  --muted: #667085;
  --line: #d8e0eb;
  --line-strong: #bdc9da;
  --soft: #f6f8fc;
  --brand: #1d4ed8;
  --brand-dark: #142f83;
  --gold: #f6b73c;
  --green: #16a34a;
  --purple: #7c3aed;
  --danger: #dc3545;
  --card: rgba(255, 255, 255, .94);
  --shadow: 0 20px 50px rgba(15, 23, 42, .10);
  --shadow-soft: 0 10px 28px rgba(15, 23, 42, .08);
}
* { box-sizing: border-box; }
body {
  margin: 0;
  min-height: 100vh;
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--ink);
  background:
    radial-gradient(circle at 8% 4%, rgba(29, 78, 216, 0.14), transparent 28%),
    radial-gradient(circle at 95% 6%, rgba(246, 183, 60, 0.18), transparent 26%),
    linear-gradient(180deg, #f8fbff 0%, #eef4fb 100%);
}
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image: linear-gradient(rgba(29,78,216,.035) 1px, transparent 1px), linear-gradient(90deg, rgba(29,78,216,.035) 1px, transparent 1px);
  background-size: 34px 34px;
  mask-image: linear-gradient(to bottom, black, transparent 80%);
}
h1, h2, h3, h4, h5 { letter-spacing: -.03em; }
a { text-decoration: none; }
.sidebar {
  min-height: 100vh;
  background: linear-gradient(180deg, rgba(29,78,216,.98) 0%, rgba(30,58,138,.98) 58%, rgba(15,31,77,.98) 100%);
  box-shadow: 12px 0 34px rgba(15, 31, 77, 0.20);
  position: sticky;
  top: 0;
  display: flex;
  flex-direction: column;
  z-index: 10;
}
.sidebar-brand { border-bottom: 1px solid rgba(255,255,255,.18); padding-bottom: 18px; }
.brand-orb {
  width: 52px; height: 52px; display: grid; place-items: center; color: #fff;
  font-size: 1.45rem; border-radius: 18px; margin-bottom: 12px;
  background: rgba(255,255,255,.18); border: 1px solid rgba(255,255,255,.24);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.18), 0 12px 28px rgba(0,0,0,.16);
}
.sidebar-menu .nav-link {
  padding: 12px 14px; border-radius: 16px; margin-bottom: 9px; transition: .25s ease;
  font-weight: 700; display: flex; align-items: center;
}
.sidebar-menu .nav-link i { width: 24px; text-align: center; }
.sidebar-menu .nav-link:hover, .sidebar-menu .nav-link.active { background-color: rgba(255,255,255,.18); transform: translateX(4px); }
.sidebar-note { color: rgba(255,255,255,.88); background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.16); border-radius: 20px; padding: 14px; display: flex; gap: 10px; align-items: flex-start; font-size: .9rem; }
.dashboard-area { padding: 24px; position: relative; z-index: 1; }
.topbar { background: rgba(255,255,255,.88); border: 1px solid rgba(255,255,255,.78); border-radius: 26px; padding: 20px 24px; box-shadow: var(--shadow-soft); margin-bottom: 22px; backdrop-filter: blur(14px); }
.topbar h2 { font-weight: 850; }
.topbar-badge { background: #eef4ff; color: var(--brand); padding: 10px 14px; border-radius: 999px; font-weight: 800; box-shadow: inset 0 0 0 1px rgba(29,78,216,.08); }
.eyebrow { text-transform: uppercase; font-size: .72rem; font-weight: 900; letter-spacing: .13em; }
.page-hero, .profile-hero, .mini-hero {
  border-radius: 30px; padding: 28px; color: #fff;
  background: linear-gradient(135deg, rgba(29,78,216,.98), rgba(30,58,138,.96));
  background-size: cover; box-shadow: 0 24px 54px rgba(29,78,216,.27); display: flex; justify-content: space-between; align-items: center; gap: 20px;
}
.staff-hero { background: linear-gradient(135deg, #1d4ed8, #0f766e); }
.import-hero { background: linear-gradient(135deg, #7c3aed, #1d4ed8); }
.page-hero h3, .profile-hero h2, .mini-hero h3 { margin: 6px 0; font-weight: 900; }
.page-hero p, .profile-hero p, .mini-hero p { color: rgba(255,255,255,.88); }
.glass-card, .elevated-card, .card { border-radius: 24px !important; border: 1px solid rgba(255,255,255,.78) !important; background: var(--card) !important; box-shadow: var(--shadow) !important; overflow: hidden; }
.card-body { position: relative; z-index: 1; }
.form-card .form-control, .form-card .form-select, .form-control, .form-select { min-height: 48px; border-radius: 15px; border-color: #d4deec; background-color: rgba(255,255,255,.96); }
.form-label { font-weight: 800; color: #2d3748; font-size: .9rem; }
.form-control:focus, .form-select:focus { border-color: var(--brand); box-shadow: 0 0 0 .22rem rgba(29,78,216,.13); }
.profile-textarea { min-height: 140px; }
.stat-card, .dashboard-card { position: relative; overflow: hidden; border-radius: 24px !important; padding: 20px; min-height: 122px; color: #fff; display: flex; align-items: center; gap: 16px; box-shadow: 0 18px 44px rgba(15,23,42,.14) !important; }
.stat-card::after, .dashboard-card::after { content: ""; position: absolute; width: 120px; height: 120px; border-radius: 999px; right: -36px; top: -36px; background: rgba(255,255,255,.16); }
.stat-card p, .dashboard-card p, .card-label { margin: 0 0 6px; opacity: .9; font-weight: 800; }
.stat-card h3, .dashboard-card h3 { margin: 0; font-weight: 900; font-size: 2rem; }
.stat-icon { width: 54px; height: 54px; border-radius: 19px; background: rgba(255,255,255,.22); display: grid; place-items: center; font-size: 1.45rem; }
.accent-blue { background: linear-gradient(135deg, #2563eb, #1e3a8a) !important; }
.accent-green { background: linear-gradient(135deg, #16a34a, #166534) !important; }
.accent-purple { background: linear-gradient(135deg, #7c3aed, #4c1d95) !important; }
.accent-gold { background: linear-gradient(135deg, #f59e0b, #b45309) !important; }
.table-card { padding: 20px; }
.beautiful-table-wrap, .table-responsive { border-radius: 20px; border: 1px solid var(--line-strong); overflow: auto; background: #fff; }
.beautiful-table, .table { margin-bottom: 0; border-collapse: separate; border-spacing: 0; }
.beautiful-table thead th, .table thead th { background: linear-gradient(180deg, #f8fbff, #eef4fb) !important; color: #172033; border-bottom: 1px solid var(--line-strong) !important; border-right: 1px solid var(--line) !important; font-size: .8rem; text-transform: uppercase; letter-spacing: .045em; white-space: nowrap; font-weight: 900; padding: 14px 12px; }
.beautiful-table td, .table td { border-right: 1px solid var(--line) !important; border-bottom: 1px solid var(--line) !important; vertical-align: middle; padding: 14px 12px; background: rgba(255,255,255,.98); }
.beautiful-table th:last-child, .beautiful-table td:last-child, .table th:last-child, .table td:last-child { border-right: 0 !important; }
.beautiful-table tbody tr:nth-child(even) td, .table tbody tr:nth-child(even) td { background: #fbfdff; }
.beautiful-table tbody tr:hover td, .table tbody tr:hover td { background: #eff6ff !important; }
.table-bordered { border-color: var(--line-strong) !important; }
.subjects-cell { min-width: 180px; }
.code-pill, .status-badge, .profile-chip, .soft-pill { display: inline-flex; align-items: center; border-radius: 999px; padding: 7px 11px; font-size: .82rem; font-weight: 850; }
.code-pill { background: #eef4ff; color: var(--brand); border: 1px solid #d7e5ff; }
.status-active { background: #dcfce7; color: #166534; border: 1px solid #bbf7d0; }
.status-inactive { background: #fee2e2; color: #991b1b; border: 1px solid #fecaca; }
.profile-chip { background: rgba(255,255,255,.18); color: #fff; border: 1px solid rgba(255,255,255,.20); }
.soft-pill { background: #f1f5f9; color: #334155; border: 1px solid #e2e8f0; }
.action-group { display: flex; gap: 7px; flex-wrap: nowrap; align-items: center; }
.action-group form { margin: 0; }
.btn { border-radius: 14px; font-weight: 800; transition: .2s ease; }
.btn:hover { transform: translateY(-1px); }
.btn-primary { background: linear-gradient(135deg, var(--brand), var(--brand-dark)); border: 0; }
.btn-warning { background: linear-gradient(135deg, #fbbf24, #f59e0b); border: 0; color: #1f2937; }
.icon-btn { width: 38px; height: 38px; padding: 0 !important; display: inline-grid !important; place-items: center; border-radius: 13px !important; line-height: 1; font-size: 1rem; }
.icon-btn-lg { width: 46px; height: 46px; border-radius: 16px !important; font-size: 1.15rem; }
.icon-btn i { margin: 0 !important; }
.btn-light.icon-btn { color: #1d4ed8; }
.subject-box { display: flex; flex-wrap: wrap; gap: 10px; padding: 13px; min-height: 48px; border: 1px solid #d4deec; border-radius: 18px; background: #fbfdff; }
.subject-chip { cursor: pointer; margin: 0; }
.subject-chip input { display: none; }
.subject-chip span { display: inline-flex; padding: 8px 12px; border-radius: 999px; background: #eef2f7; color: #334155; font-weight: 800; transition: .2s ease; border: 1px solid transparent; }
.subject-chip input:checked + span { background: #dbeafe; color: var(--brand); border-color: rgba(29,78,216,.22); box-shadow: 0 6px 14px rgba(29,78,216,.10); }
.profile-hero { align-items: center; }
.profile-avatar { width: 96px; height: 96px; border-radius: 32px; display: grid; place-items: center; font-size: 2.6rem; font-weight: 950; background: rgba(255,255,255,.2); border: 1px solid rgba(255,255,255,.25); box-shadow: inset 0 1px 0 rgba(255,255,255,.16); }
.section-title { font-weight: 900; letter-spacing: -.025em; margin-bottom: 18px; }
.info-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.info-tile, .contact-card { border: 1px solid var(--line); border-radius: 20px; padding: 15px; background: linear-gradient(180deg, #ffffff, #fbfdff); box-shadow: 0 8px 18px rgba(15,23,42,.04); }
.info-tile span, .contact-card span { display: block; color: var(--muted); font-size: .78rem; font-weight: 900; text-transform: uppercase; letter-spacing: .07em; }
.info-tile strong, .contact-card strong { display: block; margin-top: 5px; font-size: 1rem; }
.contact-card { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; }
.contact-card i { width: 42px; height: 42px; border-radius: 15px; display: grid; place-items: center; color: var(--brand); background: #eef4ff; }
.about-panel p { color: #344054; line-height: 1.8; white-space: pre-line; }
.login-page { background: linear-gradient(135deg, #1d4ed8, #0f172a); min-height: 100vh; display: grid; place-items: center; padding: 24px; }
.login-wrapper { width: min(980px, 100%); }
.login-card { display: grid; grid-template-columns: 1fr 1fr; border-radius: 32px; overflow: hidden; background: #fff; }
.login-left { padding: 52px; color: #fff; background: linear-gradient(135deg, #1d4ed8, #0f766e); display: flex; flex-direction: column; justify-content: center; }
.login-left h1 { font-size: 3rem; font-weight: 950; }
.login-right { padding: 52px; }
.demo-box { background: #f8fbff; border: 1px solid var(--line); border-radius: 18px; padding: 14px; }
.quick-card { min-height: 100%; }
.list-group-item { background: transparent; border-color: var(--line); }
@media (max-width: 991px) {
  .sidebar { min-height: auto; position: relative; }
  .dashboard-area { padding: 16px; }
  .page-hero, .profile-hero, .mini-hero { flex-direction: column; align-items: flex-start; }
  .info-grid { grid-template-columns: 1fr; }
  .topbar { flex-direction: column; align-items: flex-start !important; gap: 12px; }
  .login-card { grid-template-columns: 1fr; }
  .login-left, .login-right { padding: 32px; }
}

.student-hero { background: linear-gradient(135deg, #0f766e, #1d4ed8 56%, #7c3aed) !important; }
.form-section-title {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  color: #0f172a;
  background: linear-gradient(180deg, #ffffff, #f8fbff);
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 9px 14px;
  font-size: .9rem;
  font-weight: 900;
  margin: 6px 0 16px;
  box-shadow: 0 8px 18px rgba(15,23,42,.05);
}
.form-section-title i { color: var(--brand); }
textarea.form-control { min-height: 48px; border-radius: 15px; }
.btn-outline-info.icon-btn { color: #0891b2; border-color: #a5f3fc; background: #ecfeff; }
.btn-outline-info.icon-btn:hover { color: #fff; background: #0891b2; border-color: #0891b2; }

/* ==========================================
   PARENT DASHBOARD COLOR FIX
   ========================================== */

/* Parent dashboard stat cards */
.parent-stat-card,
.parent-summary-card,
.parent-metric-card,
.stats-card,
.metric-card {
  background: #ffffff !important;
  border: 1px solid #dbe3f0;
  border-radius: 22px;
  padding: 22px 20px;
  box-shadow: 0 10px 30px rgba(15, 23, 42, 0.06);
  color: #1e293b !important;
}

/* Labels inside cards */
.parent-stat-card .stat-label,
.parent-summary-card .stat-label,
.parent-metric-card .stat-label,
.stats-card .stat-label,
.metric-card .stat-label,
.parent-stat-card small,
.parent-summary-card small,
.parent-metric-card small,
.stats-card small,
.metric-card small,
.parent-stat-card span,
.parent-summary-card span,
.parent-metric-card span,
.stats-card span,
.metric-card span {
  color: #64748b !important;
  font-weight: 600;
}

/* Values inside cards */
.parent-stat-card .stat-value,
.parent-summary-card .stat-value,
.parent-metric-card .stat-value,
.stats-card .stat-value,
.metric-card .stat-value,
.parent-stat-card strong,
.parent-summary-card strong,
.parent-metric-card strong,
.stats-card strong,
.metric-card strong,
.parent-stat-card h3,
.parent-summary-card h3,
.parent-metric-card h3,
.stats-card h3,
.metric-card h3 {
  color: #0f172a !important;
  font-weight: 800;
}

/* Ensure any paragraph text inside cards is visible */
.parent-stat-card p,
.parent-summary-card p,
.parent-metric-card p,
.stats-card p,
.metric-card p {
  color: #475569 !important;
}

/* Recent messages panel */
.parent-message-card,
.parent-dashboard .glass-card,
.parent-dashboard .info-card {
  color: #1e293b;
}

.parent-message-card p,
.parent-dashboard .glass-card p,
.parent-dashboard .info-card p {
  color: #475569;
}

/* Child cards */
.child-card,
.parent-child-card {
  background: #ffffff;
  border: 1px solid #dbe3f0;
  border-radius: 22px;
  color: #1e293b;
}

.child-card .school-name,
.parent-child-card .school-name {
  color: #64748b;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.82rem;
}

.child-card .child-name,
.parent-child-card .child-name {
  color: #0f172a;
  font-weight: 800;
}

.child-card .child-meta,
.parent-child-card .child-meta {
  color: #64748b;
}

/* Sidebar profile block */
.parent-sidebar .profile-box,
.sidebar .profile-box {
  color: #ffffff;
}

.parent-sidebar .profile-box small,
.sidebar .profile-box small {
  color: rgba(255, 255, 255, 0.85);
}

/* Optional: force parent dashboard text visibility */
.parent-dashboard,
.parent-dashboard * {
  text-rendering: optimizeLegibility;
}

.parent-dashboard .summary-card,
.parent-dashboard .stats-card,
.parent-dashboard .metric-card {
  color: #1e293b !important;
}

.parent-dashboard .summary-card *:not(.badge):not(.btn),
.parent-dashboard .stats-card *:not(.badge):not(.btn),
.parent-dashboard .metric-card *:not(.badge):not(.btn) {
  color: inherit;
}

/* ==========================================
   PARENT MESSAGES PAGE COLOR FIX
   ========================================== */

.parent-messages-page .dashboard-card,
.parent-messages-page .summary-card,
.parent-messages-page .stats-card,
.parent-messages-page .metric-card {
  background: #ffffff !important;
  border: 1px solid #dbe3f0 !important;
  border-radius: 22px !important;
  padding: 22px 20px !important;
  min-height: 120px;
  box-shadow: 0 10px 30px rgba(15, 23, 42, 0.06) !important;
  color: #1e293b !important;
}

.parent-messages-page .dashboard-card span,
.parent-messages-page .summary-card span,
.parent-messages-page .stats-card span,
.parent-messages-page .metric-card span {
  color: #64748b !important;
  font-weight: 700;
}

.parent-messages-page .dashboard-card h3,
.parent-messages-page .summary-card h3,
.parent-messages-page .stats-card h3,
.parent-messages-page .metric-card h3 {
  color: #0f172a !important;
  font-weight: 900;
  font-size: 2rem;
}

/* Make message cards readable */
.parent-messages-page .glass-card,
.parent-messages-page .parent-message-card,
.parent-messages-page .message-card {
  background: #ffffff !important;
  color: #1e293b !important;
}

.parent-messages-page .glass-card h5,
.parent-messages-page .glass-card h6,
.parent-messages-page .parent-message-card h5,
.parent-messages-page .parent-message-card h6,
.parent-messages-page .message-card h5,
.parent-messages-page .message-card h6 {
  color: #0f172a !important;
  font-weight: 800;
}

.parent-messages-page .glass-card p,
.parent-messages-page .parent-message-card p,
.parent-messages-page .message-card p {
  color: #334155 !important;
}

.parent-messages-page .text-muted {
  color: #64748b !important;
}

/* Filter tab area */
.parent-messages-page .filter-tabs,
.parent-messages-page .message-filter-tabs {
  background: #ffffff !important;
  color: #1e293b !important;
}

/* Keep blue buttons readable */
.parent-messages-page .btn-primary,
.parent-messages-page .badge.bg-primary {
  color: #ffffff !important;
}

/* ==========================================
   PARENT DASHBOARD + PARENT MESSAGES FIX
   ========================================== */

.parent-stat-card {
  background: #ffffff !important;
  background-image: none !important;
  border: 1px solid #dbe3f0 !important;
  border-radius: 22px !important;
  padding: 24px 22px !important;
  min-height: 120px !important;
  box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08) !important;
  color: #0f172a !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
}

.parent-stat-card .stat-label {
  color: #475569 !important;
  font-weight: 800 !important;
  font-size: 0.95rem !important;
  margin-bottom: 8px !important;
}

.parent-stat-card .stat-value {
  color: #0f172a !important;
  font-weight: 900 !important;
  font-size: 2.1rem !important;
  line-height: 1.1 !important;
  margin: 0 !important;
}

.parent-messages-page .parent-filter-card {
  background: #ffffff !important;
  background-image: none !important;
}

.parent-messages-page .parent-message-card {
  background: #ffffff !important;
  background-image: none !important;
  color: #1e293b !important;
}

.parent-messages-page .parent-message-card h5,
.parent-messages-page .parent-message-card h6 {
  color: #0f172a !important;
  font-weight: 800 !important;
}

.parent-messages-page .parent-message-card p {
  color: #334155 !important;
}

.parent-messages-page .parent-message-card .text-muted {
  color: #64748b !important;
}

.parent-messages-page .parent-message-card strong {
  color: #1e293b !important;
}

/* Safety override for any old dashboard-card still appearing */
.parent-messages-page .dashboard-card,
.parent-dashboard .dashboard-card {
  background: #ffffff !important;
  background-image: none !important;
  color: #0f172a !important;
}

.parent-messages-page .dashboard-card span,
.parent-dashboard .dashboard-card span {
  color: #475569 !important;
  font-weight: 800 !important;
}

.parent-messages-page .dashboard-card h3,
.parent-dashboard .dashboard-card h3 {
  color: #0f172a !important;
  font-weight: 900 !important;
}
/* =========================================================
   FIHM EDUCATION STABLE V3 - CLEAN UI POLISH
   Global dashboard, form and table refinements.
   This layer is intentionally CSS-only so existing routes,
   queries and business logic remain untouched.
   ========================================================= */

:root {
  --fihm-navy: #0f172a;
  --fihm-blue: #1d4ed8;
  --fihm-blue-2: #2563eb;
  --fihm-cyan: #06b6d4;
  --fihm-lilac: #ede9fe;
  --fihm-cream: #fff7ed;
  --fihm-surface: rgba(255,255,255,.92);
  --fihm-border: rgba(148,163,184,.28);
  --fihm-shadow: 0 22px 60px rgba(15,23,42,.10);
  --fihm-shadow-hover: 0 28px 70px rgba(15,23,42,.16);
}

html { scroll-behavior: smooth; }
body { background-attachment: fixed; }

body::after {
  content: "";
  position: fixed;
  inset: auto 30px 30px auto;
  width: 260px;
  height: 260px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(37,99,235,.12), transparent 70%);
  pointer-events: none;
  z-index: 0;
}

.dashboard-area,
.container-fluid,
main { position: relative; z-index: 1; }

/* Sidebar polish */
.sidebar {
  border-right: 1px solid rgba(255,255,255,.18);
}
.sidebar-brand h4 {
  font-weight: 950;
  letter-spacing: -.04em;
}
.sidebar-brand small { color: rgba(255,255,255,.78) !important; }
.sidebar-menu { gap: 2px; }
.sidebar-menu .nav-item > .text-light {
  font-weight: 900;
  letter-spacing: .12em;
  font-size: .68rem;
  color: rgba(255,255,255,.62) !important;
}
.sidebar-menu .nav-link {
  position: relative;
  color: rgba(255,255,255,.90) !important;
  border: 1px solid transparent;
}
.sidebar-menu .nav-link::before {
  content: "";
  width: 4px;
  height: 22px;
  border-radius: 999px;
  background: transparent;
  position: absolute;
  left: 4px;
  top: 50%;
  transform: translateY(-50%);
  transition: .2s ease;
}
.sidebar-menu .nav-link:hover,
.sidebar-menu .nav-link.active {
  background: rgba(255,255,255,.16) !important;
  border-color: rgba(255,255,255,.18);
  color: #fff !important;
}
.sidebar-menu .nav-link:hover::before,
.sidebar-menu .nav-link.active::before { background: #fbbf24; }
.sidebar .rounded.bg-dark,
.sidebar .profile-box {
  border-radius: 20px !important;
  background: rgba(255,255,255,.13) !important;
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.10);
}

/* Top bar polish */
.topbar {
  border-radius: 30px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.96), rgba(248,250,252,.90)) !important;
  border: 1px solid rgba(255,255,255,.86) !important;
}
.topbar h2 {
  color: var(--fihm-navy);
  font-size: clamp(1.35rem, 2vw, 2.1rem);
}
.topbar .badge,
.badge.text-bg-light {
  border: 1px solid #e2e8f0;
  color: #334155 !important;
  background: #f8fafc !important;
  padding: .55rem .75rem;
  border-radius: 999px;
}
.topbar-badge {
  background: linear-gradient(135deg, #eff6ff, #eef2ff) !important;
  border: 1px solid #dbeafe;
}

/* Hero sections */
.page-hero,
.profile-hero,
.mini-hero {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.page-hero::before,
.profile-hero::before,
.mini-hero::before {
  content: "";
  position: absolute;
  inset: -80px -70px auto auto;
  width: 230px;
  height: 230px;
  border-radius: 999px;
  background: rgba(255,255,255,.15);
  z-index: -1;
}
.page-hero::after,
.profile-hero::after,
.mini-hero::after {
  content: "";
  position: absolute;
  inset: auto auto -90px -90px;
  width: 220px;
  height: 220px;
  border-radius: 999px;
  background: rgba(251,191,36,.18);
  z-index: -1;
}

/* Cards and dashboard modules */
.card,
.glass-card,
.elevated-card,
.table-card,
.parent-filter-card,
.parent-message-card,
.parent-stat-card,
.info-tile,
.contact-card,
.child-card,
.parent-child-card {
  border-radius: 26px !important;
  border: 1px solid var(--fihm-border) !important;
  box-shadow: var(--fihm-shadow) !important;
}
.card,
.glass-card,
.elevated-card,
.table-card {
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(255,255,255,.90)) !important;
}
.card:hover,
.glass-card:hover,
.elevated-card:hover,
.info-tile:hover,
.contact-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--fihm-shadow-hover) !important;
}
.card,
.glass-card,
.elevated-card,
.info-tile,
.contact-card { transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease; }
.card-header {
  background: linear-gradient(180deg, #f8fafc, #f1f5f9) !important;
  border-bottom: 1px solid #e2e8f0 !important;
  font-weight: 900;
}
.section-title,
.card-title,
h3, h4, h5 { color: #0f172a; }
.text-muted { color: #64748b !important; }

/* Dashboard statistic cards */
.stat-card,
.dashboard-card {
  border: 0 !important;
  border-radius: 28px !important;
  min-height: 132px;
}
.stat-card h3,
.dashboard-card h3 {
  font-size: clamp(1.6rem, 3vw, 2.25rem);
}
.stat-icon {
  width: 62px;
  height: 62px;
  border-radius: 22px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.18);
}
.row.g-3 > [class*="col-"] > .card.h-100,
.row.g-4 > [class*="col-"] > .card.h-100 {
  min-height: 100%;
}

/* Forms */
form .row { row-gap: .35rem; }
.form-card,
form.card,
.card:has(form) {
  overflow: visible;
}
.form-label {
  font-size: .83rem;
  text-transform: uppercase;
  letter-spacing: .055em;
  color: #334155 !important;
  margin-bottom: .45rem;
}
.form-control,
.form-select,
textarea.form-control {
  border-radius: 16px !important;
  border: 1px solid #dbe3f0 !important;
  background: #fbfdff !important;
  min-height: 50px;
  padding: .78rem .95rem;
  box-shadow: inset 0 1px 2px rgba(15,23,42,.025);
  transition: border-color .18s ease, box-shadow .18s ease, background .18s ease;
}
textarea.form-control { min-height: 118px; }
.form-control:hover,
.form-select:hover { border-color: #bfdbfe !important; background: #fff !important; }
.form-control:focus,
.form-select:focus,
textarea.form-control:focus {
  background: #fff !important;
  border-color: var(--fihm-blue-2) !important;
  box-shadow: 0 0 0 .25rem rgba(37,99,235,.13) !important;
}
.form-text {
  color: #64748b;
  font-weight: 600;
}
.input-group-text {
  border-radius: 16px;
  border-color: #dbe3f0;
  background: #f8fafc;
  color: #475569;
  font-weight: 800;
}
.required-star,
.text-danger.required { color: #dc2626 !important; }

/* Buttons */
.btn {
  border-radius: 15px !important;
  padding: .67rem 1rem;
  letter-spacing: -.01em;
  box-shadow: none !important;
}
.btn-sm { padding: .45rem .78rem; border-radius: 13px !important; }
.btn-lg { padding: .85rem 1.25rem; border-radius: 18px !important; }
.btn-primary,
.btn-success,
.btn-info,
.btn-danger,
.btn-warning {
  border: 0 !important;
}
.btn-primary { background: linear-gradient(135deg, #2563eb, #1e40af) !important; }
.btn-success { background: linear-gradient(135deg, #16a34a, #15803d) !important; }
.btn-info { background: linear-gradient(135deg, #06b6d4, #0284c7) !important; color: #fff !important; }
.btn-danger { background: linear-gradient(135deg, #ef4444, #b91c1c) !important; }
.btn-outline-primary,
.btn-outline-secondary,
.btn-outline-danger,
.btn-outline-success {
  background: rgba(255,255,255,.72);
  border-width: 1.5px;
}
.action-group .btn,
.action-group button,
td .btn { white-space: nowrap; }

/* Tables */
.table-responsive,
.beautiful-table-wrap {
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.70);
  background: #fff;
}
.table thead th,
.beautiful-table thead th {
  position: sticky;
  top: 0;
  z-index: 2;
  background: linear-gradient(180deg, #f8fafc, #eef2ff) !important;
}
.table tbody td:first-child,
.beautiful-table tbody td:first-child { font-weight: 700; color: #1e293b; }
.table tbody tr { transition: background .15s ease; }
.table .badge { font-weight: 850; }

/* Alerts and empty states */
.alert {
  border-radius: 18px;
  border-width: 1px;
  font-weight: 650;
}
.alert-success { background: #ecfdf5; border-color: #bbf7d0; color: #166534; }
.alert-danger { background: #fef2f2; border-color: #fecaca; color: #991b1b; }
.alert-warning { background: #fffbeb; border-color: #fde68a; color: #92400e; }
.alert-info { background: #eff6ff; border-color: #bfdbfe; color: #1e40af; }
.empty-state,
.no-data,
.table-empty {
  border: 1px dashed #cbd5e1;
  border-radius: 24px;
  background: #f8fafc;
  padding: 32px;
  text-align: center;
  color: #64748b;
}

/* Login page premium polish */
.login-page {
  background:
    radial-gradient(circle at 10% 15%, rgba(37,99,235,.22), transparent 28%),
    radial-gradient(circle at 86% 20%, rgba(251,191,36,.24), transparent 26%),
    linear-gradient(135deg, #eff6ff, #f8fafc 45%, #fff7ed);
}
.login-wrapper {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 28px;
}
.login-card {
  width: min(980px, 100%);
  display: grid;
  grid-template-columns: .95fr 1.05fr;
  border-radius: 34px;
  overflow: hidden;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(255,255,255,.80);
  box-shadow: 0 34px 90px rgba(15,23,42,.18) !important;
}
.login-left {
  position: relative;
  padding: 54px 42px;
  color: #fff;
  background:
    linear-gradient(135deg, rgba(29,78,216,.98), rgba(30,64,175,.94)),
    radial-gradient(circle at 30% 20%, rgba(255,255,255,.22), transparent 32%);
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.login-left::after {
  content: "";
  width: 180px;
  height: 180px;
  border-radius: 999px;
  background: rgba(255,255,255,.13);
  position: absolute;
  right: -60px;
  bottom: -60px;
}
.login-left h1 {
  font-size: clamp(2.25rem, 5vw, 4rem);
  line-height: .95;
  font-weight: 950;
  color: #fff;
  margin-bottom: 20px;
}
.login-left p { font-size: 1.1rem; color: rgba(255,255,255,.90); }
.login-left small { color: rgba(255,255,255,.78); font-weight: 700; }
.login-right { padding: 48px 44px; }
.login-right h3 {
  font-weight: 950;
  font-size: 2rem;
  letter-spacing: -.05em;
}
.demo-box {
  border: 1px solid #dbeafe;
  background: linear-gradient(180deg, #eff6ff, #f8fafc);
  border-radius: 22px;
  padding: 18px;
  color: #334155;
}

/* Parent and teacher areas */
.parent-dashboard .page-hero,
.parent-messages-page .page-hero,
.teacher-dashboard .page-hero {
  background: linear-gradient(135deg, #2563eb, #0f766e) !important;
}
.parent-message-card,
.child-card,
.parent-child-card {
  background: linear-gradient(180deg, #fff, #fbfdff) !important;
}

/* Mobile refinements */
@media (max-width: 991.98px) {
  .sidebar { position: relative; min-height: auto; }
  .dashboard-area { padding: 16px; }
  .topbar { border-radius: 24px; padding: 18px; }
  .page-hero,
  .profile-hero,
  .mini-hero { border-radius: 24px; padding: 22px; align-items: flex-start; flex-direction: column; }
  .login-card { grid-template-columns: 1fr; border-radius: 28px; }
  .login-left { padding: 34px 28px; }
  .login-right { padding: 34px 28px; }
}

@media (max-width: 575.98px) {
  .action-group { flex-wrap: wrap; }
  .btn { width: auto; }
  .topbar .d-flex.align-items-center.gap-2 { width: 100%; justify-content: space-between; }
  .topbar-badge { max-width: 100%; }
  .table-responsive { border-radius: 16px; }
}

/* =========================================================
   FIHM EDUCATION STABLE V4 - SCREEN-BY-SCREEN POLISH
   Consistent module heroes, command cards, KPI cards, forms
   and responsive operational screens. Backend untouched.
   ========================================================= */

.module-hero {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  border-radius: 32px;
  padding: 30px;
  color: #ffffff;
  background:
    radial-gradient(circle at 86% 18%, rgba(255,255,255,.22), transparent 28%),
    linear-gradient(135deg, #1d4ed8 0%, #4f46e5 48%, #7c3aed 100%);
  box-shadow: 0 28px 70px rgba(37,99,235,.24);
}
.module-hero::before {
  content: "";
  position: absolute;
  width: 260px;
  height: 260px;
  border-radius: 999px;
  right: -90px;
  bottom: -120px;
  background: rgba(251,191,36,.20);
  z-index: -1;
}
.module-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image: linear-gradient(rgba(255,255,255,.08) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.08) 1px, transparent 1px);
  background-size: 28px 28px;
  mask-image: linear-gradient(120deg, black, transparent 72%);
  z-index: -1;
}
.module-hero.fees-hero { background: linear-gradient(135deg, #0f766e 0%, #2563eb 50%, #f59e0b 100%); }
.module-hero.exams-hero { background: linear-gradient(135deg, #7c3aed 0%, #2563eb 48%, #06b6d4 100%); }
.module-hero.reports-hero { background: linear-gradient(135deg, #0f172a 0%, #1d4ed8 52%, #0f766e 100%); }
.module-hero.teacher-hero { background: linear-gradient(135deg, #2563eb 0%, #0f766e 54%, #16a34a 100%); }
.module-hero.parent-hero { background: linear-gradient(135deg, #1d4ed8 0%, #7c3aed 50%, #ec4899 100%); }
.module-hero .eyebrow,
.module-hero .text-primary { color: rgba(255,255,255,.82) !important; }
.module-hero h1,
.module-hero h2,
.module-hero h3 { color: #ffffff; font-weight: 950; letter-spacing: -.055em; }
.module-hero p { color: rgba(255,255,255,.88); }
.module-hero .hero-actions { display: flex; gap: 10px; flex-wrap: wrap; justify-content: flex-end; }
.module-hero .btn { box-shadow: 0 10px 24px rgba(15,23,42,.16) !important; }

.kpi-card {
  position: relative;
  overflow: hidden;
  height: 100%;
  border-radius: 28px;
  border: 1px solid rgba(148,163,184,.28);
  background: linear-gradient(180deg, #ffffff, #f8fafc);
  padding: 22px;
  box-shadow: 0 20px 48px rgba(15,23,42,.08);
}
.kpi-card::after {
  content: "";
  position: absolute;
  width: 110px;
  height: 110px;
  border-radius: 999px;
  right: -44px;
  top: -44px;
  background: var(--kpi-tint, rgba(37,99,235,.11));
}
.kpi-card .kpi-icon {
  width: 56px;
  height: 56px;
  border-radius: 20px;
  display: grid;
  place-items: center;
  color: #ffffff;
  font-size: 1.45rem;
  margin-bottom: 16px;
  background: var(--kpi-bg, linear-gradient(135deg, #2563eb, #1d4ed8));
  box-shadow: 0 12px 28px rgba(37,99,235,.20);
}
.kpi-card .kpi-label {
  color: #64748b;
  font-weight: 850;
  text-transform: uppercase;
  letter-spacing: .07em;
  font-size: .76rem;
  margin-bottom: 6px;
}
.kpi-card .kpi-value {
  color: #0f172a;
  font-size: clamp(1.55rem, 2.5vw, 2.2rem);
  font-weight: 950;
  letter-spacing: -.05em;
  margin: 0;
}
.kpi-card .kpi-note { color: #64748b; font-weight: 650; margin-top: 8px; }
.kpi-green { --kpi-bg: linear-gradient(135deg, #16a34a, #0f766e); --kpi-tint: rgba(22,163,74,.12); }
.kpi-purple { --kpi-bg: linear-gradient(135deg, #7c3aed, #4f46e5); --kpi-tint: rgba(124,58,237,.13); }
.kpi-gold { --kpi-bg: linear-gradient(135deg, #f59e0b, #ea580c); --kpi-tint: rgba(245,158,11,.16); }
.kpi-red { --kpi-bg: linear-gradient(135deg, #ef4444, #b91c1c); --kpi-tint: rgba(239,68,68,.12); }

.command-card,
.module-tile {
  border-radius: 28px;
  padding: 24px;
  min-height: 100%;
  background: linear-gradient(180deg, #ffffff, #fbfdff);
  border: 1px solid rgba(148,163,184,.28);
  box-shadow: 0 18px 44px rgba(15,23,42,.07);
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.command-card:hover,
.module-tile:hover {
  transform: translateY(-4px);
  box-shadow: 0 28px 70px rgba(15,23,42,.13);
  border-color: rgba(37,99,235,.30);
}
.module-tile .tile-icon,
.command-card .tile-icon {
  width: 54px;
  height: 54px;
  border-radius: 19px;
  display: grid;
  place-items: center;
  color: #ffffff;
  font-size: 1.35rem;
  margin-bottom: 16px;
  background: linear-gradient(135deg, #2563eb, #7c3aed);
}
.module-tile h4,
.command-card h4 { font-weight: 950; letter-spacing: -.04em; }
.module-tile p,
.command-card p { color: #64748b; line-height: 1.65; }
.module-tile .stretched-link::after { border-radius: 28px; }

.filter-panel {
  border-radius: 26px;
  padding: 20px;
  background: linear-gradient(180deg, #ffffff, #f8fafc);
  border: 1px solid rgba(148,163,184,.28);
  box-shadow: 0 16px 40px rgba(15,23,42,.06);
}

.table-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 16px;
}
.table-toolbar h4 { font-weight: 950; letter-spacing: -.04em; margin-bottom: 2px; }

.page-actions-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.page-actions-bar .btn { min-height: 44px; }

.form-card .card-body,
.glass-card .card-body { padding: 1.35rem; }
.form-section {
  border: 1px solid rgba(148,163,184,.22);
  border-radius: 24px;
  padding: 20px;
  background: linear-gradient(180deg, #ffffff, #fbfdff);
  margin-bottom: 18px;
}
.form-section-title {
  background: linear-gradient(135deg, #eff6ff, #eef2ff) !important;
  border-color: #dbeafe !important;
  color: #1e40af !important;
}

/* Make old summary cards look intentional without editing every view */
.row.g-3.mb-4 > [class*="col-"] > .card.border-0.shadow-sm,
.row.g-3.mb-4 > [class*="col-"] > .card.border-0.h-100 {
  border-radius: 28px !important;
  border: 1px solid rgba(148,163,184,.24) !important;
  background: linear-gradient(180deg, #ffffff, #f8fafc) !important;
  box-shadow: 0 20px 48px rgba(15,23,42,.075) !important;
  overflow: hidden;
}
.row.g-3.mb-4 > [class*="col-"] > .card .card-body p {
  color: #64748b !important;
  font-weight: 850;
  text-transform: uppercase;
  letter-spacing: .06em;
  font-size: .76rem;
}
.row.g-3.mb-4 > [class*="col-"] > .card .card-body h2,
.row.g-3.mb-4 > [class*="col-"] > .card .card-body h3 {
  font-weight: 950 !important;
  letter-spacing: -.05em;
}

/* Tables get better spacing and readable action columns */
td:last-child .btn,
th:last-child { white-space: nowrap; }
.table td strong { color: #0f172a; }
.table .table-light td,
.table tr.table-light td {
  background: linear-gradient(90deg, #eff6ff, #f8fafc) !important;
  color: #1e40af !important;
  font-weight: 950 !important;
}

/* Subtle print-friendly fallback */
@media print {
  .sidebar, .topbar, .btn, .page-actions-bar, .hero-actions { display: none !important; }
  .dashboard-area { padding: 0 !important; }
  .glass-card, .card, .table-card { box-shadow: none !important; border: 1px solid #cbd5e1 !important; }
}

/* =========================================================
   FIHM EDUCATION STABLE V5 - FINAL NAVY & GOLD BRAND LAYER
   This final layer standardises colour across the existing
   v3/v4 CSS without removing working page-specific fixes.
   Keep this block at the very end of style.css.
   ========================================================= */

:root {
  --ink: #172033;
  --muted: #667085;
  --line: #d8e0eb;
  --line-strong: #bdc9da;
  --soft: #f6f8fc;

  --brand: #1e3a8a;
  --brand-dark: #172554;
  --brand-light: #dbeafe;

  --gold: #d4af37;
  --gold-dark: #b8941f;
  --gold-light: #fff7d6;

  --green: #16a34a;
  --purple: #4f46e5;
  --danger: #dc2626;

  --card: rgba(255, 255, 255, .96);
  --shadow: 0 20px 50px rgba(15, 23, 42, .10);
  --shadow-soft: 0 10px 28px rgba(15, 23, 42, .08);

  --fihm-navy: #172554;
  --fihm-blue: #1e3a8a;
  --fihm-blue-2: #2563eb;
  --fihm-gold: #d4af37;
  --fihm-gold-dark: #b8941f;
  --fihm-surface: rgba(255,255,255,.94);
  --fihm-border: rgba(148,163,184,.30);
  --fihm-shadow: 0 22px 60px rgba(15,23,42,.10);
  --fihm-shadow-hover: 0 28px 70px rgba(15,23,42,.16);
}

/* ---------- Global brand background ---------- */
body {
  color: var(--ink);
  background:
    radial-gradient(circle at 8% 4%, rgba(30, 58, 138, 0.13), transparent 28%),
    radial-gradient(circle at 95% 6%, rgba(212, 175, 55, 0.17), transparent 26%),
    linear-gradient(180deg, #f8fbff 0%, #eef4fb 100%) !important;
}

/* ---------- Sidebar brand correction ---------- */
.sidebar {
  background: linear-gradient(
    180deg,
    #172554 0%,
    #1e3a8a 58%,
    #0f172a 100%
  ) !important;
  box-shadow: 12px 0 34px rgba(15, 31, 77, 0.22);
}

.sidebar-menu .nav-link:hover,
.sidebar-menu .nav-link.active {
  background: rgba(212, 175, 55, .20) !important;
  border-color: rgba(212, 175, 55, .35) !important;
  color: #ffffff !important;
}

.sidebar-menu .nav-link:hover::before,
.sidebar-menu .nav-link.active::before {
  background: var(--gold) !important;
}

.brand-orb,
.sidebar .profile-box,
.sidebar .rounded.bg-dark {
  background: rgba(255,255,255,.13) !important;
  border: 1px solid rgba(212,175,55,.25) !important;
}

/* ---------- Topbar correction ---------- */
.topbar {
  background: linear-gradient(135deg, rgba(255,255,255,.97), rgba(248,250,252,.92)) !important;
  border: 1px solid rgba(255,255,255,.88) !important;
  box-shadow: var(--shadow-soft) !important;
}

.topbar h2,
.topbar h1 {
  color: var(--brand-dark) !important;
}

.topbar-badge {
  background: linear-gradient(135deg, #eff6ff, #fff7d6) !important;
  color: var(--brand-dark) !important;
  border: 1px solid rgba(212,175,55,.32) !important;
}

/* ---------- Hero areas ---------- */
.page-hero,
.profile-hero,
.mini-hero,
.module-hero {
  background:
    radial-gradient(circle at 86% 18%, rgba(255,255,255,.18), transparent 28%),
    linear-gradient(135deg, #1e3a8a 0%, #1d4ed8 54%, #172554 100%) !important;
  box-shadow: 0 24px 54px rgba(30,58,138,.25) !important;
}

.page-hero::after,
.profile-hero::after,
.mini-hero::after,
.module-hero::before {
  background: rgba(212, 175, 55, .22) !important;
}

/* Keep special module identity, but still within FIHM palette */
.module-hero.fees-hero {
  background: linear-gradient(135deg, #0f766e 0%, #1e3a8a 52%, #d4af37 100%) !important;
}

.module-hero.exams-hero {
  background: linear-gradient(135deg, #4f46e5 0%, #1e3a8a 52%, #06b6d4 100%) !important;
}

.module-hero.reports-hero {
  background: linear-gradient(135deg, #0f172a 0%, #1e3a8a 52%, #0f766e 100%) !important;
}

.module-hero.teacher-hero,
.parent-dashboard .page-hero,
.parent-messages-page .page-hero,
.teacher-dashboard .page-hero {
  background: linear-gradient(135deg, #1e3a8a 0%, #0f766e 58%, #172554 100%) !important;
}

.module-hero.parent-hero {
  background: linear-gradient(135deg, #1e3a8a 0%, #4f46e5 55%, #172554 100%) !important;
}

/* ---------- Cards ---------- */
.card,
.glass-card,
.elevated-card,
.table-card,
.command-card,
.module-tile,
.kpi-card,
.parent-filter-card,
.parent-message-card,
.parent-stat-card,
.info-tile,
.contact-card,
.child-card,
.parent-child-card {
  background: linear-gradient(180deg, rgba(255,255,255,.97), rgba(255,255,255,.92)) !important;
  border: 1px solid rgba(148,163,184,.30) !important;
  box-shadow: 0 18px 44px rgba(15,23,42,.08) !important;
}

.card:hover,
.glass-card:hover,
.elevated-card:hover,
.command-card:hover,
.module-tile:hover,
.info-tile:hover,
.contact-card:hover {
  box-shadow: 0 28px 70px rgba(15,23,42,.14) !important;
  border-color: rgba(212,175,55,.42) !important;
}

/* ---------- Typography ---------- */
h1, h2, h3, h4, h5,
.card-title,
.section-title,
.module-tile h4,
.command-card h4 {
  color: #0f172a;
}

.text-primary {
  color: var(--brand) !important;
}

.text-warning,
.text-gold {
  color: var(--gold-dark) !important;
}

.text-muted {
  color: #64748b !important;
}

/* ---------- Dashboard cards ---------- */
.stat-card,
.dashboard-card {
  background: linear-gradient(135deg, #1e3a8a, #172554) !important;
  color: #ffffff !important;
}

.stat-card h3,
.dashboard-card h3,
.stat-card p,
.dashboard-card p,
.stat-card .card-label,
.dashboard-card .card-label {
  color: #ffffff !important;
}

.stat-icon {
  background: rgba(212,175,55,.22) !important;
  color: #ffffff !important;
}

/* Parent cards must remain readable on white */
.parent-dashboard .dashboard-card,
.parent-messages-page .dashboard-card,
.parent-stat-card,
.parent-summary-card,
.parent-metric-card,
.stats-card,
.metric-card {
  background: #ffffff !important;
  background-image: none !important;
  color: #0f172a !important;
}

.parent-dashboard .dashboard-card h3,
.parent-dashboard .dashboard-card span,
.parent-messages-page .dashboard-card h3,
.parent-messages-page .dashboard-card span,
.parent-stat-card h3,
.parent-stat-card span,
.parent-stat-card .stat-label,
.parent-stat-card .stat-value {
  color: inherit !important;
}

/* ---------- KPI cards ---------- */
.kpi-card .kpi-icon,
.module-tile .tile-icon,
.command-card .tile-icon {
  background: linear-gradient(135deg, #1e3a8a, #d4af37) !important;
  color: #ffffff !important;
}

.kpi-card .kpi-value {
  color: #0f172a !important;
}

.kpi-card .kpi-label,
.kpi-card .kpi-note {
  color: #64748b !important;
}

/* ---------- Forms ---------- */
.form-label {
  color: #334155 !important;
  font-weight: 850 !important;
}

.form-control,
.form-select,
textarea.form-control {
  border: 1px solid #d8e0eb !important;
  background: #fbfdff !important;
  color: #172033 !important;
}

.form-control:hover,
.form-select:hover,
textarea.form-control:hover {
  border-color: rgba(30,58,138,.35) !important;
}

.form-control:focus,
.form-select:focus,
textarea.form-control:focus {
  border-color: var(--brand) !important;
  box-shadow: 0 0 0 .25rem rgba(30,58,138,.13) !important;
  background: #ffffff !important;
}

.form-section-title {
  background: linear-gradient(135deg, #eff6ff, #fff7d6) !important;
  border-color: rgba(212,175,55,.32) !important;
  color: var(--brand-dark) !important;
}

/* ---------- Buttons ---------- */
.btn-primary {
  background: linear-gradient(135deg, #1e3a8a, #172554) !important;
  border: 0 !important;
  color: #ffffff !important;
}

.btn-primary:hover {
  background: linear-gradient(135deg, #172554, #0f172a) !important;
  color: #ffffff !important;
}

.btn-warning,
.btn-secondary {
  background: linear-gradient(135deg, #d4af37, #b8941f) !important;
  border: 0 !important;
  color: #172554 !important;
}

.btn-warning:hover,
.btn-secondary:hover {
  background: linear-gradient(135deg, #b8941f, #8a6a15) !important;
  color: #ffffff !important;
}

.btn-outline-primary {
  color: var(--brand) !important;
  border-color: rgba(30,58,138,.45) !important;
}

.btn-outline-primary:hover {
  background: var(--brand) !important;
  color: #ffffff !important;
}

/* ---------- Tables ---------- */
.table thead th,
.beautiful-table thead th {
  background: linear-gradient(180deg, #172554, #1e3a8a) !important;
  color: #ffffff !important;
  border-color: rgba(255,255,255,.16) !important;
}

.table td,
.beautiful-table td {
  color: #1e293b !important;
}

.table tbody tr:nth-child(even) td,
.beautiful-table tbody tr:nth-child(even) td {
  background: #fbfdff !important;
}

.table tbody tr:hover td,
.beautiful-table tbody tr:hover td {
  background: #eff6ff !important;
}

.table .table-light td,
.table tr.table-light td {
  background: linear-gradient(90deg, #eff6ff, #fff7d6) !important;
  color: var(--brand-dark) !important;
}

/* ---------- Badges and pills ---------- */
.code-pill,
.soft-pill,
.badge.text-bg-light {
  background: #f8fafc !important;
  color: #334155 !important;
  border: 1px solid #e2e8f0 !important;
}

.status-active,
.badge.bg-success {
  background: #dcfce7 !important;
  color: #166534 !important;
}

.status-inactive,
.badge.bg-danger {
  background: #fee2e2 !important;
  color: #991b1b !important;
}

.badge.bg-primary {
  background: var(--brand) !important;
  color: #ffffff !important;
}

.badge.bg-warning {
  background: var(--gold) !important;
  color: #172554 !important;
}

/* ---------- Login page ---------- */
.login-page {
  background:
    radial-gradient(circle at 10% 15%, rgba(30,58,138,.22), transparent 28%),
    radial-gradient(circle at 86% 20%, rgba(212,175,55,.26), transparent 26%),
    linear-gradient(135deg, #eff6ff, #f8fafc 45%, #fff7d6) !important;
}

.login-left {
  background:
    radial-gradient(circle at 30% 20%, rgba(255,255,255,.18), transparent 32%),
    linear-gradient(135deg, #172554, #1e3a8a) !important;
}

.login-left::after {
  background: rgba(212,175,55,.20) !important;
}

.login-right h3,
.login-logo h1 {
  color: var(--brand-dark) !important;
}

.demo-box {
  border: 1px solid rgba(212,175,55,.32) !important;
  background: linear-gradient(180deg, #eff6ff, #fff7d6) !important;
}

/* ---------- Print ---------- */
@media print {
  body {
    background: #ffffff !important;
  }

  .sidebar,
  .topbar,
  .btn,
  .page-actions-bar,
  .hero-actions {
    display: none !important;
  }

  .dashboard-area {
    padding: 0 !important;
  }

  .glass-card,
  .card,
  .table-card,
  .kpi-card {
    box-shadow: none !important;
    border: 1px solid #cbd5e1 !important;
  }

  .table thead th,
  .beautiful-table thead th {
    background: #f1f5f9 !important;
    color: #0f172a !important;
  }
}

/* =========================================================
   FIHM EDUCATION STABLE V5 - LIBRARY MODULE POLISH
   ========================================================= */
.module-hero.library-hero {
  background: linear-gradient(135deg, #172554 0%, #1e3a8a 48%, #d4af37 100%) !important;
}
.library-hero .btn-warning {
  background: linear-gradient(135deg, #fbbf24, #d4af37) !important;
  color: #172554 !important;
}
.library-status-card {
  border-radius: 24px;
  border: 1px solid rgba(148,163,184,.25);
  background: linear-gradient(180deg, #ffffff, #f8fafc);
  box-shadow: 0 18px 44px rgba(15,23,42,.08);
}


/* =========================================================
   FIHM EDUCATION STABLE V6 - TRANSPORT MODULE POLISH
   ========================================================= */
.module-hero.transport-hero {
  background: linear-gradient(135deg, #0f766e 0%, #1d4ed8 52%, #f59e0b 100%) !important;
}
.transport-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border-radius: 999px;
  padding: 7px 11px;
  font-size: .82rem;
  font-weight: 850;
  background: #eff6ff;
  color: #1e40af;
  border: 1px solid #bfdbfe;
}


/* =========================================================
   FIHM EDUCATION STABLE V7 - HOSTEL MODULE POLISH
   ========================================================= */
.module-hero.hostel-hero {
  background: linear-gradient(135deg, #1e3a8a 0%, #0f766e 52%, #d4af37 100%) !important;
}
.module-hero.hostel-hero .btn-warning {
  background: linear-gradient(135deg, #fbbf24, #d97706) !important;
  color: #111827 !important;
}
.hostel-hero .hero-actions .btn-outline-light:hover {
  color: #1e3a8a !important;
}

/* =========================================================
   FIHM EDUCATION STABLE V8 - PAYROLL MODULE POLISH
   ========================================================= */
.module-hero.payroll-hero {
  background: linear-gradient(135deg, #0f172a 0%, #1d4ed8 48%, #d4af37 100%) !important;
}
.payroll-hero .btn-warning {
  background: linear-gradient(135deg, #fbbf24, #d4af37) !important;
  color: #172033 !important;
}


/* FIHM Stable v9 - Inventory Module Theme */
.module-hero.inventory-hero {
  background: linear-gradient(135deg, #0f766e 0%, #1d4ed8 50%, #f59e0b 100%) !important;
}
.inventory-hero .btn-outline-light { border-color: rgba(255,255,255,.7) !important; }

/* =========================================================
   FIHM EDUCATION STABLE V10 - FINAL PROFESSIONAL BRAND LAYER
   Purpose: unify the system into a calm FIHM navy/gold identity
   without changing existing layouts, routes, or backend logic.
   ========================================================= */
:root {
  --fihm-primary: #1e3a8a;
  --fihm-primary-dark: #172554;
  --fihm-gold: #d4af37;
  --fihm-gold-dark: #b8941f;
  --fihm-bg: #f8fafc;
  --fihm-surface: #ffffff;
  --fihm-text: #172033;
  --fihm-muted: #64748b;
  --fihm-border-soft: rgba(148,163,184,.30);
  --fihm-shadow-clean: 0 18px 48px rgba(15,23,42,.09);
}
body {
  color: var(--fihm-text);
  background:
    radial-gradient(circle at 8% 4%, rgba(30,58,138,.11), transparent 28%),
    radial-gradient(circle at 94% 8%, rgba(212,175,55,.15), transparent 25%),
    linear-gradient(180deg, #f8fafc 0%, #eef4fb 100%) !important;
}
.sidebar {
  background: linear-gradient(180deg, var(--fihm-primary-dark) 0%, var(--fihm-primary) 58%, #0f1f4d 100%) !important;
}
.sidebar-menu .nav-link:hover,
.sidebar-menu .nav-link.active {
  background: rgba(212,175,55,.22) !important;
  border-color: rgba(212,175,55,.34) !important;
}
.sidebar-menu .nav-link:hover::before,
.sidebar-menu .nav-link.active::before {
  background: var(--fihm-gold) !important;
}
.topbar,
.card,
.glass-card,
.elevated-card,
.table-card,
.command-card,
.module-tile,
.kpi-card,
.filter-panel,
.form-section {
  border-color: var(--fihm-border-soft) !important;
  box-shadow: var(--fihm-shadow-clean) !important;
}
.page-hero,
.profile-hero,
.mini-hero,
.module-hero {
  background: linear-gradient(135deg, var(--fihm-primary) 0%, var(--fihm-primary-dark) 58%, #0f172a 100%) !important;
}
.module-hero::before,
.page-hero::after,
.profile-hero::after,
.mini-hero::after {
  background: rgba(212,175,55,.20) !important;
}
.module-hero.library-hero,
.module-hero.transport-hero,
.module-hero.hostel-hero,
.module-hero.payroll-hero,
.module-hero.inventory-hero,
.module-hero.fees-hero,
.module-hero.exams-hero,
.module-hero.reports-hero,
.module-hero.teacher-hero,
.module-hero.parent-hero {
  background: linear-gradient(135deg, var(--fihm-primary-dark) 0%, var(--fihm-primary) 52%, var(--fihm-gold-dark) 100%) !important;
}
.btn-primary {
  background: linear-gradient(135deg, var(--fihm-primary), var(--fihm-primary-dark)) !important;
  border: 0 !important;
}
.btn-warning,
.btn-secondary {
  background: linear-gradient(135deg, #f7d774, var(--fihm-gold)) !important;
  border: 0 !important;
  color: #172033 !important;
}
.form-control:focus,
.form-select:focus,
textarea.form-control:focus {
  border-color: var(--fihm-primary) !important;
  box-shadow: 0 0 0 .25rem rgba(30,58,138,.14) !important;
}
.table thead th,
.beautiful-table thead th {
  background: linear-gradient(180deg, #f8fafc, #eef2ff) !important;
  color: var(--fihm-primary-dark) !important;
}
.kpi-card .kpi-icon,
.module-tile .tile-icon,
.command-card .tile-icon {
  background: linear-gradient(135deg, var(--fihm-primary), var(--fihm-primary-dark)) !important;
}
.badge.bg-primary,
.text-bg-primary {
  background-color: var(--fihm-primary) !important;
}
.text-primary {
  color: var(--fihm-primary) !important;
}
.parent-stat-card,
.parent-message-card,
.parent-child-card,
.child-card {
  background: #ffffff !important;
  color: #172033 !important;
}
@media print {
  body { background: #ffffff !important; }
  .sidebar, .topbar, .btn, .page-actions-bar, .hero-actions { display: none !important; }
  .dashboard-area { padding: 0 !important; }
}


/* =========================================================
   FIHM EDUCATION STABLE V11 - BRAINTECH AI ASSISTANT UI
   ========================================================= */
.module-hero.ai-hero {
  background:
    radial-gradient(circle at 88% 18%, rgba(255,255,255,.24), transparent 28%),
    linear-gradient(135deg, #0f172a 0%, #1d4ed8 48%, #7c3aed 100%) !important;
}
.ai-output-box {
  min-height: 520px;
  font-family: "Inter", "Segoe UI", Arial, sans-serif;
  line-height: 1.7;
  background: linear-gradient(180deg, #ffffff, #f8fbff) !important;
  color: #0f172a !important;
  border: 1px solid #cbd5e1 !important;
  box-shadow: inset 0 1px 8px rgba(15,23,42,.04);
}
.sidebar-menu .nav-link[href*="ai-assistant"] {
  background: rgba(251,191,36,.14);
  border: 1px solid rgba(251,191,36,.22);
}
.sidebar-menu .nav-link[href*="ai-assistant"] i {
  color: #fbbf24;
}
