/* ═══════════════════════════════════════
   CSS VARIABLES
═══════════════════════════════════════ */
:root{
  --bg:#ffffff;
  --bg2:#f5f7ff;
  --bg3:#eef1fa;
  --card:#ffffff;
  --nav-bg:rgba(255,255,255,0.95);
  --nav-shadow:0 2px 30px rgba(26,79,196,0.12);
  --text:#0d1b2a;
  --text2:#3a4f6a;
  --text3:#7a8fa6;
  --border:#dde4f0;
  --border2:#c5d0e8;
  --blue:#1a4fc4;
  --blue2:#0e3a8f;
  --blue3:#dce8ff;
  --blue4:#ebf2ff;
  --red:#e31b23;
  --red2:#b81219;
  --red3:#ffe4e4;
  --gold:#f7c100;
  --gold2:#d4a017;
  --gold3:#fff8dc;
  --green:#22c55e;
  --green3:#dcfce7;
  --grad-hero:linear-gradient(140deg,#060e22 0%,#0e2770 50%,#1a1035 100%);
  --shadow-sm:0 2px 8px rgba(26,79,196,0.08);
  --shadow-md:0 6px 24px rgba(26,79,196,0.12);
  --shadow-lg:0 16px 48px rgba(26,79,196,0.16);
  --shadow-xl:0 24px 72px rgba(26,79,196,0.20);
  --r:14px;
  --r2:20px;
  --tr:all 0.3s cubic-bezier(0.4,0,0.2,1);
}
[data-theme=dark]{
  --bg:#07101f;
  --bg2:#0c1828;
  --bg3:#101e30;
  --card:#0f1e32;
  --nav-bg:rgba(7,16,31,0.96);
  --nav-shadow:0 2px 30px rgba(0,0,0,0.5);
  --text:#e2eaf5;
  --text2:#8aabca;
  --text3:#4e6a85;
  --border:#1a2e45;
  --border2:#1f3550;
  --blue3:#0d1e3a;
  --blue4:#091626;
  --red3:#1f0508;
  --gold3:#1a1200;
  --green3:#051209;
  --shadow-sm:0 2px 8px rgba(0,0,0,0.4);
  --shadow-md:0 6px 24px rgba(0,0,0,0.5);
  --shadow-lg:0 16px 48px rgba(0,0,0,0.6);
  --shadow-xl:0 24px 72px rgba(0,0,0,0.7);
}

/* ═══════════════════════════════════════
   RESET & BASE
═══════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:'Plus Jakarta Sans',sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.6;
  overflow-x:hidden;
  transition:background 0.3s,color 0.3s;
}
img{max-width:100%;display:block;height:auto}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{cursor:pointer;font-family:inherit;border:none;background:none}
input,textarea,select{font-family:inherit}

/* ═══════════════════════════════════════
   UTILITIES
═══════════════════════════════════════ */
.container{max-width:1180px;margin:0 auto;padding:0 24px}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}

.chip{
  display:inline-flex;align-items:center;gap:6px;
  font-size:11px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;
  padding:6px 16px;border-radius:50px;margin-bottom:18px;
}
.chip-blue{background:var(--blue3);color:var(--blue)}
.chip-gold{background:var(--gold3);color:var(--gold2)}
[data-theme=dark] .chip-blue{color:#7aaaff}
[data-theme=dark] .chip-gold{color:var(--gold)}

.section-title{
  font-family:'Playfair Display',serif;
  font-size:clamp(26px,4vw,46px);
  font-weight:900;
  color:var(--text);
  line-height:1.1;
  margin-bottom:14px;
}
.section-sub{
  font-size:16px;color:var(--text2);line-height:1.8;max-width:620px;
}

/* Grids */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}

/* ═══════════════════════════════════════
   BUTTONS
═══════════════════════════════════════ */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  padding:13px 26px;border-radius:10px;
  font-size:15px;font-weight:700;
  transition:var(--tr);border:none;
  font-family:inherit;letter-spacing:0.2px;
  white-space:nowrap;cursor:pointer;
}
.btn-lg{padding:16px 34px;font-size:16px;border-radius:12px}
.btn-blue{
  background:var(--blue);color:#fff;
  box-shadow:0 4px 16px rgba(26,79,196,0.35);
}
.btn-blue:hover{
  background:var(--blue2);
  transform:translateY(-2px);
  box-shadow:0 8px 28px rgba(26,79,196,0.45);
}
.btn-red{
  background:var(--red);color:#fff;
  box-shadow:0 4px 16px rgba(227,27,35,0.35);
}
.btn-red:hover{background:var(--red2);transform:translateY(-2px)}
.btn-gold{background:var(--gold);color:#0d1b2a;font-weight:800}
.btn-gold:hover{background:var(--gold2);transform:translateY(-2px)}
.btn-ghost{
  background:transparent;color:#fff;
  border:2px solid rgba(255,255,255,0.5);
}
.btn-ghost:hover{
  background:rgba(255,255,255,0.1);
  border-color:#fff;
  transform:translateY(-2px);
}
.btn-outline{
  background:transparent;color:var(--blue);
  border:2px solid var(--blue);
}
.btn-outline:hover{background:var(--blue3);transform:translateY(-2px)}
[data-theme=dark] .btn-outline{color:#7aaaff;border-color:#7aaaff}

/* ═══════════════════════════════════════
   CARDS
═══════════════════════════════════════ */
.card{
  background:var(--card);
  border-radius:var(--r2);
  border:1px solid var(--border);
  transition:var(--tr);
}
.card:hover{
  box-shadow:var(--shadow-lg);
  transform:translateY(-6px);
}

/* BADGE */
.badge{
  display:inline-block;padding:4px 12px;
  border-radius:6px;font-size:11px;font-weight:800;
  text-transform:uppercase;letter-spacing:0.8px;
}
.badge-gold{background:var(--gold);color:#0d1b2a}
.badge-blue{background:var(--blue3);color:var(--blue)}
[data-theme=dark] .badge-blue{color:#7aaaff}
.badge-red{background:var(--red3);color:var(--red)}
[data-theme=dark] .badge-red{background:#250508;color:#f87171}

/* Icon boxes */
.ico-box{
  width:52px;height:52px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  font-size:22px;flex-shrink:0;
}
.ic-b{background:var(--blue3);color:var(--blue)}
.ic-g{background:var(--gold3);color:var(--gold2)}
.ic-gr{background:var(--green3);color:#16a34a}
.ic-r{background:var(--red3);color:var(--red)}
[data-theme=dark] .ic-b{color:#7aaaff}
[data-theme=dark] .ic-g{background:#1a1200;color:var(--gold)}
[data-theme=dark] .ic-gr{background:#052010;color:#4ade80}
[data-theme=dark] .ic-r{background:#250508;color:#f87171}

/* ═══════════════════════════════════════
   LOADING SCREEN
═══════════════════════════════════════ */
#loader{
  position:fixed;inset:0;z-index:9999;
  background:var(--grad-hero);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:22px;
  transition:opacity 0.6s,visibility 0.6s;
}
#loader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.loader-logo{
  width:110px;height:110px;object-fit:contain;
  animation:pulse-scale 1.4s ease-in-out infinite;
  filter:drop-shadow(0 4px 24px rgba(247,193,0,0.4));
}
@keyframes pulse-scale{0%,100%{transform:scale(1)}50%{transform:scale(1.1)}}
.loader-name{
  font-family:'Playfair Display',serif;
  font-size:22px;font-weight:900;color:#fff;
  letter-spacing:0.5px;text-align:center;
}
.loader-name small{
  display:block;font-family:'Plus Jakarta Sans',sans-serif;
  font-size:12px;font-weight:500;color:rgba(255,255,255,0.6);
  letter-spacing:2px;text-transform:uppercase;margin-top:3px;
}
.loader-bar{
  width:180px;height:3px;
  background:rgba(255,255,255,0.1);
  border-radius:2px;overflow:hidden;
}
.loader-bar-fill{
  height:100%;
  background:linear-gradient(90deg,var(--gold),var(--blue),var(--red));
  animation:fill-bar 1.5s ease forwards;
}
@keyframes fill-bar{from{width:0}to{width:100%}}

/* ═══════════════════════════════════════
   NAVBAR
═══════════════════════════════════════ */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  transition:var(--tr);
}
.navbar.scrolled{
  background:var(--nav-bg);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  box-shadow:var(--nav-shadow);
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:72px;padding:0 28px;max-width:1180px;margin:0 auto;
}
.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.nav-logo-img{
  width:52px;height:52px;object-fit:contain;
  filter:drop-shadow(0 2px 8px rgba(247,193,0,0.3));
  transition:var(--tr);
}
.nav-logo-img:hover{filter:drop-shadow(0 4px 16px rgba(247,193,0,0.5))}
.nav-logo-text{
  font-size:15px;font-weight:800;color:#fff;line-height:1.2;
  transition:color 0.3s;
}
.nav-logo-text small{
  display:block;font-size:10px;font-weight:500;
  opacity:0.65;letter-spacing:1px;text-transform:uppercase;
}
.navbar.scrolled .nav-logo-text{color:var(--text)}

.nav-links{display:flex;align-items:center;gap:4px}
.nav-link{
  position:relative;
  font-size:14px;font-weight:600;
  color:rgba(255,255,255,0.82);
  padding:7px 13px;border-radius:8px;
  transition:var(--tr);cursor:pointer;
}
.navbar.scrolled .nav-link{color:var(--text2)}
.nav-link:hover,.nav-link.active{
  color:#fff;background:rgba(255,255,255,0.1);
}
.navbar.scrolled .nav-link:hover,.navbar.scrolled .nav-link.active{
  color:var(--blue);background:var(--blue3);
}
.nav-cta{
  background:var(--red) !important;
  color:#fff !important;
  padding:9px 20px !important;
  border-radius:9px;
  font-weight:700 !important;
  box-shadow:0 4px 14px rgba(227,27,35,0.4);
}
.nav-cta:hover{
  background:var(--red2) !important;
  transform:translateY(-1px) !important;
}
.nav-right{display:flex;align-items:center;gap:12px}

/* Dark mode toggle */
.theme-btn{
  width:44px;height:26px;
  background:rgba(255,255,255,0.15);
  border-radius:50px;position:relative;
  transition:var(--tr);
  border:1px solid rgba(255,255,255,0.25);
  flex-shrink:0;cursor:pointer;
}
.navbar.scrolled .theme-btn{
  background:var(--bg3);
  border-color:var(--border);
}
.theme-btn::after{
  content:'';position:absolute;top:4px;left:4px;
  width:16px;height:16px;border-radius:50%;
  background:#fff;
  transition:transform 0.3s,background 0.3s;
}
[data-theme=dark] .theme-btn::after{
  transform:translateX(18px);background:var(--gold);
}
.theme-icon{
  font-size:10px;position:absolute;
  top:50%;transform:translateY(-50%);
  transition:opacity 0.3s;
}
.icon-sun{left:6px;color:var(--gold)}
.icon-moon{right:6px;color:#aaa}
[data-theme=light] .icon-moon{opacity:0.3}
[data-theme=dark] .icon-sun{opacity:0.3}

/* Hamburger */
.hamburger{
  display:none;flex-direction:column;gap:5px;
  padding:5px;background:none;border:none;
}
.hamburger span{
  width:22px;height:2px;
  background:#fff;border-radius:2px;
  transition:var(--tr);display:block;
}
.navbar.scrolled .hamburger span{background:var(--text)}

/* Mobile nav */
.mobile-nav{
  display:none;position:fixed;
  top:72px;left:0;right:0;
  background:var(--card);
  padding:20px 24px;
  border-top:2px solid var(--blue);
  box-shadow:var(--shadow-lg);
  z-index:999;
  flex-direction:column;gap:4px;
  animation:slideDown 0.2s ease;
}
@keyframes slideDown{
  from{opacity:0;transform:translateY(-10px)}
  to{opacity:1;transform:translateY(0)}
}
.mobile-nav.open{display:flex}
.mobile-nav .nav-link{
  color:var(--text2) !important;
  background:transparent;padding:11px 14px;
}
.mobile-nav .nav-link:hover{
  color:var(--blue) !important;
  background:var(--blue3) !important;
}
.mobile-nav .nav-cta{
  color:#fff !important;
  background:var(--red) !important;
  margin-top:8px;
}

/* ═══════════════════════════════════════
   PAGE VIEW SYSTEM
═══════════════════════════════════════ */
.page-view{display:none}
.page-view.active{display:block;animation:pageFadeIn 0.4s ease}
@keyframes pageFadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ═══════════════════════════════════════
   HERO
═══════════════════════════════════════ */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;align-items:center;
  background:var(--grad-hero);
  overflow:hidden;
}
.hero-bg{position:absolute;inset:0}
.hero-bg-img{
  width:100%;height:100%;
  object-fit:cover;
  opacity:0.15;
  filter:saturate(0.5);
}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(
    to right,
    rgba(6,14,34,0.97) 0%,
    rgba(6,14,34,0.8) 50%,
    rgba(6,14,34,0.4) 100%
  );
}
/* Floating particles */
.particles{position:absolute;inset:0;pointer-events:none}
.p-dot{
  position:absolute;border-radius:50%;
  background:rgba(255,255,255,0.15);
  animation:float-dot var(--d,6s) ease-in-out infinite var(--dl,0s);
}
@keyframes float-dot{
  0%,100%{transform:translateY(0) rotate(0deg);opacity:0.4}
  50%{transform:translateY(-24px) rotate(180deg);opacity:0.9}
}

.hero-content{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1fr 1fr;
  gap:72px;align-items:center;
  padding:130px 28px 80px;
  max-width:1180px;margin:0 auto;width:100%;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(247,193,0,0.12);
  border:1px solid rgba(247,193,0,0.3);
  border-radius:50px;padding:8px 18px;
  font-size:12px;font-weight:700;
  color:var(--gold);letter-spacing:0.5px;
  margin-bottom:22px;
}
.hero-dot{
  width:8px;height:8px;
  background:#22c55e;border-radius:50%;
  animation:pulse-dot 2s infinite;
}
@keyframes pulse-dot{
  0%,100%{transform:scale(1);opacity:1}
  50%{transform:scale(1.5);opacity:0.6}
}
.hero-h1{
  font-family:'Playfair Display',serif;
  font-size:clamp(36px,5vw,66px);
  font-weight:900;color:#fff;line-height:1.05;
  margin-bottom:20px;
}
.hero-h1 .hl-red{color:var(--red)}
.hero-h1 .hl-gold,.hl-gold{color:var(--gold)}
.hero-p{
  font-size:17px;color:rgba(255,255,255,0.72);
  line-height:1.8;margin-bottom:34px;max-width:480px;
}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:44px}
.hero-stats{
  display:flex;gap:36px;
  padding-top:26px;
  border-top:1px solid rgba(255,255,255,0.1);
  flex-wrap:wrap;
}
.hstat-num{
  font-size:32px;font-weight:900;
  color:#fff;line-height:1;
}
.hstat-num span{color:var(--gold)}
.hstat-lbl{font-size:12px;color:rgba(255,255,255,0.5);margin-top:4px}

/* Hero visual */
.hero-visual{position:relative}
.hero-img-wrap{
  border-radius:24px;overflow:hidden;
  position:relative;
  box-shadow:0 24px 80px rgba(0,0,0,0.65);
  border:1px solid rgba(255,255,255,0.1);
}
.hero-img-wrap img{
  width:100%;height:440px;object-fit:cover;
  display:block;
}
.hero-img-grad{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(6,14,34,0.85) 0%,transparent 55%);
}
.hero-img-caption{
  position:absolute;bottom:22px;left:22px;right:22px;
  background:rgba(255,255,255,0.08);
  backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,0.15);
  border-radius:14px;padding:14px 18px;
  display:flex;align-items:center;gap:12px;
}
.hic-icon{
  width:40px;height:40px;background:var(--blue);
  border-radius:10px;display:flex;align-items:center;
  justify-content:center;color:#fff;font-size:18px;flex-shrink:0;
}
.hic-title{font-size:14px;font-weight:700;color:#fff}
.hic-sub{font-size:12px;color:rgba(255,255,255,0.6)}

/* Floating cards */
.hero-float{
  position:absolute;
  background:var(--card);border-radius:16px;
  padding:12px 16px;
  box-shadow:0 20px 50px rgba(0,0,0,0.4);
  display:flex;align-items:center;gap:12px;
  border:1px solid var(--border);
  animation:floatEl 3.5s ease-in-out infinite;
}
@keyframes floatEl{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-10px)}
}
.hero-float-1{top:-20px;right:-24px;animation-delay:0s}
.hero-float-2{bottom:-18px;left:-24px;animation-delay:1.8s}
.hf-icon{
  width:38px;height:38px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  font-size:16px;flex-shrink:0;
}
.hf-green{background:#dcfce7;color:#16a34a}
.hf-gold{background:#fef9c3;color:#ca8a04}
[data-theme=dark] .hf-green{background:#052010;color:#4ade80}
[data-theme=dark] .hf-gold{background:#1a1200;color:var(--gold)}
.hf-title{font-size:13px;font-weight:700;color:var(--text)}
.hf-sub{font-size:11px;color:var(--text3)}

/* Trust bar */
.trust-bar{
  position:absolute;bottom:0;left:0;right:0;
  background:rgba(255,255,255,0.04);
  backdrop-filter:blur(8px);
  border-top:1px solid rgba(255,255,255,0.07);
  padding:18px 0;
}
.trust-inner{
  display:flex;align-items:center;
  justify-content:center;gap:36px;flex-wrap:wrap;
}
.trust-item{
  display:flex;align-items:center;gap:8px;
  font-size:13px;font-weight:600;
  color:rgba(255,255,255,0.75);
}
.trust-item i{color:var(--gold);font-size:14px}
.trust-sep{width:1px;height:18px;background:rgba(255,255,255,0.12)}

/* ═══════════════════════════════════════
   SECTION BASE
═══════════════════════════════════════ */
.sec{padding:100px 0}
.sec-alt{background:var(--bg2)}
.sec-alt2{background:var(--bg3)}
.sec-header{margin-bottom:60px}
.sec-header.center{text-align:center}
.sec-header.center .section-sub{margin:0 auto}

/* ═══════════════════════════════════════
   STATS SECTION
═══════════════════════════════════════ */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.stat-card{
  background:var(--card);border-radius:var(--r2);
  border:1px solid var(--border);
  padding:32px 24px;text-align:center;
  position:relative;overflow:hidden;
  transition:var(--tr);
}
.stat-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
}
.stat-card:nth-child(1)::before{background:var(--blue)}
.stat-card:nth-child(2)::before{background:var(--gold)}
.stat-card:nth-child(3)::before{background:var(--green)}
.stat-card:nth-child(4)::before{background:var(--red)}
.stat-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.stat-ico{
  width:56px;height:56px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  font-size:22px;margin:0 auto 18px;
}
.stat-num{
  font-size:44px;font-weight:900;
  color:var(--text);line-height:1;margin-bottom:8px;
}
.stat-lbl{font-size:14px;color:var(--text3);font-weight:600}

/* ═══════════════════════════════════════
   IMAGE SHOWCASE
═══════════════════════════════════════ */
.img-showcase{
  display:grid;
  grid-template-columns:1.2fr 1fr 1fr;
  grid-template-rows:240px 240px;
  gap:16px;
  border-radius:var(--r2);overflow:hidden;
}
.img-tile{
  position:relative;overflow:hidden;border-radius:var(--r);
  cursor:pointer;
}
.img-tile img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 0.5s ease;
}
.img-tile:hover img{transform:scale(1.06)}
.img-tile:first-child{grid-row:span 2}
.img-tile-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(6,14,34,0.75) 0%,transparent 50%);
  opacity:0;transition:opacity 0.3s;
}
.img-tile:hover .img-tile-overlay{opacity:1}
.img-tile-label{
  position:absolute;bottom:14px;left:14px;
  font-size:12px;font-weight:700;color:#fff;
  opacity:0;transition:opacity 0.3s;
}
.img-tile:hover .img-tile-label{opacity:1}

/* ═══════════════════════════════════════
   COURSE CARDS
═══════════════════════════════════════ */
.courses-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.course-card{
  border-radius:var(--r2);overflow:hidden;
  border:1px solid var(--border);
  transition:var(--tr);background:var(--card);
}
.course-card:hover{
  transform:translateY(-8px);
  box-shadow:var(--shadow-xl);
}
.cc-head{
  padding:36px 32px;position:relative;
  overflow:hidden;
}
.cc-head-tef{background:linear-gradient(135deg,#1a4fc4 0%,#0e2a6e 100%)}
.cc-head-tcf{background:linear-gradient(135deg,#c41a1a 0%,#7a0e0e 100%)}
.cc-head-img{
  position:absolute;inset:0;opacity:0.12;
}
.cc-head-img img{width:100%;height:100%;object-fit:cover}
.cc-head-content{position:relative;z-index:1}
.cc-badge{
  position:absolute;top:16px;right:16px;z-index:2;
}
.cc-icon{
  width:60px;height:60px;
  background:rgba(255,255,255,0.15);
  border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  font-size:26px;color:#fff;margin-bottom:16px;
}
.cc-title{font-size:26px;font-weight:800;color:#fff;margin-bottom:4px}
.cc-sub{font-size:13px;color:rgba(255,255,255,0.65)}
.cc-body{padding:28px 32px}
.cc-desc{font-size:14px;color:var(--text2);line-height:1.75;margin-bottom:20px}
.cc-features{display:flex;flex-direction:column;gap:10px;margin-bottom:22px}
.cc-feat{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--text)}
.cc-feat-ico{
  width:20px;height:20px;
  background:var(--green3);color:#16a34a;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:10px;flex-shrink:0;
}
[data-theme=dark] .cc-feat-ico{background:#052010;color:#4ade80}
.cc-modes{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px}
.mode-pill{
  display:flex;align-items:center;gap:5px;
  padding:5px 12px;border-radius:8px;
  font-size:12px;font-weight:700;
  border:1px solid var(--border);
  color:var(--text2);background:var(--bg2);
}
.mode-pill i{color:var(--blue);font-size:11px}
[data-theme=dark] .mode-pill i{color:#7aaaff}

/* ═══════════════════════════════════════
   HOW IT WORKS
═══════════════════════════════════════ */
.steps-wrap{position:relative}
.steps-line{
  position:absolute;top:44px;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--blue),var(--gold),var(--red));
  z-index:0;
}
.steps{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:28px;position:relative;z-index:1;
}
.step{text-align:center}
.step-num{
  width:88px;height:88px;border-radius:50%;
  margin:0 auto 22px;
  background:var(--card);
  border:3px solid var(--blue);
  display:flex;align-items:center;justify-content:center;
  font-size:28px;font-weight:900;color:var(--blue);
  box-shadow:0 0 0 10px var(--blue4);
  transition:var(--tr);
}
.step:hover .step-num{background:var(--blue);color:#fff}
.step-title{font-size:16px;font-weight:800;color:var(--text);margin-bottom:8px}
.step-desc{font-size:13px;color:var(--text2);line-height:1.65}

/* ═══════════════════════════════════════
   WHY FRENCH DARK SECTION
═══════════════════════════════════════ */
.why-section{
  padding:100px 0;
  background:linear-gradient(140deg,#060e22 0%,#0e2770 55%,#1a0808 100%);
  position:relative;overflow:hidden;
}
[data-theme=dark] .why-section{
  background:linear-gradient(140deg,#02050c 0%,#060f26 55%,#0a0303 100%);
}
.why-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:72px;align-items:center;
}
.why-label{
  background:rgba(247,193,0,0.15);
  border:1px solid rgba(247,193,0,0.3);
  color:var(--gold);
}
.why-title{color:#fff}
.why-sub{color:rgba(255,255,255,0.6);max-width:480px}
.why-pts{display:flex;flex-direction:column;gap:24px;margin-top:32px}
.why-pt{display:flex;gap:14px;align-items:flex-start}
.why-pt-ico{
  width:46px;height:46px;
  background:rgba(26,79,196,0.3);
  border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  color:#7aaaff;font-size:18px;flex-shrink:0;
}
.why-pt-title{font-size:15px;font-weight:700;color:#fff;margin-bottom:3px}
.why-pt-desc{font-size:13px;color:rgba(255,255,255,0.5);line-height:1.65}
.why-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.why-card{
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:18px;padding:24px 20px;
  transition:var(--tr);
}
.why-card:hover{
  background:rgba(255,255,255,0.09);
  transform:translateY(-4px);
}
.why-card.w-blue{
  background:var(--blue);
  border-color:var(--blue);
  grid-column:span 2;
}
.why-card.w-red{
  background:var(--red);
  border-color:var(--red);
}
.wc-num{font-size:38px;font-weight:900;color:var(--gold);margin-bottom:6px}
.why-card.w-blue .wc-num{color:rgba(255,255,255,0.9)}
.wc-title{font-size:13px;font-weight:700;color:rgba(255,255,255,0.9);margin-bottom:4px}
.wc-desc{font-size:12px;color:rgba(255,255,255,0.45)}
.why-card.w-blue .wc-desc,.why-card.w-red .wc-desc{color:rgba(255,255,255,0.75)}

/* ═══════════════════════════════════════
   INSTAGRAM REELS
═══════════════════════════════════════ */
.reels-section{padding:100px 0;background:var(--bg2)}
.reels-scroll-wrap{
  overflow-x:auto;
  padding-bottom:16px;
  scrollbar-width:thin;
  scrollbar-color:var(--blue) var(--bg3);
  -webkit-overflow-scrolling:touch;
}
.reels-scroll-wrap::-webkit-scrollbar{height:4px}
.reels-scroll-wrap::-webkit-scrollbar-track{background:var(--bg3)}
.reels-scroll-wrap::-webkit-scrollbar-thumb{background:var(--blue);border-radius:2px}
.reels-row{
  display:flex;gap:20px;
  min-width:max-content;
  padding:0 4px 0 0;
}
.reel-card{
  width:270px;
  border-radius:18px;overflow:hidden;
  border:1px solid var(--border);
  background:var(--card);
  transition:var(--tr);flex-shrink:0;
}
.reel-card:hover{
  box-shadow:var(--shadow-lg);
  transform:translateY(-4px);
}
.reel-embed-wrap{width:100%;overflow:hidden}
.reel-embed-wrap iframe{width:100% !important;min-height:480px !important;border:none}
.reel-placeholder{
  aspect-ratio:9/16;
  background:linear-gradient(135deg,var(--blue3),var(--bg3));
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  gap:14px;color:var(--text2);
  text-align:center;padding:20px;
}
.reel-placeholder i{font-size:40px;color:var(--blue);opacity:0.6}
[data-theme=dark] .reel-placeholder i{color:#7aaaff}
.reel-placeholder span{font-size:12px;font-weight:600;line-height:1.5}
.reel-footer{
  padding:14px 16px;
  border-top:1px solid var(--border);
}
.reel-footer a{
  display:inline-flex;align-items:center;gap:6px;
  font-size:12px;font-weight:700;
  color:var(--blue);
}
[data-theme=dark] .reel-footer a{color:#7aaaff}
.reel-footer a:hover{text-decoration:underline}

/* IG banner */
.ig-cta-banner{
  margin-top:40px;
  background:linear-gradient(135deg,#833ab4,#e1306c,#fd1d1d);
  border-radius:var(--r2);padding:32px;
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;flex-wrap:wrap;
}
.ig-cta-left{display:flex;align-items:center;gap:16px}
.ig-cta-icon{
  width:56px;height:56px;border-radius:14px;
  background:rgba(255,255,255,0.2);
  display:flex;align-items:center;justify-content:center;
  font-size:26px;color:#fff;flex-shrink:0;
}
.ig-cta-title{font-size:19px;font-weight:800;color:#fff;margin-bottom:3px}
.ig-cta-sub{font-size:13px;color:rgba(255,255,255,0.75)}
.btn-white{
  background:#fff;color:#e1306c;font-weight:800;
  padding:13px 24px;border-radius:10px;
  display:inline-flex;align-items:center;gap:8px;
  transition:var(--tr);white-space:nowrap;
}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.2)}

/* ═══════════════════════════════════════
   TESTIMONIALS
═══════════════════════════════════════ */
.testi-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.testi-card{
  padding:28px;border-radius:var(--r2);
  border:1px solid var(--border);
  background:var(--card);
  transition:var(--tr);
  position:relative;overflow:hidden;
}
.testi-card::before{
  content:'"';position:absolute;
  top:-10px;right:18px;
  font-family:'Playfair Display',serif;
  font-size:100px;color:var(--blue);
  opacity:0.07;line-height:1;
}
.testi-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.testi-card.feat{
  background:linear-gradient(135deg,var(--blue),#0e2a6e);
  border-color:var(--blue);
  grid-row:span 2;
}
.testi-card.feat::before{color:rgba(255,255,255,0.12)}
.testi-stars{display:flex;gap:3px;margin-bottom:14px}
.testi-stars i{color:var(--gold);font-size:13px}
.testi-text{
  font-size:14px;color:var(--text2);
  line-height:1.8;margin-bottom:16px;
}
.testi-card.feat .testi-text{color:rgba(255,255,255,0.87)}
.testi-result{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--bg2);border-radius:8px;
  padding:7px 12px;
  font-size:12px;font-weight:700;
  color:var(--text);margin-bottom:16px;
}
.testi-card.feat .testi-result{background:rgba(255,255,255,0.15);color:#fff}
.testi-result i{color:var(--green)}
.testi-author{
  display:flex;align-items:center;gap:10px;
  padding-top:16px;border-top:1px solid var(--border);
}
.testi-card.feat .testi-author{border-top-color:rgba(255,255,255,0.15)}
.tav{
  width:42px;height:42px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:14px;font-weight:800;color:#fff;flex-shrink:0;
}
.av1{background:linear-gradient(135deg,#f59e0b,#d97706)}
.av2{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}
.av3{background:linear-gradient(135deg,#10b981,#059669)}
.av4{background:linear-gradient(135deg,#ef4444,#dc2626)}
.av5{background:linear-gradient(135deg,#3b82f6,#1d4ed8)}
.tav-name{font-size:13px;font-weight:700;color:var(--text)}
.testi-card.feat .tav-name{color:#fff}
.tav-role{font-size:11px;color:var(--text3)}
.testi-card.feat .tav-role{color:rgba(255,255,255,0.55)}

/* ═══════════════════════════════════════
   INSTRUCTOR / ABOUT
═══════════════════════════════════════ */
.instructor-grid{
  display:grid;grid-template-columns:1fr 1.5fr;
  gap:72px;align-items:center;
}
.instructor-img-wrap{position:relative}
.instructor-img{
  border-radius:var(--r2);overflow:hidden;
  box-shadow:var(--shadow-xl);
  position:relative;
}
.instructor-img img{width:100%;height:520px;object-fit:cover}
.instructor-badge{
  position:absolute;bottom:-16px;right:-16px;
  background:var(--card);border-radius:14px;
  padding:14px 18px;
  box-shadow:var(--shadow-lg);
  border:1px solid var(--border);
  display:flex;align-items:center;gap:10px;
}
.instructor-badge i{color:var(--gold);font-size:20px}
.ib-title{font-size:14px;font-weight:800;color:var(--text)}
.ib-sub{font-size:12px;color:var(--text3)}
.instructor-creds{display:flex;flex-direction:column;gap:14px;margin:28px 0}
.cred-item{display:flex;align-items:center;gap:12px;font-size:14px;color:var(--text)}
.cred-ico{
  width:36px;height:36px;
  background:var(--blue3);border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  color:var(--blue);font-size:14px;flex-shrink:0;
}
[data-theme=dark] .cred-ico{color:#7aaaff}
.instructor-socials{display:flex;gap:10px;margin-top:24px}
.soc-btn{
  width:42px;height:42px;border-radius:10px;
  background:var(--bg3);
  display:flex;align-items:center;justify-content:center;
  color:var(--text2);font-size:16px;
  transition:var(--tr);border:1px solid var(--border);
}
.soc-btn:hover{
  background:var(--blue);color:#fff;
  border-color:var(--blue);transform:translateY(-3px);
}
.soc-ig:hover{
  background:linear-gradient(135deg,#833ab4,#e1306c);
  border-color:#e1306c;
}

/* ═══════════════════════════════════════
   CTA BANNER
═══════════════════════════════════════ */
.cta-banner{
  padding:90px 0;
  background:linear-gradient(135deg,#060e22 0%,#1a4fc4 50%,#b81219 100%);
  text-align:center;position:relative;overflow:hidden;
}
.cta-banner::before{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23fff' fill-opacity='0.025'%3E%3Cpath d='M30 30v-12h-2v12h-12v2h12v12h2v-12h12v-2z'/%3E%3C/g%3E%3C/svg%3E") repeat;
}
.cta-inner{position:relative;z-index:1;max-width:700px;margin:0 auto}
.cta-title{
  font-family:'Playfair Display',serif;
  font-size:clamp(26px,4vw,50px);
  font-weight:900;color:#fff;margin-bottom:14px;
}
.cta-sub{font-size:17px;color:rgba(255,255,255,0.7);margin-bottom:36px}
.cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ═══════════════════════════════════════
   FAQ
═══════════════════════════════════════ */
.faq-wrap{
  display:grid;grid-template-columns:1fr 1.5fr;
  gap:72px;align-items:start;
}
.faq-sticky{position:sticky;top:90px}
.faq-contact-box{
  background:linear-gradient(135deg,var(--blue),#0e2a6e);
  border-radius:18px;padding:28px;color:#fff;margin-top:24px;
}
.faq-contact-box p{font-size:13px;opacity:0.75;margin-bottom:16px}
.faq-list{display:flex;flex-direction:column;gap:10px}
.faq-item{
  background:var(--card);border-radius:14px;
  border:1px solid var(--border);overflow:hidden;
  transition:var(--tr);
}
.faq-item:hover{box-shadow:var(--shadow-md)}
.faq-q{
  display:flex;justify-content:space-between;
  align-items:center;padding:18px 22px;
  cursor:pointer;font-weight:700;
  font-size:14px;color:var(--text);gap:14px;
}
.faq-q i{color:var(--blue);transition:transform 0.3s;flex-shrink:0}
[data-theme=dark] .faq-q i{color:#7aaaff}
.faq-item.open .faq-q i{transform:rotate(45deg)}
.faq-a{
  display:none;padding:0 22px 18px;
  font-size:13px;color:var(--text2);line-height:1.75;
}
.faq-item.open .faq-a{display:block}
.faq-item.open{
  border-color:var(--blue);
  box-shadow:0 0 0 3px var(--blue3);
}
[data-theme=dark] .faq-item.open{box-shadow:0 0 0 3px rgba(26,79,196,0.2)}

/* ═══════════════════════════════════════
   CONTACT
═══════════════════════════════════════ */
.contact-grid{
  display:grid;grid-template-columns:1fr 1.4fr;
  gap:72px;align-items:start;
}
.ig-highlight{
  background:linear-gradient(135deg,rgba(131,58,180,0.12),rgba(225,48,108,0.12));
  border:1px solid rgba(225,48,108,0.25);
  border-radius:16px;padding:22px;margin-bottom:24px;
  display:flex;align-items:center;gap:14px;
}
.ig-hl-icon{
  width:54px;height:54px;border-radius:14px;flex-shrink:0;
  background:linear-gradient(135deg,#833ab4,#e1306c,#fd1d1d);
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:26px;
}
.ig-hl-title{font-size:14px;font-weight:800;color:var(--text);margin-bottom:3px}
.ig-hl-handle{font-weight:700;color:#e1306c}
.ig-hl-sub{font-size:12px;color:var(--text2)}
.contact-methods{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}
.cmethod{display:flex;align-items:center;gap:14px}
.cm-ico{
  width:48px;height:48px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-size:18px;flex-shrink:0;
}
.cm-blu{background:var(--blue3);color:var(--blue)}
.cm-ig{background:linear-gradient(135deg,#833ab4,#e1306c);color:#fff}
.cm-ph{background:var(--red3);color:var(--red)}
.cm-loc{background:var(--green3);color:#16a34a}
[data-theme=dark] .cm-blu{color:#7aaaff}
[data-theme=dark] .cm-ph{background:#250508;color:#f87171}
[data-theme=dark] .cm-loc{background:#052010;color:#4ade80}
.cm-lbl{
  font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:0.8px;color:var(--text3);margin-bottom:2px;
}
.cm-val{font-size:14px;font-weight:700;color:var(--text)}
.cm-val a{color:inherit;transition:color 0.2s}
.cm-val a:hover{color:var(--blue)}

/* Form */
.form-box{
  background:var(--bg2);border-radius:var(--r2);
  padding:40px;border:1px solid var(--border);
}
.form-title{font-size:20px;font-weight:800;color:var(--text);margin-bottom:24px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-g{margin-bottom:18px}
.form-lbl{
  display:block;font-size:12px;font-weight:700;
  color:var(--text2);margin-bottom:7px;
  text-transform:uppercase;letter-spacing:0.5px;
}
.form-inp,.form-sel,.form-ta{
  width:100%;padding:12px 14px;
  border:1.5px solid var(--border2);
  border-radius:10px;font-size:14px;
  font-family:inherit;color:var(--text);
  background:var(--card);transition:var(--tr);
  outline:none;appearance:none;
}
.form-inp:focus,.form-sel:focus,.form-ta:focus{
  border-color:var(--blue);
  box-shadow:0 0 0 3px var(--blue3);
}
.form-ta{resize:vertical;min-height:110px}
.form-btn{
  width:100%;padding:15px;
  background:var(--blue);color:#fff;
  border:none;border-radius:10px;
  font-size:15px;font-weight:700;
  font-family:inherit;cursor:pointer;
  transition:var(--tr);
  display:flex;align-items:center;justify-content:center;gap:8px;
}
.form-btn:hover{
  background:var(--blue2);
  transform:translateY(-2px);
  box-shadow:0 8px 24px rgba(26,79,196,0.4);
}
.form-note{text-align:center;font-size:11px;color:var(--text3);margin-top:10px}
.form-success{
  display:none;background:var(--green3);
  border-radius:14px;padding:28px;
  text-align:center;margin-top:16px;
}
[data-theme=dark] .form-success{background:#052010}
.form-success-emoji{font-size:44px;margin-bottom:12px}
.form-success-title{font-size:18px;font-weight:800;color:#065f46;margin-bottom:8px}
[data-theme=dark] .form-success-title{color:#4ade80}
.form-success-sub{font-size:14px;color:#047857}
[data-theme=dark] .form-success-sub{color:#86efac}

/* ═══════════════════════════════════════
   PAGE HERO (sub-pages)
═══════════════════════════════════════ */
.page-hero{
  padding:130px 0 70px;
  background:var(--grad-hero);
  position:relative;overflow:hidden;
}
.page-hero-content{position:relative;z-index:2;text-align:center}
.page-hero-chip{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(247,193,0,0.15);
  border:1px solid rgba(247,193,0,0.3);
  border-radius:50px;padding:8px 20px;
  font-size:12px;font-weight:700;
  color:var(--gold);letter-spacing:0.5px;
  margin-bottom:20px;
}
.page-hero h1{
  font-family:'Playfair Display',serif;
  font-size:clamp(32px,5vw,60px);
  font-weight:900;color:#fff;
  margin-bottom:18px;line-height:1.1;
}
.page-hero p{
  font-size:17px;color:rgba(255,255,255,0.72);
  max-width:580px;margin:0 auto;line-height:1.8;
}

/* ═══════════════════════════════════════
   FOOTER
═══════════════════════════════════════ */
footer{
  background:#060e22;
  padding:72px 0 0;
  position:relative;overflow:hidden;
}
[data-theme=dark] footer{background:#030810}
.footer-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:48px;padding-bottom:56px;
}
.footer-brand-logo{
  display:flex;align-items:center;gap:10px;
  margin-bottom:16px;
}
.footer-brand-logo img{
  width:54px;height:54px;object-fit:contain;
  filter:drop-shadow(0 2px 8px rgba(247,193,0,0.3));
}
.footer-brand-name{
  font-size:15px;font-weight:800;color:#fff;line-height:1.2;
}
.footer-brand-name small{
  display:block;font-size:10px;font-weight:500;
  opacity:0.6;letter-spacing:1px;text-transform:uppercase;
}
.footer-desc{
  font-size:13px;color:rgba(255,255,255,0.5);
  line-height:1.75;margin-bottom:20px;
}
.footer-social{display:flex;gap:8px}
.footer-soc{
  width:36px;height:36px;border-radius:9px;
  background:rgba(255,255,255,0.06);
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,0.5);font-size:15px;
  transition:var(--tr);border:1px solid rgba(255,255,255,0.08);
}
.footer-soc:hover{
  background:var(--blue);color:#fff;
  border-color:var(--blue);transform:translateY(-3px);
}
.footer-soc.ig:hover{
  background:linear-gradient(135deg,#833ab4,#e1306c);
  border-color:#e1306c;
}
.footer-col-title{
  font-size:14px;font-weight:800;color:#fff;
  margin-bottom:18px;letter-spacing:0.3px;
}
.footer-links{display:flex;flex-direction:column;gap:10px}
.footer-links a{
  font-size:13px;color:rgba(255,255,255,0.5);
  transition:color 0.2s;
}
.footer-links a:hover{color:#fff}
.footer-contact-items{display:flex;flex-direction:column;gap:12px}
.footer-ci{display:flex;align-items:center;gap:10px}
.footer-ci i{
  width:30px;height:30px;border-radius:7px;
  background:rgba(255,255,255,0.06);
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,0.5);font-size:13px;flex-shrink:0;
}
.footer-ci span{font-size:13px;color:rgba(255,255,255,0.5)}
.footer-ci a{font-size:13px;color:rgba(255,255,255,0.5);transition:color 0.2s}
.footer-ci a:hover{color:#fff}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,0.06);
  padding:22px 0;
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:12px;
}
.footer-bottom p{font-size:12px;color:rgba(255,255,255,0.35)}
.footer-bottom-links{display:flex;gap:20px}
.footer-bottom-links a{font-size:12px;color:rgba(255,255,255,0.35);transition:color 0.2s}
.footer-bottom-links a:hover{color:rgba(255,255,255,0.7)}

/* ═══════════════════════════════════════
   REVEAL ANIMATION
═══════════════════════════════════════ */
.reveal{
  opacity:0;
  transform:translateY(28px);
  transition:opacity 0.7s ease,transform 0.7s ease;
}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ═══════════════════════════════════════
   STICKY PHONE BUTTON
═══════════════════════════════════════ */
.sticky-cta{
  position:fixed;bottom:24px;right:24px;z-index:998;
  display:flex;flex-direction:column;gap:10px;
  align-items:flex-end;
}
.sticky-btn{
  display:flex;align-items:center;gap:10px;
  padding:12px 20px;border-radius:50px;
  font-size:13px;font-weight:700;color:#fff;
  box-shadow:0 8px 28px rgba(0,0,0,0.3);
  transition:var(--tr);white-space:nowrap;
}
.sticky-btn:hover{transform:translateY(-3px);box-shadow:0 14px 38px rgba(0,0,0,0.4)}
.sticky-ig{background:linear-gradient(135deg,#833ab4,#e1306c,#fd1d1d)}
.sticky-ph{background:var(--red)}
.sticky-btn i{font-size:16px}

/* ═══════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════ */
@media(max-width:1024px){
  .hero-content{grid-template-columns:1fr;gap:48px}
  .hero-visual{display:none}
  .hero-content{padding:120px 28px 60px}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr 1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .courses-grid{grid-template-columns:1fr}
  .why-grid{grid-template-columns:1fr}
  .instructor-grid{grid-template-columns:1fr}
  .instructor-img-wrap{max-width:440px}
  .contact-grid{grid-template-columns:1fr}
  .faq-wrap{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr 1fr}
  .steps-line{display:none}
  .img-showcase{grid-template-columns:1fr 1fr;grid-template-rows:200px 200px}
  .img-tile:first-child{grid-row:span 2}
}
@media(max-width:768px){
  .nav-links{display:none}
  .hamburger{display:flex}
  .hero-content{padding:110px 20px 50px}
  .sec{padding:70px 0}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .testi-grid{grid-template-columns:1fr}
  .testi-card.feat{grid-row:span 1}
  .why-cards{grid-template-columns:1fr}
  .why-card.w-blue{grid-column:span 1}
  .footer-grid{grid-template-columns:1fr}
  .cta-btns{flex-direction:column;align-items:center}
  .hero-btns{flex-direction:column;align-items:flex-start}
  .hero-stats{gap:20px}
  .ig-cta-banner{flex-direction:column;text-align:center}
  .ig-cta-left{flex-direction:column;text-align:center}
  .img-showcase{grid-template-columns:1fr 1fr;grid-template-rows:160px 160px}
  .img-tile:first-child{grid-column:span 2;grid-row:span 1}
  .sticky-cta{bottom:16px;right:16px}
  .sticky-btn span{display:none}
  .sticky-btn{padding:14px}
  .sticky-btn i{font-size:18px}
  .form-row{grid-template-columns:1fr}
}
@media(max-width:480px){
  .stats-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .img-showcase{grid-template-columns:1fr;grid-template-rows:auto}
  .img-tile:first-child{grid-column:span 1}
}
