/* =========================================================
   Canadian International School — canadianis.org
   Style matched to sister site canadianhs.org:
   Hind + Roboto Slab, blue #2b4eff + yellow #ffb352,
   playful blob shapes, soft shadows, rounded cards.
   ========================================================= */

:root{
  --blue:#2b4eff;
  --blue-2:#1a35cc;
  --blue-soft:#eef0ff;
  --yellow:#ffb352;
  --yellow-soft:#fff1de;
  --pink:#f2277e;
  --green:#30a820;
  --teal:#1c6e7a;
  --teal-2:#155a64;
  --ink:#101828;
  --text:#44596B;
  --muted:#7a8696;
  --bg:#ffffff;
  --bg-soft:#f7f9ff;
  --line:rgba(16,24,40,.08);

  --serif:"Roboto Slab","Cormorant Garamond",Georgia,serif;
  --sans:"Hind","Helvetica Neue",Arial,sans-serif;

  --maxw:1240px;
  --gutter:clamp(20px,4vw,40px);
  --r:14px;
  --r-lg:22px;
  --r-pill:999px;
  --shadow-sm:0 4px 14px rgba(16,24,40,.06);
  --shadow:0 18px 40px rgba(16,24,40,.08);
  --shadow-blue:0 18px 40px rgba(43,78,255,.18);
  --ease:cubic-bezier(.2,.7,.2,1);
}

*,*::before,*::after{box-sizing:border-box}
/* HTML 'hidden' attribute must always win over our display: rules. */
[hidden]{display:none !important}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--sans);
  font-size:16px;
  line-height:1.7;
  color:var(--text);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
}
img,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;border:0;background:none;cursor:pointer;color:inherit}
input,textarea,select{font:inherit;color:inherit}

/* Typography ------------------------------------------------ */
h1,h2,h3,h4,h5{
  font-family:var(--serif);
  font-weight:700;
  color:var(--ink);
  line-height:1.18;
  letter-spacing:-.005em;
  margin:0 0 .5em;
}
h1{font-size:clamp(2.4rem,5vw,4.2rem);font-weight:800}
h2{font-size:clamp(1.9rem,3.4vw,2.8rem)}
h3{font-size:clamp(1.25rem,1.8vw,1.6rem)}
h4{font-size:1.05rem}
p{margin:0 0 1em}
.lede{font-size:1.05rem;line-height:1.75;color:var(--text)}

.eyebrow{
  display:inline-block;
  font-family:var(--sans);
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--blue);
  margin-bottom:1rem;
  position:relative;
  padding-left:46px;
}
.eyebrow::before{
  content:"";
  position:absolute; left:0; top:50%;
  width:34px; height:2px;
  background:var(--yellow);
  transform:translateY(-50%);
}

.scribble{
  position:relative;
  display:inline-block;
}
.scribble::after{
  content:"";
  position:absolute; left:-2%; right:-2%; bottom:-.1em;
  height:.36em; z-index:-1;
  background:var(--yellow);
  border-radius:.4em;
  opacity:.7;
  transform:rotate(-1deg);
}

/* Layout primitives ---------------------------------------- */
.container{max-width:var(--maxw); margin:0 auto; padding:0 var(--gutter)}
.section{padding:clamp(72px,9vw,120px) 0; position:relative; overflow:hidden}
.section--soft{background:var(--bg-soft)}
.section--blue{background:var(--blue); color:#dde3ff}
.section--blue h1,.section--blue h2,.section--blue h3{color:#fff}
.section-head{text-align:center; max-width:680px; margin:0 auto 56px}
.section-head .eyebrow{padding-left:0}
.section-head .eyebrow::before{display:none}

/* Buttons -------------------------------------------------- */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 28px;
  font-family:var(--sans); font-weight:600;
  font-size:.95rem; letter-spacing:.02em;
  border-radius:var(--r-pill);
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease), color .25s var(--ease);
  white-space:nowrap;
}
.btn svg{width:16px; height:16px; transition:transform .25s var(--ease)}
.btn:hover svg{transform:translateX(3px)}
.btn-primary{background:var(--yellow); color:var(--ink); box-shadow:0 10px 24px rgba(255,179,82,.35)}
.btn-primary:hover{background:var(--ink); color:#fff; transform:translateY(-2px)}
.btn-blue{background:var(--blue); color:#fff; box-shadow:var(--shadow-blue)}
.btn-blue:hover{background:var(--blue-2); transform:translateY(-2px)}
.btn-ghost{background:transparent; color:var(--ink); border:1.5px solid var(--ink)}
.btn-ghost:hover{background:var(--ink); color:#fff}
.btn-light{background:#fff; color:var(--blue)}
.btn-light:hover{background:var(--yellow); color:var(--ink)}

/* Bottom contact strip ------------------------------------- */
.contact-strip{
  background:var(--ink); color:#fff;
  font-size:.92rem;
  border-top:4px solid var(--blue);
}
.contact-strip .row{
  display:flex; align-items:center;
  flex-wrap:wrap; gap:0;
  min-height:64px; padding:10px 0;
}
.cs-item{
  display:inline-flex; align-items:center; gap:10px;
  color:#fff; padding:8px 22px;
  border-right:1px solid rgba(255,255,255,.08);
  transition:color .2s;
}
.cs-item:first-child{padding-left:0}
.cs-item:hover{color:var(--yellow)}
.cs-item.cs-label{
  font-weight:700; font-family:var(--serif);
  font-size:1rem; padding-right:30px;
}
.cs-ico{
  display:inline-grid; place-items:center;
  width:34px; height:34px; border-radius:50%;
  background:rgba(255,255,255,.06);
}
.cs-ico svg{width:16px; height:16px}
.cs-wa{
  margin-left:auto;
  display:grid; place-items:center;
  width:46px; height:46px; border-radius:50%;
  background:#25d366;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease);
  box-shadow:0 6px 16px rgba(37,211,102,.4);
}
.cs-wa:hover{transform:scale(1.06)}
.cs-wa svg{width:22px; height:22px}

/* Header / nav --------------------------------------------- */
.header{
  position:sticky; top:0; z-index:50;
  background:#c6dfe5;            /* matches hero on load */
  transition:background .45s var(--ease),
             box-shadow .45s var(--ease),
             backdrop-filter .45s var(--ease);
}
.header.is-scrolled{
  background:rgba(255,255,255,.96);
  backdrop-filter:saturate(160%) blur(10px);
  -webkit-backdrop-filter:saturate(160%) blur(10px);
  box-shadow:0 10px 30px rgba(16,24,40,.08);
}
.header.is-scrolled .nav{height:72px}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  height:96px; gap:2rem;
  transition:height .35s var(--ease);
}
.brand{display:flex; align-items:center; gap:16px; flex-shrink:0}
.brand-logo{
  display:block; width:62px; height:auto; flex-shrink:0;
  transition:transform .35s var(--ease);
}
.brand-logo img{width:100%; height:auto; display:block}
.brand:hover .brand-logo{transform:rotate(-4deg) scale(1.04)}
.header.is-scrolled .brand-logo{width:52px}
.brand-text{display:flex; flex-direction:column; line-height:1.15}
.brand-text .top{
  font-family:var(--serif); font-size:1.32rem; font-weight:800;
  color:#0a1f3d; letter-spacing:-.01em;
  white-space:nowrap;
  display:block;
}
.brand-text .sub{
  font-size:.72rem; font-weight:600;
  letter-spacing:.18em; text-transform:uppercase;
  color:#7a8696;
  white-space:nowrap;
  margin-top:2px;
  display:block;
}
.header.is-scrolled .brand-text .top{font-size:1.18rem}
/* Prevent the brand from being squeezed at mid-width; nav-links shrink first */
@media (max-width:1180px) and (min-width:821px){
  .brand-text .top{font-size:1.15rem}
  .nav{gap:1.2rem}
  .nav-links{gap:1.4rem}
}
.btn-system{
  background:var(--blue); color:#fff;
  border-radius:8px;
  padding:14px 32px;
  font-weight:700; font-size:.95rem;
  letter-spacing:.02em;
  box-shadow:0 8px 20px rgba(43,78,255,.32);
}
.btn-system:hover{
  background:var(--blue-2);
  transform:translateY(-2px);
  box-shadow:0 12px 26px rgba(43,78,255,.45);
}
.nav-links a.active{color:var(--blue)}
.nav-links{display:flex; align-items:center; gap:2rem}
.nav-links a{
  font-size:.85rem; font-weight:600;
  letter-spacing:.08em; text-transform:uppercase;
  color:var(--ink); position:relative; padding:6px 0;
  transition:color .2s;
}
.nav-links a:hover{color:var(--blue)}
.nav-links .has-sub{
  position:relative; cursor:pointer;
  display:inline-flex; align-items:center; gap:4px;
  /* match the same vertical metrics as a plain <a> */
  padding:6px 0;
}
.nav-links .has-sub > a{padding:0}
.nav-links .has-sub > svg{
  width:10px;height:10px;
  color:var(--muted);
  transition:transform .25s var(--ease);
}
.nav-links .has-sub:hover > svg{transform:rotate(180deg); color:var(--blue)}
.nav-links .submenu{
  position:absolute; top:calc(100% + 14px); left:-14px;
  min-width:220px;
  background:#fff; border-radius:var(--r);
  box-shadow:var(--shadow); padding:10px;
  opacity:0; visibility:hidden; transform:translateY(8px);
  transition:all .25s var(--ease);
}
.nav-links .has-sub:hover .submenu{
  opacity:1; visibility:visible; transform:translateY(0);
}
.nav-links .submenu a{
  display:block; padding:10px 14px;
  font-size:.78rem; letter-spacing:.06em; border-radius:8px;
}
.nav-links .submenu a:hover{background:var(--blue-soft); color:var(--blue)}

.menu-toggle{display:none}

/* Hero ----------------------------------------------------- */
.hero{
  position:relative;
  background:#c6dfe5;
  min-height:680px;
  max-height:84vh;
  overflow:hidden;
  padding:0;
}
.hero-wrap{
  position:relative; z-index:2;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(32px,4vw,60px);
  align-items:stretch;             /* stage fills full hero */
  min-height:inherit;
}
.hero-copy{align-self:center; padding:24px 0}

/* Decorative pink scribble */
.hero-scribble{
  position:absolute;
  top:60px; left:30px;
  width:170px; height:170px;
  z-index:1; opacity:.95;
  animation:float 7s ease-in-out infinite;
}

/* Decorative shapes scattered */
.hero-deco{
  position:absolute; pointer-events:none; z-index:1;
}
.hero-deco-1{ /* small circle */
  top:120px; right:46%;
  width:54px;
  animation:float-slow 8s ease-in-out infinite;
}
.hero-deco-2{ /* small circle 2 */
  bottom:120px; right:8%;
  width:64px;
  animation:float-slow 10s ease-in-out infinite reverse;
}
.hero-deco-3{ /* dots */
  bottom:30%; left:50%;
  width:46px;
  animation:float 6s ease-in-out infinite;
  opacity:.85;
}

/* Hero copy */
.hero-copy{
  position:relative; z-index:3;
  padding:clamp(20px,3vw,40px) 0;
}
.hero-title{
  font-family:var(--serif);
  font-weight:800;
  font-size:clamp(2.6rem, 6vw, 5rem);
  line-height:1.05;
  letter-spacing:-.015em;
  color:#0a1f3d;
  margin:0 0 .4em;
}
.hero-title span{display:block}
.hero-title .paint{
  position:relative; display:inline-block;
}
.hero-title .paint::after{
  content:"";
  position:absolute;
  left:-10px; right:-10px;
  bottom:-6px;
  height:18px;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 400 30' preserveAspectRatio='none'><path d='M5 18 Q 80 8 160 14 T 320 12 T 395 18 L 395 26 Q 320 22 240 24 T 80 22 L 5 26 Z' fill='%23ffb352'/></svg>") no-repeat center/100% 100%;
  z-index:-1;
  animation:paint-grow 1.4s var(--ease) .3s both;
}
@keyframes paint-grow{
  from{transform:scaleX(0); transform-origin:left}
  to{transform:scaleX(1); transform-origin:left}
}
.hero-tagline{
  font-family:var(--sans);
  font-size:clamp(1.1rem, 1.5vw, 1.4rem);
  font-weight:600;
  color:#0a1f3d;
  margin:1.6em 0 0;
  letter-spacing:.005em;
}

/* Hero stage (right side with kid + badges) */
.hero-stage{
  position:relative;
  z-index:2;
  height:100%;
  min-height:560px;
}
.hero-blob{
  position:absolute;
  right:-10%; top:6%;
  width:96%; max-width:640px;
  z-index:1;
  animation:blob-spin 22s ease-in-out infinite;
  filter:drop-shadow(0 14px 28px rgba(107,78,255,.18));
}
.hero-maple{
  position:absolute;
  right:-2%; top:14%;
  width:72%; max-width:500px;
  z-index:2;
  filter:drop-shadow(0 10px 24px rgba(233,30,63,.18));
  animation:float-slow 10s ease-in-out infinite;
}
.hero-kid{
  position:absolute;
  right:0;
  top:0;             /* anchor TOP so feet extend below + get cropped */
  bottom:auto;
  height:120%;       /* taller than stage → bottom (feet) below hero edge */
  width:auto;
  max-width:none;
  z-index:3;
  filter:drop-shadow(0 30px 50px rgba(16,24,40,.18));
  animation:hero-rise 1s var(--ease) both;
}
@keyframes hero-rise{
  from{opacity:0; transform:translateY(40px)}
  to{opacity:1; transform:translateY(0)}
}

/* Floating badge cards */
.hero-badge{
  position:absolute;
  z-index:5;
  background:#fff;
  border-radius:18px;
  padding:14px 22px 14px 14px;
  display:inline-flex; align-items:center; gap:14px;
  box-shadow:0 18px 40px rgba(16,24,40,.12);
  animation:badge-in .9s var(--ease) both;
}
@keyframes badge-in{
  from{opacity:0; transform:translateY(20px) scale(.92)}
  to{opacity:1; transform:translateY(0) scale(1)}
}
.badge-icon{
  flex-shrink:0;
  width:46px; height:46px; border-radius:50%;
  background:#ff8c2a;
  display:grid; place-items:center;
  box-shadow:0 6px 14px rgba(255,140,42,.35);
}
.badge-icon.ic-blue{background:var(--blue); box-shadow:0 6px 14px rgba(43,78,255,.35)}
.badge-icon.ic-purple{background:#6b4eff; box-shadow:0 6px 14px rgba(107,78,255,.35)}
.badge-icon svg{width:22px; height:22px}
.badge-text{display:flex; flex-direction:column; line-height:1.25}
.badge-text strong{
  font-family:var(--serif); font-weight:700;
  font-size:1rem; color:#0a1f3d;
}
.badge-text small{font-size:.78rem; color:var(--muted)}

.badge-ideas{
  top:18%; left:-12%;
  animation-delay:.6s;
}
.badge-ideas:hover{transform:translateY(-4px)}

.badge-450k{
  bottom:14%; left:-2%;
  animation-delay:.9s;
}
.badge-450k:hover{transform:translateY(-4px)}

.badge-register{
  top:38%; right:-8%;
  align-items:flex-start;
  padding:18px 24px 20px 18px;
  max-width:300px;
  animation-delay:1.2s;
}
.badge-register .badge-text{gap:6px}
.badge-register .badge-text small{
  font-size:.82rem; line-height:1.4;
  margin:2px 0 8px;
}
.badge-cta{
  display:inline-block;
  background:#9b51e0;
  color:#fff;
  padding:8px 22px;
  border-radius:10px;
  font-size:.78rem; font-weight:700;
  letter-spacing:.12em;
  transition:all .25s var(--ease);
  box-shadow:0 8px 16px rgba(155,81,224,.35);
  align-self:flex-start;
}
.badge-cta:hover{
  background:#7a3eb8;
  transform:translateY(-2px);
  box-shadow:0 12px 22px rgba(155,81,224,.5);
}

.hero-badge,
.hero-badge:hover{transition:transform .3s var(--ease)}
@keyframes float{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-14px)}
}
@keyframes float-slow{
  0%,100%{transform:translate(0,0)}
  50%{transform:translate(8px,-12px)}
}
@keyframes rotate{
  from{transform:rotate(0deg)}
  to{transform:rotate(360deg)}
}
@keyframes blob-spin{
  0%,100%{transform:rotate(0) scale(1)}
  50%{transform:rotate(8deg) scale(1.04)}
}
@keyframes pulse-ring{
  0%{transform:scale(1); opacity:.5}
  70%{transform:scale(1.4); opacity:0}
  100%{transform:scale(1.4); opacity:0}
}
@keyframes wobble{
  0%,100%{transform:rotate(-3deg)}
  50%{transform:rotate(3deg)}
}

/* Section: Testimonials ------------------------------------ */
.testimonials-head{
  display:flex; align-items:flex-end; justify-content:space-between;
  gap:2rem; margin-bottom:48px; flex-wrap:wrap;
}
.testimonials-head h2{margin:0}
.testimonials-head .meta{
  display:flex; gap:32px; align-items:center;
}
.meta-item{
  display:flex; flex-direction:column; line-height:1.2;
}
.meta-item strong{
  font-family:var(--serif); font-size:1.6rem;
  color:var(--blue); font-weight:800;
}
.meta-item span{font-size:.85rem; color:var(--muted)}

.tcards{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
}
.tcard{
  background:#fff; border-radius:var(--r-lg);
  padding:30px 26px;
  box-shadow:var(--shadow-sm);
  border:1px solid var(--line);
  position:relative;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
}
.tcard:hover{transform:translateY(-6px); box-shadow:var(--shadow)}
.tcard::before{
  content:"\201C";
  position:absolute; top:8px; right:18px;
  font-family:var(--serif); font-size:5rem;
  color:var(--yellow); line-height:1; opacity:.55;
}
.tcard-stars{
  color:var(--yellow); letter-spacing:2px;
  font-size:.95rem; margin-bottom:14px;
}
.tcard-text{
  color:var(--text); font-size:.95rem;
  line-height:1.65; margin:0 0 18px;
}
.tcard-author{
  font-family:var(--serif); color:var(--ink);
  font-weight:700; font-size:1rem;
}
.tcard-meta{font-size:.8rem; color:var(--muted)}

/* Section: Core Values ------------------------------------- */
.values{
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:28px; margin-top:8px;
}
.value{
  background:#fff;
  border-radius:var(--r-lg);
  padding:36px 28px;
  border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
  position:relative;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
}
.value:hover{transform:translateY(-6px); box-shadow:var(--shadow)}
.value-icon{
  width:64px; height:64px; border-radius:18px;
  display:grid; place-items:center;
  margin-bottom:20px;
  background:var(--blue-soft); color:var(--blue);
}
.value:nth-child(2) .value-icon{background:var(--yellow-soft); color:#c97a1a}
.value:nth-child(3) .value-icon{background:rgba(48,168,32,.10); color:var(--green)}
.value-icon svg{width:30px; height:30px}
.value h3{margin-bottom:10px; font-size:1.2rem}
.value p{color:var(--text); margin:0; font-size:.95rem}

/* CTA strip ------------------------------------------------ */
.cta-strip{
  background:linear-gradient(135deg, var(--blue) 0%, #4a6bff 100%);
  color:#fff;
  border-radius:var(--r-lg);
  padding:48px clamp(28px,5vw,64px);
  margin-top:48px;
  display:grid;
  grid-template-columns:1.6fr auto .8fr;
  gap:32px; align-items:center;
  position:relative; overflow:hidden;
}
.cta-strip::before{
  content:""; position:absolute;
  width:400px; height:400px; border-radius:50%;
  background:radial-gradient(circle, rgba(255,179,82,.22), transparent 70%);
  top:-150px; right:-80px;
  animation:pulse-glow 4s ease-in-out infinite;
}
.cta-shape-img{
  position:absolute; right:-100px; top:50%;
  transform:translateY(-50%);
  width:520px; height:auto;
  opacity:.10;
  animation:rotate 60s linear infinite;
  pointer-events:none;
}
@keyframes pulse-glow{
  0%,100%{opacity:1; transform:scale(1)}
  50%{opacity:.6; transform:scale(1.08)}
}
.cta-strip h2{
  color:#fff; margin:0; max-width:24ch;
  font-size:clamp(1.6rem,2.6vw,2.4rem);
  position:relative; z-index:2;
}
.cta-strip h2 .y{color:var(--yellow)}
.cta-strip p{color:rgba(255,255,255,.8); margin:.6em 0 0; max-width:48ch; position:relative; z-index:2}
.cta-strip .right{position:relative; z-index:2}
.cta-strip-img{
  position:relative; z-index:2;
  width:200px; height:auto;
  filter:drop-shadow(0 14px 24px rgba(0,0,0,.25));
  align-self:end;
  margin-bottom:-48px;
  animation:wobble 4s ease-in-out infinite;
}

/* Vision section ------------------------------------------- */
.vision-grid{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:clamp(40px,6vw,80px);
  align-items:center;
}
.vision-art{
  position:relative; aspect-ratio:5/6;
  border-radius:var(--r-lg); overflow:visible;
  display:grid; place-items:center;
}
.vision-art-frame{
  position:relative;
  width:100%; height:100%;
  border-radius:var(--r-lg);
  overflow:hidden;
  box-shadow:var(--shadow);
  background:#fff;
}
.vision-art-frame img{
  width:100%; height:100%;
  object-fit:cover;
  display:block;
  transition:transform .6s var(--ease);
}
.vision-art:hover .vision-art-frame img{transform:scale(1.04)}
.vision-art .badge{
  position:absolute; top:18px; right:-14px;
  z-index:3;
  background:var(--yellow); color:var(--ink);
  font-weight:700; font-size:.78rem;
  letter-spacing:.12em; text-transform:uppercase;
  padding:12px 20px; border-radius:var(--r-pill);
  box-shadow:0 14px 28px rgba(255,179,82,.45);
  animation:float 4s ease-in-out infinite;
}
.vision-art .deco-circle{
  position:absolute; width:140px; height:140px;
  border:10px solid var(--yellow); border-radius:50%;
  bottom:-60px; left:-60px; opacity:.5;
  z-index:0;
  animation:float-slow 8s ease-in-out infinite;
}
.vision-art .deco-dots{
  position:absolute; top:-20px; left:-20px;
  width:90px; height:90px;
  background-image:radial-gradient(var(--blue) 1.6px, transparent 2px);
  background-size:14px 14px;
  z-index:0; opacity:.6;
}
.vision-art .deco-star{
  position:absolute; bottom:30px; right:-30px;
  width:60px; z-index:3;
  filter:drop-shadow(0 4px 10px rgba(255,179,82,.5));
  animation:rotate 18s linear infinite;
}
.vision-body .eyebrow{padding-left:46px}
.vision-list{
  list-style:none; padding:0; margin:1.4rem 0 2rem;
  display:grid; gap:14px;
}
.vision-list li{
  display:flex; gap:14px; align-items:flex-start;
  font-size:1rem; color:var(--text);
}
.vision-list li::before{
  content:""; flex-shrink:0;
  width:22px; height:22px; border-radius:50%;
  background:var(--yellow);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23101828' stroke-width='3'><path d='M5 12l5 5L20 7'/></svg>");
  background-size:14px; background-repeat:no-repeat; background-position:center;
  margin-top:3px;
}

/* Stats ---------------------------------------------------- */
.section--blue .eyebrow{color:var(--yellow)}
.section--blue .eyebrow::before{background:#fff}
.stats{
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:28px; margin-top:48px;
}
.stat{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14);
  border-radius:var(--r-lg);
  padding:32px 28px;
  backdrop-filter:blur(6px);
  transition:transform .3s var(--ease), background .3s var(--ease);
}
.stat:hover{transform:translateY(-4px); background:rgba(255,255,255,.10)}
.stat-icon{
  width:54px; height:54px; border-radius:14px;
  background:var(--yellow); color:var(--ink);
  display:grid; place-items:center; margin-bottom:18px;
}
.stat-icon svg{width:26px; height:26px}
.stat-num{
  font-family:var(--serif); font-weight:800;
  font-size:clamp(2.4rem,4vw,3.4rem);
  color:#fff; line-height:1; display:block;
}
.stat-num em{font-style:normal; color:var(--yellow); font-size:.7em; margin-left:2px}
.stat-label{
  display:block; margin-top:10px;
  color:#dde3ff; font-size:.95rem;
}

/* Leadership ---------------------------------------------- */
.leaders{
  display:grid; grid-template-columns:1fr 1fr;
  gap:28px;
  margin-top:48px;
}
.leader{
  background:#fff; border-radius:var(--r-lg);
  padding:36px 32px;
  border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
  display:grid; grid-template-columns:auto 1fr; gap:28px;
  align-items:flex-start;
}
.leader-portrait{
  width:130px; height:160px; flex-shrink:0;
  border-radius:18px 18px 80px 18px;
  background:linear-gradient(135deg, var(--blue) 0%, var(--blue-2) 100%);
  position:relative;
  overflow:hidden;
  box-shadow:var(--shadow-blue);
}
.leader-portrait::after{
  content:""; position:absolute;
  width:30px; height:30px; border-radius:50%;
  background:var(--yellow);
  bottom:-10px; right:-10px;
  z-index:2;
  box-shadow:0 6px 14px rgba(255,179,82,.5);
}
.leader-portrait img{
  width:100%; height:100%;
  object-fit:cover;
  object-position:center 22%;   /* anchor crop on face area */
  display:block;
  transition:transform .5s var(--ease);
}
.leader:hover .leader-portrait img{transform:scale(1.08)}
.leader-portrait svg{width:54px; height:54px; color:#fff; opacity:.95}
.leader-quote{
  font-family:var(--serif); font-size:1.05rem; line-height:1.55;
  color:var(--ink); margin:0 0 16px; font-style:italic;
  font-weight:500;
}
.leader-quote::before{
  content:"\201C"; font-size:1.4em; color:var(--yellow); margin-right:2px;
}
.leader-name{
  font-family:var(--serif); font-weight:700;
  color:var(--ink); font-size:1.1rem;
}
.leader-role{
  display:inline-block; margin-top:4px;
  background:var(--blue-soft); color:var(--blue);
  font-size:.78rem; font-weight:600;
  letter-spacing:.06em;
  padding:5px 12px; border-radius:var(--r-pill);
}

/* Blog cards ---------------------------------------------- */
.posts{
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:28px; margin-top:48px;
}
.post{
  background:#fff; border-radius:var(--r-lg);
  border:1px solid var(--line);
  overflow:hidden;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
}
.post:hover{transform:translateY(-6px); box-shadow:var(--shadow)}
.post-img{
  aspect-ratio:1/1;
  background:linear-gradient(135deg, var(--blue-soft) 0%, var(--yellow-soft) 100%);
  display:grid; place-items:center;
  position:relative;
  overflow:hidden;
}
.post-img img{
  width:100%; height:100%;
  object-fit:cover; object-position:center;
  display:block;
  transition:transform .8s var(--ease);
}
.post:hover .post-img img{transform:scale(1.06)}
.post-tag{
  position:absolute; top:18px; left:18px;
  background:#fff; color:var(--ink);
  font-size:.72rem; font-weight:600;
  letter-spacing:.12em; text-transform:uppercase;
  padding:6px 14px; border-radius:var(--r-pill);
  box-shadow:var(--shadow-sm);
}
.post-body{padding:26px 26px 28px}
.post-meta{
  display:flex; align-items:center; gap:10px;
  font-size:.82rem; color:var(--muted); margin-bottom:12px;
}
.post-meta .dot{width:4px; height:4px; border-radius:50%; background:var(--muted)}
.post h3{
  font-size:1.2rem; line-height:1.35;
  margin-bottom:14px;
}
.post h3 a{transition:color .2s}
.post h3 a:hover{color:var(--blue)}
.post-link{
  display:inline-flex; align-items:center; gap:8px;
  font-weight:600; color:var(--blue); font-size:.9rem;
  letter-spacing:.04em;
}
.post-link svg{width:14px; height:14px; transition:transform .2s var(--ease)}
.post-link:hover svg{transform:translateX(3px)}

/* App download -------------------------------------------- */
.app{
  background:linear-gradient(135deg, var(--teal) 0%, var(--teal-2) 100%);
  color:#fff;
  position:relative; overflow:hidden;
}
.app::before{
  content:""; position:absolute;
  width:500px; height:500px; border-radius:50%;
  background:radial-gradient(circle, rgba(255,179,82,.15), transparent 70%);
  top:-200px; left:-100px;
}
.app::after{
  content:""; position:absolute;
  width:400px; height:400px; border-radius:50%;
  background:radial-gradient(circle, rgba(255,255,255,.06), transparent 70%);
  bottom:-150px; right:-100px;
}
.app .container{position:relative; z-index:1}
.app-grid{
  display:grid; grid-template-columns:1.2fr .8fr;
  gap:64px; align-items:center;
}
.app h2{color:#fff; max-width:18ch}
.app h2 .y{color:var(--yellow)}
.app .lede{color:rgba(255,255,255,.85); max-width:48ch}
.app-stores{display:flex; gap:14px; margin-top:24px; flex-wrap:wrap}
.store{
  display:inline-flex; align-items:center; gap:12px;
  background:#000; color:#fff;
  padding:12px 22px; border-radius:var(--r);
  border:1px solid rgba(255,255,255,.1);
  transition:transform .25s var(--ease), background .25s var(--ease);
}
.store:hover{transform:translateY(-3px); background:#1a1a1a}
.store svg{width:28px; height:28px; flex-shrink:0}
.store-text{display:flex; flex-direction:column; line-height:1.1; text-align:left}
.store-text small{font-size:.7rem; color:rgba(255,255,255,.7); letter-spacing:.04em}
.store-text strong{font-size:1rem; font-weight:600}
.app-spaceman{
  position:relative;
  max-width:380px; margin:0 auto;
  border-radius:36px;
  overflow:hidden;
  box-shadow:0 30px 60px rgba(0,0,0,.4);
  animation:float 6s ease-in-out infinite;
  border:6px solid rgba(255,255,255,.1);
}
.app-spaceman img{
  width:100%; height:auto; display:block;
  transition:transform .8s var(--ease);
}
.app-spaceman:hover img{transform:scale(1.04)}

/* Contact -------------------------------------------------- */
.contact-grid{
  display:grid; grid-template-columns:1fr 1.1fr;
  gap:48px; margin-top:48px; align-items:flex-start;
}
.contact-info{
  background:#fff; border-radius:var(--r-lg);
  border:1px solid var(--line);
  padding:36px 32px;
  box-shadow:var(--shadow-sm);
}
.contact-info dl{margin:0; display:grid; gap:24px}
.contact-row{display:flex; gap:16px; align-items:flex-start}
.contact-row .ico{
  flex-shrink:0; width:46px; height:46px; border-radius:14px;
  background:var(--blue-soft); color:var(--blue);
  display:grid; place-items:center;
}
.contact-row .ico svg{width:20px; height:20px}
.contact-row dt{
  font-size:.72rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--muted); font-weight:600; margin-bottom:4px;
}
.contact-row dd{
  margin:0; color:var(--ink); font-weight:500;
}
.contact-row dd a:hover{color:var(--blue)}
.contact-channels{
  display:flex; gap:10px; margin-top:28px; padding-top:24px;
  border-top:1px solid var(--line); flex-wrap:wrap;
}
.channel{
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 16px; border-radius:var(--r-pill);
  background:var(--blue-soft); color:var(--blue);
  font-size:.84rem; font-weight:600;
  transition:all .2s var(--ease);
}
.channel:hover{background:var(--blue); color:#fff}
.channel svg{width:14px;height:14px}

.contact-form{
  background:#fff; border-radius:var(--r-lg);
  border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
  padding:36px 32px;
}
.contact-form h3{margin-bottom:6px}
.contact-form .lede{font-size:.95rem; margin-bottom:24px}
.field{margin-bottom:16px}
.field label{
  display:block; margin-bottom:6px;
  font-size:.78rem; font-weight:600;
  letter-spacing:.06em; color:var(--ink);
}
.field input,.field select,.field textarea{
  width:100%; background:var(--bg-soft);
  border:1.5px solid transparent;
  border-radius:var(--r);
  padding:12px 16px; font-size:.95rem;
  transition:border-color .2s, background .2s;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none; border-color:var(--blue); background:#fff;
}
.field textarea{resize:vertical; min-height:120px}
.field-row{display:grid; grid-template-columns:1fr 1fr; gap:14px}
.honeypot{position:absolute; left:-9999px; width:1px; height:1px; opacity:0}
.alert{
  padding:14px 18px; margin-bottom:18px; border-radius:var(--r);
  font-size:.92rem;
  background:rgba(242,39,126,.06); color:var(--pink);
  border:1px solid rgba(242,39,126,.2);
}
.alert--ok{
  background:rgba(48,168,32,.08); color:var(--green);
  border-color:rgba(48,168,32,.25);
}
.alert.is-flash{animation:alert-flash 1.2s ease-out}
@keyframes alert-flash{
  0%   { box-shadow:0 0 0 0 rgba(43,78,255,.45); transform:translateY(0) }
  20%  { box-shadow:0 0 0 10px rgba(43,78,255,.18); transform:translateY(-2px) }
  100% { box-shadow:0 0 0 0 rgba(43,78,255,0);    transform:translateY(0) }
}

/* Footer --------------------------------------------------- */
.footer{
  background:#0a1428; color:#9aa6bb;
  padding:clamp(64px,7vw,100px) 0 28px;
  font-size:.92rem;
  position:relative; overflow:hidden;
}
.footer::before{
  content:""; position:absolute;
  width:400px; height:400px; border-radius:50%;
  background:radial-gradient(circle, rgba(43,78,255,.12), transparent 70%);
  top:-150px; right:-100px;
}
.footer .container{position:relative; z-index:1}
.footer a{color:#cdd5e2; transition:color .2s}
.footer a:hover{color:var(--yellow)}
.footer-grid{
  display:grid; grid-template-columns:1.4fr 1fr 1fr 1.3fr;
  gap:48px; margin-bottom:48px;
}
.footer-brand .brand-text .top{color:#fff}
.footer-brand .brand-text .sub{color:var(--yellow)}
.footer-brand p{color:#9aa6bb; margin-top:1.4rem; max-width:32ch}
.footer h4{
  color:#fff; font-family:var(--serif);
  font-size:1.1rem; margin-bottom:1.2rem;
}
.footer ul{list-style:none; padding:0; margin:0; display:grid; gap:.6rem}
.footer-newsletter input{
  width:100%; background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.12);
  color:#fff; padding:12px 16px; border-radius:var(--r);
  font-size:.92rem; margin-bottom:12px;
}
.footer-newsletter input::placeholder{color:#7a8696}
.footer-newsletter input:focus{outline:none; border-color:var(--yellow)}
.footer-newsletter button{
  width:100%; padding:12px 16px; border-radius:var(--r);
  background:var(--yellow); color:var(--ink);
  font-weight:700; font-size:.88rem; letter-spacing:.04em;
  transition:transform .2s var(--ease);
}
.footer-newsletter button:hover{transform:translateY(-2px)}
.footer-bottom{
  padding-top:24px; border-top:1px solid rgba(255,255,255,.08);
  display:flex; justify-content:space-between; align-items:center;
  flex-wrap:wrap; gap:1rem;
  font-size:.84rem; color:#7a8696;
}
.footer-socials{display:flex; gap:10px}
.footer-socials a{
  width:38px; height:38px; border-radius:50%;
  display:grid; place-items:center;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);
  transition:all .25s var(--ease);
}
.footer-socials a:hover{
  background:var(--yellow); border-color:var(--yellow); color:var(--ink);
  transform:translateY(-3px);
}
.footer-socials svg{width:14px; height:14px}

/* Tuition & Fees ------------------------------------------- */
.tuition-grid{
  display:grid; grid-template-columns:repeat(4, 1fr);
  gap:24px; margin-top:8px;
}
.tuition-card{
  background:#fff; border-radius:var(--r-lg);
  border:1px solid var(--line);
  padding:32px 26px 28px;
  display:flex; flex-direction:column;
  box-shadow:var(--shadow-sm);
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s var(--ease);
  position:relative;
}
.tuition-card:hover{
  transform:translateY(-8px);
  box-shadow:var(--shadow);
  border-color:var(--blue);
}
.tuition-card.is-featured{
  background:linear-gradient(160deg, var(--blue) 0%, var(--blue-2) 100%);
  color:#fff;
  border-color:var(--blue);
  box-shadow:0 18px 40px rgba(43,78,255,.30);
}
.tuition-card.is-featured h3{color:#fff}
.tuition-card.is-featured .tuition-tier{
  background:rgba(255,255,255,.18); color:#fff;
}
.tuition-card.is-featured .tuition-meta{color:rgba(255,255,255,.78)}
.tuition-card.is-featured ul li{color:rgba(255,255,255,.92)}
.tuition-card.is-featured ul li::before{background:var(--yellow)}
.tuition-card.is-featured .btn{
  background:var(--yellow); color:var(--ink);
  box-shadow:0 10px 20px rgba(255,179,82,.3);
}
.tuition-card.is-featured .btn:hover{background:#fff}
.tuition-tier{
  display:inline-block;
  background:var(--blue-soft); color:var(--blue);
  font-size:.74rem; font-weight:700;
  letter-spacing:.14em; text-transform:uppercase;
  padding:6px 14px; border-radius:var(--r-pill);
  margin-bottom:18px;
  align-self:flex-start;
}
.tuition-card h3{
  font-size:1.45rem; font-weight:800; margin-bottom:6px;
  color:var(--ink);
}
.tuition-meta{
  font-size:.86rem; color:var(--muted);
  margin-bottom:18px; letter-spacing:.02em;
}
.tuition-card ul{
  list-style:none; padding:0; margin:0 0 24px;
  display:grid; gap:10px;
}
.tuition-card ul li{
  position:relative; padding-left:24px;
  font-size:.92rem; color:var(--text);
  line-height:1.5;
}
.tuition-card ul li::before{
  content:""; position:absolute;
  left:0; top:8px;
  width:14px; height:14px; border-radius:50%;
  background:var(--blue-soft);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14' fill='none' stroke='%232b4eff' stroke-width='2.4'><path d='M3 7l3 3 5-6'/></svg>");
  background-size:10px; background-repeat:no-repeat; background-position:center;
}
.tuition-card .btn{
  margin-top:auto;
  align-self:flex-start;
}

/* Tuition perks */
.tuition-perks{
  display:grid; grid-template-columns:repeat(3, 1fr);
  gap:20px; margin-top:48px;
  padding:32px clamp(20px, 3vw, 40px);
  background:#fff; border-radius:var(--r-lg);
  border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
}
.perk{
  display:flex; gap:16px; align-items:flex-start;
}
.perk-icon{
  flex-shrink:0;
  width:48px; height:48px; border-radius:14px;
  background:var(--yellow-soft); color:#c97a1a;
  display:grid; place-items:center;
}
.perk-icon svg{width:22px; height:22px}
.perk strong{
  display:block;
  font-family:var(--serif); font-weight:700;
  color:var(--ink); font-size:1.05rem;
  margin-bottom:2px;
}
.perk p{
  margin:0; font-size:.86rem; color:var(--muted);
}

/* Admissions process */
.adm-process{
  margin-top:64px;
  padding:48px clamp(24px,4vw,56px);
  background:#fff;
  border-radius:var(--r-lg);
  border:1px solid var(--line);
}
.adm-process h3{
  text-align:center; margin-bottom:36px;
  font-size:1.6rem;
}
.adm-steps{
  list-style:none; padding:0; margin:0;
  display:grid; grid-template-columns:repeat(4, 1fr);
  gap:24px; counter-reset:adm;
}
.adm-steps li{
  position:relative; padding-top:18px;
}
.adm-steps li:not(:last-child)::after{
  content:""; position:absolute;
  left:64px; right:-12px; top:38px;
  height:2px;
  background:repeating-linear-gradient(to right, var(--blue) 0 6px, transparent 6px 12px);
  z-index:0;
}
.adm-steps li span{
  display:grid; place-items:center;
  width:54px; height:54px; border-radius:50%;
  background:var(--blue); color:#fff;
  font-family:var(--serif); font-weight:800; font-size:1.4rem;
  margin-bottom:18px;
  position:relative; z-index:1;
  box-shadow:0 8px 20px rgba(43,78,255,.30);
}
.adm-steps li strong{
  display:block;
  font-family:var(--serif); font-weight:700;
  color:var(--ink); font-size:1.15rem;
  margin-bottom:6px;
}
.adm-steps li p{
  margin:0; font-size:.92rem; color:var(--text);
  line-height:1.55;
}

/* Accreditations strip ------------------------------------- */
.accreditations{
  background:#fff;
  padding:40px 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.acc-head{
  text-align:center;
  font-size:.78rem; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--muted);
  margin-bottom:24px;
}
.acc-strip{
  display:flex; align-items:center; justify-content:center;
}
.acc-strip img{
  max-height:80px;
  max-width:100%;
  height:auto; width:auto;
  filter:grayscale(60%);
  opacity:.85;
  transition:all .4s var(--ease);
}
.acc-strip img:hover{
  filter:grayscale(0);
  opacity:1;
  transform:scale(1.02);
}

/* Section decorations -------------------------------------- */
.section-deco{position:absolute; pointer-events:none; z-index:0}
.section-deco.deco-star-tl{
  top:60px; left:30px;
  width:48px; opacity:.5;
  animation:rotate 20s linear infinite;
}
.section-deco.deco-star-br{
  bottom:60px; right:40px;
  width:36px; opacity:.4;
  animation:rotate 25s linear infinite reverse;
}
.section-deco.deco-dot-tr{
  top:80px; right:60px;
  width:60px; opacity:.4;
  animation:float 6s ease-in-out infinite;
}

/* Careers page hero ---------------------------------------- */
.careers-hero{
  position:relative; overflow:hidden;
  background:#c6dfe5;
  padding:clamp(48px, 7vw, 100px) 0 clamp(48px, 7vw, 90px);
}
.careers-hero::before{
  content:""; position:absolute;
  width:560px; height:560px; border-radius:50%;
  top:-180px; right:-180px;
  background:radial-gradient(circle, rgba(43,78,255,.20), transparent 70%);
  pointer-events:none;
}
.careers-hero::after{
  content:""; position:absolute;
  width:380px; height:380px; border-radius:50%;
  bottom:-160px; left:-100px;
  background:radial-gradient(circle, rgba(255,179,82,.30), transparent 70%);
  pointer-events:none;
}
.careers-hero-inner{
  position:relative; z-index:1;
  max-width:780px;
}
.careers-hero h1{
  font-family:var(--serif); font-weight:800;
  font-size:clamp(2.4rem, 5vw, 4.4rem);
  line-height:1.05; color:#0a1f3d;
  margin:.4em 0 .5em;
}
.careers-hero .lede{
  font-size:1.1rem; color:var(--ink);
  max-width:54ch;
}

/* Careers --------------------------------------------------- */
.careers{
  position:relative; overflow:hidden;
  background:linear-gradient(160deg, var(--ink) 0%, #0d2547 100%);
  color:#dde3ff;
}
.careers-bg{
  position:absolute; inset:0;
  background:
    radial-gradient(600px 400px at 0% 100%, rgba(43,78,255,.30), transparent 70%),
    radial-gradient(500px 400px at 100% 0%, rgba(255,179,82,.18), transparent 65%);
  pointer-events:none;
}
.careers .container{position:relative; z-index:1}
.careers-grid{
  display:grid; grid-template-columns:1fr 1.05fr;
  gap:clamp(36px, 5vw, 72px);
  align-items:flex-start;
}
.careers-intro h2{color:#fff; max-width:14ch; margin-bottom:1rem}
.careers-intro h2 .scribble::after{background:var(--yellow); opacity:.85}
.careers-intro .lede{color:#cdd5e2; max-width:48ch}
.career-perks{
  list-style:none; padding:0; margin:2rem 0 1.6rem;
  display:grid; gap:14px;
}
.career-perks li{
  display:flex; align-items:flex-start; gap:14px;
  font-size:.96rem; color:#dde3ff;
}
.career-perks li svg{
  flex-shrink:0; width:22px; height:22px;
  color:var(--yellow);
  margin-top:2px;
}
.career-perks li strong{color:#fff; font-weight:700; font-family:var(--serif)}
.career-note{
  color:#9aa6bb; font-size:.9rem;
  border-top:1px solid rgba(255,255,255,.12);
  padding-top:18px; margin-top:1.4rem;
}
.career-note a{color:var(--yellow); border-bottom:1px solid rgba(255,179,82,.4)}
.career-note a:hover{color:#fff; border-bottom-color:#fff}

/* Career form */
.career-form{
  background:#fff; color:var(--ink);
  border-radius:var(--r-lg);
  padding:36px 32px;
  box-shadow:0 30px 60px rgba(0,0,0,.30);
}
.career-form h3{margin-bottom:6px; font-size:1.6rem}
.career-form-lede{
  color:var(--muted); font-size:.95rem;
  margin-bottom:24px;
}

/* Email verification (PIN flow) */
.verify-block{
  margin:8px 0 18px;
  padding:18px 18px;
  background:var(--bg-soft);
  border:1px solid var(--line);
  border-radius:var(--r);
}
.verify-row{
  display:flex; align-items:center; justify-content:space-between;
  gap:16px; flex-wrap:wrap;
}
.verify-info strong{
  display:block;
  font-family:var(--serif); font-weight:700;
  color:var(--ink); font-size:1rem;
}
.verify-info p{
  margin:2px 0 0; font-size:.85rem; color:var(--muted);
}
.verify-send{padding:10px 22px; font-size:.82rem; flex-shrink:0}
.verify-send:disabled{
  background:var(--blue-soft); color:var(--blue); opacity:.7;
  cursor:not-allowed; box-shadow:none; transform:none;
}
.verify-pin{margin-top:14px}
.verify-pin .field{margin:0}
.verify-pin label{font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:var(--muted)}
.pin-row{display:flex; gap:10px; align-items:center}
.pin-row input{
  flex:1;
  background:#fff;
  border:1.5px solid var(--rule-strong);
  border-radius:var(--r);
  padding:14px 18px;
  font-family:var(--serif); font-weight:700;
  font-size:1.4rem; letter-spacing:.4em; text-align:center;
  color:var(--ink);
}
.pin-row input:focus{outline:none; border-color:var(--blue); background:#fff}
.pin-row .btn{flex-shrink:0; padding:14px 22px}
.verify-msg{
  display:block; margin-top:10px; font-size:.85rem;
  min-height:1.2em;
}
.verify-msg.is-ok{color:var(--green)}
.verify-msg.is-err{color:var(--pink)}
.verify-ok{
  display:flex; align-items:center; gap:10px; flex-wrap:wrap;
  padding:14px 16px;
  background:rgba(48,168,32,.10);
  border:1px solid rgba(48,168,32,.28);
  border-radius:var(--r);
  color:#1f6f15;
  margin-top:14px;
}
.verify-ok svg{
  width:20px; height:20px; flex-shrink:0;
  background:var(--green); color:#fff;
  border-radius:50%; padding:3px;
}
.verify-ok strong{font-family:var(--serif); font-weight:700}
.verify-ok-email{
  font-size:.85rem; color:var(--muted); font-weight:500;
}

#careerSubmit:disabled{
  background:#cdd5e2 !important; color:#7a8696 !important;
  box-shadow:none !important; cursor:not-allowed;
  transform:none !important;
}
#careerSubmit:disabled::before{display:none}

/* CV upload — drag/drop visual */
.cv-field{position:relative}
.cv-field > label{
  display:flex; align-items:baseline; justify-content:space-between;
  gap:8px;
}
.cv-field > label small{
  font-size:.7rem; font-weight:500; letter-spacing:.04em;
  color:var(--muted); text-transform:none;
}
.cv-drop{
  display:flex; align-items:center; gap:16px;
  padding:18px 20px;
  border:2px dashed var(--rule-strong);
  border-radius:var(--r);
  background:var(--bg-soft);
  cursor:pointer;
  transition:all .25s var(--ease);
}
.cv-drop:hover,
.cv-drop.is-drag{
  border-color:var(--blue);
  background:var(--blue-soft);
}
.cv-drop > svg{
  flex-shrink:0; width:34px; height:34px;
  color:var(--blue);
}
.cv-drop-text{display:flex; flex-direction:column; line-height:1.3}
.cv-drop-text strong{color:var(--ink); font-weight:600}
.cv-drop-text small{font-size:.78rem; color:var(--muted); margin-top:2px}
input[type=file]#c-cv{
  position:absolute; left:0; top:0;
  width:1px; height:1px; opacity:0; pointer-events:none;
}
.cv-name{
  display:inline-flex; align-items:center; gap:8px;
  margin-top:10px; padding:8px 12px;
  background:rgba(43,78,255,.08); color:var(--blue);
  border-radius:var(--r-pill);
  font-size:.85rem; font-weight:500;
  max-width:100%; word-break:break-all;
}
.cv-name::before{
  content:""; flex-shrink:0;
  width:14px; height:14px; border-radius:50%;
  background:var(--green);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14' fill='none' stroke='%23fff' stroke-width='2.4'><path d='M3 7l3 3 5-6'/></svg>");
  background-size:10px; background-repeat:no-repeat; background-position:center;
}

@media (max-width:1080px){
  .careers-grid{grid-template-columns:1fr; gap:48px}
}

/* Hero title — word-by-word reveal ------------------------- */
.hl-word{
  display:block;
  overflow:hidden;
}
.hl-word > i{
  display:inline-block;
  font-style:inherit;
  transform:translateY(110%);
  opacity:0;
  animation:hl-rise .9s cubic-bezier(.2,.7,.2,1) var(--d,0s) both;
}
@keyframes hl-rise{
  0%{transform:translateY(110%); opacity:0}
  100%{transform:translateY(0); opacity:1}
}
.hero-tagline{
  opacity:0; transform:translateY(14px);
  animation:hl-fade .8s var(--ease) var(--d,.6s) both;
}
@keyframes hl-fade{from{opacity:0; transform:translateY(14px)} to{opacity:1; transform:translateY(0)}}

/* Milestones timeline -------------------------------------- */
.milestones{
  position:relative; overflow:hidden;
  background:
    linear-gradient(180deg, #fff 0%, var(--bg-soft) 100%);
}
.ms-glow{
  position:absolute; pointer-events:none;
  width:600px; height:600px; border-radius:50%;
  top:-220px; right:-180px;
  background:radial-gradient(circle, rgba(43,78,255,.12), transparent 70%);
  z-index:0;
}
.timeline{
  list-style:none; padding:0; margin:48px 0 0;
  position:relative;
  display:grid;
  grid-template-columns:repeat(6, 1fr);
  gap:24px;
}
.timeline::before{
  content:""; position:absolute;
  top:38px; left:0; right:0;
  height:3px;
  background:repeating-linear-gradient(to right, var(--blue) 0 8px, transparent 8px 16px);
  opacity:.3;
  z-index:0;
}
.tl-item{
  position:relative; padding-top:62px;
  transition:transform .35s var(--ease);
}
.tl-item:hover{transform:translateY(-6px)}
.tl-dot{
  position:absolute; top:24px; left:0;
  width:30px; height:30px; border-radius:50%;
  background:#fff;
  border:4px solid var(--blue);
  box-shadow:0 8px 20px rgba(43,78,255,.25);
  z-index:1;
  transition:all .3s var(--ease);
}
.tl-item.now .tl-dot{
  background:var(--yellow);
  border-color:var(--yellow);
  box-shadow:0 0 0 6px rgba(255,179,82,.20),
             0 8px 20px rgba(255,179,82,.4);
  animation:pulse-dot 2s ease-in-out infinite;
}
@keyframes pulse-dot{
  0%,100%{box-shadow:0 0 0 6px rgba(255,179,82,.20), 0 8px 20px rgba(255,179,82,.4)}
  50%{box-shadow:0 0 0 14px rgba(255,179,82,.0), 0 8px 20px rgba(255,179,82,.4)}
}
.tl-item:hover .tl-dot{transform:scale(1.15)}
.tl-year{
  display:inline-block;
  font-family:var(--serif); font-weight:800;
  font-size:1.6rem; color:var(--blue);
  letter-spacing:-.01em;
  margin-bottom:8px;
}
.tl-item.now .tl-year{color:#c97a1a}
.tl-item h3{
  font-size:1.05rem; font-weight:700;
  color:var(--ink); margin:0 0 8px;
}
.tl-item p{
  font-size:.86rem; line-height:1.55;
  color:var(--text); margin:0;
}

/* Scroll progress bar -------------------------------------- */
.scroll-progress{
  position:fixed;
  top:0; left:0; right:0;
  height:3px;
  z-index:60;
  pointer-events:none;
  background:transparent;
}
.scroll-progress::after{
  content:""; display:block; height:100%;
  background:linear-gradient(90deg, var(--blue) 0%, var(--yellow) 50%, var(--pink) 100%);
  transform:scaleX(var(--p, 0));
  transform-origin:left center;
  transition:transform .15s linear;
}

/* Floating CTAs -------------------------------------------- */
.floaters{
  position:fixed;
  right:22px; bottom:22px;
  display:flex; flex-direction:column-reverse; gap:14px;
  z-index:60;
}
.float-btn{
  width:56px; height:56px; border-radius:50%;
  display:grid; place-items:center;
  cursor:pointer; position:relative;
  box-shadow:0 14px 30px rgba(0,0,0,.18);
  transition:transform .25s var(--ease), box-shadow .25s var(--ease);
  text-decoration:none;
}
.float-btn:hover{
  transform:translateY(-3px) scale(1.04);
  box-shadow:0 20px 40px rgba(0,0,0,.24);
}
.float-btn svg{width:26px; height:26px}
.float-wa{
  background:#25d366;
  animation:wa-ring 2.6s ease-in-out infinite;
}
@keyframes wa-ring{
  0%, 100%{box-shadow:0 14px 30px rgba(37,211,102,.5), 0 0 0 0 rgba(37,211,102,.4)}
  50%{box-shadow:0 14px 30px rgba(37,211,102,.5), 0 0 0 14px rgba(37,211,102,0)}
}
.float-tip{
  position:absolute;
  right:calc(100% + 12px);
  top:50%; transform:translateY(-50%) translateX(8px);
  background:var(--ink); color:#fff;
  padding:8px 14px; border-radius:8px;
  font-size:.82rem; font-weight:600; white-space:nowrap;
  opacity:0; pointer-events:none;
  transition:opacity .25s var(--ease), transform .25s var(--ease);
}
.float-tip::after{
  content:""; position:absolute;
  right:-5px; top:50%; transform:translateY(-50%);
  width:0; height:0;
  border-style:solid; border-width:5px 0 5px 6px;
  border-color:transparent transparent transparent var(--ink);
}
.float-wa:hover .float-tip{
  opacity:1; transform:translateY(-50%) translateX(0);
}
.float-top{
  background:var(--blue);
  border:0;
  opacity:0; pointer-events:none;
  transform:translateY(20px) scale(.9);
  transition:opacity .3s var(--ease), transform .3s var(--ease);
}
.float-top.is-visible{
  opacity:1; pointer-events:auto;
  transform:translateY(0) scale(1);
}

@media (max-width: 820px){
  .floaters{right:14px; bottom:14px; gap:10px}
  .float-btn{width:50px; height:50px}
  .float-btn svg{width:22px; height:22px}
  .float-tip{display:none}
  .timeline{grid-template-columns:1fr; gap:36px}
  .timeline::before{
    top:0; bottom:0; left:14px; right:auto;
    width:3px; height:auto;
    background:repeating-linear-gradient(to bottom, var(--blue) 0 8px, transparent 8px 16px);
  }
  .tl-item{padding:0 0 0 50px}
  .tl-dot{top:0; left:0}
}

/* Reveal animation ----------------------------------------- */
.reveal{
  opacity:0; transform:translateY(28px);
  transition:opacity .8s var(--ease), transform .8s var(--ease);
}
.reveal.is-visible{opacity:1; transform:translateY(0)}
.reveal.r-left{transform:translateX(-28px)}
.reveal.r-right{transform:translateX(28px)}
.reveal.r-left.is-visible,
.reveal.r-right.is-visible{transform:translateX(0)}
.reveal.d-1{transition-delay:.08s}
.reveal.d-2{transition-delay:.16s}
.reveal.d-3{transition-delay:.24s}
.reveal.d-4{transition-delay:.32s}
.reveal.d-5{transition-delay:.40s}

/* Leader portrait — hover lift ---------------------------- */
.leader{transition:transform .35s var(--ease), box-shadow .35s var(--ease)}
.leader:hover{transform:translateY(-6px); box-shadow:var(--shadow)}
.leader-portrait{transition:transform .35s var(--ease)}
.leader:hover .leader-portrait{transform:rotate(-2deg) scale(1.02)}

/* Value icon hover bounce */
.value:hover .value-icon{animation:bounce-soft .6s var(--ease)}
@keyframes bounce-soft{
  0%,100%{transform:translateY(0)}
  40%{transform:translateY(-8px) rotate(-4deg)}
  70%{transform:translateY(2px) rotate(2deg)}
}

/* Stat number — pulse on view */
.stat:hover .stat-icon{animation:bounce-soft .6s var(--ease)}

/* Hero callout — gentle pulse */
/* (legacy callout pulse kept for reuse) */
@keyframes callout-pulse{
  0%,100%{box-shadow:var(--shadow)}
  50%{box-shadow:0 18px 40px rgba(43,78,255,.18)}
}

/* Button shimmer on primary */
.btn-primary{position:relative; overflow:hidden}
.btn-primary::before{
  content:""; position:absolute; inset:0;
  background:linear-gradient(120deg, transparent 30%, rgba(255,255,255,.5) 50%, transparent 70%);
  transform:translateX(-100%);
  transition:transform .8s var(--ease);
}
.btn-primary:hover::before{transform:translateX(100%)}

/* Marquee for accreditation tagline (optional) */
.tagline-marquee{
  background:var(--ink); color:#fff;
  padding:14px 0; overflow:hidden;
  white-space:nowrap;
}
.tagline-marquee-track{
  display:inline-block;
  animation:marquee 30s linear infinite;
}
.tagline-marquee span{
  display:inline-flex; align-items:center; gap:1.2rem;
  padding:0 2rem;
  font-family:var(--serif); font-size:1.1rem; font-weight:600;
  letter-spacing:.04em;
}
.tagline-marquee span::after{
  content:"★"; color:var(--yellow); margin-left:1rem;
}
@keyframes marquee{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* Responsive ----------------------------------------------- */
@media (max-width: 1080px){
  .tuition-grid{grid-template-columns:repeat(2,1fr)}
  .adm-steps{grid-template-columns:repeat(2,1fr)}
  .adm-steps li:nth-child(2)::after{display:none}
  .tuition-perks{grid-template-columns:1fr; gap:14px}
  .tcards{grid-template-columns:repeat(2,1fr)}
  .values{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2,1fr)}
  .leaders{grid-template-columns:1fr}
  .posts{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width: 820px){
  .nav{height:74px}
  .nav-links,.nav-cta{display:none}
  .menu-toggle{
    display:grid; place-items:center;
    width:46px; height:46px; border-radius:12px;
    background:var(--blue-soft); color:var(--blue);
  }
  .menu-toggle svg{width:20px;height:20px}
  .header.is-open .mobile-menu{
    transform:translateY(0); opacity:1; pointer-events:auto;
  }
  .mobile-menu{
    position:fixed; inset:74px 0 auto 0;
    background:#fff; padding:24px var(--gutter) 32px;
    box-shadow:var(--shadow);
    transform:translateY(-12px); opacity:0; pointer-events:none;
    transition:all .3s var(--ease);
    z-index:49; display:grid; gap:.4rem;
  }
  .mobile-menu a{
    font-family:var(--serif); font-weight:600;
    font-size:1.1rem; padding:14px 4px;
    border-bottom:1px solid var(--line); color:var(--ink);
  }
  .mobile-menu .btn{margin-top:14px; justify-content:center}
  .hero{min-height:auto; padding:32px 0 0}
  .hero-wrap{grid-template-columns:1fr; gap:0}
  .hero-stage{
    height:auto; min-height:480px;
    aspect-ratio:1/1.05;
    margin:0 -10px;
  }
  .hero-kid{height:100%; max-height:560px}
  .hero-blob{right:-15%; width:90%}
  .hero-maple{right:-12%; top:14%; width:78%}
  .hero-scribble{width:120px; height:120px; top:30px; left:10px}
  .badge-ideas{left:0; top:24%}
  .badge-450k{left:0; bottom:6%}
  .badge-register{right:0; top:38%; max-width:260px}
  .badge-register .badge-text small{display:none}
  .hero-deco{display:none}
  .contact-strip{font-size:.84rem}
  .contact-strip .row{justify-content:flex-start; gap:6px}
  .cs-item{padding:6px 12px; border-right:0; flex:1 0 100%}
  .cs-item.cs-label{display:none}
  .cs-wa{margin:8px 0 8px auto; flex:0 0 auto}
  .tuition-grid{grid-template-columns:1fr}
  .adm-steps{grid-template-columns:1fr}
  .adm-steps li::after{display:none !important}
  .testimonials-head{flex-direction:column; align-items:flex-start}
  .vision-grid{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr}
  .leader{grid-template-columns:1fr; text-align:left}
  .leader-portrait{margin:0 0 8px}
  .cta-strip{
    grid-template-columns:1fr;
    text-align:left;
  }
  .cta-strip-img{display:none}
  .app-grid{grid-template-columns:1fr; gap:48px}
  .app-phone{max-width:240px}
  .contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr; gap:36px}
  .field-row{grid-template-columns:1fr}
}
@media (min-width: 821px){
  .menu-toggle,.mobile-menu{display:none !important}
}
