/* ================================================================
   TECHYGUIDE – ORANGE & TEAL THEME  |  Mobile-First
   Orange: #F97316 / #EA6C0B
   Teal:   #0D9488 / #0F766E
   Fonts:  Poppins (all text)
================================================================ */

/* ── RESET ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  /* Palette */
  --orange:      #F97316;
  --orange-d:    #EA6C0B;
  --orange-bg:   rgba(249,115,22,0.08);
  --orange-bg2:  rgba(249,115,22,0.14);
  --teal:        #0D9488;
  --teal-d:      #0F766E;
  --teal-bg:     rgba(13,148,136,0.08);
  --teal-bg2:    rgba(13,148,136,0.14);
  --ink:         #000000;
  --ink-2:       #374151;
  --ink-3:       #6B7280;
  --white:       #FFFFFF;
  --bg:          #F7F5F0;
  --bg-2:        #EDEAE3;
  --border:      #E0DDD5;
  --border-d:    #C8C4BA;
  /* Typography */
  --fd:          'Bricolage Grotesque', sans-serif;
  --fb:           'Instrument Sans', sans-serif;
  /* Tokens */
  --r:           16px;
  --r-sm:        10px;
  --r-lg:        24px;
  --sh:          0 4px 24px rgba(17,24,39,0.08);
  --sh-lg:       0 12px 48px rgba(17,24,39,0.12);
  --t:           0.28s;
  --ease:        cubic-bezier(.4,0,.2,1);
}

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body { font-family: var(--fb); background: var(--bg); color: var(--ink); overflow-x: hidden; line-height: 1.65; -webkit-font-smoothing: antialiased; }
img  { max-width: 100%; display: block; }

/* ── CONTAINERS ── */
.container  { width: 100%; max-width: 1160px; margin: 0 auto; padding: 0 20px; }
.section    { padding: 72px 0; }
.bg-white   { background: var(--white); }
.bg-offwhite{ background: var(--bg); }

/* ── TYPOGRAPHY ── */
.section-label {
  display: inline-flex; align-items: center; gap: 7px;
  font-family: var(--fb); font-size: 11px; font-weight: 700;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--orange); margin-bottom: 14px;
}
.section-label::before { content:''; width:16px; height:2px; background:var(--orange); border-radius:2px; display:block; }
.section-title {
  font-family: var(--fd); font-size: clamp(1.9rem, 5vw, 3rem);
  font-weight: 900; line-height: 1.1; letter-spacing: -.02em; color: var(--ink);
  margin-bottom: 16px;
}
.section-title em { font-style: italic; }
.grad {
  /* gradient removed – use solid teal color */
  color: var(--teal);
  background: none;
}

/* ── SCROLL REVEAL ── */
.reveal { opacity:0; transform:translateY(24px); transition: opacity .6s var(--ease), transform .6s var(--ease); }
.reveal.visible { opacity:1; transform:none; }
.d1{transition-delay:.08s} .d2{transition-delay:.16s} .d3{transition-delay:.24s} .d4{transition-delay:.34s}

/* ── BUTTONS ── */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 7px;
  font-family: var(--fb); font-weight: 700; font-size: .875rem;
  letter-spacing: .01em; text-decoration: none;
  border: 2px solid transparent; border-radius: 100px;
  cursor: pointer; transition: all var(--t) var(--ease);
  padding: 11px 24px; white-space: nowrap; line-height: 1;
  -webkit-tap-highlight-color: transparent;
}
.btn-primary  { background:var(--orange); color:var(--white); border-color:var(--orange); box-shadow:0 4px 14px rgba(249,115,22,.3); }
.btn-primary:hover, .btn-primary:focus { background:var(--orange-d); border-color:var(--orange-d); transform:translateY(-2px); box-shadow:0 6px 20px rgba(249,115,22,.4); }
.btn-ghost    { background:transparent; color:var(--ink-2); border-color:var(--border-d); }
.btn-ghost:hover { background:var(--bg-2); border-color:var(--ink-3); }
.btn-outline  { background:transparent; color:var(--orange); border-color:var(--orange); }
.btn-outline:hover { background:var(--orange-bg); }
.btn-white-filled { background:var(--white); color:var(--orange); border-color:var(--white); font-weight:800; }
.btn-white-filled:hover { background:var(--bg-2); transform:translateY(-2px); box-shadow:0 6px 20px rgba(0,0,0,.12); }
.btn-outline-white { background:transparent; color:var(--white); border-color:rgba(255,255,255,.5); }
.btn-outline-white:hover { border-color:var(--white); background:rgba(255,255,255,.1); }
.btn-submit   { width:100%; background:var(--orange); color:var(--white); border:none; padding:15px; font-family:var(--fb); font-size:1rem; font-weight:700; border-radius:var(--r-sm); cursor:pointer; transition:all var(--t) var(--ease); }
.btn-submit:hover { background:var(--orange-d); transform:translateY(-2px); box-shadow:0 6px 20px rgba(249,115,22,.35); }
.btn-lg  { padding:14px 32px; font-size:.95rem; }
.btn-sm  { padding:9px 18px; font-size:.8rem; }
@keyframes pulse-o { 0%,100%{box-shadow:0 4px 14px rgba(249,115,22,.3)} 50%{box-shadow:0 4px 24px rgba(249,115,22,.55),0 0 0 8px rgba(249,115,22,.08)} }
.pulse { animation: pulse-o 2.2s infinite; }

/* ================================================================
   NAVBAR
================================================================ */
.navbar {
  position: fixed; top:0; left:0; right:0; z-index:1000;
  background: rgba(255,255,255,.92); backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  border-bottom: 1px solid transparent;
  transition: border-color var(--t), box-shadow var(--t), padding var(--t);
  padding: 14px 0;
}
.navbar.scrolled { border-color:var(--border); box-shadow:var(--sh); padding:10px 0; }
.nav-wrap { max-width:1160px; margin:0 auto; padding:0 20px; display:flex; align-items:center; gap:24px; }
.nav-logo { display:flex; align-items:center; gap:9px; text-decoration:none; flex-shrink:0; }
.nav-logo img { height:40px; width:auto; }
.logo-chip { width:34px; height:34px; background:var(--orange); color:var(--white); border-radius:9px; font-family:var(--fd); font-weight:900; font-size:.82rem; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.nav-logo span { font-family:var(--fd); font-size:1.15rem; font-weight:900; color:var(--ink); letter-spacing:-.02em; }
.nav-center { display:none; }
.nav-end { display:none; }
.nav-tel { font-size:.82rem; color:var(--ink-3); text-decoration:none; transition:color var(--t); white-space:nowrap; }
.nav-tel:hover { color:var(--ink); }
.ham { display:flex; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:6px; margin-left:auto; flex-shrink:0; -webkit-tap-highlight-color:transparent; }
.ham span { display:block; width:22px; height:2px; background:var(--ink); border-radius:2px; transition:var(--t); }

/* Mobile drawer */
.mobile-drawer {
  display:none; flex-direction:column; gap:4px;
  padding:16px 20px 20px; border-top:1px solid var(--border);
  background:var(--white);
}
.mobile-drawer.open { display:flex; }
.mdlink { font-family:var(--fb); font-size:1rem; font-weight:600; color:var(--ink-2); text-decoration:none; padding:11px 0; border-bottom:1px solid var(--border); transition:color var(--t); }
.mdlink:hover { color:var(--orange); }
.mdlink-tel { color:var(--teal); font-weight:700; border-bottom:none; }
.md-sep { height:8px; }
.mobile-drawer .btn { width:100%; margin-top:4px; justify-content:center; }

@media(min-width:768px) {
  .ham { display:none; }
  .mobile-drawer { display:none !important; }
  .nav-center { display:flex; align-items:center; gap:28px; margin-left:auto; }
  .nav-center a { font-family:var(--fb); font-size:.875rem; font-weight:500; color:var(--ink-3); text-decoration:none; transition:color var(--t); }
  .nav-center a:hover { color:var(--ink); }
  .nav-end { display:flex; align-items:center; gap:14px; flex-shrink:0; }
}

/* ================================================================
   HERO
================================================================ */
.hero {
  padding-top: 72px; /* nav height */
  min-height: auto; display:flex; flex-direction:column; justify-content:center;
  position:relative; overflow:hidden; background:var(--white);
}
@media(min-width:900px) {
  .hero { min-height:100svh; }
}
.hero-bg { display:none; }

.hero-inner {
  position:relative; z-index:2;
  display:grid; grid-template-columns:1fr; gap:40px; align-items:center;
  padding:24px 20px 40px;
}

/* Hero inline form */
.hero-form-wrap {
  display:block; width:100%; margin-top:32px;
}
.hero-form-wrap .lead-form-box {
  width:100%; box-shadow:var(--sh-lg);
}
@media(min-width:900px) {
  .hero-form-wrap {
    display:flex; align-items:center; justify-content:center; margin-top:0;
  }
  .hero-form-wrap .lead-form-box {
    max-width:480px;
  }
}
.eyebrow { display:inline-flex; align-items:center; gap:8px; font-size:.78rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--teal); margin-bottom:16px; }
.ey-dot { width:8px; height:8px; background:var(--orange); border-radius:50%; animation:blink 1.8s ease-in-out infinite; flex-shrink:0; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.25} }

.hero-h1 {
  font-family:var(--fd); font-size:clamp(2.2rem,6vw,3.8rem);
  font-weight:900; line-height:1.0; letter-spacing:-.03em; color:var(--ink); margin-bottom:20px;
}
.hero-h1 em { font-style:italic; color:var(--orange); -webkit-text-fill-color:var(--orange); }
.hero-p { font-size:.975rem; color:var(--ink-3); line-height:1.7; margin-bottom:28px; letter-spacing:0.02em; }
.hero-p strong { color:var(--ink); }
.hero-btns { display:flex; flex-wrap:wrap; gap:12px; margin-bottom:28px; }
.trust-row { display:flex; flex-wrap:wrap; gap:8px; }
.trust-pill { font-size:.78rem; font-weight:700; padding:6px 12px; background:var(--orange-bg); color:var(--orange-d); border:1px solid rgba(249,115,22,.2); border-radius:100px; white-space:nowrap; }

/* Hero floating image */
.hero-img-wrap { display:none; }

/* Hero cards — only shown on desktop */
.hero-cards { display:none; }

/* Floating bg animation keyframes */
@keyframes float-y    { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-14px)} }

@media(min-width:900px) {
  .hero-inner { grid-template-columns:1fr 1fr; gap:60px; padding:60px 28px 80px; }

  .hero-img-wrap {
    display:flex; align-items:center; justify-content:center;
    position:relative; padding:40px;
  }

  .hero-float-img {
    position:relative; z-index:2;
    width:100%; max-width:460px; border-radius:24px;
    box-shadow:0 24px 64px rgba(17,24,39,0.18);
    object-fit:cover; aspect-ratio:4/3;
  }

  .hero-cards {
    display:flex; flex-direction:column; gap:12px;
  }
  .hcard {
    background:var(--white); border:1px solid var(--border); border-radius:var(--r);
    box-shadow:var(--sh); padding:16px 18px;
  }
  .hcard-main { display:flex; align-items:center; gap:12px; }
  .hcard-icon { font-size:1.8rem; flex-shrink:0; }
  .hcard-main div { flex:1; }
  .hcard-main strong { display:block; font-family:var(--fd); font-size:.95rem; font-weight:800; }
  .hcard-main small { font-size:.75rem; color:var(--ink-3); }
  .hcard-live { background:rgba(13,148,136,.1); color:var(--teal); font-size:.72rem; font-weight:700; padding:4px 10px; border-radius:100px; white-space:nowrap; }
  .hcard-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
  .hcard-stat { text-align:center; padding:18px; }
  .hcard-teal { border-color:rgba(13,148,136,.2); background:var(--teal-bg); }
  .hs-num { font-family:var(--fd); font-size:1.8rem; font-weight:900; color:var(--orange); line-height:1; }
  .hcard-teal .hs-num { color:var(--teal); }
  .hs-lbl { font-size:.72rem; color:var(--ink-3); margin-top:3px; }
  .hcard-gem { display:flex; align-items:center; gap:10px; background:var(--bg); }
  .gem-stars { color:#F59E0B; font-size:.9rem; letter-spacing:2px; }
  .hcard-gem span:last-child { font-size:.75rem; color:var(--ink-3); }
  .hcard-students { display:flex; align-items:center; gap:12px; font-size:.78rem; color:var(--ink-3); font-weight:500; }
  .stud-avs { display:flex; }
  .sav { width:28px; height:28px; border-radius:50%; border:2px solid var(--white); color:var(--white); font-size:.68rem; font-weight:800; display:flex; align-items:center; justify-content:center; margin-left:-7px; font-family:var(--fd); }
  .sav:first-child { margin-left:0; }
}



/* ================================================================
   HERO — MINIMAL (animations removed for performance)
================================================================ */
.hero-anim-fade  { opacity:1; }
.hero-anim-slide { opacity:1; }
.hero-delay-1, .hero-delay-2, .hero-delay-3 {}
.hero-glitch {
  position:relative; display:inline-block;
  color:var(--orange); -webkit-text-fill-color:var(--orange);
  animation:glitch-color 3s ease-in-out infinite;
}
.hero-glitch::before,
.hero-glitch::after {
  content:attr(data-text); position:absolute; top:0; left:0;
  font-style:italic; overflow:hidden; clip-path:inset(0 0 100% 0);
}
.hero-glitch::before {
  color:var(--teal); -webkit-text-fill-color:var(--teal);
  animation:glitch-top 6s ease-in-out infinite; text-shadow:2px 0 var(--teal);
}
.hero-glitch::after {
  color:var(--orange-d); -webkit-text-fill-color:var(--orange-d);
  animation:glitch-bot 6s ease-in-out infinite; text-shadow:-2px 0 var(--orange-d);
}
@keyframes glitch-color {
  0%,90%,100% { text-shadow:none; }
  92% { text-shadow: 3px 0 var(--teal), -3px 0 var(--orange-d); }
  94% { text-shadow:-3px 0 var(--teal),  3px 0 var(--orange-d); }
  96% { text-shadow: 3px 0 var(--teal), -3px 0 var(--orange-d); }
}
@keyframes glitch-top {
  0%,89%,100% { clip-path:inset(0 0 100% 0); transform:none; }
  90% { clip-path:inset(0 0 60% 0);   transform:translate(-3px,-2px); }
  92% { clip-path:inset(20% 0 40% 0); transform:translate(3px,0); }
  94% { clip-path:inset(0 0 80% 0);   transform:translate(-2px,1px); }
  96% { clip-path:inset(0 0 100% 0);  transform:none; }
}
@keyframes glitch-bot {
  0%,89%,100% { clip-path:inset(100% 0 0 0); transform:none; }
  90% { clip-path:inset(60% 0 0 0);   transform:translate(3px,2px); }
  92% { clip-path:inset(40% 0 20% 0); transform:translate(-3px,0); }
  94% { clip-path:inset(80% 0 0 0);   transform:translate(2px,-1px); }
  96% { clip-path:inset(100% 0 0 0);  transform:none; }
}
.htag {
  position:absolute; font-family:var(--fd); font-size:.72rem; font-weight:800;
  padding:5px 13px; border-radius:100px; color:var(--white); pointer-events:none; z-index:4;
}
.htag-1 { background:var(--orange); top:8%;  right:4%; }
.htag-2 { background:var(--teal);   bottom:18%; left:2%; }
.htag-3 { background:#7C3AED;       top:55%; right:2%; }
.htag-4 { background:#0891B2;       bottom:6%; right:14%; }
#heroFloatImg { transition:box-shadow var(--t); }

/* ================================================================
   MARQUEE
================================================================ */
.marquee-bar { background:var(--ink); overflow:hidden; padding:13px 0; }
.mq-track { display:inline-flex; gap:28px; white-space:nowrap; animation:mq 28s linear infinite; will-change:transform; }
.mq-track span { font-family:var(--fd); font-size:.85rem; font-weight:700; color:rgb(0, 200, 200); }
.mq-track em { color:var(--orange); font-style:normal; font-size:.7rem; }
@keyframes mq { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ================================================================
   PILLARS
================================================================ */
.two-col-header { display:grid; grid-template-columns:1fr; gap:16px; margin-bottom:48px; }
.header-desc { font-size:1rem; color:var(--ink-3); line-height:1.75; }

.pillars { display:flex; flex-direction:column; gap:2px; border:1px solid var(--border); border-radius:var(--r-lg); overflow:hidden; }
.pillar { padding:36px 28px; background:var(--white); border-bottom:1px solid var(--border); transition:background var(--t); }
.pillar:last-child { border-bottom:none; }
.pillar:hover { background:var(--bg); }
.pillar-hi { background:var(--white); }
.pillar-hi:hover { background:rgba(255,255,255,.2); }
.pillar-hi h3, .pillar-hi p { color:black; }
.pillar-n { font-family:var(--fd); font-size:3rem; font-weight:900; color:var(--ink-3); line-height:1; margin-bottom:-6px; }
.pillar-hi .pillar-n { color:var(--ink-3); }
.pillar-em { font-size:1.8rem; margin-bottom:10px; }
.pillar h3 { font-family:var(--fd); font-size:1.25rem; font-weight:900; margin-bottom:8px; }
.pillar p  { font-size:.9rem; color:var(--ink-3); line-height:1.7; }

@media(min-width:768px) {
  .two-col-header { grid-template-columns:1fr 1fr; gap:48px; align-items:center; }
  .pillars { flex-direction:row; }
  .pillar { border-bottom:none; border-right:1px solid var(--border); flex:1; }
  .pillar:last-child { border-right:none; }
  .pillar-hi { border-color:var(--orange-d); }
  .pillar-n { font-size:3.5rem; }
}

/* ================================================================
   PRODUCTS (CARDS)
================================================================ */
.prod-hdr {
  display:flex; flex-direction:column; gap:12px; margin-bottom:40px;
}
@media(min-width:640px) {
  .prod-hdr { flex-direction:row; align-items:flex-end; justify-content:space-between; }
}

.prod-grid {
  display:grid;
  grid-template-columns:1fr;
  gap:24px;
  margin-bottom:32px;
}
@media(min-width:600px)  { .prod-grid { grid-template-columns:1fr 1fr; } }
@media(min-width:1000px) { .prod-grid { grid-template-columns:repeat(4,1fr); } }

/* Card */
.pcard {
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transition:box-shadow var(--t), transform var(--t);
}
.pcard:hover { box-shadow:var(--sh-lg); transform:translateY(-5px); }

/* Image area */
.pcard-img {
  position:relative;
  width:100%; height:200px;
  overflow:hidden; flex-shrink:0;
  background:var(--bg-2);
}
.pcard-img img {
  width:100%; height:100%; object-fit:cover;
  transition:transform .5s var(--ease);
}
.pcard:hover .pcard-img img { transform:scale(1.07); }

/* Badge */
.pcard-badge {
  position:absolute; top:12px; left:12px;
  font-size:.65rem; font-weight:800; letter-spacing:.08em; text-transform:uppercase;
  padding:4px 11px; border-radius:100px;
  background:var(--orange); color:var(--white);
  box-shadow:0 2px 8px rgba(249,115,22,.35);
}
.pcard-badge-teal   { background:var(--teal);   box-shadow:0 2px 8px rgba(13,148,136,.35); }
.pcard-badge-purple { background:#7C3AED;        box-shadow:0 2px 8px rgba(124,58,237,.35); }

/* Body */
.pcard-body {
  padding:20px 22px 24px;
  display:flex; flex-direction:column; flex:1;
}
.pcard-icon { font-size:1.8rem; margin-bottom:10px; }
.pcard-body h3 {
  font-family:var(--fd); font-size:1.05rem; font-weight:900;
  color:var(--ink); margin-bottom:8px;
}
.pcard-body p {
  font-size:.82rem; color:var(--ink-3); line-height:1.65;
  margin-bottom:14px; flex:1;
}
.pcard-ul {
  list-style:none; display:flex; flex-direction:column;
  gap:5px; margin-bottom:18px;
}
.pcard-ul li {
  font-size:.78rem; color:var(--ink-3);
  padding-left:16px; position:relative;
}
.pcard-ul li::before {
  content:'✓'; position:absolute; left:0;
  color:var(--teal); font-weight:800; font-size:.72rem;
}
.pcard-btn {
  display:inline-flex; align-items:center;
  font-family:var(--fd); font-size:.82rem; font-weight:800;
  color:var(--orange); text-decoration:none;
  gap:4px; transition:gap var(--t), color var(--t);
  margin-top:auto;
}
.pcard-btn:hover { color:var(--orange-d); gap:8px; }

/* Bottom CTA banner */
.prod-cta {
  display:flex; flex-direction:column; gap:16px;
  align-items:flex-start;
  background:var(--ink); border-radius:var(--r-lg);
  padding:28px 32px;
}
.prod-cta-left {
  display:flex; align-items:center; gap:20px;
}
.prod-cta-num {
  font-family:var(--fd); font-size:3rem; font-weight:900;
  color:var(--orange); line-height:1; flex-shrink:0;
}
.prod-cta-left strong {
  display:block; font-family:var(--fd); font-size:1rem;
  font-weight:800; color:var(--white); margin-bottom:3px;
}
.prod-cta-left span { font-size:.8rem; color:rgba(255,255,255,.5); }
@media(min-width:640px) {
  .prod-cta { flex-direction:row; align-items:center; justify-content:space-between; }
}

/* ================================================================
   SCHOOLS
================================================================ */
.schools-grid { display:grid; grid-template-columns:1fr; gap:20px; margin-top:40px; }
.school-feat {
  background:var(--teal); border-radius:var(--r-lg); padding:36px 28px;
  color:var(--white); position:relative; overflow:hidden;
  display:flex; flex-direction:column;
}
.sf-img {
  width:100%; margin-bottom:20px; border-radius:var(--r);
  object-fit:cover; height:180px; flex-shrink:0;
}
.schools-images {
  display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-bottom:32px;
}
.schools-images img {
  width:100%; height:180px; object-fit:cover; border-radius:var(--r);
}
@media(max-width:640px) {
  .schools-images { grid-template-columns:1fr; }
}
.school-feat::after { content:''; position:absolute; width:220px; height:220px; border-radius:50%; background:rgba(13,148,136,.05); top:-60px; right:-50px; pointer-events:none; }
.sf-tag { display:inline-block; background:rgba(255,255,255,.2); color:var(--white); font-size:.68rem; font-weight:800; letter-spacing:.1em; text-transform:uppercase; padding:4px 12px; border-radius:100px; margin-bottom:14px; }
.sf-em { font-size:2.2rem; margin-bottom:12px; display:block; }
.school-feat h3 { font-family:var(--fd); font-size:1.5rem; font-weight:900; margin-bottom:10px; }
.school-feat p  { color:rgba(255,255,255,.8); font-size:.92rem; line-height:1.7; margin-bottom:20px; }
.sf-list { list-style:none; display:flex; flex-direction:column; gap:8px; margin-bottom:26px; }
.sf-list li { font-size:.87rem; color:rgba(255,255,255,.85); padding-left:18px; position:relative; }
.sf-list li::before { content:'✓'; position:absolute; left:0; color:rgba(255,255,255,.6); font-weight:800; }

.school-minis { display:flex; flex-direction:column; gap:14px; }
.smini { background:var(--white); border:1px solid var(--border); border-radius:var(--r); padding:20px; display:flex; gap:14px; align-items:flex-start; transition:border-color var(--t), box-shadow var(--t); flex:1; }
.smini:hover { border-color:rgba(249,115,22,.3); box-shadow:var(--sh); }
.smini-em { font-size:1.6rem; flex-shrink:0; }
.smini h4 { font-family:var(--fd); font-size:.95rem; font-weight:800; margin-bottom:5px; }
.smini p  { font-size:.82rem; color:var(--ink-3); line-height:1.6; margin-bottom:8px; }
.tlink { font-size:.8rem; font-weight:700; color:var(--teal); text-decoration:none; transition:color var(--t); }
.tlink:hover { color:var(--teal-d); text-decoration:underline; }

@media(min-width:900px) {
  .schools-grid { grid-template-columns:1fr 1fr; align-items:stretch; }
  .school-feat, .school-minis { height:100%; }
  .school-minis { justify-content:space-between; gap:0; }
  .smini { flex:1; align-items:stretch; margin-bottom:14px; }
  .smini:last-child { margin-bottom:0; }
}

/* ================================================================
   STATS BAND
================================================================ */
.stats-band { background:var(--ink); padding:36px 0; }
.stats-inner { display:flex; flex-wrap:nowrap; justify-content:space-between; align-items:center; overflow-x:auto; }
.sb-item { text-align:center; flex:1; min-width:0; padding:0 12px; }
.sb-num { font-family:var(--fd); font-size:clamp(1.2rem,3vw,3.2rem); font-weight:900; color:var(--white); display:inline; line-height:1; }
.sb-suf { font-family:var(--fd); font-size:clamp(.9rem,2.2vw,2rem); font-weight:900; color:var(--teal); display:inline; }
.sb-lbl { font-size:clamp(.6rem,1.1vw,.8rem); color:orange; margin-top:6px; white-space:nowrap; }
.sb-div { display:block; width:1px; height:40px; background:rgba(255,255,255,.12); flex-shrink:0; }
@media (max-width:768px) { .stats-band { padding:24px 0; } .sb-item { padding:0 4px; } }

/* ================================================================
   COURSES
================================================================ */
.courses-hdr { margin-bottom:36px; }
.courses-hdr p { font-size:.97rem; color:var(--ink-3); max-width:480px; margin-top:-4px; }

.course-grid {
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:24px;
  margin-bottom:36px;
}
@media(max-width:900px) { .course-grid { grid-template-columns: repeat(2,1fr); } }
@media(max-width:560px) { .course-grid { grid-template-columns: 1fr; } }

.ccard {
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--r);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transition:box-shadow var(--t), transform var(--t);
}
.ccard:hover { box-shadow:var(--sh-lg); transform:translateY(-4px); }

.ccard-img {
  position:relative;
  width:100%;
  height:180px;
  overflow:hidden;
  background:var(--bg-2);
  flex-shrink:0;
}
.ccard-img img {
  width:100%; height:100%; object-fit:cover; display:block;
  transition:transform .4s var(--ease);
}
.ccard:hover .ccard-img img { transform:scale(1.06); }

.ccard-num {
  position:absolute; top:12px; left:12px;
  background:var(--orange); color:var(--white);
  font-family:var(--fd); font-size:.68rem; font-weight:900;
  padding:3px 10px; border-radius:100px; letter-spacing:.06em;
}

.ccard-body {
  padding:20px;
  display:flex;
  flex-direction:column;
  gap:10px;
  flex:1;
}
.ccard-body h4 { font-family:var(--fd); font-size:1rem; font-weight:800; color:var(--ink); margin:0; }
.ccard-body p  { font-size:.82rem; color:var(--ink-3); line-height:1.6; flex:1; margin:0; }

.ccard-age {
  font-size:.72rem; font-weight:700; color:var(--teal);
  background:var(--teal-bg); padding:4px 10px;
  border-radius:100px; white-space:nowrap; align-self:flex-start;
}

.ccard-btn {
  display:inline-flex; align-items:center; justify-content:center;
  font-family:var(--fd); font-size:.82rem; font-weight:800;
  color:var(--white); background:var(--orange);
  padding:10px 20px; border-radius:100px;
  text-decoration:none; align-self:flex-start; margin-top:4px;
  transition:background var(--t), transform var(--t);
}
.ccard-btn:hover { background:var(--orange-d); transform:translateY(-1px); }

.courses-cta { text-align:center; }

/* ================================================================
   WHY US
================================================================ */
.why-layout { display:grid; grid-template-columns:1fr; gap:40px; }
.why-p { font-size:.97rem; color:var(--ink-3); line-height:1.7; margin-bottom:24px; }
.why-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.wc { background:var(--bg); border:1px solid var(--border); border-radius:var(--r-sm); padding:20px; transition:border-color var(--t), box-shadow var(--t); }
.wc:hover { border-color:rgba(249,115,22,.3); box-shadow:var(--sh); }
.wc-hi { background:var(--teal-bg); border-color:rgba(13,148,136,.2); }
.wc-i { font-size:1.5rem; margin-bottom:8px; }
.wc h4 { font-family:var(--fd); font-size:.9rem; font-weight:800; margin-bottom:5px; }
.wc p  { font-size:.8rem; color:var(--ink-3); line-height:1.6; }

@media(min-width:900px) {
  .why-layout { grid-template-columns:1fr 1.5fr; gap:72px; align-items:center; }
  .why-left { align-self:center; }
}

/* ================================================================
   TESTIMONIALS — infinite marquee
================================================================ */
.testi-hdr { margin-bottom:40px; }

.tmc-outer {
  overflow:hidden;
  /* fade edges */
  -webkit-mask-image:linear-gradient(to right, transparent 0%, black 8%, black 92%, transparent 100%);
  mask-image:linear-gradient(to right, transparent 0%, black 8%, black 92%, transparent 100%);
}

.tmc-track {
  display:flex;
  gap:16px;
  width:max-content;
}

.tmc-left  { animation: tmc-scroll-left  38s linear infinite; will-change:transform; }
.tmc-right { animation: tmc-scroll-right 42s linear infinite; will-change:transform; }

.tmc-track:hover { animation-play-state:paused; }

@keyframes tmc-scroll-left  { from{transform:translateX(0)} to{transform:translateX(-50%)} }
@keyframes tmc-scroll-right { from{transform:translateX(-50%)} to{transform:translateX(0)} }

.tmc {
  flex-shrink:0;
  width:300px;
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--r);
  padding:20px;
  transition:box-shadow var(--t), transform var(--t);
}
.tmc:hover { box-shadow:var(--sh); transform:translateY(-3px); }

.tmc-stars { color:#F59E0B; font-size:.8rem; letter-spacing:2px; margin-bottom:10px; }
.tmc p {
  font-size:.82rem; color:var(--ink-3); line-height:1.65;
  margin-bottom:16px; font-style:italic;
  display:-webkit-box; -webkit-line-clamp:4; -webkit-box-orient:vertical; overflow:hidden;
}
.tmc-auth { display:flex; align-items:center; gap:10px; }
.tmc-av {
  width:34px; height:34px; border-radius:50%;
  color:var(--white); font-size:.68rem; font-weight:800;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0; font-family:var(--fd);
}
.tmc-auth strong { display:block; font-size:.8rem; font-weight:700; color:var(--ink); }
.tmc-auth span   { font-size:.72rem; color:var(--ink-3); }

@media(min-width:768px) { .tmc { width:340px; } }

/* ================================================================
   LEAD FORM
================================================================ */
.lead-layout { display:grid; grid-template-columns:1fr; gap:40px; }
.lead-title { font-family:var(--fd); font-size:clamp(1.8rem,5vw,2.8rem); font-weight:900; line-height:1.1; letter-spacing:-.02em; margin-bottom:12px; }
.lead-title em { font-style:italic; color:var(--orange); }
.lead-sub { font-size:.95rem; color:var(--ink-3); line-height:1.7; margin-bottom:24px; }
.lead-perks { display:flex; flex-direction:column; gap:10px; margin-bottom:24px; }
.lp { display:flex; align-items:flex-start; gap:10px; font-size:.88rem; color:var(--ink-2); }
.lp-ck { width:20px; height:20px; background:var(--teal-bg); color:var(--teal); border-radius:50%; font-size:.65rem; font-weight:800; display:flex; align-items:center; justify-content:center; flex-shrink:0; margin-top:1px; }
.lead-contacts { display:flex; flex-direction:column; gap:8px; }
.contact-chip { font-size:.88rem; color:var(--teal); font-weight:700; text-decoration:none; transition:color var(--t); }
.contact-chip:hover { color:var(--teal-d); }

.lead-form-box { background:var(--bg); border:1px solid var(--border); border-radius:var(--r-lg); padding:28px; }
.lfb-top { margin-bottom:20px; }
.lfb-top h3 { font-family:var(--fd); font-size:1.25rem; font-weight:900; margin-bottom:3px; }
.lfb-top p  { font-size:.8rem; color:var(--ink-3); }
.frow { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.fg { display:flex; flex-direction:column; gap:5px; margin-bottom:12px; }
.fg label { font-size:.76rem; font-weight:700; color:var(--ink-3); letter-spacing:.04em; }
.fg input, .fg select, .fg textarea {
  background:var(--white); border:1.5px solid var(--border); border-radius:8px;
  color:var(--ink); font-family:var(--fb); font-size:.9rem;
  padding:11px 13px; outline:none;
  transition:border-color var(--t), box-shadow var(--t); resize:vertical;
  -webkit-appearance:none;
}
.fg input::placeholder, .fg textarea::placeholder { color:#9CA3AF; }
.fg select option { background:var(--white); }
.fg input:focus, .fg select:focus, .fg textarea:focus { border-color:var(--orange); box-shadow:0 0 0 3px rgba(249,115,22,.12); }
.fg input.err, .fg select.err { border-color:#EF4444; }
.ferr { font-size:.72rem; color:#EF4444; min-height:14px; }
.form-note { text-align:center; font-size:.73rem; color:var(--ink-3); margin-top:10px; }
.form-success { text-align:center; padding:24px 16px; }
.form-success h4 { font-family:var(--fd); font-size:1.2rem; font-weight:900; margin-bottom:6px; }
.form-success p { font-size:.88rem; color:var(--ink-3); }

@media(min-width:900px) {
  .lead-layout { grid-template-columns:1fr 1.1fr; gap:72px; align-items:center; }
  .lead-left { align-self:center; }
  .lead-form-box { padding:36px; }
}
@media(max-width:480px) {
  .frow { grid-template-columns:1fr; }
}

/* ================================================================
   FAQ
================================================================ */
.faq-layout { display:grid; grid-template-columns:1fr; gap:40px; }
.faq-left p { font-size:.9rem; color:var(--ink-3); margin-bottom:20px; }
.faq-right { display:flex; flex-direction:column; gap:8px; }
.faq-item { background:var(--white); border:1px solid var(--border); border-radius:var(--r-sm); overflow:hidden; transition:border-color var(--t); }
.faq-item.open { border-color:var(--orange); }
.faq-q { width:100%; text-align:left; background:none; border:none; font-family:var(--fb); font-size:.92rem; font-weight:600; color:var(--ink); padding:16px 18px; cursor:pointer; display:flex; justify-content:space-between; align-items:center; gap:12px; transition:color var(--t); -webkit-tap-highlight-color:transparent; }
.faq-q:hover { color:var(--orange); }
.fiq-icon { width:24px; height:24px; background:var(--bg-2); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:.95rem; font-weight:800; flex-shrink:0; transition:background var(--t), transform var(--t); }
.faq-item.open .fiq-icon { background:var(--orange); color:var(--white); transform:rotate(45deg); }
.faq-a { max-height:0; overflow:hidden; transition:max-height .4s ease; }
.faq-item.open .faq-a { max-height:160px; }
.faq-a p { padding:0 18px 16px; font-size:.86rem; color:var(--ink-3); line-height:1.7; }

@media(min-width:900px) {
  .faq-layout { grid-template-columns:1fr 1.6fr; gap:72px; align-items:start; }
}

/* ================================================================
   FINAL CTA
================================================================ */
.final-cta { background:white; padding:64px 0; border-top:1px solid var(--border); }
.fcta {
  background:black;
  border-radius:var(--r-lg); padding:48px 28px;
  display:flex; flex-direction:column; gap:28px; align-items:flex-start;
  position:relative; overflow:hidden;
}
.fcta-blob { position:absolute; width:360px; height:360px; border-radius:50%; background:rgba(255,255,255,.07); top:-120px; right:-80px; pointer-events:none; }
.fcta h2 { font-family:var(--fd); font-size:clamp(1.7rem,4vw,2.4rem); font-weight:900; color:var(--white); line-height:1.15; position:relative; }
.fcta h2 em { font-style:italic; color:var(--teal); }
.fcta p  { font-size:.95rem; color:rgba(255,255,255,.78); max-width:440px; position:relative; }
.fcta-btns { display:flex; flex-direction:column; gap:12px; width:100%; position:relative; }
.fcta-btns .btn { width:100%; justify-content:center; }

@media(min-width:700px) {
  .fcta { flex-direction:row; align-items:center; justify-content:space-between; padding:56px 56px; }
  .fcta-btns { flex-direction:column; width:auto; min-width:230px; }
  .fcta-btns .btn { width:auto; }
}

/* ================================================================
   FOOTER
================================================================ */
.footer { background:#f7f5f0; padding:56px 0 28px; }
.footer-grid { display:grid; grid-template-columns:1fr; gap:36px; margin-bottom:40px; }
.ft-brand { display:flex; flex-direction:column; gap:12px; }
.ft-brand .nav-logo { gap:8px; }
.ft-brand .nav-logo img { height:36px; }
.ft-brand .logo-chip { width:32px; height:32px; font-size:.75rem; background:var(--orange); }
.ft-brand p { font-size:.85rem; color:rgb(44, 44, 44); line-height:1.7; max-width:280px; }
.ft-contacts { display:flex; flex-direction:column; gap:6px; }
.ft-contacts a { color:rgb(44, 44, 44); text-decoration:none; font-size:.83rem; transition:color var(--t); }
.ft-contacts a:hover { color:black; }
.ft-col { display:flex; flex-direction:column; gap:10px; }
.ft-col h5 { font-family:var(--fd); font-size:.82rem; font-weight:800; color:black; letter-spacing:.04em; margin-bottom:4px; }
.ft-col a { font-size:.83rem; color:rgb(44, 44, 44); text-decoration:none; transition:color var(--t); }
.ft-col a:hover { color:var(--orange); }
.footer-bot { border-top:1px solid rgba(255,255,255,.08); padding-top:22px; display:flex; flex-direction:column; gap:4px; align-items:center; text-align:center; }
.footer-bot p { font-size:.76rem; color:rgb(44, 44, 44); }

@media(min-width:600px) {
  .footer-grid { grid-template-columns:1fr 1fr; }
}
@media(min-width:900px) {
  .footer-grid { grid-template-columns:2fr 1fr 1fr 1fr; }
  .footer-bot { flex-direction:row; justify-content:space-between; text-align:left; }
}

/* ================================================================
   FLOATING CTA
================================================================ */
.float-cta {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 999;
  opacity: 0;
  transform: translateY(20px);
  transition: all var(--t);
  pointer-events: none;
}
.float-cta.visible { opacity: 1; transform: none; pointer-events: auto; }

/* Sticky mobile CTA bar */
.mobile-cta-bar {
  display:none;
  position:fixed; bottom:0; left:0; right:0; z-index:998;
  background:var(--orange); padding:14px 20px;
  box-shadow:0 -4px 20px rgba(249,115,22,.3);
}
.mobile-cta-bar a {
  display:block; text-align:center;
  font-family:var(--fb); font-weight:800; font-size:1rem;
  color:var(--white); text-decoration:none; letter-spacing:.02em;
}
@media(max-width:899px) {
  .mobile-cta-bar { display:block; }
  body { padding-bottom:60px; }
}

/* ================================================================
   MISC MOBILE FIXES
================================================================ */
@media(max-width:480px) {
  .section { padding:56px 0; }
  .hero-h1 { font-size:clamp(2.8rem,12vw,3.8rem); }
  .hero-btns { flex-direction:column; }
  .hero-btns .btn { width:100%; justify-content:center; }
  .pillar { padding:28px 20px; }
  .lead-form-box { padding:20px; }
  .fcta { padding:32px 20px; }
  .container { padding:0 16px; }
}

