/* GL Academy — main.css (all theme styles) */

/* Elementor full-width compatibility */
#main-content { width: 100%; }
#main-content .elementor-section-boxed > .elementor-container { max-width: 1200px; }
.elementor-page #main-content { padding: 0; margin: 0; }

/* ── Language Switcher ──────────────────────────────────────
   Sits between the nav and the Apply Now button.
   Uses the same hover pattern as .simple-dropdown.
─────────────────────────────────────────────────────────── */
.lang-switcher {
  position: relative;
  flex-shrink: 0;
}
.lang-current {
  display: flex; align-items: center; gap: 6px;
  padding: 6px 10px;
  font-family: var(--font-sans); font-size: 13px; font-weight: 600;
  color: var(--gla-ink);
  background: transparent;
  border: 1px solid var(--gla-line-soft);
  border-radius: 8px;
  cursor: pointer;
  transition: background .15s, border-color .15s;
  white-space: nowrap;
}
.lang-current:hover { background: var(--gla-paper-2); border-color: var(--gla-line); }
.lang-current img { border-radius: 2px; display: block; }
.lang-current svg { opacity: .5; transition: transform .2s; }
.lang-switcher:hover .lang-current svg { transform: rotate(180deg); }

/* Dropdown list */
.lang-dropdown {
  position: absolute !important;
  top: calc(100% + 6px); right: 0;
  min-width: 160px;
  list-style: none !important; margin: 0 !important; padding: 6px !important;
  background: #fff;
  border: 1px solid var(--gla-line-soft);
  border-radius: 12px;
  box-shadow: 0 16px 40px -8px rgba(5,40,104,.14);
  z-index: 9999;
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
  transform: translateY(-4px);
  transition: opacity .18s ease, transform .2s ease, visibility 0s .2s;
}
.lang-switcher:hover .lang-dropdown,
.lang-switcher:focus-within .lang-dropdown,
.lang-switcher.open .lang-dropdown {
  visibility: visible;
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
  transition: opacity .18s ease, transform .2s ease, visibility 0s;
}
.lang-switcher.open .lang-current svg { transform: rotate(180deg); }
.lang-dropdown li { list-style: none !important; }
.lang-option {
  display: flex; align-items: center; gap: 8px;
  padding: 9px 12px;
  font-size: 13.5px; font-weight: 500;
  color: var(--gla-ink);
  border-radius: 8px;
  text-decoration: none;
  transition: background .13s, color .13s;
}
.lang-option:hover { background: var(--gla-sky-100); color: var(--gla-royal-600); }
.lang-option--active { color: var(--gla-royal-600); font-weight: 700; }
.lang-option--active::after { content: "✓"; margin-left: auto; font-size: 12px; }
.lang-option img { border-radius: 2px; flex-shrink: 0; }

/* Mobile: show switcher inside drawer footer */
.mobile-lang-switcher { display: flex; flex-wrap: wrap; gap: 8px; padding: 16px 24px 0; }
.mobile-lang-link {
  display: flex; align-items: center; gap: 6px;
  padding: 7px 12px; font-size: 13px; font-weight: 600;
  color: var(--gla-ink-2); background: var(--gla-paper-2);
  border: 1px solid var(--gla-line-soft); border-radius: 999px;
  text-decoration: none; transition: background .15s, color .15s;
}
.mobile-lang-link:hover,
.mobile-lang-link--active { background: var(--gla-sky-100); color: var(--gla-royal-600); border-color: var(--gla-sky-300); }
.mobile-lang-link img { border-radius: 2px; }

/* ─────────────────────────────────────────────────────────
   DESIGN TOKENS
───────────────────────────────────────────────────────── */
:root {
  --gla-navy-900:  #021C49;
  --gla-navy-800:  #052868;
  --gla-navy-700:  #0B3A8C;
  --gla-royal-600: #1556B5;
  --gla-azure-500: #2178E0;
  --gla-sky-300:   #8FB6E8;
  --gla-sky-100:   #DCE7F5;
  --gla-gold-700:  #8C6A1F;
  --gla-gold-600:  #B08832;
  --gla-gold-500:  #C9A961;
  --gla-gold-300:  #E4CC8A;
  --gla-gold-100:  #F5ECD3;
  --gla-ink:       #0F172A;
  --gla-ink-2:     #3D4757;
  --gla-ink-3:     #6B7385;
  --gla-line:      #E4E7EE;
  --gla-line-soft: #EFF1F5;
  --gla-paper:     #FFFFFF;
  --gla-paper-2:   #F6F7FA;
  --gla-paper-3:   #FAFBFC;
  --fg-1: var(--gla-ink);
  --fg-2: var(--gla-ink-2);
  --fg-3: var(--gla-ink-3);
  --border:        var(--gla-line);
  --border-soft:   var(--gla-line-soft);
  --shadow-xs: 0 1px 2px rgba(5,40,104,.05);
  --shadow-sm: 0 1px 3px rgba(5,40,104,.06), 0 1px 2px rgba(5,40,104,.04);
  --shadow-md: 0 6px 16px -4px rgba(5,40,104,.08), 0 2px 4px rgba(5,40,104,.04);
  --shadow-lg: 0 24px 48px -16px rgba(5,40,104,.14), 0 8px 16px -8px rgba(5,40,104,.06);
  --font-sans: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  --spline-fade-from: #FFFFFF;
}

/* ─────────────────────────────────────────────────────────
   RESET & BASE
───────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; transition: background-color .28s ease; }
body {
  margin: 0; padding: 0;
  font-family: var(--font-sans);
  font-size: 16px; font-weight: 400; line-height: 1.55;
  color: var(--gla-ink); background: var(--gla-paper);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
  transition: background-color .28s ease, color .18s ease;
}
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }
img { max-width: 100%; display: block; }
:focus-visible { outline: 2px solid var(--gla-royal-600); outline-offset: 2px; border-radius: 4px; }

/* ─────────────────────────────────────────────────────────
   LAYOUT
───────────────────────────────────────────────────────── */
.container        { max-width: 1200px; margin: 0 auto; padding: 0 28px; position: relative; }
.container-narrow { max-width: 880px;  margin: 0 auto; padding: 0 28px; }
@media (max-width: 720px) { .container, .container-narrow { padding: 0 20px; } }

/* ─────────────────────────────────────────────────────────
   SKIP LINK
───────────────────────────────────────────────────────── */
.skip-link { position: absolute; left: -10000px; top: 8px; background: var(--gla-navy-900); color: #fff; padding: 10px 16px; border-radius: 6px; z-index: 1000; font-size: 14px; font-weight: 600; }
.skip-link:focus { left: 16px; }

/* ─────────────────────────────────────────────────────────
   SCROLL PROGRESS BAR
───────────────────────────────────────────────────────── */
.scroll-progress { position: fixed; top: 0; left: 0; right: 0; height: 2.5px; z-index: 200; background: linear-gradient(90deg, var(--gla-royal-600), var(--gla-azure-500), var(--gla-gold-500)); transform-origin: left center; transform: scaleX(0); will-change: transform; pointer-events: none; border-radius: 0 2px 2px 0; transition: transform .08s linear; }

/* ─────────────────────────────────────────────────────────
   MASTHEAD
───────────────────────────────────────────────────────── */
.mast { position: sticky; top: 0; z-index: 50; background: rgba(255,255,255,.85); backdrop-filter: saturate(180%) blur(16px); -webkit-backdrop-filter: saturate(180%) blur(16px); border-bottom: 1px solid var(--gla-line-soft); transition: background .2s; }
.mast .row { display: flex; align-items: center; justify-content: space-between; height: 76px; gap: 32px; }
.mast .brand { display: flex; align-items: center; gap: 12px; }
.mast .brand img { height: 42px; display: block; }
.mast nav { display: flex; align-items: center; gap: 2px; flex: 1; margin-left: 28px; }
.mast nav a { position: relative; font-size: 14px; font-weight: 500; color: var(--fg-1); padding: 10px 14px; border-radius: 6px; transition: background .18s, color .18s; }
.mast nav a:hover { background: var(--gla-paper-2); }
.mast nav a.active { color: var(--gla-royal-600); }
.mast nav a.active::after { content: ""; position: absolute; left: 14px; right: 14px; bottom: 2px; height: 2px; background: var(--gla-royal-600); border-radius: 2px; }
.mast .has-dd { position: relative; }
.mast .dd { position: absolute; top: calc(100% + 6px); background: #fff; border: 1px solid var(--border-soft); border-radius: 14px; box-shadow: var(--shadow-lg); padding: 16px 14px; opacity: 0; pointer-events: none; transition: opacity .18s, transform .18s; z-index: 100; }
.mast .dd--mega { min-width: 700px; display: grid !important; grid-template-columns: 1fr 1px 1fr; left: 50%; transform: translateX(-50%) translateY(-6px); }
.has-dd:hover .dd, .has-dd:focus-within .dd { opacity: 1; pointer-events: auto; }
.mast .dd--mega:hover, .mast .has-dd:hover .dd--mega, .mast .has-dd:focus-within .dd--mega { transform: translateX(-50%) translateY(0); }
.dd-col { display: flex; flex-direction: column; gap: 2px; }
.dd-sep-v { background: var(--border-soft); margin: 0 8px; align-self: stretch; width: 1px; }
.dd-lbl { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; padding: 5px 12px 8px; display: flex; align-items: center; gap: 6px; }
.dd-lbl.lang { color: var(--gla-royal-600); }
.dd-lbl.adp  { color: var(--gla-gold-700); }
.mast .dd a { display: flex; align-items: flex-start; gap: 12px; padding: 10px 12px; border-radius: 8px; }
.mast .dd a:hover { background: var(--gla-paper-2); }
.mast .dd a .ic { width: 32px; height: 32px; border-radius: 8px; flex: 0 0 32px; display: grid; place-items: center; font-size: 16px; margin-top: 2px; }
.ic--lang { background: linear-gradient(135deg,#EAF1FB,#DCE7F5); color: var(--gla-royal-600); }
.ic--adp  { background: linear-gradient(135deg,#F5ECD3,#E4CC8A); color: var(--gla-gold-700); }
.mast .dd a .tx { display: flex; flex-direction: column; }
.mast .dd a strong { font-weight: 600; font-size: 14px; color: var(--gla-navy-900); }
.mast .dd a small  { font-size: 12.5px; color: var(--fg-3); margin-top: 2px; }
.mast .cta { display: flex; align-items: center; gap: 10px; }
.mast .signin { font-size: 14px; font-weight: 500; color: var(--fg-1); padding: 9px 14px; border-radius: 6px; background: transparent; border: none; transition: background .18s; }
.mast .signin:hover { background: var(--gla-paper-2); }
.menu-toggle { display: none; background: transparent; border: none; color: var(--fg-1); font-size: 22px; padding: 8px; }
@media (max-width: 1000px) { .mast nav, .mast .signin { display: none; } .menu-toggle { display: grid; place-items: center; } }

/* Drawer */
.drawer { position: fixed; inset: 76px 0 0 0; background: #fff; z-index: 49; visibility: hidden; opacity: 0; transform: translateY(-12px); transition: opacity .25s cubic-bezier(.22,.61,.36,1), transform .25s cubic-bezier(.22,.61,.36,1), visibility 0s .25s; padding: 20px 24px 40px; overflow-y: auto; }
.drawer.open { visibility: visible; opacity: 1; transform: translateY(0); transition: opacity .25s, transform .25s, visibility 0s; }
.drawer a { display: block; padding: 14px 8px; font-size: 16px; font-weight: 600; color: var(--gla-navy-900); border-bottom: 1px solid var(--border-soft); }
.drawer a.sub { font-size: 14px; font-weight: 500; color: var(--fg-2); padding-left: 18px; }
.drawer .drawer-section-label { display: block; padding: 14px 8px 6px; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; border-bottom: none; }
.drawer .drawer-section-label.lang { color: var(--gla-royal-600); }
.drawer .drawer-section-label.adp  { color: var(--gla-gold-700); }
.drawer .btn { margin-top: 24px; width: 100%; justify-content: center; }

/* ─────────────────────────────────────────────────────────
   DARK MODE TOGGLE
───────────────────────────────────────────────────────── */
.theme-toggle { width: 38px; height: 38px; border-radius: 999px; flex: 0 0 38px; background: transparent; border: 1px solid var(--border-soft); display: grid; place-items: center; cursor: pointer; color: var(--fg-3); transition: background .18s, border-color .18s, color .18s, transform .22s; }
.theme-toggle:hover { background: var(--gla-paper-2); border-color: var(--border); color: var(--fg-1); transform: rotate(18deg) scale(1.06); }
.sun-icon  { display: none; }
.moon-icon { display: block; }
[data-theme="dark"] .sun-icon  { display: block; }
[data-theme="dark"] .moon-icon { display: none; }

/* ─────────────────────────────────────────────────────────
   BUTTONS
───────────────────────────────────────────────────────── */
.btn { font-family: var(--font-sans); font-size: 14px; font-weight: 600; letter-spacing: -.005em; line-height: 1; padding: 12px 20px; border-radius: 999px; border: 1px solid transparent; display: inline-flex; align-items: center; gap: 8px; transition: background .18s, color .18s, border-color .18s; white-space: nowrap; }
.btn--primary   { background: var(--gla-navy-800); color: #fff; box-shadow: 0 1px 0 rgba(255,255,255,.18) inset; }
.btn--primary:hover { background: var(--gla-navy-900); }
.btn--secondary { background: transparent; color: var(--gla-navy-800); border-color: var(--border); }
.btn--secondary:hover { background: var(--gla-paper-2); border-color: var(--fg-3); }
.btn--ghost     { background: transparent; color: var(--gla-navy-800); }
.btn--ghost:hover { background: var(--gla-paper-2); }
.btn--lg { font-size: 15px; padding: 15px 24px; }
.arrow { display: inline-flex; align-items: center; gap: 6px; font-size: 14px; font-weight: 600; color: var(--gla-royal-600); transition: gap .2s; }
.arrow:hover { gap: 10px; }

/* ─────────────────────────────────────────────────────────
   SECTIONS
───────────────────────────────────────────────────────── */
.section      { padding: 144px 0; background: var(--gla-paper); }
.section--tight { padding: 96px 0; }
.section--lg  { padding: 180px 0; }
.section--alt { background: var(--gla-paper-2); }
@media (max-width: 720px) { .section { padding: 96px 0; } .section--lg { padding: 120px 0; } }

.eyebrow { font-size: 13px; font-weight: 600; color: var(--gla-royal-600); display: inline-flex; align-items: center; gap: 6px; margin: 0 0 14px; }
.eyebrow.gold { color: var(--gla-gold-700); }

.section-head { text-align: center; }
.section-head h2 { font-family: var(--font-sans); font-weight: 700; font-size: clamp(32px,4vw,48px); line-height: 1.05; letter-spacing: -.025em; margin: 0 auto 18px; max-width: 22ch; text-wrap: balance; color: var(--gla-navy-900); }
.section-head p  { font-size: 18px; line-height: 1.55; color: var(--fg-2); max-width: 62ch; margin: 0 auto; }

/* ─────────────────────────────────────────────────────────
   HERO
───────────────────────────────────────────────────────── */
.hero { position: relative; overflow: hidden; background: #FFFFFF; isolation: isolate; padding: 120px 0 140px; }
.hero::before { content: ""; position: absolute; inset: -20% -10% 0 -10%; z-index: -2; background: radial-gradient(at 18% 24%,rgba(33,120,224,.32) 0,transparent 42%), radial-gradient(at 78% 18%,rgba(108,180,255,.40) 0,transparent 45%), radial-gradient(at 92% 62%,rgba(201,169,97,.20) 0,transparent 50%), radial-gradient(at 58% 86%,rgba(21,86,181,.28) 0,transparent 55%), radial-gradient(at 8% 78%,rgba(143,182,232,.42) 0,transparent 48%), linear-gradient(180deg,#F4F8FE 0%,#FFFFFF 70%); filter: blur(.5px); animation: meshDrift 24s ease-in-out infinite alternate; }
.hero::after  { content: ""; position: absolute; inset: 0; z-index: -1; background: linear-gradient(180deg,rgba(255,255,255,0) 60%,#FFFFFF 100%); pointer-events: none; }
@keyframes meshDrift { 0%{transform:translate3d(0,0,0) scale(1)} 50%{transform:translate3d(-2%,1%,0) scale(1.04)} 100%{transform:translate3d(2%,-1%,0) scale(1.02)} }
@media (prefers-reduced-motion:reduce) { .hero::before { animation: none; } }

.hero .inner { position: relative; z-index: 2; display: grid; grid-template-columns: 1.15fr 1fr; gap: 64px; align-items: center; }
.hero h1 { font-weight: 700; font-size: clamp(40px,5vw,72px); line-height: 1.02; letter-spacing: -.035em; margin: 0 0 22px; color: var(--gla-navy-900); text-wrap: balance; max-width: 18ch; }
.hero h1 em { font-style: italic; font-weight: 700; background: linear-gradient(95deg,#1556B5 0%,#2178E0 35%,#6CB4FF 65%,#C9A961 100%); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent; }
.hero .lead { font-size: 19px; line-height: 1.55; color: var(--fg-2); max-width: 52ch; margin: 0 0 32px; font-weight: 400; }
.hero .pill { display: inline-flex; align-items: center; gap: 10px; font-size: 13px; font-weight: 600; color: var(--gla-royal-600); padding: 7px 14px; border-radius: 999px; background: rgba(255,255,255,.7); border: 1px solid rgba(21,86,181,.18); backdrop-filter: blur(8px); margin-bottom: 22px; }
.hero .cta-row { display: flex; gap: 12px; flex-wrap: wrap; }
@media (max-width: 940px) { .hero .inner { grid-template-columns: 1fr; gap: 40px; } }

/* Hero blobs */
.hero-blobs { position: absolute; top: -48px; right: -48px; width: 520px; height: 520px; pointer-events: none; z-index: 1; overflow: hidden; }
.blob { position: absolute; border-radius: 50%; filter: blur(72px); }
.blob-1 { width: 300px; height: 300px; background: rgba(33,120,224,.38); top: 24px; right: 24px; animation: blobPulse 10s ease-in-out infinite alternate; }
.blob-2 { width: 210px; height: 210px; background: rgba(201,169,97,.28); top: 120px; right: 160px; animation: blobPulse 13s ease-in-out infinite alternate; animation-delay: -4s; }
.blob-3 { width: 170px; height: 170px; background: rgba(108,180,255,.45); top: 240px; right: 50px; animation: blobPulse 8s ease-in-out infinite alternate; animation-delay: -6s; }
@keyframes blobPulse { 0%{transform:scale(1) translate(0,0);opacity:.55} 50%{transform:scale(1.14) translate(-18px,12px);opacity:.80} 100%{transform:scale(.92) translate(8px,-10px);opacity:.50} }
@media (prefers-reduced-motion:reduce) { .blob { animation: none; } }

/* Hero division cards */
.hero-div-wrap { display: flex; flex-direction: column; gap: 14px; position: relative; z-index: 2; }
.hero-div-card { background: rgba(255,255,255,.76); backdrop-filter: saturate(160%) blur(20px); -webkit-backdrop-filter: saturate(160%) blur(20px); border: 1px solid rgba(21,86,181,.14); border-radius: 18px; padding: 22px 24px; box-shadow: 0 8px 28px -8px rgba(5,40,104,.12); transition: box-shadow .22s, border-color .22s; text-decoration: none; display: block; }
.hero-div-card:hover { box-shadow: 0 16px 36px -12px rgba(5,40,104,.18); border-color: rgba(21,86,181,.24); }
.hero-div-card .dc-head { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 12px; }
.hero-div-card .dc-icon { width: 38px; height: 38px; border-radius: 10px; flex: 0 0 38px; display: grid; place-items: center; font-size: 20px; }
.dc-icon--lang { background: linear-gradient(135deg,#EAF1FB,#DCE7F5); color: var(--gla-royal-600); }
.dc-icon--adp  { background: linear-gradient(135deg,#F5ECD3,#E4CC8A); color: var(--gla-gold-700); }
.hero-div-card .dc-name { font-weight: 700; font-size: 15px; color: var(--gla-navy-900); margin-bottom: 2px; }
.hero-div-card .dc-sub  { font-size: 12px; color: var(--fg-3); line-height: 1.45; }
.hero-div-card .dc-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.hero-div-card .dc-tags span { font-size: 12px; font-weight: 500; color: var(--gla-navy-800); background: var(--gla-paper-2); border: 1px solid var(--border-soft); padding: 4px 10px; border-radius: 999px; }
.hero-meta { display: flex; gap: 18px; flex-wrap: wrap; margin-top: 6px; }
.hero-meta span { font-size: 12px; color: var(--fg-3); display: flex; align-items: center; gap: 5px; }

/* Spline 3D */
.hero-spline-wrap { position: absolute; left: 0; right: 0; bottom: 0; height: 70%; z-index: 1; pointer-events: none; overflow: hidden; }
.hero-spline-canvas { display: block; width: 100%; height: 100%; }
.hero-spline-fade-top { position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: linear-gradient(to bottom,#fff 0%,#fff 55%,transparent 82%); z-index: 2; pointer-events: none; }
.hero-spline-fade-br  { position: absolute; bottom: 0; right: 0; width: 220px; height: 80px; background: radial-gradient(ellipse at 100% 100%,#fff 0%,transparent 58%); z-index: 3; pointer-events: none; }

/* ─────────────────────────────────────────────────────────
   ACCREDITATION MARQUEE
───────────────────────────────────────────────────────── */
.proof { background: #FFFFFF; padding: 36px 0 48px; border-bottom: 1px solid var(--border-soft); }
.proof .lbl { font-size: 12px; font-weight: 600; color: var(--fg-3); letter-spacing: .02em; text-align: center; margin: 0 0 20px; }
.marquee-outer { overflow: hidden; mask-image: linear-gradient(to right,transparent 0%,#000 10%,#000 90%,transparent 100%); -webkit-mask-image: linear-gradient(to right,transparent 0%,#000 10%,#000 90%,transparent 100%); }
.marquee-track { display: flex; align-items: center; gap: 56px; width: max-content; animation: marqueeScroll 30s linear infinite; will-change: transform; }
.marquee-track:hover { animation-play-state: paused; }
@keyframes marqueeScroll { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }
.proof .badge { display: inline-flex; align-items: center; gap: 10px; font-weight: 700; font-size: 16px; color: var(--fg-3); letter-spacing: -.005em; white-space: nowrap; }
.proof .badge i { font-size: 22px; color: var(--gla-navy-700); opacity: .65; }

/* ─────────────────────────────────────────────────────────
   FEATURE CARDS
───────────────────────────────────────────────────────── */
.feat { position: relative; background: linear-gradient(170deg,#FAFBFC 0%,#FFFFFF 60%); border: 1px solid var(--border-soft); border-radius: 14px; padding: 32px 28px; transition: transform .25s cubic-bezier(.22,.61,.36,1), box-shadow .25s, border-color .25s; overflow: hidden; }
.feat::before { content: ""; position: absolute; top: 0; left: 24px; right: 24px; height: 2px; background: linear-gradient(90deg,var(--gla-royal-600),var(--gla-azure-500),var(--gla-gold-500)); border-radius: 2px; opacity: .85; }
.feat:hover { transform: translateY(-3px); box-shadow: 0 16px 40px -16px rgba(5,40,104,.14); border-color: var(--border); }
.feat .ic { width: 48px; height: 48px; border-radius: 10px; display: grid; place-items: center; color: var(--gla-royal-600); background: linear-gradient(135deg,#EAF1FB,#DCE7F5); font-size: 24px; margin-bottom: 20px; }
.feat h3 { font-weight: 700; font-size: 22px; line-height: 1.15; letter-spacing: -.015em; color: var(--gla-navy-900); margin: 0 0 10px; }
.feat p  { font-size: 15px; line-height: 1.6; color: var(--fg-2); margin: 0; }

/* ─────────────────────────────────────────────────────────
   STAT STRIP
───────────────────────────────────────────────────────── */
.stats { background: linear-gradient(180deg,#FAFBFC 0%,#FFFFFF 100%); border-block: 1px solid var(--border-soft); }
.stats .row { display: grid; grid-template-columns: repeat(4,1fr); gap: 8px; padding: 72px 0; }
.stats .col { padding: 0 24px; border-left: 1px solid var(--border-soft); }
.stats .col:first-child { border-left: none; }
.stats .num { font-weight: 700; font-size: 64px; line-height: 1; color: var(--gla-navy-900); letter-spacing: -.035em; }
.stats .num sup { font-size: 28px; color: var(--gla-gold-600); vertical-align: super; top: -8px; position: relative; margin-left: 4px; }
.stats .lbl { font-size: 13px; font-weight: 500; color: var(--fg-3); margin-top: 14px; }
.count-num { display: inline-block; min-width: 1.5ch; }
@media (max-width: 720px) { .stats .row { grid-template-columns: 1fr 1fr; } }

/* ─────────────────────────────────────────────────────────
   PROGRAMME CARDS
───────────────────────────────────────────────────────── */
.grid-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; margin-top: 56px; }
@media (max-width: 980px) { .grid-3 { grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px) { .grid-3 { grid-template-columns: 1fr; } }

.prog { display: flex; flex-direction: column; background: #fff; border: 1px solid var(--border-soft); border-radius: 14px; overflow: hidden; box-shadow: var(--shadow-xs); transition: transform .28s cubic-bezier(.22,.61,.36,1), box-shadow .28s, border-color .28s; text-decoration: none; }
.prog:hover { box-shadow: 0 20px 40px -16px rgba(5,40,104,.18); transform: translateY(-3px); border-color: var(--border); }
.prog .media { aspect-ratio: 4/3; position: relative; border-bottom: 1px solid var(--border-soft); }
.prog .body  { padding: 26px; display: flex; flex-direction: column; flex: 1; }
.prog h3     { font-weight: 700; font-size: 22px; line-height: 1.15; letter-spacing: -.015em; margin: 0 0 10px; color: var(--gla-navy-900); }
.prog p      { font-size: 15px; line-height: 1.6; color: var(--fg-2); margin: 0; }
.prog .meta  { display: flex; gap: 16px; flex-wrap: wrap; margin-top: 16px; font-size: 12.5px; color: var(--fg-3); font-weight: 500; }
.prog .meta span { display: inline-flex; align-items: center; gap: 6px; }
.prog .meta i    { font-size: 14px; color: var(--gla-royal-600); }
.prog .more      { display: inline-flex; align-items: center; gap: 6px; font-size: 14px; font-weight: 600; color: var(--gla-royal-600); margin-top: auto; padding-top: 22px; transition: gap .2s; }
.prog:hover .more { gap: 10px; }

.ic-big { position: absolute; left: 24px; top: 24px; width: 56px; height: 56px; border-radius: 14px; background: rgba(255,255,255,.92); border: 1px solid var(--border-soft); display: grid; place-items: center; color: var(--gla-royal-600); font-size: 28px; backdrop-filter: blur(8px); }
.age    { position: absolute; right: 16px; top: 16px; font-size: 12px; font-weight: 500; color: var(--gla-navy-900); background: rgba(255,255,255,.92); padding: 5px 12px; border-radius: 999px; border: 1px solid var(--border-soft); backdrop-filter: blur(8px); }

/* Programme media gradients — language */
.m-intensive { background: radial-gradient(at 28% 32%,rgba(33,120,224,.30) 0,transparent 55%),radial-gradient(at 78% 72%,rgba(201,169,97,.18) 0,transparent 60%),linear-gradient(170deg,#DCE7F5 0%,#F6F7FA 70%); }
.m-junior    { background: radial-gradient(at 30% 70%,rgba(108,180,255,.34) 0,transparent 55%),radial-gradient(at 78% 28%,rgba(201,169,97,.16) 0,transparent 60%),linear-gradient(170deg,#E8F1FE 0%,#FAFBFC 70%); }
.m-business  { background: radial-gradient(at 25% 25%,rgba(21,86,181,.36) 0,transparent 55%),radial-gradient(at 80% 80%,rgba(2,28,73,.18) 0,transparent 60%),linear-gradient(170deg,#DCE7F5 0%,#EAF1FB 70%); }
.m-ielts     { background: radial-gradient(at 22% 78%,rgba(176,136,50,.24) 0,transparent 55%),radial-gradient(at 78% 22%,rgba(33,120,224,.30) 0,transparent 60%),linear-gradient(170deg,#F5ECD3 0%,#EAF1FB 70%); }
.m-vip       { background: radial-gradient(at 50% 50%,rgba(201,169,97,.28) 0,transparent 55%),radial-gradient(at 80% 80%,rgba(21,86,181,.18) 0,transparent 60%),linear-gradient(170deg,#F5ECD3 0%,#FAFBFC 70%); }
.m-camp      { background: radial-gradient(at 30% 25%,rgba(108,180,255,.40) 0,transparent 55%),radial-gradient(at 75% 75%,rgba(201,169,97,.22) 0,transparent 60%),linear-gradient(170deg,#DCE7F5 0%,#F5ECD3 100%); }
/* Programme media gradients — academic */
.m-primary   { background: radial-gradient(at 28% 72%,rgba(201,169,97,.32) 0,transparent 55%),radial-gradient(at 78% 28%,rgba(33,120,224,.16) 0,transparent 60%),linear-gradient(170deg,#F5ECD3 0%,#EAF1FB 100%); }
.m-lower-sec { background: radial-gradient(at 22% 30%,rgba(21,86,181,.28) 0,transparent 55%),radial-gradient(at 78% 78%,rgba(108,180,255,.22) 0,transparent 60%),linear-gradient(170deg,#DCE7F5 0%,#F6F7FA 70%); }
.m-igcse     { background: radial-gradient(at 30% 30%,rgba(2,28,73,.28) 0,transparent 55%),radial-gradient(at 78% 72%,rgba(33,120,224,.24) 0,transparent 60%),linear-gradient(170deg,#D0DCF0 0%,#EAF1FB 70%); }
.m-alevel    { background: radial-gradient(at 25% 25%,rgba(5,40,104,.26) 0,transparent 55%),radial-gradient(at 80% 80%,rgba(201,169,97,.20) 0,transparent 60%),linear-gradient(170deg,#C8D5EC 0%,#F5ECD3 100%); }
.m-ibdp      { background: radial-gradient(at 35% 35%,rgba(11,58,140,.28) 0,transparent 55%),radial-gradient(at 75% 75%,rgba(108,180,255,.30) 0,transparent 60%),linear-gradient(170deg,#D4E2F4 0%,#EAF1FB 70%); }
.m-lang-exam { background: radial-gradient(at 28% 72%,rgba(176,136,50,.26) 0,transparent 55%),radial-gradient(at 78% 28%,rgba(201,169,97,.30) 0,transparent 60%),linear-gradient(170deg,#F5ECD3 0%,#FFFBF0 70%); }

/* ─────────────────────────────────────────────────────────
   DIVISION BADGE
───────────────────────────────────────────────────────── */
.division-badge { display: inline-flex; align-items: center; gap: 7px; font-size: 12px; font-weight: 700; letter-spacing: .04em; padding: 5px 13px; border-radius: 999px; margin-bottom: 8px; }
.division-badge.lang { background: var(--gla-sky-100); color: var(--gla-royal-600); }
.division-badge.adp  { background: var(--gla-gold-100); color: var(--gla-gold-700); }

/* ─────────────────────────────────────────────────────────
   TWO-COL
───────────────────────────────────────────────────────── */
.two-col { display: grid; grid-template-columns: 1.1fr 1fr; gap: 64px; align-items: center; }
.two-col.reverse { grid-template-columns: 1fr 1.1fr; }
.two-col h2 { font-weight: 700; font-size: clamp(30px,3.6vw,44px); line-height: 1.06; letter-spacing: -.025em; margin: 14px 0 18px; color: var(--gla-navy-900); }
.two-col p  { font-size: 17px; line-height: 1.65; color: var(--fg-2); margin: 0 0 16px; }
@media (max-width: 880px) { .two-col, .two-col.reverse { grid-template-columns: 1fr; gap: 32px; } }
.photo-frame { aspect-ratio: 4/3; border-radius: 16px; border: 1px solid var(--border-soft); background: radial-gradient(at 30% 30%,rgba(33,120,224,.28) 0,transparent 60%),radial-gradient(at 75% 80%,rgba(201,169,97,.16) 0,transparent 55%),linear-gradient(170deg,#DCE7F5 0%,#F6F7FA 100%); position: relative; overflow: hidden; box-shadow: var(--shadow-lg); }
.photo-frame[data-label]::after { content: attr(data-label); position: absolute; left: 20px; bottom: 20px; font-size: 12px; font-weight: 600; color: var(--gla-navy-900); background: rgba(255,255,255,.92); padding: 6px 12px; border-radius: 999px; border: 1px solid var(--border-soft); }

/* ─────────────────────────────────────────────────────────
   CHECKS LIST
───────────────────────────────────────────────────────── */
.checks { list-style: none; padding: 0; margin: 16px 0 0; }
.checks li { display: flex; gap: 12px; align-items: flex-start; padding: 12px 0; border-top: 1px solid var(--border-soft); font-size: 15.5px; line-height: 1.55; color: var(--fg-1); }
.checks li:first-child { border-top: none; }
.checks li i { flex: 0 0 24px; width: 24px; height: 24px; border-radius: 999px; background: linear-gradient(135deg,#EAF1FB,#DCE7F5); color: var(--gla-royal-600); display: grid; place-items: center; font-size: 14px; margin-top: 2px; }

/* ─────────────────────────────────────────────────────────
   QUOTE BAND
───────────────────────────────────────────────────────── */
.quote-band { background: linear-gradient(180deg,#FFFFFF 0%,#F6F7FA 100%); padding: 180px 0; position: relative; overflow: hidden; }
.quote-band .inner { position: relative; z-index: 2; max-width: 920px; margin: 0 auto; text-align: center; }
.quote-band .mark { display: block; margin: 0 auto 24px; font-weight: 700; font-size: 64px; line-height: 1; color: var(--gla-gold-500); }
.quote-band blockquote { font-weight: 600; font-size: clamp(26px,3.2vw,38px); line-height: 1.25; letter-spacing: -.02em; margin: 0 0 36px; text-wrap: balance; color: var(--gla-navy-900); }
.quote-band cite { display: inline-flex; align-items: center; gap: 14px; font-style: normal; font-size: 14px; font-weight: 600; color: var(--gla-navy-900); }
.quote-band cite .avatar { width: 44px; height: 44px; border-radius: 999px; background: linear-gradient(135deg,#DCE7F5,#F6F7FA); border: 1px solid var(--border-soft); display: grid; place-items: center; color: var(--gla-navy-800); font-weight: 700; font-size: 16px; }
.quote-band cite .who small { display: block; margin-top: 2px; color: var(--fg-3); font-weight: 400; font-size: 13px; }

/* ─────────────────────────────────────────────────────────
   CTA CARD
───────────────────────────────────────────────────────── */
.cta-wrap { padding: 144px 0 180px; background: #FFFFFF; }
.cta-card { position: relative; background: radial-gradient(at 8% 0%,rgba(33,120,224,.18) 0,transparent 40%),radial-gradient(at 95% 20%,rgba(108,180,255,.22) 0,transparent 45%),radial-gradient(at 60% 110%,rgba(201,169,97,.14) 0,transparent 50%),linear-gradient(170deg,#F4F8FE 0%,#FFFFFF 60%,#FAFBFC 100%); border: 1px solid var(--border-soft); border-radius: 24px; padding: 64px 56px; display: grid; grid-template-columns: 1.4fr 1fr; gap: 56px; align-items: center; box-shadow: 0 24px 48px -24px rgba(5,40,104,.10); overflow: hidden; }
.cta-card h2 { font-weight: 700; font-size: clamp(28px,3.2vw,42px); line-height: 1.05; letter-spacing: -.025em; margin: 12px 0 16px; color: var(--gla-navy-900); }
.cta-card p  { color: var(--fg-2); font-size: 16px; line-height: 1.6; margin: 0 0 28px; }
.cta-card .dates { background: rgba(255,255,255,.78); backdrop-filter: blur(10px); border: 1px solid var(--border-soft); border-radius: 14px; padding: 24px; box-shadow: var(--shadow-xs); }
.cta-card .dates h5 { font-size: 13px; font-weight: 600; color: var(--gla-royal-600); margin: 0 0 16px; }
.cta-card .date-item { display: flex; align-items: flex-start; gap: 14px; padding: 12px 0; border-bottom: 1px solid var(--border-soft); }
.cta-card .date-item:last-child { border-bottom: 0; padding-bottom: 0; }
.cta-card .date-item:first-of-type { padding-top: 0; }
.cta-card .date-item .d { font-weight: 700; font-size: 16px; color: var(--gla-navy-900); line-height: 1.2; min-width: 64px; }
.cta-card .date-item .l { font-size: 13px; color: var(--fg-2); line-height: 1.5; }
.cta-card .date-item .l strong { display: block; font-weight: 600; font-size: 14px; color: var(--fg-1); margin-bottom: 2px; }
@media (max-width: 880px) { .cta-card { grid-template-columns: 1fr; padding: 40px 28px; gap: 32px; } }

/* ─────────────────────────────────────────────────────────
   INNER PAGE HERO
───────────────────────────────────────────────────────── */
.hero--page { background: linear-gradient(180deg,#F4F8FE 0%,#FFFFFF 100%); padding: 80px 0 64px; border-bottom: 1px solid var(--border-soft); }
.hero--page h1 { font-weight: 700; font-size: clamp(36px,4.5vw,60px); line-height: 1.04; letter-spacing: -.03em; margin: 14px 0 18px; color: var(--gla-navy-900); max-width: 20ch; text-wrap: balance; }
.hero--page .lead { font-size: 19px; line-height: 1.55; color: var(--fg-2); max-width: 60ch; margin: 0; }
.crumbs { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--fg-3); margin-bottom: 8px; }
.crumbs a { color: var(--fg-3); transition: color .18s; }
.crumbs a:hover { color: var(--gla-navy-800); }

/* ─────────────────────────────────────────────────────────
   STEPS (admissions journey)
───────────────────────────────────────────────────────── */
.steps { display: grid; grid-template-columns: repeat(4,1fr); gap: 24px; margin-top: 56px; }
.step { position: relative; padding: 32px 26px 28px; background: #fff; border: 1px solid var(--border-soft); border-radius: 14px; box-shadow: var(--shadow-xs); }
.step .n { position: absolute; top: -16px; left: 26px; width: 36px; height: 36px; border-radius: 50%; background: var(--gla-navy-800); color: #fff; font-weight: 700; font-size: 16px; display: grid; place-items: center; box-shadow: 0 4px 12px rgba(5,40,104,.20); }
.step h3 { font-weight: 700; font-size: 18px; letter-spacing: -.01em; color: var(--gla-navy-900); margin: 14px 0 10px; }
.step p  { font-size: 14.5px; color: var(--fg-2); line-height: 1.6; margin: 0; }
@media (max-width: 980px) { .steps { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .steps { grid-template-columns: 1fr; } }

/* ─────────────────────────────────────────────────────────
   FORM
───────────────────────────────────────────────────────── */
.form-card { background: #fff; border: 1px solid var(--border-soft); border-radius: 18px; padding: 36px; box-shadow: var(--shadow-md); }
.form-card h2 { font-weight: 700; font-size: 26px; letter-spacing: -.02em; margin: 0 0 8px; color: var(--gla-navy-900); }
.form-card p.intro { color: var(--fg-2); margin: 0 0 24px; font-size: 15px; }
.field-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 14px; }
.field.full { grid-column: 1 / -1; }
.field label { font-size: 13px; font-weight: 600; color: var(--gla-navy-900); }
.field input, .field select, .field textarea { font-family: var(--font-sans); font-size: 14px; padding: 11px 13px; background: #fff; border: 1px solid var(--border); border-radius: 8px; color: var(--fg-1); transition: border-color .18s, box-shadow .18s; }
.field textarea { min-height: 110px; resize: vertical; }
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--gla-royal-600); box-shadow: 0 0 0 3px rgba(33,120,224,.18); }
.form-actions { display: flex; justify-content: flex-end; gap: 10px; margin-top: 20px; flex-wrap: wrap; }

/* ─────────────────────────────────────────────────────────
   ADDRESS CARD & MAP
───────────────────────────────────────────────────────── */
.contact-grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: 56px; align-items: start; }
@media (max-width: 980px) { .contact-grid { grid-template-columns: 1fr; gap: 32px; } }
.address-card { display: flex; flex-direction: column; gap: 18px; }
.address-card .info { display: flex; gap: 14px; padding: 18px; background: var(--gla-paper-2); border: 1px solid var(--border-soft); border-radius: 12px; }
.address-card .info i { flex: 0 0 36px; width: 36px; height: 36px; border-radius: 10px; background: linear-gradient(135deg,#EAF1FB,#DCE7F5); color: var(--gla-royal-600); display: grid; place-items: center; font-size: 18px; }
.address-card .info h4 { font-size: 13px; font-weight: 700; color: var(--gla-navy-900); margin: 0 0 4px; letter-spacing: .04em; text-transform: uppercase; }
.address-card .info p, .address-card .info a { font-size: 14.5px; color: var(--fg-2); margin: 0; line-height: 1.55; }
.map-wrap { border: 1px solid var(--border-soft); border-radius: 16px; overflow: hidden; box-shadow: var(--shadow-md); aspect-ratio: 4/3; background: linear-gradient(170deg,#DCE7F5 0%,#F6F7FA 100%); position: relative; }
.map-wrap iframe { width: 100%; height: 100%; border: 0; display: block; }

/* ─────────────────────────────────────────────────────────
   PARTNER STRIPS & DIRECTOR
───────────────────────────────────────────────────────── */
.partners-strip { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; margin-top: 36px; }
.partner { display: flex; align-items: center; gap: 14px; padding: 18px 20px; background: #fff; border: 1px solid var(--border-soft); border-radius: 12px; box-shadow: var(--shadow-xs); transition: border-color .18s, box-shadow .18s; }
.partner:hover { border-color: var(--border); box-shadow: var(--shadow-md); }
.partner .badge-p { width: 44px; height: 44px; border-radius: 10px; flex: 0 0 44px; background: linear-gradient(135deg,#EAF1FB,#DCE7F5); color: var(--gla-royal-600); display: grid; place-items: center; font-size: 22px; }
.partner strong { font-weight: 700; font-size: 15px; color: var(--gla-navy-900); letter-spacing: -.01em; display: block; }
.partner small  { font-size: 12px; color: var(--fg-3); margin-top: 2px; display: block; }
@media (max-width: 720px) { .partners-strip { grid-template-columns: 1fr; } }

.director { display: grid; grid-template-columns: 280px 1fr; gap: 40px; align-items: start; background: linear-gradient(170deg,#FAFBFC 0%,#FFFFFF 60%); border: 1px solid var(--border-soft); border-radius: 20px; padding: 40px; box-shadow: var(--shadow-xs); }
.director .avatar-lg { aspect-ratio: 1; border-radius: 16px; background: radial-gradient(at 35% 35%,rgba(33,120,224,.30) 0,transparent 60%),radial-gradient(at 70% 75%,rgba(201,169,97,.20) 0,transparent 55%),linear-gradient(170deg,#DCE7F5 0%,#F6F7FA 100%); border: 1px solid var(--border-soft); position: relative; overflow: hidden; }
.director .avatar-lg::after { content: "JE"; position: absolute; inset: 0; display: grid; place-items: center; font-weight: 900; font-size: 80px; color: rgba(5,40,104,.18); letter-spacing: -.02em; }
.director h3    { font-weight: 700; font-size: 28px; letter-spacing: -.02em; color: var(--gla-navy-900); margin: 0 0 4px; }
.director .role { font-size: 14px; color: var(--gla-royal-600); font-weight: 600; margin: 0 0 18px; }
.director p     { font-size: 16.5px; line-height: 1.7; color: var(--fg-2); margin: 0 0 14px; }
@media (max-width: 720px) { .director { grid-template-columns: 1fr; padding: 28px; gap: 24px; } }

/* ─────────────────────────────────────────────────────────
   LANGUAGES
───────────────────────────────────────────────────────── */
.langs { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 24px; }
.lang  { display: inline-flex; align-items: center; gap: 8px; background: #fff; border: 1px solid var(--border-soft); padding: 9px 16px; border-radius: 999px; font-size: 14px; font-weight: 500; color: var(--fg-1); box-shadow: var(--shadow-xs); }
.lang .flag { width: 18px; height: 18px; border-radius: 50%; background: linear-gradient(135deg,#DCE7F5,#EAF1FB); display: grid; place-items: center; font-size: 10px; color: var(--gla-navy-800); font-weight: 700; }

/* ─────────────────────────────────────────────────────────
   FAQ
───────────────────────────────────────────────────────── */
.faq { display: grid; gap: 12px; max-width: 880px; margin: 56px auto 0; }
.faq details { background: #fff; border: 1px solid var(--border-soft); border-radius: 12px; padding: 20px 24px; transition: border-color .18s, box-shadow .18s; }
.faq details[open] { border-color: var(--border); box-shadow: var(--shadow-sm); }
.faq summary { font-weight: 700; font-size: 17px; color: var(--gla-navy-900); cursor: pointer; list-style: none; display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; font-weight: 700; font-size: 22px; color: var(--gla-royal-600); transition: transform .2s; flex-shrink: 0; }
.faq details[open] summary::after { transform: rotate(45deg); }
.faq details p { margin: 14px 0 0; font-size: 15px; line-height: 1.65; color: var(--fg-2); }

/* ─────────────────────────────────────────────────────────
   FOOTER
───────────────────────────────────────────────────────── */
.foot { background: var(--gla-paper-2); color: var(--fg-2); padding: 80px 0 32px; font-size: 14px; line-height: 1.7; border-top: 1px solid var(--border-soft); }
.foot .row { display: grid; grid-template-columns: 1.6fr repeat(4,1fr); gap: 48px; }
.foot img.logo { height: 56px; margin-bottom: 18px; }
.foot .tag { font-size: 13.5px; color: var(--fg-2); max-width: 32ch; line-height: 1.6; margin: 0 0 18px; }
.foot h5 { font-size: 12.5px; font-weight: 700; color: var(--gla-navy-900); margin: 0 0 18px; text-transform: uppercase; letter-spacing: .06em; }
.foot ul { margin: 0; padding: 0; list-style: none; }
.foot ul li { margin-bottom: 10px; }
.foot ul li a { color: var(--fg-2); transition: color .18s; }
.foot ul li a:hover { color: var(--gla-navy-800); }
.foot .contact-col { display: flex; flex-direction: column; gap: 10px; font-size: 13.5px; }
.foot .contact-col a, .foot .contact-col span { display: flex; align-items: flex-start; gap: 10px; color: var(--fg-2); line-height: 1.45; }
.foot .contact-col i { color: var(--gla-royal-600); margin-top: 3px; font-size: 14px; flex: 0 0 14px; }
.foot .socials { display: flex; gap: 8px; margin-top: 16px; }
.foot .socials a { width: 36px; height: 36px; border-radius: 999px; display: grid; place-items: center; background: #fff; border: 1px solid var(--border-soft); color: var(--gla-navy-800); transition: background .18s, border-color .18s; }
.foot .socials a:hover { background: var(--gla-paper); border-color: var(--border); }
.foot .legal { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px; margin-top: 56px; padding-top: 24px; border-top: 1px solid var(--border-soft); font-size: 12.5px; color: var(--fg-3); }
.foot .legal-links { display: flex; gap: 20px; }
.foot .legal a { color: var(--fg-3); transition: color .18s; }
.foot .legal a:hover { color: var(--gla-navy-800); }
@media (max-width: 980px) { .foot .row { grid-template-columns: 1fr 1fr; gap: 32px; } }
@media (max-width: 600px) { .foot .row { grid-template-columns: 1fr; } }

/* ─────────────────────────────────────────────────────────
   SCROLL REVEAL
───────────────────────────────────────────────────────── */
@media (prefers-reduced-motion: no-preference) {
  [data-reveal] { opacity: 0; transition: opacity .65s cubic-bezier(.22,.61,.36,1), transform .65s cubic-bezier(.22,.61,.36,1); }
  [data-reveal]:not([data-reveal="left"]):not([data-reveal="right"]):not([data-reveal="scale"]) { transform: translateY(32px); }
  [data-reveal="left"]  { transform: translateX(-36px); }
  [data-reveal="right"] { transform: translateX(36px); }
  [data-reveal="scale"] { transform: scale(.94) translateY(12px); }
  [data-reveal].revealed { opacity: 1; transform: translateY(0) translateX(0) scale(1); }
  [data-reveal-group] > * { opacity: 0; transform: translateY(32px); transition: opacity .65s cubic-bezier(.22,.61,.36,1), transform .65s cubic-bezier(.22,.61,.36,1); }
  [data-reveal-group].revealed > * { opacity: 1; transform: translateY(0); }
  [data-reveal-group].revealed > *:nth-child(1) { transition-delay: 0s; }
  [data-reveal-group].revealed > *:nth-child(2) { transition-delay: .09s; }
  [data-reveal-group].revealed > *:nth-child(3) { transition-delay: .18s; }
  [data-reveal-group].revealed > *:nth-child(4) { transition-delay: .27s; }
  [data-reveal-group].revealed > *:nth-child(5) { transition-delay: .36s; }
  [data-reveal-group].revealed > *:nth-child(6) { transition-delay: .45s; }
}
@keyframes pageIn { from{opacity:0;transform:translateY(12px)} to{opacity:1;transform:translateY(0)} }
.page-entering main { animation: pageIn .44s cubic-bezier(.22,.61,.36,1) both; }
.page-exiting { pointer-events: none; transition: opacity .26s ease, transform .26s ease; opacity: 0; transform: translateY(-10px); }

/* ─────────────────────────────────────────────────────────
   DARK MODE
───────────────────────────────────────────────────────── */
[data-theme="dark"] {
  color-scheme: dark;
  --gla-paper: #0E1525; --gla-paper-2: #131C2E; --gla-paper-3: #192235;
  --gla-ink: #E6EDF6; --gla-ink-2: #9BACC4; --gla-ink-3: #5E718C;
  --gla-line: #263350; --gla-line-soft: #1A2640;
  --fg-1: #E6EDF6; --fg-2: #9BACC4; --fg-3: #5E718C;
  --border: #263350; --border-soft: #1A2640;
  --spline-fade-from: #0E1525;
}
[data-theme="dark"] .mast { background: rgba(14,21,37,.92); border-bottom-color: #1A2640; }
[data-theme="dark"] .hero { background: #0E1525; }
[data-theme="dark"] .hero::before { background: radial-gradient(at 18% 24%,rgba(33,120,224,.18) 0,transparent 42%),radial-gradient(at 78% 18%,rgba(108,180,255,.20) 0,transparent 45%),linear-gradient(180deg,#090F1E 0%,#0E1525 70%); }
[data-theme="dark"] .hero::after { background: linear-gradient(180deg,rgba(14,21,37,0) 60%,#0E1525 100%); }
[data-theme="dark"] .hero h1 { color: #E6EDF6; }
[data-theme="dark"] .hero .lead { color: #9BACC4; }
[data-theme="dark"] .hero-div-card { background: rgba(19,28,46,.86); border-color: rgba(38,51,80,.90); }
[data-theme="dark"] .hero-div-card .dc-name { color: #E6EDF6; }
[data-theme="dark"] .hero-spline-fade-top { background: linear-gradient(to bottom,#0E1525 0%,#0E1525 55%,transparent 82%); }
[data-theme="dark"] .hero-spline-fade-br  { background: radial-gradient(ellipse at 100% 100%,#0E1525 0%,transparent 58%); }
[data-theme="dark"] .proof { background: #0E1525; border-bottom-color: #1A2640; }
[data-theme="dark"] .section  { background: #0E1525; }
[data-theme="dark"] .section--alt { background: #131C2E; }
[data-theme="dark"] .feat { background: linear-gradient(170deg,#131C2E 0%,#192235 60%); border-color: #1A2640; }
[data-theme="dark"] .feat h3 { color: #E6EDF6; }
[data-theme="dark"] .stats { background: linear-gradient(180deg,#131C2E 0%,#0E1525 100%); border-block-color: #1A2640; }
[data-theme="dark"] .stats .num { color: #E6EDF6; }
[data-theme="dark"] .prog { background: #131C2E; border-color: #1A2640; }
[data-theme="dark"] .prog h3 { color: #E6EDF6; }
[data-theme="dark"] .quote-band { background: linear-gradient(180deg,#0E1525 0%,#131C2E 100%); }
[data-theme="dark"] .quote-band blockquote { color: #E6EDF6; }
[data-theme="dark"] .cta-wrap { background: #0E1525; }
[data-theme="dark"] .cta-card { background: linear-gradient(170deg,#131C2E 0%,#192235 60%,#131C2E 100%); border-color: #263350; }
[data-theme="dark"] .cta-card h2 { color: #E6EDF6; }
[data-theme="dark"] .cta-card .dates { background: rgba(255,255,255,.04); border-color: #1A2640; }
[data-theme="dark"] .foot { background: #090F1E; border-top-color: #1A2640; }
[data-theme="dark"] .hero--page { background: linear-gradient(180deg,#090F1E 0%,#0E1525 100%); border-bottom-color: #1A2640; }
[data-theme="dark"] .hero--page h1 { color: #E6EDF6; }
[data-theme="dark"] .form-card { background: #131C2E; border-color: #263350; }
[data-theme="dark"] .field input, [data-theme="dark"] .field select, [data-theme="dark"] .field textarea { background: #0E1525; border-color: #263350; color: #E6EDF6; }
[data-theme="dark"] .step { background: #131C2E; border-color: #263350; }
[data-theme="dark"] .step h3 { color: #E6EDF6; }
[data-theme="dark"] .director { background: linear-gradient(170deg,#131C2E 0%,#192235 60%); border-color: #1A2640; }
[data-theme="dark"] .faq details { background: #131C2E; border-color: #263350; }
[data-theme="dark"] .faq summary { color: #E6EDF6; }
[data-theme="dark"] .section-head h2 { color: #E6EDF6; }
[data-theme="dark"] .two-col h2 { color: #E6EDF6; }
[data-theme="dark"] .address-card .info { background: #131C2E; border-color: #263350; }
[data-theme="dark"] .partner { background: #131C2E; border-color: #263350; }
[data-theme="dark"] .partner strong { color: #E6EDF6; }
[data-theme="dark"] .scroll-progress { background: linear-gradient(90deg,#4D8AF0,#6CB4FF,#C9A961); }
[data-theme="dark"] .theme-toggle { border-color: #263350; color: #5E718C; }
[data-theme="dark"] .theme-toggle:hover { background: #192235; border-color: #263350; color: #9BACC4; }
[data-theme="dark"] .mast .dd { background: #131C2E; border-color: #263350; }
[data-theme="dark"] .mast .dd a strong { color: #E6EDF6; }
[data-theme="dark"] .drawer { background: #0E1525; }
[data-theme="dark"] .drawer a { color: #E6EDF6; border-bottom-color: #1A2640; }

/* ─────────────────────────────────────────────────────────
   WORDPRESS THEME COMPONENT STYLES
   (matches header.php, front-page.php, and page templates)
───────────────────────────────────────────────────────── */

/* Scroll progress */
#scroll-progress { position: fixed; top: 0; left: 0; right: 0; height: 3px; z-index: 9999; background: linear-gradient(90deg, var(--gla-royal-600), var(--gla-azure-500), var(--gla-gold-500)); transform-origin: left; transform: scaleX(0); pointer-events: none; }

/* ══ HEADER ═══════════════════════════════════════════════ */
.site-header {
  position: sticky; top: 0; z-index: 1000;
  background: rgba(255,255,255,.95);
  backdrop-filter: saturate(180%) blur(16px);
  -webkit-backdrop-filter: saturate(180%) blur(16px);
  border-bottom: 1px solid var(--gla-line-soft);
  transition: box-shadow .2s;
}
.site-header.scrolled { box-shadow: 0 2px 20px rgba(5,40,104,.10); }

/* Fixed height — logo cannot push this open */
.header-inner {
  display: flex; align-items: center; justify-content: space-between;
  height: 72px; gap: 32px; overflow: visible;
}

/* Logo — fixed 40px tall, overrides WP inline width/height attrs */
.site-logo { display: flex; align-items: center; flex-shrink: 0; text-decoration: none; }
.site-logo a,
.site-logo .custom-logo-link { display: flex; align-items: center; text-decoration: none; }
.site-logo img,
.site-logo .custom-logo,
.custom-logo-link img,
img.custom-logo {
  height: 40px !important;
  width: auto !important;
  max-height: 40px !important;
  max-width: none !important;
  display: block !important;
  object-fit: contain !important;
}

/* Primary nav — centred, takes remaining space */
.primary-nav { display: flex; align-items: center; flex: 1; justify-content: center; }
.nav-list { list-style: none !important; margin: 0 !important; padding: 0 !important; display: flex; align-items: center; gap: 0; }
.nav-list > li { list-style: none !important; }
.nav-item { position: relative !important; }

/* Nav links */
.nav-link {
  display: flex; align-items: center; gap: 4px;
  padding: 8px 13px; font-size: 13.5px; font-weight: 500;
  color: var(--gla-ink); border-radius: 6px; white-space: nowrap;
  transition: background .15s, color .15s; text-decoration: none;
}
.nav-link svg { opacity: .5; transition: transform .22s, opacity .15s; flex-shrink: 0; }
.nav-item:hover > .nav-link,
.nav-item:focus-within > .nav-link { background: var(--gla-paper-2); color: var(--gla-royal-600); }
.nav-item:hover > .nav-link svg,
.nav-item:focus-within > .nav-link svg { transform: rotate(180deg); opacity: .9; }

/* CTA buttons */
.nav-actions { display: flex; align-items: center; flex-shrink: 0; }
.btn { display: inline-flex; align-items: center; gap: 7px; font-family: var(--font-sans); font-size: 13.5px; font-weight: 600; line-height: 1; padding: 9px 18px; border-radius: 999px; border: 1px solid transparent; transition: background .18s, color .18s, border-color .18s; white-space: nowrap; cursor: pointer; text-decoration: none; }
.btn-primary { background: var(--gla-navy-800); color: #fff; }
.btn-primary:hover { background: var(--gla-navy-900); }
.btn-ghost { background: transparent; color: var(--gla-navy-800); border-color: var(--gla-line); }
.btn-ghost:hover { background: var(--gla-paper-2); }
.btn-gold { background: var(--gla-gold-600); color: #fff; }
.btn-gold:hover { background: var(--gla-gold-700); }
.btn-sm { font-size: 13px; padding: 8px 16px; }
.btn-lg { font-size: 15px; padding: 13px 24px; }
.btn-full { width: 100%; justify-content: center; }

/* ── Simple dropdown (About / Admission / Contact Us) ── */
/* Invisible bridge: fills the gap between nav-link and dropdown
   so the hover state is never lost when moving the mouse down */
.nav-item::after {
  content: "";
  position: absolute;
  top: 100%;
  left: 0; right: 0;
  height: 12px; /* covers the gap between link bottom and dropdown top */
  display: none;
}
.nav-item:hover::after,
.nav-item:focus-within::after { display: block; }

.simple-dropdown {
  position: absolute !important;
  top: calc(100% + 6px); left: 0;
  min-width: 210px;
  background: #fff;
  border: 1px solid var(--gla-line-soft);
  border-radius: 12px;
  box-shadow: 0 16px 40px -8px rgba(5,40,104,.14);
  padding: 6px;
  z-index: 9999;
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
  transform: translateY(-4px);
  /* Delay hiding by 100ms so mouse can reach the dropdown */
  transition: opacity .18s ease, transform .2s ease, visibility 0s .12s;
}
.nav-item:hover .simple-dropdown,
.nav-item:focus-within .simple-dropdown {
  visibility: visible;
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
  transition: opacity .18s ease, transform .2s ease, visibility 0s;
}
.simple-dropdown ul { list-style: none !important; margin: 0 !important; padding: 0 !important; }
.simple-dropdown ul li { list-style: none !important; }
.simple-dropdown ul li a {
  display: block; padding: 9px 14px; font-size: 13.5px; font-weight: 500;
  color: var(--gla-ink); border-radius: 8px;
  transition: background .13s, color .13s; text-decoration: none;
}
.simple-dropdown ul li a:hover { background: var(--gla-sky-100); color: var(--gla-royal-600); }

/* ── Mega dropdown (Programmes) ─────────────────────── */
.mega-dropdown {
  position: absolute !important;
  top: calc(100% + 6px);
  left: 50%; transform: translateX(-50%) translateY(-4px);
  width: 680px;
  background: #fff;
  border: 1px solid var(--gla-line-soft);
  border-radius: 16px;
  box-shadow: 0 24px 56px -16px rgba(5,40,104,.16);
  padding: 22px 20px;
  z-index: 9999;
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
  /* Same delay trick for mega menu */
  transition: opacity .18s ease, transform .2s ease, visibility 0s .12s;
}
.nav-item:hover .mega-dropdown,
.nav-item:focus-within .mega-dropdown {
  visibility: visible;
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
  transition: opacity .18s ease, transform .2s ease, visibility 0s;
}
.mega-inner { display: grid !important; grid-template-columns: 1fr 1px 1fr; align-items: start; }
.mega-divider { background: var(--gla-line-soft); align-self: stretch; margin: 0 4px; }
.mega-col { padding: 0 14px; }
.mega-col:first-child { padding-left: 0; }
.mega-col:last-child  { padding-right: 0; }
.mega-heading {
  font-size: 10.5px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .09em; margin: 0 0 8px; padding: 0 8px 8px;
  border-bottom: 1px solid var(--gla-line-soft);
  list-style: none !important;
}
.mega-heading.lang { color: var(--gla-royal-600); }
.mega-heading.adp  { color: var(--gla-gold-700); }
.mega-col ul { list-style: none !important; margin: 0 !important; padding: 0 !important; }
.mega-col ul li { list-style: none !important; }
.mega-col ul li a {
  display: flex; align-items: center; gap: 9px;
  padding: 8px; border-radius: 7px; font-size: 13px; font-weight: 500;
  color: var(--gla-ink); transition: background .13s, color .13s; text-decoration: none;
}
.mega-col ul li a:hover { background: var(--gla-sky-100); color: var(--gla-royal-600); }
.mega-icon { font-size: 15px; flex: 0 0 18px; line-height: 1; }

/* ── Mobile hamburger ───────────────────────────────── */
.mobile-menu-btn {
  display: none; flex-direction: column; justify-content: center;
  gap: 5px; width: 36px; height: 36px; background: transparent;
  border: 1px solid var(--gla-line-soft); border-radius: 8px;
  padding: 6px; cursor: pointer; flex-shrink: 0;
}
.mobile-menu-btn span { display: block; width: 100%; height: 2px; background: var(--gla-ink); border-radius: 2px; transition: transform .25s, opacity .2s; }
.mobile-menu-btn.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.mobile-menu-btn.open span:nth-child(2) { opacity: 0; }
.mobile-menu-btn.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ── Mobile drawer ──────────────────────────────────── */
.mobile-drawer {
  position: fixed; top: 72px; left: 0; right: 0; bottom: 0;
  background: #fff; z-index: 999;
  overflow-y: auto; -webkit-overflow-scrolling: touch;
  visibility: hidden; opacity: 0;
  transform: translateY(-10px);
  transition: opacity .25s ease, transform .25s ease, visibility 0s .25s;
}
.mobile-drawer.open {
  visibility: visible; opacity: 1; transform: translateY(0);
  transition: opacity .25s ease, transform .25s ease;
}
.mobile-drawer-inner { padding: 8px 0 60px; }
.mobile-link {
  display: block; padding: 15px 24px; font-size: 15px; font-weight: 600;
  color: var(--gla-navy-900); border-bottom: 1px solid var(--gla-line-soft);
  text-decoration: none;
}
.mobile-link:hover { background: var(--gla-paper-2); color: var(--gla-royal-600); }
.mobile-section { border-bottom: 1px solid var(--gla-line-soft); }
.mobile-section-toggle {
  width: 100%; display: flex; justify-content: space-between; align-items: center;
  padding: 15px 24px; font-size: 15px; font-weight: 600;
  color: var(--gla-navy-900); background: transparent; border: none; cursor: pointer;
  text-align: left;
}
.mobile-section-toggle svg { flex-shrink: 0; opacity: .5; transition: transform .22s; }
.mobile-section-toggle[aria-expanded="true"] svg { transform: rotate(180deg); }
.mobile-section-list {
  list-style: none; margin: 0; padding: 0;
  max-height: 0; overflow: hidden;
  transition: max-height .3s ease;
}
.mobile-section-list.open { max-height: 600px; }
.mobile-section-list li a {
  display: block; padding: 11px 24px 11px 36px; font-size: 14px;
  color: var(--gla-ink-2); border-bottom: 1px solid var(--gla-line-soft);
  text-decoration: none; transition: background .13s, color .13s;
}
.mobile-section-list li a:hover { background: var(--gla-paper-2); color: var(--gla-royal-600); }
.mobile-sub-label {
  display: block; padding: 10px 24px 4px 36px;
  font-size: 10.5px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .08em; color: var(--gla-royal-600);
  background: var(--gla-paper-2);
}
.mobile-footer { padding: 20px 24px; }

/* Hide desktop nav on mobile, show hamburger */
@media (max-width: 960px) {
  .primary-nav { display: none; }
  .nav-actions  { display: none; }
  .mobile-menu-btn { display: flex; }
}
@media (min-width: 961px) {
  .mobile-drawer { display: none; }
  .mobile-menu-btn { display: none; }
}

/* ── Gradient text ──────────────────────────────────── */
.gradient-text { background: linear-gradient(95deg, #1556B5 0%, #2178E0 35%, #6CB4FF 65%, #C9A961 100%); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent; }

/* ── Glass card ─────────────────────────────────────── */
.glass-card { background: rgba(255,255,255,.78); backdrop-filter: saturate(160%) blur(20px); -webkit-backdrop-filter: saturate(160%) blur(20px); border: 1px solid rgba(21,86,181,.12); border-radius: 16px; box-shadow: 0 8px 28px -8px rgba(5,40,104,.10); }

/* ── Hero (WP template) ─────────────────────────────── */
.blob-cluster { position: absolute; top: -48px; right: -48px; width: 480px; height: 480px; pointer-events: none; z-index: 1; overflow: hidden; }
.hero-inner { display: grid; grid-template-columns: 1.1fr 1fr; gap: 60px; align-items: center; position: relative; z-index: 3; padding-top: 0; }
@media (max-width: 900px) { .hero-inner { grid-template-columns: 1fr; gap: 36px; } .blob-cluster { display: none; } }
.hero-badge { display: inline-flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 600; color: var(--gla-royal-600); background: rgba(255,255,255,.75); border: 1px solid rgba(21,86,181,.18); border-radius: 999px; padding: 7px 14px; backdrop-filter: blur(8px); margin-bottom: 20px; }
.hero-headline { font-weight: 700; font-size: clamp(38px,5vw,68px); line-height: 1.03; letter-spacing: -.03em; color: var(--gla-navy-900); margin: 0 0 20px; text-wrap: balance; }
.hero-sub { font-size: 18px; line-height: 1.6; color: var(--gla-ink-2); margin: 0 0 32px; max-width: 52ch; }
.hero-cta { display: flex; gap: 12px; flex-wrap: wrap; }
.hero-cards { display: flex; flex-direction: column; gap: 14px; position: relative; z-index: 3; }
.division-card { display: flex; align-items: center; gap: 14px; padding: 18px 20px; text-decoration: none; transition: box-shadow .22s, border-color .22s, transform .22s; }
.division-card:hover { transform: translateY(-2px); box-shadow: 0 16px 36px -12px rgba(5,40,104,.18); border-color: rgba(21,86,181,.22); }
.division-card-icon { font-size: 24px; width: 40px; height: 40px; border-radius: 10px; background: var(--gla-sky-100); display: grid; place-items: center; flex: 0 0 40px; }
.division-card-title { font-size: 15px; font-weight: 700; color: var(--gla-navy-900); margin: 0 0 3px; }
.division-card-desc  { font-size: 12.5px; color: var(--gla-ink-3); margin: 0; }
.division-card-arrow { margin-left: auto; color: var(--gla-royal-600); opacity: .6; flex: 0 0 20px; }
.hero-stat-row { display: flex; align-items: center; gap: 0; background: rgba(255,255,255,.6); border: 1px solid rgba(21,86,181,.10); border-radius: 14px; padding: 16px 20px; }
.hero-stat { flex: 1; text-align: center; }
.hero-stat-num { font-size: 26px; font-weight: 700; color: var(--gla-navy-900); letter-spacing: -.02em; }
.hero-stat span:not(.hero-stat-num):not(.hero-stat-label) { font-size: 16px; font-weight: 700; color: var(--gla-gold-600); }
.hero-stat-label { display: block; font-size: 11px; font-weight: 500; color: var(--gla-ink-3); margin-top: 2px; }
.hero-stat-divider { width: 1px; height: 36px; background: var(--gla-line-soft); flex: 0 0 1px; }

/* ── Marquee (WP) ───────────────────────────────────── */
.marquee-section { padding: 24px 0; border-bottom: 1px solid var(--gla-line-soft); background: var(--gla-paper); }
.marquee-label { text-align: center; font-size: 12px; font-weight: 600; color: var(--gla-ink-3); letter-spacing: .04em; text-transform: uppercase; margin-bottom: 16px; }
.marquee-track-wrap { overflow: hidden; mask-image: linear-gradient(to right, transparent 0%, #000 10%, #000 90%, transparent 100%); -webkit-mask-image: linear-gradient(to right, transparent 0%, #000 10%, #000 90%, transparent 100%); }
.marquee-track { display: flex; align-items: center; gap: 48px; width: max-content; animation: marqueeScroll 32s linear infinite; }
.marquee-track:hover { animation-play-state: paused; }
.marquee-item { font-size: 14px; font-weight: 600; color: var(--gla-ink-3); white-space: nowrap; }

/* ── Stats bar ──────────────────────────────────────── */
.stats-bar { background: var(--gla-paper-2); border-bottom: 1px solid var(--gla-line-soft); padding: 60px 0; }
.stats-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 0; }
.stat-item { text-align: center; padding: 0 24px; border-left: 1px solid var(--gla-line-soft); }
.stat-item:first-child { border-left: none; }
.stat-num { font-size: 52px; font-weight: 700; color: var(--gla-navy-900); letter-spacing: -.03em; line-height: 1; }
.stat-suffix { font-size: 28px; font-weight: 700; color: var(--gla-gold-600); }
.stat-label { display: block; font-size: 13px; font-weight: 500; color: var(--gla-ink-3); margin-top: 8px; }
@media (max-width: 720px) { .stats-grid { grid-template-columns: 1fr 1fr; } .stat-item { padding: 16px; border-left: none; border-top: 1px solid var(--gla-line-soft); } .stats-bar { padding: 40px 0; } }

/* ── Section head ───────────────────────────────────── */
.section-badge { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--gla-royal-600); background: var(--gla-sky-100); padding: 5px 12px; border-radius: 999px; margin-bottom: 12px; }
.section-badge-light { color: rgba(255,255,255,.9); background: rgba(255,255,255,.15); }
.section-title { font-size: clamp(28px,3.8vw,46px); font-weight: 700; line-height: 1.05; letter-spacing: -.025em; color: var(--gla-navy-900); margin: 0 0 16px; text-wrap: balance; }
.section-sub { font-size: 17px; line-height: 1.6; color: var(--gla-ink-2); max-width: 64ch; margin: 0 auto; }
.section-head { text-align: center; margin-bottom: 56px; }
.text-white    { color: #fff !important; -webkit-text-fill-color: initial !important; }
.text-white-70 { color: rgba(255,255,255,.75) !important; }

/* ── Programmes section ─────────────────────────────── */
.programmes-section { padding: 120px 0; background: var(--gla-paper); }
.programme-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
@media (max-width: 960px) { .programme-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 580px) { .programme-grid { grid-template-columns: 1fr; } }
.programme-card { background: #fff; border: 1px solid var(--gla-line-soft); border-radius: 14px; overflow: hidden; box-shadow: 0 1px 3px rgba(5,40,104,.05); transition: transform .25s, box-shadow .25s, border-color .25s; }
.programme-card:hover { transform: translateY(-4px); box-shadow: 0 20px 40px -16px rgba(5,40,104,.16); border-color: var(--gla-line); }
.programme-card-img { position: relative; aspect-ratio: 16/9; overflow: hidden; }
.programme-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.programme-card:hover .programme-card-img img { transform: scale(1.04); }
.programme-badge { position: absolute; top: 12px; left: 12px; font-size: 11px; font-weight: 700; background: var(--gla-gold-500); color: #fff; padding: 4px 10px; border-radius: 999px; }
.programme-card-body { padding: 22px; }
.programme-card-icon { font-size: 24px; margin-bottom: 10px; }
.programme-card-body h3 { font-size: 17px; font-weight: 700; color: var(--gla-navy-900); margin: 0 0 8px; letter-spacing: -.01em; }
.programme-card-body p  { font-size: 14px; line-height: 1.6; color: var(--gla-ink-2); margin: 0 0 14px; }
.programme-link { display: inline-flex; align-items: center; gap: 6px; font-size: 13.5px; font-weight: 600; color: var(--gla-royal-600); transition: gap .2s; }
.programme-link:hover { gap: 10px; }

/* ── ADP section ────────────────────────────────────── */
.adp-section { position: relative; overflow: hidden; padding: 120px 0; background: var(--gla-navy-900); isolation: isolate; }
.adp-media { position: absolute; inset: 0; z-index: 0; }
.adp-media img { width: 100%; height: 100%; object-fit: cover; }
.adp-media-overlay { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(2,28,73,.94) 40%, rgba(2,28,73,.6) 100%); }
.adp-inner { position: relative; z-index: 2; }
.adp-content { max-width: 640px; }
.adp-subject-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 12px; margin: 28px 0 36px; }
.adp-subject-card { display: flex; align-items: center; gap: 12px; padding: 14px 16px; background: rgba(255,255,255,.08) !important; border-color: rgba(255,255,255,.14) !important; }
.adp-subject-icon { font-size: 20px; flex: 0 0 24px; }
.adp-subject-name   { font-size: 14px; font-weight: 600; color: #fff; margin: 0 0 2px; }
.adp-subject-levels { font-size: 12px; color: rgba(255,255,255,.6); margin: 0; }

/* ── Why section ────────────────────────────────────── */
.why-section { padding: 120px 0; background: var(--gla-paper-2); }
.why-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
@media (max-width: 900px) { .why-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 560px) { .why-grid { grid-template-columns: 1fr; } }
.why-card { background: #fff; border: 1px solid var(--gla-line-soft); border-radius: 14px; padding: 28px; transition: transform .25s, box-shadow .25s; }
.why-card:hover { transform: translateY(-3px); box-shadow: 0 16px 32px -12px rgba(5,40,104,.12); }
.why-icon { font-size: 28px; margin-bottom: 14px; }
.why-card h3 { font-size: 17px; font-weight: 700; color: var(--gla-navy-900); margin: 0 0 8px; }
.why-card p  { font-size: 14.5px; line-height: 1.6; color: var(--gla-ink-2); margin: 0; }

/* ── Testimonials ───────────────────────────────────── */
.testimonials-section { padding: 120px 0; background: var(--gla-paper); }
.testimonial-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
@media (max-width: 900px) { .testimonial-grid { grid-template-columns: 1fr; } }
.testimonial-card { padding: 28px; position: relative; }
.testimonial-quote { color: var(--gla-royal-600); margin-bottom: 16px; }
.testimonial-text { font-size: 15.5px; line-height: 1.65; color: var(--gla-ink-2); margin: 0 0 20px; font-style: italic; }
.testimonial-author { display: flex; align-items: center; gap: 12px; }
.testimonial-author img { width: 46px; height: 46px; border-radius: 50%; object-fit: cover; }
.testimonial-name { font-size: 14px; font-weight: 700; color: var(--gla-navy-900); margin: 0 0 2px; }
.testimonial-role { font-size: 12.5px; color: var(--gla-ink-3); margin: 0; }

/* ── CTA Banner ─────────────────────────────────────── */
.cta-banner { background: linear-gradient(135deg, var(--gla-navy-800), var(--gla-navy-900)); padding: 80px 0; }
.cta-inner { display: flex; align-items: center; justify-content: space-between; gap: 32px; flex-wrap: wrap; }
.cta-text h2 { font-size: clamp(24px,3vw,38px); font-weight: 700; color: #fff; margin: 0 0 8px; }
.cta-text p  { font-size: 16px; color: rgba(255,255,255,.75); margin: 0; }
.cta-actions { display: flex; gap: 12px; flex-wrap: wrap; }
.cta-banner .btn-ghost { color: rgba(255,255,255,.9); border-color: rgba(255,255,255,.3); }
.cta-banner .btn-ghost:hover { background: rgba(255,255,255,.12); }

/* ── Page hero (inner pages) ────────────────────────── */
.page-hero { background: linear-gradient(180deg, #F4F8FE 0%, #fff 100%); padding: 80px 0 64px; border-bottom: 1px solid var(--gla-line-soft); }
.page-hero-inner { max-width: 720px; }
.page-hero-text .section-badge { margin-bottom: 14px; }
.page-hero-text h1 { font-size: clamp(34px,4.5vw,58px); font-weight: 700; line-height: 1.04; letter-spacing: -.03em; color: var(--gla-navy-900); margin: 0 0 16px; text-wrap: balance; }
.page-hero-text p  { font-size: 18px; line-height: 1.6; color: var(--gla-ink-2); margin: 0; }

/* ── About page ─────────────────────────────────────── */
.about-mv-section { padding: 80px 0; }
.about-mv-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
@media (max-width: 720px) { .about-mv-grid { grid-template-columns: 1fr; } }
.about-mv-card { padding: 32px; }
.about-mv-icon { font-size: 32px; margin-bottom: 16px; }
.about-mv-card h2 { font-size: 22px; font-weight: 700; color: var(--gla-navy-900); margin: 0 0 12px; }
.about-mv-card p  { font-size: 15px; line-height: 1.7; color: var(--gla-ink-2); margin: 0; }
.about-stats-section { padding: 60px 0; background: var(--gla-paper-2); border-block: 1px solid var(--gla-line-soft); }
.about-approach-section { padding: 100px 0; }
.approach-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 24px; }
@media (max-width: 900px) { .approach-grid { grid-template-columns: repeat(2,1fr); } }
.approach-card { background: var(--gla-paper-2); border: 1px solid var(--gla-line-soft); border-radius: 14px; padding: 28px; }
.approach-step { font-size: 36px; font-weight: 900; color: var(--gla-royal-600); opacity: .3; line-height: 1; margin-bottom: 16px; }
.approach-card h3 { font-size: 18px; font-weight: 700; color: var(--gla-navy-900); margin: 0 0 8px; }
.approach-card p  { font-size: 14.5px; line-height: 1.6; color: var(--gla-ink-2); margin: 0; }
.team-section { padding: 100px 0; background: var(--gla-paper-2); }
.team-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 24px; }
@media (max-width: 900px) { .team-grid { grid-template-columns: repeat(2,1fr); } }
.team-card { text-align: center; }
.team-photo { aspect-ratio: 3/4; border-radius: 14px; overflow: hidden; margin-bottom: 14px; }
.team-photo img { width: 100%; height: 100%; object-fit: cover; }
.team-name { font-size: 16px; font-weight: 700; color: var(--gla-navy-900); margin: 0 0 4px; }
.team-role { font-size: 13px; color: var(--gla-royal-600); margin: 0; font-weight: 500; }

/* ── Admissions page ────────────────────────────────── */
.process-section { padding: 80px 0; background: var(--gla-paper-2); }
.process-steps { display: grid; grid-template-columns: repeat(4,1fr); gap: 24px; }
@media (max-width: 900px) { .process-steps { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 520px) { .process-steps { grid-template-columns: 1fr; } }
.process-step { position: relative; background: #fff; border: 1px solid var(--gla-line-soft); border-radius: 14px; padding: 28px 22px 24px; }
.process-num { position: absolute; top: -16px; left: 22px; width: 34px; height: 34px; border-radius: 50%; background: var(--gla-navy-800); color: #fff; font-weight: 700; font-size: 15px; display: grid; place-items: center; box-shadow: 0 4px 12px rgba(5,40,104,.2); }
.process-step h3 { font-size: 17px; font-weight: 700; color: var(--gla-navy-900); margin: 14px 0 8px; }
.process-step p  { font-size: 14px; line-height: 1.6; color: var(--gla-ink-2); margin: 0; }
.form-section { padding: 80px 0; }
.form-section-inner { display: grid; grid-template-columns: 1fr 1.3fr; gap: 60px; align-items: start; }
@media (max-width: 900px) { .form-section-inner { grid-template-columns: 1fr; } }
.form-info h2 { font-size: 26px; font-weight: 700; color: var(--gla-navy-900); margin: 0 0 12px; }
.form-info p  { font-size: 15px; line-height: 1.65; color: var(--gla-ink-2); margin: 0 0 20px; }
.form-info-list { list-style: none; padding: 0; margin: 0 0 28px; display: flex; flex-direction: column; gap: 10px; }
.form-info-list li { font-size: 14.5px; color: var(--gla-ink-2); }
.form-contact-note { background: var(--gla-paper-2); border: 1px solid var(--gla-line-soft); border-radius: 12px; padding: 18px 20px; }
.form-contact-note p { font-size: 14px; color: var(--gla-ink-2); margin: 0 0 6px; }
.form-card { padding: 32px; }
.gla-form .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 520px) { .gla-form .form-row { grid-template-columns: 1fr; } }
.gla-form .form-group { display: flex; flex-direction: column; gap: 5px; margin-bottom: 16px; }
.gla-form label { font-size: 13px; font-weight: 600; color: var(--gla-navy-900); }
.gla-form input,
.gla-form select,
.gla-form textarea { font-family: var(--font-sans); font-size: 14px; padding: 10px 12px; background: var(--gla-paper); border: 1px solid var(--gla-line); border-radius: 8px; color: var(--gla-ink); transition: border-color .18s, box-shadow .18s; width: 100%; }
.gla-form textarea { min-height: 100px; resize: vertical; }
.gla-form input:focus,
.gla-form select:focus,
.gla-form textarea:focus { outline: none; border-color: var(--gla-royal-600); box-shadow: 0 0 0 3px rgba(33,120,224,.15); }
.form-divider { border: none; border-top: 1px solid var(--gla-line-soft); margin: 8px 0 20px; }
.form-section-label { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: var(--gla-royal-600); margin-bottom: 16px; display: block; }
.form-status { font-size: 14px; padding: 10px 0; min-height: 20px; }
.form-status--success { color: #15803d; }
.form-status--error   { color: #b91c1c; }

/* ── Contact page ───────────────────────────────────── */
.contact-section { padding: 80px 0; }
.contact-grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: 60px; align-items: start; }
@media (max-width: 900px) { .contact-grid { grid-template-columns: 1fr; } }
.contact-info h2 { font-size: 26px; font-weight: 700; color: var(--gla-navy-900); margin: 0 0 24px; }
.contact-item { display: flex; align-items: flex-start; gap: 14px; margin-bottom: 20px; }
.contact-icon { font-size: 20px; flex: 0 0 24px; }
.contact-label { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: var(--gla-royal-600); margin: 0 0 2px; }
.contact-item p { font-size: 14.5px; color: var(--gla-ink-2); margin: 0; line-height: 1.5; }
.map-placeholder { margin-top: 24px; border-radius: 14px; overflow: hidden; border: 1px solid var(--gla-line-soft); }

/* ── International students page ────────────────────── */
.intl-section { padding: 100px 0; }
.intl-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
@media (max-width: 900px) { .intl-grid { grid-template-columns: repeat(2,1fr); } }
.support-section { padding: 100px 0; background: var(--gla-paper-2); }
.support-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
@media (max-width: 900px) { .support-grid { grid-template-columns: repeat(2,1fr); } }

/* ── Footer ─────────────────────────────────────────── */
.site-footer { background: var(--gla-paper-2); border-top: 1px solid var(--gla-line-soft); padding: 72px 0 32px; }
.footer-grid { display: grid; grid-template-columns: 1.4fr repeat(4,1fr); gap: 40px; margin-bottom: 56px; }
@media (max-width: 1080px) {
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
  .footer-brand { grid-column: 1 / -1; }
}
@media (max-width: 540px) {
  .footer-grid { grid-template-columns: 1fr; gap: 24px; }
  .footer-brand { grid-column: auto; }
  .footer-bottom { flex-direction: column; align-items: flex-start; gap: 8px; }
}
.footer-brand { display: flex; flex-direction: column; gap: 0; }
.footer-desc { font-size: 13px; line-height: 1.65; color: var(--gla-ink-3); margin: 0 0 16px; max-width: 30ch; }
.footer-logo img { height: 38px; margin-bottom: 14px; }
.footer-tagline { font-size: 15px; line-height: 1.6; color: var(--gla-ink-2); margin: 0 0 20px; }
.footer-socials { display: flex; gap: 8px; }
.social-link { width: 34px; height: 34px; border-radius: 50%; display: grid; place-items: center; background: #fff; border: 1px solid var(--gla-line-soft); color: var(--gla-navy-800); transition: background .18s, border-color .18s; }
.social-link:hover { background: var(--gla-sky-100); border-color: var(--gla-sky-300); color: var(--gla-royal-600); }
.footer-col {}
.footer-heading { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: var(--gla-navy-900); margin: 0 0 16px; }
.footer-links { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 9px; }
.footer-links li a { font-size: 14px; color: var(--gla-ink-3); transition: color .18s; }
.footer-links li a:hover { color: var(--gla-navy-800); }
.footer-contact li { display: flex; align-items: flex-start; gap: 8px; font-size: 13.5px; color: var(--gla-ink-3); }
.footer-contact li svg { flex: 0 0 16px; margin-top: 1px; color: var(--gla-royal-600); }
.footer-bottom { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px; padding-top: 24px; border-top: 1px solid var(--gla-line-soft); }
.footer-bottom p { font-size: 13px; color: var(--gla-ink-3); margin: 0; }
.footer-bottom-links { display: flex; gap: 20px; }
.footer-bottom-links a { font-size: 13px; color: var(--gla-ink-3); transition: color .18s; }
.footer-bottom-links a:hover { color: var(--gla-navy-800); }

/* ── Dark mode — WP component overrides ─────────────── */
[data-theme="dark"] .site-header { background: rgba(14,21,37,.92); border-bottom-color: #1A2640; }
[data-theme="dark"] .mega-dropdown { background: #131C2E; border-color: #263350; }
[data-theme="dark"] .mega-col ul li a strong { color: #E6EDF6; }
[data-theme="dark"] .mobile-drawer { background: #0E1525; }
[data-theme="dark"] .mobile-section-toggle { color: #E6EDF6; border: none; }
[data-theme="dark"] .mobile-section-list li a { color: #9BACC4; border-bottom-color: #1A2640; }
[data-theme="dark"] .mobile-link { color: #E6EDF6; border-bottom-color: #1A2640; }
[data-theme="dark"] .mobile-section { border-bottom-color: #1A2640; }
[data-theme="dark"] .simple-dropdown { background: #131C2E; border-color: #263350; }
[data-theme="dark"] .simple-dropdown ul li a { color: #E6EDF6; }
[data-theme="dark"] .simple-dropdown ul li a:hover { background: #192235; }
[data-theme="dark"] .glass-card { background: rgba(19,28,46,.82); border-color: rgba(38,51,80,.8); }
[data-theme="dark"] .hero-headline { color: #E6EDF6; }
[data-theme="dark"] .division-card-title { color: #E6EDF6; }
[data-theme="dark"] .hero-stat-num { color: #E6EDF6; }
[data-theme="dark"] .section-title { color: #E6EDF6; }
[data-theme="dark"] .page-hero { background: linear-gradient(180deg, #090F1E 0%, #0E1525 100%); border-bottom-color: #1A2640; }
[data-theme="dark"] .page-hero-text h1 { color: #E6EDF6; }
[data-theme="dark"] .programme-card { background: #131C2E; border-color: #1A2640; }
[data-theme="dark"] .programme-card-body h3 { color: #E6EDF6; }
[data-theme="dark"] .why-card { background: #131C2E; border-color: #1A2640; }
[data-theme="dark"] .why-card h3 { color: #E6EDF6; }
[data-theme="dark"] .process-step { background: #131C2E; border-color: #263350; }
[data-theme="dark"] .process-step h3 { color: #E6EDF6; }
[data-theme="dark"] .about-mv-card h2 { color: #E6EDF6; }
[data-theme="dark"] .approach-card { background: #131C2E; border-color: #263350; }
[data-theme="dark"] .approach-card h3 { color: #E6EDF6; }
[data-theme="dark"] .team-name { color: #E6EDF6; }
[data-theme="dark"] .testimonial-name { color: #E6EDF6; }
[data-theme="dark"] .stats-bar { background: #131C2E; border-color: #1A2640; }
[data-theme="dark"] .stat-num { color: #E6EDF6; }
[data-theme="dark"] .about-stats-section { background: #131C2E; border-color: #1A2640; }
[data-theme="dark"] .contact-info h2 { color: #E6EDF6; }
[data-theme="dark"] .form-section-label { color: #9BACC4; }
[data-theme="dark"] .gla-form label { color: #E6EDF6; }
[data-theme="dark"] .gla-form input,
[data-theme="dark"] .gla-form select,
[data-theme="dark"] .gla-form textarea { background: #0E1525; border-color: #263350; color: #E6EDF6; }
[data-theme="dark"] .form-info h2 { color: #E6EDF6; }
[data-theme="dark"] .form-contact-note { background: #131C2E; border-color: #263350; }
[data-theme="dark"] .site-footer { background: #090F1E; border-top-color: #1A2640; }
[data-theme="dark"] .footer-heading { color: #E6EDF6; }
[data-theme="dark"] .footer-bottom { border-top-color: #1A2640; }
[data-theme="dark"] .social-link { background: #131C2E; border-color: #263350; color: #9BACC4; }
[data-theme="dark"] .why-section { background: #131C2E; }
[data-theme="dark"] .support-section { background: #131C2E; }
[data-theme="dark"] .stats-grid .stat-item { border-color: #1A2640; }
[data-theme="dark"] .marquee-section { background: #0E1525; border-color: #1A2640; }

/* ══════════════════════════════════════════════════════════
   HOME PAGE — UPDATED SECTIONS
══════════════════════════════════════════════════════════ */

/* ── Hero: GL Academy name + photo layout ───────────────── */
.hero { position: relative; overflow: hidden; background: #F4F8FE; padding: 96px 0 112px; isolation: isolate; }
.hero::before { content: ""; position: absolute; inset: 0; z-index: 0; background: radial-gradient(at 18% 24%, rgba(33,120,224,.22) 0, transparent 48%), radial-gradient(at 82% 12%, rgba(108,180,255,.28) 0, transparent 45%), linear-gradient(180deg, #F4F8FE 0%, #fff 100%); }
.hero-inner { position: relative; z-index: 2; display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
@media (max-width: 900px) { .hero-inner { grid-template-columns: 1fr; gap: 40px; } .hero-photo-wrap { order: -1; } }

.hero-aka { font-size: .65em; font-weight: 600; color: var(--gla-ink-3); letter-spacing: 0; display: inline; }
.hero-headline { font-size: clamp(32px, 4.2vw, 58px); font-weight: 800; line-height: 1.06; letter-spacing: -.03em; color: var(--gla-navy-900); margin: 0 0 18px; }

/* Google badge */
.hero-google-badge { display: inline-flex; align-items: center; gap: 10px; margin-top: 24px; background: #fff; border: 1px solid var(--gla-line-soft); border-radius: 12px; padding: 10px 16px; box-shadow: 0 2px 8px rgba(5,40,104,.06); }
.hero-google-logo svg { display: block; }
.hero-google-stars { display: flex; align-items: center; gap: 4px; }
.stars { color: #FBBC05; font-size: 15px; letter-spacing: 1px; }
.rating-num { font-size: 15px; font-weight: 700; color: var(--gla-navy-900); }
.hero-google-text { font-size: 12px; color: var(--gla-ink-3); font-weight: 500; border-left: 1px solid var(--gla-line-soft); padding-left: 10px; }

/* Hero photo */
.hero-photo-wrap { position: relative; }
.hero-photo { position: relative; border-radius: 20px; overflow: hidden; aspect-ratio: 4/3; box-shadow: 0 32px 64px -24px rgba(5,40,104,.22); }
.hero-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.hero-photo-card { position: absolute; background: rgba(255,255,255,.92); backdrop-filter: blur(12px); border: 1px solid var(--gla-line-soft); border-radius: 14px; padding: 12px 18px; box-shadow: 0 8px 24px rgba(5,40,104,.10); }
.hero-photo-card--tl { top: 20px; left: -16px; }
.hero-photo-card--br { bottom: 20px; right: -16px; }
.hero-photo-card-num { display: block; font-size: 26px; font-weight: 800; color: var(--gla-navy-900); line-height: 1; letter-spacing: -.02em; }
.hero-photo-card-num span { font-size: 18px; color: var(--gla-gold-600); }
.hero-photo-card-label { display: block; font-size: 11px; font-weight: 500; color: var(--gla-ink-3); margin-top: 3px; }
@media (max-width: 640px) { .hero-photo-card--tl { left: 10px; } .hero-photo-card--br { right: 10px; } }

/* ── Simplified programme cards ─────────────────────────── */
.section-light { background: var(--gla-paper); padding: 100px 0; }
.prog-cards-simple { display: grid; grid-template-columns: repeat(3,1fr); gap: 28px; }
@media (max-width: 960px) { .prog-cards-simple { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 580px) { .prog-cards-simple { grid-template-columns: 1fr; max-width: 480px; margin: 0 auto; } }
.prog-card-simple { background: #fff; border: 1px solid var(--gla-line-soft); border-radius: 18px; overflow: hidden; box-shadow: 0 2px 8px rgba(5,40,104,.05); transition: transform .28s, box-shadow .28s; display: flex; flex-direction: column; }
.prog-card-simple:hover { transform: translateY(-6px); box-shadow: 0 24px 48px -16px rgba(5,40,104,.16); }
.prog-card-simple--featured { border-color: var(--gla-royal-600); box-shadow: 0 4px 20px rgba(21,86,181,.12); }
.prog-card-img { position: relative; aspect-ratio: 16/9; overflow: hidden; }
.prog-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.prog-card-simple:hover .prog-card-img img { transform: scale(1.04); }
.prog-card-badge { position: absolute; top: 12px; right: 12px; font-size: 11px; font-weight: 700; background: var(--gla-gold-500); color: #fff; padding: 4px 10px; border-radius: 999px; }
.prog-card-division { position: absolute; bottom: 10px; left: 12px; font-size: 10.5px; font-weight: 700; padding: 3px 9px; border-radius: 999px; }
.lang-div { background: var(--gla-sky-100); color: var(--gla-royal-600); }
.adp-div  { background: var(--gla-gold-100); color: var(--gla-gold-700); }
.prog-card-body { padding: 22px; display: flex; flex-direction: column; flex: 1; }
.prog-card-icon { font-size: 26px; margin-bottom: 10px; }
.prog-card-body h3 { font-size: 18px; font-weight: 700; color: var(--gla-navy-900); margin: 0 0 10px; letter-spacing: -.01em; }
.prog-card-body p  { font-size: 14px; line-height: 1.65; color: var(--gla-ink-2); margin: 0 0 14px; }
.prog-card-points { list-style: none; margin: 0 0 18px; padding: 0; display: flex; flex-direction: column; gap: 6px; }
.prog-card-points li { font-size: 13px; color: var(--gla-ink-2); padding-left: 18px; position: relative; }
.prog-card-points li::before { content: "✓"; position: absolute; left: 0; color: var(--gla-royal-600); font-weight: 700; }
.prog-view-all { text-align: center; margin-top: 40px; }

/* ── Google Reviews section ─────────────────────────────── */
.reviews-section { background: var(--gla-paper-2); padding: 100px 0; }
.google-rating-summary { display: flex; align-items: center; gap: 20px; justify-content: center; margin-top: 16px; flex-wrap: wrap; }
.google-rating-score { display: flex; align-items: center; gap: 12px; }
.google-rating-num { font-size: 42px; font-weight: 800; color: var(--gla-navy-900); line-height: 1; }
.google-stars { display: block; color: #FBBC05; font-size: 18px; letter-spacing: 2px; }
.google-rating-sub { display: block; font-size: 12px; color: var(--gla-ink-3); margin-top: 2px; }
.google-review-btn { gap: 6px; }

.review-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 20px; margin-top: 48px; }
@media (max-width: 768px) { .review-grid { grid-template-columns: 1fr; } }
.review-card { padding: 22px; }
.review-card-top { display: flex; align-items: center; gap: 12px; margin-bottom: 10px; }
.review-avatar { width: 44px; height: 44px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.review-author { flex: 1; }
.review-name { font-size: 14px; font-weight: 700; color: var(--gla-navy-900); margin: 0 0 2px; }
.review-role { font-size: 12px; color: var(--gla-ink-3); margin: 0; }
.review-google-icon { flex-shrink: 0; }
.review-stars { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; }
.review-star { color: #FBBC05; font-size: 15px; }
.review-date { font-size: 12px; color: var(--gla-ink-3); margin-left: auto; }
.review-text { font-size: 14px; line-height: 1.65; color: var(--gla-ink-2); margin: 0; font-style: italic; }

/* ── Home contact section ───────────────────────────────── */
.home-contact-section { background: var(--gla-paper); padding: 100px 0; }
.home-contact-grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: 48px; align-items: start; margin-top: 0; }
@media (max-width: 900px) { .home-contact-grid { grid-template-columns: 1fr; } }
.home-contact-cards { display: flex; flex-direction: column; gap: 16px; }
.home-contact-card { display: flex; align-items: flex-start; gap: 14px; background: var(--gla-paper-2); border: 1px solid var(--gla-line-soft); border-radius: 14px; padding: 18px 20px; }
.hcc-icon { font-size: 22px; flex-shrink: 0; width: 40px; text-align: center; }
.hcc-label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: var(--gla-royal-600); margin: 0 0 4px; }
.hcc-value { font-size: 14.5px; color: var(--gla-ink-2); margin: 0; line-height: 1.55; }
.hcc-value a { color: var(--gla-ink-2); transition: color .18s; }
.hcc-value a:hover { color: var(--gla-royal-600); }
.home-contact-actions { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 8px; }
.home-contact-map { border-radius: 18px; overflow: hidden; border: 1px solid var(--gla-line-soft); box-shadow: 0 16px 40px -16px rgba(5,40,104,.12); height: 420px; }
.home-contact-map iframe { width: 100%; height: 100%; display: block; }

/* ── Registration Page ──────────────────────────────────── */
.reg-section { padding: 80px 0 120px; background: var(--gla-paper); }
.reg-layout { display: grid; grid-template-columns: 340px 1fr; gap: 40px; align-items: start; }
@media (max-width: 960px) { .reg-layout { grid-template-columns: 1fr; } }

/* Info panel */
.reg-info { display: flex; flex-direction: column; gap: 20px; position: sticky; top: 92px; }
@media (max-width: 960px) { .reg-info { position: static; } }
.reg-info-card { background: var(--gla-paper-2); border: 1px solid var(--gla-line-soft); border-radius: 16px; padding: 28px; }
.reg-info-icon { font-size: 32px; margin-bottom: 14px; }
.reg-info-card h3 { font-size: 17px; font-weight: 700; color: var(--gla-navy-900); margin: 0 0 16px; letter-spacing: -.01em; }
.reg-steps-list { padding: 0 0 0 18px; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.reg-steps-list li { font-size: 14.5px; color: var(--gla-ink-2); line-height: 1.5; }
.reg-info-card--contact { display: flex; flex-direction: column; gap: 12px; }
.reg-info-card__label { font-size: 13px; font-weight: 600; color: var(--gla-ink-3); margin: 0; }
.reg-whatsapp-btn { display: inline-flex; align-items: center; gap: 8px; background: #25D366; color: #fff; font-size: 14px; font-weight: 700; padding: 10px 18px; border-radius: 999px; text-decoration: none; transition: background .18s; }
.reg-whatsapp-btn:hover { background: #1fba59; }
.reg-phone-link { font-size: 14px; font-weight: 600; color: var(--gla-royal-600); text-decoration: none; }
.reg-phone-link:hover { text-decoration: underline; }

/* Form card */
.reg-form-card { padding: 36px 40px; }
@media (max-width: 640px) { .reg-form-card { padding: 24px 20px; } }
.req { color: var(--gla-royal-600); }

/* Form footer */
.reg-form-footer { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-top: 28px; flex-wrap: wrap; }
@media (max-width: 520px) { .reg-form-footer { flex-direction: column; align-items: flex-start; } .reg-form-footer .btn { width: 100%; justify-content: center; } }
.reg-privacy { display: flex; align-items: center; gap: 7px; font-size: 12.5px; color: var(--gla-ink-3); margin: 0; }
.reg-privacy svg { flex-shrink: 0; color: var(--gla-ink-3); }

/* Success state */
.reg-success { text-align: center; padding: 56px 24px; }
.reg-success__icon { font-size: 56px; margin-bottom: 20px; }
.reg-success h2 { font-size: 28px; font-weight: 700; color: var(--gla-navy-900); margin: 0 0 14px; }
.reg-success p { font-size: 16px; color: var(--gla-ink-2); max-width: 52ch; margin: 0 auto 10px; line-height: 1.6; }
.reg-success__sub { font-size: 14px !important; color: var(--gla-ink-3) !important; }
.reg-success .btn { margin-top: 28px; }

/* Dark mode — registration */
[data-theme="dark"] .reg-info-card { background: #131C2E; border-color: #263350; }
[data-theme="dark"] .reg-info-card h3 { color: #E6EDF6; }
[data-theme="dark"] .reg-form-card { background: #131C2E; border-color: #263350; }
[data-theme="dark"] .reg-success h2 { color: #E6EDF6; }
[data-theme="dark"] .form-divider { border-top-color: #263350; }

/* Dark mode — home page cards */
[data-theme="dark"] .home-contact-card { background: #131C2E; border-color: #263350; }
[data-theme="dark"] .google-rating-num { color: #E6EDF6; }
[data-theme="dark"] .review-name { color: #E6EDF6; }
[data-theme="dark"] .review-card { background: #131C2E; border-color: #263350; }
[data-theme="dark"] .reviews-section { background: #131C2E; }
[data-theme="dark"] .hero-google-badge { background: #131C2E; border-color: #263350; }
[data-theme="dark"] .rating-num { color: #E6EDF6; }
[data-theme="dark"] .hero-photo-card { background: rgba(19,28,46,.9); border-color: #263350; }

/* ── Registration Form Enhancements ──────────────────── */

/* Phone row: country code + number side-by-side */
.reg-phone-row { display: flex; gap: 8px; align-items: center; }
.reg-phone-row > .reg-cc-select { flex: 0 0 110px; width: 110px; }
.reg-phone-row > .reg-phone-input { flex: 1 1 auto; width: auto; min-width: 0; }

/* Tooltip (ⓘ icon) */
.reg-tip { position: relative; display: inline-flex; align-items: center; cursor: help; color: var(--gla-ink-3); margin-left: 5px; vertical-align: middle; }
.reg-tip svg { display: block; }
.reg-tip__popup { visibility: hidden; opacity: 0; pointer-events: none; position: absolute; bottom: calc(100% + 8px); left: 50%; transform: translateX(-50%); width: 260px; background: var(--gla-navy-900); color: #fff; font-size: 12.5px; font-weight: 400; line-height: 1.55; padding: 10px 13px; border-radius: 8px; text-transform: none; letter-spacing: 0; white-space: normal; z-index: 99; transition: opacity .15s; }
.reg-tip__popup::after { content: ''; position: absolute; top: 100%; left: 50%; transform: translateX(-50%); border: 6px solid transparent; border-top-color: var(--gla-navy-900); }
.reg-tip:hover .reg-tip__popup,
.reg-tip:focus-within .reg-tip__popup { visibility: visible; opacity: 1; pointer-events: auto; }

/* Terms & Conditions checkbox */
.reg-terms { margin: 20px 0 4px; }
.reg-terms__label { display: flex; align-items: flex-start; gap: 10px; cursor: pointer; font-size: 13.5px; color: var(--gla-ink-2); line-height: 1.5; }
.reg-terms__label input[type="checkbox"] { flex-shrink: 0; width: 16px; height: 16px; margin-top: 2px; accent-color: var(--gla-royal-600); cursor: pointer; }
.reg-terms__label a { color: var(--gla-royal-600); text-decoration: underline; }
.reg-terms__label a:hover { color: var(--gla-royal-700); }

/* KakaoTalk button */
.reg-kakao-btn { display: inline-flex; align-items: center; gap: 8px; background: #FAE100; color: #3C1E1E; font-size: 14px; font-weight: 700; padding: 10px 18px; border-radius: 999px; text-decoration: none; transition: background .18s; }
.reg-kakao-btn:hover { background: #f0d800; }

/* WeChat label */
.reg-wechat-wrap { display: flex; align-items: center; gap: 8px; color: var(--gla-ink-2); }
.reg-wechat-wrap svg { flex-shrink: 0; color: #07C160; }
.reg-wechat-id { font-size: 13.5px; }

[data-theme="dark"] .reg-tip__popup { background: #0f1b30; }
[data-theme="dark"] .reg-tip__popup::after { border-top-color: #0f1b30; }
[data-theme="dark"] .hero-photo-card-num { color: #E6EDF6; }
