
:root{
  --bg:#f7f5f0;
  --card:#ffffff;
  --text:#1f2a22;
  --muted:#5d665f;
  --accent:#2d5a3a;
  --accent-2:#dfe9df;
  --border:#d7ddd4;
  --max:1120px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.65;
}
a{color:var(--accent); text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:var(--max); margin:0 auto; padding:0 22px}
.site-header{
  position:sticky; top:0; z-index:10;
  background:rgba(247,245,240,.92); backdrop-filter: blur(10px);
  border-bottom:1px solid var(--border);
}
.header-inner{display:flex; justify-content:space-between; align-items:center; padding:16px 0}
.brand{font-weight:800; font-size:1.2rem; letter-spacing:.01em}
.nav{display:flex; gap:18px; flex-wrap:wrap; font-size:.98rem}
.hero{
  padding:72px 0 40px;
  background:linear-gradient(180deg,#eef4ee 0%,var(--bg) 100%);
  border-bottom:1px solid var(--border);
}
.hero h1{font-size:clamp(2rem,5vw,3.6rem); line-height:1.08; margin:0 0 16px}
.hero p{max-width:760px; font-size:1.12rem; color:var(--muted); margin:0 0 28px}
.btn-row{display:flex; gap:14px; flex-wrap:wrap}
.btn{
  display:inline-block; padding:12px 18px; border-radius:999px;
  font-weight:700; border:1px solid var(--accent); transition:.2s;
}
.btn.primary{background:var(--accent); color:#fff}
.btn.secondary{background:#fff; color:var(--accent)}
.btn:hover{text-decoration:none; transform:translateY(-1px)}
main section{padding:42px 0}
.grid{display:grid; gap:18px}
.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.card{
  background:var(--card); border:1px solid var(--border); border-radius:18px;
  padding:20px; box-shadow:0 2px 14px rgba(28,44,31,.04);
}
.card h3,.card h4{margin:0 0 8px}
.card p{margin:0; color:var(--muted)}
.section-head{margin-bottom:16px}
.section-head h2{margin:0 0 8px; font-size:1.8rem}
.section-head p{margin:0; color:var(--muted); max-width:760px}
.month-strip{display:flex; flex-wrap:wrap; gap:10px; margin-top:18px}
.pill{
  display:inline-block; padding:9px 13px; border-radius:999px;
  background:#fff; border:1px solid var(--border); font-weight:600; color:var(--text)
}
.quick-box{
  background:#f1f6f1; border:1px solid var(--border); border-radius:18px; padding:18px;
}
.quick-box ul{margin:0; padding-left:20px}
.quick-box li{margin:6px 0}
.content h1{font-size:clamp(2rem,4vw,3rem); line-height:1.1; margin:0 0 14px}
.content h2{font-size:1.7rem; margin:34px 0 12px}
.content h3{font-size:1.18rem; margin:22px 0 8px}
.content p{margin:0 0 14px}
.content ul{margin:0 0 16px; padding-left:20px}
.content li{margin:6px 0}
.two-col{display:grid; grid-template-columns:minmax(0,1fr) 320px; gap:28px}
.side-card{position:sticky; top:88px}
.note{color:var(--muted); font-size:.96rem}
.site-footer{
  border-top:1px solid var(--border); background:#f0f3ee; margin-top:50px
}
.footer-inner{padding:28px 0}
.footer-grid{display:grid; grid-template-columns:1.4fr 1fr; gap:24px}
.small{font-size:.94rem; color:var(--muted)}
.list-clean{list-style:none; padding:0; margin:0}
.list-clean li{margin:8px 0}
.feature-list{display:grid; gap:10px; padding-left:18px}
blockquote{
  margin:18px 0; padding:14px 18px; border-left:4px solid var(--accent);
  background:#fff; border-radius:10px;
}
@media (max-width:900px){
  .grid.cols-3,.grid.cols-4,.two-col,.footer-grid{grid-template-columns:1fr}
  .side-card{position:static}
}


.hero.hero-photo{
  position:relative;
  color:#fff;
  background-image: linear-gradient(rgba(10,18,12,.42), rgba(10,18,12,.52)), var(--hero-image);
  background-size:cover;
  background-position:center;
  overflow:hidden;
}
.hero.hero-photo .container{position:relative; z-index:1}
.hero.hero-photo p, .hero.hero-photo .small{color:rgba(255,255,255,.9)}
.hero.hero-photo::after{
  content:"";
  position:absolute; inset:0;
  border-bottom:1px solid rgba(255,255,255,.15);
}
.content .hero.hero-photo{padding:88px 0 56px !important; min-height:320px; display:flex; align-items:end}
.hero.hero-photo h1{text-shadow:0 2px 14px rgba(0,0,0,.22)}
.hero-badge{
  display:inline-block; margin-bottom:12px; padding:6px 10px; border-radius:999px;
  background:rgba(255,255,255,.16); border:1px solid rgba(255,255,255,.22); font-size:.9rem; font-weight:700;
}
.photo-credit{font-size:.82rem; color:rgba(255,255,255,.82); margin-top:18px}
@media (max-width:900px){
  .content .hero.hero-photo{min-height:260px; padding:72px 0 42px !important}
}


.newsletter-signup{padding:12px 0 28px}
.signup-embed{max-width:720px; margin:0 auto}
.content .newsletter-signup{padding:24px 0 8px}
.newsletter-signup-inline{margin:28px 0 8px}
