
:root{
  --bg:#f5fbf7;
  --ink:#0e1f17;
  --muted:#658b77;
  --brand:#2B7A4B;
  --brand-2:#3EA66E;
  --card:#ffffff;
  --glass: rgba(255,255,255,0.65);
  --shadow: 0 10px 30px rgba(24,60,40,0.12);
  --radius: 18px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  color:var(--ink);
  background: var(--bg) url('../img/pattern.svg') center/280px repeat;
  line-height:1.6;
  overflow-x:hidden;
}
a{color:var(--brand);text-decoration:none}
img{max-width:100%;display:block;border-radius:12px}
.container{width:min(1200px, 100% - 32px);margin:0 auto}

header{
  position:sticky;top:0;z-index:40;
  backdrop-filter:saturate(1.2) blur(8px);
  background:linear-gradient(180deg, rgba(245,251,247,0.85), rgba(245,251,247,0.55));
  border-bottom:1px solid rgba(43,122,75,0.08);
}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 0;
}
.nav .brand{display:flex;gap:10px;align-items:center}
.nav .links a{margin:0 10px;font-weight:600;color:#254432}
.nav .links a:hover{color:var(--brand)}
.nav .cta{
  padding:10px 16px;border-radius:999px;background:linear-gradient(135deg,var(--brand),var(--brand-2));color:white;
  box-shadow:var(--shadow);font-weight:700;border:none;cursor:pointer
}
.nav .cta:hover{transform:translateY(-1px) scale(1.01)}

.hero{
  position:relative;isolation:isolate;
  padding:80px 0 60px;
  background: radial-gradient(1200px 400px at 50% -20%, #e3f7ec 10%, transparent 60%);
}
.hero .wrap{
  display:grid;grid-template-columns:1.2fr 1fr;gap:32px;align-items:center
}
.badge{
  display:inline-flex;gap:8px;align-items:center;
  background:var(--glass);border:1px solid rgba(43,122,75,0.15);padding:8px 12px;border-radius:999px;
  box-shadow:var(--shadow)
}
h1{font-size:clamp(32px, 4vw, 56px);line-height:1.05;margin:14px 0 10px}
.lead{font-size:clamp(16px, 2vw, 20px);color:#2a4a3a}
.hero-cta{display:flex;gap:12px;margin-top:18px;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;gap:10px;padding:12px 18px;border-radius:12px;border:1px solid rgba(43,122,75,0.15);
  background:white;font-weight:700;color:#214131;cursor:pointer;box-shadow:var(--shadow)
}
.btn.primary{background:linear-gradient(135deg,var(--brand),var(--brand-2));color:white;border:none}
.btn.ghost{background:transparent}
.btn span.icon{display:inline-grid;place-items:center;width:22px;height:22px;border-radius:6px;background:#e7f5ee}

.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:24px}
.stat{background:var(--glass);border:1px solid rgba(43,122,75,0.12);padding:16px;border-radius:var(--radius);text-align:center;box-shadow:var(--shadow)}
.stat .num{font-size:28px;font-weight:800;color:#1e3a2e}
.stat .lbl{color:var(--muted);font-weight:600}

.hero-visual{
  position:relative;border-radius:22px;overflow:hidden;box-shadow:var(--shadow);background:#eaf6ef;
}
.hero-visual img{width:100%;height:auto;display:block}
#leaf-canvas{position:absolute;inset:0;z-index:0;opacity:0.75}

.section{padding:72px 0}
.section h2{font-size:clamp(28px, 3vw, 40px);margin:0 0 10px}
.section p.sub{color:#345c4b;margin-top:0}

.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:22px}
.card{
  background:var(--card);border:1px solid rgba(43,122,75,0.12);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow);
  transform:translateY(6px);opacity:0;transition:all .6s ease-out;
}
.card.in-view{transform:translateY(0);opacity:1}
.card .title{font-weight:800;font-size:18px;margin:8px 0 6px}
.tag{display:inline-block;background:#e7f5ee;color:#245a43;border:1px solid rgba(43,122,75,.2);padding:6px 10px;border-radius:999px;font-weight:700;font-size:12px;margin-right:8px}

.grid-park{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:20px}
.park{background:var(--card);border:1px solid rgba(43,122,75,0.12);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column}
.park .content{padding:14px}
.park .meta{display:flex;gap:10px;align-items:center;color:#39614d;font-weight:600}
.park .cta{margin-top:auto;padding:12px 14px;border-top:1px solid rgba(43,122,75,0.12);display:flex;gap:8px;justify-content:flex-end}

.itinerary{
  display:grid;grid-template-columns: 1.2fr 1fr;gap:18px;align-items:start;margin-top:18px
}
.option{
  background:var(--card);border:1px solid rgba(43,122,75,0.12);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)
}
.plan{background:linear-gradient(180deg,#eaf6ef, #ffffff);padding:16px;border-radius:var(--radius);border:1px solid rgba(43,122,75,0.12);box-shadow:var(--shadow)}

.row{display:flex;flex-wrap:wrap;gap:12px}
.pill{padding:10px 12px;border-radius:999px;background:#eef8f2;border:1px solid rgba(43,122,75,0.18);font-weight:700;color:#2a4a3a;cursor:pointer}
.pill.active{background:linear-gradient(135deg,var(--brand),var(--brand-2));color:white;border:none}

.slider{display:flex;gap:16px;overflow:auto;scroll-snap-type:x mandatory;padding-bottom:6px}
.slide{min-width:320px;scroll-snap-align:start;background:var(--card);border:1px solid rgba(43,122,75,0.12);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}

.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:18px}
.tier{background:var(--card);border:1px solid rgba(43,122,75,0.12);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);position:relative}
.tier .price{font-size:32px;font-weight:900;color:#1c3b2e}
.tier .save{position:absolute;top:12px;right:12px;background:#ffedd5;color:#7c4a03;font-weight:800;padding:6px 10px;border-radius:999px;font-size:12px;border:1px solid #facc15}

.gallery{columns:3 240px;column-gap:16px}
.gallery img{width:100%;break-inside:avoid;margin:0 0 16px}

.faq{display:grid;grid-template-columns:1fr;gap:10px}
.faq details{background:var(--card);border:1px solid rgba(43,122,75,0.12);border-radius:12px;padding:12px;box-shadow:var(--shadow)}
.faq summary{cursor:pointer;font-weight:800;color:#2a4a3a}

.contact{
  display:grid;grid-template-columns: 1fr 1.2fr;gap:18px;align-items:start;margin-top:18px
}
.form{background:var(--card);border:1px solid rgba(43,122,75,0.12);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
.form input,.form textarea, .form select{
  width:100%;padding:12px;border-radius:12px;border:1px solid rgba(43,122,75,0.25);margin:8px 0;font:inherit;background:#f7fcf9
}
.form button{width:100%;margin-top:8px}

.map{
  background:linear-gradient(135deg,#d7f1e3, #f0fbf6);
  border:1px solid rgba(43,122,75,0.12);border-radius:var(--radius);height:380px;position:relative;overflow:hidden;box-shadow:var(--shadow)
}
.marker{position:absolute;width:12px;height:12px;background:#ef4444;border:2px solid white;border-radius:999px;box-shadow:0 2px 6px rgba(0,0,0,0.2);transform:translate(-50%,-50%)}
.marker::after{content:'';position:absolute;bottom:-12px;left:50%;transform:translateX(-50%);width:2px;height:12px;background:#ef4444}

footer{
  margin-top:60px;padding:28px 0;background:#eaf6ef;border-top:1px solid rgba(43,122,75,0.12)
}
.footer-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px}
.small{font-size:12px;color:#3e6b57}

.reveal{opacity:0;transform:translateY(10px);transition:all .6s ease-out}
.reveal.in-view{opacity:1;transform:none}

/* Responsive */
@media (max-width: 980px){
  .hero .wrap{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr 1fr}
  .cards{grid-template-columns:1fr}
  .grid-park{grid-template-columns:1fr 1fr}
  .itinerary{grid-template-columns:1fr}
  .pricing{grid-template-columns:1fr}
  .contact{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
}
