:root{
  --bg:#F2F5FF;
  --bg-alt:#FFFFFF;
  --surface:#F7F8FC;
  --divider:#E0E6F8;
  --text:#0B1220;
  --muted:#3F4C6E;
  --brand:#2743DA;
  --brand-2:#9B6DF7;
  --gold:#D4A24F;
  --accent:#7A56FF;

  --grad-brand: linear-gradient(135deg, #2743DA 0%, #9B6DF7 45%, #D4A24F 100%);
  --grad-soft: radial-gradient(1200px 600px at 20% -10%, #E9EEF7 0%, #F7F8FC 60%, #FFFFFF 100%);

  --radius:18px;
  --shadow-lg: 0 20px 45px rgba(22, 38, 120, 0.16);
  --shadow-card: 0 26px 60px rgba(39,67,218,0.18);

  --s-1:8px; --s-2:16px; --s-3:24px; --s-4:32px;
  --s-5:40px; --s-6:52px; --s-7:72px; --s-8:104px;

  --fs-48: clamp(2.4rem, 3.6vw, 3.4rem);
  --fs-36: clamp(1.85rem, 2.8vw, 2.45rem);
  --fs-28: clamp(1.35rem, 2.2vw, 1.85rem);
  --fs-22: clamp(1.1rem, 1.8vw, 1.4rem);
  --fs-18: clamp(1rem, 1.4vw, 1.15rem);
  --fs-16: 1rem;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--text);
  background:linear-gradient(150deg, rgba(247,249,255,1) 0%, rgba(233,240,255,1) 42%, rgba(220,229,255,1) 100%);
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
  line-height:1.6;
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
  position:relative;
  overflow-x:hidden;
  display:flex;
  flex-direction:column;
  overflow-x:hidden;
}
/* Global responsive media and text wrapping to prevent overflow */
img, svg, video, canvas, iframe, embed{max-width:100%; height:auto}
/* Prevent long unbroken strings from causing horizontal scroll */
h1, h2, h3, h4, p, li, figcaption{overflow-wrap:anywhere; word-break:normal}
body::before{
  content:"";
  position:fixed;
  inset:0;
  background:radial-gradient(900px 600px at 12% 10%, rgba(122,108,255,0.22) 0%, rgba(122,108,255,0) 65%),
             radial-gradient(820px 560px at 88% -4%, rgba(255,193,133,0.25) 0%, rgba(255,193,133,0) 70%);
  pointer-events:none;
  z-index:-1;
}
h1,h2,h3,h4{font-family:"Playfair Display", Georgia, "Times New Roman", serif; line-height:1.2; margin:0 0 var(--s-2)}
h1{font-size:var(--fs-48)}
h2{font-size:var(--fs-36)}
h3{font-size:var(--fs-28)}
h4{font-size:var(--fs-22)}
p{margin:0 0 var(--s-2); color:var(--muted)}
.page-shell{flex:1; display:grid; position:relative}
.section{padding:var(--s-6) var(--s-2); position:relative}
.section::after{
  content:"";
  position:absolute;
  inset:var(--s-2) auto var(--s-2) calc(-1 * var(--s-2));
  width:1px;
  background:linear-gradient(180deg, rgba(121,86,255,0.18), rgba(121,86,255,0));
  opacity:0.5;
  pointer-events:none;
}
.section > .container{
  position:relative;
  max-width:1180px;
  margin:0 auto;
  padding:var(--s-6) clamp(var(--s-3), 4vw, var(--s-5));
  border-radius:calc(var(--radius) * 1.6);
  background:linear-gradient(150deg, rgba(255,255,255,0.94) 0%, rgba(244,247,255,0.92) 48%, rgba(237,240,255,0.88) 100%);
  border:1px solid rgba(39,67,218,0.16);
  box-shadow:var(--shadow-card);
  overflow:hidden;
}
.section > .container::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(135deg, rgba(155,109,247,0.12) 0%, rgba(39,67,218,0.06) 55%, rgba(255,193,133,0.16) 100%);
  opacity:0.38;
  mix-blend-mode:screen;
  pointer-events:none;
}
.container{position:relative; z-index:1}
.card{
  position:relative;
  background:linear-gradient(150deg, rgba(255,255,255,0.96) 0%, rgba(240,244,255,0.9) 100%);
  border:1px solid rgba(39,67,218,0.14);
  border-radius:calc(var(--radius) * 1.05);
  box-shadow:0 22px 40px rgba(12, 20, 55, 0.14);
  padding:var(--s-4);
  overflow:hidden;
}
.card::after{
  content:"";
  position:absolute;
  inset:1px;
  border-radius:inherit;
  background:linear-gradient(140deg, rgba(155,109,247,0.1), rgba(255,255,255,0));
  opacity:0.4;
  pointer-events:none;
}
.badge{display:inline-block; padding:6px 12px; border-radius:999px; background:rgba(122,108,255,0.18); color:#24328a; font-size:0.85rem; border:1px solid rgba(39,67,218,0.22); backdrop-filter:blur(8px)}
.hr{height:1px; background:linear-gradient(90deg, rgba(39,67,218,0), rgba(39,67,218,0.35), rgba(39,67,218,0)); border:0; margin:var(--s-6) 0}
.btn{appearance:none; border:0; cursor:pointer; font-weight:600; border-radius:999px; padding:12px 20px; transition:transform .18s ease, box-shadow .18s ease, background .18s ease; letter-spacing:0.01em}
.btn:focus-visible{outline:3px solid rgba(155,109,247,0.55); outline-offset:2px}
.btn-primary{ color:#fff; background:linear-gradient(135deg, #2743DA 0%, #7A56FF 55%, #D4A24F 100%); box-shadow:0 14px 28px rgba(39,67,218,0.35) }
.btn-primary:hover{transform:translateY(-2px); box-shadow:0 18px 32px rgba(39,67,218,0.4)}
.btn-ghost{ background:rgba(39,67,218,0.08); color:#2134b5; border:1px solid rgba(39,67,218,0.16) }
.btn-ghost:hover{background:rgba(39,67,218,0.12)}
.loading-bar{position:fixed; top:0; left:0; width:100%; height:4px; background:rgba(255,255,255,0.35); backdrop-filter:blur(12px); z-index:9999; overflow:hidden; transition:opacity .35s ease, transform .35s ease}
.loading-bar__progress{display:block; width:100%; height:100%; background:linear-gradient(90deg, #2743DA 0%, #7A56FF 50%, #D4A24F 100%); transform-origin:left; animation:loadingSweep 3s ease forwards}
body.is-loaded .loading-bar{opacity:0; transform:translateY(-100%)}
body.is-loaded .loading-bar__progress{animation:loadingSweepComplete .4s ease forwards}
.nav-section{padding-top:var(--s-2); padding-bottom:var(--s-2)}
.nav-section > .container{padding:var(--s-2) var(--s-3); background:transparent; border:none; box-shadow:none}
.nav-section > .container::before{display:none}
.nav-section::after{display:none}
.nav-card{display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:var(--s-2); padding:10px var(--s-3); border-radius:calc(var(--radius) * 1.05); background:linear-gradient(140deg, rgba(255,255,255,0.97), rgba(236,242,255,0.93)); border:1px solid rgba(39,67,218,0.14); box-shadow:0 10px 24px rgba(39,67,218,0.1); width:100%}
.nav-logo img{display:block; width:120px; max-width:100%; height:auto}
.nav-title{
  font-family:"Playfair Display", Georgia, "Times New Roman", serif;
  font-size:0.95rem;
  letter-spacing:0.2em;
  text-transform:uppercase;
  text-align:center;
  font-weight:600;
  background:linear-gradient(120deg,
    #8EC5FC 0%,
    #E0C3FC 22%,
    #FFE7F1 44%,
    #B5FFFC 66%,
    #FFF7C0 88%,
    #8EC5FC 100%);
  background-size:260% 260%;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  animation:navTitlePulse 8s ease-in-out infinite;
  text-shadow:0 8px 24px rgba(142,197,252,0.35);
}
.nav-cta{padding-inline:var(--s-2); white-space:nowrap; justify-self:end; margin-left:auto}
@media (max-width:767px){
  .nav-card{grid-template-columns:auto auto; justify-content:space-between}
  .nav-title{display:none}
}
.hero{position:relative; overflow:hidden; background:linear-gradient(135deg, #f2f6ff 0%, #e6ecff 45%, #f8f4ff 100%); color:#0f1a45}
.hero.section{padding-block:clamp(var(--s-5), 6vw, var(--s-6)); padding:0px;}
.hero::before, .hero::after{content:""; position:absolute; pointer-events:none; filter:blur(120px)}
.hero::before{top:-28%; left:-18%; width:720px; height:720px; background:radial-gradient(closest-side, rgba(122,108,255,0.38), rgba(122,108,255,0)); opacity:.65; animation:heroGlow 18s ease-in-out infinite alternate}
.hero::after{bottom:-30%; right:-22%; width:780px; height:780px; background:radial-gradient(closest-side, rgba(255,193,133,0.32), rgba(255,193,133,0)); opacity:.5; animation:heroGlow 22s ease-in-out infinite alternate-reverse}
.hero > .container{
  width:100%;
  max-width:none;
  margin:0;
  /* Fit to viewport height and center content */
  min-height:calc(var(--app-vh, 1vh) * 100);
  display:flex;
  align-items:center;
  justify-content:center;
  /* Fallback padding for older browsers (overridden by clamp below if supported) */
  padding:48px 24px;
  padding:clamp(var(--s-5), 5.5vw, var(--s-6)) clamp(var(--s-4), 5vw, var(--s-6));
  background:transparent;
  border:none;
  box-shadow:none;
  border-radius:0;
}
.hero-gradient-overlay{position:absolute; inset:0; pointer-events:none; z-index:0; mix-blend-mode:screen; background:
  radial-gradient(120% 120% at 12% 14%, rgba(122,108,255,0.35), rgba(122,108,255,0) 60%),
  radial-gradient(130% 120% at 88% 18%, rgba(255,193,133,0.28), rgba(255,193,133,0) 60%),
  radial-gradient(160% 140% at 48% 110%, rgba(155,109,247,0.24), rgba(155,109,247,0) 70%);
  opacity:0.9;
}
.hero-bubbles{position:absolute; inset:0; z-index:0; overflow:hidden}
.hero-bubbles span{position:absolute; bottom:-200px; display:block; width:52px; height:52px; border-radius:50%; background:linear-gradient(135deg, rgba(122,108,255,0.34), rgba(255,193,133,0.32)); box-shadow:0 32px 58px rgba(39,67,218,0.26); animation:rise var(--dur, 22s) linear infinite; opacity:0.78; border:1px solid rgba(39,67,218,0.2)}
/* Variations */
.hero-bubbles span:nth-child(1){left:4%; width:44px; height:44px; --dur: 18s; animation-delay:-2s}
.hero-bubbles span:nth-child(2){left:10%; width:60px; height:60px; --dur: 22s; animation-delay:-4s}
.hero-bubbles span:nth-child(3){left:18%; width:42px; height:42px; --dur: 17s; animation-delay:-6s}
.hero-bubbles span:nth-child(4){left:25%; width:64px; height:64px; --dur: 26s; animation-delay:-3s}
.hero-bubbles span:nth-child(5){left:32%; width:54px; height:54px; --dur: 20s; animation-delay:-8s}
.hero-bubbles span:nth-child(6){left:38%; width:72px; height:72px; --dur: 28s; animation-delay:-10s}
.hero-bubbles span:nth-child(7){left:45%; width:50px; height:50px; --dur: 19s; animation-delay:-5s}
.hero-bubbles span:nth-child(8){left:52%; width:62px; height:62px; --dur: 25s; animation-delay:-9s}
.hero-bubbles span:nth-child(9){left:59%; width:48px; height:48px; --dur: 18s; animation-delay:-11s}
.hero-bubbles span:nth-child(10){left:65%; width:56px; height:56px; --dur: 23s; animation-delay:-7s}
.hero-bubbles span:nth-child(11){left:71%; width:46px; height:46px; --dur: 16s; animation-delay:-12s}
.hero-bubbles span:nth-child(12){left:76%; width:66px; height:66px; --dur: 27s; animation-delay:-14s}
.hero-bubbles span:nth-child(13){left:82%; width:50px; height:50px; --dur: 19s; animation-delay:-16s}
.hero-bubbles span:nth-child(14){left:88%; width:60px; height:60px; --dur: 24s; animation-delay:-18s}
.hero-bubbles span:nth-child(15){left:94%; width:48px; height:48px; --dur: 20s; animation-delay:-13s}
.hero-bubbles span:nth-child(16){left:1%; width:74px; height:74px; --dur: 30s; animation-delay:-20s}
.hero-bubbles span:nth-child(17){left:22%; width:56px; height:56px; --dur: 21s; animation-delay:-17s}
.hero-bubbles span:nth-child(18){left:47%; width:46px; height:46px; --dur: 18s; animation-delay:-19s}
.hero-bubbles span:nth-child(19){left:68%; width:68px; height:68px; --dur: 29s; animation-delay:-21s}
.hero-bubbles span:nth-child(20){left:86%; width:54px; height:54px; --dur: 22s; animation-delay:-23s}
.hero-bubbles span:nth-child(21){left:12%; width:50px; height:50px; --dur: 18s; animation-delay:-24s}
.hero-bubbles span:nth-child(22){left:58%; width:64px; height:64px; --dur: 27s; animation-delay:-26s}
.hero-bubbles span:nth-child(23){left:74%; width:46px; height:46px; --dur: 19s; animation-delay:-22s}
.hero-bubbles span:nth-child(24){left:48%; width:58px; height:58px; --dur: 24s; animation-delay:-28s}

@keyframes rise{
  0%{transform:translate3d(0,0,0) scale(0.9); opacity:0}
  15%{opacity:0.45}
  30%{transform:translate3d(-14px,-30vh,0) scale(1.05); opacity:0.75}
  55%{transform:translate3d(18px,-60vh,0) scale(1); opacity:0.9}
  80%{transform:translate3d(-20px,-95vh,0) scale(1.08); opacity:0.6}
  100%{transform:translate3d(12px,-130vh,0) scale(0.95); opacity:0}
}
.hero-grid{position:relative; display:grid; gap:clamp(var(--s-3), 2.6vw, var(--s-4)); align-items:stretch; width:100%; max-width:1180px; margin:0 auto; padding:0 clamp(var(--s-2), 6vw, var(--s-3)); z-index:1}
.hero-copy{position:relative; display:grid; gap:clamp(var(--s-3), 2vw, var(--s-3)); padding:clamp(var(--s-3), 2.4vw, var(--s-4)); border-radius:calc(var(--radius) * 1.6); background:linear-gradient(160deg, rgba(255,255,255,0.94) 0%, rgba(233,238,255,0.9) 64%, rgba(226,232,255,0.88) 100%); border:1px solid rgba(39,67,218,0.14); backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px); box-shadow:0 26px 58px rgba(25,49,140,0.16); text-align:center; justify-items:center}
.hero-copy::before{content:""; position:absolute; inset:-18px; border-radius:inherit; background:linear-gradient(135deg, rgba(122,108,255,0.22), rgba(255,193,133,0.18)); opacity:0.4; z-index:-1; filter:blur(18px)}
.hero-copy p{color:#33406b}
.hero-heading{display:grid; gap:var(--s-2); width:100%}
.hero-tag{display:inline-flex; align-items:center; gap:10px; padding:9px 18px; border-radius:999px; background:rgba(122,108,255,0.15); color:#26327f; font-weight:700; letter-spacing:0.2em; text-transform:uppercase; font-size:0.78rem; backdrop-filter:blur(10px); box-shadow:0 10px 24px rgba(39,67,218,0.14)}
.hero-title{margin:var(--s-2) 0 0; letter-spacing:0.06em; line-height:1.12; font-size:clamp(2rem, 3.1vw, 2.8rem); text-transform:uppercase; position:relative; display:inline-block; opacity:0; transform:translateY(18px); animation:heroTitleRise .75s ease forwards}
.hero-title-main{display:inline-block; padding-inline:8px; background:linear-gradient(130deg, #1d2b6f 0%, #2743DA 40%, #7A56FF 70%, #D4A24F 100%); -webkit-background-clip:text; background-clip:text; color:transparent; text-shadow:0 18px 36px rgba(39,67,218,0.28); animation:heroTitleGlow 2.6s ease-in-out .2s infinite alternate}
.hero-title-sub{margin:clamp(var(--s-2), 1.7vw, var(--s-3)) 0 0; font-size:clamp(1.05rem, 2.1vw, 1.25rem); letter-spacing:0.12em; text-transform:uppercase; font-weight:700; background:linear-gradient(120deg, #4b60de 0%, #8f6efc 55%, #f0b97a 100%); -webkit-background-clip:text; background-clip:text; color:transparent; text-shadow:0 12px 26px rgba(39,67,218,0.22); opacity:0; transform:translateY(12px); animation:heroSubtitleFade .85s ease .15s forwards}
.hero-title::after{content:""; position:absolute; left:0; right:0; bottom:-14px; height:6px; border-radius:999px; background:linear-gradient(90deg, rgba(39,67,218,0.65), rgba(122,86,255,0.6), rgba(212,162,79,0.58)); transform:scaleX(0.38); transform-origin:center; opacity:0; animation:heroAccent .65s ease .25s forwards}
.hero-heading .accent{display:block; width:120px; height:6px; border-radius:999px; background:var(--grad-brand); box-shadow:0 6px 18px rgba(39,67,218,0.28); transform:scaleX(0); transform-origin:left; animation:heroAccent .7s ease .45s forwards}
.hero-lead{color:#0f1f58; font-size:clamp(1.35rem, 2.2vw, 1.55rem); font-weight:600}
.hero-description{display:grid; gap:clamp(var(--s-3), 2vw, var(--s-4)); max-width:760px; margin-inline:auto; color:#2b356d; opacity:0; animation:heroSubtitleFade .9s ease .25s forwards}
.hero-body{display:grid; gap:clamp(var(--s-2), 1.6vw, var(--s-3)); border-radius:calc(var(--radius) * 1.35); padding:clamp(var(--s-2), 2vw, var(--s-3)); background:linear-gradient(150deg, rgba(255,255,255,0.88) 0%, rgba(236,240,255,0.82) 70%, rgba(226,232,255,0.8) 100%); border:1px solid rgba(39,67,218,0.12); box-shadow:0 22px 44px rgba(25,49,140,0.12)}
.hero-body p{margin:0; padding:clamp(var(--s-2), 1.5vw, var(--s-2)) clamp(var(--s-3), 2vw, var(--s-3)); border-radius:calc(var(--radius) * 1.15); background:linear-gradient(140deg, rgba(255,255,255,0.95) 0%, rgba(243,246,255,0.9) 100%); border:1px solid rgba(39,67,218,0.08); box-shadow:0 12px 26px rgba(15,29,86,0.08); color:#243369; line-height:1.7}
.hero-body .hero-lead{color:#10205c; font-size:clamp(1.2rem, 2vw, 1.45rem); font-weight:600; letter-spacing:0.01em; background:linear-gradient(135deg, rgba(39,67,218,0.18), rgba(122,86,255,0.14))}
.hero-actions{display:flex; gap:clamp(var(--s-2), 1.4vw, var(--s-3)); flex-wrap:wrap; align-items:center; justify-content:center; margin:0}
.hero-actions .btn{min-width:210px}
.hero .btn-primary{box-shadow:0 20px 38px rgba(39,67,218,0.32)}
.hero .btn-primary:hover{transform:translateY(-2px)}
.hero-details{margin-top:var(--s-4); padding:var(--s-5); border-radius:calc(var(--radius) + 2px); background:linear-gradient(150deg, rgba(255,255,255,0.96) 0%, rgba(239,244,255,0.92) 100%); border:1px solid rgba(39,67,218,0.2); box-shadow:0 26px 52px rgba(9,20,66,0.2); display:grid; gap:var(--s-3)}
.hero-details h3{margin:0; text-align:center; color:#0f1a45}
.hero-details h3::after{content:""; display:block; width:82px; height:6px; border-radius:999px; background:var(--grad-brand); margin:10px auto 0; box-shadow:0 6px 16px rgba(39,67,218,0.25); transform:scaleX(0); transform-origin:center; transition:transform .55s ease .12s}
.hero-details ul{max-width:820px; margin:0 auto}
.hero-details p{text-align:center; color:#2a3568}
.hero-details{isolation:isolate}
.hero-details::before{
  content:""; position:absolute; inset:-6%; z-index:-1; border-radius:calc(var(--radius) * 1.6);
  background:radial-gradient(800px 520px at 50% -10%, rgba(122,108,255,0.18), rgba(255,193,133,0.14), rgba(255,255,255,0));
  filter:blur(14px); opacity:0.85; pointer-events:none;
}
.hero-details ul{list-style:none; padding-left:0; display:grid; gap:var(--s-2)}
.hero-details ul li{position:relative; padding-left:38px; opacity:0; transform:translateY(8px)}
.hero-details ul li::before{
  content:""; position:absolute; left:0; top:8px; width:24px; height:24px; border-radius:10px;
  background:var(--grad-brand); box-shadow:0 8px 18px rgba(39,67,218,0.28);
}
.hero-details.reveal.show h3::after{transform:scaleX(1)}
.hero-details.reveal.show ul li{animation:fadeUp .5s ease forwards}
.hero-details.reveal.show ul li:nth-child(1){animation-delay:.02s}
.hero-details.reveal.show ul li:nth-child(2){animation-delay:.08s}
.hero-details.reveal.show ul li:nth-child(3){animation-delay:.14s}
.hero-details-buttons .btn-primary{position:relative}
.hero-details-buttons .btn-primary::after{
  content:""; position:absolute; inset:-2px; border-radius:inherit; z-index:-1;
  background:linear-gradient(135deg, rgba(39,67,218,0.35), rgba(155,109,247,0.32), rgba(212,162,79,0.35));
  filter:blur(12px); opacity:0; transition:opacity .28s ease;
}
.hero-details-buttons .btn-primary:hover::after{opacity:.65}

@keyframes fadeUp{to{opacity:1; transform:none}}
.hero-details-figure{margin:var(--s-3) 0 0; border-radius:calc(var(--radius) + 4px); overflow:hidden; border:1px solid rgba(39,67,218,0.16); box-shadow:0 22px 38px rgba(39,67,218,0.18)}
.hero-details-figure img{display:block; width:100%; height:auto}
/* Make meeting2.png smaller on desktop and centered */
@media (min-width: 1024px){
  .hero-details-figure img[src$="images/meeting2.png"],
  .hero-details-figure img[src$="/images/meeting2.png"]{
    width:50%;
    margin-inline:auto;
    display:block;
  }
  .hero-details-figure img[src$="images/meeting.png"],
  .hero-details-figure img[src$="/images/meeting.png"]{
    width:50%;
    margin-inline:auto;
    display:block;
  }
  /* CTA image city_kl: make smaller and centered on desktop */
  .cta-figure img[src$="images/city_kl.png"],
  .cta-figure img[src$="/images/city_kl.png"]{
    width:50%;
    height:auto;
    margin-inline:auto;
    align-self:center;
    flex:0 0 auto;
    object-fit:contain;
  }
}
.section-gains{position:relative; overflow:hidden}
.section-gains::before{content:""; position:absolute; inset:0; background:linear-gradient(135deg, rgba(39,67,218,0.12), rgba(122,86,255,0.08)); opacity:0.65; pointer-events:none}
.section-gains .container{background:linear-gradient(140deg, rgba(255,255,255,0.94) 0%, rgba(239,244,255,0.9) 55%, rgba(231,239,255,0.88) 100%); border:1px solid rgba(39,67,218,0.12); box-shadow:0 28px 62px rgba(25,49,140,0.12); border-radius:calc(var(--radius) * 1.5); padding:clamp(var(--s-4), 4vw, var(--s-5)) clamp(var(--s-4), 4vw, var(--s-5))}
.gains-container{display:grid; gap:clamp(var(--s-4), 4vw, var(--s-5))}
.gains-header{display:grid; gap:var(--s-2); text-align:center}
.gains-eyebrow{display:inline-flex; justify-content:center; align-items:center; gap:10px; margin:0 auto; padding:6px 18px; border-radius:999px; font-weight:600; letter-spacing:0.18em; text-transform:uppercase; font-size:0.72rem; color:#24328a; background:rgba(39,67,218,0.12); border:1px solid rgba(39,67,218,0.16)}
.gains-header p{margin:0; color:#2e3a72; max-width:640px; margin-inline:auto}
.gains-layout{display:grid; gap:clamp(var(--s-4), 4vw, var(--s-5)); align-items:start}
.gains-list{display:grid; gap:var(--s-3); grid-template-columns:minmax(0,1fr)}
.gains-list .gains-card:nth-child(odd){background:linear-gradient(130deg, rgba(255,255,255,0.97) 0%, rgba(235,242,255,0.9) 100%)}
.gains-list .gains-card:nth-child(even){background:linear-gradient(130deg, rgba(255,255,255,0.98) 0%, rgba(244,248,255,0.92) 100%)}
.gains-card{display:grid; grid-template-columns:auto 1fr; gap:var(--s-3); padding:clamp(var(--s-3), 3vw, var(--s-4)); border-radius:calc(var(--radius) * 1.3); background:linear-gradient(130deg, rgba(255,255,255,0.97) 0%, rgba(242,245,255,0.92) 100%); border:1px solid rgba(39,67,218,0.14); box-shadow:0 20px 40px rgba(25,49,140,0.12); width:100%}
.gains-icon{display:grid; place-items:center; width:60px; height:60px; border-radius:20px; background:linear-gradient(140deg, rgba(39,67,218,0.22), rgba(122,86,255,0.22)); font-weight:700; color:#1f2c67; font-size:1.1rem; letter-spacing:0.08em}
.gains-copy h3{margin:0 0 6px; font-size:clamp(1.1rem, 2vw, 1.3rem); color:#1b2660}
.gains-copy p{margin:0; color:#2d3770; line-height:1.65}
.gains-visual{display:grid; place-items:center}
.gains-visual figure{margin:0; border-radius:calc(var(--radius) * 1.4); overflow:hidden; border:1px solid rgba(39,67,218,0.16); box-shadow:0 30px 60px rgba(39,67,218,0.2); background:linear-gradient(160deg, rgba(39,67,218,0.12), rgba(122,86,255,0.12))}
.gains-visual img{display:block; width:100%; height:auto}
.gains-cta-wrap{display:flex; justify-content:center; margin-top:var(--s-3)}
.gains-cta-wrap .btn{min-width:220px; text-align: center;}
.hero-details-buttons{display:flex; justify-content:flex-end; gap:var(--s-2); flex-wrap:wrap; margin-top:var(--s-2)}
.hero-details-cta{white-space:nowrap}
.hero-benefits{position:relative; /* allow children to escape decorative overlap on small screens */ overflow:visible; z-index:3}
.hero-benefits::before{content:""; position:absolute; inset:0; background:linear-gradient(135deg, rgba(39,67,218,0.08), rgba(122,86,255,0.06)); opacity:0.8; pointer-events:none}
.hero-benefits .container{position:relative; z-index:4; background:linear-gradient(150deg, rgba(255,255,255,0.96) 0%, rgba(239,244,255,0.94) 60%, rgba(232,239,255,0.9) 100%); border:1px solid rgba(39,67,218,0.12); box-shadow:0 26px 54px rgba(25,49,140,0.12); border-radius:calc(var(--radius) * 1.5)}
.benefits-header{display:grid; gap:8px; text-align:center; padding:clamp(var(--s-4), 4vw, var(--s-5)) clamp(var(--s-4), 4vw, var(--s-5)) var(--s-2)}
.benefits-eyebrow{display:inline-flex; align-items:center; justify-content:center; gap:10px; margin:0 auto; padding:6px 16px; border-radius:999px; font-weight:700; letter-spacing:0.16em; text-transform:uppercase; font-size:0.72rem; color:#24328a; background:rgba(39,67,218,0.12); border:1px solid rgba(39,67,218,0.16)}
.benefits-header h2{margin:6px 0 0; color:#0f1a45}
.benefits-header h2::after{content:""; display:block; width:86px; height:6px; border-radius:999px; background:var(--grad-brand); margin:10px auto 0; box-shadow:0 6px 16px rgba(39,67,218,0.22)}
.benefits-header p{margin:0; color:#2a3568}
.benefits-list{list-style:none; padding:0; margin:0; display:grid; gap:var(--s-3); grid-template-columns:repeat(1, minmax(0,1fr));}
.benefits-list li{position:relative; display:flex; align-items:center; min-height:clamp(72px, 9vw, 112px); padding:var(--s-3); padding-left:56px; border-radius:calc(var(--radius) * 1.2); background:linear-gradient(145deg, rgba(255,255,255,0.98) 0%, rgba(241,245,255,0.94) 100%); border:1px solid rgba(39,67,218,0.14); box-shadow:0 22px 42px rgba(39,67,218,0.16); color:#2b356d; font-weight:600}
.benefits-list li::before{content:"✓"; position:absolute; left:18px; top:50%; transform:translateY(-50%); width:28px; height:28px; border-radius:10px; display:grid; place-items:center; color:#fff; background:var(--grad-brand); box-shadow:0 10px 22px rgba(39,67,218,0.25)}
.benefits-footnote{margin:var(--s-4) auto 0; text-align:center; color:#2a3568; padding:0 clamp(var(--s-4), 4vw, var(--s-5))}
.benefits-cta{display:flex; justify-content:center; padding:var(--s-4);}
.benefits-cta .btn{min-width:220px; text-align: center;}
@media (min-width:720px){
  .benefits-list{grid-template-columns:repeat(3, minmax(0,1fr))}
}
.hero-media,
.media-panel{position:relative; display:grid; justify-items:center; align-content:center; gap:clamp(var(--s-3), 2vw, var(--s-3)); padding:clamp(var(--s-3), 2.4vw, var(--s-4)); min-height:100%; width:100%}
.hero-media::before,
.media-panel::before{content:""; position:absolute; inset:-18% -24% -22% -24%; border-radius:50%; background:radial-gradient(closest-side, rgba(122,108,255,0.22), rgba(122,108,255,0)); opacity:0.5; filter:blur(14px); pointer-events:none}
.hero-media-orbit{position:absolute; inset:0; margin:auto; width:min(82vw, 520px); height:min(82vw, 520px); max-width:100%; max-height:100%; border-radius:50%; border:1px solid rgba(122,108,255,0.35); background:radial-gradient(closest-side, rgba(255,255,255,0.1), rgba(122,108,255,0.12) 58%, rgba(255,255,255,0)); box-shadow:0 24px 70px rgba(39,67,218,0.16); transform:rotate(8deg); animation:heroOrbit 18s ease-in-out infinite alternate; z-index:0; pointer-events:none}
.hero-figure{position:relative; z-index:1; width:min(82vw, 520px); aspect-ratio:5 / 4; border-radius:calc(var(--radius) * 1.9); overflow:hidden; border:1px solid rgba(39,67,218,0.18); box-shadow:0 38px 90px rgba(39,67,218,0.22); background:linear-gradient(160deg, rgba(255,255,255,0.35), rgba(122,108,255,0.12)); isolation:isolate; margin:0}
.hero-figure, .cta-figure{transform:perspective(800px) rotateX(var(--tiltX, 0deg)) rotateY(var(--tiltY, 0deg)); transition:transform .35s ease}
.hero-figure::before{content:""; position:absolute; inset:-18% -20% 32%; border-radius:45%; background:radial-gradient(closest-side, rgba(122,108,255,0.32), rgba(122,108,255,0)); opacity:0.65; mix-blend-mode:screen}
.hero-figure img{display:block; width:100%; height:100%; object-fit:cover}
/* Safari < 14 fallback where aspect-ratio is unsupported */
@supports not (aspect-ratio: 1 / 1){
  .hero-figure{position:relative}
  .hero-figure::after{content:""; display:block; padding-top:80%}
  .hero-figure img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover}
}
.hero-glow{position:absolute; inset:0; background:radial-gradient(140% 120% at 80% 10%, rgba(122,108,255,0.38), rgba(255,193,133,0.26) 40%, rgba(122,108,255,0.08) 70%, transparent 100%); mix-blend-mode:screen; opacity:0.6; pointer-events:none}
.cta-section{position:relative; overflow:hidden; background:linear-gradient(135deg, rgba(246,249,255,1) 0%, rgba(232,239,255,0.96) 45%, rgba(220,232,255,0.92) 100%)}
.cta-section > .container{padding:0; background:transparent; border:none; box-shadow:none}
.cta-section > .container::before{display:none}
.cta-section::after{content:""; position:absolute; top:auto; right:-20%; bottom:-40%; left:-20%; height:60%; background:linear-gradient(120deg, rgba(122,108,255,0.18), rgba(255,193,133,0.12), rgba(122,108,255,0.1)); filter:blur(110px); opacity:0.75}
/* CTA: subtle brand watermark */
.cta-section .cta-card::after{content:""; position:absolute; bottom:14px; right:14px; width:120px; height:120px; background:url("images/parents_first_logo1.png") no-repeat center/contain; opacity:0.06; filter:grayscale(100%) contrast(0.9); pointer-events:none}
.cta-card{position:relative; z-index:1; padding:var(--s-6); border-radius:calc(var(--radius) * 1.6); background:linear-gradient(145deg, rgba(255,255,255,0.98) 0%, rgba(239,244,255,0.95) 55%, rgba(231,239,255,0.92) 100%); border:1px solid rgba(39,67,218,0.16); box-shadow:0 32px 66px rgba(39,67,218,0.22); overflow:hidden; max-width:1120px; margin:0 auto}
.cta-card::before{content:""; position:absolute; inset:14%; border-radius:calc(var(--radius) * 1.25); background:radial-gradient(140% 100% at 0% 0%, rgba(122,108,255,0.18), rgba(255,193,133,0.12), rgba(255,255,255,0)); opacity:0.6; pointer-events:none}
.cta-grid{position:relative; z-index:1; display:grid; gap:var(--s-5); align-items:stretch; justify-items:stretch; grid-template-columns:1fr; grid-template-areas:"content" "figure"}
.cta-figure{grid-area:figure}
.cta-content{grid-area:content}
.cta-content{display:grid; gap:var(--s-3); color:#142252; justify-items:flex-start; text-align:left; max-width:680px; margin-inline:0; align-self:center; width:100%}
.cta-content h2{margin:0; color:#101944; position:relative; text-align:center}
.cta-content h2::after{content:""; display:block; width:90px; height:6px; border-radius:999px; background:var(--grad-brand); margin:10px 0 0; box-shadow:0 6px 16px rgba(39,67,218,0.25)}
.cta-content p{margin:0}
.cta-points{display:grid; gap:var(--s-3); margin-top:var(--s-2)}
.cta-point{display:grid; grid-template-columns:auto 1fr; gap:var(--s-2); padding:var(--s-2) var(--s-3); border-radius:calc(var(--radius) + 6px); background:linear-gradient(150deg, rgba(255,255,255,0.98) 0%, rgba(240,244,255,0.94) 100%); border:1px solid rgba(39,67,218,0.16); box-shadow:0 22px 40px rgba(39,67,218,0.16); align-items:center; transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease}
.cta-point:hover{transform:translateY(-4px); box-shadow:0 26px 48px rgba(39,67,218,0.2); border-color:rgba(39,67,218,0.28)}
.cta-point p{margin:0; color:#273567}
.cta-icon{display:inline-grid; place-items:center; width:46px; height:46px; border-radius:14px; background:linear-gradient(140deg, rgba(122,108,255,0.32), rgba(255,193,133,0.32)); font-size:1.5rem; animation:cta-orbit 6s ease-in-out infinite; box-shadow:0 10px 24px rgba(87,112,214,0.2); color:#1c275d; border:1px solid rgba(39,67,218,0.2)}
.cta-actions{display:flex; align-items:center; gap:var(--s-2); justify-content:center; width:100%}
.cta-figure{position:relative; width:100%; border-radius:calc(var(--radius) * 1.6); overflow:hidden; box-shadow:0 26px 60px rgba(39,67,218,0.18); border:1px solid rgba(39,67,218,0.2); min-height:260px; display:flex; align-self:stretch; margin:0}
.cta-figure img{flex:1; width:100%; height:100%; object-fit:cover; object-position:center}
.cta-figure-glow{position:absolute; inset:0; background:linear-gradient(160deg, rgba(122,108,255,0.32), rgba(255,193,133,0.26) 50%, rgba(122,108,255,0.22)); mix-blend-mode:screen; opacity:0.6; pointer-events:none}
.cta-mobile-bar{position:sticky; bottom:0; left:0; right:0; display:flex; align-items:center; justify-content:space-between; gap:var(--s-2); padding:var(--s-2) var(--s-3); background:linear-gradient(135deg, rgba(82,111,250,0.92), rgba(143,122,255,0.92)); color:#FFFFFF; box-shadow:0 -12px 30px rgba(82,111,250,0.22); border-top:1px solid rgba(255,255,255,0.25); border-radius:calc(var(--radius) + 8px) calc(var(--radius) + 8px) 0 0; margin:var(--s-4) var(--s-2) 0; z-index:4}
.cta-mobile-bar span{font-weight:600; letter-spacing:0.03em; text-transform:uppercase}
.cta-mobile-bar .btn{flex:0 0 auto}
/* CTA: small-screen tweaks */
@media (max-width:640px){
  .cta-section .cta-card::after{display:none}
  .cta-content{max-width:none}
  .cta-card{padding:var(--s-5)}
}
@media (max-width:899px){
  .cta-content{justify-items:center; text-align:center; margin-inline:auto}
  .cta-content h2::after{margin:10px auto 0}
  .cta-actions{justify-content:center}
  .cta-figure{margin:var(--s-4) 0 0}
}
.grid{display:grid; gap:var(--s-4)}
.grid-2{grid-template-columns:repeat(1,1fr)}
.grid-3{grid-template-columns:repeat(1,1fr)}
.grid-4{grid-template-columns:repeat(1,1fr)}
.grid-5{grid-template-columns:repeat(2,1fr)}
/* Ensure grid children can shrink without overflowing */
/* Testimonials */
#testimonials > .container{padding: clamp(var(--s-4), 4vw, var(--s-5));}
.t-carousel{position:relative; width:100%;}
.t-track{position:relative; display:flex; gap:0; overflow:hidden; scroll-behavior:smooth; -webkit-overflow-scrolling:touch; scroll-snap-type:x mandatory}
.t-card{flex:0 0 100%; position:relative; padding:var(--s-3); border-radius:calc(var(--radius) * 1.1); border:1px solid rgba(39,67,218,0.14); background:linear-gradient(150deg, rgba(255,255,255,0.98) 0%, rgba(240,244,255,0.94) 100%); box-shadow:0 18px 42px rgba(25,49,140,0.12); scroll-snap-align:start}
.t-card::after{content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none}
.t-embed{position:relative; z-index:1; display:flex; justify-content:center}
/* Always one full-width slide visible */
.t-nav{position:absolute; top:50%; left:0; right:0; height:0; display:flex; align-items:center; justify-content:space-between; pointer-events:none; z-index:2}
.t-btn{pointer-events:auto; appearance:none; border:none; width:44px; height:44px; border-radius:50%; display:grid; place-items:center; font-size:24px; font-weight:700; color:#1d2b6f; background:#fff; box-shadow:0 10px 24px rgba(25,49,140,0.18); border:1px solid rgba(39,67,218,0.16); cursor:pointer; transition:transform .15s ease, box-shadow .15s ease, background .15s ease; transform:translateY(-50%); z-index:3}
.t-btn:hover{transform:translateY(-50%) scale(1.02); box-shadow:0 14px 28px rgba(25,49,140,0.2)}
.t-btn:disabled{opacity:0.5; cursor:default}
.grid > *{min-width:0}
/* Prevent accidental horizontal scroll due to nested elements */
.container{overflow-x:hidden}
/* (Removed) Testimonials styles after reverting to original page */
@media (prefers-reduced-motion:reduce){
  .cta-icon,
  .icon,
  .nav-card .icon{animation:none}
  .loading-bar__progress{animation:none; transform:scaleX(1)}
  /* Reduce motion in hero */
  .hero::before,
  .hero::after{animation:none !important}
  .hero-bubbles span{animation:none}
  .hero-heading .accent{animation:none; transform:none}
  .hero-media-orbit{animation:none}
  /* Ensure hero titles never stay hidden if animations are disabled */
  .hero-title,
  .hero-title-sub,
  .hero-description{animation:none !important; opacity:1 !important; transform:none !important}
  /* Make benefits list instantly visible without animation */
  .hero-details.reveal{opacity:1; transform:none}
  .hero-details.reveal.show ul li{animation:none; opacity:1; transform:none}
  .hero-details h3::after{transition:none; transform:scaleX(1)}
}
@keyframes cta-orbit{
  0%,100%{transform:translate3d(0,0,0) rotate(0deg); box-shadow:0 10px 25px rgba(0,0,0,0.25)}
  30%{transform:translate3d(2px,-4px,0) rotate(4deg)}
  60%{transform:translate3d(-2px,3px,0) rotate(-3deg); box-shadow:0 16px 30px rgba(0,0,0,0.22)}
}
@keyframes navTitlePulse{
  0%{background-position:0% 50%;}
  50%{background-position:100% 50%;}
  100%{background-position:0% 50%;}
}
@keyframes heroTitleRise{
  0%{opacity:0; transform:translateY(24px)}
  60%{opacity:1}
  100%{opacity:1; transform:translateY(0)}
}
@keyframes heroTitleGlow{
  0%{filter:drop-shadow(0 0 0 rgba(39,67,218,0.18))}
  100%{filter:drop-shadow(0 9px 22px rgba(39,67,218,0.34))}
}
@keyframes heroSubtitleFade{
  0%{opacity:0; transform:translateY(20px)}
  100%{opacity:1; transform:translateY(0)}
}
@keyframes loadingSweep{
  0%{transform:scaleX(0)}
  70%{transform:scaleX(0.85)}
  100%{transform:scaleX(1)}
}
@keyframes loadingSweepComplete{to{transform:scaleX(1)}}
@media (min-width:700px){
  .grid-2{grid-template-columns:repeat(2,1fr)}
  .grid-3{grid-template-columns:repeat(3,1fr)}
  .grid-4{grid-template-columns:repeat(4,1fr)}
  .grid-5{grid-template-columns:repeat(5,1fr)}
}
@media (min-width:960px){
  .hero-actions{justify-content:flex-start}
}
@media (min-width:1100px){
  .hero-body{grid-template-columns:repeat(2,minmax(0,1fr)); align-items:start}
  .hero-body p:nth-child(3){grid-column:1 / -1}
}
@media (max-width:640px){
  /* Allow natural height on very small screens so content doesn't get cramped */
  .hero > .container{min-height:auto; padding:clamp(var(--s-4), 7vw, var(--s-5)) clamp(var(--s-2), 6vw, var(--s-3)); align-items:flex-start}
  .hero-grid{gap:clamp(var(--s-3), 5vw, var(--s-4))}
  .hero-copy{padding:clamp(var(--s-3), 7vw, var(--s-4)); border-radius:calc(var(--radius) * 1.3); align-items:flex-start; justify-items:flex-start; text-align:left}
  .hero-copy::before{inset:-12px}
  .hero-heading{gap:var(--s-2)}
  .hero-title{font-size:clamp(1.8rem, 7vw, 2.4rem)}
  /* Make media align edge-to-edge with the container for clean alignment */
  .hero-media{margin-top:var(--s-3); padding:0; border-radius:0; overflow:visible; background:transparent; border:0; box-shadow:none}
  .hero-media::before{display:none}
  .hero-body{padding:clamp(var(--s-2), 4.8vw, var(--s-2)); gap:clamp(var(--s-2), 4vw, var(--s-2))}
  .hero-figure{width:100%; max-width:none}
  .hero-actions{justify-content:flex-start; width:100%}
  .hero-media{margin-top:var(--s-3); padding:clamp(var(--s-3), 6vw, var(--s-4)); border-radius:calc(var(--radius) * 1.4); overflow:hidden; background:linear-gradient(150deg, rgba(255,255,255,0.32), rgba(122,108,255,0.16))}
  .hero-media::before{inset:-12% -18% -16% -18%}
  .hero-media-orbit{width:min(84vw, 440px); height:min(84vw, 440px)}
  .hero-figure{width:min(80vw, 420px)}

  /* --- MOBILE ALIGNMENT FIXES --- */
  /* Remove decorative vertical accent that was nudged left and could create visual misalignment */
  .section::after{display:none}
  /* Reduce double horizontal padding (section + container). This keeps content visually centered and full */
  .section{padding-left:var(--s-1); padding-right:var(--s-1)}
  .section > .container{
    margin-left:0; margin-right:0; width:100%;
    padding:clamp(var(--s-4), 6vw, var(--s-5)) clamp(var(--s-3), 6vw, var(--s-4));
    border-radius:20px;
  }
  /* For visually dense sections, slightly tighten internal card padding */
  .card{padding:clamp(var(--s-3), 6vw, var(--s-4))}
  /* Ensure grids do not introduce phantom overflow */
  .grid, .gains-list, .benefits-list{margin:0}
  /* Prevent any child using calc() or transforms from causing horizontal scroll */
  .page-shell, main, body{overflow-x:hidden}
  /* Testimonials: remove side padding inside slide to align video flush with container radius */
  .t-card{padding:var(--s-2) var(--s-2)}
  /* Footer sticky CTA bar: align with new reduced page gutters */
  .cta-mobile-bar{margin-left:var(--s-1); margin-right:var(--s-1)}
}
@media (max-width:640px){
  .grid{gap:clamp(var(--s-3), 6vw, var(--s-3))}
  .grid-5{grid-template-columns:1fr; justify-items:stretch}
}
@media (min-width:900px){
  .cta-content{max-width:1160px}
}
@media (min-width:720px){
  .cta-points{grid-template-columns:repeat(2,minmax(0,1fr))}
  .gains-list{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (min-width:1200px){
  .gains-list{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media (min-width:960px){
  .hero-grid{grid-template-columns:repeat(2,minmax(0,1fr)); align-items:center; justify-items:start; text-align:left; gap:clamp(var(--s-3), 2.4vw, var(--s-4)); padding:0 clamp(var(--s-4), 3vw, var(--s-5))}
  .hero-copy{justify-items:start; text-align:left}
  .hero-heading{max-width:620px}
  .hero-description{max-width:700px; margin-inline:0}
  .hero-media,
  .media-panel{justify-items:end; align-content:center; padding:clamp(var(--s-3), 2.2vw, var(--s-4))}
  .hero-details{grid-column:1 / -1; margin-top:0}
  .gains-layout{align-items:center}
}
@media (max-width:768px){
  .hero-copy{text-align:left; justify-items:flex-start; padding:clamp(var(--s-4), 6vw, var(--s-5))}
  .hero-description{margin-inline:0}
  .hero-grid{gap:clamp(var(--s-3), 5vw, var(--s-4)); padding:0 clamp(var(--s-2), 7vw, var(--s-2))}
  .hero-media,
  .media-panel{width:100%; justify-items:center; margin-top:clamp(var(--s-3), 5vw, var(--s-4))}
  .hero-figure{width:100%; max-width:420px}
}
@media (max-width:560px){
  .hero-heading h1{font-size:clamp(1.9rem, 8vw, 2.4rem)}
  .hero-title-sub{font-size:clamp(1rem, 4.2vw, 1.2rem); letter-spacing:0.06em}
  .hero-copy{padding:clamp(var(--s-3), 8vw, var(--s-4)); align-items:flex-start}
  .hero-body{padding:clamp(var(--s-2), 6vw, var(--s-2)); box-shadow:0 16px 34px rgba(15,29,86,0.08)}
  .hero-body p{padding:clamp(var(--s-2), 6vw, var(--s-2)); font-size:clamp(0.95rem, 4vw, 1.05rem)}
  .hero-body .hero-lead{font-size:clamp(1.05rem, 5vw, 1.25rem)}
  .hero-actions .btn{width:100%; max-width:none}
  .hero-media-orbit{width:min(88vw, 400px); height:min(88vw, 400px)}
  .hero-figure{width:min(84vw, 380px)}
  .hero-bubbles span:nth-child(n+15){display:none}
}
/* Ultra-narrow devices like 412px width (Pixel 7-like): eliminate any orbit and ensure full-width figure */
@media (max-width:420px){
  .hero-grid{padding:0}
  .hero-media-orbit{display:none}
  .hero-media{padding:0; margin-top:var(--s-3)}
  .hero-figure{width:100%; max-width:none}
}
@media (max-width:420px){
  .hero-copy{border-radius:calc(var(--radius) * 1.2)}
  .hero-grid{gap:clamp(var(--s-2), 6vw, var(--s-3))}
  .hero-actions{justify-content:center}
  .hero-actions .btn{width:100%}
}

/* --- Mobile-only: stronger stacking overrides to ensure hero decorations
   don't visually cover the following content (e.g., "Who Should Join").
   These use !important to reliably override decorative z-index values on
   narrow viewports while keeping desktop behavior unchanged. */
@media (max-width:640px){
  .hero::before,
  .hero::after,
  .hero-bubbles,
  .hero-media-orbit,
  .hero-details::before,
  .hero-details::after{
    z-index: 0 !important;
    pointer-events: none !important;
  }

  /* Ensure the hero itself doesn't create a higher stacking context */
  .hero{z-index:0 !important}

  /* Force hero-benefits to sit above hero decorations on mobile */
  .hero-benefits{overflow:visible !important; z-index:60 !important}
  .hero-benefits .container{z-index:70 !important}
}

@keyframes heroGlow{0%{transform:translate3d(0,0,0)}100%{transform:translate3d(0,-8px,0)}}
@keyframes heroAccent{to{transform:scaleX(1)}}
@keyframes heroOrbit{
  0%{transform:rotate(8deg) scale(0.96); opacity:0.55}
  50%{transform:rotate(0deg) scale(1.02); opacity:0.75}
  100%{transform:rotate(-6deg) scale(0.97); opacity:0.55}
}
@media (min-width:960px){
  .cta-card{padding:var(--s-7)}
}
@media (min-width:780px){
  .cta-mobile-bar{display:none}
}
@media (max-width:479px){
  .cta-card{padding:var(--s-5)}
  .cta-point{grid-template-columns:1fr; text-align:left}
  .cta-icon{width:40px; height:40px}
}
@media (max-width:520px){
  .what-gain-actions{margin:var(--s-3) 0}
  .what-gain-cta{width:100%}
}
@keyframes floaty{
  0%,100%{transform:translate3d(0,0,0)}
  40%{transform:translate3d(0,-6px,0)}
  60%{transform:translate3d(0,3px,0)}
}
.figure{
  aspect-ratio:4/3; border-radius:calc(var(--radius) * 1.2); overflow:hidden;
  background:linear-gradient(150deg, rgba(255,255,255,0.96) 0%, rgba(240,244,255,0.9) 100%);
  border:1px solid rgba(39,67,218,0.16);
  box-shadow:0 24px 45px rgba(12, 20, 55, 0.16);
  display:flex; align-items:center; justify-content:center;
  color:#4B5675; font-weight:600;
}
.table{width:100%; border-collapse:separate; border-spacing:0; overflow:hidden; border-radius:calc(var(--radius) * 1.2); background:rgba(255,255,255,0.96); border:1px solid rgba(39,67,218,0.14); box-shadow:0 20px 35px rgba(15,24,64,0.12)}
.table thead th{background:linear-gradient(140deg, rgba(39,67,218,0.12), rgba(155,109,247,0.08)); text-align:left; padding:16px; font-size:var(--fs-16); color:#1a2440}
.table tbody td{padding:16px 18px; border-top:1px solid rgba(39,67,218,0.12); color:var(--muted)}
/* Table responsiveness */
.table{display:block; overflow-x:auto; -webkit-overflow-scrolling:touch}
.table thead, .table tbody, .table tr{display:table; width:100%; table-layout:fixed}
.table th, .table td{word-wrap:break-word; overflow-wrap:anywhere}
.note{font-size:.95rem; color:#4A5771}
.form-shell{background:#ffffff; border-radius:calc(var(--radius) * 1.4); border:1px solid rgba(39,67,218,0.1); box-shadow:0 18px 40px rgba(25,49,140,0.12); padding:var(--s-5) clamp(var(--s-4), 5vw, var(--s-5)); display:grid; gap:var(--s-4); max-width:960px; margin:0 auto}
.form-header{text-align:center}
.form-header h2{margin:0; color:#101944; text-align:center}
.form-header p{margin:0; color:#576189; max-width:640px; display: inline-block; margin-top:8px;}
.form-card{position:relative; margin-top:20px; display:grid; gap:var(--s-4)}
.form-card::before{
  content:"";
  position:absolute;
  inset:-18px;
  border-radius:calc(var(--radius) * 1.8);
  background:radial-gradient(600px 320px at 20% 0%, rgba(122,108,255,0.18), rgba(122,108,255,0) 65%),
             radial-gradient(680px 360px at 90% 110%, rgba(255,193,133,0.2), rgba(255,193,133,0));
  opacity:0.45;
  filter:blur(12px);
  pointer-events:none;
}
.form-card > *{position:relative; z-index:1}
.form-grid{display:grid; gap:var(--s-3)}
.form-grid-compact{grid-template-columns:repeat(1,minmax(0,1fr))}
.form-field{display:grid; gap:8px; position:relative}
.form-field:focus-within label{color:#1a2656}
.form-field-full{grid-column:1 / -1}
.form-field.error label{color:#B71C1C}
.slide-toggle{transition:max-height .24s ease, opacity .18s ease; max-height:400px}
.slide-toggle.is-hidden{display:none; max-height:0; opacity:0}
label{font-weight:600; color:#101830; display:block; margin-bottom:0; letter-spacing:0.01em}
input, select, textarea{
  width:100%; padding:14px 16px; border-radius:14px; border:1px solid rgba(39,67,218,0.18);
  background:linear-gradient(150deg, rgba(255,255,255,0.98), rgba(242,245,255,0.94)); color:#101830; font:inherit; box-shadow:0 10px 20px rgba(25,49,140,0.08);
}
textarea{resize:vertical; min-height:120px}
input:focus-visible, select:focus-visible, textarea:focus-visible{outline:3px solid rgba(155,109,247,0.32); outline-offset:2px; box-shadow:0 16px 30px rgba(39,67,218,0.16)}
.form-field.error input,
.form-field.error textarea,
.form-field.error select{border-color:rgba(183,28,28,0.9); box-shadow:0 0 0 1px rgba(183,28,28,0.2),0 12px 24px rgba(183,28,28,0.14)}
.form-fieldset.error{border:1px solid rgba(183,28,28,0.65); border-radius:calc(var(--radius) + 6px); padding:clamp(var(--s-2), 3vw, var(--s-3)); background:linear-gradient(150deg, rgba(255,235,238,0.9), rgba(255,255,255,0.95))}
.form-confirm.error{border-radius:calc(var(--radius) + 4px); background:linear-gradient(150deg, rgba(255,235,238,0.75), rgba(255,255,255,0.95)); padding:var(--s-2); outline:1px solid rgba(183,28,28,0.5)}
.form-confirm.error span{color:#B71C1C}
.req::after{content:" *"; color:#C62828}
.form-help{font-size:.9rem; color:#000000; margin-top:4px; font-weight: 800;}
.form-fieldset{border:0; margin:0; padding:0; display:grid; gap:var(--s-3)}
.form-fieldset legend{font-weight:700; color:#111f54; letter-spacing:0.02em}
.option-grid{display:grid; gap:var(--s-2); grid-template-columns:repeat(1,minmax(0,1fr))}
.option-tile{display:flex; align-items:center; gap:12px; padding:var(--s-2); border:1px solid rgba(39,67,218,0.14); border-radius:calc(var(--radius) + 6px); background:#f7f9ff; transition:border-color .18s ease, box-shadow .18s ease, background .18s ease}
.option-tile input{width:18px; height:18px; accent-color:var(--brand); flex-shrink:0}
.option-tile span{color:#2f3b68; font-weight:600}
.option-tile:hover{border-color:rgba(39,67,218,0.28); box-shadow:0 12px 20px rgba(39,67,218,0.12); background:#ffffff}
.form-inset{padding:var(--s-3); border-radius:calc(var(--radius) + 4px); background:#f5f7ff; border:1px solid rgba(39,67,218,0.12); display:grid; gap:var(--s-2)}
.form-inset h4{margin:0; color:#223164; letter-spacing:0.02em}
.form-note{margin:0; color:#5d6a8c}
.form-confirm{display:flex; align-items:center; gap:10px; font-weight:600; color:#2a3772}
.form-confirm input{width:20px; height:20px}
.form-shell mark{background:rgba(122,108,255,0.16); padding:0 6px; border-radius:6px; color:#1a2656}
/* Reduce adjacent spacing to the next block when Other is hidden */
.form-card .form-fieldset.is-compact + .form-inset{ margin-top: calc(-1 * var(--s-2)); }
@media (min-width:720px){
  .form-grid-compact{grid-template-columns:repeat(2,minmax(0,1fr)); gap:var(--s-3)}
  .form-field-full{grid-column:span 2}
  .option-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (min-width:1080px){
  .option-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media (min-width:700px){
  .footer-grid{grid-template-columns:1.4fr 1fr}
}
@media (max-width:639px){
  .footer-brand{flex-direction:column; align-items:flex-start}
}
.nav-card{grid-template-columns:auto auto}
.nav-title{display:none}
@media (min-width:768px){
  .nav-card{grid-template-columns:auto 1fr auto}
  .nav-title{display:block}
}
.form-msg{display:none; margin-top:8px; font-weight:600}
.form-msg.ok{color:#1B5E20}
.form-msg.err{color:#B71C1C}
.form-actions{display:flex; justify-content:flex-end; gap:var(--s-2); padding-top:var(--s-2); border-top:1px solid rgba(39,67,218,0.12)}
.btn.is-loading{position:relative; pointer-events:none; opacity:0.85}
.btn.is-loading::after{content:""; position:absolute; width:18px; height:18px; border-radius:50%; border:2px solid rgba(255,255,255,0.8); border-top-color:transparent; animation:spin .9s linear infinite; right:18px; top:50%; transform:translateY(-50%)}

@keyframes spin{to{transform:translateY(-50%) rotate(360deg)}}
/* Press feedback */
.btn:active{transform:scale(0.98)}
details{
  background:linear-gradient(150deg, rgba(255,255,255,0.95) 0%, rgba(241,244,255,0.9) 100%); border:1px solid rgba(39,67,218,0.12); border-radius:calc(var(--radius) * 1.05);
  padding: var(--s-3); box-shadow:0 18px 34px rgba(15,24,64,0.14)
}
details + details{margin-top:var(--s-2)}
summary{cursor:pointer; font-weight:700; color:#111831; display:flex; align-items:center; gap:var(--s-2)}
summary:focus-visible{outline:3px solid rgba(155,109,247,0.32); border-radius:12px}
.reveal{opacity:1; transform:none; transition:opacity .6s ease, transform .6s ease}
.js-reveal .reveal{opacity:0; transform:translateY(14px)}
.js-reveal .reveal.show{opacity:1; transform:none}
/* Always-visible reveals: allow marking critical content to bypass animation gating */
.js-reveal .reveal[data-instant]{opacity:1 !important; transform:none !important}
/* FAQ: animate content under summary */
#faq details > *:not(summary){opacity:0; transform:translateY(-6px); transition:opacity .25s ease, transform .25s ease}
#faq details[open] > *:not(summary){opacity:1; transform:none}
.footer.section{background:linear-gradient(150deg, rgba(238,242,255,0.95) 0%, rgba(223,231,255,0.92) 60%, rgba(213,226,255,0.92) 100%); color:#273567; padding:var(--s-6) var(--s-2) var(--s-4)}
.footer.section::after{display:none}
.footer .container{background:transparent; border:none; box-shadow:none; padding:0}
.footer .container::before{display:none}
.footer-grid{display:grid; gap:var(--s-5)}
.footer-brand{display:grid; gap:var(--s-2)}
.footer-logo{width:160px; max-width:100%; height:auto}
.footer-brand p{margin:0; color:#3d4a72; line-height:1.7}
.footer-contact{display:grid; gap:var(--s-2)}
.footer-contact h4{margin:0; letter-spacing:0.06em; color:#1d2a6d}
.footer-contact ul{list-style:none; margin:0; padding:0; display:grid; gap:10px}
.footer-contact li{display:flex; align-items:center; gap:10px; color:#384679}
.footer-contact a{color:#31429b; text-decoration:none}
.footer-contact a:hover{color:#1f2d85}
.footer-contact a:focus-visible{outline:3px solid rgba(155,109,247,0.32); outline-offset:2px}
.footer-contact-icon{font-size:1.1rem}
.footer-meta{margin-top:var(--s-5); padding-top:var(--s-3); border-top:1px solid rgba(39,67,218,0.14); text-align:center; color:#4a5781}
.footer p{color:#384679}
.footer a{color:#31429b; text-decoration:none; transition:color .18s ease}
.footer a:hover{color:#1f2d85}
.footer a:focus-visible{outline:3px solid rgba(155,109,247,0.32); outline-offset:2px}
.icon{width:46px;height:46px;border-radius:16px;display:inline-grid;place-items:center;background:linear-gradient(140deg, rgba(122,108,255,0.2), rgba(255,193,133,0.2));border:1px solid rgba(39,67,218,0.22); color:#1E2C66; font-weight:700; box-shadow:0 16px 28px rgba(39,67,218,0.18); animation:floaty 7s ease-in-out infinite}
.center{display:grid;place-items:center}
.maxw{max-width:900px;margin:0 auto}

/* Footer responsiveness */
@media (min-width: 768px){
  .footer-grid{grid-template-columns: 2fr 1fr; align-items:start}
}
@media (max-width: 767.98px){
  .footer.section{padding:var(--s-5) var(--s-3) var(--s-4)}
  .footer-grid{grid-template-columns:1fr; justify-items:center; gap:var(--s-4); text-align:center}
  .footer-brand{justify-items:center; text-align:center}
  .footer-logo{width:140px; margin:0 auto var(--s-2)}
  .footer-contact{justify-items:center}
  .footer-contact ul{justify-items:center}
  .footer-contact li{justify-content:center}
  .footer-meta{margin-top:var(--s-4)}
}

/* --- Global: mirrored elegant heading accent for section H2s (non-CTA) --- */
.section > .container > h2.reveal{position:relative; color:#0f1a45; text-align:center}
.section > .container > h2.reveal::after{content:""; display:block; width:86px; height:6px; border-radius:999px; background:var(--grad-brand); margin:10px auto 0; box-shadow:0 6px 16px rgba(39,67,218,0.22); transform:scaleX(0); transform-origin:center; transition:transform .55s ease .1s}
.section > .container > h2.reveal.show::after{transform:scaleX(1)}
/* Admission Requirement heading lives inside a card */
.section .card h2{position:relative; text-align:center}
.section .card h2::after{content:""; display:block; width:72px; height:5px; border-radius:999px; background:var(--grad-brand); margin:8px auto 0; opacity:0.95}

/* -------------------------------------------------------------------------
   Who Should Join — scoped section styling
   This block keeps the visual look consistent with other sections while
   removing decorative pseudo-elements and ensuring stable stacking on
   older iOS / mobile browsers. Scoped to `.who-join-reset`.
   ------------------------------------------------------------------------- */
.who-join-reset{position:relative; z-index:120; overflow:visible}
/* remove any pseudo-element decorations that might overlap */
.who-join-reset::before,
.who-join-reset::after,
.who-join-reset .container::before,
.who-join-reset .container::after,
.who-join-reset .hero-bubbles,
.who-join-reset .hero-media-orbit,
.who-join-reset .hero-details::before,
.who-join-reset .hero-details::after{
  display:none !important;
  content:none !important;
  background:none !important;
  pointer-events:none !important;
}

/* Container: adopt the site's section card look so it matches others */
.who-join-reset > .container{
  position:relative;
  z-index:130;
  max-width:1180px;
  margin:0 auto;
  padding:var(--s-6) clamp(var(--s-3), 4vw, var(--s-5));
  border-radius:calc(var(--radius) * 1.6);
  background:linear-gradient(150deg, rgba(255,255,255,0.94) 0%, rgba(244,247,255,0.92) 48%, rgba(237,240,255,0.88) 100%);
  border:1px solid rgba(39,67,218,0.16);
  box-shadow:var(--shadow-card);
  overflow:visible;
}

/* Keep header styling consistent with other sections */
.who-join-reset .benefits-header{display:grid; gap:8px; text-align:center; padding:clamp(var(--s-4), 4vw, var(--s-5)) clamp(var(--s-4), 4vw, var(--s-5)) var(--s-2)}
.who-join-reset .benefits-header h2{margin:6px 0 0; color:#0f1a45}
.who-join-reset .benefits-header h2::after{content:""; display:block; width:86px; height:6px; border-radius:999px; background:var(--grad-brand); margin:10px auto 0; box-shadow:0 6px 16px rgba(39,67,218,0.22)}
.who-join-reset .benefits-header p{margin:0; color:#2a3568}

/* Restore original benefits list visuals but scoped */
.who-join-reset .benefits-list{list-style:none; padding:0; margin:0; display:grid; gap:var(--s-3); grid-template-columns:repeat(1, minmax(0,1fr));}
.who-join-reset .benefits-list li{position:relative; display:flex; align-items:center; min-height:clamp(72px, 9vw, 112px); padding:var(--s-3); padding-left:56px; border-radius:calc(var(--radius) * 1.2); background:linear-gradient(145deg, rgba(255,255,255,0.98) 0%, rgba(241,245,255,0.94) 100%); border:1px solid rgba(39,67,218,0.14); box-shadow:0 22px 42px rgba(39,67,218,0.16); color:#2b356d; font-weight:600}
.who-join-reset .benefits-list li::before{content:"✓"; position:absolute; left:18px; top:50%; transform:translateY(-50%); width:28px; height:28px; border-radius:10px; display:grid; place-items:center; color:#fff; background:var(--grad-brand); box-shadow:0 10px 22px rgba(39,67,218,0.25)}
.who-join-reset .benefit-text{font-weight:600; color:var(--text)}

.who-join-reset .benefits-cta{display:flex; justify-content:center; padding:var(--s-4);} 
.who-join-reset .benefits-cta .btn{min-width:220px; text-align:center}

/* Responsive: match site's existing breakpoint behaviour */
@media (min-width:720px){
  .who-join-reset .benefits-list{grid-template-columns:repeat(3, minmax(0,1fr))}
}

/* Mobile-specific safety for older iOS */
@media (max-width:640px){
  .who-join-reset > .container{padding:clamp(var(--s-4), 6vw, var(--s-5)) clamp(var(--s-3), 6vw, var(--s-4)); border-radius:20px}
  .who-join-reset, .who-join-reset > .container{ -webkit-transform: translateZ(0); transform: translateZ(0); -webkit-overflow-scrolling: auto;}
}

/* End Who Should Join scoped styling */
