
:root{
  --paper:#fbf4ea;
  --ink:#14343b;
  --muted:rgba(20,52,59,.70);
  --card:rgba(255,255,255,.82);
  --border:rgba(20,52,59,.10);
  --shadow:0 18px 55px rgba(0,0,0,.12);
  --shadowSoft:0 14px 36px rgba(0,0,0,.08);
  --radius:22px;
  --radiusLg:26px;
  --max:1120px;

  --accent:#ff6b6a;
  --mint:#7cc9b8;
  --peri:#86aefc;

  --footer:#1f3a3a;

  --font: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:var(--font);color:var(--ink);
  background:linear-gradient(180deg,var(--paper),#f9f6ef 38%,#f3f6f2 72%,#f7f6f2)}
a{color:inherit;text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:var(--max);margin:0 auto;padding:0 22px}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadowSoft)}
.section{padding:44px 0}
.sectionTitle{text-align:center;font-size:22px;font-weight:900;color:rgba(20,52,59,.82);margin:0 0 14px;letter-spacing:.02em}
.subhead{text-align:center;max-width:70ch;margin:0 auto 18px;color:var(--muted);line-height:1.6}
.pill{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border-radius:999px;border:1px solid var(--border);
  background:rgba(255,255,255,.72);font-weight:850;font-size:12px;color:rgba(20,52,59,.75)}
.pill.primary{background:rgba(124,201,184,.26);border-color:rgba(124,201,184,.35)}
.pill.soft{background:rgba(134,174,252,.20);border-color:rgba(134,174,252,.30)}
.pill.warm{background:rgba(255,107,106,.18);border-color:rgba(255,107,106,.28)}

/* NAV */
.nav{position:sticky;top:0;z-index:50;-webkit-backdrop-filter:saturate(160%) blur(12px);backdrop-filter:saturate(160%) blur(12px);
  background:rgba(251,244,234,.78);border-bottom:1px solid rgba(20,52,59,.08)}
.navContainer{max-width:1240px}
.navInner{position:relative;display:flex;align-items:center;gap:14px;min-height:78px;padding:10px 0}
.brand{display:flex;align-items:center;gap:10px;font-weight:900;letter-spacing:.2px;min-width:0;flex:1 1 auto}
.brandTitle{font-family:"Blue Winter", var(--font);font-size:clamp(20px,2.3vw,34px);line-height:1.05;color:rgba(20,52,59,.95);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.brandLogo{width:42px;height:42px;min-width:30px;min-height:30px;max-width:42px;max-height:42px;border-radius:12px;object-fit:cover;display:block;flex:0 0 auto}
@supports (width:clamp(30px,2.6vw,42px)){.brandLogo{width:clamp(30px,2.6vw,42px);height:clamp(30px,2.6vw,42px);}}
.brandMark{width:36px;height:36px;border-radius:12px;
  background:radial-gradient(120% 120% at 20% 20%,rgba(255,255,255,.95),rgba(255,255,255,.55) 55%,rgba(255,255,255,.2)),
            linear-gradient(135deg,rgba(124,201,184,.90),rgba(134,174,252,.80));
  box-shadow:0 12px 30px rgba(134,174,252,.18);display:grid;place-items:center}
.brandMark svg{width:22px;height:22px;opacity:.92}
.navLinks{display:flex;align-items:center;gap:8px;flex:0 1 auto}
.navLinks a{padding:10px 12px;border-radius:14px;color:rgba(20,52,59,.72);font-weight:750;white-space:nowrap}
.navLinks a:hover{background:rgba(20,52,59,.06);text-decoration:none}
.navLinks a.active{background:rgba(20,52,59,.06);text-decoration:none}
.navCta{display:inline-flex;align-items:center;justify-content:center;margin-left:auto;padding:10px 14px;border-radius:14px;white-space:nowrap;
  background:rgba(255,107,106,.16);border:1px solid rgba(255,107,106,.26);color:rgba(20,52,59,.92);font-weight:800}
.navCta:hover{text-decoration:none;background:rgba(255,107,106,.24)}
.navToggle{display:none;align-items:center;justify-content:center;flex-direction:column;gap:4px;width:42px;height:42px;
  border-radius:12px;border:1px solid rgba(20,52,59,.14);background:rgba(255,255,255,.88);color:rgba(20,52,59,.9);cursor:pointer}
.navToggleBar{display:block;width:16px;height:2px;background:currentColor;border-radius:99px;transition:transform .2s ease,opacity .2s ease}
.navToggle[aria-expanded="true"] .navToggleBar:nth-child(1){transform:translateY(6px) rotate(45deg)}
.navToggle[aria-expanded="true"] .navToggleBar:nth-child(2){opacity:0}
.navToggle[aria-expanded="true"] .navToggleBar:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

@media (max-width:1024px){
  .navInner{gap:10px;min-height:74px}
  .brand{min-width:160px}
  .brandTitle{font-size:clamp(19px,2vw,28px)}
  .navLinks a{padding:9px 10px}
}

@media (max-width:768px){
  .navInner{min-height:72px;gap:8px}
  .brand{flex:1 1 auto;min-width:0;max-width:calc(100% - 176px)}
  .brandTitle{font-size:clamp(18px,5.2vw,24px)}
  .navToggle{display:inline-flex;flex:0 0 auto;order:2}
  .navLinks{display:none;position:absolute;left:0;right:0;top:100%;padding:12px;border-radius:18px;
    background:rgba(251,244,234,.97);border:1px solid rgba(20,52,59,.12);box-shadow:var(--shadowSoft);flex-direction:column;align-items:stretch;gap:6px}
  .navLinks.is-open{display:flex}
  .navLinks a{display:block;padding:11px 12px}
  .navCta{order:3;margin-left:0;padding:10px 12px;font-size:14px}
}

@media (max-width:420px){
  .brand{max-width:calc(100% - 152px)}
  .navCta{padding:9px 10px;font-size:13px}
}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:12px 16px;border-radius:999px;border:1px solid rgba(20,52,59,.14);
  background:rgba(255,255,255,.80);color:rgba(20,52,59,.92);font-weight:900;text-decoration:none!important}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btnPrimary{background:linear-gradient(135deg,rgba(255,107,106,.98),rgba(255,107,106,.78));
  border-color:rgba(255,107,106,.55);color:#fff;box-shadow:0 14px 36px rgba(255,107,106,.16)}
.btnSoft{background:rgba(124,201,184,.20);border-color:rgba(124,201,184,.32)}
.btnGhost{background:rgba(255,255,255,.62)}

/* Home HERO */
.hero{margin-top:10px;border-radius:var(--radiusLg);overflow:hidden;border:1px solid rgba(20,52,59,.10);
  box-shadow:var(--shadowSoft);position:relative;background:#000}
.heroBg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.02)}
.heroOverlay{position:absolute;inset:0;background:
  linear-gradient(90deg,rgba(12,30,34,.72) 0%,rgba(12,30,34,.35) 55%,rgba(12,30,34,.10) 100%),
  radial-gradient(70% 100% at 15% 50%,rgba(0,0,0,.25),transparent 60%),
  linear-gradient(180deg,rgba(0,0,0,.10),rgba(0,0,0,.35))}
.heroContent{position:relative;min-height:360px;padding:58px 54px;display:flex;align-items:flex-end}
@media (max-width:720px){.heroContent{padding:44px 22px;min-height:320px}}
.kicker{display:inline-flex;align-items:center;gap:10px;font-weight:900;letter-spacing:.14em;text-transform:uppercase;font-size:12px;color:rgba(255,255,255,.82)}
.kickerDot{width:9px;height:9px;border-radius:99px;background:rgba(134,174,252,.92);box-shadow:0 10px 18px rgba(134,174,252,.28)}
.hTitle{margin:14px 0 8px;font-size:54px;line-height:1.02;color:#fff;font-weight:950;letter-spacing:-.02em}
@media (max-width:720px){.hTitle{font-size:42px}}
.hSub{margin:0 0 18px;max-width:52ch;color:rgba(255,255,255,.86);font-size:18px}
.heroBtns{display:flex;flex-wrap:wrap;gap:12px}

/* Stories page */
.pageHero{text-align:center;padding:36px 0 10px}
.pageHero h1{margin:0 0 8px;font-size:44px;font-weight:950;letter-spacing:-.02em}
.pageHero p{margin:0 auto;max-width:72ch;color:var(--muted);line-height:1.6}
.filterPills{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:18px}
.filterPills button{cursor:pointer;border:1px solid var(--border);background:rgba(255,255,255,.72);color:rgba(20,52,59,.76);
  padding:9px 14px;border-radius:999px;font-weight:900;font-size:12px}
.filterPills button.active{background:rgba(124,201,184,.26);border-color:rgba(124,201,184,.38)}
.storiesGrid{margin-top:22px;display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media (max-width:980px){.storiesGrid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.storiesGrid{grid-template-columns:1fr}}
.storyCard{padding:12px}
.storyThumb{border-radius:18px;overflow:hidden;height:170px;border:1px solid rgba(20,52,59,.10);position:relative;
  background:
    radial-gradient(110% 110% at 20% 20%,rgba(134,174,252,.35),transparent 55%),
    radial-gradient(110% 110% at 80% 30%,rgba(124,201,184,.30),transparent 55%),
    radial-gradient(110% 110% at 60% 80%,rgba(255,107,106,.22),transparent 55%),
    linear-gradient(135deg,rgba(255,255,255,.70),rgba(255,255,255,.32));
}
.storyThumb::after{content:"";position:absolute;inset:0;opacity:.22;background-image:url("./img/hero-cabin-river.png");background-size:cover;background-position:center;mix-blend-mode:multiply}
.badge{position:absolute;top:10px;left:10px}
.storyTitle{margin:10px 0 6px;font-size:16px;font-weight:950}
.storyDesc{margin:0;color:var(--muted);font-size:13px;line-height:1.55;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.storyMeta{margin-top:10px;display:flex;gap:10px;align-items:center;color:rgba(20,52,59,.62);font-size:12px;font-weight:800}
.storyMeta .dot{width:4px;height:4px;border-radius:99px;background:rgba(20,52,59,.35)}
.ctaStrip{
  margin: 42px 0 0;
  border-radius: var(--radiusLg);
  border:1px solid rgba(20,52,59,.08);
  background: linear-gradient(180deg, rgba(124,201,184,.18), rgba(255,255,255,.55));
  box-shadow: var(--shadowSoft);
  padding: 44px 18px;
  text-align:center;
}
.ctaStrip h2{margin:0 0 8px;font-size:38px;font-weight:950;letter-spacing:-.02em}
.ctaStrip p{margin:0 auto 16px;max-width:70ch;color:var(--muted);line-height:1.6}
.ctaStrip .row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* Parents page */
.parentsPage{padding:34px 0 8px}
.parentsSection{padding:14px 0 34px}
.parentsHeroSection{text-align:center;padding-top:10px;padding-bottom:32px}
.parentsHeroTitle{margin:0;font-size:clamp(42px,5vw,64px);font-weight:950;letter-spacing:-.02em;color:#25464b}
.parentsHeroSubtitle{margin:12px auto 0;max-width:64ch;color:rgba(37,70,75,.78);font-size:22px;line-height:1.55}
.parentsSectionTitle{margin:0 0 24px;text-align:center;font-size:clamp(34px,4.2vw,52px);font-weight:950;letter-spacing:-.02em;color:#25464b}
.parentsBenefits{display:grid;gap:34px}
.parentsBenefitRow{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);column-gap:32px;align-items:center}
.parentsBenefitRowReverse .parentsBenefitContent{order:1}
.parentsBenefitRowReverse .parentsImageCard{order:2}
.parentsImageCard{margin:0;border-radius:18px;overflow:hidden;border:1px solid rgba(20,52,59,.08);box-shadow:0 10px 24px rgba(20,52,59,.08);background:#fff;aspect-ratio:4/3;max-width:560px}
.parentsImageCard img{display:block;width:100%;height:100%;object-fit:cover}
.parentsBenefitContent{padding:6px 4px;max-width:560px}
.parentsBenefitIcon{width:34px;height:34px;border-radius:11px;border:1px solid transparent;display:grid;place-items:center;font-size:15px;margin:0}
.parentsBenefitIconGreen{background:#e8f3e7;color:#4f9c66}
.parentsBenefitIconPeach{background:#fdebe4;color:#d67f5f}
.parentsBenefitIconLilac{background:#efe8fb;color:#9475d0}
.parentsBenefitIconBlue{background:#e8f3f7;color:#5d89a0}
.parentsBenefitHeading{display:flex;align-items:center;gap:10px;margin:0 0 12px}
.parentsBenefitContent h2{margin:0;font-size:42px;font-weight:950;letter-spacing:-.015em;color:#23474c}
.parentsBenefitContent ul{list-style:none;margin:0;padding:0;display:grid;gap:10px;color:rgba(36,63,69,.82);font-size:18px;line-height:1.45}
.parentsBenefitContent li{position:relative;padding-left:20px}
.parentsBenefitContent li::before{content:"✓";position:absolute;left:0;top:0;color:#6fb985;font-weight:900}
.parentsLoveGrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.parentsLoveCard{padding:22px 20px;text-align:center}
.parentsLoveHeading{display:flex;align-items:center;justify-content:center;gap:8px;margin:0 0 10px}
.parentsLoveCard .parentsBenefitIcon{margin:0}
.parentsLoveCard h3{margin:0;font-size:26px;font-weight:950;color:#27484e}
.parentsLoveCard p{margin:0;color:rgba(36,63,69,.78);font-size:15px;line-height:1.45}
.parentsFaqWrap{max-width:1000px;margin:0 auto;display:grid;gap:12px}
.parentsFaqWrap details{background:rgba(255,255,255,.78);border:1px solid rgba(20,52,59,.08);border-radius:14px;padding:14px 18px;box-shadow:0 6px 16px rgba(20,52,59,.06)}
.parentsFaqWrap summary{cursor:pointer;font-weight:900;color:#27484e}
.parentsFaqWrap details p{margin:10px 0 0;color:var(--muted);font-size:14px;line-height:1.6}

@media (max-width:1200px){
  .parentsHeroTitle{font-size:clamp(36px,5vw,56px)}
  .parentsHeroSubtitle{font-size:18px}
  .parentsBenefitContent h2{font-size:35px}
  .parentsBenefitContent ul{font-size:16px}
  .parentsLoveCard h3{font-size:22px}
}

@media (max-width:980px){
  .parentsBenefitRow,.parentsBenefitRowReverse{grid-template-columns:1fr;row-gap:14px}
  .parentsBenefitRowReverse .parentsBenefitContent,.parentsBenefitRowReverse .parentsImageCard{order:initial}
  .parentsImageCard,.parentsBenefitContent{max-width:none}
  .parentsBenefitContent{padding:6px 0}
  .parentsLoveGrid{grid-template-columns:1fr}
}

@media (max-width:640px){
  .parentsPage{padding-top:22px}
  .parentsSection{padding-bottom:24px}
  .parentsHeroTitle{font-size:44px}
  .parentsHeroSubtitle{font-size:16px}
  .parentsSectionTitle{font-size:36px}
  .parentsBenefitContent h2{font-size:31px}
  .parentsBenefitContent ul{font-size:15px}
}

/* Footer */
.footer{
  margin-top:52px;
  padding:44px 24px 30px;
  background:var(--footer);
  color:rgba(255,255,255,.86);
  border-radius:26px 26px 0 0;
}
.footerGrid{
  display:grid;
  grid-template-columns:minmax(260px,1.6fr) repeat(2,minmax(160px,1fr));
  gap:20px;
  align-items:start;
}
.footerGrid>div{
  padding:16px;
  border-radius:18px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.10);
}
.footer h4{margin:0 0 12px;font-weight:950;color:#fff;font-size:15px;letter-spacing:.01em}
.footer .brand{margin-bottom:12px;flex:0 1 auto}
.footer .brandTitle{color:#fff}
.footer a{color:rgba(255,255,255,.82)}
.footer a:hover{color:#fff;text-decoration:none}
.footer ul{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.footer ul a{display:inline-flex;padding:4px 0}
.badgeSafe{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:999px;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);font-weight:900;color:#fff;margin-top:6px}
.footerBottom{
  margin-top:20px;
  padding-top:16px;
  border-top:1px solid rgba(255,255,255,.16);
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px 16px;
  flex-wrap:wrap;
  font-size:12px;
  color:rgba(255,255,255,.72);
}

@media (max-width:980px){
  .footerGrid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .footerGrid>div:first-child{grid-column:1/-1}
}

@media (max-width:640px){
  .footer{padding:36px 14px 24px}
  .footerGrid{grid-template-columns:1fr;gap:12px}
  .footerGrid>div{padding:14px}
  .footerBottom{font-size:11.5px;justify-content:center;text-align:center}
}

/* Floating chat */
.fab{position:fixed;right:18px;bottom:18px;z-index:60}
.fab button{width:54px;height:54px;border-radius:18px;border:1px solid rgba(20,52,59,.12);
  background:rgba(255,255,255,.90);box-shadow:var(--shadowSoft);cursor:pointer;display:grid;place-items:center}
.fabPanel{position:absolute;right:0;bottom:64px;width:min(320px,calc(100vw - 36px));
  background:rgba(255,255,255,.95);border:1px solid rgba(20,52,59,.12);border-radius:20px;box-shadow:var(--shadow);
  padding:14px;display:none}
.fabPanel.open{display:block}
.fabPanel p{margin:0;color:var(--muted);font-size:13px}
