/* =====================================================================
   XOX Wallet Training LMS — Brand-aligned stylesheet
   Source of truth: XOX Wallet Branding Identity Guidelines (231012)
   Laravel: Montserrat via Google Fonts (local @font-face paths removed).
   ===================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@300;500;700&display=swap');

/* ---------- 2. Tokens ------------------------------------------------- */
:root {
  --xox-red:        #EA0029;
  --xox-navy:       #26225E;
  --xox-white:      #FFFFFF;
  --xox-black:      #000000;

  --xox-ink:        #1B1B1B;
  --xox-ink-2:      #4A4A4A;
  --xox-ink-3:      #8A8A8A;
  --xox-line:       #E6E6EA;
  --xox-surface:    #F6F6F8;
  --xox-surface-2:  #FAFAFB;

  /* Functional colours — use ONLY for status / iconography */
  --func-success:   #16A34A;
  --func-warning:   #F59E0B;
  --func-danger:    #DC2626;
  --func-info:      #26225E;

  /* Legacy Bootstrap shims map to brand */
  --primary-color:   var(--xox-navy);
  --secondary-color: var(--xox-ink-3);
  --success-color:   var(--func-success);
  --danger-color:    var(--func-danger);
  --warning-color:   var(--func-warning);
  --info-color:      var(--xox-navy);
  --light-color:     var(--xox-surface);
  --dark-color:      var(--xox-navy);

  --font-sans: "Montserrat", "Helvetica Neue", Arial, sans-serif;

  --r-sm: 8px; --r-md: 12px; --r-lg: 16px; --r-xl: 24px; --r-pill: 9999px;

  --shadow-sm: 0 1px 2px rgba(38, 34, 94, 0.08);
  --shadow-md: 0 4px 12px rgba(38, 34, 94, 0.10);
  --shadow-lg: 0 12px 32px rgba(38, 34, 94, 0.14);
  --shadow-cta-red:  0 6px 18px rgba(234, 0, 41, 0.30);
  --shadow-cta-navy: 0 6px 18px rgba(38, 34, 94, 0.30);

  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
}

/* ---------- 3. Reset / base ----------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  font-family: var(--font-sans);
  font-weight: 300;
  font-size: 14px;
  line-height: 1.55;
  color: var(--xox-ink);
  background: var(--xox-surface-2);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

a { color: var(--xox-red); text-decoration: none; font-weight: 500; transition: color .2s var(--ease-out); }
a:hover { color: var(--xox-navy); text-decoration: none; }

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-sans);
  font-weight: 700;
  color: var(--xox-navy);
  letter-spacing: -0.015em;
  line-height: 1.15;
  margin: 0 0 .75rem;
  text-wrap: balance;
}
h1 { font-size: 2rem; }
h2 { font-size: 1.5rem; }
h3 { font-size: 1.25rem; }
h4 { font-size: 1.125rem; }
h5 { font-size: 1rem; }
h6 { font-size: .875rem; }

p { margin: 0 0 1rem; text-wrap: pretty; }
strong, b { font-weight: 500; }
small { font-size: .8125rem; color: var(--xox-ink-2); }
hr { border: 0; border-top: 1px solid var(--xox-line); margin: 1rem 0; }

main { min-height: calc(100vh - 200px); }

/* ---------- 4. Layout helpers (Bootstrap-compatible) ---------------- */
.container, .container-fluid {
  width: 100%; max-width: 1200px; margin: 0 auto; padding: 0 24px;
}
.container-fluid { max-width: 1320px; }

.row { display: flex; flex-wrap: wrap; margin-left: -12px; margin-right: -12px; }
.row > * { padding-left: 12px; padding-right: 12px; width: 100%; }
.col, .col-12 { flex: 1 0 0%; }
.col-md-1 { flex: 0 0 8.333333%; max-width: 8.333333%; }
.col-md-2 { flex: 0 0 16.666667%; max-width: 16.666667%; }
.col-md-3 { flex: 0 0 25%; max-width: 25%; }
.col-md-4 { flex: 0 0 33.333333%; max-width: 33.333333%; }
.col-md-6 { flex: 0 0 50%; max-width: 50%; }
.col-md-8 { flex: 0 0 66.666667%; max-width: 66.666667%; }
.col-lg-4 { flex: 0 0 33.333333%; max-width: 33.333333%; }

.d-flex { display: flex; }
.justify-content-center  { justify-content: center; }
.justify-content-between { justify-content: space-between; }
.justify-content-end     { justify-content: flex-end; }
.align-items-center      { align-items: center; }
.align-items-end         { align-items: flex-end; }
.flex-grow-1             { flex: 1 1 auto; }
.gap-2 { gap: .5rem; } .gap-3 { gap: 1rem; }

.text-center { text-align: center; }
.text-end    { text-align: right; }
.text-muted  { color: var(--xox-ink-3) !important; }
.text-success{ color: var(--func-success) !important; }
.text-danger { color: var(--func-danger)  !important; }
.text-warning{ color: var(--func-warning) !important; }
.text-white  { color: #fff !important; }
.text-primary{ color: var(--xox-navy) !important; }
.fw-bold     { font-weight: 700; }
.fw-medium   { font-weight: 500; }

.bg-primary  { background: var(--xox-navy)    !important; color: #fff; }
.bg-info     { background: var(--xox-navy)    !important; color: #fff; }
.bg-warning  { background: #F59E0B            !important; color: #fff; }
.bg-success  { background: var(--func-success)!important; color: #fff; }
.bg-danger   { background: var(--xox-red)     !important; color: #fff; }
.bg-secondary{ background: var(--xox-ink-3)   !important; color: #fff; }
.bg-light    { background: var(--xox-surface) !important; }

.py-3 { padding-top: 1rem;  padding-bottom: 1rem; }
.py-4 { padding-top: 1.5rem;padding-bottom: 1.5rem; }
.py-5 { padding-top: 3rem;  padding-bottom: 3rem; }
.p-3  { padding: 1rem; } .p-4 { padding: 1.5rem; }
.mt-3 { margin-top: 1rem; } .mt-4 { margin-top: 1.5rem; } .mt-5 { margin-top: 3rem; }
.mb-0 { margin-bottom: 0; } .mb-2 { margin-bottom: .5rem; }
.mb-3 { margin-bottom: 1rem; } .mb-4 { margin-bottom: 1.5rem; }
.me-2 { margin-right: .5rem; }
.float-end { float: right; }
.w-100 { width: 100%; }

/* ---------- 5. Top navigation --------------------------------------- */
.navbar {
  display: flex; align-items: center;
  background: #fff;
  border-bottom: 1px solid var(--xox-line);
  min-height: 72px;
  padding: 0 32px;
  position: sticky; top: 0; z-index: 50;
  box-shadow: 0 1px 0 rgba(38, 34, 94, .03);
}
.navbar.navbar-dark, .navbar.bg-primary { /* override Bootstrap dark nav */
  background: #fff !important;
  color: var(--xox-ink) !important;
}
.navbar .container-fluid { display: flex; align-items: center; gap: 1.5rem; padding: 0; max-width: 1320px; }

.navbar-brand {
  display: inline-flex !important; align-items: center; gap: 12px;
  color: var(--xox-navy) !important;
  font-weight: 700; font-size: 15px; letter-spacing: -.01em;
  margin-right: 1rem;
}
.navbar-brand .xox-brand-logo {
  width: 38px; height: 38px; border-radius: 10px;
  object-fit: contain;
  flex-shrink: 0;
  background: #fff;
  padding: 4px;
}
.navbar-brand .fa-graduation-cap { display: none; } /* hide legacy icon */

.navbar-nav { list-style: none; display: flex; align-items: center; gap: 4px; margin: 0; padding: 0; }
.navbar-nav.me-auto { margin-right: auto; }
.nav-item { position: relative; }
.nav-link {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 14px;
  border-radius: 9999px;
  color: var(--xox-ink) !important;
  font-weight: 500; font-size: 14px;
  transition: background .2s var(--ease-out), color .2s var(--ease-out);
}
.nav-link:hover { background: var(--xox-surface); color: var(--xox-navy) !important; text-decoration: none; }
.nav-link.active, .nav-item.active .nav-link {
  background: var(--xox-navy); color: #fff !important;
}

.dropdown-menu {
  position: absolute; right: 0; top: 100%;
  display: none; min-width: 220px;
  margin-top: 8px; padding: 6px;
  background: #fff; border: 1px solid var(--xox-line);
  border-radius: 14px; box-shadow: var(--shadow-md);
  list-style: none;
  z-index: 1000;
}
.dropdown:hover .dropdown-menu, .dropdown:focus-within .dropdown-menu { display: block; }
.dropdown-toggle::after { content: "▾"; margin-left: 6px; font-size: 10px; opacity: .6; }
.dropdown-item {
  display: block; padding: 8px 12px; border-radius: 9px;
  color: var(--xox-ink); font-size: 13px; font-weight: 400;
}
.dropdown-item:hover { background: var(--xox-surface); color: var(--xox-navy); text-decoration: none; }
.dropdown-divider { border: 0; border-top: 1px solid var(--xox-line); margin: 6px 4px; }

.navbar-toggler {
  display: none;
  border: 1px solid var(--xox-line); background: #fff;
  border-radius: 10px; padding: 6px 10px; cursor: pointer;
}
.navbar-toggler-icon {
  display: inline-block; width: 18px; height: 14px;
  border-top: 2px solid var(--xox-navy);
  border-bottom: 2px solid var(--xox-navy); position: relative;
}
.navbar-toggler-icon::before {
  content: ""; position: absolute; left: 0; right: 0; top: 4px;
  border-top: 2px solid var(--xox-navy);
}

/* ---------- 6. Buttons (pill-shaped, brand colours) ----------------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 12px 20px;
  border-radius: 9999px;
  border: 1px solid transparent;
  font-family: var(--font-sans);
  font-size: 13px; font-weight: 500; letter-spacing: .04em;
  line-height: 1.2;
  cursor: pointer; text-decoration: none;
  transition: transform .2s var(--ease-out), box-shadow .2s var(--ease-out), background .2s var(--ease-out), color .2s var(--ease-out);
  white-space: nowrap;
}
.btn:hover { transform: translateY(-1px); text-decoration: none; }
.btn:active { transform: translateY(0); }

.btn-sm  { padding: 8px 14px; font-size: 12px; }
.btn-lg  { padding: 14px 28px; font-size: 14px; }

.btn-primary { background: var(--xox-navy); color: #fff; box-shadow: var(--shadow-cta-navy); }
.btn-primary:hover { color: #fff; }
.btn-danger  { background: var(--xox-red); color: #fff; box-shadow: var(--shadow-cta-red); }
.btn-danger:hover  { color: #fff; }
.btn-success { background: var(--func-success); color: #fff; }
.btn-warning { background: #F59E0B; color: #fff; }
.btn-info    { background: var(--xox-navy); color: #fff; }
.btn-secondary { background: #fff; color: var(--xox-navy); border-color: var(--xox-line); }
.btn-secondary:hover { background: var(--xox-surface); color: var(--xox-navy); }
.btn-outline-primary { background: #fff; color: var(--xox-navy); border-color: var(--xox-line); }
.btn-outline-primary:hover { background: var(--xox-surface); color: var(--xox-navy); }
.btn-outline-danger  { background: #fff; color: var(--xox-red);  border-color: rgba(234,0,41,.30); }
.btn-outline-danger:hover  { background: rgba(234,0,41,.06); color: var(--xox-red); }
.btn-outline-success { background: #fff; color: var(--func-success); border-color: rgba(22,163,74,.30); }

.btn-close {
  background: transparent; border: 0; padding: 4px 8px;
  font-size: 18px; line-height: 1; color: var(--xox-ink-2); cursor: pointer;
}
.btn-close::before { content: "×"; }

/* ---------- 7. Cards ------------------------------------------------- */
.card {
  background: #fff;
  border: 1px solid var(--xox-line);
  border-radius: 16px;
  box-shadow: var(--shadow-sm);
  margin-bottom: 1.5rem;
  overflow: hidden;
  transition: box-shadow .2s var(--ease-out);
}
.card:hover { box-shadow: var(--shadow-md); }
.card-body { padding: 22px 24px; }
.card-header {
  padding: 18px 24px;
  background: #fff;
  border-bottom: 1px solid var(--xox-line);
  font-weight: 700; color: var(--xox-navy); font-size: 15px;
}
.card-header h5, .card-header .h5 { margin: 0; color: inherit; font-size: 15px; font-weight: 700; }
.card-title { margin: 0 0 .5rem; font-size: 14px; font-weight: 500; color: var(--xox-navy); }

/* Dark-coloured stat cards (keeps Bootstrap markup but recolours) */
.card.text-white { color: #fff !important; border: 0; }
.card.text-white .card-title { color: rgba(255,255,255,.85); font-weight: 500; font-size: 12px; letter-spacing: .06em; text-transform: uppercase; }
.card.text-white h2 { color: #fff; font-size: 36px; font-weight: 700; margin: 4px 0 0; letter-spacing: -.02em; }
.card.text-white small { color: rgba(255,255,255,.85); }
.card.text-white.bg-primary { background: var(--xox-navy) !important; box-shadow: var(--shadow-md); position: relative; overflow: hidden; }
.card.text-white.bg-primary::after,
.card.text-white.bg-warning::after,
.card.text-white.bg-danger::after,
.card.text-white.bg-success::after {
  /* signature mountain-curve flourish on stat cards */
  content: "";
  position: absolute; right: -40px; bottom: -40px;
  width: 180px; height: 110px; opacity: .85;
  background: var(--xox-red);
  border-radius: 50% 50% 0 0 / 100% 100% 0 0;
  pointer-events: none;
}
.card.text-white.bg-warning::after { background: rgba(255,255,255,.18); }
.card.text-white.bg-danger::after  { background: var(--xox-navy); opacity: .7; }
.card.text-white.bg-success::after { background: var(--xox-navy); opacity: .55; }
.card.text-white > * { position: relative; z-index: 1; }
.card.text-white.bg-warning { background: var(--xox-navy) !important; }
.card.text-white.bg-warning .card-title { color: #FFD080; }
.card.text-white.bg-danger  { background: var(--xox-red)  !important; box-shadow: var(--shadow-cta-red); }
.card.text-white.bg-success { background: var(--xox-navy) !important; }
.card.text-white.bg-success .card-title { color: #B7F0C5; }
.card.text-white.bg-info    { background: var(--xox-navy) !important; }

.shadow-sm { box-shadow: var(--shadow-sm) !important; }

/* ---------- 8. Forms ------------------------------------------------- */
.form-group { margin-bottom: 1rem; }
.form-label {
  display: block; margin-bottom: 6px;
  font-size: 12px; font-weight: 500;
  color: var(--xox-navy);
  letter-spacing: .04em; text-transform: uppercase;
}
.form-control, .form-select {
  display: block; width: 100%;
  padding: 12px 14px;
  font-family: var(--font-sans); font-size: 14px; font-weight: 400;
  color: var(--xox-ink);
  background: #fff;
  border: 1px solid var(--xox-line);
  border-radius: 12px;
  transition: border .2s var(--ease-out), box-shadow .2s var(--ease-out);
}
.form-control:focus, .form-select:focus {
  outline: none; border-color: var(--xox-navy);
  box-shadow: 0 0 0 4px rgba(38, 34, 94, .12);
}
.form-select { appearance: auto; }
.input-group { display: flex; align-items: stretch; width: 100%; }
.input-group .form-control { border-radius: 0; }
.input-group .form-control:first-child { border-top-left-radius: 12px; border-bottom-left-radius: 12px; }
.input-group .form-control:last-child { border-top-right-radius: 12px; border-bottom-right-radius: 12px; }
.input-group-text {
  display: flex; align-items: center; padding: 12px 14px;
  background: var(--xox-surface); border: 1px solid var(--xox-line); color: var(--xox-ink-2);
}

/* ---------- 9. Tables ----------------------------------------------- */
.table-responsive { width: 100%; overflow-x: auto; }
.table {
  width: 100%; border-collapse: collapse; margin: 0;
  font-size: 13px;
}
.table th, .table td {
  padding: 14px 16px; vertical-align: middle; text-align: left;
  border-bottom: 1px solid var(--xox-line);
}
.table thead th {
  background: var(--xox-surface);
  color: var(--xox-ink-3);
  font-weight: 500; font-size: 11px;
  letter-spacing: .06em; text-transform: uppercase;
  border-bottom: 1px solid var(--xox-line);
}
.table tbody tr { transition: background .15s var(--ease-out); }
.table-striped tbody tr:nth-child(odd) { background: var(--xox-surface-2); }
.table-hover tbody tr:hover { background: rgba(38, 34, 94, .03); }
.table-warning  { background: rgba(245, 158, 11, .08) !important; }
.table-danger   { background: rgba(234, 0, 41, .06) !important; }
.table-sm th, .table-sm td { padding: 10px 12px; }

/* Data table (legacy) */
.data-table { width: 100%; border-collapse: collapse; background: #fff; }
.data-table th { background: var(--xox-surface); padding: 12px; text-align: left; font-weight: 500; color: var(--xox-navy); border-bottom: 1px solid var(--xox-line); }
.data-table td { padding: 12px; border-bottom: 1px solid var(--xox-line); }
.data-table tr:hover { background: var(--xox-surface-2); }

/* ---------- 10. Badges & status pills ------------------------------- */
.badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 12px; border-radius: 9999px;
  font-size: 11px; font-weight: 500; letter-spacing: .02em;
  white-space: nowrap;
}
.badge.bg-primary  { background: rgba(38, 34, 94, .10) !important; color: var(--xox-navy) !important; }
.badge.bg-info     { background: rgba(38, 34, 94, .10) !important; color: var(--xox-navy) !important; }
.badge.bg-success  { background: rgba(22,163,74,.10)  !important; color: #15803d !important; }
.badge.bg-warning  { background: rgba(245,158,11,.14) !important; color: #B45309 !important; }
.badge.bg-danger   { background: rgba(234,0,41,.10)   !important; color: var(--xox-red) !important; }
.badge.bg-secondary{ background: var(--xox-surface)   !important; color: var(--xox-ink-2) !important; }

.status-badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 12px; border-radius: 9999px;
  font-size: 11px; font-weight: 500;
}
.status-not-started { background: var(--xox-surface); color: var(--xox-ink-2); }
.status-in-progress { background: rgba(38, 34, 94, .10); color: var(--xox-navy); }
.status-completed   { background: rgba(22, 163, 74, .10); color: #15803d; }
.status-failed      { background: rgba(234, 0, 41, .10); color: var(--xox-red); }
.status-overdue     { background: var(--xox-red); color: #fff; }

/* ---------- 11. Alerts ---------------------------------------------- */
.alert {
  position: relative;
  padding: 16px 18px 16px 56px;
  margin-bottom: 1rem;
  border-radius: 14px;
  border: 1px solid transparent;
  font-size: 13px; line-height: 1.5;
}
.alert::before {
  position: absolute; left: 18px; top: 50%; transform: translateY(-50%);
  width: 24px; height: 24px;
  display: grid; place-items: center;
  border-radius: 9999px;
  font-size: 14px; font-weight: 700;
}
.alert-success { background: rgba(22,163,74,.06); border-color: rgba(22,163,74,.20); color: #15803d; }
.alert-success::before { content: "✓"; background: rgba(22,163,74,.15); color: #15803d; }
.alert-info    { background: rgba(38,34,94,.05);  border-color: rgba(38,34,94,.18);  color: var(--xox-navy); }
.alert-info::before    { content: "i"; background: rgba(38,34,94,.12); color: var(--xox-navy); font-style: italic; }
.alert-warning { background: rgba(245,158,11,.08); border-color: rgba(245,158,11,.25); color: #B45309; }
.alert-warning::before { content: "!"; background: rgba(245,158,11,.18); color: #B45309; }
.alert-danger  { background: rgba(234,0,41,.06); border-color: rgba(234,0,41,.22); color: var(--xox-red); }
.alert-danger::before  { content: "!"; background: rgba(234,0,41,.14); color: var(--xox-red); }
.alert-heading { color: inherit; font-weight: 700; margin: 0 0 6px; font-size: 14px; }
.alert-permanent { padding-right: 18px; }
.alert-dismissible { padding-right: 48px; }
.alert-dismissible .btn-close { position: absolute; right: 14px; top: 14px; }

/* Pulse — kept for overdue indicators, but soft */
@keyframes pulse {
  0%, 100% { opacity: 1; }
  50%      { opacity: .8; }
}

/* ---------- 12. Lists / pagination ---------------------------------- */
.list-group { display: flex; flex-direction: column; padding: 0; margin: 0; list-style: none; }
.list-group-item {
  display: block; padding: 14px 18px;
  border-bottom: 1px solid var(--xox-line);
  background: #fff; color: var(--xox-ink);
}
.list-group-item-action:hover { background: var(--xox-surface-2); text-decoration: none; }

.pagination { display: flex; gap: 6px; list-style: none; padding: 0; margin: 1.5rem 0 0; }
.page-link {
  display: inline-grid; place-items: center;
  min-width: 36px; height: 36px; padding: 0 10px;
  border: 1px solid var(--xox-line); border-radius: 9999px;
  background: #fff; color: var(--xox-ink);
  font-size: 13px; font-weight: 500;
  text-decoration: none;
}
.page-link:hover { background: var(--xox-surface); color: var(--xox-navy); }
.page-item.active .page-link { background: var(--xox-navy); color: #fff; border-color: var(--xox-navy); }
.page-item.disabled .page-link { color: var(--xox-ink-3); pointer-events: none; }

/* ---------- 13. Footer ---------------------------------------------- */
.site-footer, footer.site-footer-brand {
  background: #fff;
  border-top: 1px solid var(--xox-line);
  color: var(--xox-ink-2);
  padding: 28px 0;
  margin-top: 48px;
  font-size: 12px;
}
.site-footer p { margin: 0; }
.site-footer .footer-tagline {
  font-weight: 500; color: var(--xox-navy);
  letter-spacing: .08em; text-transform: uppercase; font-size: 11px;
}
.site-footer .footer-meta { color: var(--xox-ink-3); }

/* ---------- 14. Login chrome ---------------------------------------- */
.xox-login-shell {
  min-height: calc(100vh - 0px);
  display: grid; grid-template-columns: 1.1fr 1fr;
  background: #fff;
}
.xox-login-shell .login-brand {
  position: relative; overflow: hidden;
  background: var(--xox-navy); color: #fff;
  padding: 56px;
  display: flex; flex-direction: column; justify-content: space-between;
}
.xox-login-shell .login-brand::before {
  content: ""; position: absolute; left: -10%; right: -10%; bottom: -25%;
  height: 60%;
  background: var(--xox-red);
  border-radius: 50% 50% 0 0 / 100% 100% 0 0;
}
.xox-login-shell .login-brand > * { position: relative; z-index: 1; }
.xox-login-shell .login-brand .brand-mark {
  display: inline-flex; align-items: center; gap: 14px;
}
.xox-login-shell .login-brand .brand-mark .xox-brand-logo {
  width: 52px; height: 52px; border-radius: 12px;
  object-fit: contain;
  flex-shrink: 0;
  background: #fff;
  padding: 6px;
}
.xox-login-shell .login-brand .brand-mark .brand-name { font-size: 18px; font-weight: 700; letter-spacing: -.01em; }
.xox-login-shell .login-brand .brand-mark .brand-sub  { font-size: 11px; opacity: .75; font-weight: 500; letter-spacing: .1em; text-transform: uppercase; margin-top: 2px; }
.xox-login-shell .login-brand .login-eyebrow {
  font-size: 12px; font-weight: 500; opacity: .75;
  letter-spacing: .1em; text-transform: uppercase; margin-bottom: 14px;
}
.xox-login-shell .login-brand h1 {
  color: #fff; font-size: clamp(40px, 4.5vw, 56px); line-height: 1.05;
  letter-spacing: -.02em; margin: 0;
}
.xox-login-shell .login-brand p { font-size: 16px; font-weight: 300; opacity: .85; margin-top: 18px; max-width: 380px; }
.xox-login-shell .login-brand .login-tag { font-size: 11px; opacity: .75; }

.xox-login-shell .login-form-pane {
  display: grid; place-items: center;
  padding: 56px;
}
.xox-login-shell .login-form-card { width: 100%; max-width: 420px; }
.xox-login-shell .login-form-card .form-eyebrow {
  font-size: 11px; font-weight: 500; color: var(--xox-navy);
  letter-spacing: .1em; text-transform: uppercase; margin-bottom: 12px;
}
.xox-login-shell .login-form-card h2 {
  font-size: 32px; letter-spacing: -.02em; margin: 0 0 8px; color: var(--xox-navy);
}
.xox-login-shell .login-form-card .form-sub { color: var(--xox-ink-2); font-size: 14px; margin-bottom: 32px; }
.xox-login-shell .security-note {
  margin-top: 32px; padding-top: 20px;
  border-top: 1px solid var(--xox-line);
  font-size: 11px; color: var(--xox-ink-3); font-weight: 300; line-height: 1.55;
}

/* ---------- 15. Dashboard hero / sections --------------------------- */
.xox-hero {
  position: relative; overflow: hidden;
  background: var(--xox-navy); color: #fff;
  border-radius: 24px;
  padding: 36px 40px;
  margin: 24px 0 28px;
  display: flex; align-items: center; justify-content: space-between; gap: 24px;
}
.xox-hero::after {
  content: ""; position: absolute; right: -120px; bottom: -80px;
  width: 600px; height: 220px;
  background: var(--xox-red);
  border-radius: 50% 50% 0 0 / 100% 100% 0 0;
  pointer-events: none;
}
.xox-hero > * { position: relative; z-index: 1; }
.xox-hero .hero-eyebrow {
  font-size: 12px; font-weight: 500; opacity: .75;
  letter-spacing: .1em; text-transform: uppercase; margin-bottom: 10px;
}
.xox-hero h1 { color: #fff; font-size: clamp(28px, 3.5vw, 36px); margin: 0 0 10px; letter-spacing: -.02em; line-height: 1.1; }
.xox-hero p  { font-size: 15px; opacity: .85; margin: 0; max-width: 600px; }

.section-eyebrow {
  font-size: 11px; font-weight: 500; color: var(--xox-ink-3);
  letter-spacing: .1em; text-transform: uppercase; margin-bottom: 8px;
}

/* ---------- 16. Lucide icon helper ---------------------------------- */
.xi {
  display: inline-flex; align-items: center; justify-content: center;
  width: 1em; height: 1em; vertical-align: -0.15em;
  flex-shrink: 0;
}
.xi svg { width: 100%; height: 100%; display: block; }

/* ---------- 17. Display helpers / utilities ------------------------- */
.display-1 { font-size: 4rem; font-weight: 700; color: var(--xox-navy); }
.lead { font-size: 1.05rem; color: var(--xox-ink-2); font-weight: 300; }

.border-success { border-color: rgba(22,163,74,.30) !important; }
.border-danger  { border-color: rgba(234,0,41,.30)  !important; }
.border-info    { border-color: rgba(38,34,94,.20)  !important; }
.border-warning { border-color: rgba(245,158,11,.30)!important; }
.border-secondary { border-color: var(--xox-line)   !important; }

/* ---------- 18. Responsive ------------------------------------------ */
@media (max-width: 980px) {
  .xox-login-shell { grid-template-columns: 1fr; }
  .xox-login-shell .login-brand { padding: 36px; min-height: 280px; }
  .xox-login-shell .login-brand h1 { font-size: 36px; }
  .xox-login-shell .login-form-pane { padding: 36px 24px; }
}
@media (max-width: 768px) {
  .navbar { padding: 0 16px; min-height: 64px; }
  .navbar-toggler { display: inline-flex; margin-left: auto; }
  .navbar .container-fluid { flex-wrap: wrap; }
  .collapse:not(.show) { display: none; }
  .navbar-collapse.show { width: 100%; flex-direction: column; align-items: stretch; padding: 12px 0; }
  .navbar-nav { flex-direction: column; align-items: stretch; gap: 2px; }
  .nav-link { padding: 10px 14px; }
  .col-md-1, .col-md-2, .col-md-3, .col-md-4, .col-md-6, .col-md-8, .col-lg-4 {
    flex: 0 0 100%; max-width: 100%;
  }
  .container, .container-fluid { padding-left: 16px; padding-right: 16px; }
  .xox-hero { padding: 28px 24px; }
  .dropdown-menu { position: static; box-shadow: none; }
}

/* ---------- Gamification: Badges --------------------------------------- */
.xox-badge-card {
  display: flex; flex-direction: column; align-items: center;
  width: 110px; text-align: center; gap: 8px;
  padding: 14px 8px; border-radius: 14px;
  transition: transform .25s ease, box-shadow .25s ease;
  position: relative;
  overflow: hidden;
}
.xox-badge-card:hover { transform: translateY(-4px); box-shadow: 0 12px 28px rgba(38,34,94,.14); }
.xox-badge-card:hover .xox-badge-art { transform: scale(1.04) rotate(-2deg); }
.xox-badge-art {
  width: 80px; height: 80px; flex-shrink: 0;
  filter: drop-shadow(0 8px 14px rgba(30,20,80,.18));
  transition: transform .35s cubic-bezier(.2,.9,.3,1.2);
}
.xox-badge-earned .xox-badge-art { opacity: 1; animation: xox-badge-float 3s ease-in-out infinite; }
.xox-badge-locked .xox-badge-art {
  filter: grayscale(1) brightness(1.05) opacity(.45) drop-shadow(0 4px 8px rgba(0,0,0,.05));
}
.xox-badge-name {
  font-size: 11px; font-weight: 600; color: var(--xox-ink);
  line-height: 1.3; word-break: break-word;
}
.xox-badge-locked .xox-badge-name { color: var(--xox-ink-3); }

/* Shimmer sweep on earned badges */
.xox-badge-earned::after {
  content: '';
  position: absolute; top: 0; left: -100%; width: 60%; height: 100%;
  background: linear-gradient(105deg, transparent 20%, rgba(255,255,255,.5) 50%, transparent 80%);
  animation: xox-badge-shimmer 4s ease-in-out infinite;
  pointer-events: none;
}
@keyframes xox-badge-shimmer {
  0%, 75%, 100% { left: -100%; opacity: 0; }
  5% { opacity: 1; }
  35% { left: 150%; opacity: 0; }
}

/* Float / bob animation for earned badges */
@keyframes xox-badge-float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-4px); }
}

/* Pulsing glow ring for recently earned badges */
.xox-badge-recent .xox-badge-art {
  animation: xox-badge-float 3s ease-in-out infinite, xox-badge-glow 2s ease-in-out infinite alternate;
}
@keyframes xox-badge-glow {
  0% { filter: drop-shadow(0 8px 14px rgba(30,20,80,.18)) drop-shadow(0 0 6px rgba(255,180,50,.0)); }
  100% { filter: drop-shadow(0 8px 14px rgba(30,20,80,.18)) drop-shadow(0 0 14px rgba(255,180,50,.55)); }
}

/* "NEW" tag on recently earned badges */
.xox-badge-new-tag {
  font-size: 9px; font-weight: 800; letter-spacing: .08em;
  background: linear-gradient(135deg, #ff5a3d, #ff8a3d);
  color: #fff; padding: 2px 6px; border-radius: 6px;
  position: absolute; top: 6px; right: 6px;
  box-shadow: 0 2px 8px rgba(255,90,61,.35);
  animation: xox-badge-tag-pulse 2s ease-in-out infinite;
}
@keyframes xox-badge-tag-pulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.08); }
}

/* Locked badge wiggle on hover */
.xox-badge-locked:hover .xox-badge-art {
  animation: xox-badge-wiggle .4s ease;
  transform: none;
}
@keyframes xox-badge-wiggle {
  0%, 100% { transform: rotate(0deg); }
  20% { transform: rotate(-6deg); }
  40% { transform: rotate(5deg); }
  60% { transform: rotate(-3deg); }
  80% { transform: rotate(2deg); }
}

/* Confetti particles for badge unlock */
.xox-confetti-particle {
  position: fixed; width: 8px; height: 8px; border-radius: 2px;
  pointer-events: none; z-index: 1200;
  animation: xox-confetti-burst .8s cubic-bezier(.2,.8,.3,1) forwards;
}
@keyframes xox-confetti-burst {
  0% { transform: translate(0, 0) rotate(0deg) scale(1); opacity: 1; }
  100% { transform: translate(var(--tx), var(--ty)) rotate(var(--rot)) scale(0); opacity: 0; }
}

/* Badge toast */
.xox-badge-toast {
  position: fixed; top: 20px; right: 20px; z-index: 1100;
  background: #fff; border-radius: 16px; padding: 16px 24px;
  box-shadow: 0 12px 48px rgba(38,34,94,.18);
  display: flex; align-items: center; gap: 14px;
  animation: xox-toast-in .4s cubic-bezier(.16,1,.3,1) forwards;
  max-width: 380px;
}
.xox-badge-toast .xox-badge-art { width: 52px; height: 52px; flex-shrink: 0; }
.xox-badge-toast-body { line-height: 1.35; }
.xox-badge-toast-label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--func-success); }
.xox-badge-toast-name { font-size: 15px; font-weight: 600; color: var(--xox-navy); }
@keyframes xox-toast-in {
  from { opacity: 0; transform: translateX(40px) scale(.95); }
  to   { opacity: 1; transform: translateX(0) scale(1); }
}
@keyframes xox-toast-out {
  from { opacity: 1; transform: translateX(0) scale(1); }
  to   { opacity: 0; transform: translateX(40px) scale(.95); }
}

/* Badge popover */
.xox-badge-popover {
  position: absolute; z-index: 200;
  background: #fff; border: 1px solid var(--xox-line);
  border-radius: 14px; padding: 16px 20px;
  box-shadow: 0 12px 36px rgba(38,34,94,.16);
  width: 260px;
  opacity: 0; pointer-events: none;
  transform: translateY(6px);
  transition: opacity .2s var(--ease-out), transform .2s var(--ease-out);
}
.xox-badge-popover.is-visible {
  opacity: 1; pointer-events: auto; transform: translateY(0);
}
.xox-badge-popover-arrow {
  position: absolute; top: -6px; left: 50%; margin-left: -6px;
  width: 12px; height: 12px;
  background: #fff; border: 1px solid var(--xox-line);
  border-right: 0; border-bottom: 0;
  transform: rotate(45deg);
}
.xox-badge-popover-status {
  font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em;
  margin-bottom: 4px;
}
.xox-badge-popover-status.is-earned { color: var(--func-success); }
.xox-badge-popover-status.is-locked { color: var(--xox-ink-3); }
.xox-badge-popover-title {
  font-size: 15px; font-weight: 700; color: var(--xox-navy); margin-bottom: 6px;
}
.xox-badge-popover-desc {
  font-size: 13px; color: var(--xox-ink-2); line-height: 1.45;
}
.xox-badge-popover-date {
  font-size: 11px; color: var(--xox-ink-3); margin-top: 8px;
  padding-top: 8px; border-top: 1px solid var(--xox-line);
}

/* ---------- Avatar: edit button & modal ------------------------------ */
.xox-avatar-edit-btn {
  position: absolute; bottom: 0; right: -4px;
  width: 24px; height: 24px; border-radius: 9999px;
  background: var(--xox-navy); border: 2px solid #fff;
  display: grid; place-items: center; cursor: pointer;
  transition: background .2s;
}
.xox-avatar-edit-btn:hover { background: var(--xox-accent, #3d5cff); }
.xox-avatar-modal {
  position: fixed; inset: 0; z-index: 1050;
  background: rgba(0,0,0,.4); backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center;
}
.xox-avatar-modal-box {
  background: #fff; border-radius: 16px; padding: 24px 28px;
  width: 100%; max-width: 420px; max-height: 90vh; overflow-y: auto;
  box-shadow: 0 20px 60px rgba(0,0,0,.2);
}
.xox-avatar-badge-pick {
  background: #f6f6f8; border: 2px solid transparent; border-radius: 12px;
  padding: 6px; cursor: pointer; transition: border-color .2s, transform .2s;
}
.xox-avatar-badge-pick:hover { border-color: var(--xox-navy); transform: scale(1.08); }
.xox-avatar-badge-pick.is-active { border-color: var(--func-success); background: #eafff0; }
