
:root{
  --brand:#3b5e1e; /* olive green from logo */
  --brand-dark:#2e4717;
  --accent:#ffffff;
  --text:#1b1b1b;
  --muted:#f5f7f2;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,'Helvetica Neue',Arial,'Noto Sans',sans-serif;color:var(--text);background:#fff;scroll-behavior:smooth}
a{color:var(--brand);text-decoration:none}
img{max-width:100%;display:block;height:auto}
.container{max-width:1120px;margin:0 auto;padding:0 20px}
.header{position:sticky;top:0;background:#fff9;backdrop-filter:saturate(180%) blur(8px);z-index:50;border-bottom:1px solid #e9ecef}
.nav{display:flex;align-items:center;justify-content:space-between;padding:12px 0}
.brand{display:flex;align-items:center;gap:12px}
.brand img{width:42px;height:42px;border-radius:10px;object-fit:cover}
.brand .name{font-weight:800;letter-spacing:.3px;color:var(--brand);font-size:1.15rem}
.menu a{margin:0 10px;font-weight:600;opacity:.9}
.btn{display:inline-block;padding:12px 18px;border-radius:999px;background:var(--brand);color:#fff;font-weight:700;transition:transform .2s ease,box-shadow .2s ease}
.btn:hover{transform:translateY(-1px);box-shadow:0 8px 20px rgba(0,0,0,.12)}
.hero{position:relative;isolation:isolate}
.hero .overlay{position:absolute;inset:0;background:linear-gradient(180deg, rgba(0,0,0,.5), rgba(0,0,0,.35))}
.hero .content{position:absolute;inset:0;display:grid;place-items:center;text-align:center;color:#fff;padding:24px}
.hero h1{font-size:clamp(28px, 4.5vw, 64px);line-height:1.05;margin:.2em 0 .35em 0;font-weight:900}
.hero p{font-size:clamp(16px,2.2vw,22px);opacity:.95}
.hero .badge{display:inline-block;background:#00000066;color:#fff;padding:8px 12px;border-radius:999px;margin-top:16px;border:1px solid #ffffff22;font-weight:700}
.hero picture img{width:100%;height:66vh;object-fit:cover;filter:saturate(105%) contrast(102%)}
.section{padding:64px 0}
.section h2{font-size:clamp(24px,3vw,36px);margin:0 0 8px 0}
.section p.lead{color:#4b4b4b;margin:0 0 24px 0}
.grid{display:grid;gap:18px}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
@media (max-width:900px){.grid-3{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.grid-3,.grid-2{grid-template-columns:1fr}}
.card{background:#fff;border:1px solid #eaeaea;border-radius:18px;overflow:hidden;box-shadow:0 10px 24px rgba(0,0,0,.05)}
.card .body{padding:16px}
.badge-soft{display:inline-block;border-radius:999px;padding:6px 10px;background:var(--muted);color:var(--brand);font-weight:700;font-size:.85rem}
.gallery{columns:1;column-gap:14px}
@media(min-width:640px){.gallery{columns:2}}
@media(min-width:1000px){.gallery{columns:3}}
.gallery figure{break-inside:avoid;margin:0 0 14px 0;border-radius:16px;overflow:hidden;cursor:zoom-in;position:relative;box-shadow:0 6px 20px rgba(0,0,0,.08)}
.gallery figcaption{position:absolute;left:10px;bottom:10px;background:#0008;color:#fff;padding:4px 10px;border-radius:999px;font-size:.8rem}
.whatsapp-float{position:fixed;right:18px;bottom:18px;z-index:60;background:#25D366;border-radius:999px;padding:12px 16px;display:flex;align-items:center;gap:10px;color:#fff;font-weight:800;box-shadow:0 10px 30px rgba(0,0,0,.25)}
.whatsapp-float svg{width:22px;height:22px;fill:#fff}
.footer{padding:28px 0;background:var(--brand);color:#fff;margin-top:32px}
.footer a{color:#fff;text-decoration:underline}
.map-wrap iframe{width:100%;min-height:320px;border:0;border-radius:16px}
/* Lightbox */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.9);display:none;align-items:center;justify-content:center;z-index:80}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:12px}
.lightbox.show{display:flex}
.fade-in{animation:fade .7s ease both}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.small{font-size:.9rem;color:#5b5b5b}
