/* ====== Paisana Viajera Styles ====== */
:root{
  --green:#567a3a;        /* del logo */
  --green-700:#365225;
  --cream:#faf7ef;
  --ink:#1e1e1e;
  --muted:#6b7280;
  --radius:18px;
  --shadow:0 10px 25px rgba(0,0,0,.08);
}
*{box-sizing:border-box}
html,body{margin:0}
body{
  font-family:Poppins, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--ink);
  background:#fff;
  line-height:1.6;
}
img{max-width:100%;height:auto;display:block}
.container{width:min(1120px, 92%); margin-inline:auto}

.topbar{
  position:sticky; top:0; z-index:50;
  backdrop-filter:saturate(1.2) blur(8px);
  background:rgba(255,255,255,.85);
  border-bottom:1px solid #eee;
}
.topbar .container{display:flex; align-items:center; justify-content:space-between; padding:10px 0}
.brand{display:flex; align-items:center; gap:12px; text-decoration:none; color:inherit}
.brand img{width:44px; height:44px; border-radius:50%; object-fit:cover}
.brand-text span{display:block; font-size:.78rem; color:var(--muted)}
.nav a{margin-left:18px; text-decoration:none; color:var(--ink); font-weight:600}
.nav .btn{margin-left:12px}
.btn{
  display:inline-flex; align-items:center; gap:.5rem;
  padding:10px 16px; border-radius:999px; font-weight:700;
  border:2px solid var(--green); color:var(--green);
  text-decoration:none; transition:.2s;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--green); color:#fff}
.btn-outline:hover{background:var(--green); color:#fff}

.hero{position:relative; min-height:72vh; display:grid; place-items:center; overflow:hidden}
.hero-media{position:absolute; inset:0}
.hero-media img{width:100%; height:100%; object-fit:cover}
.hero-overlay{position:absolute; inset:0; background:linear-gradient(180deg, rgba(0,0,0,.35), rgba(0,0,0,.55))}
.hero-content{position:relative; color:#fff; text-align:center}
.hero h1{font-size:clamp(2rem, 4vw, 3rem); margin:0 0 8px}
.hero p{font-size:clamp(1rem, 2.2vw, 1.2rem); opacity:.95}
.hero-cta{margin-top:18px; display:flex; gap:12px; justify-content:center; flex-wrap:wrap}

.section{padding:64px 0}
.section.alt{background:var(--cream)}
h2{font-size:clamp(1.4rem, 2.8vw, 2rem); margin:0 0 12px}
.muted{color:var(--muted)}
.small{font-size:.85rem}

.grid-2{display:grid; grid-template-columns: 1.2fr 1fr; gap:28px}
@media (max-width: 900px){ .grid-2{grid-template-columns:1fr} }

.card{background:#fff; border-radius:var(--radius); box-shadow:var(--shadow); overflow:hidden}
.media-card img{width:100%; height:100%; object-fit:cover}

.cards{display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:24px; margin-top:18px}
.card.trip img{aspect-ratio: 4/3; object-fit:cover}
.card .card-body{padding:16px}

.checks{padding:0; margin:12px 0 0 0; list-style:none}
.checks li{margin:8px 0; position:relative; padding-left:28px}
.checks li::before{content:"✔"; position:absolute; left:0; top:0; color:var(--green)}

.gallery{display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:12px}
.gallery img{border-radius:14px; box-shadow:var(--shadow)}

.video-wrap{position:relative; padding-bottom:56.25%; height:0; overflow:hidden; border-radius:var(--radius); box-shadow:var(--shadow)}
.video-wrap iframe{position:absolute; inset:0; width:100%; height:100%}

.form{padding:18px}
.form label{display:block; font-weight:600; margin:8px 0}
.form input, .form textarea{
  width:100%; padding:12px 14px; border-radius:12px;
  border:1px solid #e5e7eb; outline:none;
}
.form input:focus, .form textarea:focus{border-color:var(--green)}
.form .row{display:grid; grid-template-columns:1fr 1fr; gap:12px}
@media (max-width:700px){ .form .row{grid-template-columns:1fr} }

.info{padding:18px}
.contact-list{list-style:none; padding:0; margin:0 0 12px}
.contact-list li{margin:10px 0}
.map iframe{width:100%; height:260px; border:0; border-radius:12px}

.whatsapp-float{
  position:fixed; right:18px; bottom:18px; width:56px; height:56px;
  border-radius:50%; background:#25D366; color:#fff; display:grid; place-items:center;
  font-size:28px; box-shadow:var(--shadow); z-index:60;
}

.footer{padding:26px 0; border-top:1px solid #eee; background:#fff}
.footer-grid{display:grid; gap:12px; align-items:center; grid-template-columns:1fr auto auto}
@media (max-width:900px){ .footer-grid{grid-template-columns:1fr} }
.footer .social a{margin-left:12px; color:var(--ink); text-decoration:none}
.link-cta{color:var(--green-700); font-weight:700; text-decoration:none}
.link-cta:hover{text-decoration:underline}
