/* =========================================
   OET GCC — Shared Design System
   ========================================= */

:root{
  --ink:#0E1F26;
  --ink-soft:#243842;
  --ink-muted:#5B6A72;
  --teal:#1A4D52;
  --teal-deep:#0E3438;
  --teal-glow:#2A6E73;
  --cream:#F7F1E3;
  --cream-2:#EFE6CF;
  --paper:#FBF8EF;
  --copper:#B65F2E;
  --copper-light:#D08550;
  --copper-deep:#8F4720;
  --gold:#C29E5F;
  --gold-deep:#A78343;
  --rose:#C9605E;
  --green:#3A7D5E;
  --line:rgba(14,31,38,0.12);
  --line-soft:rgba(14,31,38,0.06);
  --shadow-sm: 0 1px 2px rgba(14,31,38,0.04), 0 2px 8px rgba(14,31,38,0.05);
  --shadow-md: 0 4px 12px rgba(14,31,38,0.06), 0 12px 32px rgba(14,31,38,0.08);
  --shadow-lg: 0 12px 32px rgba(14,31,38,0.10), 0 30px 80px rgba(14,31,38,0.12);
  --radius-sm:8px;
  --radius-md:16px;
  --radius-lg:28px;
  --ease: cubic-bezier(.2,.8,.2,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'DM Sans',system-ui,sans-serif;
  font-size:16px;line-height:1.55;
  color:var(--ink);
  background:var(--paper);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}

/* Typography */
.serif{font-family:'Fraunces',Georgia,serif;font-optical-sizing:auto;letter-spacing:-0.01em}
.mono{font-family:'JetBrains Mono',monospace;font-size:.74rem;text-transform:uppercase;letter-spacing:.2em}
h1,h2,h3,h4,h5{font-family:'Fraunces',Georgia,serif;color:var(--ink);letter-spacing:-0.02em;line-height:1.05;font-weight:400}
h1{font-size:clamp(2.4rem,5.8vw,4.8rem);font-variation-settings:"opsz" 144,"SOFT" 30}
h2{font-size:clamp(1.9rem,4.2vw,3.4rem);font-variation-settings:"opsz" 96,"SOFT" 30}
h3{font-size:clamp(1.4rem,2.2vw,1.8rem);font-variation-settings:"opsz" 48}
h4{font-size:1.15rem;font-variation-settings:"opsz" 36;font-weight:500}
h5{font-size:.95rem;font-weight:500}
.italic-accent{font-style:italic;color:var(--copper);font-variation-settings:"opsz" 144,"SOFT" 80}

.eyebrow{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:'DM Sans',sans-serif;
  font-size:.72rem;font-weight:500;
  text-transform:uppercase;letter-spacing:.22em;
  color:var(--copper);
}
.eyebrow::before{content:"";width:28px;height:1px;background:var(--copper)}
.eyebrow-light{color:var(--gold)}
.eyebrow-light::before{background:var(--gold)}

/* Layout */
.container{max-width:1280px;margin:0 auto;padding:0 24px}
@media (min-width:768px){.container{padding:0 40px}}
section{padding:80px 0;position:relative}
@media (min-width:768px){section{padding:120px 0}}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:.6rem;
  padding:14px 26px;font-size:.92rem;font-weight:500;
  border-radius:999px;transition:all .3s var(--ease);
  white-space:nowrap;cursor:pointer;
}
.btn-primary{background:var(--ink);color:var(--cream)}
.btn-primary:hover{background:var(--teal);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn-secondary{background:transparent;color:var(--ink);border:1px solid var(--ink)}
.btn-secondary:hover{background:var(--ink);color:var(--cream)}
.btn-copper{background:var(--copper);color:#fff}
.btn-copper:hover{background:var(--copper-deep);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn-cream{background:var(--cream);color:var(--ink)}
.btn-cream:hover{background:var(--copper);color:var(--cream);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn-gold{background:var(--gold);color:var(--ink)}
.btn-gold:hover{background:var(--gold-deep);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn-outline-light{background:transparent;color:var(--cream);border:1px solid rgba(247,241,227,0.4)}
.btn-outline-light:hover{background:var(--cream);color:var(--ink);border-color:var(--cream)}
.btn-arrow{transition:transform .3s ease;display:inline-block}
.btn:hover .btn-arrow{transform:translateX(4px)}
.btn-block{display:flex;width:100%;justify-content:center}
.btn-lg{padding:18px 32px;font-size:1rem}

/* =========================================
   URGENCY BANNER
   ========================================= */
.urgency-bar{
  background:linear-gradient(90deg,var(--copper),var(--copper-deep));
  color:var(--cream);
  padding:10px 0;
  font-size:.86rem;
  position:relative;z-index:101;
  overflow:hidden;
}
.urgency-bar-inner{
  display:flex;align-items:center;justify-content:center;
  gap:18px;flex-wrap:wrap;text-align:center;
}
.urgency-dot{
  width:8px;height:8px;border-radius:50%;background:var(--gold);
  animation:pulse 1.4s infinite;
}
.urgency-bar strong{color:var(--gold);font-weight:600}
.urgency-bar a{
  color:var(--cream);text-decoration:underline;font-weight:500;
  text-underline-offset:3px;
}
@keyframes pulse{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.4;transform:scale(1.3)}
}

/* =========================================
   NAVIGATION
   ========================================= */
.topbar{
  position:sticky;top:0;left:0;right:0;
  z-index:100;
  padding:16px 0;
  transition:all .35s ease;
  background:var(--paper);
  border-bottom:1px solid transparent;
}
.topbar.scrolled{
  background:rgba(251,248,239,0.96);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom-color:var(--line-soft);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:12px;font-family:'Fraunces',serif;font-weight:500;font-size:1.4rem;letter-spacing:-.01em;color:var(--ink)}
.brand-logo{
  height:44px;width:auto;display:block;
  /* Keep the logo legible on the cream nav; the JPEG ships with a faint blue
     background — once a transparent PNG/SVG is available, swap the file. */
}
.brand-text{font-family:'Fraunces',serif;font-weight:500;font-size:1.05rem;letter-spacing:-.005em;color:var(--ink-soft);display:none}
@media (min-width:480px){.brand-text{display:inline}}
/* Legacy fallback if any page still uses the OG pill */
.brand-mark{
  width:38px;height:38px;border-radius:50%;
  background:var(--teal);color:var(--cream);
  display:grid;place-items:center;font-size:.85rem;font-weight:600;
}
.nav-links{display:none;gap:28px;align-items:center}
.nav-links a{
  font-size:.93rem;color:var(--ink-soft);
  position:relative;padding:6px 0;transition:color .2s;
}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-links a::after{
  content:"";position:absolute;bottom:0;left:0;
  width:0;height:1px;background:var(--copper);
  transition:width .3s ease;
}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-cta{display:none;gap:10px;align-items:center}
.menu-toggle{display:flex;flex-direction:column;gap:5px;padding:8px}
.menu-toggle span{width:22px;height:1.5px;background:var(--ink);transition:.3s}
@media (min-width:1024px){
  .nav-links,.nav-cta{display:flex}
  .menu-toggle{display:none}
}

.mobile-menu{
  position:fixed;inset:0;background:var(--paper);z-index:99;
  transform:translateX(100%);transition:transform .4s var(--ease);
  padding:120px 32px 40px;overflow-y:auto;
}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu a{
  display:block;padding:18px 0;
  font-family:'Fraunces',serif;font-size:1.6rem;
  border-bottom:1px solid var(--line-soft);
}
.mobile-menu .btn{margin-top:24px;display:inline-flex}

/* =========================================
   PAGE HERO
   ========================================= */
.page-hero{
  padding:80px 0 60px;
  background:var(--cream);
  position:relative;overflow:hidden;
}
.page-hero::before{
  content:"";position:absolute;top:-150px;right:-150px;
  width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(194,158,95,0.25),transparent 70%);
}
.page-hero .container{position:relative;z-index:2}
.page-hero-content{max-width:780px}
.page-hero h1{margin:18px 0 20px}
.page-hero p{font-size:1.1rem;color:var(--ink-soft);max-width:600px}
.breadcrumb{
  display:flex;align-items:center;gap:8px;
  font-size:.82rem;color:var(--ink-muted);
  margin-bottom:8px;
}
.breadcrumb a:hover{color:var(--copper)}
.breadcrumb span{color:var(--copper)}

/* =========================================
   HERO (HOME)
   ========================================= */
.hero{
  padding-top:80px;padding-bottom:80px;
  position:relative;overflow:hidden;
}
.hero::before{
  content:"";position:absolute;top:0;right:-15%;
  width:60%;height:120%;
  background:radial-gradient(ellipse at center, rgba(194,158,95,0.18), transparent 65%);
  pointer-events:none;
}
.hero-grid{
  display:grid;gap:48px;align-items:center;
  grid-template-columns:1fr;
}
@media (min-width:1024px){
  .hero-grid{grid-template-columns:1.1fr 1fr;gap:64px}
}
.hero-content{position:relative;z-index:2}
.hero h1{margin:24px 0 24px}
.hero-lead{font-size:1.1rem;color:var(--ink-soft);max-width:520px;margin-bottom:30px}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:36px}
.hero-bullets{display:flex;flex-direction:column;gap:14px;max-width:520px;margin-bottom:32px}
.hero-bullets li{
  list-style:none;display:flex;gap:14px;align-items:flex-start;
  font-size:.96rem;color:var(--ink-soft);
}
.hero-bullets li::before{
  content:"";flex-shrink:0;width:22px;height:22px;border-radius:50%;
  background:var(--cream-2);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23B65F2E' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E");
  background-position:center;background-size:14px;background-repeat:no-repeat;
}
.hero-trust{
  display:flex;flex-wrap:wrap;gap:24px;align-items:center;
  padding-top:28px;border-top:1px solid var(--line);
}
.hero-trust-item{display:flex;align-items:center;gap:10px}
.hero-trust-item strong{
  font-family:'Fraunces',serif;font-size:1.6rem;color:var(--teal);
  display:block;line-height:1;
}
.hero-trust-item span{font-size:.78rem;color:var(--ink-muted);display:block}

.hero-visual{position:relative;height:580px}
.hero-img-main{
  position:absolute;top:0;right:0;
  width:78%;height:88%;
  border-radius:240px 240px 24px 24px;
  overflow:hidden;
  box-shadow:var(--shadow-lg);
  background:linear-gradient(160deg,#1A4D52,#0E3438);
}
.hero-img-main img{width:100%;height:100%;object-fit:cover}
.hero-img-sec{
  position:absolute;bottom:0;left:0;
  width:46%;aspect-ratio:1/1;
  border-radius:24px;overflow:hidden;
  box-shadow:var(--shadow-lg);
  border:8px solid var(--paper);
  background:linear-gradient(160deg,var(--copper),var(--copper-deep));
}
.hero-img-sec img{width:100%;height:100%;object-fit:cover}
.hero-badge{
  position:absolute;top:24%;left:-5%;
  background:var(--paper);
  padding:14px 18px;border-radius:14px;
  box-shadow:var(--shadow-md);
  display:flex;align-items:center;gap:12px;z-index:3;
}
.hero-badge-icon{
  width:42px;height:42px;border-radius:50%;
  background:var(--cream-2);
  display:grid;place-items:center;font-size:1.2rem;
}
.hero-badge-text{font-size:.78rem;line-height:1.2}
.hero-badge-text strong{display:block;font-family:'Fraunces',serif;font-size:1.2rem;color:var(--teal)}
.hero-stat{
  position:absolute;bottom:6%;right:-3%;
  background:var(--teal);color:var(--cream);
  padding:18px 22px;border-radius:14px;
  box-shadow:var(--shadow-lg);z-index:3;
}
.hero-stat strong{display:block;font-family:'Fraunces',serif;font-size:1.8rem;line-height:1}
.hero-stat span{font-size:.78rem;opacity:.85;letter-spacing:.04em}

/* =========================================
   TRUST STRIP / MARQUEE
   ========================================= */
.trust-strip{
  padding:48px 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  overflow:hidden;
  background:var(--paper);
}
.trust-label{
  text-align:center;font-size:.78rem;
  text-transform:uppercase;letter-spacing:.24em;
  color:var(--ink-soft);margin-bottom:28px;
}
.marquee-track{overflow:hidden;mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent)}
.marquee{display:flex;gap:80px;animation:marquee 32s linear infinite;width:fit-content}
.marquee-item{
  font-family:'Fraunces',serif;font-size:1.4rem;
  color:var(--ink-soft);white-space:nowrap;
  display:flex;align-items:center;gap:80px;opacity:.7;
}
.marquee-item::after{content:"✦";color:var(--copper);font-size:1rem}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* =========================================
   GENERIC SECTIONS
   ========================================= */
.section-cream{background:var(--cream)}
.section-dark{background:var(--ink);color:var(--cream)}
.section-dark h2,.section-dark h3,.section-dark h4{color:var(--cream)}
.section-teal{background:var(--teal);color:var(--cream)}
.section-teal h2{color:var(--cream)}

.split-grid{
  display:grid;gap:64px;
  grid-template-columns:1fr;align-items:start;
}
@media (min-width:1024px){.split-grid{grid-template-columns:1fr 1.2fr;gap:96px}}
.split-grid-reverse{
  display:grid;gap:64px;
  grid-template-columns:1fr;align-items:start;
}
@media (min-width:1024px){.split-grid-reverse{grid-template-columns:1.2fr 1fr;gap:96px}}

/* About images */
.about-images{position:relative;height:560px}
.about-img-1{
  position:absolute;top:0;left:0;
  width:65%;aspect-ratio:3/4;
  border-radius:280px 280px 24px 24px;
  overflow:hidden;box-shadow:var(--shadow-lg);
  background:linear-gradient(160deg,var(--teal),var(--teal-deep));
}
.about-img-1 img{width:100%;height:100%;object-fit:cover}
.about-img-2{
  position:absolute;bottom:0;right:0;
  width:55%;aspect-ratio:4/3;
  border-radius:24px;overflow:hidden;
  box-shadow:var(--shadow-lg);border:10px solid var(--cream);
  background:linear-gradient(160deg,var(--copper),var(--copper-deep));
}
.about-img-2 img{width:100%;height:100%;object-fit:cover}
.about-deco{
  position:absolute;top:30%;right:5%;
  font-family:'Fraunces',serif;font-style:italic;
  font-size:5rem;color:var(--copper);opacity:.25;pointer-events:none;
}

/* Vision/Mission cards */
.vm-grid{display:grid;gap:24px;grid-template-columns:1fr 1fr;margin-bottom:36px}
.vm-card{
  padding:28px 24px;background:var(--paper);
  border-radius:var(--radius-md);border:1px solid var(--line-soft);
  transition:transform .3s ease,box-shadow .3s ease;
}
.vm-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.vm-icon{
  width:48px;height:48px;border-radius:12px;
  background:var(--cream-2);
  display:grid;place-items:center;margin-bottom:18px;font-size:1.4rem;
}
.vm-card h4{margin-bottom:10px}
.vm-card p{font-size:.94rem;color:var(--ink-soft);line-height:1.5}

/* =========================================
   WHY CHOOSE / FEATURE CARDS
   ========================================= */
.why-header{
  display:grid;gap:40px;grid-template-columns:1fr;
  align-items:end;margin-bottom:56px;
}
@media (min-width:768px){.why-header{grid-template-columns:1.4fr 1fr}}
.why-grid{
  display:grid;gap:24px;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
}
.feature-card{
  padding:32px 28px;background:var(--cream);
  border-radius:var(--radius-md);position:relative;overflow:hidden;
  transition:all .35s var(--ease);border:1px solid transparent;
}
.feature-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--copper),var(--gold));
  transform:scaleX(0);transform-origin:left;transition:transform .4s ease;
}
.feature-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);background:var(--cream-2)}
.feature-card:hover::before{transform:scaleX(1)}
.feature-num{
  font-family:'Fraunces',serif;font-style:italic;
  font-size:2.4rem;color:var(--copper);line-height:1;margin-bottom:20px;
}
.feature-card h4{margin-bottom:8px;font-size:1.2rem}
.feature-card p{font-size:.92rem;color:var(--ink-soft);line-height:1.55}
.feature-stat{
  display:block;margin-top:14px;
  font-family:'JetBrains Mono',monospace;
  font-size:.72rem;color:var(--green);text-transform:uppercase;letter-spacing:.16em;
}

/* =========================================
   PROCESS / STEPS
   ========================================= */
.process::before{
  content:"";position:absolute;top:-200px;right:-200px;
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(194,158,95,0.15),transparent 70%);
  pointer-events:none;
}
.process-header{display:grid;gap:24px;grid-template-columns:1fr;margin-bottom:64px}
@media (min-width:768px){.process-header{grid-template-columns:1fr 1fr;align-items:end;gap:60px}}
.process-header p{color:rgba(247,241,227,0.7);max-width:480px}
.steps{display:grid;gap:20px;grid-template-columns:1fr}
@media (min-width:768px){.steps{grid-template-columns:repeat(2,1fr)}}
@media (min-width:1024px){.steps{grid-template-columns:repeat(3,1fr)}}
.step{
  padding:36px 32px;border:1px solid rgba(247,241,227,0.1);
  border-radius:var(--radius-md);position:relative;
  transition:all .3s ease;background:rgba(247,241,227,0.02);
}
.step:hover{
  background:rgba(247,241,227,0.05);
  border-color:rgba(194,158,95,0.4);transform:translateY(-4px);
}
.step-num{display:flex;align-items:center;gap:12px;margin-bottom:22px}
.step-num-circle{
  width:42px;height:42px;border-radius:50%;
  background:var(--gold);color:var(--ink);
  display:grid;place-items:center;
  font-family:'Fraunces',serif;font-weight:500;font-size:1.05rem;
}
.step-num-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.2em;color:var(--gold)}
.step h4{color:var(--cream);margin-bottom:10px;font-size:1.25rem}
.step p{font-size:.92rem;color:rgba(247,241,227,0.65);line-height:1.55}

/* =========================================
   COUNTRIES
   ========================================= */
.countries-header{text-align:center;max-width:700px;margin:0 auto 64px}
.countries-header p{font-size:1.05rem;color:var(--ink-soft);margin-top:24px}
.countries-grid{display:grid;gap:18px;grid-template-columns:repeat(2,1fr)}
@media (min-width:640px){.countries-grid{grid-template-columns:repeat(3,1fr)}}
@media (min-width:1024px){.countries-grid{grid-template-columns:repeat(6,1fr)}}
.country-card{
  position:relative;aspect-ratio:3/4;
  border-radius:var(--radius-md);overflow:hidden;cursor:pointer;
  transition:transform .4s var(--ease);
  background:linear-gradient(160deg,var(--teal),var(--teal-deep));
}
.country-card:hover{transform:translateY(-6px)}
.country-card img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.country-card:hover img{transform:scale(1.08)}
.country-card::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 40%,rgba(14,31,38,0.85) 100%);
}
.country-label{
  position:absolute;bottom:18px;left:18px;right:18px;
  color:var(--cream);z-index:2;
}
.country-label .mono{display:block;color:var(--gold);margin-bottom:4px;font-size:.7rem}
.country-label strong{font-family:'Fraunces',serif;font-weight:500;font-size:1.2rem;letter-spacing:-.01em}

/* =========================================
   TESTIMONIAL CARDS
   ========================================= */
.test-header{text-align:center;max-width:640px;margin:0 auto 64px}
.test-header p{color:var(--ink-soft);margin-top:18px}
.test-grid{display:grid;gap:28px;grid-template-columns:1fr}
@media (min-width:768px){.test-grid{grid-template-columns:repeat(2,1fr)}}
@media (min-width:1024px){.test-grid{grid-template-columns:repeat(3,1fr)}}
.test-card{
  padding:36px 32px;background:var(--cream);
  border-radius:var(--radius-md);position:relative;
  transition:all .3s ease;
  display:flex;flex-direction:column;gap:18px;
}
.test-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.test-quote-mark{
  font-family:'Fraunces',serif;font-style:italic;
  font-size:5rem;line-height:.6;color:var(--copper);margin-bottom:-10px;
}
.test-stars{display:flex;gap:3px;color:var(--gold);font-size:.95rem}
.test-text{font-size:1.0rem;color:var(--ink);line-height:1.6;flex-grow:1}
.test-author{display:flex;align-items:center;gap:14px;padding-top:18px;border-top:1px solid var(--line-soft)}
.test-author img{width:48px;height:48px;border-radius:50%;object-fit:cover;background:var(--copper)}
.test-author strong{display:block;font-weight:500}
.test-author span{font-size:.82rem;color:var(--ink-soft)}
.test-score-badge{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--green);color:#fff;
  padding:5px 12px;border-radius:999px;
  font-size:.74rem;font-weight:500;
  align-self:flex-start;
}

/* =========================================
   FAQ ACCORDION
   ========================================= */
.faq-grid{display:grid;gap:64px;grid-template-columns:1fr;align-items:start}
@media (min-width:1024px){.faq-grid{grid-template-columns:1fr 1.4fr;gap:96px}}
.faq-aside{position:sticky;top:140px}
.faq-aside h2{margin:20px 0 24px}
.faq-aside p{color:var(--ink-soft);margin-bottom:32px}
.faq-contact-card{
  padding:28px 26px;background:var(--paper);
  border-radius:var(--radius-md);border:1px solid var(--line-soft);
}
.faq-contact-card .mono{color:var(--copper);display:block;margin-bottom:10px}
.faq-contact-card a{
  font-family:'Fraunces',serif;font-size:1.4rem;color:var(--teal);
  display:inline-flex;align-items:center;gap:8px;
}
.faq-contact-card a:hover{color:var(--copper)}

.accordion{display:flex;flex-direction:column}
.acc-item{border-bottom:1px solid var(--line);transition:padding .3s ease}
.acc-item:first-child{border-top:1px solid var(--line)}
.acc-trigger{
  width:100%;text-align:left;padding:24px 0;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  font-family:'Fraunces',serif;font-size:1.15rem;
  color:var(--ink);font-weight:500;
  transition:color .25s ease;
}
.acc-trigger:hover{color:var(--copper)}
.acc-icon{
  position:relative;flex-shrink:0;width:32px;height:32px;
  border-radius:50%;border:1px solid var(--line);
  display:grid;place-items:center;transition:all .3s ease;
}
.acc-icon::before,.acc-icon::after{content:"";position:absolute;background:var(--ink)}
.acc-icon::before{width:12px;height:1.5px}
.acc-icon::after{width:1.5px;height:12px;transition:transform .3s ease}
.acc-item.open .acc-icon{background:var(--copper);border-color:var(--copper)}
.acc-item.open .acc-icon::before,.acc-item.open .acc-icon::after{background:var(--cream)}
.acc-item.open .acc-icon::after{transform:rotate(90deg)}
.acc-content{max-height:0;overflow:hidden;transition:max-height .4s ease}
.acc-content-inner{
  padding:0 0 28px;color:var(--ink-soft);
  font-size:.98rem;line-height:1.65;max-width:90%;
}

/* =========================================
   CTA SECTIONS
   ========================================= */
.cta-section{
  background:var(--teal);color:var(--cream);
  position:relative;overflow:hidden;padding:80px 0;
}
.cta-section::before{
  content:"";position:absolute;top:-100px;left:-100px;
  width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,rgba(194,158,95,0.25),transparent 70%);
}
.cta-section::after{
  content:"";position:absolute;bottom:-100px;right:-100px;
  width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(182,95,46,0.2),transparent 70%);
}
.cta-inner{position:relative;z-index:2;text-align:center;max-width:780px;margin:0 auto}
.cta-inner .eyebrow{color:var(--gold)}
.cta-inner .eyebrow::before{background:var(--gold)}
.cta-inner h2{color:var(--cream);margin:20px 0 24px}
.cta-inner h2 em{font-style:italic;color:var(--gold)}
.cta-inner p{font-size:1.05rem;opacity:.85;max-width:560px;margin:0 auto 36px}
.cta-actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}
.cta-guarantees{
  display:flex;flex-wrap:wrap;gap:14px 28px;justify-content:center;
  margin-top:36px;font-size:.84rem;
}
.cta-guarantees span{display:inline-flex;align-items:center;gap:8px;color:rgba(247,241,227,0.85)}
.cta-guarantees span::before{
  content:"";width:16px;height:16px;border-radius:50%;
  background:var(--gold);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230E1F26' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E");
  background-size:10px;background-position:center;background-repeat:no-repeat;
}

/* =========================================
   STATS BAND
   ========================================= */
.stats-band{
  padding:64px 0;background:var(--cream);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.stats-grid{
  display:grid;gap:48px 24px;
  grid-template-columns:repeat(2,1fr);
  text-align:center;
}
@media (min-width:768px){.stats-grid{grid-template-columns:repeat(4,1fr)}}
.stat-item strong{
  display:block;font-family:'Fraunces',serif;
  font-size:clamp(2.5rem,5vw,3.6rem);color:var(--teal);
  line-height:1;margin-bottom:8px;
  font-variation-settings:"opsz" 144;
}
.stat-item .stat-suffix{color:var(--copper)}
.stat-item span{font-size:.86rem;color:var(--ink-soft);letter-spacing:.04em}

/* =========================================
   PRICING CARD
   ========================================= */
.pricing-wrap{
  display:grid;gap:32px;
  grid-template-columns:1fr;align-items:center;
}
@media (min-width:1024px){.pricing-wrap{grid-template-columns:1fr 1fr;gap:64px}}
.pricing-card{
  background:var(--paper);
  border-radius:var(--radius-lg);
  padding:40px 36px;
  box-shadow:var(--shadow-lg);
  position:relative;overflow:hidden;
  border:1px solid var(--line-soft);
}
.pricing-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:6px;
  background:linear-gradient(90deg,var(--copper),var(--gold));
}
.pricing-badge{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--copper);color:#fff;
  padding:6px 14px;border-radius:999px;
  font-size:.74rem;font-weight:500;
  text-transform:uppercase;letter-spacing:.12em;
  margin-bottom:18px;
}
.pricing-title{font-size:1.6rem;margin-bottom:8px}
.pricing-sub{color:var(--ink-soft);margin-bottom:26px}
.pricing-amount{display:flex;align-items:flex-end;gap:14px;margin-bottom:6px}
.pricing-amount .now{
  font-family:'Fraunces',serif;font-size:3.4rem;color:var(--ink);
  line-height:1;font-weight:400;
}
.pricing-amount .was{
  font-family:'Fraunces',serif;font-size:1.5rem;
  text-decoration:line-through;color:var(--ink-muted);
  padding-bottom:6px;
}
.pricing-save{
  color:var(--green);font-size:.86rem;font-weight:500;margin-bottom:24px;
}
.pricing-includes{list-style:none;display:flex;flex-direction:column;gap:12px;margin-bottom:28px}
.pricing-includes li{display:flex;gap:12px;font-size:.94rem;color:var(--ink-soft)}
.pricing-includes li::before{
  content:"";flex-shrink:0;width:20px;height:20px;border-radius:50%;
  background:var(--cream-2);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23B65F2E' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E");
  background-size:12px;background-position:center;background-repeat:no-repeat;
}
.pricing-foot{
  margin-top:20px;padding-top:20px;border-top:1px solid var(--line-soft);
  display:flex;flex-wrap:wrap;gap:8px 20px;
  font-size:.78rem;color:var(--ink-muted);
}
.pricing-foot span::before{content:"✓ ";color:var(--green);font-weight:700}

/* =========================================
   TRAINERS
   ========================================= */
.trainers-grid{
  display:grid;gap:24px;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
}
.trainer-card{
  background:var(--paper);border-radius:var(--radius-md);
  overflow:hidden;border:1px solid var(--line-soft);
  transition:all .3s ease;
}
.trainer-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.trainer-img{
  aspect-ratio:1/1;background:linear-gradient(160deg,var(--teal),var(--copper));
  position:relative;overflow:hidden;
}
.trainer-img img{width:100%;height:100%;object-fit:cover}
.trainer-body{padding:24px 22px}
.trainer-body h4{margin-bottom:4px}
.trainer-role{font-size:.86rem;color:var(--copper);font-weight:500;letter-spacing:.04em;display:block;margin-bottom:14px}
.trainer-cred{font-size:.86rem;color:var(--ink-soft);line-height:1.5}

/* =========================================
   MODULE / TEST FORMAT CARDS
   ========================================= */
.module-grid{
  display:grid;gap:24px;
  grid-template-columns:1fr;
}
@media (min-width:768px){.module-grid{grid-template-columns:1fr 1fr}}
.module-card{
  background:var(--paper);
  border-radius:var(--radius-md);
  padding:36px 32px;
  border:1px solid var(--line-soft);
  display:grid;
  grid-template-columns:auto 1fr;
  gap:24px;
  align-items:start;
  transition:all .3s ease;
}
.module-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.module-icon{
  width:64px;height:64px;border-radius:16px;
  background:var(--cream-2);
  display:grid;place-items:center;
  font-size:1.8rem;color:var(--copper);
  flex-shrink:0;
}
.module-card h4{
  display:flex;align-items:center;gap:12px;
  margin-bottom:10px;flex-wrap:wrap;
}
.module-time{
  font-family:'JetBrains Mono',monospace;font-size:.7rem;
  background:var(--ink);color:var(--cream);
  padding:4px 10px;border-radius:999px;letter-spacing:.1em;
}
.module-card p{color:var(--ink-soft);font-size:.94rem;line-height:1.55}

/* =========================================
   VIDEO / PROCESS VIDEO
   ========================================= */
.video-section{padding:80px 0}

/* ===========================================================
   FEATURED STORY — large editorial pull-quote card
   Used in place of hero video on index.html
   =========================================================== */
.featured-story{
  display:grid;gap:0;grid-template-columns:1fr;
  background:var(--ink);color:var(--cream);
  border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow-lg);position:relative;
}
@media (min-width:900px){.featured-story{grid-template-columns:5fr 7fr}}
.featured-story::before{
  content:"";position:absolute;top:-80px;right:-80px;
  width:280px;height:280px;border-radius:50%;
  background:radial-gradient(circle,rgba(194,158,95,0.2),transparent 70%);
  pointer-events:none;
}
.featured-story-img{
  position:relative;min-height:320px;background:var(--teal);
}
.featured-story-img img{
  width:100%;height:100%;object-fit:cover;
}
.featured-story-img .verified-badge{
  position:absolute;top:18px;left:18px;
  background:rgba(0,0,0,0.55);backdrop-filter:blur(8px);
  color:#fff;padding:6px 12px;border-radius:999px;
  font-size:.74rem;font-family:'JetBrains Mono',monospace;
  letter-spacing:.06em;display:flex;align-items:center;gap:6px;
}
.featured-story-img .verified-badge::before{
  content:"";width:8px;height:8px;border-radius:50%;
  background:#3A7D5E;
}
.featured-story-content{
  padding:48px 44px;position:relative;z-index:2;
  display:flex;flex-direction:column;justify-content:center;
}
@media (max-width:899px){.featured-story-content{padding:36px 28px}}
.featured-story-content .grade-pill{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--gold);color:var(--ink);
  padding:6px 14px;border-radius:999px;
  font-size:.78rem;font-weight:600;margin-bottom:20px;
  font-family:'JetBrains Mono',monospace;letter-spacing:.04em;
  align-self:flex-start;
}
.featured-story-content .stars{
  color:var(--gold);font-size:1.1rem;margin-bottom:18px;letter-spacing:.05em;
}
.featured-story-content blockquote{
  font-family:'Fraunces',serif;font-size:1.45rem;
  line-height:1.45;font-weight:400;color:var(--cream);
  margin:0 0 28px;quotes:"\201C" "\201D";font-style:italic;
}
.featured-story-content blockquote::before{
  content:open-quote;display:block;font-size:3.5rem;
  color:var(--gold);line-height:0;margin-top:24px;margin-bottom:8px;opacity:.7;
}
@media (max-width:899px){.featured-story-content blockquote{font-size:1.18rem}}
.featured-story-author{
  display:flex;align-items:center;gap:14px;
  padding-top:22px;border-top:1px solid rgba(247,241,227,0.14);
}
.featured-story-author img{
  width:56px;height:56px;border-radius:50%;object-fit:cover;
  border:2px solid var(--gold);
}
.featured-story-author-text strong{
  display:block;color:var(--cream);font-weight:500;font-family:'Fraunces',serif;font-size:1.1rem;
}
.featured-story-author-text span{
  color:rgba(247,241,227,0.7);font-size:.86rem;
}

/* ===========================================================
   LARGE STORY CARD — for success-stories.html top section
   Bigger version of test-card with more content
   =========================================================== */
.story-card-grid{display:grid;gap:24px;grid-template-columns:1fr;margin-top:40px}
@media (min-width:768px){.story-card-grid{grid-template-columns:repeat(3,1fr)}}
.story-card{
  background:var(--paper);border-radius:var(--radius-md);
  padding:32px 28px;border:1px solid var(--line-soft);
  display:flex;flex-direction:column;gap:18px;
  transition:all .3s ease;position:relative;
}
.story-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.story-card-header{display:flex;gap:14px;align-items:center}
.story-card-header img{
  width:56px;height:56px;border-radius:50%;object-fit:cover;
  border:2px solid var(--copper);
}
.story-card-header-text strong{
  display:block;font-family:'Fraunces',serif;font-size:1.08rem;font-weight:500;
}
.story-card-header-text span{
  display:block;color:var(--ink-soft);font-size:.82rem;
}
.story-card .stars{color:var(--gold);font-size:.95rem;letter-spacing:.05em}
.story-card-quote{
  font-family:'Fraunces',serif;font-size:1.05rem;
  line-height:1.55;color:var(--ink);
  font-style:italic;flex-grow:1;margin:0;
  position:relative;padding-left:18px;
}
.story-card-quote::before{
  content:"";position:absolute;left:0;top:6px;bottom:6px;
  width:3px;background:var(--copper);border-radius:2px;
}
.story-card-footer{
  display:flex;justify-content:space-between;align-items:center;gap:12px;
  padding-top:18px;border-top:1px solid var(--line-soft);font-size:.82rem;
}
.story-card-footer .grade{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--green);color:#fff;padding:4px 10px;border-radius:999px;
  font-weight:600;font-family:'JetBrains Mono',monospace;font-size:.74rem;letter-spacing:.04em;
}
.story-card-footer .employer{
  color:var(--ink-soft);font-size:.78rem;text-align:right;
}
.story-card-footer .employer strong{display:block;color:var(--ink);font-size:.84rem;font-family:'Fraunces',serif;font-weight:500}

/* ===========================================================
   PROGRAMME HIGHLIGHTS — replaces training walkthrough video
   =========================================================== */
.prog-highlights{
  display:grid;gap:0;grid-template-columns:1fr;
  background:var(--paper);border-radius:var(--radius-lg);
  overflow:hidden;border:1px solid var(--line-soft);box-shadow:var(--shadow-sm);
}
@media (min-width:900px){.prog-highlights{grid-template-columns:1fr 1fr}}
.prog-highlights-left{
  background:var(--ink);color:var(--cream);padding:48px 44px;
  display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden;
}
.prog-highlights-left::before{
  content:"";position:absolute;bottom:-100px;right:-100px;
  width:300px;height:300px;border-radius:50%;
  background:radial-gradient(circle,rgba(194,158,95,0.18),transparent 70%);
}
.prog-highlights-left > *{position:relative;z-index:2}
.prog-highlights-left h3{
  color:var(--cream);font-size:2rem;margin-bottom:14px;
}
.prog-highlights-left p{color:rgba(247,241,227,0.78);font-size:1rem;line-height:1.65}
.prog-highlights-stats{
  display:grid;grid-template-columns:repeat(2,1fr);gap:24px;
  margin-top:32px;padding-top:32px;border-top:1px solid rgba(247,241,227,0.14);
}
.prog-highlights-stat .num{
  font-family:'Fraunces',serif;font-size:2.2rem;color:var(--gold);line-height:1;
}
.prog-highlights-stat .label{
  display:block;margin-top:6px;font-size:.82rem;color:rgba(247,241,227,0.65);
  font-family:'JetBrains Mono',monospace;letter-spacing:.05em;
}
.prog-highlights-right{
  padding:48px 44px;display:flex;flex-direction:column;gap:24px;
}
@media (max-width:899px){
  .prog-highlights-left,.prog-highlights-right{padding:36px 28px}
}
.prog-highlight-item{
  display:flex;gap:16px;align-items:flex-start;
}
.prog-highlight-icon{
  flex-shrink:0;width:42px;height:42px;border-radius:50%;
  background:var(--cream);color:var(--copper);
  display:grid;place-items:center;font-family:'Fraunces',serif;
  font-weight:700;font-size:1.05rem;
}
.prog-highlight-text strong{
  display:block;font-family:'Fraunces',serif;font-size:1.05rem;
  font-weight:500;margin-bottom:4px;
}
.prog-highlight-text p{color:var(--ink-soft);font-size:.92rem;line-height:1.55;margin:0}
.video-wrap{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow-lg);aspect-ratio:16/9;
  background:linear-gradient(135deg,var(--teal-deep),var(--ink));
  cursor:pointer;transition:transform .4s var(--ease);
  max-width:1080px;margin:0 auto;
}
.video-wrap:hover{transform:scale(1.01)}
.video-wrap img{width:100%;height:100%;object-fit:cover;opacity:.4}
.video-wrap::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 40%,rgba(14,31,38,0.6) 100%);
}
.video-play{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:88px;height:88px;border-radius:50%;
  background:var(--copper);color:#fff;
  display:grid;place-items:center;
  box-shadow:0 12px 40px rgba(182,95,46,0.6);
  transition:all .3s ease;z-index:2;
}
.video-play:hover{transform:translate(-50%,-50%) scale(1.1);background:var(--copper-deep)}
.video-play::before{
  content:"";width:0;height:0;
  border-left:24px solid #fff;
  border-top:14px solid transparent;
  border-bottom:14px solid transparent;
  margin-left:8px;
}
.video-meta{
  position:absolute;bottom:28px;left:32px;right:32px;
  color:var(--cream);z-index:2;
}
.video-meta strong{
  display:block;font-family:'Fraunces',serif;font-size:1.4rem;font-weight:500;
}
.video-meta span{font-size:.86rem;opacity:.7}

.video-grid{
  display:grid;gap:24px;grid-template-columns:1fr;
  margin-top:48px;
}
@media (min-width:768px){.video-grid{grid-template-columns:repeat(3,1fr)}}
.video-thumb{
  position:relative;border-radius:var(--radius-md);overflow:hidden;
  aspect-ratio:16/10;cursor:pointer;
  background:linear-gradient(160deg,var(--teal),var(--copper));
}
.video-thumb img{width:100%;height:100%;object-fit:cover;opacity:.5}
.video-thumb::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(14,31,38,0.8) 100%);
}
.video-thumb .play-sm{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:54px;height:54px;border-radius:50%;
  background:rgba(255,255,255,0.2);
  backdrop-filter:blur(10px);
  border:2px solid #fff;
  display:grid;place-items:center;z-index:2;
}
.video-thumb .play-sm::before{
  content:"";width:0;height:0;
  border-left:14px solid #fff;
  border-top:8px solid transparent;
  border-bottom:8px solid transparent;
  margin-left:5px;
}
.video-thumb-info{
  position:absolute;bottom:14px;left:16px;right:16px;
  color:var(--cream);z-index:2;
}
.video-thumb-info strong{display:block;font-family:'Fraunces',serif;font-size:1rem;font-weight:500}
.video-thumb-info span{font-size:.76rem;opacity:.8}

/* =========================================
   FORM
   ========================================= */
.form-row{display:grid;gap:18px;grid-template-columns:1fr;margin-bottom:18px}
@media (min-width:640px){.form-row{grid-template-columns:1fr 1fr}}
.form-field label{
  display:block;font-size:.84rem;font-weight:500;
  margin-bottom:8px;color:var(--ink);
}
.form-field input,.form-field select,.form-field textarea{
  width:100%;padding:14px 16px;
  border:1px solid var(--line);
  background:var(--paper);
  border-radius:12px;
  font-family:inherit;font-size:.95rem;
  color:var(--ink);
  transition:all .25s ease;
}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{
  outline:none;border-color:var(--copper);
  box-shadow:0 0 0 4px rgba(182,95,46,0.1);
}
.form-field textarea{resize:vertical;min-height:120px}

/* =========================================
   COMPARISON TABLE
   ========================================= */
.compare-wrap{overflow-x:auto;border-radius:var(--radius-md);background:var(--paper);box-shadow:var(--shadow-md);border:1px solid var(--line-soft)}
.compare-table{width:100%;border-collapse:collapse;min-width:600px}
.compare-table th,.compare-table td{padding:18px 22px;text-align:left;border-bottom:1px solid var(--line-soft)}
.compare-table th{
  font-family:'Fraunces',serif;font-weight:500;font-size:1rem;
  background:var(--cream-2);
}
.compare-table th.us{background:var(--teal);color:var(--cream)}
.compare-table td.us{background:rgba(26,77,82,0.04);font-weight:500;color:var(--teal)}
.compare-table td.us::before{content:"✓ ";color:var(--green);font-weight:700}
.compare-table td.them::before{content:"× ";color:var(--rose);font-weight:700}
.compare-table tr:last-child td{border-bottom:none}

/* =========================================
   COUNTDOWN
   ========================================= */
.countdown{
  display:flex;gap:14px;flex-wrap:wrap;justify-content:center;
  margin:32px auto 0;
}
.count-box{
  background:rgba(247,241,227,0.1);
  border:1px solid rgba(247,241,227,0.2);
  border-radius:12px;padding:14px 18px;
  min-width:78px;text-align:center;
  backdrop-filter:blur(10px);
}
.count-box strong{
  display:block;font-family:'Fraunces',serif;
  font-size:2rem;color:var(--gold);line-height:1;
}
.count-box span{font-size:.7rem;color:var(--cream);opacity:.7;text-transform:uppercase;letter-spacing:.14em}

/* =========================================
   GUARANTEE BAND
   ========================================= */
.guarantees-band{padding:60px 0;background:var(--cream);border-top:1px solid var(--line)}
.guarantees-grid{
  display:grid;gap:24px;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
}
.guarantee-item{
  display:flex;align-items:flex-start;gap:18px;
  padding:24px 20px;background:var(--paper);
  border-radius:var(--radius-md);border:1px solid var(--line-soft);
}
.guarantee-icon{
  width:48px;height:48px;border-radius:12px;
  background:var(--cream-2);color:var(--copper);
  display:grid;place-items:center;font-size:1.4rem;flex-shrink:0;
}
.guarantee-item h5{font-size:1rem;margin-bottom:4px}
.guarantee-item p{font-size:.86rem;color:var(--ink-soft);line-height:1.5}

/* =========================================
   FLOATING WHATSAPP + STICKY ENROLL BAR
   ========================================= */
.chat-fab{
  position:fixed;bottom:24px;right:24px;
  width:58px;height:58px;border-radius:50%;
  background:linear-gradient(135deg,#1A4D52,#B65F2E);color:#fff;
  display:grid;place-items:center;
  box-shadow:0 12px 32px rgba(26,77,82,0.45);
  z-index:90;transition:all .3s ease;cursor:pointer;
  border:none;font-family:inherit;
}
.chat-fab:hover{transform:scale(1.1);box-shadow:0 16px 40px rgba(26,77,82,0.6)}
.chat-fab svg{width:28px;height:28px}
.chat-fab::after{
  content:"";position:absolute;top:4px;right:4px;
  width:12px;height:12px;border-radius:50%;
  background:#3A7D5E;border:2px solid var(--paper);
  animation:pulse 1.6s infinite;
}
/* Keep legacy class working in case any pages still reference it */
.whatsapp-fab{
  position:fixed;bottom:24px;right:24px;
  width:58px;height:58px;border-radius:50%;
  background:linear-gradient(135deg,#1A4D52,#B65F2E);color:#fff;
  display:grid;place-items:center;
  box-shadow:0 12px 32px rgba(26,77,82,0.45);
  z-index:90;transition:all .3s ease;
}
.whatsapp-fab:hover{transform:scale(1.1)}
.whatsapp-fab svg{width:28px;height:28px}

.sticky-enroll{
  position:fixed;bottom:0;left:0;right:0;
  background:var(--ink);color:var(--cream);
  padding:14px 24px;z-index:88;
  display:none;align-items:center;justify-content:space-between;gap:16px;
  box-shadow:0 -8px 32px rgba(14,31,38,0.2);
  transform:translateY(100%);transition:transform .4s var(--ease);
}
.sticky-enroll.show{transform:translateY(0)}
.sticky-enroll-text{
  display:flex;align-items:center;gap:14px;
}
.sticky-enroll-text strong{font-family:'Fraunces',serif;font-size:1.1rem}
.sticky-enroll-text span{font-size:.78rem;opacity:.7;display:none}
@media (min-width:640px){
  .sticky-enroll{display:flex}
  .sticky-enroll-text span{display:inline}
}

/* =========================================
   LIVE NOTIFICATION POPUP
   ========================================= */
.live-notif{
  position:fixed;bottom:100px;left:24px;
  background:var(--paper);color:var(--ink);
  padding:14px 18px 14px 14px;border-radius:14px;
  box-shadow:var(--shadow-lg);
  display:flex;align-items:center;gap:12px;
  z-index:89;max-width:320px;
  transform:translateX(-120%);transition:transform .5s var(--ease);
  border:1px solid var(--line-soft);
}
.live-notif.show{transform:translateX(0)}
.live-notif-avatar{
  width:42px;height:42px;border-radius:50%;
  background:linear-gradient(160deg,var(--copper),var(--gold));
  display:grid;place-items:center;color:#fff;
  font-family:'Fraunces',serif;font-weight:500;flex-shrink:0;
}
.live-notif-text{font-size:.84rem;line-height:1.4}
.live-notif-text strong{display:block}
.live-notif-time{font-size:.72rem;color:var(--ink-muted);margin-top:2px}
.live-notif-close{
  position:absolute;top:6px;right:6px;
  width:20px;height:20px;border-radius:50%;
  background:var(--line-soft);color:var(--ink-muted);
  display:grid;place-items:center;font-size:.7rem;
  cursor:pointer;
}

/* =========================================
   FOOTER
   ========================================= */
footer{background:var(--ink);color:var(--cream);padding:80px 0 32px}
.footer-grid{display:grid;gap:48px;grid-template-columns:1fr;margin-bottom:60px}
@media (min-width:768px){.footer-grid{grid-template-columns:2fr 1fr 1fr 1fr}}
.footer-brand{display:flex;align-items:center;gap:12px;margin-bottom:20px;font-family:'Fraunces',serif;font-size:1.6rem}
.footer-about{font-size:.94rem;color:rgba(247,241,227,0.6);line-height:1.6;margin-bottom:24px;max-width:380px}
.footer-social{display:flex;gap:12px}
.footer-social a{
  width:38px;height:38px;border-radius:50%;
  border:1px solid rgba(247,241,227,0.2);
  display:grid;place-items:center;transition:all .3s ease;
}
.footer-social a:hover{background:var(--copper);border-color:var(--copper)}
.footer-col h5{
  font-size:.82rem;text-transform:uppercase;letter-spacing:.18em;
  color:var(--gold);margin-bottom:18px;
  font-family:'DM Sans',sans-serif;font-weight:500;
}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:12px}
.footer-col a{color:rgba(247,241,227,0.7);font-size:.94rem;transition:color .2s}
.footer-col a:hover{color:var(--gold)}
.footer-bottom{
  padding-top:28px;border-top:1px solid rgba(247,241,227,0.08);
  display:flex;flex-wrap:wrap;gap:16px;
  justify-content:space-between;align-items:center;
  font-size:.84rem;color:rgba(247,241,227,0.5);
}

/* =========================================
   REVEAL ANIMATIONS
   ========================================= */
.reveal{opacity:0;transform:translateY(24px);transition:all .8s var(--ease)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}
.reveal-delay-4{transition-delay:.4s}

/* =========================================
   RESPONSIVE TWEAKS
   ========================================= */
@media (max-width:1023px){
  .hero-visual{height:520px;margin-top:24px}
  .about-images{height:520px}
  .hero-badge{left:0}
  .hero-stat{right:0}
  .faq-aside{position:static}
}
@media (max-width:640px){
  .vm-grid{grid-template-columns:1fr}
  .hero-visual{height:420px}
  .about-images{height:420px}
  .hero-bullets li{font-size:.92rem}
  .test-text{font-size:.95rem}
  .module-card{grid-template-columns:1fr;gap:16px}
  .live-notif{left:12px;right:12px;max-width:none;bottom:84px}
  .whatsapp-fab,.chat-fab{bottom:84px;right:16px;width:52px;height:52px}
  .whatsapp-fab svg,.chat-fab svg{width:26px;height:26px}
  .sticky-enroll{padding:12px 16px}
  body{padding-bottom:72px}
}
