
/* ── RESET & VARS ── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --navy:#050D1A;--navy-2:#091426;--navy-3:#0D1E38;--navy-4:#132844;--navy-mid:#1C3A5E;
  --blue:#1A6FB5;--blue-l:#3A8FD5;
  --white:#FFFFFF;--off:#F5F7FA;--wd:rgba(255,255,255,.85);--wm:rgba(255,255,255,.5);--wf:rgba(255,255,255,.12);
  --gold:#C9A84C;--gl:#E8D08A;--gb:#F0DC96;--gd:#8B6914;--gf:rgba(201,168,76,.12);
  --serif:'Cormorant',Georgia,serif;--sans:'Jost',sans-serif;
  --ease:cubic-bezier(.25,.46,.45,.94);
}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--white);color:var(--navy);overflow-x:hidden}
::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--off)}::-webkit-scrollbar-thumb{background:var(--gd);border-radius:2px}
.reveal{opacity:0;transform:translateY(36px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.v{opacity:1;transform:none}
.reveal-l{opacity:0;transform:translateX(-40px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal-l.v{opacity:1;transform:none}
.reveal-r{opacity:0;transform:translateX(40px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal-r.v{opacity:1;transform:none}

/* ══ NAV ══ */
nav{
  position:fixed;top:0;left:0;right:0;z-index:900;
  padding:0 6%;height:80px;
  display:flex;align-items:center;justify-content:space-between;
  transition:all .5s var(--ease);
}
nav.scrolled{
  background:rgba(5,13,26,.96);
  box-shadow:0 1px 0 rgba(201,168,76,.15);
  backdrop-filter:blur(20px);
}
.logo{display:flex;flex-direction:column;text-decoration:none}
.logo-m{font-family:var(--serif);font-size:1.25rem;font-weight:500;color:var(--gl);letter-spacing:.04em;line-height:1.1}
.logo-s{font-size:.54rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.38);margin-top:3px}
.nav-links{display:flex;align-items:center;gap:2.5rem}
.nl{font-size:.73rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.5);text-decoration:none;transition:color .3s;position:relative}
.nl::after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:right;transition:transform .35s var(--ease)}
.nl:hover{color:var(--white)}.nl:hover::after,.nl.act{color:var(--gold)}.nl.act::after{transform:scaleX(1);transform-origin:left}.nl:hover::after{transform:scaleX(1);transform-origin:left}
.btn-enroll{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;padding:.65rem 1.6rem;background:var(--gold);color:var(--navy);font-weight:600;text-decoration:none;transition:all .3s;border:2px solid var(--gold)}
.btn-enroll:hover{background:transparent;color:var(--gold);transform:translateY(-2px);box-shadow:0 8px 30px rgba(201,168,76,.3)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;background:none;border:none}
.hamburger span{display:block;width:24px;height:1.5px;background:var(--white);transition:all .3s}
.mob-menu{display:none;position:fixed;inset:0;z-index:800;background:var(--navy);flex-direction:column;align-items:center;justify-content:center;gap:2.5rem}
.mob-menu.open{display:flex}
.mob-menu a{font-family:var(--serif);font-size:2.2rem;color:var(--white);text-decoration:none;transition:color .3s}
.mob-menu a:hover{color:var(--gl)}
.mob-close{position:absolute;top:1.5rem;right:6%;font-size:1.5rem;color:rgba(255,255,255,.4);cursor:pointer;background:none;border:none;font-family:var(--sans)}

/* ══ HERO ══ */
.hero{
  min-height:100vh;position:relative;
  background:var(--navy-2);
  display:flex;align-items:center;
  overflow:hidden;
}
/* Deep blue layered bg */
.hero-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 90% 80% at 15% 50%,rgba(26,111,181,.18) 0%,transparent 65%),
    radial-gradient(ellipse 60% 50% at 90% 10%,rgba(201,168,76,.1) 0%,transparent 60%),
    radial-gradient(ellipse 50% 70% at 80% 80%,rgba(26,111,181,.1) 0%,transparent 60%),
    linear-gradient(160deg,#050D1A 0%,#091426 50%,#0D1E38 100%);
}
/* Diagonal light beam */
.hero-beam{
  position:absolute;inset:0;
  background:linear-gradient(105deg,transparent 30%,rgba(201,168,76,.04) 48%,rgba(255,255,255,.03) 52%,transparent 70%);
  pointer-events:none;
}
/* Blueprint grid */
.hero-grid{position:absolute;inset:0;opacity:.05;pointer-events:none;overflow:hidden}
.hero-grid-i{
  width:100%;height:100%;
  background-image:
    linear-gradient(rgba(58,143,213,1) 1px,transparent 1px),
    linear-gradient(90deg,rgba(58,143,213,1) 1px,transparent 1px);
  background-size:60px 60px;
  animation:gdrift 40s linear infinite;
}
@keyframes gdrift{to{transform:translate(60px,60px)}}
/* Radial vignette */
.hero-vignette{
  position:absolute;inset:0;
  background:radial-gradient(ellipse 80% 80% at 50% 50%,transparent 40%,rgba(5,13,26,.6) 100%);
  pointer-events:none;
}
/* Floating orbs */
.orb{
  position:absolute;border-radius:50%;pointer-events:none;
  animation:orbFloat 8s ease-in-out infinite;
}
.orb1{width:600px;height:600px;top:-200px;right:-100px;background:radial-gradient(circle,rgba(26,111,181,.12) 0%,transparent 70%);animation-delay:0s}
.orb2{width:400px;height:400px;bottom:-100px;left:5%;background:radial-gradient(circle,rgba(201,168,76,.08) 0%,transparent 70%);animation-delay:-3s}
@keyframes orbFloat{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-30px) scale(1.03)}}

.hero-inner{
  position:relative;z-index:10;
  padding:0 6%;
  display:grid;grid-template-columns:1fr 1fr;
  gap:4rem;align-items:center;
  width:100%;max-width:1400px;margin:0 auto;
  padding-top:80px;
}
.hero-left{}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:.8rem;
  font-size:.62rem;letter-spacing:.4em;text-transform:uppercase;
  color:var(--gold);margin-bottom:2rem;
  opacity:0;animation:fadeUp .9s .3s forwards;
}
.hero-eyebrow span{display:block;width:28px;height:1px;background:var(--gold);opacity:.7}
.hero-h1{
  font-family:var(--serif);
  font-size:clamp(3rem,5vw,5.5rem);
  font-weight:400;line-height:1.15;color:var(--white);
  margin-bottom:1.75rem;
  opacity:0;animation:fadeUp .9s .5s forwards;
}
.hero-h1 em{font-style:italic;color:var(--gl);display:block}
.hero-p{
  font-size:1.05rem;line-height:1.85;color:rgba(255,255,255,.55);
  max-width:500px;font-weight:300;margin-bottom:2.5rem;
  opacity:0;animation:fadeUp .9s .7s forwards;
}
.hero-btns{
  display:flex;gap:1rem;flex-wrap:wrap;
  opacity:0;animation:fadeUp .9s .9s forwards;
}
.btn-g{
  display:inline-block;text-decoration:none;
  font-size:.75rem;letter-spacing:.18em;text-transform:uppercase;
  padding:1rem 2.4rem;font-weight:600;
  background:var(--gold);color:var(--navy);
  transition:all .35s;border:2px solid var(--gold);
}
.btn-g:hover{background:transparent;color:var(--gold);transform:translateY(-3px);box-shadow:0 12px 40px rgba(201,168,76,.25)}
.btn-w{
  display:inline-block;text-decoration:none;
  font-size:.75rem;letter-spacing:.18em;text-transform:uppercase;
  padding:1rem 2.4rem;font-weight:500;
  background:transparent;color:var(--white);
  border:1.5px solid rgba(255,255,255,.25);
  transition:all .35s;
}
.btn-w:hover{border-color:var(--gl);color:var(--gl)}

/* Hero right — feature card */
.hero-right{
  opacity:0;animation:fadeUp .9s .6s forwards;
}
.hero-card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.1);
  border-top:2px solid var(--gold);
  backdrop-filter:blur(20px);
  padding:2.5rem;
  position:relative;overflow:hidden;
}
.hero-card::before{
  content:'';position:absolute;top:0;left:0;right:0;bottom:0;
  background:linear-gradient(135deg,rgba(26,111,181,.08),transparent);
  pointer-events:none;
}
.hc-tag{font-size:.6rem;letter-spacing:.35em;text-transform:uppercase;color:var(--gold);margin-bottom:1.5rem}
.hc-title{font-family:var(--serif);font-size:1.6rem;color:var(--white);font-weight:400;margin-bottom:.75rem}
.hc-desc{font-size:.84rem;line-height:1.75;color:rgba(255,255,255,.45);margin-bottom:2rem;font-weight:300}
.hc-stats{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(255,255,255,.08)}
.hc-stat{
  background:rgba(5,13,26,.4);padding:1.2rem 1.4rem;
}
.hc-stat strong{
  display:block;font-family:var(--serif);font-size:2rem;font-weight:400;color:var(--gl);line-height:1;margin-bottom:.3rem
}
.hc-stat span{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.35)}
.hero-scroll{
  position:absolute;bottom:2.5rem;left:6%;
  display:flex;align-items:center;gap:.8rem;z-index:10;
  opacity:0;animation:fadeUp 1s 1.2s forwards;
}
.hs-text{font-size:.58rem;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.3)}
.hs-line{width:44px;height:1px;background:linear-gradient(to right,var(--gold),transparent);animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.3;transform:scaleX(.6)}50%{opacity:1;transform:scaleX(1)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}

/* ══ MARQUEE ══ */
.marquee-wrap{
  background:var(--gold);padding:.8rem 0;overflow:hidden;
  border-top:1px solid var(--gd);border-bottom:1px solid var(--gd);
}
.marquee-track{
  display:flex;gap:3rem;
  animation:marquee 25s linear infinite;
  white-space:nowrap;width:max-content;
}
.marquee-track span{
  font-size:.68rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--navy);font-weight:600;
}
.marquee-track .dot{color:rgba(5,13,26,.35)}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ══ STATS BAR ══ */
.stats{
  background:var(--navy);
  display:grid;grid-template-columns:repeat(4,1fr);
}
.stat{
  padding:3rem 2rem;text-align:center;
  border-right:1px solid rgba(255,255,255,.07);
  transition:background .3s;
}
.stat:last-child{border-right:none}
.stat:hover{background:rgba(255,255,255,.03)}
.stat-n{
  font-family:var(--serif);font-size:3rem;font-weight:400;
  color:var(--gl);line-height:1;display:block;margin-bottom:.4rem
}
.stat-l{font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.35)}

/* ══ INTRO ══ */
.intro{padding:8rem 6%;background:var(--white)}
.intro-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:7rem;align-items:center}

/* Left visual */
.intro-visual{position:relative;height:560px}
.iv-main{
  position:absolute;top:0;left:0;width:65%;height:75%;
  background:var(--navy-3);
  border:1px solid rgba(5,13,26,.08);
  overflow:hidden;
}
.iv-main-inner{
  width:100%;height:100%;
  background:linear-gradient(135deg,var(--navy-2) 0%,var(--navy-4) 100%);
  display:flex;align-items:center;justify-content:center;flex-direction:column;gap:.75rem;
}
.iv-accent{
  position:absolute;bottom:0;right:0;width:55%;height:55%;
  background:var(--off);border:1px solid rgba(5,13,26,.08);
  overflow:hidden;
}
.iv-accent-inner{
  width:100%;height:100%;
  background:linear-gradient(135deg,var(--off) 0%,#E8EDF4 100%);
  display:flex;align-items:center;justify-content:center;flex-direction:column;gap:.5rem;
}
.iv-badge{
  position:absolute;left:-1rem;
  background:var(--gold);color:var(--navy);
  padding:.9rem 1.2rem;z-index:10;
  border-radius:1.75rem;
  min-width:130px;
  text-align:center;
  box-shadow:0 10px 28px rgba(201,168,76,.28);
}
.iv-badge strong{font-family:var(--serif);font-size:1.7rem;font-weight:500;line-height:1;display:block;margin-bottom:.1rem}
.iv-badge span{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700}
.iv-line{
  position:absolute;top:55%;left:60%;width:1px;height:80px;
  background:linear-gradient(to bottom,var(--gold),transparent);
  opacity:.4;
}
/* photo placeholder labels */
.ph-img{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;opacity:.25}
.ph-img-icon{font-size:2.5rem}
.ph-img-txt{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--navy-mid)}

/* Right text */
.intro-text .section-eyebrow{color:var(--blue);margin-bottom:1.1rem}
.intro-text .section-eyebrow::before{background:var(--blue)}
.intro-h{font-family:var(--serif);font-size:clamp(2rem,3vw,3rem);font-weight:400;line-height:1.25;color:var(--navy);margin-bottom:1.25rem}
.intro-h em{font-style:italic;color:var(--blue)}
.intro-body{font-size:.95rem;line-height:1.85;color:rgba(5,13,26,.6);font-weight:300;max-width:480px;margin-bottom:2.5rem}
.intro-pillars{display:flex;flex-direction:column;gap:0}
.pillar{
  display:flex;align-items:flex-start;gap:1.2rem;
  padding:1rem 1rem;
  border-left:2px solid transparent;
  transition:all .35s;cursor:default;
}
.pillar:hover{border-left-color:var(--gold);background:rgba(201,168,76,.04)}
.p-n{font-family:var(--serif);font-size:1.5rem;color:rgba(201,168,76,.3);min-width:30px;line-height:1}
.p-c h4{font-size:.84rem;font-weight:600;color:var(--navy);margin-bottom:.2rem}
.p-c p{font-size:.76rem;color:rgba(5,13,26,.5);line-height:1.6}

/* ══ VIDEO SECTION ══ */
.video-section{
  padding:8rem 6%;
  background:var(--navy-2);
  position:relative;overflow:hidden;
}
.video-section::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 70% 80% at 50% 50%,rgba(26,111,181,.15),transparent),
    radial-gradient(ellipse 40% 40% at 10% 80%,rgba(201,168,76,.07),transparent);
  pointer-events:none;
}
.vs-inner{max-width:1200px;margin:0 auto}
.vs-hdr{text-align:center;margin-bottom:4rem}
.vs-hdr .se{color:var(--gl);margin-bottom:1.1rem}
.vs-hdr .se::before{background:var(--gl)}
.vs-h{font-family:var(--serif);font-size:clamp(2rem,3.5vw,3.2rem);font-weight:400;color:var(--white);margin-bottom:1rem}
.vs-h em{font-style:italic;color:var(--gl)}
.vs-p{font-size:.95rem;line-height:1.8;color:rgba(255,255,255,.45);font-weight:300;max-width:500px;margin:0 auto}

.video-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:1.5rem}
.vid-main{
  position:relative;aspect-ratio:16/9;
  background:var(--navy-3);
  border:1px solid rgba(255,255,255,.08);border-top:2px solid var(--gold);
  overflow:hidden;cursor:pointer;
}
.vid-ph{
  width:100%;height:100%;
  background:linear-gradient(135deg,var(--navy-3),var(--navy-4),var(--navy-mid));
  display:flex;align-items:center;justify-content:center;flex-direction:column;gap:1rem;
  opacity:.4;
}
.vid-ph-icon{font-size:3rem}
.vid-ph-txt{font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.5)}
.vid-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(5,13,26,.9) 0%,transparent 55%);
  display:flex;flex-direction:column;justify-content:flex-end;padding:2rem;
  transition:background .4s;
}
.vid-main:hover .vid-overlay{background:linear-gradient(to top,rgba(5,13,26,.7) 0%,transparent 65%)}
.play-btn{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:72px;height:72px;border-radius:50%;
  background:rgba(201,168,76,.15);border:2px solid var(--gold);
  display:flex;align-items:center;justify-content:center;
  transition:all .35s;backdrop-filter:blur(10px);
}
.vid-main:hover .play-btn{background:var(--gold);transform:translate(-50%,-50%) scale(1.08)}
.play-btn svg{width:24px;height:24px;fill:var(--gold);transition:fill .3s;margin-left:4px}
.vid-main:hover .play-btn svg{fill:var(--navy)}
.vid-tag{font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:.4rem}
.vid-title{font-family:var(--serif);font-size:1.5rem;font-weight:400;color:var(--white)}

.vid-side{display:flex;flex-direction:column;gap:1.5rem}
.vid-card{
  position:relative;flex:1;min-height:180px;
  background:var(--navy-3);border:1px solid rgba(255,255,255,.07);
  overflow:hidden;cursor:pointer;transition:border-color .3s;
}
.vid-card:hover{border-color:rgba(201,168,76,.35)}
.vid-card-ph{
  width:100%;height:100%;
  background:linear-gradient(135deg,var(--navy-3),var(--navy-mid));
  display:flex;align-items:center;justify-content:center;font-size:2.5rem;opacity:.3;
}
.vid-card-ov{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(5,13,26,.75),rgba(5,13,26,.3));
  display:flex;flex-direction:column;justify-content:flex-end;padding:1.25rem;
  transition:background .4s;
}
.vid-card:hover .vid-card-ov{background:linear-gradient(135deg,rgba(5,13,26,.55),rgba(5,13,26,.1))}
.play-sm{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:48px;height:48px;border-radius:50%;
  background:rgba(201,168,76,.12);border:1px solid var(--gold);
  display:flex;align-items:center;justify-content:center;
  transition:all .3s;backdrop-filter:blur(8px);
}
.vid-card:hover .play-sm{background:var(--gold)}
.play-sm svg{width:16px;height:16px;fill:var(--gold);margin-left:3px;transition:fill .3s}
.vid-card:hover .play-sm svg{fill:var(--navy)}
.vc-tag{font-size:.58rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:.3rem}
.vc-title{font-size:.9rem;font-weight:500;color:var(--white)}

/* ══ PROGRAMMES PREVIEW ══ */
.programmes{padding:8rem 6%;background:var(--off)}
.prog-inner{max-width:1200px;margin:0 auto}
.prog-hdr{text-align:center;margin-bottom:5rem}
.prog-hdr .se{color:var(--blue);margin-bottom:1rem}
.prog-hdr .se::before{background:var(--blue)}
.prog-hdr h2{font-family:var(--serif);font-size:clamp(2rem,3.5vw,3.2rem);font-weight:400;color:var(--navy);margin-bottom:1rem}
.prog-hdr h2 em{font-style:italic;color:var(--blue)}
.prog-hdr p{font-size:.95rem;line-height:1.8;color:rgba(5,13,26,.55);max-width:520px;margin:0 auto}

.prog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:3.5rem}
.prog-card{
  background:var(--white);
  border:1px solid rgba(5,13,26,.07);
  border-top:3px solid transparent;
  padding:2.5rem 2rem;
  transition:all .4s;cursor:pointer;
  position:relative;overflow:hidden;
}
.prog-card::before{
  content:'';position:absolute;bottom:0;left:0;right:0;height:0;
  background:var(--navy-2);transition:height .4s var(--ease);z-index:0;
}
.prog-card:hover::before{height:100%}
.prog-card:hover{border-top-color:var(--gold);transform:translateY(-6px);box-shadow:0 20px 60px rgba(5,13,26,.15)}
.prog-card *{position:relative;z-index:1;transition:color .4s}
.prog-num{
  font-family:var(--serif);font-size:3.5rem;font-weight:300;
  color:rgba(5,13,26,.07);line-height:1;margin-bottom:1.25rem;
  transition:color .4s;
}
.prog-card:hover .prog-num{color:rgba(201,168,76,.12)}
.prog-icon{font-size:1.4rem;margin-bottom:1rem;display:block}
.prog-title{font-family:var(--serif);font-size:1.3rem;font-weight:400;color:var(--navy);margin-bottom:.6rem}
.prog-card:hover .prog-title{color:var(--gl)}
.prog-desc{font-size:.8rem;line-height:1.7;color:rgba(5,13,26,.5);font-weight:300}
.prog-card:hover .prog-desc{color:rgba(255,255,255,.45)}
.prog-arrow{
  display:inline-flex;align-items:center;gap:.5rem;
  font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;
  color:var(--blue);margin-top:1.5rem;font-weight:500;
}
.prog-card:hover .prog-arrow{color:var(--gold)}
.prog-cta{text-align:center}

/* ══ JOURNEY PREVIEW ══ */
.journey{padding:8rem 6%;background:var(--white)}
.j-inner{max-width:1100px;margin:0 auto}
.j-hdr{text-align:center;margin-bottom:5rem}
.j-steps{display:grid;grid-template-columns:repeat(5,1fr);position:relative}
.j-steps::before{
  content:'';position:absolute;top:30px;left:10%;right:10%;height:1px;
  background:linear-gradient(to right,transparent,var(--gold),transparent);opacity:.25;
}
.j-step{text-align:center;padding:0 .75rem}
.j-circle{
  width:60px;height:60px;border:1.5px solid rgba(5,13,26,.12);border-radius:50%;
  margin:0 auto 1.5rem;display:flex;align-items:center;justify-content:center;
  background:var(--white);font-family:var(--serif);font-size:1.35rem;color:var(--navy);
  position:relative;z-index:1;transition:all .35s;
  box-shadow:0 2px 20px rgba(5,13,26,.06);
}
.j-step:hover .j-circle{background:var(--navy);color:var(--gl);border-color:var(--navy);box-shadow:0 8px 30px rgba(5,13,26,.2)}
.j-step h4{font-size:.84rem;font-weight:600;color:var(--navy);margin-bottom:.35rem}
.j-step p{font-size:.72rem;color:rgba(5,13,26,.45);line-height:1.55}

/* ══ TESTIMONIAL / PROMISE ══ */
.promise{
  padding:9rem 6%;
  background:var(--navy);
  position:relative;overflow:hidden;text-align:center;
}
.promise::before{
  content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:800px;height:800px;border-radius:50%;
  border:1px solid rgba(201,168,76,.06);pointer-events:none;
}
.promise::after{
  content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:500px;height:500px;border-radius:50%;
  border:1px solid rgba(201,168,76,.08);pointer-events:none;
}
.promise-bg{
  position:absolute;inset:0;
  background:radial-gradient(ellipse 70% 70% at 50% 50%,rgba(26,111,181,.12),transparent);
  pointer-events:none;
}
.promise-inner{position:relative;z-index:1;max-width:800px;margin:0 auto}
.p-eyebrow{
  display:inline-flex;align-items:center;gap:.75rem;
  font-size:.62rem;letter-spacing:.4em;text-transform:uppercase;
  color:var(--gold);margin-bottom:2rem;
}
.p-eyebrow span{display:block;width:28px;height:1px;background:var(--gold);opacity:.6}
.p-h{font-family:var(--serif);font-size:clamp(2rem,4vw,3.5rem);font-weight:400;line-height:1.25;color:var(--white);margin-bottom:1.5rem}
.p-h em{font-style:italic;color:var(--gl)}
.p-txt{font-size:1rem;line-height:1.9;color:rgba(255,255,255,.45);font-weight:300;margin-bottom:3rem;max-width:640px;margin-left:auto;margin-right:auto}
.p-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ══ FOOTER ══ */
footer{
  background:var(--navy-2);
  border-top:1px solid rgba(201,168,76,.15);
  padding:4rem 6% 2.5rem;
}
.ft{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:3rem;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.07);margin-bottom:2rem}
.fb-name{font-family:var(--serif);font-size:1.3rem;font-weight:400;color:var(--gl);margin-bottom:.5rem}
.fb-tag{font-size:.58rem;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.25);margin-bottom:1.2rem}
.fb-desc{font-size:.8rem;line-height:1.75;color:rgba(255,255,255,.35);max-width:240px}
.fc-title{font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:1.2rem}
.fc-links{display:flex;flex-direction:column;gap:.7rem}
.fc-links a{font-size:.8rem;color:rgba(255,255,255,.4);text-decoration:none;transition:color .3s}
.fc-links a:hover{color:var(--gl)}
.fb{display:flex;justify-content:space-between;align-items:center}
.fc{font-size:.7rem;color:rgba(255,255,255,.22)}
.ftg{font-family:var(--serif);font-style:italic;font-size:.88rem;color:rgba(201,168,76,.4)}

/* ══ RESPONSIVE ══ */
@media(max-width:1024px){
  .hero-inner{grid-template-columns:1fr;padding-top:100px}
  .hero-right{display:none}
  .intro-inner{grid-template-columns:1fr;gap:4rem}
  .intro-visual{height:340px}
  .video-grid{grid-template-columns:1fr}
  .prog-grid{grid-template-columns:1fr 1fr}
  .j-steps{grid-template-columns:1fr 1fr 1fr;gap:2rem}
  .j-steps::before{display:none}
}
@media(max-width:768px){
  .stats{grid-template-columns:1fr 1fr}
  .prog-grid{grid-template-columns:1fr}
  .j-steps{grid-template-columns:1fr 1fr}
  .ft{grid-template-columns:1fr 1fr;gap:2rem}
  nav .nav-links{display:none}
  .hamburger{display:flex}
  .fb{flex-direction:column;gap:1rem;text-align:center}
}
@media(max-width:480px){
  .j-steps{grid-template-columns:1fr}
  .ft{grid-template-columns:1fr}
}

/* Section eyebrow shared */
.se{
  display:inline-flex;align-items:center;gap:.75rem;
  font-size:.62rem;letter-spacing:.4em;text-transform:uppercase;margin-bottom:1rem;
}
.se::before{content:'';display:block;width:22px;height:1px}
