/* ==========================================================================
   WILBERFORCE GROUP LIMITED — Premium Corporate Theme
   Version 1.0.0
   ========================================================================== */

/* ------------------------------------------------------------------
   1. DESIGN TOKENS
------------------------------------------------------------------ */
:root {
  /* Brand Colors */
  --navy:         #0B1F3A;
  --navy-800:     #0E2847;
  --navy-700:     #112F54;
  --navy-600:     #163860;
  --navy-500:     #1E4D80;
  --gold:         #C8A24A;
  --gold-light:   #D4B268;
  --gold-dark:    #A88530;
  --gold-pale:    #F5EDD8;
  --white:        #FFFFFF;
  --off-white:    #F9F7F4;
  --light-gray:   #F0EDE8;
  --mid-gray:     #9CA3AF;
  --dark-gray:    #374151;
  --text-body:    #374151;

  /* Typography */
  --font-cinzel:      'Cinzel', Georgia, serif;
  --font-playfair:    'Playfair Display', Georgia, serif;
  --font-inter:       'Inter', system-ui, sans-serif;
  --font-montserrat:  'Montserrat', system-ui, sans-serif;

  /* Spacing */
  --section-py:       clamp(4rem, 8vw, 7.5rem);
  --container-max:    1380px;
  --container-pad:    clamp(1.25rem, 4vw, 2.5rem);

  /* Effects */
  --shadow-sm:    0 2px 8px rgba(11,31,58,.08);
  --shadow-md:    0 8px 32px rgba(11,31,58,.14);
  --shadow-lg:    0 20px 60px rgba(11,31,58,.18);
  --shadow-gold:  0 8px 32px rgba(200,162,74,.25);

  /* Transitions */
  --ease-out:     cubic-bezier(.25,.46,.45,.94);
  --ease-bounce:  cubic-bezier(.34,1.56,.64,1);
  --dur-fast:     0.2s;
  --dur-med:      0.4s;
  --dur-slow:     0.7s;

  /* Border Radius */
  --radius-sm:  4px;
  --radius-md:  8px;
  --radius-lg:  16px;
  --radius-xl:  24px;
}

/* ------------------------------------------------------------------
   2. RESET & BASE
------------------------------------------------------------------ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font-inter);
  font-size: clamp(0.9375rem, 1.5vw, 1rem);
  line-height: 1.7;
  color: var(--text-body);
  background: var(--white);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }
ul { list-style: none; }
input, textarea, select {
  font-family: var(--font-inter);
  font-size: 1rem;
}

.skip-link { position: absolute; transform: translateY(-100%); focus: translateY(0); }
.skip-link:focus { position: fixed; top: 0; left: 0; z-index: 9999; background: var(--gold); color: var(--navy); padding: .5rem 1rem; }

/* ------------------------------------------------------------------
   3. LAYOUT UTILITIES
------------------------------------------------------------------ */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--container-pad);
}
.container--narrow  { max-width: 860px; }
.container--article { max-width: 780px; }

.section {
  padding-block: var(--section-py);
  position: relative;
}
.section--tight { padding-block: clamp(1.5rem, 3vw, 2.5rem); }
.section--white { background: var(--white); }
.section--light { background: var(--off-white); }
.section--navy  { background: var(--navy); color: var(--white); }
.section--stats { background: var(--navy); color: var(--white); overflow: hidden; }
.section--gold-band { background: var(--gold); }

.text-center { text-align: center; }
.lead { font-size: clamp(1.0625rem, 1.8vw, 1.1875rem); line-height: 1.6; color: var(--dark-gray); }
.prose p { margin-bottom: 1.25em; }
.prose h2, .prose h3 { margin-top: 2em; margin-bottom: .75em; }
.prose ul { padding-left: 1.5em; list-style: disc; }
.prose ul li { margin-bottom: .5em; }

/* ------------------------------------------------------------------
   4. TYPOGRAPHY
------------------------------------------------------------------ */
h1, h2, h3 {
  font-family: var(--font-cinzel);
  font-weight: 600;
  line-height: 1.15;
  letter-spacing: -0.01em;
}
h1 { font-size: clamp(2.25rem, 5vw, 3.75rem); }
h2 { font-size: clamp(1.75rem, 3.5vw, 2.75rem); }
h3 { font-size: clamp(1.125rem, 2vw, 1.375rem); }
h4 { font-family: var(--font-montserrat); font-size: 0.875rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; }

.section--navy h1,
.section--navy h2,
.section--navy h3 { color: var(--white); }

/* Section label */
.wgl-section-label {
  font-family: var(--font-montserrat);
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: .875rem;
  display: block;
}

/* Gold divider */
.wgl-gold-divider {
  display: flex;
  align-items: center;
  gap: .75rem;
  margin: 1.25rem 0 1.75rem;
}
.wgl-gold-divider span { display: block; }
.wgl-gold-divider span:not(.diamond) {
  height: 1px;
  width: 40px;
  background: var(--gold);
  opacity: .7;
}
.wgl-gold-divider .diamond { color: var(--gold); font-size: .5rem; }

.text-center .wgl-gold-divider { justify-content: center; }

/* Section header */
.section__header { margin-bottom: clamp(2.5rem, 5vw, 4rem); }
.section__header--flex { display: flex; align-items: flex-end; justify-content: space-between; gap: 1.5rem; flex-wrap: wrap; }
.section__subtitle { font-size: clamp(.9375rem, 1.5vw, 1.0625rem); color: var(--mid-gray); max-width: 600px; margin-inline: auto; margin-top: .75rem; line-height: 1.6; }
.section__subtitle--light { color: rgba(255,255,255,.65); }

/* ------------------------------------------------------------------
   5. BUTTONS
------------------------------------------------------------------ */
.btn {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-family: var(--font-montserrat);
  font-size: 0.8125rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 0.875rem 2rem;
  border-radius: var(--radius-sm);
  transition: all var(--dur-med) var(--ease-out);
  white-space: nowrap;
  position: relative;
  overflow: hidden;
}
.btn::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,.1);
  opacity: 0;
  transition: opacity var(--dur-fast);
}
.btn:hover::before { opacity: 1; }

.btn--sm { font-size: .6875rem; padding: .625rem 1.25rem; }
.btn--md { padding: .75rem 1.75rem; }
.btn--lg { font-size: .875rem; padding: 1rem 2.25rem; }

/* Gold */
.btn--gold {
  background: var(--gold);
  color: var(--navy);
  box-shadow: var(--shadow-gold);
}
.btn--gold:hover {
  background: var(--gold-dark);
  transform: translateY(-2px);
  box-shadow: 0 12px 40px rgba(200,162,74,.4);
}

/* Outline gold */
.btn--outline-gold {
  background: transparent;
  color: var(--gold);
  border: 2px solid var(--gold);
}
.btn--outline-gold:hover {
  background: var(--gold);
  color: var(--navy);
  transform: translateY(-2px);
}

/* Outline navy */
.btn--outline-navy {
  background: transparent;
  color: var(--navy);
  border: 2px solid var(--navy);
}
.btn--outline-navy:hover {
  background: var(--navy);
  color: var(--white);
  transform: translateY(-2px);
}

/* Navy */
.btn--navy {
  background: var(--navy);
  color: var(--white);
  border: 2px solid var(--navy);
}
.btn--navy:hover {
  background: var(--navy-600);
  transform: translateY(-2px);
}

/* Ghost (white on dark) */
.btn--ghost {
  background: rgba(255,255,255,.1);
  color: var(--white);
  border: 2px solid rgba(255,255,255,.3);
  backdrop-filter: blur(8px);
}
.btn--ghost:hover {
  background: rgba(255,255,255,.2);
  border-color: rgba(255,255,255,.6);
}

/* ------------------------------------------------------------------
   6. SITE HEADER
------------------------------------------------------------------ */
.site-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 900;
  transition: all var(--dur-med) var(--ease-out);
}

/* Topbar */
.site-header__topbar {
  background: var(--navy-800);
  padding-block: .45rem;
  transition: all var(--dur-med) var(--ease-out);
  border-bottom: 1px solid rgba(200,162,74,.15);
}
.topbar__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.topbar__left, .topbar__right {
  display: flex;
  align-items: center;
  gap: .875rem;
  flex-wrap: wrap;
}
.topbar__link {
  display: flex;
  align-items: center;
  gap: .35rem;
  font-family: var(--font-montserrat);
  font-size: .6875rem;
  letter-spacing: .04em;
  color: rgba(255,255,255,.7);
  transition: color var(--dur-fast);
}
.topbar__link:hover { color: var(--gold); }
.topbar__link--gold { color: var(--gold); }
.topbar__sep { color: rgba(255,255,255,.25); }
.topbar__social { display: flex; gap: .5rem; }
.social-icon { display: flex; align-items: center; justify-content: center; width: 24px; height: 24px; color: rgba(255,255,255,.6); transition: color var(--dur-fast); }
.social-icon:hover { color: var(--gold); }

/* Nav */
.site-header__nav {
  background: rgba(11,31,58,.92);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(200,162,74,.12);
  padding-block: .25rem;
}
.nav__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
  height: 68px;
}

/* Logo */
.site-logo { display: flex; align-items: center; gap: .875rem; text-decoration: none; }
.site-logo__text { display: flex; align-items: center; gap: .75rem; }
.site-logo__w {
  font-family: var(--font-cinzel);
  font-size: 2.25rem;
  font-weight: 900;
  color: var(--gold);
  line-height: 1;
  text-shadow: 0 2px 12px rgba(200,162,74,.4);
}
.site-logo__name { display: flex; flex-direction: column; }
.site-logo__wilberforce {
  font-family: var(--font-cinzel);
  font-size: .875rem;
  font-weight: 700;
  color: var(--white);
  letter-spacing: .12em;
  line-height: 1.2;
}
.site-logo__group {
  font-family: var(--font-montserrat);
  font-size: .5rem;
  font-weight: 600;
  color: var(--gold);
  letter-spacing: .2em;
  text-transform: uppercase;
}

/* Nav menu */
.nav__menu { display: flex; align-items: center; gap: .25rem; }
.nav__link {
  display: flex;
  align-items: center;
  gap: .25rem;
  font-family: var(--font-montserrat);
  font-size: .6875rem;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: rgba(255,255,255,.85);
  padding: .625rem .875rem;
  border-radius: var(--radius-sm);
  transition: all var(--dur-fast);
  position: relative;
}
.nav__link::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 50%;
  right: 50%;
  height: 1px;
  background: var(--gold);
  transition: all var(--dur-fast);
}
.nav__item--active .nav__link,
.nav__link:hover { color: var(--gold); }
.nav__item--active .nav__link::after,
.nav__link:hover::after { left: .875rem; right: .875rem; }
.nav__link.btn { color: var(--navy); }
.nav__link.btn::after { display: none; }
.nav__chevron { transition: transform var(--dur-fast); }
.nav__item--has-dropdown:hover .nav__chevron { transform: rotate(180deg); }

/* Mega dropdown */
.nav__item--has-dropdown { position: relative; }
.nav__dropdown {
  position: absolute;
  top: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%) translateY(8px);
  width: 620px;
  background: var(--white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg), 0 0 0 1px rgba(11,31,58,.06);
  padding: 1.5rem;
  opacity: 0;
  pointer-events: none;
  transition: all var(--dur-med) var(--ease-out);
  z-index: 100;
}
.nav__item--has-dropdown:hover .nav__dropdown {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}
.nav__dropdown-inner { display: grid; grid-template-columns: 1fr 1fr auto; gap: 1rem; }
.nav__dropdown-label {
  font-family: var(--font-montserrat);
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--mid-gray);
  margin-bottom: .75rem;
  padding-bottom: .5rem;
  border-bottom: 1px solid var(--light-gray);
}
.nav__dropdown-link {
  display: flex;
  align-items: flex-start;
  gap: .625rem;
  padding: .5rem .625rem;
  border-radius: var(--radius-sm);
  transition: background var(--dur-fast);
  margin-bottom: .25rem;
}
.nav__dropdown-link:hover { background: var(--off-white); }
.nav__dropdown-icon { font-size: 1.125rem; line-height: 1; margin-top: .1rem; }
.nav__dropdown-link strong { display: block; font-family: var(--font-montserrat); font-size: .6875rem; font-weight: 700; color: var(--navy); margin-bottom: .1rem; }
.nav__dropdown-link small { font-size: .6rem; color: var(--mid-gray); }
.nav__dropdown-featured { border-left: 1px solid var(--light-gray); padding-left: 1rem; display: flex; align-items: center; }
.nav__dropdown-cta p { font-size: .75rem; color: var(--dark-gray); margin-bottom: .75rem; }

/* Scrolled state */
.site-header.is-scrolled .site-header__topbar { display: none; }
.site-header.is-scrolled .site-header__nav {
  background: rgba(11,31,58,.98);
  box-shadow: var(--shadow-md);
}

/* Hamburger */
.nav__hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  padding: .5rem;
  width: 40px;
}
.nav__hamburger span {
  height: 2px;
  background: var(--white);
  border-radius: 2px;
  transition: all var(--dur-med) var(--ease-out);
  display: block;
}
.nav__hamburger.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav__hamburger.is-open span:nth-child(2) { opacity: 0; }
.nav__hamburger.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile menu */
.mobile-menu {
  position: fixed;
  inset: 0;
  background: var(--navy);
  z-index: 850;
  transform: translateX(100%);
  transition: transform var(--dur-slow) var(--ease-out);
  overflow-y: auto;
}
.mobile-menu.is-open { transform: translateX(0); }
.mobile-menu__inner { padding: 5rem 2rem 2rem; min-height: 100dvh; display: flex; flex-direction: column; }
.mobile-menu__close { position: absolute; top: 1.25rem; right: 1.5rem; font-size: 2rem; color: var(--white); opacity: .7; }
.mobile-menu__list { flex: 1; }
.mobile-menu__list li { border-bottom: 1px solid rgba(255,255,255,.08); }
.mobile-menu__list a { display: block; padding: 1rem 0; font-family: var(--font-cinzel); font-size: 1.125rem; color: var(--white); }
.mobile-menu__list a.btn { display: inline-flex; margin-top: 1.5rem; }
.mobile-menu__sub { padding-left: 1rem; }
.mobile-menu__sub a { font-family: var(--font-inter); font-size: .875rem; color: rgba(255,255,255,.7); padding: .625rem 0; }
.mobile-menu__footer { padding-top: 2rem; border-top: 1px solid rgba(255,255,255,.1); }
.mobile-menu__footer p { font-family: var(--font-playfair); font-style: italic; color: var(--gold); margin-bottom: 1rem; }
.mobile-menu__social { display: flex; gap: 1rem; }
.mobile-menu__social a { font-family: var(--font-montserrat); font-size: .75rem; color: rgba(255,255,255,.6); }

/* Space for fixed header */
body:not(.page--home) main > *:first-child {
  padding-top: calc(68px + 36px);
}
.page--home .hero { padding-top: calc(68px + 36px); }

/* ------------------------------------------------------------------
   7. HERO SECTION
------------------------------------------------------------------ */
.hero {
  position: relative;
  min-height: 100vh;
  min-height: 100svh;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: var(--navy);
}
.hero__particles {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
}
.hero__bg {
  position: absolute;
  inset: 0;
  z-index: 1;
}
.hero__bg-image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  transform: scale(1.05);
  transform-origin: center center;
  animation: heroZoom 20s ease-in-out infinite alternate;
  will-change: transform;
}
@keyframes heroZoom { from { transform: scale(1.05); } to { transform: scale(1.12); } }
.hero__bg-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(11,31,58,.95) 0%, rgba(11,31,58,.7) 50%, rgba(11,31,58,.85) 100%);
}
.hero__bg-gradient {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(11,31,58,1) 0%, transparent 60%);
}

/* Gold lines */
.hero__lines { position: absolute; inset: 0; z-index: 3; pointer-events: none; overflow: hidden; }
.hero__line {
  position: absolute;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
  opacity: 0;
  animation: lineDraw 4s ease-in-out infinite;
}
.hero__line--1 { height: 1px; top: 30%; width: 60%; left: -60%; animation-delay: 0s; }
.hero__line--2 { height: 1px; bottom: 35%; width: 40%; right: -40%; animation-delay: 1.5s; animation-direction: reverse; }
.hero__line--3 { width: 1px; left: 60%; height: 50%; top: -50%; animation-delay: 3s; }
@keyframes lineDraw { 0%,100% { opacity: 0; transform: translateX(0); } 20% { opacity: .4; } 80% { opacity: .2; } }

/* Hero container */
.hero__container { position: relative; z-index: 10; width: 100%; }
.hero__content {
  max-width: 760px;
  padding-block: clamp(4rem, 10vh, 7rem);
  animation: heroContentIn 1.2s var(--ease-out) both;
}
@keyframes heroContentIn { from { opacity: 0; transform: translateY(32px); } to { opacity: 1; transform: translateY(0); } }

/* W logo */
.hero__logo-wrap {
  position: relative;
  display: inline-flex;
  width: 80px;
  height: 80px;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.75rem;
  animation: heroLogoIn 1.5s var(--ease-bounce) .3s both;
}
@keyframes heroLogoIn { from { opacity: 0; transform: scale(.6) rotate(-10deg); } to { opacity: 1; transform: scale(1) rotate(0deg); } }
.hero__logo-w {
  font-family: var(--font-cinzel);
  font-size: 4rem;
  font-weight: 900;
  color: var(--gold);
  line-height: 1;
  text-shadow: 0 0 40px rgba(200,162,74,.6), 0 0 80px rgba(200,162,74,.3);
  position: relative;
  z-index: 2;
}
.hero__logo-pulse {
  position: absolute;
  inset: -8px;
  border: 1px solid rgba(200,162,74,.3);
  border-radius: 50%;
  animation: heroPulse 3s ease-in-out infinite;
}
@keyframes heroPulse {
  0%,100% { transform: scale(1); opacity: .6; }
  50% { transform: scale(1.15); opacity: .2; }
}

/* Labels */
.hero__label {
  font-family: var(--font-montserrat);
  font-size: .6875rem;
  font-weight: 700;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 1.25rem;
  opacity: 0;
  animation: fadeUp .8s var(--ease-out) .6s both;
}
.hero__headline {
  font-family: var(--font-cinzel);
  font-size: clamp(2.5rem, 6vw, 4.25rem);
  font-weight: 700;
  color: var(--white);
  line-height: 1.08;
  margin-bottom: 1.5rem;
}
.hero__headline-line { display: block; }
.hero__headline-line { opacity: 0; animation: fadeUp .8s var(--ease-out) both; }
.hero__headline-line:nth-child(1) { animation-delay: .7s; }
.hero__headline-line--gold { color: var(--gold); animation-delay: .9s; }
.hero__sub {
  font-size: clamp(.9375rem, 1.6vw, 1.125rem);
  color: rgba(255,255,255,.8);
  max-width: 600px;
  line-height: 1.7;
  margin-bottom: 2.5rem;
  opacity: 0;
  animation: fadeUp .8s var(--ease-out) 1.1s both;
}
.hero__ctas {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  opacity: 0;
  animation: fadeUp .8s var(--ease-out) 1.3s both;
}
.hero__scroll {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-top: 3rem;
  opacity: 0;
  animation: fadeUp .8s var(--ease-out) 1.6s both;
}
.hero__scroll span {
  font-family: var(--font-montserrat);
  font-size: .6rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: rgba(255,255,255,.5);
}
.hero__scroll-line {
  width: 40px;
  height: 1px;
  background: rgba(255,255,255,.3);
  position: relative;
  overflow: hidden;
}
.hero__scroll-line::after {
  content: '';
  position: absolute;
  top: 0; left: -100%; width: 100%; height: 100%;
  background: var(--gold);
  animation: scrollLine 2s ease-in-out 2s infinite;
}
@keyframes scrollLine { to { left: 200%; } }

.hero__world-map { position: absolute; right: -5%; top: 20%; z-index: 4; pointer-events: none; opacity: .06; width: 50%; }

/* ------------------------------------------------------------------
   8. TRUST BAR
------------------------------------------------------------------ */
.trust-bar {
  background: rgba(11,31,58,.96);
  border-top: 1px solid rgba(200,162,74,.15);
  border-bottom: 1px solid rgba(200,162,74,.15);
  padding-block: 1rem;
}
.trust-bar__inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  flex-wrap: wrap;
}
.trust-bar__item {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-family: var(--font-montserrat);
  font-size: .6rem;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.65);
  padding: .5rem 1.25rem;
  white-space: nowrap;
  transition: color var(--dur-fast);
}
.trust-bar__item:hover { color: var(--gold); }
.trust-bar__icon { display: inline-flex; align-items: center; }
.trust-bar__divider { width: 1px; height: 18px; background: rgba(255,255,255,.12); flex-shrink: 0; }

/* ------------------------------------------------------------------
   9. STATISTICS
------------------------------------------------------------------ */
.section--stats .stats__bg {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 20% 50%, rgba(200,162,74,.06) 0%, transparent 60%),
    radial-gradient(circle at 80% 20%, rgba(200,162,74,.04) 0%, transparent 50%);
}
.stats__header { text-align: center; margin-bottom: clamp(2rem, 4vw, 3.5rem); }
.stats__title { color: var(--white); font-size: clamp(1.5rem, 3vw, 2.25rem); }
.stats__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 1.5px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.stat-card {
  background: rgba(255,255,255,.03);
  padding: 2.5rem 2rem;
  text-align: center;
  position: relative;
  transition: background var(--dur-med);
}
.stat-card::before {
  content: '';
  position: absolute;
  bottom: 0; left: 20%; right: 20%;
  height: 2px;
  background: var(--gold);
  opacity: 0;
  transition: opacity var(--dur-med);
}
.stat-card:hover { background: rgba(200,162,74,.05); }
.stat-card:hover::before { opacity: 1; }
.stat-card__number {
  font-family: var(--font-cinzel);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 700;
  color: var(--gold);
  line-height: 1;
  margin-bottom: .625rem;
}
.stat-card__label {
  font-family: var(--font-montserrat);
  font-size: .6875rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--white);
  margin-bottom: .375rem;
}
.stat-card__desc { font-size: .75rem; color: rgba(255,255,255,.45); line-height: 1.5; }

/* ------------------------------------------------------------------
   10. BUSINESS DIVISIONS
------------------------------------------------------------------ */
.divisions__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.75rem;
}

.division-card {
  background: var(--white);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: all var(--dur-med) var(--ease-out);
  border: 1px solid rgba(0,0,0,.06);
}
.division-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-lg);
}
.division-card__image {
  height: 220px;
  overflow: hidden;
  position: relative;
  background: var(--navy);
}
.division-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .6s var(--ease-out);
}
.division-card:hover .division-card__image img { transform: scale(1.07); }
.division-card__image-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(11,31,58,.6) 0%, transparent 60%);
}
.division-card__body { padding: 1.75rem; }
.division-card__icon {
  width: 52px;
  height: 52px;
  background: var(--gold-pale);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--gold-dark);
  margin-bottom: 1rem;
  border: 1px solid rgba(200,162,74,.25);
  transition: all var(--dur-med);
}
.division-card:hover .division-card__icon { background: var(--gold); color: var(--navy); }
.division-card h3 { font-size: 1.0625rem; color: var(--navy); margin-bottom: .625rem; }
.division-card p { font-size: .875rem; color: var(--dark-gray); line-height: 1.65; margin-bottom: 1.25rem; }
.division-card__link {
  display: inline-flex;
  align-items: center;
  gap: .375rem;
  font-family: var(--font-montserrat);
  font-size: .6875rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--gold-dark);
  transition: gap var(--dur-fast);
}
.division-card__link span { transition: transform var(--dur-fast); }
.division-card:hover .division-card__link span { transform: translateX(4px); }

/* ------------------------------------------------------------------
   11. ABOUT PREVIEW
------------------------------------------------------------------ */
.about-preview__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(3rem, 6vw, 6rem);
  align-items: center;
}
.about-preview__image-stack {
  position: relative;
  height: 520px;
}
.about-preview__img {
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  position: absolute;
  object-fit: cover;
}
.about-preview__img--main {
  width: 80%;
  height: 420px;
  top: 0; left: 0;
  z-index: 2;
}
.about-preview__img--accent {
  width: 55%;
  height: 250px;
  bottom: 0; right: 0;
  z-index: 3;
  border: 3px solid var(--navy);
}
.about-preview__badge {
  position: absolute;
  top: 1.5rem;
  right: 0;
  z-index: 4;
  background: var(--gold);
  color: var(--navy);
  border-radius: var(--radius-md);
  padding: .875rem 1.25rem;
  text-align: center;
  box-shadow: var(--shadow-gold);
}
.about-preview__badge-num {
  display: block;
  font-family: var(--font-cinzel);
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1;
}
.about-preview__badge-text {
  display: block;
  font-family: var(--font-montserrat);
  font-size: .5rem;
  font-weight: 700;
  letter-spacing: .15em;
  text-transform: uppercase;
  margin-top: .25rem;
}
.about-preview__title { color: var(--white); font-size: clamp(1.5rem, 2.5vw, 2.125rem); }
.about-preview__lead { font-size: 1.0625rem; color: rgba(255,255,255,.85); line-height: 1.65; margin-bottom: 1rem; }
.about-preview__body { color: rgba(255,255,255,.65); line-height: 1.7; margin-bottom: 2rem; }
.about-preview__pillars {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .75rem;
  margin-bottom: 2.5rem;
}
.pillar {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: .8125rem;
  color: rgba(255,255,255,.75);
  padding: .625rem .75rem;
  background: rgba(255,255,255,.05);
  border-radius: var(--radius-sm);
  border-left: 2px solid var(--gold);
}
.pillar__icon { font-size: 1rem; }
.about-preview__actions { display: flex; gap: 1rem; flex-wrap: wrap; }

/* ------------------------------------------------------------------
   12. PHILOSOPHY
------------------------------------------------------------------ */
.philosophy__steps {
  display: flex;
  align-items: stretch;
  gap: 0;
  position: relative;
}
.philosophy__step {
  flex: 1;
  position: relative;
  padding: 2.5rem 2rem;
  background: var(--white);
  border: 1px solid var(--light-gray);
  border-radius: var(--radius-lg);
  transition: all var(--dur-med);
}
.philosophy__step:hover {
  border-color: var(--gold);
  box-shadow: 0 8px 32px rgba(200,162,74,.12);
  transform: translateY(-4px);
}
.philosophy__step-number {
  font-family: var(--font-cinzel);
  font-size: 3.5rem;
  font-weight: 700;
  color: var(--gold-pale);
  line-height: 1;
  margin-bottom: 1rem;
}
.philosophy__step-body h3 { color: var(--navy); margin-bottom: .625rem; }
.philosophy__step-body p { font-size: .875rem; color: var(--dark-gray); line-height: 1.65; }
.philosophy__step-icon { position: absolute; top: 1.5rem; right: 1.5rem; color: var(--gold); opacity: .5; }
.philosophy__connector {
  width: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.philosophy__connector::before {
  content: '→';
  color: var(--gold);
  font-size: 1.25rem;
  opacity: .6;
}

/* ------------------------------------------------------------------
   13. WHY WILBERFORCE
------------------------------------------------------------------ */
.why__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.75rem;
}
.why-card {
  padding: 2.5rem 2rem;
  border-radius: var(--radius-lg);
  background: var(--white);
  border: 1px solid var(--light-gray);
  transition: all var(--dur-med) var(--ease-out);
  position: relative;
  overflow: hidden;
}
.why-card::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--gold), var(--gold-light));
  transform: scaleX(0);
  transition: transform var(--dur-med) var(--ease-out);
}
.why-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); border-color: transparent; }
.why-card:hover::after { transform: scaleX(1); }
.why-card__icon {
  font-size: 2rem;
  margin-bottom: 1.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  background: var(--gold-pale);
  border-radius: var(--radius-md);
  color: var(--gold-dark);
}
.why-card h3 { color: var(--navy); margin-bottom: .625rem; font-size: 1rem; }
.why-card p { font-size: .875rem; color: var(--dark-gray); line-height: 1.65; }

/* ------------------------------------------------------------------
   14. PORTFOLIO PREVIEW
------------------------------------------------------------------ */
.portfolio-preview__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}
.portfolio-card {
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--radius-lg);
  padding: 1.75rem;
  transition: all var(--dur-med) var(--ease-out);
  display: flex;
  flex-direction: column;
}
.portfolio-card:hover {
  background: rgba(255,255,255,.08);
  border-color: var(--gold);
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(200,162,74,.15);
}
.portfolio-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.25rem;
}
.portfolio-card__logo-placeholder {
  width: 48px;
  height: 48px;
  background: rgba(200,162,74,.15);
  border: 1px solid rgba(200,162,74,.3);
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-cinzel);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--gold);
}
.portfolio-card__status {
  font-family: var(--font-montserrat);
  font-size: .5625rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--gold);
  background: rgba(200,162,74,.12);
  padding: .25rem .75rem;
  border-radius: 100px;
  border: 1px solid rgba(200,162,74,.25);
}
.portfolio-card__industry {
  font-family: var(--font-montserrat);
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: .5rem;
}
.portfolio-card__name { color: var(--white); font-size: 1.0625rem; margin-bottom: .625rem; }
.portfolio-card__desc { font-size: .8125rem; color: rgba(255,255,255,.6); line-height: 1.65; flex: 1; margin-bottom: 1.25rem; }
.portfolio-card__footer { border-top: 1px solid rgba(255,255,255,.08); padding-top: 1rem; }
.portfolio-card__link {
  font-family: var(--font-montserrat);
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--gold);
  transition: opacity var(--dur-fast);
}

/* ------------------------------------------------------------------
   15. IR BAND
------------------------------------------------------------------ */
.ir-band__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
  flex-wrap: wrap;
}
.ir-band__content h2 {
  font-family: var(--font-cinzel);
  font-size: clamp(1.375rem, 2.5vw, 2rem);
  color: var(--navy);
  margin-bottom: .625rem;
}
.ir-band__label {
  font-family: var(--font-montserrat);
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--navy-600);
  margin-bottom: .5rem;
}
.ir-band__content p { color: var(--navy-600); max-width: 520px; }
.ir-band__actions { display: flex; gap: 1rem; flex-wrap: wrap; }

/* ------------------------------------------------------------------
   16. NEWS CARDS
------------------------------------------------------------------ */
.news-preview__grid, .news-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
}
.news-card {
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--white);
  border: 1px solid var(--light-gray);
  transition: all var(--dur-med) var(--ease-out);
  display: flex;
  flex-direction: column;
}
.news-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.news-card__image {
  display: block;
  height: 200px;
  overflow: hidden;
  background: var(--navy);
  position: relative;
}
.news-card__image img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s; }
.news-card:hover .news-card__image img { transform: scale(1.05); }
.news-card__image-placeholder { height: 200px; background: var(--navy); }
.news-card__image-fallback {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-cinzel);
  font-size: 3rem;
  color: rgba(200,162,74,.3);
}
.news-card__body { padding: 1.5rem; flex: 1; display: flex; flex-direction: column; }
.news-card__meta { font-family: var(--font-montserrat); font-size: .625rem; letter-spacing: .08em; color: var(--mid-gray); margin-bottom: .625rem; }
.news-card__title { font-size: 1rem; color: var(--navy); line-height: 1.4; margin-bottom: .75rem; flex: 1; }
.news-card__title a { transition: color var(--dur-fast); }
.news-card__title a:hover { color: var(--gold-dark); }
.news-card__excerpt { font-size: .8125rem; color: var(--dark-gray); margin-bottom: 1.25rem; line-height: 1.6; }
.news-card__read-more {
  display: inline-flex;
  align-items: center;
  gap: .25rem;
  font-family: var(--font-montserrat);
  font-size: .625rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--gold-dark);
}
.news-card__read-more span { transition: transform var(--dur-fast); }
.news-card:hover .news-card__read-more span { transform: translateX(3px); }

/* ------------------------------------------------------------------
   17. HOMEPAGE CONTACT CTA
------------------------------------------------------------------ */
.contact-cta__grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: clamp(3rem, 6vw, 6rem);
  align-items: start;
}
.contact-cta__content { padding-top: 1rem; }
.contact-cta__content h2 { color: var(--white); margin-bottom: 1rem; }
.contact-cta__content p { color: rgba(255,255,255,.7); margin-bottom: 2rem; }
.contact-cta__methods { display: flex; flex-direction: column; gap: .875rem; }
.contact-method {
  display: flex;
  align-items: center;
  gap: .75rem;
  font-size: .875rem;
  color: rgba(255,255,255,.7);
}
.contact-method svg { color: var(--gold); flex-shrink: 0; }
.contact-method a { color: rgba(255,255,255,.85); transition: color var(--dur-fast); }
.contact-method a:hover { color: var(--gold); }

/* ------------------------------------------------------------------
   18. CONTACT FORM
------------------------------------------------------------------ */
.wgl-contact-form { display: flex; flex-direction: column; gap: 1.25rem; }
.form-row--two { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.form-group { display: flex; flex-direction: column; gap: .4rem; }
.form-group label {
  font-family: var(--font-montserrat);
  font-size: .6875rem;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: rgba(255,255,255,.7);
}
/* On white backgrounds */
.contact-form-wrap .form-group label,
.section--light .form-group label,
.section--white .form-group label,
#contact-page .form-group label,
#ir-contact .form-group label { color: var(--dark-gray); }

.form-group label span { color: var(--gold); }
.form-group input,
.form-group textarea,
.form-group select {
  padding: .875rem 1rem;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: var(--radius-sm);
  color: var(--white);
  font-size: .9375rem;
  transition: border-color var(--dur-fast), box-shadow var(--dur-fast);
  outline: none;
  width: 100%;
}
.form-group input::placeholder,
.form-group textarea::placeholder { color: rgba(255,255,255,.3); }
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
  border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(200,162,74,.15);
}
.form-group select { appearance: none; cursor: pointer; }
.form-group select option { background: var(--navy); color: var(--white); }

/* Light theme form */
.contact-form-wrap .form-group input,
.contact-form-wrap .form-group textarea,
.contact-form-wrap .form-group select,
.section--light .wgl-contact-form input,
.section--light .wgl-contact-form textarea,
.section--light .wgl-contact-form select,
.section--white .wgl-contact-form input,
.section--white .wgl-contact-form textarea,
.section--white .wgl-contact-form select {
  background: var(--off-white);
  border-color: var(--light-gray);
  color: var(--text-body);
}
.contact-form-wrap .form-group input::placeholder,
.contact-form-wrap .form-group textarea::placeholder { color: var(--mid-gray); }

.form-group--checkbox .checkbox-label {
  display: flex;
  align-items: flex-start;
  gap: .625rem;
  cursor: pointer;
  font-size: .8125rem;
  color: rgba(255,255,255,.6);
  line-height: 1.5;
}
.contact-form-wrap .form-group--checkbox .checkbox-label { color: var(--dark-gray); }
.checkbox-label input[type="checkbox"] { margin-top: .15rem; width: 16px; height: 16px; accent-color: var(--gold); flex-shrink: 0; }
.checkbox-label a { color: var(--gold); text-decoration: underline; }

.form-messages { font-size: .875rem; padding: .75rem 1rem; border-radius: var(--radius-sm); }
.form-messages.success { background: rgba(52,211,153,.1); border: 1px solid rgba(52,211,153,.3); color: #34D399; }
.form-messages.error   { background: rgba(248,113,113,.1); border: 1px solid rgba(248,113,113,.3); color: #F87171; }

/* ------------------------------------------------------------------
   19. FOOTER
------------------------------------------------------------------ */
.footer-newsletter {
  background: var(--navy-800);
  padding-block: 2.5rem;
  border-top: 1px solid rgba(200,162,74,.15);
}
.footer-newsletter__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
  flex-wrap: wrap;
}
.footer-newsletter__text h3 {
  font-family: var(--font-cinzel);
  font-size: 1.125rem;
  color: var(--white);
  margin-bottom: .375rem;
}
.footer-newsletter__text p { font-size: .875rem; color: rgba(255,255,255,.6); }
.footer-newsletter__input-wrap { display: flex; gap: 0; border-radius: var(--radius-sm); overflow: hidden; border: 1px solid rgba(255,255,255,.15); }
.footer-newsletter__input-wrap input {
  padding: .875rem 1.25rem;
  background: rgba(255,255,255,.07);
  border: none;
  color: var(--white);
  font-size: .875rem;
  min-width: 240px;
  outline: none;
}
.footer-newsletter__input-wrap input::placeholder { color: rgba(255,255,255,.4); }
.footer-newsletter__input-wrap .btn { border-radius: 0; }
.footer-newsletter__message { font-size: .8rem; margin-top: .5rem; }

.footer-main { background: var(--navy); padding-block: 4rem; }
.footer-main__grid {
  display: grid;
  grid-template-columns: 1.8fr 1fr 1fr 1fr;
  gap: 3rem;
}
.footer-col--brand { }
.footer-logo { display: flex; align-items: center; gap: .875rem; margin-bottom: 1rem; }
.footer-logo__icon {
  font-family: var(--font-cinzel);
  font-size: 2.25rem;
  font-weight: 900;
  color: var(--gold);
  line-height: 1;
}
.footer-logo__text { display: flex; flex-direction: column; }
.footer-logo__name { font-family: var(--font-cinzel); font-size: .875rem; font-weight: 700; color: var(--white); letter-spacing: .1em; }
.footer-logo__group { font-family: var(--font-montserrat); font-size: .5rem; font-weight: 600; color: var(--gold); letter-spacing: .18em; text-transform: uppercase; }
.footer-tagline { font-family: var(--font-playfair); font-style: italic; color: var(--gold); font-size: .9375rem; margin-bottom: .875rem; }
.footer-description { font-size: .8125rem; color: rgba(255,255,255,.5); line-height: 1.65; margin-bottom: 1.5rem; }
.footer-social { display: flex; gap: .625rem; }
.footer-social__link {
  width: 36px;
  height: 36px;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,.55);
  transition: all var(--dur-fast);
}
.footer-social__link:hover { background: var(--gold); border-color: var(--gold); color: var(--navy); }

.footer-col__title {
  font-family: var(--font-montserrat);
  font-size: .625rem;
  font-weight: 700;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 1.25rem;
  padding-bottom: .875rem;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.footer-links { display: flex; flex-direction: column; gap: .5rem; }
.footer-links a {
  font-size: .8125rem;
  color: rgba(255,255,255,.55);
  transition: color var(--dur-fast), padding-left var(--dur-fast);
}
.footer-links a:hover { color: var(--gold); padding-left: .375rem; }

.footer-bottom {
  background: rgba(0,0,0,.3);
  border-top: 1px solid rgba(255,255,255,.06);
  padding-block: 1.25rem;
}
.footer-bottom__inner { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; flex-wrap: wrap; }
.footer-copyright { font-size: .75rem; color: rgba(255,255,255,.4); }
.footer-legal { display: flex; gap: 1.25rem; flex-wrap: wrap; }
.footer-legal a { font-size: .75rem; color: rgba(255,255,255,.4); transition: color var(--dur-fast); }
.footer-legal a:hover { color: var(--gold); }

/* ------------------------------------------------------------------
   20. PAGE HEROES (inner pages)
------------------------------------------------------------------ */
.page-hero--inner {
  background: var(--navy);
  padding-block: clamp(6rem, 12vh, 9rem);
  position: relative;
  overflow: hidden;
}
.page-hero--inner::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 80% 50%, rgba(200,162,74,.06) 0%, transparent 60%),
    radial-gradient(circle at 20% 80%, rgba(200,162,74,.04) 0%, transparent 50%);
}
.page-hero--navy { background: var(--navy); padding-block: clamp(6rem, 12vh, 9rem); position: relative; overflow: hidden; }
.page-hero--navy::before { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 70% 40%, rgba(200,162,74,.06) 0%, transparent 60%); }
.page-hero--about {
  position: relative;
  padding-block: clamp(7rem, 14vh, 10rem);
  overflow: hidden;
}
.page-hero__bg { position: absolute; inset: 0; background-size: cover; background-position: center; }
.page-hero__overlay { position: absolute; inset: 0; background: linear-gradient(135deg, rgba(11,31,58,.92) 0%, rgba(11,31,58,.7) 100%); }
.page-hero__content {
  position: relative;
  z-index: 5;
  max-width: 700px;
}
.page-hero--inner .page-hero__content,
.page-hero--navy .page-hero__content { position: relative; z-index: 5; }
.page-hero__content h1 { color: var(--white); }
.page-hero__sub { color: rgba(255,255,255,.75); font-size: 1.0625rem; max-width: 580px; margin-top: .75rem; line-height: 1.65; }
.page-hero__breadcrumb { font-size: .75rem; color: rgba(255,255,255,.5); margin-bottom: 1.25rem; }
.page-hero__breadcrumb a { color: rgba(255,255,255,.65); }
.page-hero__breadcrumb a:hover { color: var(--gold); }
.page-hero__breadcrumb span { margin-inline: .5rem; color: rgba(255,255,255,.3); }

/* ------------------------------------------------------------------
   21. ABOUT PAGE SPECIFIC
------------------------------------------------------------------ */
.about-mission__grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(3rem,6vw,6rem); align-items: start; }
.about-mission__image { position: relative; }
.about-mission__image img { width: 100%; border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); }
.about-mission__quote {
  background: var(--navy);
  border-left: 3px solid var(--gold);
  padding: 1.5rem;
  border-radius: var(--radius-md);
  margin-top: 1.5rem;
}
.about-mission__quote blockquote {
  font-family: var(--font-playfair);
  font-style: italic;
  color: var(--gold);
  font-size: 1.125rem;
  line-height: 1.6;
}

/* Timeline */
.timeline { position: relative; padding-block: 1rem; }
.timeline::before {
  content: '';
  position: absolute;
  left: 50%;
  top: 0; bottom: 0;
  width: 1px;
  background: linear-gradient(to bottom, transparent, var(--gold), transparent);
  transform: translateX(-50%);
}
.timeline__item {
  display: grid;
  grid-template-columns: 1fr 120px 1fr;
  gap: 2rem;
  align-items: center;
  margin-bottom: 2.5rem;
}
.timeline__item--right { direction: rtl; }
.timeline__item--right .timeline__card { direction: ltr; }
.timeline__item--right .timeline__marker { direction: ltr; }
.timeline__marker { grid-column: 2; text-align: center; }
.timeline__year {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 80px;
  height: 80px;
  background: var(--gold);
  color: var(--navy);
  border-radius: 50%;
  font-family: var(--font-cinzel);
  font-size: .8125rem;
  font-weight: 700;
  box-shadow: var(--shadow-gold);
  border: 3px solid var(--white);
}
.timeline__card {
  background: var(--white);
  border: 1px solid var(--light-gray);
  border-radius: var(--radius-md);
  padding: 1.5rem;
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--dur-med);
}
.timeline__card:hover { box-shadow: var(--shadow-md); }
.timeline__card h3 { font-size: 1rem; color: var(--navy); margin-bottom: .5rem; }
.timeline__card p { font-size: .8125rem; color: var(--dark-gray); line-height: 1.65; }

/* Values */
.values__grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; }
.value-card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--radius-lg);
  padding: 2rem;
  transition: all var(--dur-med);
}
.value-card:hover {
  background: rgba(255,255,255,.07);
  border-color: rgba(200,162,74,.4);
  transform: translateY(-3px);
}
.value-card__icon { display: flex; align-items: center; justify-content: center; margin-bottom: 1rem; }
.value-card h3 { color: var(--white); font-size: 1rem; margin-bottom: .625rem; }
.value-card p { font-size: .8125rem; color: rgba(255,255,255,.6); line-height: 1.65; }

/* Leadership */
.leadership__grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 1.75rem; }
.leader-card { text-align: center; }
.leader-card__photo { width: 100%; aspect-ratio: 4/5; border-radius: var(--radius-lg); overflow: hidden; margin-bottom: 1rem; background: var(--light-gray); }
.leader-card__photo img { width: 100%; height: 100%; object-fit: cover; }
.leader-card__photo--placeholder { display: flex; align-items: center; justify-content: center; font-family: var(--font-cinzel); font-size: 2rem; color: var(--gold); background: var(--navy); }
.leader-card__info h3 { font-size: 1rem; color: var(--navy); }
.leader-card__role { font-family: var(--font-montserrat); font-size: .6875rem; font-weight: 600; color: var(--gold-dark); text-transform: uppercase; letter-spacing: .08em; margin-top: .25rem; }
.leader-card__bio { font-size: .8125rem; color: var(--dark-gray); margin-top: .5rem; line-height: 1.6; }
.leader-card__linkedin { display: inline-flex; align-items: center; justify-content: center; width: 28px; height: 28px; background: #0077b5; color: white; border-radius: 4px; font-size: .75rem; font-weight: 700; margin-top: .75rem; }

/* Governance */
.governance__grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 1.75rem; }
.governance__item {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--radius-lg);
  padding: 2rem;
  display: flex;
  flex-direction: column;
  gap: .75rem;
}
.governance__item-number { font-family: var(--font-cinzel); font-size: 2.5rem; color: rgba(200,162,74,.25); font-weight: 700; line-height: 1; }
.governance__item h3 { color: var(--white); font-size: 1rem; }
.governance__item p { font-size: .875rem; color: rgba(255,255,255,.6); line-height: 1.65; }

/* ------------------------------------------------------------------
   22. INVESTOR RELATIONS
------------------------------------------------------------------ */
.ir-quicklinks { display: flex; gap: 1rem; flex-wrap: wrap; }
.ir-quicklink {
  display: flex;
  align-items: center;
  gap: .5rem;
  padding: .75rem 1.25rem;
  background: var(--white);
  border: 1px solid var(--light-gray);
  border-radius: 100px;
  font-family: var(--font-montserrat);
  font-size: .6875rem;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--navy);
  transition: all var(--dur-fast);
  box-shadow: var(--shadow-sm);
}
.ir-quicklink:hover { background: var(--navy); color: var(--white); border-color: var(--navy); box-shadow: var(--shadow-md); }
.ir-quicklink__icon { font-size: 1rem; }
.ir-section__header { margin-bottom: 2.5rem; }
.ir-profile__grid { display: grid; grid-template-columns: 1fr .6fr; gap: 3rem; align-items: start; }
.ir-profile__facts { display: grid; grid-template-columns: 1fr 1fr; gap: .875rem; margin-top: 1.5rem; }
.ir-fact { display: flex; flex-direction: column; gap: .25rem; padding: .875rem 1rem; background: var(--off-white); border-radius: var(--radius-sm); }
.ir-fact__label { font-family: var(--font-montserrat); font-size: .5625rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--mid-gray); }
.ir-fact__value { font-size: .875rem; font-weight: 600; color: var(--navy); }
.ir-download-card { background: var(--navy); border-radius: var(--radius-lg); padding: 2rem; text-align: center; border: 1px solid rgba(200,162,74,.2); }
.ir-download-card__icon { font-size: 3rem; margin-bottom: 1rem; }
.ir-download-card h3 { color: var(--white); margin-bottom: .75rem; }
.ir-download-card p { color: rgba(255,255,255,.65); font-size: .875rem; margin-bottom: 1.5rem; line-height: 1.65; }
.ir-download-card__note { font-size: .6875rem; color: rgba(255,255,255,.4); margin-top: .75rem; }
.ir-reports__grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.25rem; }
.ir-report-card { background: var(--white); border: 1px solid var(--light-gray); border-radius: var(--radius-md); padding: 1.5rem; display: flex; gap: 1rem; align-items: center; box-shadow: var(--shadow-sm); }
.ir-report-card__icon { font-size: 2rem; flex-shrink: 0; }
.ir-report-card__info { flex: 1; }
.ir-report-card__type { font-family: var(--font-montserrat); font-size: .625rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--mid-gray); }
.ir-report-card__year { font-size: 1rem; font-weight: 600; color: var(--navy); }
.ir-report-card__status { font-size: .75rem; color: var(--dark-gray); }
.governance-docs__grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.25rem; }
.governance-doc-card { background: var(--off-white); border: 1px solid var(--light-gray); border-radius: var(--radius-md); padding: 1.5rem; }
.governance-doc-card__status { font-family: var(--font-montserrat); font-size: .625rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; margin-bottom: .875rem; }
.governance-doc-card__status--available { color: #059669; }
.governance-doc-card__status--pending { color: var(--mid-gray); }
.governance-doc-card h3 { font-size: .9375rem; color: var(--navy); margin-bottom: .5rem; }
.governance-doc-card p { font-size: .8125rem; color: var(--dark-gray); margin-bottom: 1rem; line-height: 1.6; }
.press-list { display: flex; flex-direction: column; gap: 0; }
.press-item { display: grid; grid-template-columns: 120px 1fr auto; gap: 1.5rem; align-items: start; padding: 1.5rem 0; border-bottom: 1px solid rgba(255,255,255,.08); }
.press-item__date { font-family: var(--font-montserrat); font-size: .6875rem; font-weight: 600; color: var(--gold); letter-spacing: .06em; text-transform: uppercase; padding-top: .2rem; }
.press-item h3 { font-size: 1rem; color: var(--white); margin-bottom: .375rem; }
.press-item p { font-size: .8125rem; color: rgba(255,255,255,.6); line-height: 1.6; }
.press-item__link { font-family: var(--font-montserrat); font-size: .625rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--gold); white-space: nowrap; padding-top: .2rem; }
.faq-list { display: flex; flex-direction: column; max-width: 860px; margin-inline: auto; }
.faq-item { border-bottom: 1px solid var(--light-gray); }
.faq-item__question {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.5rem 0;
  text-align: left;
  font-family: var(--font-inter);
  font-size: 1rem;
  font-weight: 600;
  color: var(--navy);
  cursor: pointer;
}
.faq-item__question:hover { color: var(--gold-dark); }
.faq-chevron { flex-shrink: 0; transition: transform var(--dur-med); color: var(--gold); }
.faq-item--open .faq-chevron { transform: rotate(180deg); }
.faq-item__answer { overflow: hidden; max-height: 0; transition: max-height .4s ease; }
.faq-item--open .faq-item__answer { max-height: 500px; }
.faq-item__answer p { padding-bottom: 1.5rem; color: var(--dark-gray); line-height: 1.7; font-size: .9375rem; }
.ir-contact-grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: clamp(3rem,6vw,6rem); }

/* ------------------------------------------------------------------
   23. CONTACT PAGE
------------------------------------------------------------------ */
.contact-page__grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: clamp(3rem,6vw,5rem); }
.contact-info__block { margin-bottom: 2.5rem; padding-bottom: 2.5rem; border-bottom: 1px solid var(--light-gray); }
.contact-info__block:last-child { border-bottom: none; }
.contact-info__block h3 { font-size: 1.125rem; color: var(--navy); margin-bottom: 1.25rem; }
.contact-info__item { display: flex; align-items: flex-start; gap: .875rem; margin-bottom: 1rem; font-size: .9375rem; color: var(--dark-gray); }
.contact-info__item svg { color: var(--gold); flex-shrink: 0; margin-top: .15rem; }
.contact-info__item a { color: var(--navy); transition: color var(--dur-fast); }
.contact-info__item a:hover { color: var(--gold-dark); }
.contact-dept { display: flex; flex-direction: column; gap: .25rem; margin-bottom: .875rem; }
.contact-dept__name { font-family: var(--font-montserrat); font-size: .6875rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--mid-gray); }
.contact-dept__email { font-size: .875rem; color: var(--navy); }
.contact-dept__email:hover { color: var(--gold-dark); }
.contact-hours { width: 100%; font-size: .875rem; }
.contact-hours td { padding: .5rem 0; color: var(--dark-gray); }
.contact-hours td:first-child { font-weight: 600; width: 50%; }
.contact-social-links { display: flex; flex-direction: column; gap: .5rem; }
.contact-social-link { display: flex; align-items: center; gap: .75rem; font-size: .875rem; color: var(--navy); transition: color var(--dur-fast); }
.contact-social-link svg { color: var(--gold); }
.contact-social-link:hover { color: var(--gold-dark); }
.contact-form-wrap { background: var(--off-white); border-radius: var(--radius-xl); padding: 2.5rem; }
.contact-form-header { margin-bottom: 2rem; }
.contact-form-header h2 { font-size: 1.5rem; color: var(--navy); margin-bottom: .5rem; }
.contact-form-header p { font-size: .875rem; color: var(--dark-gray); }
.contact-map { height: 300px; background: var(--navy); display: flex; align-items: center; justify-content: center; }
.contact-map__pin { text-align: center; }
.contact-map__pin p { color: rgba(255,255,255,.6); margin-top: .5rem; font-size: .875rem; }

/* ------------------------------------------------------------------
   24. CAREERS PAGE
------------------------------------------------------------------ */
.careers-culture__grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(3rem,6vw,6rem); }
.careers-culture__values { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; align-content: start; }
.careers-perk { display: flex; gap: .875rem; padding: 1rem; background: var(--off-white); border-radius: var(--radius-md); }
.careers-perk__icon { display: inline-flex; align-items: center; flex-shrink: 0; }
.careers-perk strong { display: block; font-size: .875rem; color: var(--navy); margin-bottom: .25rem; }
.careers-perk p { font-size: .75rem; color: var(--dark-gray); line-height: 1.5; margin: 0; }
.jobs-list { display: flex; flex-direction: column; gap: 1rem; }
.job-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  padding: 1.75rem 2rem;
  background: var(--white);
  border: 1px solid var(--light-gray);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  transition: all var(--dur-med);
}
.job-card:hover { border-color: var(--gold); box-shadow: var(--shadow-md); }
.job-card__tags { display: flex; gap: .5rem; flex-wrap: wrap; margin-bottom: .625rem; }
.job-tag {
  font-family: var(--font-montserrat);
  font-size: .5625rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: .25rem .625rem;
  border-radius: 100px;
  background: var(--light-gray);
  color: var(--dark-gray);
}
.job-tag--type { background: var(--gold-pale); color: var(--gold-dark); }
.job-tag--location { background: rgba(11,31,58,.06); color: var(--navy); }
.job-card h3 { font-size: 1.0625rem; color: var(--navy); margin-bottom: .5rem; }
.job-card p { font-size: .8125rem; color: var(--dark-gray); line-height: 1.6; }
.jobs-empty { text-align: center; padding: 3rem 1rem; }
.jobs-empty__icon { display: flex; align-items: center; justify-content: center; margin-bottom: 1rem; color: var(--mid-gray); }
.jobs-empty h3 { font-size: 1.375rem; color: var(--navy); margin-bottom: .75rem; }
.departments__grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; }
.dept-card {
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--radius-lg);
  padding: 1.75rem;
  transition: all var(--dur-med);
}
.dept-card:hover { background: rgba(255,255,255,.08); border-color: rgba(200,162,74,.4); }
.dept-card__icon { display: flex; align-items: center; justify-content: center; margin-bottom: 1rem; }
.dept-card h3 { color: var(--white); font-size: 1rem; margin-bottom: .5rem; }
.dept-card p { font-size: .8125rem; color: rgba(255,255,255,.6); line-height: 1.65; }

/* ------------------------------------------------------------------
   25. COMMUNITY PAGE
------------------------------------------------------------------ */
.community__grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 1.5rem; }
.community-card { display: flex; gap: 1.25rem; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1); border-radius: var(--radius-lg); padding: 1.75rem; transition: all var(--dur-med); }
.community-card:hover { background: rgba(255,255,255,.08); border-color: rgba(200,162,74,.35); }
.community-card__icon { display: inline-flex; align-items: center; flex-shrink: 0; }
.community-card__header { display: flex; align-items: center; gap: .75rem; margin-bottom: .625rem; flex-wrap: wrap; }
.community-card h3 { color: var(--white); font-size: 1rem; }
.community-card p { font-size: .875rem; color: rgba(255,255,255,.65); line-height: 1.65; }
.community-card__status { font-family: var(--font-montserrat); font-size: .5625rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; padding: .2rem .625rem; border-radius: 100px; }
.community-card__status--active { background: rgba(52,211,153,.15); color: #34D399; }
.community-card__status--planned { background: rgba(200,162,74,.15); color: var(--gold); }

/* ------------------------------------------------------------------
   26. DIVISION PAGE
------------------------------------------------------------------ */
.division-overview__grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(3rem,6vw,6rem); align-items: start; }
.division-overview__image { border-radius: var(--radius-lg); overflow: hidden; }
.division-overview__image img { width: 100%; height: auto; }
.services__grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1rem; }
.service-item {
  display: flex;
  align-items: center;
  gap: .75rem;
  padding: 1rem 1.25rem;
  background: var(--white);
  border: 1px solid var(--light-gray);
  border-radius: var(--radius-sm);
  font-size: .875rem;
  color: var(--navy);
  box-shadow: var(--shadow-sm);
  transition: all var(--dur-fast);
}
.service-item:hover { border-color: var(--gold); box-shadow: 0 4px 16px rgba(200,162,74,.12); }
.service-item__check { color: var(--gold); font-weight: 700; flex-shrink: 0; }

/* ------------------------------------------------------------------
   27. SIMPLE CTA
------------------------------------------------------------------ */
.cta-simple { text-align: center; }
.cta-simple h2 { margin-bottom: 1rem; }
.cta-simple p { font-size: 1.0625rem; color: rgba(255,255,255,.7); max-width: 540px; margin-inline: auto; }
.section--light .cta-simple p { color: var(--dark-gray); }
.cta-simple__actions { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; margin-top: 2rem; }

/* 404 */
.page-404 { min-height: 70vh; display: flex; align-items: center; }
.page-404__content { text-align: center; }
.page-404__number { font-family: var(--font-cinzel); font-size: 8rem; color: var(--gold); opacity: .3; line-height: 1; margin-bottom: 1rem; }
.page-404 h1 { color: var(--white); }
.page-404 p { color: rgba(255,255,255,.65); margin: 1rem auto 2rem; max-width: 400px; }

/* Article */
.article-featured-image { margin-block: 2rem; }
.article-featured-image__img { width: 100%; border-radius: var(--radius-lg); max-height: 500px; object-fit: cover; }
.article-meta { display: flex; gap: 1rem; align-items: center; font-family: var(--font-montserrat); font-size: .6875rem; letter-spacing: .08em; color: rgba(255,255,255,.5); text-transform: uppercase; margin-bottom: .75rem; }
.article-intro { font-size: 1.125rem; color: rgba(255,255,255,.8); line-height: 1.65; }
.article-body { padding-block: 3rem 4rem; }
.article-footer { display: flex; justify-content: space-between; align-items: center; padding-top: 2rem; border-top: 1px solid var(--light-gray); gap: 1rem; flex-wrap: wrap; }
.article-share { display: flex; gap: 1rem; align-items: center; }
.share-link { font-family: var(--font-montserrat); font-size: .6875rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--navy); border: 1px solid var(--light-gray); padding: .375rem .875rem; border-radius: 100px; transition: all var(--dur-fast); }
.share-link:hover { background: var(--navy); color: var(--white); }

/* Pagination */
.pagination { margin-top: 3rem; display: flex; justify-content: center; }
.pagination .page-numbers { font-family: var(--font-montserrat); font-size: .75rem; font-weight: 600; padding: .625rem 1rem; margin: 0 .25rem; border: 1px solid var(--light-gray); border-radius: var(--radius-sm); color: var(--navy); transition: all var(--dur-fast); }
.pagination .page-numbers.current,
.pagination .page-numbers:hover { background: var(--navy); color: var(--white); border-color: var(--navy); }

/* ------------------------------------------------------------------
   28. SCROLL ANIMATIONS
------------------------------------------------------------------ */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeIn  { from { opacity: 0; } to { opacity: 1; } }
@keyframes scaleIn { from { opacity: 0; transform: scale(.9); } to { opacity: 1; transform: scale(1); } }

.wgl-reveal-item {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .7s var(--ease-out), transform .7s var(--ease-out);
  transition-delay: calc(var(--i, 0) * 100ms);
}
.wgl-reveal.is-visible .wgl-reveal-item {
  opacity: 1;
  transform: translateY(0);
}

/* ------------------------------------------------------------------
   29. RESPONSIVE
------------------------------------------------------------------ */
@media (max-width: 1200px) {
  .divisions__grid { grid-template-columns: repeat(2,1fr); }
  .why__grid { grid-template-columns: repeat(2,1fr); }
  .footer-main__grid { grid-template-columns: 1fr 1fr; gap: 2rem; }
  .leadership__grid { grid-template-columns: repeat(3,1fr); }
  .portfolio-preview__grid { grid-template-columns: repeat(2,1fr); }
}

@media (max-width: 1024px) {
  .philosophy__steps { flex-direction: column; }
  .philosophy__connector { width: auto; height: 24px; writing-mode: unset; }
  .philosophy__connector::before { content: '↓'; }
  .about-preview__grid { grid-template-columns: 1fr; }
  .about-preview__image-stack { display: none; }
  .contact-cta__grid { grid-template-columns: 1fr; }
  .ir-profile__grid { grid-template-columns: 1fr; }
  .ir-reports__grid { grid-template-columns: repeat(2,1fr); }
  .governance-docs__grid { grid-template-columns: repeat(2,1fr); }
  .ir-contact-grid { grid-template-columns: 1fr; }
  .contact-page__grid { grid-template-columns: 1fr; }
  .careers-culture__grid { grid-template-columns: 1fr; }
  .division-overview__grid { grid-template-columns: 1fr; }
  .about-mission__grid { grid-template-columns: 1fr; }
  .nav__dropdown { width: 460px; }
  .nav__dropdown-inner { grid-template-columns: 1fr 1fr; }
  .nav__dropdown-featured { display: none; }
}

@media (max-width: 768px) {
  :root { --section-py: clamp(3rem, 8vw, 5rem); }
  .nav__menu-wrap { display: none; }
  .nav__hamburger { display: flex; }
  .site-header__topbar { display: none; }
  body:not(.page--home) main > *:first-child { padding-top: 68px; }
  .hero { min-height: 90dvh; min-height: 90svh; }
  .hero__bg-image { object-position: center top; }

  .divisions__grid { grid-template-columns: 1fr; }
  .stats__grid { grid-template-columns: repeat(2,1fr); }
  .news-preview__grid, .news-grid { grid-template-columns: 1fr; }
  .why__grid { grid-template-columns: 1fr; }
  .values__grid { grid-template-columns: 1fr 1fr; }
  .leadership__grid { grid-template-columns: repeat(2,1fr); }
  .governance__grid { grid-template-columns: 1fr; }
  .portfolio-preview__grid { grid-template-columns: 1fr; }
  .ir-quicklinks { gap: .5rem; }
  .ir-reports__grid { grid-template-columns: 1fr; }
  .governance-docs__grid { grid-template-columns: 1fr; }
  .timeline::before { left: 32px; }
  .timeline__item { grid-template-columns: 80px 1fr; }
  .timeline__item--right { direction: ltr; }
  .timeline__marker { grid-column: 1; }
  .timeline__card { grid-column: 2; }
  .timeline__year { width: 60px; height: 60px; font-size: .6875rem; }
  .about-mission__grid { grid-template-columns: 1fr; }
  .careers-culture__values { grid-template-columns: 1fr; }
  .departments__grid { grid-template-columns: 1fr 1fr; }
  .community__grid { grid-template-columns: 1fr; }
  .services__grid { grid-template-columns: 1fr 1fr; }
  .ir-band__inner { flex-direction: column; text-align: center; }
  .ir-band__actions { justify-content: center; }
  .form-row--two { grid-template-columns: 1fr; }
  .section__header--flex { flex-direction: column; align-items: flex-start; }
  .footer-main__grid { grid-template-columns: 1fr; }
  .footer-newsletter__inner { flex-direction: column; }
  .footer-newsletter__input-wrap { width: 100%; }
  .footer-newsletter__input-wrap input { min-width: unset; flex: 1; }
  .footer-bottom__inner { flex-direction: column; text-align: center; }
  .hero__ctas { flex-direction: column; }
  .hero__btn { width: 100%; justify-content: center; }
  .trust-bar__inner { justify-content: flex-start; overflow-x: auto; flex-wrap: nowrap; gap: 0; padding-inline: 1rem; }
  .trust-bar__divider { display: none; }
  .trust-bar__item { flex-shrink: 0; padding: .5rem .875rem; }
  .press-item { grid-template-columns: 1fr; }
  .press-item__date { margin-bottom: .25rem; }
  .job-card { flex-direction: column; align-items: flex-start; }
}

@media (max-width: 480px) {
  .stats__grid { grid-template-columns: 1fr 1fr; }
  .values__grid { grid-template-columns: 1fr; }
  .leadership__grid { grid-template-columns: 1fr 1fr; }
  .departments__grid { grid-template-columns: 1fr; }
  .services__grid { grid-template-columns: 1fr; }
}

/* ------------------------------------------------------------------
   30. ACCESSIBILITY & UTILITIES
------------------------------------------------------------------ */
:focus-visible { outline: 2px solid var(--gold); outline-offset: 3px; }
.sr-only { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; }
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
}
@media print {
  .wgl-reveal, .wgl-reveal-item { opacity: 1 !important; transform: none !important; }
  .hero__bg-image { animation: none !important; }
  .site-header__topbar, .nav__hamburger { display: none !important; }
}

/* ------------------------------------------------------------------
   31. IPO / JSE READINESS COMPONENTS
------------------------------------------------------------------ */

/* Disclosure Badge */
.disclosure-badge {
  display: inline-block;
  background: rgba(200,162,74,.18);
  color: var(--gold);
  border: 1px solid var(--gold);
  border-radius: 2rem;
  padding: .3rem 1rem;
  font-size: .6875rem;
  font-family: var(--font-mono, 'Inter', sans-serif);
  letter-spacing: .12em;
  text-transform: uppercase;
  font-weight: 600;
  margin-bottom: 1.25rem;
}

/* Investment Highlights */
.investment-highlights__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  margin-top: 2.5rem;
}
.highlight-card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(200,162,74,.3);
  border-top: 3px solid var(--gold);
  border-radius: var(--radius);
  padding: 2rem 1.75rem;
  transition: var(--transition);
}
.highlight-card:hover { background: rgba(255,255,255,.07); transform: translateY(-4px); }
.highlight-card__icon { font-size: 2rem; margin-bottom: 1rem; }
.highlight-card h3 { color: var(--gold); font-family: var(--font-heading); font-size: 1.0625rem; margin-bottom: .75rem; }
.highlight-card p { color: rgba(255,255,255,.78); font-size: .9375rem; line-height: 1.65; margin: 0; }

/* Pre-IPO Disclosure Box */
.disclosure-box {
  background: #fff;
  border: 2px solid var(--gold);
  border-radius: var(--radius);
  padding: 2.5rem 3rem;
  max-width: 900px;
  margin: 0 auto;
}
.disclosure-box__header {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1.5rem;
  color: var(--navy);
}
.disclosure-box__header svg { flex-shrink: 0; color: var(--gold); }
.disclosure-box__header h2 { font-size: 1.25rem; margin: 0; color: var(--navy); }
.disclosure-box__body p { color: var(--text); line-height: 1.75; margin-bottom: 1rem; font-size: .9375rem; }
.disclosure-box__body p:last-child { margin-bottom: 0; }
.disclosure-box__footer { margin-top: 2rem; display: flex; gap: 1rem; flex-wrap: wrap; }

/* Capital Structure Table */
.capital-structure__wrap { max-width: 800px; }
.capital-table { width: 100%; border-collapse: collapse; }
.capital-table th,
.capital-table td { padding: .875rem 1.25rem; text-align: left; border-bottom: 1px solid rgba(11,31,58,.1); font-size: .9375rem; vertical-align: top; }
.capital-table th { background: var(--navy); color: var(--white); font-family: var(--font-heading); font-size: .8125rem; letter-spacing: .04em; white-space: nowrap; width: 36%; }
.capital-table td { color: var(--text); }
.capital-table tr:last-child th,
.capital-table tr:last-child td { border-bottom: none; }
.capital-table__note { margin-top: 1.25rem; font-size: .875rem; color: var(--text-muted); border-left: 3px solid var(--gold); padding-left: 1rem; line-height: 1.65; }

/* Financial Calendar */
.financial-calendar { overflow-x: auto; }
.fin-cal-table { width: 100%; border-collapse: collapse; min-width: 520px; }
.fin-cal-table th { background: var(--navy); color: var(--white); padding: .875rem 1.25rem; font-family: var(--font-heading); font-size: .8125rem; letter-spacing: .04em; text-align: left; }
.fin-cal-table td { padding: .875rem 1.25rem; border-bottom: 1px solid rgba(11,31,58,.08); font-size: .9375rem; color: var(--text); }
.fin-cal-table tr:last-child td { border-bottom: none; }
.fin-cal-table tr:hover td { background: rgba(200,162,74,.05); }
.cal-status { display: inline-block; padding: .2rem .75rem; border-radius: 2rem; font-size: .75rem; font-weight: 600; letter-spacing: .04em; }
.cal-status--upcoming { background: rgba(34,197,94,.12); color: #15803d; }
.cal-status--planned  { background: rgba(59,130,246,.12); color: #1d4ed8; }
.cal-status--tbc      { background: rgba(200,162,74,.15); color: #92640f; }
.fin-cal__alert-prompt { display: flex; align-items: center; gap: 1rem; margin-top: 1.5rem; background: rgba(200,162,74,.07); border: 1px solid rgba(200,162,74,.25); border-radius: var(--radius); padding: 1rem 1.5rem; flex-wrap: wrap; }
.fin-cal__alert-prompt svg { color: var(--gold); flex-shrink: 0; }
.fin-cal__alert-prompt span { flex: 1; min-width: 200px; font-size: .9375rem; color: var(--text); }

/* Reports note */
.reports-note { margin-top: 1.5rem; font-size: .875rem; color: var(--text-muted); border-left: 3px solid var(--gold); padding-left: 1rem; line-height: 1.65; }

/* Committee Cards */
.committee-cards {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.75rem;
  margin-top: 2.5rem;
}
.committee-card {
  background: var(--white);
  border: 1px solid rgba(11,31,58,.1);
  border-top: 4px solid var(--gold);
  border-radius: var(--radius);
  padding: 2rem 1.75rem;
  box-shadow: var(--shadow-sm);
}
.committee-card__icon { display: flex; align-items: center; justify-content: center; margin-bottom: 1rem; }
.committee-card h3 { color: var(--navy); font-family: var(--font-heading); font-size: 1.0625rem; margin-bottom: .75rem; }
.committee-card__purpose { color: var(--text); font-size: .9375rem; line-height: 1.65; margin-bottom: .75rem; }
.committee-card__composition { color: var(--text-muted); font-size: .875rem; margin-bottom: .5rem; }
.committee-card__freq { color: var(--text-muted); font-size: .875rem; margin-bottom: 1rem; }
.committee-card__list { padding-left: 1.25rem; margin: 0; }
.committee-card__list li { font-size: .9rem; color: var(--text); margin-bottom: .4rem; line-height: 1.5; }

/* Risk Factors */
.risk-factors__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  margin-top: 2.5rem;
}
.risk-card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--radius);
  padding: 2rem 1.75rem;
}
.risk-card__num { display: block; font-family: var(--font-heading); font-size: .75rem; color: var(--gold); letter-spacing: .1em; margin-bottom: .75rem; }
.risk-card h3 { color: var(--white); font-family: var(--font-heading); font-size: 1rem; margin-bottom: .75rem; }
.risk-card p { color: rgba(255,255,255,.72); font-size: .9rem; line-height: 1.65; margin: 0; }

/* IR Alerts Box */
.ir-alerts-box {
  max-width: 640px;
  margin: 0 auto;
  text-align: center;
}
.ir-alerts-box__icon { font-size: 2.5rem; margin-bottom: 1rem; }
.ir-alerts-box h2 { color: var(--navy); }
.ir-alerts-box > p { color: var(--text); max-width: 520px; margin: 1rem auto 0; line-height: 1.65; }
.ir-alerts-box__form { margin-top: 2rem; }
.ir-alerts-box__input-wrap { display: flex; gap: .75rem; max-width: 480px; margin: 0 auto; }
.ir-alerts-box__input-wrap input { flex: 1; padding: .75rem 1rem; border: 1.5px solid rgba(11,31,58,.2); border-radius: var(--radius); font-size: 1rem; outline: none; transition: var(--transition); }
.ir-alerts-box__input-wrap input:focus { border-color: var(--gold); }
.ir-alerts-box__message { margin-top: .75rem; font-size: .9rem; min-height: 1.5rem; }
.ir-alerts-box__privacy { margin-top: 1.25rem; font-size: .8125rem; color: var(--text-muted); }
.ir-alerts-box__privacy a { color: var(--navy); text-decoration: underline; }

/* IR Contact Person */
.ir-contact__person { margin-top: 1.5rem; background: rgba(11,31,58,.04); border-left: 4px solid var(--gold); padding: 1rem 1.25rem; border-radius: 0 var(--radius) var(--radius) 0; }
.ir-contact__person-name { font-family: var(--font-heading); font-size: .9375rem; color: var(--navy); font-weight: 600; }
.ir-contact__person-title { font-size: .875rem; color: var(--text-muted); margin-top: .2rem; }

/* Governance Framework Grid */
.governance-framework__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.75rem;
  margin-top: 2.5rem;
}
.gov-framework-card {
  background: var(--white);
  border: 1px solid rgba(11,31,58,.1);
  border-radius: var(--radius);
  padding: 2rem 1.75rem;
  box-shadow: var(--shadow-sm);
}
.gov-framework-card__icon { display: flex; align-items: center; justify-content: center; margin-bottom: 1rem; }
.gov-framework-card h3 { color: var(--navy); font-family: var(--font-heading); font-size: 1.0625rem; margin-bottom: 1rem; }
.gov-framework-card p { color: var(--text); font-size: .9375rem; line-height: 1.65; margin-bottom: .75rem; }
.gov-list { padding-left: 1.25rem; margin: 0; }
.gov-list li { font-size: .9rem; color: var(--text); margin-bottom: .4rem; line-height: 1.5; }

/* Governance Hierarchy */
.gov-hierarchy { display: flex; flex-direction: column; align-items: center; gap: .25rem; margin-top: 1rem; }
.gov-hierarchy__level { background: var(--navy); color: var(--white); padding: .5rem 1rem; border-radius: var(--radius); font-size: .8rem; text-align: center; width: 100%; font-family: var(--font-heading); letter-spacing: .02em; }
.gov-hierarchy__level--1 { background: var(--gold); color: var(--navy); }
.gov-hierarchy__level--2 { background: var(--navy); }
.gov-hierarchy__level--3 { background: rgba(11,31,58,.75); font-size: .75rem; }
.gov-hierarchy__level--4 { background: rgba(11,31,58,.6); }
.gov-hierarchy__level--5 { background: rgba(11,31,58,.5); font-size: .75rem; }
.gov-hierarchy__arrow { color: var(--gold); font-size: 1.1rem; line-height: 1; }

/* Board Directors Grid */
.board-directors__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
  margin-top: 2.5rem;
}
.board-director-card { background: var(--white); border: 1px solid rgba(11,31,58,.1); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-sm); }
.board-director-card__photo { aspect-ratio: 3/4; overflow: hidden; background: var(--light); }
.board-director-card__photo img { width: 100%; height: 100%; object-fit: cover; }
.board-director-card__photo--placeholder { display: flex; align-items: center; justify-content: center; background: var(--navy); }
.board-director-card__photo--placeholder span { font-size: 3rem; color: var(--gold); font-family: var(--font-heading); font-weight: 700; }
.board-director-card__info { padding: 1.25rem 1rem; }
.board-director-card__info h3 { font-size: .9375rem; color: var(--navy); margin-bottom: .25rem; font-family: var(--font-heading); }
.board-director-card__role { font-size: .8125rem; color: var(--text-muted); margin-bottom: .5rem; }
.board-director-card__badge { display: inline-block; font-size: .6875rem; padding: .15rem .6rem; border-radius: 2rem; font-weight: 600; letter-spacing: .04em; margin-bottom: .5rem; }
.board-director-card__badge--independent { background: rgba(34,197,94,.12); color: #15803d; }
.board-director-card__badge--executive { background: rgba(11,31,58,.1); color: var(--navy); }
.board-director-card__appointed { font-size: .8rem; color: var(--text-muted); margin-bottom: .35rem; }
.board-director-card__committee { font-size: .8rem; color: var(--text); line-height: 1.4; margin-bottom: .5rem; }
.board-director-card__bio { font-size: .8125rem; color: var(--text-muted); line-height: 1.55; }

/* Policy Statement */
.policy-statement p { font-size: .9375rem; line-height: 1.75; color: var(--text); margin-bottom: 1rem; }
.policy-statement p.lead { font-size: 1.0625rem; color: var(--navy); }
.policy-list { padding-left: 1.5rem; }
.policy-list li { font-size: .9375rem; color: var(--text); margin-bottom: .6rem; line-height: 1.65; }

/* Internal Controls Grid */
.controls__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
  margin-top: 2.5rem;
}
.control-pillar { background: var(--white); border: 1px solid rgba(11,31,58,.1); border-top: 3px solid var(--gold); border-radius: var(--radius); padding: 1.75rem 1.5rem; box-shadow: var(--shadow-sm); }
.control-pillar__icon { display: flex; align-items: center; justify-content: center; margin-bottom: .75rem; }
.control-pillar h3 { color: var(--navy); font-family: var(--font-heading); font-size: .9375rem; margin-bottom: .75rem; }
.control-pillar p { color: var(--text); font-size: .875rem; line-height: 1.65; margin: 0; }

/* ESG Pillars */
.esg-pillars {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.75rem;
  margin-top: 2.5rem;
}
.esg-pillar {
  border-radius: var(--radius);
  padding: 2.5rem 2rem;
  text-align: center;
  box-shadow: var(--shadow);
}
.esg-pillar--env { background: linear-gradient(135deg, #f0fdf4 0%, #dcfce7 100%); border: 1px solid #86efac; }
.esg-pillar--soc { background: linear-gradient(135deg, #eff6ff 0%, #dbeafe 100%); border: 1px solid #93c5fd; }
.esg-pillar--gov { background: linear-gradient(135deg, #fdfbf5 0%, #fef3c7 100%); border: 1px solid #fcd34d; }
.esg-pillar__icon { display: flex; align-items: center; justify-content: center; margin-bottom: 1rem; }
.esg-pillar h3 { color: var(--navy); font-family: var(--font-heading); font-size: 1.25rem; margin-bottom: 1rem; }
.esg-pillar p { color: var(--text); font-size: .9375rem; line-height: 1.65; margin-bottom: 1.25rem; }
.esg-pillar__stat { margin-top: 1rem; }
.esg-pillar__stat span { display: block; font-family: var(--font-display); font-size: 2rem; font-weight: 700; color: var(--navy); }

/* ESG Detail */
.esg-detail__grid { display: grid; grid-template-columns: 1fr 380px; gap: 3rem; align-items: start; }
.esg-detail__content h3 { color: var(--navy); font-family: var(--font-heading); font-size: 1.0625rem; margin: 1.5rem 0 .5rem; }
.esg-detail__content h3:first-child { margin-top: 0; }
.esg-detail__content p { color: var(--text); font-size: .9375rem; line-height: 1.7; margin-bottom: .75rem; }
.esg-detail__content p.lead { font-size: 1.0625rem; color: var(--navy); margin-bottom: 1.5rem; }
.esg-detail__commitments { background: var(--navy); border-radius: var(--radius); padding: 2rem; position: sticky; top: 100px; }
.esg-detail__commitments h3 { color: var(--gold); font-family: var(--font-heading); font-size: 1rem; margin-bottom: 1.25rem; }
.esg-commit-list { list-style: none; padding: 0; margin: 0; }
.esg-commit-list li { display: flex; align-items: flex-start; gap: .75rem; color: rgba(255,255,255,.85); font-size: .9rem; line-height: 1.55; padding-bottom: .75rem; border-bottom: 1px solid rgba(255,255,255,.08); margin-bottom: .75rem; }
.esg-commit-list li:last-child { border-bottom: none; margin-bottom: 0; padding-bottom: 0; }
.esg-commit-list__icon { color: var(--gold); flex-shrink: 0; display: inline-flex; align-items: center; margin-top: .05rem; }

/* SDG Grid */
.sdg-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  margin-top: 2.5rem;
}
.sdg-card {
  border-radius: var(--radius);
  padding: 1.75rem 1.5rem;
  background: var(--white);
  border: 1px solid rgba(11,31,58,.08);
  border-top: 4px solid var(--sdg-color, var(--gold));
  box-shadow: var(--shadow-sm);
}
.sdg-card__num { font-size: .75rem; font-weight: 700; letter-spacing: .08em; color: var(--sdg-color, var(--gold)); margin-bottom: .5rem; text-transform: uppercase; }
.sdg-card h3 { color: var(--navy); font-family: var(--font-heading); font-size: .9375rem; margin-bottom: .75rem; }
.sdg-card p { color: var(--text); font-size: .875rem; line-height: 1.6; margin: 0; }

/* Legal Document */
.legal-doc { max-width: 800px; margin: 0 auto; }
.legal-doc__intro { margin-bottom: 2.5rem; padding-bottom: 2rem; border-bottom: 1px solid rgba(11,31,58,.1); }
.legal-doc__intro p.lead { font-size: 1.0625rem; color: var(--navy); line-height: 1.7; }
.legal-doc h2 { font-family: var(--font-heading); font-size: 1.1875rem; color: var(--navy); margin: 2.5rem 0 1rem; padding-bottom: .5rem; border-bottom: 2px solid var(--gold); }
.legal-doc h3 { font-family: var(--font-heading); font-size: 1rem; color: var(--navy); margin: 1.5rem 0 .5rem; }
.legal-doc p { color: var(--text); font-size: .9375rem; line-height: 1.8; margin-bottom: .875rem; }
.legal-doc a { color: var(--navy); text-decoration: underline; }
.legal-doc a:hover { color: var(--gold); }
.legal-list { padding-left: 1.5rem; margin-bottom: 1rem; }
.legal-list li { font-size: .9375rem; color: var(--text); line-height: 1.75; margin-bottom: .5rem; }
.legal-contact-block { background: rgba(11,31,58,.04); border-left: 4px solid var(--gold); padding: 1.25rem 1.5rem; border-radius: 0 var(--radius) var(--radius) 0; margin: 1rem 0 1.5rem; }
.legal-contact-block p { margin: 0; line-height: 1.65; font-size: .9375rem; }
.legal-highlight-box { background: rgba(200,162,74,.06); border: 1.5px solid var(--gold); border-radius: var(--radius); padding: 2rem; margin: 1.5rem 0 2rem; }
.legal-highlight-box h3 { color: var(--navy); font-family: var(--font-heading); font-size: 1rem; margin-bottom: 1rem; margin-top: 0; border-bottom: none; }
.legal-highlight-box p { font-size: .9rem; line-height: 1.7; }

/* Responsive — 1024px */
@media (max-width: 1024px) {
  .investment-highlights__grid { grid-template-columns: repeat(2, 1fr); }
  .governance-framework__grid { grid-template-columns: 1fr; }
  .board-directors__grid { grid-template-columns: repeat(2, 1fr); }
  .controls__grid { grid-template-columns: repeat(2, 1fr); }
  .esg-detail__grid { grid-template-columns: 1fr; }
  .esg-detail__commitments { position: static; }
  .sdg-grid { grid-template-columns: repeat(2, 1fr); }
  .disclosure-box { padding: 2rem; }
}

/* Responsive — 768px */
@media (max-width: 768px) {
  .investment-highlights__grid { grid-template-columns: 1fr; }
  .committee-cards { grid-template-columns: 1fr; }
  .risk-factors__grid { grid-template-columns: 1fr; }
  .board-directors__grid { grid-template-columns: repeat(2, 1fr); }
  .controls__grid { grid-template-columns: 1fr; }
  .esg-pillars { grid-template-columns: 1fr; }
  .sdg-grid { grid-template-columns: 1fr; }
  .ir-alerts-box__input-wrap { flex-direction: column; }
  .disclosure-box { padding: 1.5rem; }
  .disclosure-box__footer { flex-direction: column; }
  .capital-table th { white-space: normal; }
  .fin-cal__alert-prompt { flex-direction: column; align-items: flex-start; }
}

/* ------------------------------------------------------------------
   32. PORTAL NAV BUTTON
------------------------------------------------------------------ */
.nav__portal-btn {
  display: flex;
  align-items: center;
  gap: .375rem;
  border: 1.5px solid rgba(200,162,74,.5);
  border-radius: 999px;
  padding: .375rem .875rem !important;
  color: var(--gold) !important;
  font-size: .6875rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  transition: all .2s;
  white-space: nowrap;
}
.nav__portal-btn::after { display: none !important; }
.nav__portal-btn:hover {
  background: var(--gold);
  color: var(--navy) !important;
  border-color: var(--gold);
}
.nav__portal-btn svg { flex-shrink: 0; }

/* Responsive — 480px */
@media (max-width: 480px) {
  .board-directors__grid { grid-template-columns: 1fr; }
  .disclosure-box__header { flex-direction: column; align-items: flex-start; }
}
