:root{
  --cream:#F4EEE4;
  --cream-2:#F8F5EF;
  --ink:#1D1C19;
  --ink-soft:#3A3933;
  --muted:#6E6C63;
  --green:#1F5B3F;
  --green-dark:#17492F;
  --line:#E6E1D5;
  --card:#FFFFFF;
  --shadow:0 22px 60px -18px rgba(46,34,16,.30);
  --shadow-sm:0 8px 24px -12px rgba(46,34,16,.22);
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;color:var(--ink);background:var(--cream-2)}
a{text-decoration:none;color:inherit}
img,video{display:block;max-width:100%}
.container{width:100%;max-width:1180px;margin:0 auto;padding:0 40px}
.serif{font-family:'Newsreader',Georgia,serif}
section{scroll-margin-top:84px}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 22px;border:none;border-radius:10px;cursor:pointer;
  font-family:inherit;font-size:15.5px;font-weight:600;transition:background .18s,transform .06s,box-shadow .18s;
}
.btn-primary{background:var(--green);color:#fff}
.btn-primary:hover{background:var(--green-dark)}
.btn-primary:active{transform:translateY(1px)}
.btn-ghost{background:#fff;color:var(--ink);border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--green);color:var(--green)}

/* ---------- STICKY HEADER ---------- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(248,245,239,.86);backdrop-filter:saturate(1.4) blur(10px);border-bottom:1px solid transparent;transition:border-color .2s,box-shadow .2s}
.site-header.scrolled{border-color:var(--line);box-shadow:0 6px 20px -16px rgba(46,34,16,.5)}
.topnav{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.brand{display:flex;align-items:center;gap:11px}
.logo{width:30px;height:30px;border-radius:50%;background:var(--green);display:grid;place-items:center;flex:none;box-shadow:0 2px 8px rgba(31,91,63,.30)}
.logo svg{width:15px;height:15px}
.wordmark{font-size:18px;letter-spacing:-.01em;color:var(--ink)}
.wordmark b{font-weight:700}.wordmark span{font-weight:400;color:var(--muted)}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{font-size:14.5px;font-weight:500;color:var(--ink-soft);transition:color .18s}
.nav-links a:hover{color:var(--green)}
.nav-phone{display:inline-flex;align-items:center;gap:7px;color:var(--green);font-weight:600}
.nav-phone svg{width:14px;height:14px}
.nav-cta{padding:9px 16px;font-size:14px}
/* Keep button colors inside the nav — beats the .nav-links a color rule above. */
.nav-links a.btn-primary{color:#fff}
.nav-links a.btn-ghost{color:var(--ink)}
.nav-links a.btn-primary:hover{color:#fff}
.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:6px}
.menu-toggle svg{width:26px;height:26px;color:var(--ink)}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:660px;display:flex;flex-direction:column;overflow:hidden;isolation:isolate;background:var(--cream) center/cover no-repeat}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:0;filter:saturate(1.03) contrast(1.015)}
.hero-wash{position:absolute;inset:0;z-index:1;pointer-events:none;background:
  linear-gradient(180deg,rgba(244,238,228,.5) 0%,rgba(244,238,228,0) 12%),
  linear-gradient(180deg,rgba(244,238,228,0) 80%,rgba(244,238,228,.55) 93%,var(--cream-2) 100%),
  linear-gradient(96deg,rgba(244,238,228,.93) 0%,rgba(244,238,228,.86) 16%,rgba(244,238,228,.54) 30%,rgba(244,238,228,.26) 42%,rgba(244,238,228,.20) 52%,rgba(244,238,228,.30) 63%,rgba(244,238,228,.48) 80%,rgba(244,238,228,.64) 100%)}
.hero-inner{position:relative;z-index:2;flex:1;display:flex;flex-direction:column;width:100%;max-width:1180px;margin:0 auto;padding:0 40px}
.hero-grid{flex:1;display:grid;grid-template-columns:minmax(0,1.1fr) minmax(360px,410px);align-items:center;gap:56px;padding:40px 0 76px}
.eyebrow{font-size:12.5px;font-weight:700;letter-spacing:.145em;text-transform:uppercase;color:var(--green);margin-bottom:20px}
.hero h1{font-family:'Newsreader',Georgia,serif;font-weight:500;font-size:clamp(2.5rem,4.6vw,3.45rem);line-height:1.06;letter-spacing:-.012em;color:var(--ink);max-width:14ch}
.subcopy{margin-top:22px;max-width:34ch;font-size:17.5px;line-height:1.6;color:var(--ink-soft)}
.trust{display:flex;flex-wrap:wrap;gap:20px;margin-top:28px}
.trust span{display:inline-flex;align-items:center;gap:8px;font-size:13.5px;color:var(--ink-soft)}
.trust .tick{width:17px;height:17px;border-radius:50%;background:rgba(31,91,63,.12);color:var(--green);display:grid;place-items:center;flex:none}
.trust .tick svg{width:10px;height:10px}

/* ---------- QUIZ CARD ---------- */
.card{background:var(--card);border:1px solid rgba(20,16,8,.05);border-radius:18px;box-shadow:var(--shadow);padding:24px 26px 26px}
.card-head{display:flex;align-items:center;justify-content:space-between}
.card-title{font-size:17px;font-weight:700;color:var(--ink)}
.card-step{font-size:13px;color:var(--muted);font-weight:500}
.progress{height:5px;background:#E9E4D9;border-radius:999px;margin:14px 0 20px;overflow:hidden}
.progress i{display:block;height:100%;width:20%;background:var(--green);border-radius:999px;transition:width .35s cubic-bezier(.2,.7,.2,1)}
.step{display:none;animation:fadeStep .35s ease both}
.step.active{display:block}
@keyframes fadeStep{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.q{font-size:18.5px;font-weight:700;color:var(--ink);margin-bottom:4px;line-height:1.25}
.q-sub{font-size:13.5px;color:var(--muted);margin-bottom:16px}
.options{display:grid;gap:10px}
.opt{display:flex;align-items:center;gap:12px;width:100%;text-align:left;padding:14px 15px;border:1.5px solid var(--line);border-radius:12px;background:#fff;cursor:pointer;font:inherit;font-size:15px;color:var(--ink);transition:border-color .15s,background .15s,transform .06s}
.opt:hover{border-color:var(--green);background:#FAFCFA}
.opt:active{transform:translateY(1px)}
.opt.selected{border-color:var(--green);background:#F0F6F2;box-shadow:0 0 0 3px rgba(31,91,63,.10)}
.opt .ic{width:34px;height:34px;border-radius:9px;background:#E5EFE8;color:var(--green);display:grid;place-items:center;flex:none}
.opt .ic svg{width:18px;height:18px}
.field{width:100%;font-family:inherit;font-size:15px;color:var(--ink);padding:13px 15px;border:1px solid var(--line);border-radius:10px;background:#fff;margin-bottom:12px;transition:border-color .18s,box-shadow .18s}
.field::placeholder{color:#9A988E}
.field:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(31,91,63,.12)}
.field.invalid{border-color:#C0492F;box-shadow:0 0 0 3px rgba(192,73,47,.12)}
.consent{display:flex;gap:9px;align-items:flex-start;font-size:11.5px;line-height:1.5;color:var(--muted);margin:2px 0 14px}
.consent input{margin-top:2px;accent-color:var(--green);width:15px;height:15px;flex:none}
.consent a{color:var(--green);text-decoration:underline}
.card .btn{width:100%;margin-top:2px}
.step-foot{display:flex;align-items:center;justify-content:space-between;margin-top:14px}
.back-link{font-size:13.5px;color:var(--muted);cursor:pointer;background:none;border:none;font:inherit;padding:0}
.back-link:hover{color:var(--ink-soft)}
.reassure{font-size:12px;color:var(--muted);text-align:center;margin-top:12px;display:flex;align-items:center;justify-content:center;gap:6px}
.reassure svg{width:13px;height:13px;color:var(--green)}
/* success */
.check-circle{width:56px;height:56px;border-radius:50%;background:#E5EFE8;border:1px solid #D2E3D7;color:var(--green);display:grid;place-items:center;margin:6px auto 16px;animation:pop .4s cubic-bezier(.2,.9,.3,1.4) both}
@keyframes pop{from{transform:scale(.4);opacity:0}to{transform:scale(1);opacity:1}}
.check-circle svg{width:26px;height:26px}
.success-title{text-align:center;font-size:20px;font-weight:700;margin-bottom:6px}
.success-body{text-align:center;color:var(--muted);font-size:14.5px;line-height:1.5;max-width:30ch;margin:0 auto}
.field-err{color:#C0492F;font-size:12.5px;margin:-6px 0 10px}

/* ---------- STATS BAND ---------- */
.stats{background:var(--cream-2);border-top:1px solid rgba(20,16,8,.06)}
.stats-inner{max-width:1180px;margin:0 auto;padding:44px 40px;display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
.stat .num{font-family:'Newsreader',Georgia,serif;font-weight:600;font-size:33px;color:var(--ink);letter-spacing:-.01em}
.stat .num .star{color:var(--green)}
.stat .lbl{margin-top:6px;font-size:13.5px;color:var(--muted)}

/* ---------- SECTION SHELL ---------- */
.sec{padding:84px 0}
.sec-alt{background:var(--cream)}
.sec-green{background:var(--green);color:#fff}
.sec-head{max-width:640px;margin:0 auto 52px;text-align:center}
.sec-eyebrow{font-size:12.5px;font-weight:700;letter-spacing:.145em;text-transform:uppercase;color:var(--green);margin-bottom:14px}
.sec-green .sec-eyebrow{color:#A9D6BC}
.sec-head h2{font-family:'Newsreader',Georgia,serif;font-weight:500;font-size:clamp(2rem,3.4vw,2.7rem);line-height:1.1;letter-spacing:-.01em}
.sec-head p{margin-top:14px;font-size:17px;line-height:1.6;color:var(--muted)}
.sec-green .sec-head p{color:rgba(255,255,255,.82)}

/* ---------- HOW IT WORKS ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.stepcard{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:30px 26px;box-shadow:var(--shadow-sm)}
.stepcard .n{width:40px;height:40px;border-radius:11px;background:var(--green);color:#fff;font-family:'Newsreader',serif;font-size:20px;font-weight:600;display:grid;place-items:center;margin-bottom:18px}
.stepcard h3{font-size:19px;font-weight:700;margin-bottom:8px}
.stepcard p{color:var(--muted);font-size:15px;line-height:1.6}

/* ---------- TYPES OF CARE ---------- */
.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.typecard{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:26px;transition:transform .18s,box-shadow .18s;box-shadow:var(--shadow-sm)}
.typecard:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.typecard .ic{width:46px;height:46px;border-radius:12px;background:#E5EFE8;color:var(--green);display:grid;place-items:center;margin-bottom:16px}
.typecard .ic svg{width:24px;height:24px}
.typecard h3{font-size:18px;font-weight:700;margin-bottom:8px}
.typecard p{color:var(--muted);font-size:14.5px;line-height:1.6}
.typecard .tag{display:inline-block;margin-top:14px;font-size:12.5px;color:var(--green);font-weight:600}

/* ---------- COSTS / HOW TO PAY ---------- */
.costs{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:48px;align-items:center}
.pay-list{display:grid;gap:14px}
.pay-item{display:flex;gap:14px;align-items:flex-start;background:var(--card);border:1px solid var(--line);border-radius:13px;padding:18px 20px}
.pay-item .ic{width:38px;height:38px;border-radius:10px;background:#E5EFE8;color:var(--green);display:grid;place-items:center;flex:none}
.pay-item .ic svg{width:19px;height:19px}
.pay-item h4{font-size:16px;font-weight:700;margin-bottom:3px}
.pay-item p{font-size:14px;color:var(--muted);line-height:1.55}
.cost-panel{background:var(--green);color:#fff;border-radius:20px;padding:38px 34px;box-shadow:var(--shadow)}
.cost-panel .big{font-family:'Newsreader',serif;font-size:46px;font-weight:600;line-height:1}
.cost-panel .big small{font-size:18px;font-weight:500;opacity:.8}
.cost-panel h3{font-size:21px;font-weight:600;margin:18px 0 10px}
.cost-panel p{color:rgba(255,255,255,.85);font-size:15px;line-height:1.6;margin-bottom:22px}
.cost-panel .btn{background:#fff;color:var(--green)}
.cost-panel .btn:hover{background:#EAF3EC}

/* ---------- TESTIMONIALS ---------- */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.quote{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:28px 26px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}
.stars{color:var(--green);letter-spacing:2px;font-size:15px;margin-bottom:14px}
.quote p{font-size:15.5px;line-height:1.65;color:var(--ink-soft);flex:1}
.quote .who{margin-top:18px;display:flex;align-items:center;gap:12px}
.quote .av{width:40px;height:40px;border-radius:50%;background:var(--green);color:#fff;display:grid;place-items:center;font-weight:600;font-size:15px;flex:none}
.quote .who b{display:block;font-size:14.5px}
.quote .who span{font-size:13px;color:var(--muted)}

/* ---------- FAQ ---------- */
.faq{max-width:760px;margin:0 auto}
.faq details{border-bottom:1px solid var(--line);padding:6px 0}
.faq summary{list-style:none;cursor:pointer;padding:18px 4px;font-size:17px;font-weight:600;display:flex;align-items:center;justify-content:space-between;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pl{width:22px;height:22px;flex:none;position:relative;transition:transform .2s}
.faq summary .pl::before,.faq summary .pl::after{content:'';position:absolute;background:var(--green);border-radius:2px}
.faq summary .pl::before{top:10px;left:3px;right:3px;height:2px}
.faq summary .pl::after{left:10px;top:3px;bottom:3px;width:2px;transition:transform .2s}
.faq details[open] summary .pl::after{transform:scaleY(0)}
.faq details[open] summary{color:var(--green)}
.faq .ans{padding:0 4px 20px;color:var(--muted);font-size:15.5px;line-height:1.7;max-width:64ch}

/* ---------- CTA BAND ---------- */
.cta-band{text-align:center;padding:80px 0}
.cta-band h2{font-family:'Newsreader',serif;font-weight:500;font-size:clamp(2rem,3.6vw,2.8rem);line-height:1.1;max-width:18ch;margin:0 auto}
.cta-band p{color:rgba(255,255,255,.85);font-size:17px;margin:16px auto 28px;max-width:46ch;line-height:1.6}
.cta-band .btn{background:#fff;color:var(--green);font-size:16.5px;padding:16px 30px}
.cta-band .btn:hover{background:#EAF3EC}
.cta-band .phone-line{margin-top:18px;font-size:14.5px;color:rgba(255,255,255,.8)}
.cta-band .phone-line a{color:#fff;font-weight:600;border-bottom:1px solid rgba(255,255,255,.4)}

/* ---------- FOOTER ---------- */
footer{background:var(--ink);color:#CFCDC5;padding:60px 0 30px;font-size:14px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.1)}
footer .brand .wordmark{color:#fff}
footer .brand .wordmark span{color:#9A988E}
.foot-about{margin-top:16px;line-height:1.65;color:#9A988E;max-width:34ch}
.foot-col h5{color:#fff;font-size:13px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px}
.foot-col a,.foot-col p{display:block;color:#B7B5AC;margin-bottom:9px;line-height:1.5}
.foot-col a:hover{color:#fff}
.foot-col a.btn-primary{color:#fff}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;padding-top:24px;color:#8A887F;font-size:12.5px}
.foot-bottom a{color:#8A887F}.foot-bottom a:hover{color:#fff}

/* ---------- entrance ---------- */
.fade{opacity:0;transform:translateY(10px);animation:rise .9s cubic-bezier(.2,.7,.2,1) forwards}
.fade.d1{animation-delay:.05s}.fade.d2{animation-delay:.14s}.fade.d3{animation-delay:.23s}.fade.d4{animation-delay:.32s}
@keyframes rise{to{opacity:1;transform:none}}
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- RESPONSIVE ---------- */
@media (max-width:1024px){
  .container,.hero-inner,.stats-inner{padding-left:26px;padding-right:26px}
  .nav-links{display:none}
  .menu-toggle{display:block}
  .hero-grid{grid-template-columns:1fr;gap:34px;padding:24px 0 56px}
  .hero{min-height:0}
  .hero h1{max-width:18ch}.subcopy{max-width:48ch}
  .card{max-width:460px}
  .stats-inner{grid-template-columns:repeat(2,1fr);gap:30px 20px;padding:36px 26px}
  .steps,.cards-grid,.quotes{grid-template-columns:1fr}
  .costs{grid-template-columns:1fr;gap:30px}
  .foot-grid{grid-template-columns:1fr 1fr;gap:30px}
  .hero-wash{background:linear-gradient(180deg,rgba(244,238,228,.78) 0%,rgba(244,238,228,.5) 30%,rgba(244,238,228,.6) 62%,rgba(244,238,228,.85) 100%)}
}
@media (max-width:680px){
  .container,.hero-inner,.stats-inner{padding-left:20px;padding-right:20px}
  .sec{padding:60px 0}
  .stats-inner{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr}
  .hero-video{transform:scale(1.3);transform-origin:50% 60%}
}
/* slide-in mobile menu */
.mobile-menu{position:fixed;inset:0;z-index:60;background:var(--cream-2);transform:translateX(100%);transition:transform .3s ease;display:flex;flex-direction:column;padding:24px}
.mobile-menu.open{transform:none}
.mobile-menu .mm-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}
.mobile-menu a{font-size:20px;font-weight:600;padding:16px 0;border-bottom:1px solid var(--line)}
.mm-close{background:none;border:none;cursor:pointer;font-size:28px;line-height:1;color:var(--ink)}

@media (prefers-reduced-motion:reduce){
  .hero-video{display:none}
  .fade,.reveal{animation:none;opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}
