*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:#f7f6f2;font-family:'Hanken Grotesk',system-ui,-apple-system,sans-serif;color:#2f2a25;-webkit-font-smoothing:antialiased}
html,body{overflow-x:hidden;max-width:100%}
img{max-width:100%}
/* let grid/flex children shrink so wide content wraps instead of overflowing on mobile */
[style*="grid-template-columns"]>*{min-width:0}
h1,h2,h3,h4{margin:0}
main{display:block}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.btn{display:inline-block;text-decoration:none;border-radius:999px;font-weight:600;font-family:inherit;cursor:pointer;border:none;line-height:1.15;transition:background .15s ease,transform .15s ease,box-shadow .15s ease}
.btn-lg{padding:16px 30px;font-size:16.5px}
.btn-sm{padding:11px 20px;font-size:14.5px}
.btn-green{background:#5b8a72;color:#fff;box-shadow:0 8px 22px rgba(91,138,114,.3)}
.btn-green:hover{background:#487059}
.btn-outline{background:#fff;color:#46705b;border:1px solid #d9d2c6}
.btn-outline:hover{background:#f1ede5}
.btn-cream{background:#f2c88f;color:#2f2a25}
.btn-cream:hover{background:#f6d6a6}
.lift{transition:transform .18s ease,box-shadow .18s ease}
.lift:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(47,42,37,.10)}
.linkcard:hover{box-shadow:0 22px 52px rgba(47,42,37,.13)}
.svc-arrow{transition:transform .15s ease}
.svc-card:hover .svc-arrow{transform:translateX(4px)}
.field{font-family:inherit;font-size:15px;padding:13px 15px;border:1px solid #ddd6ca;border-radius:12px;background:#faf9f6;color:#2f2a25;outline:none;width:100%}
.field:focus{border-color:#5b8a72;background:#fff}
/* header */
.site-header{position:sticky;top:0;z-index:100;background:rgba(247,246,242,.86);backdrop-filter:saturate(140%) blur(10px);-webkit-backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid #ece7df}
.nav-wrap{max-width:1180px;margin:0 auto;padding:14px 24px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none;flex-shrink:0}
.brand-mark{width:38px;height:38px;border-radius:12px;background:#5b8a72;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(91,138,114,.28);flex-shrink:0}
.brand-ring{width:14px;height:14px;border-radius:50%;border:3px solid #f3ece0}
.brand-text{display:flex;flex-direction:column;line-height:1.05;white-space:nowrap}
.brand-name{font-family:'Newsreader',serif;font-size:20px;font-weight:600;color:#2f2a25;letter-spacing:-.01em}
.brand-loc{font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:#5b8a72}
.desktop-nav{display:flex;align-items:center;gap:4px}
.nav-link{position:relative;padding:9px 14px;font-size:15px;font-weight:500;color:#3c3731;text-decoration:none;border-radius:10px;background:none;border:none;cursor:pointer;font-family:inherit;display:inline-flex;align-items:center;gap:5px}
.nav-link:hover{color:#5b8a72}
.nav-link.is-active::after{content:'';position:absolute;left:14px;right:14px;bottom:2px;height:3px;border-radius:3px;background:#d98c5f}
.nav-item{position:relative}
.nav-item.is-active>.nav-trigger::after{content:'';position:absolute;left:14px;right:26px;bottom:2px;height:3px;border-radius:3px;background:#d98c5f}
.nav-item>.dropdown{position:absolute;top:100%;left:0;min-width:240px;padding-top:10px;opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity .16s ease,transform .16s ease,visibility .16s ease;z-index:90}
.nav-item:hover>.dropdown,.nav-item:focus-within>.dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown-card{background:#fff;border:1px solid #ece7df;border-radius:16px;padding:8px;box-shadow:0 16px 40px rgba(47,42,37,.14);display:flex;flex-direction:column;gap:1px}
.dropdown-card a{display:block;padding:10px 14px;font-size:14.5px;font-weight:500;color:#3c3731;text-decoration:none;border-radius:10px;white-space:nowrap}
.dropdown-card a:hover{background:#eef3ef;color:#46705b}
.burger{display:none;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;border:1px solid #e2dcd2;background:#fff;cursor:pointer;flex-shrink:0}
.mobile-panel{display:none}
.mobile-inner{max-width:1180px;margin:0 auto;padding:8px 18px 22px;display:flex;flex-direction:column;gap:0}
.mobile-inner a{padding:13px 12px;font-size:16px;font-weight:500;color:#2f2a25;text-decoration:none;border-bottom:1px solid #f0ebe3}
.mobile-inner a.m-sub{padding:11px 12px 11px 22px;font-size:15px;font-weight:400;color:#3c3731;border-bottom:none}
.mobile-inner .m-label{padding:14px 12px 6px;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#9a948b}
.mobile-inner .btn{border-bottom:none;display:block}
/* footer */
.site-footer{background:#2f2a25;color:#e9e3d8}
.footer-grid{max-width:1180px;margin:0 auto;padding:64px 24px 36px;display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:44px 32px}
.footer-about{max-width:300px}
.footer-brand{display:flex;align-items:center;gap:11px;margin-bottom:16px}
.footer-brand-name{font-family:'Newsreader',serif;font-size:20px;font-weight:600;color:#f7f3ec}
.footer-about p{margin:0;font-size:14.5px;line-height:1.6;color:#b7afa1}
.footer-pill{display:inline-flex;align-items:center;gap:8px;margin-top:18px;padding:8px 14px;background:rgba(91,138,114,.22);border:1px solid rgba(91,138,114,.4);border-radius:999px;font-size:13px;font-weight:600;color:#cfe6d8}
.footer-pill .dot{width:8px;height:8px;border-radius:50%;background:#7fbf9a}
.site-footer h4{margin:0 0 16px;font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#8d8678}
.f-col{display:flex;flex-direction:column;gap:11px}
.f-link{font-size:14.5px;color:#cfc8ba;text-decoration:none}
.f-link:hover{color:#fff}
.footer-bottom{border-top:1px solid #443e36}
.footer-bottom-inner{max-width:1180px;margin:0 auto;padding:20px 24px;display:flex;flex-wrap:wrap;gap:10px 24px;align-items:center;justify-content:space-between;font-size:13px;color:#8d8678}
/* article */
.article{max-width:680px;margin:0 auto;padding:8px 24px 20px;font-size:18.5px;line-height:1.75;color:#3f3a33}
.article>p{margin:0 0 22px}
.article p.lead{font-size:21px;line-height:1.6;color:#2a2620;margin:0 0 22px}
.article h2{margin:34px 0 14px;font-family:'Newsreader',serif;font-weight:600;font-size:28px;line-height:1.2;color:#2a2620}
.article blockquote{margin:30px 0;padding:22px 26px;background:#e8efe9;border-radius:18px;border-left:4px solid #5b8a72}
.article blockquote p{margin:0;font-family:'Newsreader',serif;font-size:22px;line-height:1.4;font-style:italic;color:#2a2620}
.article ul{margin:0 0 22px;padding:0;list-style:none;display:flex;flex-direction:column;gap:13px}
.article li{position:relative;padding-left:22px;line-height:1.7}
.article li::before{content:'';position:absolute;left:2px;top:11px;width:8px;height:8px;border-radius:50%;background:#5b8a72}
.article a{color:#46705b}
/* faq */
.faq{display:flex;flex-direction:column;gap:12px}
.faq details{background:#fff;border:1px solid #ece7df;border-radius:18px;overflow:hidden}
.faq summary{list-style:none;cursor:pointer;padding:20px 22px;font-family:'Newsreader',serif;font-size:19px;font-weight:600;color:#2a2620;display:flex;align-items:center;justify-content:space-between;gap:12px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'';flex-shrink:0;width:10px;height:10px;border-right:2px solid #9a948b;border-bottom:2px solid #9a948b;transform:rotate(45deg);transition:transform .2s ease}
.faq details[open] summary::after{transform:rotate(-135deg)}
.faq p{margin:0;padding:0 22px 20px;font-size:16px;line-height:1.65;color:#5e574d}
/* hero badge */
.hero-visual{position:relative}
.hero-badge{position:absolute;bottom:-42px;left:-20px;transform:rotate(-3deg);background:#5b8a72;color:#fff;padding:14px 20px;border-radius:18px;box-shadow:0 14px 30px rgba(91,138,114,.35)}
@media(max-width:760px){
  .hero-visual{display:flex;flex-direction:column;align-items:flex-start}
  .hero-badge{position:static;transform:rotate(-2deg);bottom:auto;left:auto;margin:20px 0 0}
}
@media(max-width:880px){
  .desktop-nav{display:none}
  .burger{display:inline-flex}
  .mobile-panel{display:block;max-height:0;overflow:hidden;opacity:0;transition:max-height .3s ease,opacity .2s ease;background:rgba(247,246,242,.98);border-bottom:1px solid #ece7df}
  .mobile-panel.open{max-height:1400px;opacity:1}
}