/* ============================================================
   Happy Palm Daycare — Modern Design System (v3)
   Fraunces (display) + Plus Jakarta Sans (body)
   Warm editorial · soft modern · bento · glass · grain
   ============================================================ */

:root{
  --paper:#FCF8F1; --paper-2:#F4EBDC; --cream:#EEE1CC; --card:#FFFFFF;
  --ink:#15282B; --ink-soft:#42565A; --ink-mute:#74868A;
  --teal:#127C70; --teal-deep:#0A5249; --teal-ink:#063630;
  --coral:#E66A48; --coral-deep:#C44A2C; --sun:#E6AE3C; --sun-soft:#F6E2B0;
  --berry:#D96E94; --sky:#7FC6DE;
  --line:rgba(15,132,120,.16); --line-soft:rgba(15,132,120,.09);
  --sh-1:0 1px 2px rgba(8,51,47,.05),0 6px 18px -6px rgba(8,51,47,.10);
  --sh-2:0 14px 40px -16px rgba(8,51,47,.24);
  --sh-3:0 36px 70px -28px rgba(8,51,47,.40);
  --r:18px; --r2:26px; --r3:34px;
  --maxw:1200px;
  --fd:"Fraunces",Georgia,serif;
  --fb:"Plus Jakarta Sans","Segoe UI",sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--fb);color:var(--ink);background:var(--paper);
  line-height:1.65;font-size:17px;-webkit-font-smoothing:antialiased;overflow-x:hidden;
  position:relative;
}
/* subtle grain overlay */
body::before{
  content:"";position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
}
body>*{position:relative;z-index:2}
img{max-width:100%;display:block}
picture{display:contents}
picture>source{display:none}
a{color:var(--teal-deep);text-decoration:none;transition:color .15s}
a:hover{color:var(--coral-deep)}

h1,h2,h3,h4{font-family:var(--fd);color:var(--teal-ink);line-height:1.08;font-weight:600;letter-spacing:-.018em;margin:0 0 .5em}
h1{font-size:clamp(2.5rem,5.6vw,4.4rem);font-weight:500}
h2{font-size:clamp(1.9rem,3.8vw,2.9rem)}
h3{font-size:clamp(1.2rem,2vw,1.5rem)}
p{margin:0 0 1rem}
.lead{font-size:clamp(1.08rem,1.5vw,1.25rem);color:var(--ink-soft);line-height:1.6}

.kicker{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--fb);font-weight:800;
  letter-spacing:.04em;text-transform:uppercase;font-size:.76rem;color:var(--coral-deep);
  background:rgba(242,107,67,.10);border:1px solid rgba(242,107,67,.20);
  padding:.4rem .85rem;border-radius:999px;margin:0 0 1.1rem}
.kicker::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--coral)}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:86px 0}
.section-tight{padding:54px 0}
.center{text-align:center}
.measure{max-width:720px;margin-left:auto;margin-right:auto}
.center .kicker{justify-content:center}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--fb);font-weight:800;
  padding:.92rem 1.6rem;border-radius:999px;border:2px solid transparent;cursor:pointer;
  font-size:1rem;transition:transform .2s,box-shadow .2s,background .2s;line-height:1;white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn-coral{background:linear-gradient(135deg,#ED7A59,var(--coral-deep));color:#fff;box-shadow:0 12px 26px -10px rgba(217,78,43,.65)}
.btn-coral:hover{color:#fff;transform:translateY(-3px);box-shadow:0 20px 34px -12px rgba(217,78,43,.7)}
.btn-teal{background:linear-gradient(135deg,#15897B,var(--teal-deep));color:#fff;box-shadow:0 12px 26px -10px rgba(11,95,87,.6)}
.btn-teal:hover{color:#fff;transform:translateY(-3px)}
.btn-ghost{background:rgba(255,255,255,.7);color:var(--teal-deep);border-color:var(--line);backdrop-filter:blur(6px)}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal-deep);transform:translateY(-3px)}
.btn-sun{background:var(--sun);color:var(--teal-ink)}
.btn-sun:hover{background:#efbb2e;color:var(--teal-ink);transform:translateY(-3px)}
.btn-lg{padding:1.1rem 2rem;font-size:1.08rem}

/* ---------- Header + dropdown ---------- */
.site-header{position:sticky;top:0;z-index:60;background:rgba(255,251,244,.82);
  backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid var(--line-soft)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:13px 24px;max-width:1320px;margin:0 auto}
.brand{display:flex;align-items:center;gap:.7rem;font-family:var(--fd);font-weight:600;font-size:1.3rem;color:var(--teal-ink);white-space:nowrap;flex-shrink:0}
.brand span{white-space:nowrap}
.brand img{width:44px;height:44px;border-radius:13px;box-shadow:var(--sh-1)}
.brand span small{display:block;font-family:var(--fb);font-weight:800;font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--coral-deep);margin-top:2px}
.nav-links{display:flex;align-items:center;gap:.15rem;list-style:none;margin:0;padding:0}
.nav-links>li{position:relative}
.nav-links a,.nav-links .subtoggle{font-family:var(--fb);font-weight:700;font-size:.95rem;color:var(--ink);
  padding:.55rem .8rem;border-radius:11px;transition:background .15s,color .15s;background:none;border:0;cursor:pointer;display:inline-flex;align-items:center;gap:.3rem}
.nav-links a:hover,.nav-links .subtoggle:hover,.nav-links a[aria-current="page"]{background:rgba(15,132,120,.10);color:var(--teal-deep)}
.subnav{position:absolute;top:calc(100% + 8px);left:0;min-width:240px;background:#fff;border:1px solid var(--line);
  border-radius:16px;box-shadow:var(--sh-2);padding:8px;list-style:none;margin:0;opacity:0;visibility:hidden;
  transform:translateY(8px);transition:.18s}
.has-sub:hover .subnav,.has-sub:focus-within .subnav{opacity:1;visibility:visible;transform:none}
.subnav a{display:block;padding:.6rem .8rem;border-radius:10px;font-weight:700}
.nav-cta{display:flex;align-items:center;gap:.5rem}
.nav-toggle{display:none;background:#fff;border:1px solid var(--line);border-radius:12px;padding:.55rem .65rem;cursor:pointer}
.nav-toggle span{display:block;width:22px;height:2.4px;background:var(--teal-ink);border-radius:3px;margin:4px 0;transition:.2s}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;z-index:0;background:
  radial-gradient(720px 540px at 86% -8%,rgba(134,207,230,.34),transparent 62%),
  radial-gradient(620px 520px at 4% 108%,rgba(246,196,69,.26),transparent 58%),
  radial-gradient(700px 600px at 110% 80%,rgba(242,107,67,.14),transparent 60%),
  linear-gradient(180deg,#FFFDF8,var(--paper))}
.hero .wrap{position:relative;z-index:1}
.hero-grid{display:grid;grid-template-columns:1.04fr .96fr;gap:60px;align-items:center;padding:70px 0 80px}
.hero h1{margin-bottom:.32em}
.hero .lead{margin-bottom:1.7rem;max-width:34ch}
.hero-cta{display:flex;flex-wrap:wrap;gap:.7rem;margin-bottom:1.5rem}
.trust-row{display:flex;flex-wrap:wrap;gap:.5rem}
.chip{display:inline-flex;align-items:center;gap:.42rem;background:#fff;border:1px solid var(--line);
  border-radius:999px;padding:.45rem .85rem;font-weight:800;font-size:.84rem;color:var(--teal-ink);box-shadow:var(--sh-1)}
.chip .star{color:var(--sun)}
.stars{color:var(--sun);letter-spacing:1px}

/* hero photo collage */
.hero-photo{position:relative;justify-self:start;max-width:560px;width:100%}
.hero-photo .main{border-radius:var(--r3);box-shadow:var(--sh-3);border:7px solid #fff;aspect-ratio:4/3;object-fit:cover;object-position:center 35%;width:100%}
.hero-badge{position:absolute;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);border-radius:18px;
  box-shadow:var(--sh-2);padding:.75rem 1.05rem;display:flex;align-items:center;gap:.55rem;font-weight:800;font-size:.92rem;color:var(--teal-ink)}
.hero-badge.tl{top:-20px;left:-18px}
.hero-badge.br{bottom:-20px;right:-14px}
.hero-badge .big{font-family:var(--fd);font-size:1.5rem;color:var(--coral-deep);line-height:1}
.hero-photo .float-av{position:absolute;bottom:18px;left:-22px;display:flex;align-items:center;gap:.6rem;
  background:#fff;border-radius:999px;padding:.4rem .9rem .4rem .4rem;box-shadow:var(--sh-2);font-weight:800;font-size:.82rem;color:var(--teal-ink)}
.hero-photo .float-av img{width:42px;height:42px;border-radius:50%;object-fit:cover}

/* ---------- Marquee ---------- */
.marquee{background:var(--teal-ink);color:#fff;overflow:hidden;padding:13px 0}
.marquee-track{display:flex;gap:0;width:max-content;animation:scroll 32s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee span{display:inline-flex;align-items:center;gap:.55rem;font-weight:800;font-size:.92rem;padding:0 1.8rem;white-space:nowrap}
.marquee .dot{opacity:.45}
@keyframes scroll{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.marquee-track{animation:none}}

/* ---------- Section header ---------- */
.sec-head{max-width:680px}

/* ---------- Grids / cards ---------- */
.grid{display:grid;gap:24px}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--card);border:1px solid var(--line-soft);border-radius:var(--r2);padding:28px;
  box-shadow:var(--sh-1);transition:transform .22s,box-shadow .22s}
.card:hover{transform:translateY(-5px);box-shadow:var(--sh-2)}
.card .ic{width:56px;height:56px;border-radius:16px;display:grid;place-items:center;margin-bottom:16px;font-size:1.6rem;
  background:linear-gradient(135deg,var(--sun-soft),#fff)}
.card h3{margin-bottom:.35em}
.card p{color:var(--ink-soft);margin-bottom:0}
.card-link{font-weight:800;color:var(--coral-deep);display:inline-flex;align-items:center;gap:.35rem}
.card-link:hover{gap:.6rem;color:var(--coral-deep)}

/* ---------- Bento ---------- */
.bento{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.bento .b{background:#fff;border:1px solid var(--line-soft);border-radius:var(--r2);padding:26px;box-shadow:var(--sh-1);
  display:flex;flex-direction:column;justify-content:flex-start;min-height:208px;transition:transform .22s,box-shadow .22s;overflow:hidden;position:relative}
.bento .b:hover{transform:translateY(-5px);box-shadow:var(--sh-2)}
.bento .b .ic{width:50px;height:50px;border-radius:14px;display:grid;place-items:center;font-size:1.4rem;margin-bottom:16px;
  background:linear-gradient(135deg,var(--sun-soft),#fff)}
.bento .b h3{margin:0 0 .35em}
.bento .b p{color:var(--ink-soft);margin:0;font-size:.96rem}
.bento .photo{padding:0;position:relative;min-height:240px}
.bento .photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;min-height:0}
.bento .accent{background:linear-gradient(140deg,var(--teal),var(--teal-deep));color:#fff}
.bento .accent h3,.bento .accent .big{color:#fff}.bento .accent p{color:rgba(255,255,255,.9)}
.bento .accent .ic{background:rgba(255,255,255,.16)}
.bento .big{font-family:var(--fd);font-size:2.6rem;line-height:1;color:var(--coral-deep)}
.bento .coral{background:linear-gradient(140deg,#ED7A59,var(--coral-deep));color:#fff}
.bento .coral h3,.bento .coral p{color:#fff}.bento .coral p{color:rgba(255,255,255,.92)}
.bento .coral .ic{background:rgba(255,255,255,.16)}

/* ---------- Programs ---------- */
.prog{background:#fff;border:1px solid var(--line-soft);border-radius:var(--r2);overflow:hidden;box-shadow:var(--sh-1);
  transition:transform .22s,box-shadow .22s;display:flex;flex-direction:column}
.prog:hover{transform:translateY(-6px);box-shadow:var(--sh-2)}
.prog img{aspect-ratio:4/3;object-fit:cover;width:100%}
.prog .body{padding:22px 22px 24px;display:flex;flex-direction:column;flex:1}
.prog .tag{font-weight:800;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--coral-deep);margin-bottom:.45rem}
.prog h3{margin-bottom:.4rem}
.prog p{color:var(--ink-soft);font-size:.97rem;flex:1}

/* ---------- feat list ---------- */
.feat{display:flex;gap:14px;align-items:flex-start}
.feat .tick{flex:none;width:32px;height:32px;border-radius:10px;background:linear-gradient(135deg,#15897B,var(--teal-deep));
  color:#fff;display:grid;place-items:center;font-weight:900;font-size:.95rem;margin-top:2px}
.feat h3{font-size:1.1rem;margin-bottom:.2rem}
.feat p{color:var(--ink-soft);font-size:.96rem;margin:0}

/* ---------- split ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.split img{border-radius:var(--r3);box-shadow:var(--sh-2);border:7px solid #fff;object-fit:cover;width:100%}

/* ---------- 24/7 hours band ---------- */
.hours-band{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--teal-deep),var(--teal-ink));color:#fff;border-radius:var(--r3);box-shadow:var(--sh-2)}
.hours-band .inner{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center;padding:46px 50px}
.hours-band h2{color:#fff}
.hours-band p{color:rgba(255,255,255,.9)}
.hours-band .pills{display:flex;flex-wrap:wrap;gap:.5rem;margin:1.1rem 0 1.4rem}
.hours-band .pills span{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:999px;padding:.4rem .85rem;font-weight:700;font-size:.86rem}
.hours-band .media{border-radius:var(--r2);overflow:hidden;box-shadow:var(--sh-3);border:6px solid rgba(255,255,255,.85);aspect-ratio:1.1/1}
.hours-band .media img{width:100%;height:100%;object-fit:cover}

/* ---------- founder ---------- */
.founder{display:grid;grid-template-columns:.85fr 1.15fr;gap:50px;align-items:center}
.founder .photo-wrap{position:relative;justify-self:center}
.founder .photo-wrap img{width:min(360px,80vw);aspect-ratio:1;object-fit:cover;border-radius:50%;border:8px solid #fff;box-shadow:var(--sh-3)}
.founder .photo-wrap .ring{position:absolute;inset:-14px;border-radius:50%;border:2px dashed var(--coral);opacity:.5}
.founder .photo-wrap .badge{position:absolute;bottom:14px;right:6px;background:#fff;border-radius:16px;box-shadow:var(--sh-2);padding:.6rem .9rem;font-weight:800;color:var(--teal-ink);font-size:.85rem}
.founder blockquote{font-family:var(--fd);font-size:1.35rem;line-height:1.4;color:var(--teal-ink);margin:0 0 1rem;font-style:italic}
.founder .sign{font-family:var(--fd);font-style:italic;font-size:1.5rem;color:var(--coral-deep)}

/* ---------- stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.stat{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:var(--r2);padding:24px;text-align:center}
.stat .n{font-family:var(--fd);font-size:2.5rem;color:var(--sun);line-height:1}
.stat .l{font-weight:700;color:#bcd9d5;font-size:.9rem;margin-top:.35rem}

/* ---------- reviews ---------- */
.review{background:#fff;border:1px solid var(--line-soft);border-radius:var(--r2);padding:26px;box-shadow:var(--sh-1);break-inside:avoid;margin-bottom:24px}
.review .stars{font-size:1rem;margin-bottom:.5rem}
.review p{font-size:1.02rem;color:var(--ink)}
.review .who{display:flex;align-items:center;gap:.7rem;margin-top:.9rem}
.review .av{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,#15897B,var(--teal-deep));color:#fff;display:grid;place-items:center;font-weight:800}
.review .who b{display:block;font-size:.95rem;color:var(--teal-ink)}
.review .who small{color:var(--ink-mute)}
.masonry{columns:3;column-gap:24px}

/* ---------- gallery ---------- */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:210px;gap:16px}
.gallery picture{display:block;height:100%;border-radius:var(--r);overflow:hidden;box-shadow:var(--sh-1)}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.gallery picture:hover img{transform:scale(1.05)}

/* ---------- FAQ ---------- */
.faq{max-width:840px;margin:0 auto}
.faq details{background:#fff;border:1px solid var(--line-soft);border-radius:16px;margin-bottom:12px;box-shadow:var(--sh-1);overflow:hidden}
.faq summary{cursor:pointer;padding:18px 22px;font-weight:800;color:var(--teal-ink);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem;font-size:1.04rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--fd);font-size:1.6rem;color:var(--coral);transition:transform .2s;line-height:1}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details>div{padding:0 22px 20px;color:var(--ink-soft)}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--teal),var(--teal-deep));color:#fff;border-radius:var(--r3);box-shadow:var(--sh-2)}
.cta-band h2{color:#fff}.cta-band p{color:rgba(255,255,255,.9)}
.cta-band .inner{padding:60px 48px;text-align:center;position:relative;z-index:2}
.cta-band .palm{position:absolute;right:-40px;top:-30px;width:300px;opacity:.16;z-index:1}

/* ---------- breadcrumb / answer / policy ---------- */
.crumb{font-size:.86rem;color:var(--ink-mute);padding:18px 0 0}
.crumb a{font-weight:700}
.answer-block{background:#fff;border:1px solid var(--line-soft);border-left:5px solid var(--teal);border-radius:16px;padding:22px 26px;margin:0 0 14px;box-shadow:var(--sh-1)}
.answer-block h2,.answer-block h3{font-size:1.15rem;margin-bottom:.35rem;color:var(--teal-ink)}
.answer-block p{margin:0;color:var(--ink)}
.answer-wrap{max-width:840px;margin:0 auto}
.verify-card{background:linear-gradient(135deg,var(--teal),var(--teal-deep));color:#fff;border-radius:var(--r3);padding:34px 36px;box-shadow:var(--sh-2);display:flex;flex-wrap:wrap;gap:20px;align-items:center;justify-content:space-between}
.verify-card h3{color:#fff;margin:0 0 .3rem}.verify-card p{color:rgba(255,255,255,.9);margin:0}
.verify-card .lic{font-family:var(--fd);font-size:1.8rem}
.policy{background:#fff;border:1px solid var(--line-soft);border-radius:var(--r2);padding:26px;box-shadow:var(--sh-1);transition:transform .2s,box-shadow .2s}
.policy:hover{transform:translateY(-4px);box-shadow:var(--sh-2)}
.policy h3{display:flex;align-items:center;gap:.55rem;margin-bottom:.5rem;font-size:1.18rem}
.policy h3 .e{font-size:1.35rem}
.policy p{color:var(--ink-soft);margin:0}
.factbar{display:flex;flex-wrap:wrap;gap:10px}

/* ---------- article / blog ---------- */
.post-hero{background:linear-gradient(180deg,#FFFDF8,var(--paper));padding:30px 0 8px}
.article{max-width:760px;margin:0 auto;padding:30px 24px 10px}
.article h2{margin-top:1.8em;font-size:1.7rem}
.article h3{margin-top:1.4em;color:var(--coral-deep)}
.article p,.article li{font-size:1.07rem;color:#26353b}
.article ul,.article ol{padding-left:1.2em}
.article li{margin-bottom:.5em}
.article img{border-radius:var(--r2);box-shadow:var(--sh-1);margin:1.6em 0}
.article .callout{background:var(--paper-2);border-left:4px solid var(--coral);border-radius:14px;padding:18px 22px;margin:1.7em 0}
.article .callout p:last-child{margin:0}
.article .src{font-size:.92rem;color:var(--ink-mute);border-top:1px solid var(--line-soft);margin-top:2.2em;padding-top:1em}
.meta{display:flex;flex-wrap:wrap;gap:.6rem 1rem;align-items:center;color:var(--ink-mute);font-weight:700;font-size:.9rem}
.tagpill{background:var(--sun-soft);color:var(--teal-ink);border-radius:999px;padding:.28rem .75rem;font-size:.78rem;font-weight:800}
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.post-card{background:#fff;border:1px solid var(--line-soft);border-radius:var(--r2);overflow:hidden;box-shadow:var(--sh-1);transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column}
.post-card:hover{transform:translateY(-5px);box-shadow:var(--sh-2)}
.post-card .ph{height:8px;background:linear-gradient(90deg,var(--coral),var(--sun))}
.post-card .body{padding:24px;display:flex;flex-direction:column;flex:1}
.post-card .tagpill{align-self:flex-start;margin-bottom:.7rem}
.post-card h3{font-size:1.18rem;margin-bottom:.4rem}
.post-card p{color:var(--ink-soft);font-size:.95rem;flex:1}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:start}
.info-card{background:#fff;border:1px solid var(--line-soft);border-radius:var(--r);padding:16px;box-shadow:var(--sh-1);margin-bottom:14px;display:flex;gap:14px;align-items:center;transition:transform .18s}
.info-card:hover{transform:translateX(4px)}
.info-card .ic{flex:none;width:50px;height:50px;border-radius:14px;background:linear-gradient(135deg,var(--sun-soft),#fff);display:grid;place-items:center;font-size:1.35rem}
.info-card b{display:block;color:var(--teal-ink)}
.info-card a{font-weight:800;font-size:1.12rem}
.map-embed{border-radius:var(--r2);overflow:hidden;box-shadow:var(--sh-1);border:1px solid var(--line-soft)}
.map-embed iframe{display:block;width:100%;height:340px;border:0}

/* ---------- footer ---------- */
.site-footer{background:var(--teal-ink);color:#dfeeec;padding:64px 0 28px;margin-top:10px}
.site-footer a{color:#cfe7e4}.site-footer a:hover{color:#fff}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:36px}
.foot-brand{display:flex;align-items:center;gap:.6rem;font-family:var(--fd);font-size:1.3rem;color:#fff;margin-bottom:.8rem}
.foot-brand img{width:42px;height:42px;border-radius:12px}
.site-footer h4{color:#fff;font-family:var(--fb);font-weight:800;font-size:.8rem;letter-spacing:.13em;text-transform:uppercase;margin:0 0 .9rem}
.foot-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem;font-size:.95rem}
.foot-mini{font-size:.9rem;color:#a8c9c5;line-height:1.7}
.foot-bottom{border-top:1px solid rgba(255,255,255,.13);margin-top:38px;padding-top:20px;display:flex;flex-wrap:wrap;justify-content:space-between;gap:.6rem;font-size:.83rem;color:#9cbcb8}
.foot-social{display:flex;gap:.5rem;margin-top:.4rem}
.foot-social a{width:38px;height:38px;border-radius:11px;background:rgba(255,255,255,.1);display:grid;place-items:center;font-weight:800;transition:background .15s}
.foot-social a:hover{background:var(--coral)}

/* ---------- mobile sticky bar ---------- */
.mobile-bar{position:fixed;bottom:0;left:0;right:0;z-index:70;display:none;background:#fff;border-top:1px solid var(--line);box-shadow:0 -8px 24px -12px rgba(8,51,47,.3)}
.mobile-bar a{flex:1;text-align:center;padding:15px 6px;font-weight:800;display:flex;align-items:center;justify-content:center;gap:.4rem;font-size:.98rem}
.mobile-bar a.call{background:linear-gradient(135deg,#ED7A59,var(--coral-deep));color:#fff}
.mobile-bar a.text{background:linear-gradient(135deg,#15897B,var(--teal-deep));color:#fff}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---------- responsive ---------- */
@media (max-width:1000px){
  .hero-grid{grid-template-columns:1fr;gap:44px;padding-bottom:54px}
  .hero-photo{order:-1;max-width:560px;margin:0 auto}
  .split,.founder,.hours-band .inner{grid-template-columns:1fr;gap:34px}
  .founder .photo-wrap{order:-1}
  .g-4{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(2,1fr)}
  .masonry{columns:2}.post-grid{grid-template-columns:repeat(2,1fr)}
  .contact-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .bento{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:1040px) and (min-width:681px){
  .nav-links{gap:.05rem}
  .nav-links a,.nav-links .subtoggle{padding:.5rem .5rem;font-size:.9rem}
  .nav .nav-cta .call-mini{display:none}
  .nav{gap:.5rem}
}
@media (max-width:680px){
  body{font-size:16px}
  .section{padding:58px 0}.section-tight{padding:40px 0}
  /* --- redesigned mobile nav: slide-down sheet + dimming scrim --- */
  .nav-links{display:flex;flex-direction:column;align-items:stretch;list-style:none;margin:0;
    position:fixed;top:0;left:0;right:0;z-index:55;
    background:var(--paper);
    padding:calc(env(safe-area-inset-top,0px) + 74px) 16px 24px;gap:1px;
    border-radius:0 0 26px 26px;box-shadow:0 26px 54px -22px rgba(8,51,47,.55);
    max-height:100dvh;overflow-y:auto;
    transform:translateY(-103%);opacity:0;visibility:hidden;
    transition:transform .36s cubic-bezier(.33,1.15,.45,1),opacity .26s,visibility .36s}
  .nav-links.open{transform:translateY(0);opacity:1;visibility:visible}
  .nav-links>li{width:100%;border-bottom:1px solid rgba(8,51,47,.07)}
  .nav-links>li.has-sub,.nav-links>li.only-mobile{border-bottom:0}
  .nav-links a,.nav-links .subtoggle{padding:.95rem .55rem;width:100%;justify-content:flex-start;
    font-size:1.08rem;border-radius:12px;display:flex}
  .nav-links .subtoggle{font-weight:800;color:var(--teal-deep);background:transparent}
  .subnav{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;
    border-left:2px solid rgba(18,124,112,.35);border-radius:0;margin:1px 0 10px 12px;padding:0 0 0 4px;min-width:0;background:transparent}
  .subnav a{padding:.62rem .6rem;font-weight:600;font-size:1rem;color:var(--ink-soft)}
  .only-mobile{display:block!important;margin-top:14px}
  .only-mobile .btn{width:100%;justify-content:center;padding:.95rem 1rem;font-size:1.02rem}
  .nav-toggle{display:block}
  .nav .nav-cta .call-mini{display:none}
  .nav-scrim{position:fixed;inset:0;z-index:48;background:rgba(8,51,47,.5);backdrop-filter:blur(3px);
    opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}
  .nav-scrim.open{opacity:1;visibility:visible}
  body.nav-open{overflow:hidden}
  .g-2,.g-3,.g-4{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2,1fr)}
  .masonry{columns:1}.post-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .bento{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:150px}
  .cta-band .inner{padding:42px 22px}
  .hours-band .inner{padding:34px 24px}
  .verify-card{padding:26px}
  .mobile-bar{display:flex}
  body{padding-bottom:56px}
  .hero-badge.tl{left:6px;top:6px}.hero-badge.br{right:6px;bottom:-14px}
  .hero-photo{max-width:280px}
  .hero-photo .main{border-width:5px}
  .hero-photo .float-av{left:auto;right:6px;bottom:-14px}
}

/* ============================================================
   v4 additions — motion, loading, gradients, charts, tables
   ============================================================ */

/* scroll progress bar */
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:200;
  background:linear-gradient(90deg,var(--coral),var(--sun) 50%,var(--teal));box-shadow:0 0 8px rgba(18,124,112,.4)}

/* gradient text */
.grad{background:linear-gradient(115deg,var(--teal-deep),var(--coral-deep) 70%,var(--coral));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}

/* shimmer loading for images */
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.gallery picture,.prog>picture,.split picture,.hero-photo>picture{
  background:linear-gradient(100deg,#efe4d2 28%,#f8efde 48%,#efe4d2 68%);background-size:200% 100%;animation:shimmer 1.5s linear infinite}
.fade-img{opacity:0;animation:fadeIn .7s ease forwards}
@keyframes fadeIn{to{opacity:1}}

/* staggered reveal */
.reveal.s1{transition-delay:.08s}.reveal.s2{transition-delay:.16s}.reveal.s3{transition-delay:.24s}
.reveal.s4{transition-delay:.32s}.reveal.s5{transition-delay:.4s}

/* count-up stat numbers already styled via .stat .n */

/* rating ring (radial graph) */
.ring-wrap{display:flex;align-items:center;gap:24px;flex-wrap:wrap;justify-content:center}
.ring{--p:0;width:150px;height:150px;border-radius:50%;display:grid;place-items:center;flex:none;
  background:conic-gradient(var(--sun) calc(var(--p)*1%),rgba(255,255,255,.16) 0);transition:none}
.ring::before{content:"";position:absolute;width:118px;height:118px;border-radius:50%;background:var(--teal-ink)}
.ring{position:relative}
.ring b{position:relative;font-family:var(--fd);font-size:2.4rem;color:#fff;line-height:1}
.ring b small{display:block;font-family:var(--fb);font-size:.7rem;font-weight:700;color:#bcd9d5;letter-spacing:.08em}

/* animated meter bars (figure) */
.meters{display:grid;gap:18px;max-width:640px;margin:0 auto}
.meter .lab{display:flex;justify-content:space-between;font-weight:700;color:var(--teal-ink);margin-bottom:6px;font-size:.96rem}
.meter .track{height:12px;border-radius:999px;background:rgba(15,132,120,.12);overflow:hidden}
.meter .fill{height:100%;width:0;border-radius:999px;background:linear-gradient(90deg,var(--teal),var(--coral));transition:width 1.3s cubic-bezier(.22,1,.36,1)}
.meter.in .fill{width:var(--w)}

/* comparison table / chart */
.cmp-wrap{overflow-x:auto;border-radius:var(--r2);box-shadow:var(--sh-1);border:1px solid var(--line-soft)}
.cmp{width:100%;border-collapse:collapse;background:#fff;min-width:560px;font-size:.97rem}
.cmp thead th{background:linear-gradient(135deg,var(--teal),var(--teal-deep));color:#fff;font-family:var(--fb);font-weight:800;
  padding:16px 18px;text-align:center;font-size:.95rem}
.cmp thead th:first-child{text-align:left;background:linear-gradient(135deg,var(--teal-deep),var(--teal-ink))}
.cmp thead th.hl{background:linear-gradient(135deg,#ED7A59,var(--coral-deep))}
.cmp tbody th{text-align:left;font-weight:700;color:var(--teal-ink);padding:14px 18px;border-bottom:1px solid var(--line-soft);background:var(--paper)}
.cmp tbody td{text-align:center;padding:14px 18px;border-bottom:1px solid var(--line-soft);color:var(--ink-soft)}
.cmp tbody tr:last-child th,.cmp tbody tr:last-child td{border-bottom:0}
.cmp td.col-hl{background:rgba(242,107,67,.06);font-weight:700;color:var(--teal-ink)}
.cmp .yes{color:var(--teal);font-weight:900}.cmp .no{color:#c2553a;opacity:.55;font-weight:900}.cmp .mid{color:var(--sun);font-weight:900}
.cmp-note{text-align:center;font-size:.85rem;color:var(--ink-mute);margin-top:12px}

/* timeline figure */
.timeline{position:relative;max-width:760px;margin:0 auto;padding-left:8px}
.timeline::before{content:"";position:absolute;left:23px;top:8px;bottom:8px;width:3px;border-radius:3px;
  background:linear-gradient(180deg,var(--sun),var(--coral),var(--teal))}
.tl-item{position:relative;padding:0 0 26px 64px}
.tl-item:last-child{padding-bottom:0}
.tl-item .dot{position:absolute;left:8px;top:2px;width:34px;height:34px;border-radius:50%;display:grid;place-items:center;
  background:#fff;border:3px solid var(--teal);font-size:1rem;box-shadow:var(--sh-1);z-index:1}
.tl-item .t{font-family:var(--fb);font-weight:800;color:var(--coral-deep);font-size:.82rem;letter-spacing:.03em}
.tl-item h4{font-family:var(--fd);font-size:1.15rem;color:var(--teal-ink);margin:.1rem 0 .25rem}
.tl-item p{margin:0;color:var(--ink-soft);font-size:.96rem}

/* hamburger -> X */
.nav-toggle span{transition:transform .25s,opacity .2s}

@media (max-width:680px){
  .brand{font-size:1.12rem;white-space:nowrap}
  .brand img{width:38px;height:38px}
  .brand span small{font-size:.52rem}
  .nav{padding:11px 15px;gap:.4rem}
  .nav-cta>.btn-coral{display:none}
  .only-mobile{display:block!important;margin-top:10px;padding:0 .2rem}
  .only-mobile .btn{width:100%;justify-content:center}
  .nav-toggle.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
  .nav-toggle.open span:nth-child(2){opacity:0}
  .nav-toggle.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
  .ring{width:130px;height:130px}.ring::before{width:100px;height:100px}
}
.only-mobile{display:none}

@property --p{syntax:"<number>";inherits:false;initial-value:0}

/* ---------- image lightbox ---------- */
.gallery img,img.zoom{cursor:zoom-in}
.lightbox{position:fixed;inset:0;z-index:300;display:flex;align-items:center;justify-content:center;padding:24px;
  background:rgba(8,51,47,.88);backdrop-filter:blur(4px);opacity:0;visibility:hidden;transition:opacity .25s,visibility .25s}
.lightbox.open{opacity:1;visibility:visible}
.lightbox img{max-width:92vw;max-height:86vh;border-radius:14px;box-shadow:0 30px 80px -18px rgba(0,0,0,.6);
  transform:scale(.95);transition:transform .28s cubic-bezier(.33,1.15,.45,1);background:#fff}
.lightbox.open img{transform:scale(1)}
.lightbox .lb-close{position:absolute;top:16px;right:18px;width:46px;height:46px;border-radius:50%;border:0;cursor:pointer;
  background:rgba(255,255,255,.16);color:#fff;font-size:1.6rem;line-height:1;display:grid;place-items:center;transition:background .2s}
.lightbox .lb-close:hover{background:rgba(255,255,255,.3)}
.lightbox .lb-cap{position:absolute;bottom:18px;left:0;right:0;text-align:center;color:rgba(255,255,255,.92);
  font-size:.9rem;padding:0 24px}

/* ---------- trust / proof block ---------- */
.proof-card{background:linear-gradient(180deg,#fff,var(--paper));border:1px solid var(--line);border-radius:var(--r2);
  box-shadow:var(--sh-2);padding:30px 28px}
.proof-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px 26px}
.proof-item{display:flex;align-items:flex-start;gap:.7rem;padding:12px 0;border-bottom:1px solid rgba(8,51,47,.07)}
.proof-item .pi-ic{font-size:1.35rem;line-height:1;flex-shrink:0;margin-top:2px}
.proof-item .pi-k{font-family:var(--fb);font-weight:800;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--coral-deep)}
.proof-item .pi-v{font-weight:600;color:var(--ink);margin-top:2px}
.proof-foot{margin-top:18px;text-align:center;color:var(--ink-mute);font-size:.94rem}
@media (max-width:680px){.proof-grid{grid-template-columns:1fr;gap:0}.proof-card{padding:24px 18px}}

/* ---------- references list in posts ---------- */
.refs{margin:.4rem 0 1rem;padding-left:1.3rem}
.refs li{margin:.4rem 0;color:var(--ink-soft);font-size:.96rem}
.refs li a{font-weight:700}
