/* --- Base --- */
:root{
  --brand-1:#1cb5e0; /* azul del logo */
  --brand-2:#00d775; /* verde del logo */
  --ink:#0f172a;
  --muted:#475569;
  --bg:#ffffff;
  --card:#f8fafc;
  --radius:18px;
  --shadow:0 10px 30px rgba(2,8,23,.08);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,'Helvetica Neue',Arial;}
img{max-width:100%;height:auto;display:block;border-radius:12px}
a{color:var(--brand-1);text-decoration:none}
a:hover{text-decoration:underline}
.container{width:min(1120px,92%);margin-inline:auto}
h1,h2,h3{line-height:1.2;margin:0 0 .5rem 0}
p{margin:.25rem 0 1rem 0;color:var(--muted)}
.btn{display:inline-block;padding:.75rem 1rem;border-radius:9999px;background:linear-gradient(45deg,var(--brand-1),var(--brand-2));color:#fff;font-weight:600;box-shadow:var(--shadow)}
.btn:hover{opacity:.95;text-decoration:none}
.btn-primary{font-size:1rem}
.link{font-weight:600}

/* --- Header --- */
.skip-link{position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:1rem;top:1rem;width:auto;height:auto;padding:.5rem 1rem;background:#fff;border-radius:8px;box-shadow:var(--shadow)}
.site-header{position:sticky;top:0;background:#fff;z-index:50;border-bottom:1px solid #e2e8f0}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:.6rem 0}
.logo{width:42px;height:42px}

/* Navigation */
.nav-toggle{display:none;background:none;border:1px solid #e2e8f0;border-radius:10px;padding:.4rem .6rem;font-size:1.1rem}
.menu{list-style:none;display:flex;gap:1rem;margin:0;padding:0}
.menu a{display:block;padding:.6rem .8rem;border-radius:12px}
.menu a:hover{background:#f1f5f9}
@media (max-width:820px){
  .nav-toggle{display:inline-block}
  .menu{display:none;position:absolute;top:64px;right:4%;flex-direction:column;background:#fff;padding:.6rem;border-radius:16px;box-shadow:var(--shadow)}
  .menu.open{display:flex}
}

/* --- Hero --- */
.hero{position:relative;isolation:isolate}
.hero img{width:100%;height:70vh;object-fit:cover;border-radius:0}
.hero-overlay{position:absolute;inset:0;display:grid;place-items:center;text-align:center;background:linear-gradient(180deg,rgba(0,0,0,.0),rgba(0,0,0,.4));color:#fff;padding:1rem}
.hero h1{font-size:clamp(2rem,6vw,4rem);text-shadow:0 10px 30px rgba(0,0,0,.3)}
.hero p{font-size:clamp(1rem,2vw,1.25rem);color:#e2e8f0;margin-bottom:1rem}

/* --- Highlights --- */
.highlights{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin:2.2rem auto}
.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;display:grid;grid-template-columns:120px 1fr;gap:1rem;align-items:center;padding:1rem}
.card img{height:100%;object-fit:cover;border-radius:12px}
@media (max-width:900px){.highlights{grid-template-columns:1fr}.card{grid-template-columns:1fr}}

/* --- Experiencias --- */
.experiencias{background:linear-gradient(180deg,#f0f9ff,#ecfeff)}
.experiencias h2{padding-top:2rem;margin-bottom:1rem;text-align:center}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;padding-bottom:2rem}
.trip{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column}
.trip-body{padding:1rem}
.trip h3{margin-bottom:.5rem}
.trip ul{margin:.5rem 0 1rem 1rem;color:var(--muted)}

@media (max-width:900px){.grid-3{grid-template-columns:1fr}}

/* --- Galería --- */
.galeria{padding:2rem 0}
.galeria h2{text-align:center;margin-bottom:1rem}
.masonry{columns:2;column-gap:1rem}
.masonry img{break-inside:avoid;margin:0 0 1rem 0}
@media (min-width:1000px){.masonry{columns:3}}
@media (max-width:640px){.masonry{columns:1}}

/* --- Redes --- */
.redes{padding:2rem 0}
.social-embeds{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.social-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:1rem}
.embed-wrapper{position:relative;width:100%;height:0;padding-bottom:130%;overflow:hidden;border-radius:12px;border:1px solid #e2e8f0;background:#f8fafc}
.embed-wrapper iframe{position:absolute;inset:0;width:100%;height:100%}
.embed-wrapper.ig{padding:1.2rem;height:auto}
@media (max-width:1020px){.social-embeds{grid-template-columns:1fr}}

/* --- Contacto --- */
.contacto{background:linear-gradient(180deg,#ecfeff,#ffffff);padding:2rem 0}
.contact-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:1.2rem;align-items:start}
.contact-list{list-style:none;padding:0;margin:0 0 1rem 0}
.contact-list li{margin:.4rem 0}
.map-wrap{border-radius:12px;overflow:hidden;border:1px solid #e2e8f0;box-shadow:var(--shadow)}
.map-wrap iframe{width:100%;height:320px;border:0}
.form{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:1rem}
.form label{display:block;font-weight:600;margin:.4rem 0}
.form input,.form textarea{width:100%;padding:.7rem;border:1px solid #e2e8f0;border-radius:10px;margin-top:.25rem}
.form button{margin-top:.6rem}

/* --- Footer --- */
.site-footer{padding:1.2rem 0;border-top:1px solid #e2e8f0;background:#fff}
.footer-inner{display:flex;align-items:center;justify-content:space-between}
@media (max-width:720px){.footer-inner{flex-direction:column;gap:.5rem;text-align:center}}

/* --- WhatsApp Float --- */
.whatsapp-float{
  position:fixed;right:18px;bottom:18px;background:linear-gradient(45deg,var(--brand-2),var(--brand-1));
  color:#fff;padding:.9rem 1rem;border-radius:999px;font-weight:700;box-shadow:var(--shadow);z-index:60
}
.whatsapp-float:hover{text-decoration:none;opacity:.95}
