
:root{
  --ink:#0a0a0a; --muted:#224030; --brand:#2f7a43; --accent:#e2f3e2;
  --shadow: 0 10px 30px rgba(0,0,0,.12); --radius:14px;
}
*{box-sizing:border-box} html,body{margin:0;padding:0}
body{font-family: system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, 'Helvetica Neue', Arial, sans-serif;
     color:var(--ink); background:#f6faf7; line-height:1.5}
.container{width:min(1100px, 92%); margin-inline:auto}
.narrow{width:min(900px, 92%); margin-inline:auto}
.site-header{position:sticky; top:0; z-index:1000; background:rgba(255,255,255,.9); backdrop-filter:saturate(1.5) blur(6px); box-shadow: var(--shadow)}
.header-inner{display:flex; align-items:center; justify-content:space-between; padding:10px 0}
.brand{display:flex; gap:.6rem; align-items:center; text-decoration:none; color:inherit}
.brand-text{font-weight:700}
.brand-logo{border-radius:8px}
.site-nav{display:flex; gap:1rem; align-items:center}
.site-nav a{color:#194126; text-decoration:none; font-weight:600; padding:.4rem .6rem; border-radius:8px}
.site-nav a:hover{background:var(--accent)}
.site-nav .cta{background:var(--brand); color:#fff}
.nav-toggle{display:none; background:none; border:0; font-size:1.4rem}
.site-nav a.social{border:1px solid #dfeee2; border-radius:999px; padding:.3rem .6rem}
@media (max-width:900px){
  .site-nav{display:none; position:absolute; top:62px; right:4%; background:#fff; padding:12px; border-radius:12px; box-shadow:var(--shadow); flex-direction:column}
  .nav-toggle{display:block}
}
/* HERO */
.hero.full{position:relative; min-height:72vh; display:grid; place-items:center; text-align:center; color:#fff}
.hero-bg{position:absolute; inset:0; overflow:hidden}
.hero-bg picture, .hero-bg img{width:100%; height:100%; object-fit:cover; display:block}
.hero-overlay{position:absolute; inset:0; background:linear-gradient(180deg, rgba(0,0,0,.35), rgba(0,0,0,.45))}
.hero-inner{position:relative; z-index:2; display:grid; gap:1rem}
.hero-logo{width:140px; height:auto; justify-self:center; filter:drop-shadow(0 6px 20px rgba(0,0,0,.4))}
.hero h1{font-size: clamp(1.9rem, 3.8vw, 3rem); margin:0}
.hero p{max-width: 760px; margin:0 auto}
/* SECTIONS */
.section{padding:56px 0}
.section.alt{background:#fff}
.grid-3{display:grid; grid-template-columns: repeat(3, 1fr); gap:18px}
@media (max-width:900px){ .grid-3{grid-template-columns:1fr} }
.grid-2{display:grid; grid-template-columns: repeat(2, 1fr); gap:18px}
@media (max-width:900px){ .grid-2{grid-template-columns:1fr} }
.card{background:#fff; border-radius:var(--radius); box-shadow:var(--shadow); padding:18px}
.gallery .photo picture, .photo img{width:100%; height:auto; border-radius:12px; box-shadow: var(--shadow)}
.pill{display:flex; gap:.6rem; flex-wrap:wrap; list-style:none; padding:0}
.pill li{background:#fff; border-radius:999px; padding:.4rem .8rem; border:1px solid #dfeee2}
/* CTA */
.button{display:inline-block; padding:.75rem 1.1rem; border-radius:12px; text-decoration:none; font-weight:700; border:2px solid #1f6132; color:#fff; background:#2f7a43}
.button:hover{filter:brightness(.96)}
.button.outline{background:transparent; color:#1f6132}
.cta-band{background:linear-gradient(180deg, #e9f6ec, #fff)}
.cta-band-inner{display:grid; gap:.4rem; text-align:center}
.cta-band .button{margin:.2rem}
/* MAP + FOOTER */
.map-card iframe{width:100%; height:320px; border:0; border-radius:12px}
.site-footer{background:#10381f; color:#e9f6ec; padding:28px 0}
.site-footer .small{opacity:.8; font-size:.9rem}
.cookie{position:fixed; bottom:14px; left:14px; right:14px; background:#fff; border-radius:12px; box-shadow: var(--shadow); padding:10px; display:none}
.cookie .linklike{background:#2f7a43; color:#fff; border:0; border-radius:10px; padding:.4rem .7rem; cursor:pointer}
