
:root {
  /* Brand tokens */
  --gavy-royal: #2541ff;
  --gavy-royal-rgb: 37, 65, 255;
  --gavy-royal-dark: #1a2eb8;
  --gavy-royal-soft: #eef0ff;

  --gavy-purple: #7b3ff2;
  --gavy-purple-rgb: 123, 63, 242;
  --gavy-purple-dark: #5b25c5;
  --gavy-purple-soft: #f1eaff;

  --gavy-lime: #84cc16;
  --gavy-lime-rgb: 132, 204, 22;
  --gavy-lime-dark: #5d930a;
  --gavy-lime-soft: #ecfccb;

  --gavy-orange: #f97316;
  --gavy-orange-rgb: 249, 115, 22;
  --gavy-orange-dark: #c45508;
  --gavy-orange-soft: #ffedd5;

  --gavy-ink: #14163a;
  --gavy-muted: #6b7196;
  --gavy-surface: #ffffff;
  --gavy-canvas: #f5f6ff;

  /* Map onto Bootstrap / Sneat tokens */
  --bs-primary: var(--gavy-royal);
  --bs-primary-rgb: var(--gavy-royal-rgb);
  --bs-secondary: var(--gavy-purple);
  --bs-secondary-rgb: var(--gavy-purple-rgb);
  --bs-success: var(--gavy-lime);
  --bs-success-rgb: var(--gavy-lime-rgb);
  --bs-warning: var(--gavy-orange);
  --bs-warning-rgb: var(--gavy-orange-rgb);
  --bs-link-color: var(--gavy-royal);
  --bs-link-hover-color: var(--gavy-royal-dark);
  --bs-body-color: var(--gavy-ink);
  --bs-body-bg: var(--gavy-canvas);
  --bs-border-radius: 0.65rem;
  --bs-border-radius-lg: 1rem;
  --bs-border-radius-sm: 0.4rem;
}

[data-bs-theme="dark"] {
  --gavy-canvas: #0c0e2c;
  --gavy-surface: #161a3d;
  --gavy-ink: #e5e7ff;
  --gavy-muted: #9aa0c8;
  --bs-body-bg: var(--gavy-canvas);
  --bs-body-color: var(--gavy-ink);
}

/* ---------- Body / typography ---------- */
body {
  background: var(--gavy-canvas);
  color: var(--gavy-ink);
  font-family: "Public Sans", "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", sans-serif;
  font-size: 10.5px;


  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6 {
  color: var(--gavy-ink);
  letter-spacing: -0.01em;
}

/* ---------- Sidebar — white bg with coloured fonts & borders ---------- */
#layout-menu,
.layout-menu {
  background: #ffffff !important;
  border: 0 !important;
  border-right: 1px solid rgba(105, 108, 255, 0.14) !important;
  box-shadow: 0 1px 0 rgba(15, 23, 42, 0.04);
}

#layout-menu .app-brand,
.layout-menu .app-brand {
  border-bottom: 1px solid rgba(105, 108, 255, 0.10);
}
#layout-menu .app-brand-text,
.layout-menu .app-brand-text {
  color: #1e293b !important;
  font-weight: 800 !important;
  letter-spacing: 0.01em;
  background: linear-gradient(135deg, #2541ff, #7b3ff2);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* ─────────────────────────────────────────────────────────────────────
   Sidebar typography — restored to Sneat theme defaults (14 px rows,
   comfortable spacing). Brand colour (white bg + purple accents) is
   preserved; only the compact-mode overrides are removed.
   ───────────────────────────────────────────────────────────────────── */
.menu-vertical .menu-link,
.layout-menu .menu-link {
  color: #566a7f;
  border-radius: 0.375rem;
  margin: 0.0625rem 0.75rem;
  padding: 0.5rem 0.875rem;
  border: 1px solid transparent;
  font-size: 11px;
  line-height: 1.47;
  letter-spacing: normal;
  transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

.menu-vertical .menu-link .text-truncate,
.layout-menu .menu-link .text-truncate {
  font-size: inherit;
  line-height: inherit;
}

.menu-vertical .menu-link:hover,
.layout-menu .menu-link:hover {
  background: rgba(105, 108, 255, 0.08);
  color: #2541ff;
  border-color: rgba(105, 108, 255, 0.22);
}
.menu-vertical .menu-link:hover .menu-icon,
.layout-menu .menu-link:hover .menu-icon {
  color: #2541ff;
}

.menu-vertical .menu-item.active > .menu-link,
.layout-menu .menu-item.active > .menu-link {
  background: rgba(105, 108, 255, 0.12);
  color: #2541ff;
  font-weight: 600;
  border-color: rgba(105, 108, 255, 0.32);
  box-shadow: 0 2px 6px rgba(105, 108, 255, 0.08);
}
.menu-vertical .menu-item.active > .menu-link .menu-icon,
.layout-menu .menu-item.active > .menu-link .menu-icon {
  color: #2541ff;
}

/* Coloured left rail on the active item — 3px to match Sneat's default rhythm */
.menu-vertical .menu-item.active > .menu-link::before {
  content: "";
  position: absolute;
  left: -0.75rem;
  top: 0.4rem;
  bottom: 0.4rem;
  width: 3px;
  border-radius: 0 3px 3px 0;
  background: linear-gradient(180deg, #2541ff, #7b3ff2);
}

.menu-vertical .menu-icon,
.layout-menu .menu-icon {
  color: #677788;
  font-size: 1.125rem;
  width: 1.375rem;
  height: 1.375rem;
  margin-right: 0.5rem;
  transition: color 0.15s ease;
}
.menu-vertical .menu-toggle::after,
.layout-menu .menu-toggle::after {
  font-size: 0.875rem;
}

/* Section headers — Sneat's default uppercase small caps */
.menu-header-text,
.menu-vertical .menu-header {
  color: #a1acb8;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding-top: 0.875rem;
  padding-bottom: 0.5rem;
  position: relative;
  line-height: 1.4;
}
.menu-vertical .menu-header::before {
  content: "";
  display: block;
  height: 1px;
  background: linear-gradient(90deg, rgba(105, 108, 255, 0.18), transparent 60%);
  margin: 0 10px 0.225rem;
}
.menu-vertical .menu-header::before {
  content: "";
  display: block;
  height: 1px;
  background: linear-gradient(90deg, rgba(105, 108, 255, 0.18), transparent 60%);
  margin: 0 0.875rem 0.5rem;
}

/* Submenu items — slightly smaller than top-level rows, Sneat default size */
.menu-vertical .menu-sub .menu-link,
.layout-menu .menu-sub .menu-link {
  padding: 0.4rem 0.875rem;
  font-size: 0.8125rem;
}

/* Don't put a divider above the very first menu-header */
.menu-vertical .menu-inner > .menu-header:first-child::before { display: none; }

/* Logout (text-danger inside menu-link) — keep red but with hover red tint */
.menu-vertical .menu-link.text-danger:hover,
.layout-menu .menu-link.text-danger:hover {
  background: rgba(239, 68, 68, 0.08) !important;
  color: #dc2626 !important;
  border-color: rgba(239, 68, 68, 0.30) !important;
}
.menu-vertical .menu-link.text-danger:hover .menu-icon,
.layout-menu .menu-link.text-danger:hover .menu-icon {
  color: #dc2626 !important;
}

/* Identity strip card — adjust to read on white bg */
.aside-identity > div {
  background: rgba(105, 108, 255, 0.06) !important;
  border-color: rgba(105, 108, 255, 0.18) !important;
  color: #1e293b;
}
.aside-identity .text-truncate.fw-semibold { color: #1e293b !important; }
.aside-identity .text-truncate:not(.fw-semibold) { color: #64748b !important; opacity: 1 !important; }

/* Mobile drawer optimisation (≤ 1199.98px = below xl, when the drawer slides in) */
@media (max-width: 1199.98px) {
  #layout-menu,
  .layout-menu {
    width: 260px !important;
    max-width: 82vw;
    box-shadow: 0 24px 48px rgba(15, 23, 42, 0.18) !important;
    transition: transform 0.28s cubic-bezier(0.22, 1, 0.36, 1) !important;
  }
}

/* ─── Phone slim scrollbar — visual polish only, no size overrides ─────── */
@media (max-width: 575.98px) {
  #layout-menu .menu-inner,
  .layout-menu .menu-inner { scrollbar-width: thin; }
  #layout-menu .menu-inner::-webkit-scrollbar,
  .layout-menu .menu-inner::-webkit-scrollbar { width: 4px; }
  #layout-menu .menu-inner::-webkit-scrollbar-thumb,
  .layout-menu .menu-inner::-webkit-scrollbar-thumb {
    background: rgba(105, 108, 255, 0.22);
    border-radius: 2px;
  }
}

/* ---------- Topbar / navbar ---------- */
.layout-navbar,
.navbar-detached {
  background: var(--gavy-surface) !important;
  border-radius: var(--bs-border-radius-lg) !important;
  box-shadow: 0 8px 24px rgba(20, 22, 58, 0.06) !important;
  border: 1px solid rgba(20, 22, 58, 0.04);
}

.navbar .navbar-search-wrapper input {
  background: var(--gavy-canvas);
  border-radius: 999px;
}

/* ---------- Cards ---------- */
.card,
.card.card-action {
  border: 1px solid rgba(20, 22, 58, 0.05);
  border-radius: var(--bs-border-radius-lg);
  box-shadow: 0 4px 18px rgba(20, 22, 58, 0.05);
  background: var(--gavy-surface);
}

.card:hover { box-shadow: 0 12px 28px rgba(20, 22, 58, 0.08); }

.card-header { border-bottom: 1px solid rgba(20, 22, 58, 0.05); padding: 1.1rem 1.35rem; }
.card-body  { padding: 1.25rem 1.35rem; }

/* Stat card variant */
.gavy-stat {
  position: relative;
  overflow: hidden;
  border-radius: var(--bs-border-radius-lg);
  padding: 1.25rem 1.35rem;
  color: #fff;
}
.gavy-stat .stat-label { opacity: 0.85; font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.14em; }
.gavy-stat .stat-value { font-size: 1.85rem; font-weight: 700; line-height: 1.05; margin-top: 0.35rem; }
.gavy-stat .stat-trend { font-size: 0.78rem; margin-top: 0.4rem; opacity: 0.95; }
.gavy-stat .stat-icon  { position: absolute; right: 0.9rem; top: 0.9rem; font-size: 2.1rem; opacity: 0.25; }
.gavy-stat--royal  { background: linear-gradient(135deg, var(--gavy-royal) 0%, #4a64ff 100%); }
.gavy-stat--purple { background: linear-gradient(135deg, var(--gavy-purple) 0%, #9764ff 100%); }
.gavy-stat--lime   { background: linear-gradient(135deg, var(--gavy-lime) 0%, #a3e635 100%); color: #1a2e05; }
.gavy-stat--orange { background: linear-gradient(135deg, var(--gavy-orange) 0%, #fb923c 100%); }

/* ---------- Buttons ---------- */
.btn-primary {
  background: var(--gavy-royal);
  border-color: var(--gavy-royal);
  box-shadow: 0 6px 14px rgba(var(--gavy-royal-rgb), 0.28);
}
.btn-primary:hover, .btn-primary:focus { background: var(--gavy-royal-dark); border-color: var(--gavy-royal-dark); }

.btn-secondary {
  background: var(--gavy-purple);
  border-color: var(--gavy-purple);
  color: #fff;
}
.btn-secondary:hover, .btn-secondary:focus { background: var(--gavy-purple-dark); border-color: var(--gavy-purple-dark); color: #fff; }

.btn-success { background: var(--gavy-lime); border-color: var(--gavy-lime); color: #1a2e05; }
.btn-warning { background: var(--gavy-orange); border-color: var(--gavy-orange); color: #fff; }

.btn-outline-primary { color: var(--gavy-royal); border-color: var(--gavy-royal); }
.btn-outline-primary:hover { background: var(--gavy-royal); color: #fff; }

/* Soft / label buttons */
.btn-label-primary, .bg-label-primary { background: var(--gavy-royal-soft) !important; color: var(--gavy-royal) !important; border: none; }
.btn-label-secondary, .bg-label-secondary { background: var(--gavy-purple-soft) !important; color: var(--gavy-purple-dark) !important; border: none; }
.btn-label-success, .bg-label-success { background: var(--gavy-lime-soft) !important; color: var(--gavy-lime-dark) !important; border: none; }
.btn-label-warning, .bg-label-warning { background: var(--gavy-orange-soft) !important; color: var(--gavy-orange-dark) !important; border: none; }

/* ---------- Badges ---------- */
.badge.bg-primary { background: var(--gavy-royal) !important; }
.badge.bg-secondary { background: var(--gavy-purple) !important; }
.badge.bg-success { background: var(--gavy-lime) !important; color: #1a2e05; }
.badge.bg-warning { background: var(--gavy-orange) !important; color: #fff; }

/* ---------- Forms ---------- */
.form-control, .form-select {
  border-radius: var(--bs-border-radius);
  border-color: rgba(20, 22, 58, 0.12);
  padding: 0.55rem 0.85rem;
  font-size: 0.95rem;
}
.form-control:focus, .form-select:focus {
  border-color: var(--gavy-royal);
  box-shadow: 0 0 0 0.18rem rgba(var(--gavy-royal-rgb), 0.18);
}

/* ---------- Tables ---------- */
.table {
  --bs-table-bg: var(--gavy-surface);
  --bs-table-border-color: rgba(20, 22, 58, 0.06);
}
.table > thead {
  background: var(--gavy-canvas);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 0.74rem;
  color: var(--gavy-muted);
}
.table > tbody > tr:hover { background: rgba(var(--gavy-royal-rgb), 0.04); }

/* ---------- Page header ---------- */
.gavy-pageheader {
  display: flex; flex-direction: column; gap: 0.35rem;
  padding: 0.75rem 0 1.25rem;
}
.gavy-pageheader__eyebrow { color: var(--gavy-purple); font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.18em; font-weight: 700; }
.gavy-pageheader__title { font-size: 1.6rem; font-weight: 700; color: var(--gavy-ink); margin: 0; line-height: 1.15; }
.gavy-pageheader__subtitle { color: var(--gavy-muted); font-size: 0.95rem; margin: 0; }
.gavy-pageheader__actions { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-top: 0.5rem; }

/* ---------- Mobile-first responsive ---------- */
@media (max-width: 767.98px) {
  .layout-navbar, .navbar-detached {
    border-radius: 0 !important;
    margin: 0 !important;
  }
  .container-p-y { padding-top: 1rem !important; padding-bottom: 5.5rem !important; }
  .gavy-pageheader { padding: 0.25rem 0 0.85rem; }
  .gavy-pageheader__title { font-size: 1.25rem; }
  .gavy-pageheader__subtitle { font-size: 0.88rem; }
  .gavy-pageheader__actions .btn { flex: 1 1 calc(50% - 0.5rem); }
  .card-body, .card-header { padding: 0.95rem 1rem; }
  .gavy-stat .stat-value { font-size: 1.45rem; }
  .table-responsive { border-radius: var(--bs-border-radius); }

  /* Mobile bottom tab bar */
  .gavy-tabbar {
    position: fixed;
    left: 0; right: 0; bottom: 0;
    z-index: 1040;
    display: grid;
    grid-template-columns: repeat(var(--gavy-tabbar-cols, 4), 1fr);
    gap: 0;
    background: var(--gavy-surface);
    border-top: 1px solid rgba(20, 22, 58, 0.08);
    box-shadow: 0 -8px 24px rgba(20, 22, 58, 0.08);
    padding: 0.35rem max(0.5rem, env(safe-area-inset-left)) calc(0.45rem + env(safe-area-inset-bottom));
  }
  .gavy-tabbar a {
    display: grid; place-items: center; gap: 2px;
    padding: 0.3rem 0.2rem;
    color: var(--gavy-muted);
    font-size: 0.66rem;
    text-decoration: none;
    border-radius: 0.6rem;
    text-align: center;
    line-height: 1;
  }
  .gavy-tabbar a i { font-size: 1.25rem; }
  .gavy-tabbar a.active { color: var(--gavy-royal); background: var(--gavy-royal-soft); font-weight: 600; }
}

@media (min-width: 768px) {
  .gavy-tabbar { display: none; }
}

/* Sticky safe top on iOS */
@supports (padding-top: env(safe-area-inset-top)) {
  body { padding-top: env(safe-area-inset-top); }
}

/* ---------- Tenant theme bridge (per-school override) ---------- */
body[data-tenant-theme="1"] {
  --gavy-royal: var(--theme-primary, #2541ff);
  --gavy-purple: var(--theme-secondary, #7b3ff2);
}

/* ---------- Misc utilities ---------- */
.gavy-divider { height: 1px; background: rgba(20, 22, 58, 0.07); margin: 1rem 0; }
.text-purple { color: var(--gavy-purple) !important; }
.text-royal { color: var(--gavy-royal) !important; }
.text-lime { color: var(--gavy-lime-dark) !important; }
.text-orange { color: var(--gavy-orange-dark) !important; }
.bg-royal { background: var(--gavy-royal) !important; color: #fff; }
.bg-purple { background: var(--gavy-purple) !important; color: #fff; }
.bg-lime { background: var(--gavy-lime) !important; color: #1a2e05; }
.bg-orange { background: var(--gavy-orange) !important; color: #fff; }
