
:root{
  --green:#2E7D32;--green-l:#F1F8F1;--green-b:#43A047;--green-g:linear-gradient(135deg,#1B5E20,#43A047);
  --magenta:#C2185B;--magenta-l:#FFF0F5;--magenta-b:#E91E8C;
  --purple:#6A1B9A;--purple-d:#4A148C;--purple-l:#F3E5F5;--purple-m:#7B1FA2;
  --dark:#0D1B0F;--mid:#1A2E1C;--gray:#4A5568;--light:#F8FDF8;
  --white:#FFFFFF;--border:#E2F0E3;
  --shadow:0 20px 60px rgba(0,0,0,.10);
  --glow-g:0 0 40px rgba(67,160,71,.18);
  --glow-p:0 0 32px rgba(106,27,154,.18);
  --r:18px;--r2:28px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Plus Jakarta Sans',sans-serif;background:var(--light);color:var(--mid);line-height:1.7;overflow-x:hidden}

/* ── TOPBAR (slimmer) ── */
.topbar{background:var(--green-g);padding:6px 5%;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:6px}
.topbar-l,.topbar-r{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.topbar a,.topbar span{color:rgba(255,255,255,.92);font-size:12px;font-weight:600;text-decoration:none;display:flex;align-items:center;gap:4px;transition:.2s;white-space:nowrap}
.topbar a:hover{color:white;text-decoration:underline}
.tb-sep{color:rgba(255,255,255,.3);font-size:14px}

/* ── NAV ── */
nav{background:rgba(255,255,255,.98);backdrop-filter:blur(20px);padding:0 5%;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:1000;box-shadow:0 2px 24px rgba(0,0,0,.07);border-bottom:2px solid var(--purple-l);height:72px}
.logo-wrap{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.logo-wrap img{height:54px;width:auto;object-fit:contain}
.logo-txt .ln{font-family:'Outfit',sans-serif;font-size:15px;font-weight:800;color:var(--green);line-height:1.1;display:block}
.logo-txt .lp{font-family:'Outfit',sans-serif;font-size:13px;font-weight:800;color:var(--purple-d);display:block;line-height:1.15}
.logo-txt .ls{font-size:9.5px;font-weight:600;color:var(--gray);letter-spacing:.8px;text-transform:uppercase;display:block;margin-top:1px}
.nav-links{display:flex;gap:2px;list-style:none;align-items:center}
.nav-links a{text-decoration:none;color:var(--mid);font-weight:600;font-size:14px;padding:8px 13px;border-radius:50px;transition:.22s}
.nav-links a:hover{color:var(--purple-d);background:var(--purple-l)}
.btn-book{background:var(--magenta)!important;color:white!important;padding:10px 22px!important;border-radius:50px;font-weight:700;text-decoration:none;box-shadow:0 4px 18px rgba(194,24,91,.30);transition:.25s!important;display:inline-flex;align-items:center;gap:6px;font-size:14px!important;white-space:nowrap}
.btn-book:hover{background:var(--purple-d)!important;transform:translateY(-2px);box-shadow:0 8px 28px rgba(74,20,140,.35)!important}

/* Hamburger — fixed mobile */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:var(--purple-d);border:none;padding:10px 12px;border-radius:10px;flex-shrink:0;z-index:1300}
.hamburger span{width:20px;height:2px;background:white;border-radius:2px;display:block;transition:.3s;pointer-events:none}
/* Mobile menu backdrop */
.mmenu-backdrop{
  display:none;position:fixed;
  top:0;left:0;right:0;bottom:0;width:100%;height:100%;  /* explicit edges, not just inset */
  background:rgba(0,0,0,.55);
  z-index:1199;                    /* just below mmenu */
  backdrop-filter:blur(2px);
  -webkit-backdrop-filter:blur(2px);
  opacity:0;
  transition:opacity .30s ease;
  -webkit-tap-highlight-color:transparent;
}
.mmenu-backdrop.open{opacity:1}  /* display managed by JS */.mmenu-backdrop.open{display:block;opacity:1;}
.mmenu-backdrop.open{display:block}
/* Mobile menu drawer — slides in from right */
.mmenu{
  position:fixed;
  top:0;right:0;
  width:min(360px,100vw);   /* full-width on phones, max 360px on tablets */
  height:100%;
  height:100dvh;
  background:#ffffff;
  z-index:1200;
  display:flex;flex-direction:column;
  transform:translateX(110%);
  transition:transform .30s cubic-bezier(.4,0,.2,1);
  box-shadow:-6px 0 40px rgba(74,20,140,.22);
  overflow:hidden;
  will-change:transform;
}
.mmenu.open{transform:translateX(0)}
/* On truly small phones — go completely full-screen */
@media(max-width:400px){
  .mmenu{
    width:100vw;
    left:0;right:0;
    box-shadow:none;
  }
}
/* Menu header bar */
.mmenu-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:0 20px;
  height:72px;min-height:72px;
  width:100%;                              /* force full width */
  border-bottom:1px solid rgba(255,255,255,.12);
  background:linear-gradient(135deg,#3d1278 0%,#6A1B9A 100%);
  flex-shrink:0;
  box-sizing:border-box;
}
.mmenu-header .mh-logo{font-family:'Outfit',sans-serif;font-size:15px;font-weight:800;color:white;line-height:1.2}
.mmenu-header .mh-logo span{display:block;font-size:11px;font-weight:500;color:rgba(255,255,255,.7);letter-spacing:.5px}
.mmenu-close{background:rgba(255,255,255,.15);border:1.5px solid rgba(255,255,255,.3);color:white;width:36px;height:36px;border-radius:50%;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.2s;flex-shrink:0;line-height:1}
.mmenu-close:hover{background:rgba(255,255,255,.3)}
/* Menu links body */
.mmenu-body{flex:1;overflow-y:auto;padding:12px 14px;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;min-height:0;}
.mmenu a{text-decoration:none;font-size:15px;color:var(--mid);font-weight:600;padding:13px 16px;border-radius:12px;transition:.18s;display:flex;align-items:center;gap:10px;margin-bottom:2px}
.mmenu a:hover,.mmenu a:active{background:var(--purple-l);color:var(--purple-d)}
.mmenu .mmenu-icon{font-size:18px;width:24px;text-align:center;flex-shrink:0}
.mmenu-divider{height:1px;background:#f0e8f8;margin:8px 0}
/* Book button at bottom */
.mmenu-footer{padding:14px 14px 20px;padding-bottom:max(20px,env(safe-area-inset-bottom));flex-shrink:0;border-top:1px solid #f3e5f5;background:#ffffff;}
.mmenu .mb{background:linear-gradient(135deg,var(--magenta),#e91e8c);color:white!important;text-align:center;border-radius:50px;padding:14px 20px;font-weight:700;font-size:15px;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 4px 18px rgba(194,24,91,.30)}
.mmenu .mb:hover{background:linear-gradient(135deg,var(--purple-d),var(--purple-m))!important;transform:translateY(-1px)}
/* Contact strip inside menu */
.mmenu-contact{background:#fafafa;border-radius:12px;padding:12px 14px;margin:0 14px 12px;border:1px solid #f0e8f8}
.mmenu-contact a{font-size:13px;color:var(--gray);display:flex;align-items:center;gap:8px;padding:4px 0;font-weight:600;text-decoration:none}
.mmenu-contact a:hover{color:var(--purple-d);background:none}
/* Hamburger animated icon */
.hamburger span:nth-child(1){transform-origin:center}
.hamburger span:nth-child(2){transform-origin:center}
.hamburger span:nth-child(3){transform-origin:center}
.hamburger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.active span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── HERO ── */
.hero{padding:52px 5% 72px;display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:52px;background:white;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:-200px;right:-200px;width:650px;height:650px;border-radius:50%;background:radial-gradient(circle,rgba(106,27,154,.05),transparent 70%);z-index:0}
.hero::after{content:'';position:absolute;bottom:-150px;left:-80px;width:450px;height:450px;border-radius:50%;background:radial-gradient(circle,rgba(67,160,71,.06),transparent 70%);z-index:0}
.hero-content{position:relative;z-index:1}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;background:var(--purple-l);border:1.5px solid #CE93D8;border-radius:50px;padding:7px 16px;margin-bottom:22px;font-size:12.5px;font-weight:700;color:var(--purple-d)}
.hero-eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--purple-m);animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.6)}}
.hero h1{font-family:'Outfit',sans-serif;font-size:clamp(30px,4vw,54px);font-weight:900;line-height:1.1;margin-bottom:20px}
.hero h1 .g{color:var(--green)}
.hero h1 .p{color:var(--purple-d)}
.hero-caption{font-size:16px;color:var(--gray);margin-bottom:36px;max-width:490px;line-height:1.85;min-height:80px;transition:opacity .5s ease}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:40px}
.btn-primary{background:var(--green-g);color:white;padding:14px 30px;border-radius:50px;text-decoration:none;font-weight:700;font-size:15px;box-shadow:0 4px 22px rgba(46,125,50,.30);transition:.25s;display:inline-flex;align-items:center;gap:8px}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(46,125,50,.38)}
.btn-sec{border:2.5px solid var(--purple-d);color:var(--purple-d);padding:12px 26px;border-radius:50px;text-decoration:none;font-weight:700;font-size:15px;transition:.22s;display:inline-flex;align-items:center;gap:6px}
.btn-sec:hover{background:var(--purple-l)}
.hero-stats{display:flex;gap:12px;flex-wrap:wrap}
.hs{background:var(--light);border:1.5px solid var(--border);border-radius:16px;padding:13px 18px;text-align:center;min-width:86px}
.hs .n{font-family:'Outfit',sans-serif;font-size:24px;font-weight:800;background:linear-gradient(135deg,var(--green),var(--purple-m));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}
.hs .l{font-size:10px;font-weight:700;color:var(--gray);margin-top:3px;text-transform:uppercase;letter-spacing:.5px}

/* Hero visual — slider */
.hero-visual{position:relative;z-index:1}
.hero-img-box{position:relative;width:100%;padding-top:72%;border-radius:var(--r2);overflow:hidden;box-shadow:var(--shadow);border:6px solid var(--purple-l);background:#f3e5f5}
.slide-item{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;transition:opacity 1.2s ease-in-out}
.slide-item.active{opacity:1}
.slide-item img{width:100%;height:100%;object-fit:cover;display:block}
/* caption overlay on slider */
.slide-caption-bar{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(74,20,140,.75));padding:28px 20px 16px;color:white}
.slide-caption-bar .sc-text{font-size:14px;font-weight:600;opacity:.95}
.slider-dots{display:flex;gap:7px;justify-content:center;margin-top:14px}
.sdot{width:8px;height:8px;border-radius:50%;background:var(--border);cursor:pointer;transition:.3s;border:none;padding:0}
.sdot.active{background:var(--purple-d);width:24px;border-radius:4px}

/* ── SHARED ── */
.sec{padding:84px 5%}
.sec-bg{background:white}
.sec-alt{background:var(--light)}
.sec-purple{background:linear-gradient(135deg,var(--purple-d) 0%,var(--purple-m) 100%)}
.wrap{max-width:1180px;margin:0 auto}
.stag{display:inline-flex;align-items:center;gap:7px;font-size:11.5px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--purple-d);margin-bottom:10px}
.stag::before{content:'';width:18px;height:2.5px;background:linear-gradient(90deg,var(--purple-d),var(--green-b));border-radius:2px}
.sh2{font-family:'Outfit',sans-serif;font-size:clamp(24px,3vw,40px);font-weight:800;color:var(--dark);margin-bottom:14px;line-height:1.18}
.sbar{width:64px;height:5px;background:var(--purple-d);border-radius:10px;margin:0 auto 24px}
.ssub{font-size:16px;color:var(--gray);max-width:560px;line-height:1.82}
.sec-head{margin-bottom:52px}
.sec-head.c{text-align:center}
.sec-head.c .ssub{margin:0 auto}

/* ── SERVICES ── */
.svc-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.sc{background:white;border:1.5px solid var(--border);border-radius:var(--r);padding:26px 18px 22px;text-align:center;cursor:pointer;transition:all .28s;position:relative;overflow:hidden}
.sc::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--purple-d),var(--green-b));transform:scaleX(0);transform-origin:left;transition:.3s}
.sc:hover{transform:translateY(-7px);border-color:var(--purple-m);box-shadow:var(--glow-p)}
.sc:hover::after{transform:scaleX(1)}
.sc.alt{background:var(--light)}
.sc-ico{width:64px;height:64px;border-radius:50%;background:var(--purple-l);color:var(--purple-d);display:flex;align-items:center;justify-content:center;margin:0 auto 14px;font-size:26px;transition:.28s;border:2px solid transparent}
.sc.alt .sc-ico{background:var(--green-l);color:var(--green)}
.sc:hover .sc-ico{border-color:var(--purple-m);transform:scale(1.08)}
.sc.alt:hover .sc-ico{border-color:var(--green-b)}
.sc h3{font-size:13px;font-weight:700;color:var(--purple-d);margin-bottom:6px;line-height:1.35}
.sc.alt h3{color:var(--green)}
.sc p{font-size:12px;color:var(--gray);line-height:1.7}
.sc .lm{color:var(--purple-d);font-weight:800;font-size:11px;text-transform:uppercase;display:block;margin-top:10px;letter-spacing:.5px}
.sc.alt .lm{color:var(--green)}

/* ── MODAL ── */
.modal-ov{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.82);z-index:2000;display:none;align-items:center;justify-content:center;backdrop-filter:blur(10px);padding:20px}
.modal-ov.open{display:flex}
.modal-box{background:white;border-radius:var(--r2);max-width:640px;width:100%;overflow:hidden;box-shadow:0 32px 80px rgba(0,0,0,.25);animation:popIn .3s ease}
@keyframes popIn{from{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}
.modal-top{background:linear-gradient(135deg,var(--purple-l),var(--green-l));padding:44px 36px;text-align:center;position:relative}
.modal-top .m-ico{font-size:52px;margin-bottom:12px;display:block}
.modal-top h2{font-family:'Outfit',sans-serif;font-size:24px;font-weight:800;color:var(--purple-d)}
.modal-close{position:absolute;top:14px;right:18px;background:rgba(74,20,140,.12);border:none;width:36px;height:36px;border-radius:50%;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:.2s;color:var(--mid)}
.modal-close:hover{background:var(--magenta);color:white}
.modal-body{padding:28px 36px 34px}
.modal-body p{font-size:15px;color:var(--gray);line-height:1.82;margin-bottom:26px}
.btn-appt{background:var(--purple-d);color:white;padding:13px 30px;border-radius:50px;font-weight:700;font-size:15px;text-decoration:none;display:inline-flex;align-items:center;gap:8px;box-shadow:0 4px 18px rgba(74,20,140,.28);transition:.25s;border:none;cursor:pointer}
.btn-appt:hover{background:var(--magenta);transform:translateY(-2px)}

/* ── WHY US — dark purple ── */
.why-bg{background:linear-gradient(135deg,var(--purple-d) 0%,#311B92 50%,#1B5E20 100%);position:relative;overflow:hidden}
.why-bg::before{content:'';position:absolute;top:-100px;left:-80px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.07),transparent)}
.why-bg::after{content:'';position:absolute;bottom:-80px;right:-60px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(67,160,71,.10),transparent)}
.why-bg .stag{color:#CE93D8}
.why-bg .stag::before{background:linear-gradient(90deg,#CE93D8,#81c784)}
.why-bg .sh2{color:white}
.why-bg .ssub{color:#B0BEC5}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.wc{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:var(--r);padding:28px 20px;transition:.28s;position:relative;overflow:hidden}
.wc::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,#CE93D8,#81c784);opacity:0;transition:.28s}
.wc:hover{background:rgba(255,255,255,.12);transform:translateY(-4px)}
.wc:hover::after{opacity:1}
.wc-ico{width:50px;height:50px;border-radius:14px;background:rgba(255,255,255,.10);display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:16px}
.wc h4{font-family:'Outfit',sans-serif;font-size:16px;font-weight:700;color:white;margin-bottom:7px}
.wc p{font-size:13px;color:#B0BEC5;line-height:1.75}

/* ── ABOUT ── */
.about-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:68px;align-items:center}
.about-logo-col{position:relative;display:flex;flex-direction:column;align-items:center;gap:16px}
.about-logo{width:80%;max-width:340px;filter:drop-shadow(0 20px 52px rgba(74,20,140,.18))}
.about-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%}
.aic{background:white;border-radius:14px;padding:14px;border:1.5px solid var(--border);display:flex;align-items:center;gap:10px;transition:.2s}
.aic:hover{border-color:var(--purple-m);transform:translateY(-2px);box-shadow:var(--glow-p)}
.aic-ico{width:34px;height:34px;border-radius:9px;background:var(--purple-l);font-size:15px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.aic-ico.g{background:var(--green-l)}
.aic strong{display:block;font-size:12px;font-weight:700;color:var(--dark)}
.aic span{font-size:11px;color:var(--gray)}
.about-copy p{font-size:15.5px;color:var(--gray);line-height:1.88;margin-bottom:14px}
.cklist{list-style:none;display:flex;flex-direction:column;gap:10px;margin:20px 0 28px}
.cklist li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--mid);font-weight:500}
.ck{width:21px;height:21px;border-radius:50%;background:linear-gradient(135deg,var(--purple-d),var(--purple-m));display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.ck svg{width:11px;height:11px;stroke:white;fill:none;stroke-width:2.5}

/* ── TEAM ── */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.tc{background:white;border:1.5px solid var(--border);border-radius:var(--r2);padding:30px 20px 24px;text-align:center;transition:.28s;position:relative;overflow:hidden}
.tc::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--purple-d),var(--magenta),var(--green-b))}
.tc:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.tc-av{width:78px;height:78px;border-radius:50%;margin:0 auto 13px;display:flex;align-items:center;justify-content:center;font-family:'Outfit',sans-serif;font-size:16px;font-weight:800;border:3px solid}
.tc-av.g{background:var(--green-l);color:var(--green);border-color:#A5D6A7}
.tc-av.p{background:var(--purple-l);color:var(--purple-d);border-color:#CE93D8}
.tc h4{font-size:16px;font-weight:700;color:var(--dark);margin-bottom:4px}
.tc-role{font-size:13px;font-weight:700;color:var(--purple-d);margin-bottom:9px}
.tc-cred{font-size:13px;color:var(--gray);line-height:1.65}

/* ── TESTIMONIALS ── */
.tgrid3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.tcard{background:white;border:1.5px solid var(--border);border-radius:var(--r2);padding:26px 22px;transition:.28s}
.tcard:hover{border-color:var(--purple-m);box-shadow:var(--glow-p);transform:translateY(-4px)}
.t-stars{font-size:16px;letter-spacing:2px;margin-bottom:12px}
.t-stars.g{color:#43A047}
.t-stars.p{color:var(--purple-m)}
.tcard blockquote{font-size:14px;color:var(--gray);font-style:italic;line-height:1.82;margin-bottom:16px;border-left:3px solid var(--purple-l);padding-left:13px}
.t-auth{display:flex;align-items:center;gap:10px}
.t-av{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex-shrink:0}
.t-av.g{background:var(--green-l);color:var(--green)}
.t-av.p{background:var(--purple-l);color:var(--purple-d)}
.t-info strong{display:block;font-size:14px;font-weight:700;color:var(--dark)}
.t-info span{font-size:12px;color:var(--gray)}

/* ── SCHOOL SECTION ── */
.school-grid{display:grid;grid-template-columns:1fr 1fr;gap:52px;align-items:center}
.school-img{border-radius:var(--r2);overflow:hidden;box-shadow:var(--shadow);border:5px solid var(--purple-l)}
.school-img img{width:100%;height:340px;object-fit:cover;display:block}
.school-badges{display:flex;flex-wrap:wrap;gap:8px;margin:18px 0 24px}
.sbadge{background:var(--purple-l);color:var(--purple-d);font-size:12.5px;font-weight:700;padding:5px 14px;border-radius:50px;border:1.5px solid #CE93D8}
.sbadge.g{background:var(--green-l);color:var(--green);border-color:#A5D6A7}
.school-check{list-style:none;display:flex;flex-direction:column;gap:9px;margin-bottom:24px}
.school-check li{display:flex;align-items:center;gap:10px;font-size:14.5px;color:var(--mid);font-weight:500}
.school-check li::before{content:'✓';width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,var(--purple-d),var(--purple-m));color:white;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;flex-shrink:0}
.cctv-tag{display:inline-flex;align-items:center;gap:7px;background:linear-gradient(135deg,var(--purple-d),var(--purple-m));color:white;font-size:12.5px;font-weight:700;padding:7px 16px;border-radius:50px;margin-top:4px}

/* ── DAYCARE SECTION ── */
.daycare-grid{display:grid;grid-template-columns:1fr 1fr;gap:52px;align-items:center}
.daycare-img{border-radius:var(--r2);overflow:hidden;box-shadow:var(--shadow);border:5px solid var(--green-l);order:2}
.daycare-img img{width:100%;height:340px;object-fit:cover;display:block}
.daycare-copy{order:1}
.daycare-features{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:20px 0 26px}
.df{background:white;border:1.5px solid var(--border);border-radius:14px;padding:14px 16px;display:flex;align-items:center;gap:10px;transition:.2s}
.df:hover{border-color:var(--green-b);transform:translateY(-2px)}
.df-ico{font-size:22px;flex-shrink:0}
.df strong{display:block;font-size:13px;font-weight:700;color:var(--dark)}
.df span{font-size:12px;color:var(--gray)}

/* ── CONTACT ── */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:start}
.contact-map h3{font-family:'Outfit',sans-serif;font-size:24px;font-weight:800;color:var(--purple-d);margin-bottom:8px}
.contact-map>p{font-size:15px;color:var(--gray);margin-bottom:20px;line-height:1.8}
.map-frame{width:100%;height:300px;border-radius:var(--r);border:none;box-shadow:var(--shadow);display:block}
.cinfo-list{display:flex;flex-direction:column;gap:10px;margin-top:18px}
.ci{display:flex;align-items:flex-start;gap:11px;padding:12px 14px;background:var(--purple-l);border:1.5px solid #CE93D8;border-radius:14px;transition:.2s}
.ci:hover{border-color:var(--purple-m)}
.ci-ico{width:36px;height:36px;border-radius:9px;background:white;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:15px;box-shadow:0 2px 8px rgba(0,0,0,.06)}
.ci strong{display:block;font-size:13px;font-weight:700;color:var(--purple-d)}
.ci span,.ci a{font-size:13px;color:var(--gray);text-decoration:none}
.ci a{color:var(--magenta);font-weight:700}
.fb-link{display:inline-flex;align-items:center;gap:8px;background:white;border:1.5px solid var(--border);border-radius:12px;padding:10px 15px;text-decoration:none;color:var(--dark);font-weight:700;font-size:14px;transition:.2s;margin-top:14px}
.fb-link:hover{border-color:var(--purple-m);background:var(--purple-l)}
.fb-ico{width:26px;height:26px;border-radius:7px;background:#1877f2;display:flex;align-items:center;justify-content:center;color:white;font-weight:900;font-size:14px;font-family:serif;flex-shrink:0}
/* Form */
.booking-form{background:white;border:2px solid var(--purple-l);border-radius:var(--r2);padding:34px}
.booking-form h3{font-family:'Outfit',sans-serif;font-size:22px;font-weight:800;color:var(--purple-d);margin-bottom:4px}
.bf-note{font-size:13px;color:var(--gray);margin-bottom:22px}
.fg{margin-bottom:14px}
.fg label{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--purple-d);margin-bottom:5px;opacity:.8}
.fg input,.fg select,.fg textarea{width:100%;padding:12px 15px;border:1.5px solid var(--border);border-radius:12px;font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;color:var(--dark);background:var(--light);transition:.2s;outline:none;-webkit-appearance:none}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--purple-m);box-shadow:0 0 0 3px rgba(106,27,154,.10);background:white}
.fg textarea{resize:vertical;min-height:88px}
.fg2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.sbtn{width:100%;background:linear-gradient(135deg,var(--purple-d),var(--purple-m));color:white;border:none;padding:15px;border-radius:50px;font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;font-weight:700;cursor:pointer;box-shadow:0 4px 20px rgba(74,20,140,.28);transition:.25s;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:4px}
.sbtn:hover{background:var(--magenta);transform:translateY(-2px);box-shadow:0 8px 28px rgba(194,24,91,.32)}
.form-note{font-size:11.5px;color:var(--gray);text-align:center;margin-top:9px}
.suc-msg{display:none;background:var(--purple-l);border:1.5px solid var(--purple-m);border-radius:12px;padding:14px;text-align:center;color:var(--purple-d);font-weight:700;margin-top:12px;font-size:15px}

/* ── FOOTER ── */
footer{background:#0a0a14;padding:60px 5% 26px}
.ft-inner{max-width:1180px;margin:0 auto}
.ft-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:38px;margin-bottom:44px}
.ft-brand .f-logo{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.ft-brand .f-logo img{height:52px;width:auto;object-fit:contain;display:block;filter:brightness(1.1)}
.ft-brand .f-logo .fn{font-family:'Outfit',sans-serif;font-size:15px;font-weight:800;color:rgba(255,255,255,.92);line-height:1.2}
.ft-brand .f-logo .fp{font-size:12.5px;color:#CE93D8}
.ft-brand p{font-size:13px;color:#7d8f7e;line-height:1.82}
.ft-col h5{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:rgba(255,255,255,.88);margin-bottom:16px}
.ft-col ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.ft-col li,.ft-col a{font-size:13px;color:#7d8f7e;text-decoration:none;transition:.2s}
.ft-col a:hover{color:#CE93D8}
.ft-bot{border-top:1px solid rgba(255,255,255,.07);padding-top:20px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;font-size:12.5px;color:#7d8f7e}
.soc{display:flex;gap:8px}
.soc a{width:34px;height:34px;border-radius:9px;background:rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;text-decoration:none;color:#7d8f7e;font-weight:700;font-size:12px;transition:.2s}
.soc a:hover{background:var(--purple-m);color:white}

/* ── WHATSAPP FLOAT ── */
.wa-float{position:fixed;bottom:26px;right:26px;z-index:500;background:#25D366;width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 22px rgba(37,211,102,.45);transition:.3s;text-decoration:none}
.wa-float:hover{transform:scale(1.12) translateY(-3px);box-shadow:0 12px 36px rgba(37,211,102,.55)}
.wa-float svg{width:28px;height:28px;fill:white}

/* ── ANIMATIONS ── */
.fade-up{opacity:0;transform:translateY(24px);transition:opacity .55s,transform .55s}
.fade-up.vis{opacity:1;transform:translateY(0)}

/* ── RESPONSIVE ── */
@media(max-width:1060px){.svc-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:900px){
  .hero{grid-template-columns:1fr;padding:36px 5% 52px;gap:32px}
  .hero-visual{order:-1}
  .about-grid,.contact-grid,.school-grid,.daycare-grid{grid-template-columns:1fr;gap:32px}
  .daycare-img{order:1}
  .daycare-copy{order:2}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .ft-grid{grid-template-columns:1fr 1fr;gap:28px}
  .team-grid,.tgrid3{grid-template-columns:1fr 1fr}
  .nav-links{display:none!important}
  .hamburger{display:flex!important}
}
@media(max-width:640px){
  .topbar{display:none}
  .svc-grid{grid-template-columns:1fr 1fr}
  .topbar{flex-direction:column;gap:4px;text-align:center;padding:5px 5%}
  .topbar-l,.topbar-r{justify-content:center;gap:10px}
  .ft-grid{grid-template-columns:1fr}
  .fg2{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .hero-stats{gap:8px}
  .why-grid{grid-template-columns:1fr 1fr}
  .daycare-features{grid-template-columns:1fr}
  .school-img img,.daycare-img img{height:240px}
}
@media(max-width:420px){
  .svc-grid{grid-template-columns:1fr}
  .team-grid,.tgrid3{grid-template-columns:1fr}
  .about-info-grid{grid-template-columns:1fr}
  .why-grid{grid-template-columns:1fr}
}


/* ══ MULTI-PAGE NAV ADDITIONS ══ */
.nav-dropdown{position:relative}
.nav-dropdown>a::after{content:" ▾";font-size:10px;opacity:.7}
.dropdown-menu{
  display:none;position:absolute;top:calc(100% + 8px);left:50%;
  transform:translateX(-50%);
  background:white;border-radius:14px;
  box-shadow:0 12px 48px rgba(74,20,140,.18);
  border:1.5px solid var(--purple-l);
  min-width:240px;padding:8px;z-index:900;
  animation:ddFade .18s ease;
}
@keyframes ddFade{from{opacity:0;transform:translateX(-50%) translateY(-6px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
.nav-dropdown:hover .dropdown-menu,
.nav-dropdown:focus-within .dropdown-menu{display:block}
.dropdown-menu a{
  display:flex;align-items:center;gap:10px;
  text-decoration:none;font-size:14px;font-weight:600;
  color:var(--mid);padding:10px 14px;border-radius:10px;transition:.18s;
}
.dropdown-menu a:hover{background:var(--purple-l);color:var(--purple-d)}
.dropdown-menu .dd-icon{display:none}
.dropdown-menu .dd-desc{font-size:11px;color:var(--gray);font-weight:400;display:block;margin-top:1px}
/* active page highlight */
nav a.active,nav a[aria-current="page"]{color:var(--purple-d)!important;background:var(--purple-l)}

/* ══ PRELOADER ══ */
#preloader{
  position:fixed;inset:0;background:white;
  z-index:9999;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:20px;
  transition:opacity .4s ease,visibility .4s ease;
}
#preloader.hidden{opacity:0;visibility:hidden}
.pl-logo{width:80px;height:80px;animation:plPulse 1.2s ease-in-out infinite}
@keyframes plPulse{0%,100%{transform:scale(1);filter:drop-shadow(0 0 0 rgba(74,20,140,0))}50%{transform:scale(1.08);filter:drop-shadow(0 0 18px rgba(74,20,140,.30))}}
.pl-bar{width:200px;height:4px;background:#f3e5f5;border-radius:4px;overflow:hidden}
.pl-bar-fill{height:100%;background:linear-gradient(90deg,var(--purple-d),var(--green-b));border-radius:4px;animation:plFill 0.9s ease forwards}
@keyframes plFill{from{width:0%}to{width:100%}}
.pl-text{font-family:'Outfit',sans-serif;font-size:14px;font-weight:700;color:var(--purple-d);letter-spacing:.5px}

/* ══ PAGE HERO (inner pages) ══ */
.page-hero{
  background:linear-gradient(135deg,var(--purple-d) 0%,var(--purple-m) 60%,var(--green) 100%);
  padding:72px 5% 64px;text-align:center;color:white;position:relative;overflow:hidden;
}
.page-hero::before{content:'';position:absolute;top:-80px;right:-80px;width:360px;height:360px;border-radius:50%;background:rgba(255,255,255,.05)}
.page-hero::after{content:'';position:absolute;bottom:-60px;left:-60px;width:260px;height:260px;border-radius:50%;background:rgba(255,255,255,.04)}
.page-hero .ph-tag{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.25);border-radius:50px;padding:6px 16px;font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:16px;color:rgba(255,255,255,.9)}
.page-hero h1{font-family:'Outfit',sans-serif;font-size:clamp(28px,4vw,52px);font-weight:900;line-height:1.12;margin-bottom:16px;position:relative;z-index:1}
.page-hero p{font-size:17px;opacity:.88;max-width:560px;margin:0 auto;line-height:1.82;position:relative;z-index:1}
.ph-breadcrumb{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:24px;font-size:13px;opacity:.75;position:relative;z-index:1}
.ph-breadcrumb a{color:white;text-decoration:none;font-weight:600}
.ph-breadcrumb a:hover{text-decoration:underline}
.ph-breadcrumb span{opacity:.6}

/* ══ CONTENT SECTIONS (inner pages) ══ */
.content-block{padding:72px 5%}
.content-block.alt{background:white}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;max-width:1180px;margin:0 auto}
.two-col.reverse .col-img{order:2}
.two-col.reverse .col-text{order:1}
.col-img img{width:100%;border-radius:var(--r2);box-shadow:var(--shadow);border:5px solid var(--purple-l);display:block}
.col-text h2{font-family:'Outfit',sans-serif;font-size:clamp(22px,2.8vw,36px);font-weight:800;color:var(--dark);margin-bottom:14px;line-height:1.2}
.col-text p{font-size:15.5px;color:var(--gray);line-height:1.88;margin-bottom:14px}

/* FAQ accordion */
.faq-list{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:10px}
.faq-item{background:white;border:1.5px solid var(--border);border-radius:var(--r);overflow:hidden}
.faq-q{width:100%;background:none;border:none;padding:18px 22px;text-align:left;font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;font-weight:700;color:var(--dark);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:12px;transition:.2s}
.faq-q:hover{background:var(--purple-l);color:var(--purple-d)}
.faq-q .faq-arrow{font-size:18px;transition:transform .25s;flex-shrink:0;color:var(--purple-d)}
.faq-item.open .faq-arrow{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease,padding .25s ease}
.faq-item.open .faq-a{max-height:400px;padding:0 22px 18px}
.faq-a p{font-size:14.5px;color:var(--gray);line-height:1.82;margin:0}

/* Benefit cards */
.benefit-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:1180px;margin:0 auto}
.benefit-card{background:white;border:1.5px solid var(--border);border-radius:var(--r2);padding:28px 22px;text-align:center;transition:.28s}
.benefit-card:hover{border-color:var(--purple-m);box-shadow:var(--glow-p);transform:translateY(-4px)}
.bc-ico{font-size:36px;margin-bottom:14px;display:block}
.bc-title{font-family:'Outfit',sans-serif;font-size:17px;font-weight:800;color:var(--purple-d);margin-bottom:8px}
.bc-desc{font-size:14px;color:var(--gray);line-height:1.75}

/* Signs list */
.signs-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;max-width:900px;margin:24px auto 0}
.sign-item{background:white;border-left:4px solid var(--purple-d);border-radius:0 12px 12px 0;padding:14px 18px;font-size:14.5px;color:var(--mid);font-weight:500;display:flex;align-items:center;gap:10px;box-shadow:0 2px 12px rgba(0,0,0,.05)}
.sign-item::before{content:"⚠️";font-size:16px;flex-shrink:0}

/* CTA banner */
.cta-banner{background:linear-gradient(135deg,var(--purple-d),var(--purple-m),var(--green));padding:60px 5%;text-align:center;color:white}
.cta-banner h2{font-family:'Outfit',sans-serif;font-size:clamp(24px,3vw,38px);font-weight:900;margin-bottom:12px}
.cta-banner p{font-size:16px;opacity:.88;margin-bottom:30px;max-width:520px;margin-left:auto;margin-right:auto}
.cta-banner .btn-white{background:white;color:var(--purple-d);padding:15px 36px;border-radius:50px;font-weight:800;font-size:15px;text-decoration:none;display:inline-flex;align-items:center;gap:8px;box-shadow:0 8px 32px rgba(0,0,0,.18);transition:.25s}
.cta-banner .btn-white:hover{transform:translateY(-2px);box-shadow:0 12px 40px rgba(0,0,0,.25)}

/* Responsive inner pages */
@media(max-width:860px){.two-col{grid-template-columns:1fr;gap:32px}.two-col.reverse .col-img,.two-col.reverse .col-text{order:unset}.benefit-grid{grid-template-columns:1fr 1fr}.signs-grid{grid-template-columns:1fr}}
@media(max-width:540px){.benefit-grid{grid-template-columns:1fr}}

/* ══ FACEBOOK VIDEO EMBEDS ══ */

/* Facebook badge label */
.fb-badge{
  display:inline-flex;align-items:center;gap:6px;
  background:linear-gradient(135deg,#1877f2,#0a4fa6);
  color:white;font-size:12px;font-weight:700;
  padding:5px 14px;border-radius:50px;
  margin-bottom:16px;letter-spacing:.3px;
  box-shadow:0 3px 12px rgba(24,119,242,.30);
}

/* Watch on Facebook fallback link */
.fb-watch-link{
  display:inline-flex;align-items:center;gap:7px;
  margin-top:14px;font-size:13.5px;font-weight:700;
  color:#1877f2;text-decoration:none;
  background:#f0f5ff;border:1.5px solid #c5d8fc;
  padding:9px 18px;border-radius:50px;transition:.2s;
}
.fb-watch-link:hover{background:#e0ecff;transform:translateY(-1px)}

/* ── Reel (vertical 9:16) ── */
.fb-reel-outer{
  display:flex;flex-direction:column;align-items:center;
  max-width:400px;margin:0 auto;
}
.fb-reel-frame{display:none}

/* ── Nutrition horizontal split ── */
.nutr-video-split{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:52px;
  align-items:center;
  max-width:1100px;
  margin:0 auto;
}
.nutr-video-col{display:flex;flex-direction:column;align-items:flex-start}
.nutr-video-frame{
  width:100%;
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 20px 56px rgba(46,125,50,.16);
  border:4px solid var(--green-l);
  background:#0a0a0a;
  min-height:240px;
}
.nutr-video-frame .fb-video{display:block;width:100%!important}
.nutr-video-frame .fb-video span{width:100%!important}
.nutr-video-frame .fb-video span iframe{width:100%!important}
.nutr-facts-col{display:flex;flex-direction:column}

/* ── Responsive ── */
@media(max-width:860px){
  .nutr-video-split{
    grid-template-columns:1fr;
    gap:32px;
  }
  .nutr-video-col{align-items:center;text-align:center}
  .nutr-facts-col{text-align:left}
  .fb-reel-outer{max-width:320px}
}
@media(max-width:480px){
  .fb-reel-outer{max-width:100%}
  .fb-reel-frame{border-radius:14px;border-width:3px}
  .nutr-video-frame{border-radius:14px;border-width:3px}
}

/* ══ SVG SERVICE ICONS ══ */
.svc-icon-wrap{
  display:flex;align-items:center;justify-content:center;
}
.svc-svg{
  width:32px;height:32px;
  stroke:currentColor;
  transition:transform .28s;
}
.sc:hover .svc-svg{transform:scale(1.12)}

/* ══ PROFESSIONAL MOBILE MENU SECTIONS ══ */
.mmenu-section-label{
  font-size:9.5px;font-weight:800;
  text-transform:uppercase;letter-spacing:2px;
  color:var(--purple-d);
  padding:14px 16px 4px;
  opacity:.7;
}
.mmenu a.mmenu-sub{
  padding:10px 16px 10px 22px;
  font-size:14px;
  color:var(--gray);
  border-left:2px solid var(--purple-l);
  border-radius:0 10px 10px 0;
  margin-left:10px;
}
.mmenu a.mmenu-sub:hover,.mmenu a.mmenu-sub:active{
  border-left-color:var(--purple-d);
  color:var(--purple-d);
  background:var(--purple-l);
}

/* ══ AUTOPLAY IFRAME REEL ══ */
.fb-reel-frame{
  width:100%;
  max-width:400px;
  margin:0 auto;
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 20px 56px rgba(74,20,140,.18);
  border:3px solid var(--purple-l);
  background:#000;
  aspect-ratio:9/16;  /* vertical reel proportions */
  position:relative;
}
.fb-reel-frame iframe{
  position:absolute;top:0;left:0;
  width:100%!important;height:100%!important;
  border:none;display:block;
}
.fb-reel-outer{
  display:flex;flex-direction:column;
  align-items:center;
  max-width:400px;
  margin:0 auto;
}
/* Nutrition horizontal video */
.nutr-video-frame{
  width:100%;
  border-radius:16px;
  overflow:hidden;
  box-shadow:0 18px 48px rgba(46,125,50,.15);
  border:3px solid var(--green-l);
  background:#000;
  aspect-ratio:16/9;
  position:relative;
}
.nutr-video-frame iframe{
  position:absolute;top:0;left:0;
  width:100%!important;height:100%!important;
  border:none;display:block;
}
/* Hide badge */
.fb-badge{display:none}
.fb-watch-link{display:none}

/* ══ PERFORMANCE: image sizing hints ══ */
img{height:auto;max-width:100%}
.logo-wrap img{width:54px;height:54px}
.f-logo img{width:52px;height:52px}

/* ══ PERFORMANCE ══ */
*{-webkit-tap-highlight-color:transparent}
img{content-visibility:auto}
.fade-up{contain:layout style}
.sec,.content-block{contain:layout}
/* GPU-accelerate animated elements only */
.mmenu,.mmenu-backdrop,.hero-img-box .slide-item{will-change:transform,opacity}
/* Reduce layout thrash on scroll */
nav{contain:layout style}

/* ══ SMOOTH TRANSITIONS & POLISH ══ */

/* Smooth scroll globally */
html{scroll-behavior:smooth;scroll-padding-top:72px}

/* Nav transitions */
.nav-links a{transition:color .18s,background .18s}
.btn-book{transition:background .2s,transform .18s,box-shadow .2s!important}

/* mmenu: faster slide (0.28s instead of 0.35s) */
.mmenu{transition:transform .28s cubic-bezier(.4,0,.2,1)!important}
.mmenu-backdrop{transition:opacity .28s ease!important}

/* Hamburger spans: smooth X animation */
.hamburger span{transition:transform .25s ease,opacity .2s ease}

/* Service cards: smoother hover */
.sc{transition:transform .22s ease,border-color .22s ease,box-shadow .22s ease}
.sc:hover{transform:translateY(-5px)}

/* Cards: uniform hover */
.benefit-card,.tcard,.tc,.wc,.aic,.df{transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease}

/* Buttons: consistent feel */
.btn-primary,.btn-sec,.btn-g,.btn-appt,.sbtn{transition:transform .18s ease,box-shadow .18s ease,background .18s ease}

/* nutr-video-frame: 16:9 */
.nutr-video-frame{
  position:relative;
  aspect-ratio:16/9;
  height:auto;
  min-height:unset;
}
.nutr-video-frame iframe{
  position:absolute;
  top:0;left:0;
  width:100%!important;
  height:100%!important;
  border:none;display:block;
}

/* ── Topbar: tighter, professional ──────── */
.topbar{
  padding:5px 5%;
  font-size:11.5px;
  letter-spacing:.2px;
}
.topbar a,.topbar span{font-size:11.5px}

/* ── Scrollbar styling ─────────────────── */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--purple-l);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--purple-m)}

/* ── Focus visible (accessibility + professionalism) ─── */
a:focus-visible,button:focus-visible{
  outline:2px solid var(--purple-m);
  outline-offset:3px;
  border-radius:4px;
}

/* ── Image rendering ─────────────────── */
img{image-rendering:-webkit-optimize-contrast}
.hero-img-box img,.school-img img,.daycare-img img{object-fit:cover;width:100%;height:100%}

/* TRUE 9:16 reel container */
.reel-ratio{
  position:relative;
  width:100%;
  /* True 9:16 = 177.78%, add a little extra to hide Facebook UI chrome */
  padding-top:180%;
  border-radius:16px;
  overflow:hidden;
  background:#000;
  box-shadow:0 16px 48px rgba(74,20,140,.20);
  border:2px solid var(--purple-l);
}
.reel-ratio iframe{
  position:absolute;
  /* Pull up slightly to hide FB top bar, clip with overflow:hidden */
  top:-4%;left:-2%;
  width:104%;
  height:108%;
  border:none;
  display:block;
}
@media(max-width:480px){
  .fb-reel-outer{max-width:min(340px,90vw)}
}

/* ══ VIDEO SIZING — OVERRIDES ══ */
/* Ensure reel never gets too tall on desktop */
@media(min-width:600px){
  .fb-reel-outer{max-width:320px}
  .reel-ratio{padding-top:170%}   /* slightly less tall on desktop */
}
/* Nutrition 16:9 fix */
.nutr-video-frame{
  position:relative;
  aspect-ratio:16/9;
  height:unset!important;
  min-height:unset!important;
  overflow:hidden;
  border-radius:16px;
  border:3px solid var(--green-l);
  background:#000;
  box-shadow:0 16px 48px rgba(46,125,50,.15);
}
.nutr-video-frame iframe{
  position:absolute;
  top:0;left:0;
  width:100%!important;
  height:100%!important;
  border:none;display:block;
}
