/* ============================================================
   LONDON SCHOOL — Sections FINAL
   Clean · Warm · Consistent · Kid-friendly
   Every icon has a soft tinted rounded-square bg.
   Color through tinted cards and icon containers only.
   No blobs. No pseudo-elements. No randomness.
   ============================================================ */

/* ── NAV ── */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:var(--s-4) 0;transition:all var(--dur) var(--ease)}
.nav.scrolled{background:rgba(255,255,255,.96);backdrop-filter:blur(14px);box-shadow:0 1px 12px rgba(0,0,0,.04);padding:var(--s-3) 0}
.nav__inner{display:flex;align-items:center;justify-content:space-between}
.nav__logo{display:flex;align-items:center;gap:var(--s-3)}
.nav__crest{width:42px;height:42px;object-fit:contain;flex-shrink:0}
.nav__name{font-family:var(--font-heading);font-weight:800;font-size:1.1rem;color:var(--navy-dark);line-height:1.15}
.nav__name small{display:block;font-size:.6rem;font-weight:600;color:var(--text-muted);letter-spacing:.03em;margin-top:1px}
.nav__links{display:flex;align-items:center;gap:clamp(var(--s-3),1.6vw,var(--s-6))}
.nav__link{font-family:var(--font-heading);font-size:var(--text-sm);font-weight:700;color:var(--sand-500);transition:color var(--dur-fast)}
.nav__link:hover,.nav__link.active{color:var(--red)}
.nav__right{display:flex;align-items:center;gap:var(--s-3)}
.nav__hamburger{display:none;flex-direction:column;gap:5px;padding:8px}
.nav__hamburger span{width:22px;height:2px;background:var(--text-dark);border-radius:2px;transition:all .3s}
.nav__hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.nav__hamburger.open span:nth-child(2){opacity:0}
.nav__hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.mob-menu{display:none;position:fixed;inset:0;background:rgba(255,255,255,.98);backdrop-filter:blur(20px);z-index:99;flex-direction:column;align-items:center;justify-content:center;gap:var(--s-8)}
.mob-menu.open{display:flex}
.mob-menu a{font-family:var(--font-heading);font-size:var(--text-h3);font-weight:800;color:var(--text-dark)}
.mob-menu a:hover{color:var(--red)}
@media(max-width:1100px){.nav__links{display:none}.nav__right .btn{display:none}.nav__hamburger{display:flex}}

/* ── HERO ── */
.hero{position:relative;padding:calc(76px + var(--s-16)) 0 var(--s-8);overflow:hidden;background:var(--cream)}
.hero__grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-12);align-items:start;min-height:540px}
.hero__text{position:relative;z-index:2}
.hero__badge{display:inline-flex;align-items:center;gap:var(--s-2);padding:7px 16px;background:var(--white);border-radius:var(--r-pill);box-shadow:var(--sh-sm);font-family:var(--font-heading);font-size:var(--text-xs);font-weight:700;color:var(--text-muted);margin-bottom:var(--s-8)}
.hero__badge-dot{width:7px;height:7px;border-radius:50%;background:var(--sage);animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.3)}}
.hero__title{font-size:var(--text-display);margin-bottom:var(--s-5);color:var(--navy-dark);letter-spacing:-.02em}
.hero__title em{font-style:normal;color:var(--red)}
.hero__sub{font-size:var(--text-lg);color:var(--text-muted);line-height:1.8;margin-bottom:var(--s-10);max-width:480px}
.hero__btns{display:flex;gap:var(--s-4);flex-wrap:wrap}
.hero__trust{display:flex;align-items:center;gap:var(--s-3);margin-top:var(--s-10)}
.hero__trust-ico{width:22px;height:22px;color:var(--sage);flex-shrink:0}
.hero__trust-label{font-size:var(--text-sm);color:var(--text-muted)}
.hero__trust-label strong{color:var(--text-dark)}
.hero__visual{position:relative;z-index:1}
.hero__photo{border-radius:var(--r-2xl);overflow:hidden;box-shadow:var(--sh-lg)}
.hero__photo img,.hero__photo video{width:100%;object-fit:cover;object-position:center 60%;aspect-ratio:3/4;display:block}

/* Floating badges — overflow outside photo for dynamic feel */
.hero__float{position:absolute;border-radius:var(--r-pill);padding:9px 18px 9px 12px;box-shadow:var(--sh-md);display:flex;align-items:center;gap:10px;z-index:3;animation:float 6s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
.hero__float--tl{top:8%;left:-5%;animation-delay:0s}
.hero__float--tr{top:16%;right:-6%;animation-delay:-2s}
.hero__float--bl{bottom:22%;left:-7%;animation-delay:-4s}
.hero__float--br{bottom:10%;right:-4%;animation-delay:-1s}
.hero__float-ico{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.hero__float-ico svg{width:18px;height:18px}
/* Sage — Cambridge Pathway */
.hero__float--sage{background:var(--sage);color:var(--white)}
.hero__float--sage .hero__float-ico{background:rgba(255,255,255,.2);color:var(--white)}
.hero__float--sage .hero__float-txt{color:var(--white)}
.hero__float--sage .hero__float-txt small{color:rgba(255,255,255,.75)}
/* Peach — Robotics Lab */
.hero__float--peach{background:var(--peach);color:var(--text-dark)}
.hero__float--peach .hero__float-ico{background:rgba(193,53,61,.12);color:var(--red)}
.hero__float--peach .hero__float-txt{color:var(--text-dark)}
.hero__float--peach .hero__float-txt small{color:var(--text-muted)}
/* Navy — 25+ Sports */
.hero__float--navy{background:var(--navy);color:var(--white)}
.hero__float--navy .hero__float-ico{background:rgba(255,255,255,.15);color:var(--white)}
.hero__float--navy .hero__float-txt{color:var(--white)}
.hero__float--navy .hero__float-txt small{color:rgba(255,255,255,.7)}
/* Red — Ask Prof Mir */
.hero__float--red{background:var(--red);color:var(--white)}
.hero__float--red .hero__float-ico{background:rgba(255,255,255,.2);color:var(--white)}
.hero__float--red .hero__float-txt{color:var(--white)}
.hero__float--red .hero__float-txt small{color:rgba(255,255,255,.75)}
.hero__float-txt{font-family:var(--font-heading);font-size:var(--text-xs);font-weight:700;line-height:1.25}
.hero__float-txt small{display:block;font-weight:500;font-size:.6rem;margin-top:1px}

@media(max-width:900px){
  .hero__grid{grid-template-columns:1fr;text-align:center}
  .hero__sub{margin:0 auto var(--s-10)}
  .hero__btns{justify-content:center}
  .hero__trust{justify-content:center}
  .hero__visual{max-width:380px;margin:var(--s-8) auto 0}
  .hero__photo{border-radius:var(--r-2xl)}
  .hero__photo img,.hero__photo video{aspect-ratio:1}
  .hero__float{display:none}
}

/* ── PROOF BAR ── */
.proof{position:relative}
.proof__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s-5)}
.proof__card{background:var(--white);border-radius:var(--r-2xl);padding:var(--s-8) var(--s-5);text-align:center;box-shadow:var(--sh-md);transition:all var(--dur) var(--ease)}
.proof__card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg)}
.proof__ico{width:48px;height:48px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;margin:0 auto var(--s-4)}
.proof__ico svg{width:24px;height:24px}
.proof__card:nth-child(1) .proof__ico{background:var(--sage-100);color:var(--sage-dark)}
.proof__card:nth-child(2) .proof__ico{background:var(--red-100);color:var(--red)}
.proof__card:nth-child(3) .proof__ico{background:var(--navy-100);color:var(--navy)}
.proof__card:nth-child(4) .proof__ico{background:var(--peach);color:var(--red-dark)}
.proof__num{font-family:var(--font-heading);font-size:var(--text-h1);font-weight:900;line-height:1}
.proof__card:nth-child(1) .proof__num{color:var(--sage-dark)}
.proof__card:nth-child(2) .proof__num{color:var(--red);font-size:clamp(1.5rem, 2.5vw + 0.4rem, 2.2rem);letter-spacing:-0.01em}
.proof__card:nth-child(3) .proof__num{color:var(--navy)}
.proof__card:nth-child(4) .proof__num{color:var(--peach-dark)}
.proof__lbl{font-size:var(--text-sm);color:var(--text-muted);margin-top:var(--s-2);font-weight:500}
@media(max-width:768px){.proof__grid{grid-template-columns:repeat(2,1fr);gap:var(--s-4)}}

/* ── PROGRAMS ── */
.programs{padding:clamp(4.5rem,7vw,7rem) 0}
.prog-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s-6)}

.prog{
  border-radius:var(--r-2xl);
  padding:var(--s-8);
  display:flex;
  flex-direction:column;
  position:relative;
  isolation:isolate;
  overflow:hidden;
  transition:transform .55s cubic-bezier(.2,.8,.2,1), box-shadow .55s ease;
}
.prog:hover{
  transform:translateY(-6px);
  box-shadow:0 24px 48px -16px rgba(47,85,129,.22), 0 8px 16px -6px rgba(47,85,129,.08);
}
.prog--discover{background:var(--red-50)}
.prog--create{background:var(--navy-50)}
.prog--move{background:var(--sage-50)}
.prog--grow{background:var(--peach-50)}

/* Image container — bleeds to card edges; top radius matches card exactly */
.prog__img{
  height:220px;
  border-radius:var(--r-2xl) var(--r-2xl) 0 0;
  overflow:hidden;
  margin:calc(-1 * var(--s-8)) calc(-1 * var(--s-8)) var(--s-6);
  position:relative;
  background:var(--sand-100, #F5F0E8);
}
.prog__photo{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transform:scale(1.01);
  transition:transform .9s cubic-bezier(.2,.8,.2,1), filter .5s ease;
  filter:saturate(.96);
}
.prog:hover .prog__photo{
  transform:scale(1.07);
  filter:saturate(1.08);
}

/* Tint overlay — soft radial brand glow + bottom depth vignette */
.prog__img::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  transition:opacity .4s ease;
}
.prog__img--discover::after{background:radial-gradient(circle at 18% 20%, rgba(193,53,61,.24) 0%, transparent 48%), linear-gradient(180deg, transparent 55%, rgba(0,0,0,.18) 100%)}
.prog__img--create::after  {background:radial-gradient(circle at 18% 20%, rgba(47,85,129,.22) 0%, transparent 48%), linear-gradient(180deg, transparent 55%, rgba(0,0,0,.18) 100%)}
.prog__img--move::after    {background:radial-gradient(circle at 18% 20%, rgba(95,175,134,.24) 0%, transparent 48%), linear-gradient(180deg, transparent 55%, rgba(0,0,0,.18) 100%)}
.prog__img--grow::after    {background:radial-gradient(circle at 18% 20%, rgba(242,213,197,.40) 0%, transparent 48%), linear-gradient(180deg, transparent 55%, rgba(0,0,0,.18) 100%)}

/* Floating category badge (top-right glass pill) */
.prog__badge{
  position:absolute;
  top:16px;
  right:16px;
  z-index:2;
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 12px;
  border-radius:var(--r-pill);
  background:rgba(255,255,255,.92);
  -webkit-backdrop-filter:blur(10px);
  backdrop-filter:blur(10px);
  box-shadow:0 4px 14px rgba(0,0,0,.12);
  font-family:var(--font-heading);
  font-size:11px;
  font-weight:800;
  letter-spacing:.04em;
  text-transform:uppercase;
  transition:transform .4s cubic-bezier(.2,.8,.2,1), box-shadow .4s ease;
}
.prog__badge svg{width:12px;height:12px}
.prog:hover .prog__badge{transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,.18)}
.prog--discover .prog__badge{color:var(--red)}
.prog--create   .prog__badge{color:var(--navy)}
.prog--move     .prog__badge{color:var(--sage-dark)}
.prog--grow     .prog__badge{color:var(--red-dark)}

.prog__ico{display:none}
.prog__ico svg{width:24px;height:24px}

.prog__title{
  font-size:var(--text-h3);
  margin-bottom:var(--s-2);
  transition:color .3s ease;
}
.prog--discover:hover .prog__title{color:var(--red)}
.prog--create:hover   .prog__title{color:var(--navy)}
.prog--move:hover     .prog__title{color:var(--sage-dark)}
.prog--grow:hover     .prog__title{color:var(--red-dark)}

.prog__desc{font-size:var(--text-sm);color:var(--text-muted);line-height:1.7;margin-bottom:var(--s-5)}

.prog__pills{display:flex;flex-wrap:wrap;gap:6px}
.prog__pill{
  padding:5px 13px;
  border-radius:var(--r-pill);
  font-family:var(--font-heading);
  font-size:11px;
  font-weight:700;
  background:rgba(255,255,255,.6);
  transition:background .3s ease, transform .3s ease;
}
.prog:hover .prog__pill{background:rgba(255,255,255,.95)}
.prog--discover .prog__pill{color:var(--red)}
.prog--create .prog__pill{color:var(--navy)}
.prog--move .prog__pill{color:var(--sage-dark)}
.prog--grow .prog__pill{color:var(--red-dark)}

@media(max-width:600px){
  .prog-grid{grid-template-columns:1fr}
  .prog__img{height:180px}
}
@media(prefers-reduced-motion:reduce){
  .prog,.prog__photo,.prog__pill,.prog__title,.prog__badge{transition:none}
  .prog:hover{transform:none}
  .prog:hover .prog__photo{transform:scale(1.01);filter:saturate(.96)}
  .prog:hover .prog__badge{transform:none}
}

/* ── ABOUT ── */
.about{padding:clamp(4.5rem,7vw,7rem) 0;background:var(--cream)}

/* Message from Principal */
.about__msg-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-12);align-items:center}
.about__msg-img{border-radius:var(--r-2xl);overflow:hidden;box-shadow:var(--sh-lg)}
.about__msg-img img{width:100%;aspect-ratio:3/4;object-fit:cover}
.about__quote{font-size:var(--text-lg);color:var(--text-dark);font-style:italic;line-height:1.9;margin:var(--s-6) 0;border-left:4px solid var(--red);padding-left:var(--s-5);opacity:.9}
.about__msg-sign{font-family:var(--font-heading);font-weight:700;color:var(--text-dark);margin-top:var(--s-4)}
.about__msg-sign small{display:block;font-size:var(--text-sm);font-weight:500;color:var(--text-muted);margin-top:var(--s-1)}

/* Core Values */
.about__vals-section{}
.about__vals{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-6)}
.about__val{background:var(--white);padding:var(--s-6);border-radius:var(--r-2xl);box-shadow:var(--sh-sm);transition:all var(--dur) var(--ease)}
.about__val:hover{transform:translateY(-4px);box-shadow:var(--sh-md)}
.about__val-ico{width:54px;height:54px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-bottom:var(--s-4)}
.about__val-ico svg{width:28px;height:28px}
.about__val h4{margin-bottom:var(--s-2);color:var(--text-dark)}
.about__val p{font-size:var(--text-sm);color:var(--text-muted);line-height:1.7}

/* Vision */
.about__vision{background:var(--navy);color:var(--white);padding:var(--s-12);border-radius:var(--r-2xl)}
.about__vision .sec-label i{background:var(--red)}
.about__vision h2{color:var(--white)}
.about__vision .sec-desc{color:rgba(255,255,255,.85)}

/* Founder & Legacy */
.about__founder-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-12);align-items:center}
.about__founder-img{border-radius:var(--r-2xl);overflow:hidden;box-shadow:var(--sh-lg)}
.about__founder-img img{width:100%;aspect-ratio:3/4;object-fit:cover}
.about__founder-text p{font-size:var(--text-sm);color:var(--text-muted);line-height:1.8;margin-bottom:var(--s-4)}

/* What Guides Us */
.about__guides-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-6)}
.about__guide{background:var(--white);padding:var(--s-6);border-radius:var(--r-2xl);box-shadow:var(--sh-sm)}
.about__guide h3{font-size:var(--text-h4);margin-bottom:var(--s-3);color:var(--text-dark)}
.about__guide p{font-size:var(--text-sm);color:var(--text-muted);line-height:1.8}

/* Leadership */
.about__leadership{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s-6)}
.about__leader{background:var(--white);border-radius:var(--r-2xl);overflow:hidden;box-shadow:var(--sh-sm);transition:all var(--dur) var(--ease)}
.about__leader:hover{transform:translateY(-4px);box-shadow:var(--sh-md)}
.about__leader-img{height:220px;overflow:hidden}
.about__leader-img img{width:100%;height:100%;object-fit:cover}
.about__leader-img+h4{padding:var(--s-4) var(--s-4) 0}
.about__leader h4{color:var(--text-dark);margin-bottom:var(--s-1)}
.about__leader-role{font-size:var(--text-xs);color:var(--red);font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:0 var(--s-4);margin-bottom:var(--s-2)}
.about__leader-bio{font-size:var(--text-xs);color:var(--text-muted);line-height:1.6;padding:0 var(--s-4) var(--s-4)}

/* Teachers Grid */
.about__teachers-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:var(--s-5)}
.about__teacher{background:var(--white);border-radius:var(--r-2xl);overflow:hidden;box-shadow:var(--sh-sm);transition:all var(--dur) var(--ease);text-align:center}
.about__teacher:hover{transform:translateY(-4px);box-shadow:var(--sh-md)}
.about__teacher-img{height:180px;overflow:hidden}
.about__teacher-img img{width:100%;height:100%;object-fit:cover}
.about__teacher h4{padding:var(--s-3) var(--s-3) 0;color:var(--text-dark);margin-bottom:var(--s-1)}
.about__teacher p{font-size:var(--text-xs);color:var(--text-muted);padding:0 var(--s-3) var(--s-3)}

@media(max-width:900px){
  .about__msg-grid,.about__founder-grid{grid-template-columns:1fr}
  .about__vals,.about__guides-grid,.about__leadership{grid-template-columns:repeat(2,1fr)}
  .about__teachers-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:600px){
  .about__vals,.about__guides-grid,.about__leadership,.about__teachers-grid{grid-template-columns:1fr}
}

/* ── AI DEMO ── */
.demo{background:var(--cream);padding:clamp(4.5rem,7vw,7rem) 0}
.demo__grid{display:grid;grid-template-columns:5fr 7fr;gap:var(--s-12);align-items:center}
.demo__feats{display:flex;flex-direction:column;gap:var(--s-4);margin-top:var(--s-6)}
.demo__feat{display:flex;align-items:flex-start;gap:var(--s-4);padding:var(--s-4) var(--s-5);background:var(--white);border-radius:var(--r-xl);box-shadow:var(--sh-sm);transition:all var(--dur) var(--ease)}
.demo__feat:hover{transform:translateX(4px);box-shadow:var(--sh-md)}
.demo__feat-ico{width:42px;height:42px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.demo__feat-ico svg{width:20px;height:20px}
.demo__feat:nth-child(1) .demo__feat-ico{background:var(--sage-100);color:var(--sage-dark)}
.demo__feat:nth-child(2) .demo__feat-ico{background:var(--peach);color:var(--red)}
.demo__feat:nth-child(3) .demo__feat-ico{background:var(--navy-100);color:var(--navy)}
.demo__feat strong{display:block;font-family:var(--font-heading);font-size:var(--text-sm);font-weight:700;margin-bottom:2px}
.demo__feat span{font-size:var(--text-xs);color:var(--text-muted);line-height:1.5}

/* Chat */
.chat{background:var(--white);border-radius:var(--r-2xl);box-shadow:var(--sh-lg);overflow:hidden;border:1px solid var(--sand-100)}
.chat__head{display:flex;align-items:center;gap:var(--s-3);padding:var(--s-4) var(--s-5);background:var(--navy);color:white}
.chat__avatar{width:36px;height:36px;border-radius:50%;overflow:hidden;flex-shrink:0;border:2px solid rgba(255,255,255,.3)}
.chat__avatar img{width:100%;height:100%;object-fit:cover}
.chat__head-info strong{display:block;font-family:var(--font-heading);font-size:var(--text-sm)}
.chat__head-info small{font-size:var(--text-xs);opacity:.75}
.chat__body{padding:var(--s-5);min-height:350px;max-height:400px;overflow-y:auto;display:flex;flex-direction:column;gap:var(--s-4)}
.msg{display:flex;gap:var(--s-3);max-width:86%;opacity:0;transform:translateY(10px);transition:all .5s var(--ease)}
.msg.on{opacity:1;transform:none}
.msg--user{align-self:flex-end;flex-direction:row-reverse}
.msg__av{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}
.msg__av svg{width:14px;height:14px}
.msg--ai .msg__av{background:var(--sage-100);color:var(--sage-dark)}
.msg--user .msg__av{background:var(--peach);color:var(--red)}
.msg__bub{padding:var(--s-3) var(--s-4);border-radius:var(--r-xl);font-size:var(--text-sm);line-height:1.65}
.msg--ai .msg__bub{background:var(--sand-50);color:var(--text-body);border-bottom-left-radius:var(--r-sm)}
.msg--user .msg__bub{background:var(--navy);color:white;border-bottom-right-radius:var(--r-sm)}
.chat__foot{display:flex;gap:var(--s-2);padding:var(--s-3) var(--s-4);border-top:1px solid var(--sand-100)}
.chat__foot input{flex:1;border:1px solid var(--sand-200);border-radius:var(--r-pill);padding:var(--s-3) var(--s-4);font:inherit;font-size:var(--text-sm);outline:none;transition:border-color var(--dur-fast)}
.chat__foot input:focus{border-color:var(--sage)}
.chat__foot button{background:var(--red);color:white;border-radius:50%;width:38px;height:38px;display:flex;align-items:center;justify-content:center;transition:background var(--dur-fast)}
.chat__foot button:hover{background:var(--red-dark)}
/* Chat status indicator */
.chat__status{margin-left:auto;display:flex;align-items:center;gap:6px;font-size:var(--text-xs);opacity:.8}
.chat__status-dot{width:8px;height:8px;border-radius:50%;background:#4ade80;animation:pulse 2s ease-in-out infinite}

/* Chat suggestion chips (inside chat) */
.chat__suggestions{display:flex;flex-wrap:wrap;gap:var(--s-2);padding:var(--s-3) var(--s-4);border-top:1px solid var(--sand-100);display:none}
.chat__sug{background:var(--sand-50);border:1px solid var(--sand-200);border-radius:var(--r-pill);padding:6px 14px;font:inherit;font-size:var(--text-xs);color:var(--text-muted);cursor:pointer;transition:all var(--dur-fast)}
.chat__sug:hover{background:var(--sage-100);color:var(--sage-dark);border-color:var(--sage)}

/* Topic chips (left panel) */
.demo__chips{display:flex;flex-wrap:wrap;gap:var(--s-2)}
.demo__chip{background:var(--white);border:1px solid var(--sand-200);border-radius:var(--r-pill);padding:7px 16px;font:inherit;font-size:var(--text-xs);font-weight:600;color:var(--navy);cursor:pointer;transition:all var(--dur-fast);box-shadow:var(--sh-sm)}
.demo__chip:hover{background:var(--navy);color:var(--white);border-color:var(--navy);transform:translateY(-2px);box-shadow:var(--sh-md)}

.chat__foot button svg{width:16px;height:16px}
.chat--large .chat__body{min-height:420px;max-height:500px}
.demo__grid--full{grid-template-columns:5fr 7fr}
@media(max-width:900px){.demo__grid,.demo__grid--full{grid-template-columns:1fr}}

/* ── PROF MIR PAGE ── */
.profmir-hero{padding:calc(76px + var(--s-12)) 0 var(--s-8);background:var(--cream)}
.profmir-hero__inner{display:grid;grid-template-columns:1fr 1.5fr;gap:var(--s-12);align-items:center}
.profmir-hero__img{border-radius:var(--r-2xl);overflow:hidden;box-shadow:var(--sh-lg)}
.profmir-hero__img img{width:100%;aspect-ratio:3/4;object-fit:cover}
.profmir-hero__text h1{font-size:var(--text-display);color:var(--navy-dark);margin-bottom:var(--s-4)}
.profmir-hero__text p{font-size:var(--text-sm);color:var(--text-muted);line-height:1.8;margin-bottom:var(--s-4)}
.profmir-hero__stats{display:flex;gap:var(--s-8);margin-top:var(--s-6)}
.profmir-hero__stat{text-align:center}
.profmir-hero__stat strong{display:block;font-family:var(--font-heading);font-size:var(--text-h3);color:var(--red)}
.profmir-hero__stat span{font-size:var(--text-xs);color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em}

/* Timeline */
.profmir-about{padding:clamp(4.5rem,7vw,7rem) 0;background:var(--white)}
.profmir-timeline{max-width:700px;margin:0 auto;position:relative;padding-left:var(--s-8)}
.profmir-timeline::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--sand-200);border-radius:3px}
.profmir-tl__item{position:relative;margin-bottom:var(--s-8);padding-left:var(--s-6)}
.profmir-tl__item::before{content:'';position:absolute;left:calc(var(--s-8) * -1 + -1.5px);top:6px;width:14px;height:14px;border-radius:50%;background:var(--red);border:3px solid var(--white);box-shadow:0 0 0 2px var(--red)}
.profmir-tl__year{font-family:var(--font-heading);font-weight:800;font-size:var(--text-sm);color:var(--red);margin-bottom:var(--s-1)}
.profmir-tl__content h4{margin-bottom:var(--s-2);color:var(--text-dark)}
.profmir-tl__content p{font-size:var(--text-sm);color:var(--text-muted);line-height:1.7}

/* Quotes grid */
.profmir-quotes{padding:clamp(4.5rem,7vw,7rem) 0;background:var(--cream)}
.profmir-quotes__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-5)}
.profmir-q{background:var(--white);padding:var(--s-6);border-radius:var(--r-2xl);box-shadow:var(--sh-sm);font-style:italic;font-size:var(--text-sm);line-height:1.8;color:var(--text-dark);border-left:4px solid var(--red);margin:0;transition:all var(--dur) var(--ease)}
.profmir-q:hover{transform:translateY(-4px);box-shadow:var(--sh-md)}

@media(max-width:900px){
  .profmir-hero__inner{grid-template-columns:1fr;text-align:center}
  .profmir-hero__img{max-width:300px;margin:0 auto}
  .profmir-hero__stats{justify-content:center}
  .profmir-quotes__grid{grid-template-columns:1fr}
}

/* ── CAMPUS ── */
.campus{padding:clamp(4.5rem,7vw,7rem) 0}
.mosaic{display:grid;grid-template-columns:repeat(6,1fr);grid-template-rows:260px 260px;gap:var(--s-4)}
.tile{border-radius:var(--r-2xl);overflow:hidden;position:relative;cursor:pointer}
.tile:nth-child(1){grid-column:span 3}
.tile:nth-child(2){grid-column:span 3}
.tile:nth-child(3){grid-column:span 2}
.tile:nth-child(4){grid-column:span 2}
.tile:nth-child(5){grid-column:span 2}
.tile img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.tile:hover img{transform:scale(1.04)}
.tile__cap{position:absolute;bottom:0;left:0;right:0;padding:var(--s-5);background:linear-gradient(transparent,rgba(47,85,129,.8));color:white}
.tile__cap strong{font-family:var(--font-heading);font-weight:800;font-size:var(--text-sm);display:block}
.tile__cap small{font-size:var(--text-xs);opacity:.8;margin-top:2px;display:block}
@media(max-width:768px){
  .mosaic{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .tile{height:200px}
  .tile:nth-child(n){grid-column:span 1}
}

/* ── TESTIMONIALS ── */
.testi{padding:clamp(4.5rem,7vw,7rem) 0;background:var(--cream)}
.testi-scroll{display:flex;gap:var(--s-6);overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;padding:var(--s-4) var(--s-2)}
.testi-scroll::-webkit-scrollbar{display:none}
.tcard{flex:0 0 360px;scroll-snap-align:start;background:var(--white);border-radius:var(--r-2xl);padding:var(--s-8);box-shadow:var(--sh-sm);border:1px solid var(--sand-100);transition:all var(--dur) var(--ease)}
.tcard:hover{transform:translateY(-3px);box-shadow:var(--sh-md)}
.tcard__stars{color:var(--peach-dark);font-size:1rem;letter-spacing:2px;margin-bottom:var(--s-4)}
.tcard__txt{font-size:var(--text-sm);color:var(--text-muted);line-height:1.8;margin-bottom:var(--s-6)}
.tcard__who{display:flex;align-items:center;gap:var(--s-3)}
.tcard__av{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-weight:800;font-size:var(--text-sm);color:white}
.tcard__name{font-family:var(--font-heading);font-weight:700;font-size:var(--text-sm)}
.tcard__role{font-size:var(--text-xs);color:var(--text-muted);margin-top:1px}
@media(max-width:600px){.tcard{flex:0 0 calc(100vw - 3rem)}}

/* ── FEES ── */
.fees{padding:clamp(4.5rem,7vw,7rem) 0}
.fee-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-6);align-items:start}
.fee{background:var(--white);border-radius:var(--r-2xl);padding:var(--s-8);text-align:center;box-shadow:var(--sh-sm);border:1px solid var(--sand-100);transition:all var(--dur) var(--ease);position:relative}
.fee:hover{transform:translateY(-3px);box-shadow:var(--sh-md)}
.fee--pop{background:var(--sage-50);border-color:var(--sage-light)}
.fee--pop:hover{border-color:var(--sage)}
.fee__badge{position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:var(--sage);color:white;font-family:var(--font-heading);font-size:11px;font-weight:800;padding:4px 16px;border-radius:var(--r-pill);white-space:nowrap}
.fee__age{font-family:var(--font-heading);font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--s-4)}
.fee__price{font-family:var(--font-heading);font-size:var(--text-h1);font-weight:900;color:var(--text-dark);line-height:1}
.fee__per{font-size:var(--text-sm);color:var(--text-muted);margin-top:var(--s-2)}
.fee__div{height:1px;background:var(--sand-100);margin:var(--s-6) 0}
.fee__list{text-align:left;display:flex;flex-direction:column;gap:var(--s-3);margin-bottom:var(--s-8)}
.fee__li{display:flex;align-items:center;gap:var(--s-3);font-size:var(--text-sm);color:var(--text-body)}
.fee__dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;background:var(--sage)}
.fee--pop .fee__dot{background:var(--sage-dark)}
@media(max-width:768px){.fee-grid{grid-template-columns:1fr;max-width:400px;margin:0 auto}}

/* ── CTA ── */
.cta{padding:clamp(3rem,5vw,5rem) 0}
.cta-card{background:var(--navy);border-radius:var(--r-2xl);padding:clamp(3rem,5vw,4.5rem) clamp(2rem,5vw,4rem);text-align:center;position:relative;overflow:hidden}
.cta-card h2{color:white;font-size:var(--text-h2)}
.cta-card p{color:rgba(255,255,255,.75);max-width:440px;margin:var(--s-4) auto var(--s-8);font-size:var(--text-base);line-height:1.7}
.cta-btns{display:flex;gap:var(--s-4);justify-content:center;flex-wrap:wrap}
/* .cta-orb styles moved to blobs.css */

/* ── CONTACT ── */
.contact{padding:clamp(4.5rem,7vw,7rem) 0;background:var(--cream)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-12);align-items:start}
.ct-card{display:flex;gap:var(--s-4);padding:var(--s-5);background:var(--white);border-radius:var(--r-xl);box-shadow:var(--sh-sm);transition:all var(--dur) var(--ease)}
.ct-card:hover{transform:translateY(-2px);box-shadow:var(--sh-md)}
.ct-card__ico{width:42px;height:42px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ct-card__ico svg{width:20px;height:20px}
.ct-card:nth-child(1) .ct-card__ico{background:var(--sage-100);color:var(--sage-dark)}
.ct-card:nth-child(2) .ct-card__ico{background:var(--peach);color:var(--red)}
.ct-card:nth-child(3) .ct-card__ico{background:var(--navy-100);color:var(--navy)}
.ct-card:nth-child(4) .ct-card__ico{background:var(--red-100);color:var(--red)}
.ct-card h4{font-size:var(--text-sm);margin-bottom:2px}
.ct-card p{font-size:var(--text-sm);color:var(--text-muted);line-height:1.6}
.ct-map{border-radius:var(--r-2xl);overflow:hidden;height:100%;min-height:360px;box-shadow:var(--sh-sm)}
.ct-map iframe{width:100%;height:100%;border:0}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr}}

/* ── FOOTER ── */
.ft{background:var(--navy-dark);color:var(--sand-400);padding:var(--s-16) 0 var(--s-8);position:relative}
.ft__grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:var(--s-10);margin-bottom:var(--s-12)}
.ft__about p{font-size:var(--text-sm);line-height:1.75;margin-top:var(--s-4);max-width:300px}
.ft__socials{display:flex;gap:var(--s-3);margin-top:var(--s-5)}
.ft__socials a{width:36px;height:36px;border-radius:var(--r-md);background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;transition:all var(--dur-fast)}
.ft__socials a svg{width:16px;height:16px;color:var(--sand-400)}
.ft__socials a:hover{background:var(--sage)}
.ft__socials a:hover svg{color:white}
.ft__h{font-family:var(--font-heading);font-size:var(--text-xs);font-weight:800;color:white;text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--s-5)}
.ft__links{display:flex;flex-direction:column;gap:var(--s-3)}
.ft__links a{font-size:var(--text-sm);transition:color var(--dur-fast)}
.ft__links a:hover{color:var(--sage-light)}
.ft__bot{padding-top:var(--s-6);border-top:1px solid rgba(255,255,255,.06);display:flex;justify-content:space-between;font-size:var(--text-xs);color:var(--sand-500)}
@media(max-width:768px){.ft__grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.ft__grid{grid-template-columns:1fr}.ft__bot{flex-direction:column;gap:var(--s-3);text-align:center}}

/* ── WHATSAPP ── */
.wa{position:fixed;bottom:var(--s-6);right:var(--s-6);z-index:90;width:54px;height:54px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px rgba(37,211,102,.3);transition:all var(--dur) var(--ease)}
.wa:hover{transform:scale(1.06);box-shadow:0 6px 20px rgba(37,211,102,.4)}
.wa svg{width:26px;height:26px;color:white}

/* ── CONTACT (inline-styled section, one responsive rule) ── */
@media(max-width:900px){
  .contact-grid{grid-template-columns:1fr !important}
  .contact-info{grid-template-columns:1fr !important}
  .contact-card[style*="grid-column"]{grid-column:auto !important}
}


/* ============================================================
   AI PREVIEW — compact homepage strip linking to pillar page
   Clean, emoji-free, SEO-aware. Full story lives at /ai-robotics.html
   ============================================================ */
.ai-prev {
  padding: clamp(4rem, 6vw, 5.5rem) 0;
  background: var(--white);
  border-top: 1px solid var(--sand-100);
  border-bottom: 1px solid var(--sand-100);
  position: relative;
}
.ai-prev__head {
  text-align: center;
  max-width: 720px;
  margin: 0 auto clamp(2.5rem, 4vw, 3.5rem);
}
.ai-prev__head .sec-label { justify-content: center; margin-bottom: var(--s-3); }
.ai-prev__title {
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  color: var(--navy);
  line-height: 1.15;
  letter-spacing: -0.015em;
  margin-bottom: var(--s-4);
}
.ai-prev__lead {
  font-size: clamp(1rem, 1.3vw, 1.1rem);
  color: var(--text-body);
  line-height: 1.6;
  max-width: 580px;
  margin: 0 auto;
}
.ai-prev__lead strong { color: var(--navy); font-weight: 700; }

/* Journey track — soft wash cards, matches Program Cards pattern */
.ai-prev__track {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--s-4);
  position: relative;
  background: transparent;
  border: none;
  border-radius: 0;
  overflow: visible;
}

/* Each step — soft wash card */
.ai-prev__step {
  padding: clamp(1.5rem, 2.2vw, 1.85rem) clamp(1.15rem, 1.8vw, 1.5rem);
  text-align: left;
  position: relative;
  border-radius: var(--r-2xl);
  background: var(--sand-50);
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.ai-prev__step:hover {
  transform: translateY(-3px);
  box-shadow: var(--sh-sm);
}
.ai-prev__step--peach { background: var(--peach-50); }
.ai-prev__step--sage  { background: var(--sage-50); }
.ai-prev__step--navy  { background: var(--navy-50); }
.ai-prev__step--sand  { background: var(--sand-50); }
.ai-prev__step--featured {
  background: var(--red-50);
}
.ai-prev__step--featured:hover {
  box-shadow: var(--sh-md);
}
.ai-prev__step--featured::before {
  content: 'Unique in Pakistan';
  position: absolute;
  top: 14px;
  right: 14px;
  font-family: var(--font-heading);
  font-size: 0.62rem;
  font-weight: 800;
  color: var(--red);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  background: rgba(255, 255, 255, 0.8);
  padding: 4px 10px;
  border-radius: var(--r-pill);
}

.ai-prev__num {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(1.9rem, 3.2vw, 2.4rem);
  color: var(--navy);
  line-height: 1;
  margin-bottom: var(--s-1);
  letter-spacing: -0.02em;
}
.ai-prev__num span {
  font-size: 0.55em;
  font-weight: 700;
  color: var(--navy-light);
  opacity: 0.75;
}
.ai-prev__step--featured .ai-prev__num { color: var(--red); }
.ai-prev__step--featured .ai-prev__num span { color: var(--red-light); opacity: 0.85; }

.ai-prev__label {
  font-family: var(--font-heading);
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: var(--s-4);
}
.ai-prev__step--featured .ai-prev__label { color: var(--red); }

.ai-prev__step h3 {
  font-size: 0.98rem;
  color: var(--navy);
  line-height: 1.3;
  margin-bottom: var(--s-1);
  font-weight: 800;
}
.ai-prev__step p {
  font-size: 0.82rem;
  color: var(--text-body);
  line-height: 1.55;
  margin: 0;
}

/* CTA row */
.ai-prev__cta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--s-5);
  margin-top: clamp(2rem, 4vw, 3rem);
  flex-wrap: wrap;
}
.ai-prev__cta-link {
  color: var(--navy);
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 0.9rem;
  text-decoration: none;
  border-bottom: 1.5px solid transparent;
  transition: border-color 0.2s;
}
.ai-prev__cta-link:hover { border-bottom-color: var(--navy); }

/* Hide the stale hidden wrapper if it exists */
#ai-journey-old-removed { display: none !important; }

/* Responsive */
@media (max-width: 900px) {
  .ai-prev__track { grid-template-columns: repeat(2, 1fr); }
  .ai-prev__step:last-child { grid-column: 1 / -1; }
}
@media (max-width: 520px) {
  .ai-prev__track { grid-template-columns: 1fr; }
  .ai-prev__step:last-child { grid-column: auto; }
}

/* ─────────────────────────────────────────
   LEADERSHIP — CEO centered, Directors flanking
───────────────────────────────────────── */
.leadership { margin-top: clamp(3rem, 7vw, 5rem); }
.leadership__grid {
  display: grid;
  grid-template-columns: 1fr 1.15fr 1fr;
  gap: clamp(1rem, 3vw, 2rem);
  align-items: end;
  max-width: 1000px;
  margin: 0 auto;
}
.leader-card {
  margin: 0;
  text-align: center;
  background: var(--white);
  border-radius: var(--r-lg);
  padding: var(--s-5) var(--s-4) var(--s-5);
  box-shadow: var(--sh-sm);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.leader-card:hover { transform: translateY(-4px); box-shadow: var(--sh-md); }
.leader-card__img {
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  overflow: hidden;
  margin: 0 auto var(--s-4);
  max-width: 200px;
  background: var(--cream);
}
.leader-card__img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.leader-card figcaption strong {
  display: block;
  font-family: var(--font-heading);
  font-size: clamp(1.05rem, 1.5vw, 1.25rem);
  color: var(--navy);
  margin-bottom: 4px;
}
.leader-card figcaption span {
  display: block;
  font-size: 0.9rem;
  color: var(--gray-600);
  letter-spacing: 0.02em;
}
.leader-card--featured {
  background: var(--peach);
  box-shadow: var(--sh-md);
  padding-top: var(--s-6);
  padding-bottom: var(--s-6);
}
.leader-card--featured .leader-card__img { max-width: 240px; }
.leader-card--featured figcaption strong { font-size: clamp(1.15rem, 1.7vw, 1.4rem); }
.leader-card--featured figcaption span { color: var(--red); font-weight: 700; }

@media (max-width: 720px) {
  .leadership__grid {
    grid-template-columns: 1fr;
    max-width: 360px;
  }
  .leader-card--featured { order: -1; }
  .leader-card__img { max-width: 180px; }
}
