:root{
  --bg:#ffffff;
  --soft:#f6f7fb;
  --text:#0b1220;
  --muted:#5b6476;
  --line: rgba(11,18,32,.10);
  --shadow: 0 18px 55px rgba(11,18,32,.10);
  --r: 18px;
  --font: "Plus Jakarta Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;

  --header-h: 92px; /* incluye meta debajo */
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:var(--font);color:var(--text);background:var(--bg)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(1140px, calc(100% - 40px));margin:0 auto}
.muted{color:var(--muted)}
.w100{width:100%}

/* offset para anchors */
section{scroll-margin-top: calc(var(--header-h) + 18px);}

/* ---------------------------------------
   HEADER ÚNICO (ya no hay topbar)
--------------------------------------- */
.header{
  position:fixed;top:0;left:0;right:0;
  z-index:90;
  display:block;
  background: rgba(11,18,32,.12);
  border-bottom:1px solid rgba(255,255,255,.14);
  backdrop-filter: blur(10px);
}
.header__inner{
  height:62px;
  display:flex;align-items:center;justify-content:space-between;gap:14px;width:100%;
}
.brand{display:flex;gap:12px;align-items:center}
.brand img{height:40px;width:auto;filter: drop-shadow(0 10px 20px rgba(0,0,0,.25))}
.brand__text strong{display:block;font-size:14px;line-height:1.1;color:#fff}
.brand__text span{display:block;font-size:12px;color:rgba(255,255,255,.80)}

.nav{display:flex;gap:18px;align-items:center}
.nav a{font-size:13px;color:rgba(255,255,255,.86)}

.header__cta{display:flex;gap:10px;align-items:center}

.header__meta{
  height:30px;
  display:flex;align-items:center;gap:10px;
  padding-bottom:10px;
}
.meta-pill{
  font-size:12px;padding:6px 10px;border-radius:999px;
  border:1px solid rgba(255,255,255,.20);
  background: rgba(255,255,255,.10);
  color:#fff;
}
.meta-muted{font-size:13px;color:rgba(255,255,255,.82)}

.btn{display:inline-flex;align-items:center;gap:8px;border-radius:999px;padding:10px 14px;font-weight:800;font-size:13px;border:1px solid transparent;cursor:pointer;transition: transform .12s ease, background .12s ease, border-color .12s ease, color .12s ease}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn--primary{background:var(--primary);color:white;box-shadow:0 16px 40px rgba(14,165,164,.25)}
.btn--ghost{background:rgba(255,255,255,.88);border-color:rgba(255,255,255,.35);color:var(--text)}
.btn--top{background: rgba(255,255,255,.90);border-color: rgba(255,255,255,.35);color: var(--text);}

/* Burger + mobile menu */
.burger{
  display:none;border:1px solid rgba(255,255,255,.25);
  background: rgba(255,255,255,.10);
  border-radius:12px;padding:10px;cursor:pointer
}
.burger span{display:block;width:18px;height:2px;background:#fff;margin:4px 0;border-radius:2px}

.mobilemenu{
  position:fixed;
  top: var(--header-h);
  left:0;right:0;
  display:none;flex-direction:column;gap:10px;
  padding:14px 20px;
  background: rgba(255,255,255,.96);
  border-bottom:1px solid var(--line);
  z-index:89;
}
.mobilemenu__meta{
  border:1px solid var(--line);
  background:#fff;border-radius:16px;padding:12px;
  color:var(--muted);font-size:13px;
  display:grid;gap:6px;
}
.mobilemenu a{padding:10px 0;color:var(--muted)}
.mobilemenu.is-open{display:flex}

/* Estado “scrolled”: header pasa a blanco */
body.scrolled .header{
  background: rgba(255,255,255,.92);
  border-bottom:1px solid var(--line);
}
body.scrolled .brand__text strong{color: var(--text)}
body.scrolled .brand__text span{color: var(--muted)}
body.scrolled .nav a{color: var(--muted)}
body.scrolled .meta-pill{
  border-color: var(--line);
  background: rgba(255,255,255,.75);
  color: var(--text);
}
body.scrolled .meta-muted{color: var(--muted)}
body.scrolled .burger{
  border-color: var(--line);
  background: #fff;
}
body.scrolled .burger span{background: var(--text)}

/* ---------------------------------------
   HERO
--------------------------------------- */
.hero{
  position:relative;
  min-height: 100vh;
  display:flex;
  align-items:center;
  overflow:hidden;
  padding-top: calc(var(--header-h) + 34px);
  padding-bottom: 46px;
}
.hero__media{
  position:absolute;inset:0;
  overflow:hidden;
  background:
    radial-gradient(900px 520px at 15% 20%, rgba(242,193,78,.22), transparent 60%),
    radial-gradient(900px 520px at 85% 10%, rgba(14,165,164,.20), transparent 60%),
    linear-gradient(180deg, rgba(11,18,32,.55), rgba(11,18,32,.20));
}
.hero__img{
  width:100%;
  height:100%;
  object-fit:cover;   /* desktop: cover se ve brutal */
  object-position:center;
  transform:scale(1.02);
  filter:saturate(1.05) contrast(1.02)
}
.hero__overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(90deg, rgba(11,18,32,.78), rgba(11,18,32,.20) 55%, rgba(11,18,32,.08)),
    linear-gradient(180deg, rgba(0,0,0,.10), rgba(0,0,0,.25));
}

.hero__content{
  position:relative;z-index:2;
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap:26px;
}
.kicker{
  display:inline-flex;gap:10px;align-items:center;
  font-size:12px;font-weight:900;letter-spacing:.06em;color:#fff;text-transform:uppercase;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);
  padding:8px 12px;border-radius:999px
}
.hero h1{color:#fff;font-size:46px;letter-spacing:-.03em;line-height:1.03;margin:14px 0 10px}
.hero p{color:rgba(255,255,255,.86);max-width:58ch;line-height:1.7;margin:0}
.hero__actions{display:flex;gap:10px;flex-wrap:wrap;margin:18px 0 16px}
.hero__cards{display:grid;grid-template-columns:repeat(3, minmax(0,1fr));gap:12px;margin-top:10px}

.pricecard{
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.16);
  border-radius:18px;padding:14px;color:#fff;
  backdrop-filter: blur(10px);
}
.pricecard__title{font-size:12px;text-transform:uppercase;letter-spacing:.08em;font-weight:900;opacity:.92}
.pricecard__price{font-size:26px;font-weight:900;margin:6px 0 10px}
.pricecard__price span{font-size:12px;font-weight:800;opacity:.85}
.pricecard__list{margin:0;padding-left:18px;font-size:12px;opacity:.90}

.glass{
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.18);
  border-radius:22px;padding:18px;color:#fff;
  box-shadow: 0 30px 90px rgba(0,0,0,.18);
  backdrop-filter: blur(12px);
}
.glass__title{font-weight:1000;letter-spacing:-.01em;font-size:18px}
.glass__text{color:rgba(255,255,255,.86);line-height:1.6;margin:10px 0 12px}
.divider{height:1px;background:rgba(255,255,255,.18);margin:14px 0}
.mini{display:grid;grid-template-columns:1fr 1fr;gap:10px;font-size:13px;color:rgba(255,255,255,.88)}
.scrollcue{
  position:absolute;left:50%;bottom:16px;transform:translateX(-50%);
  width:44px;height:44px;border-radius:999px;display:grid;place-items:center;
  background:rgba(255,255,255,.88);border:1px solid rgba(255,255,255,.35);
  z-index:3;
}

/* ---------------------------------------
   SECCIONES
--------------------------------------- */
.section{padding:70px 0}
.section--soft{background:var(--soft)}
.sectionhead{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;margin-bottom:18px}
.sectionhead h2{margin:0;font-size:30px;letter-spacing:-.02em}
.sectionhead p{margin:6px 0 0}

.tourgrid{display:grid;grid-template-columns:repeat(3, minmax(0,1fr));gap:16px}
.tourcard{
  border:1px solid var(--line);
  border-radius:22px;
  overflow:hidden;
  background:#fff;
  box-shadow:0 10px 30px rgba(11,18,32,.06)
}
.tourcard__media{
  position:relative;
  aspect-ratio: 16 / 10;
  background:linear-gradient(135deg, rgba(14,165,164,.16), rgba(242,193,78,.14));
}
.tourcard__media img{width:100%;height:100%;object-fit:cover}
.tourcard__badges{position:absolute;left:12px;bottom:12px;display:flex;gap:8px;flex-wrap:wrap}
.badge{
  font-size:12px;font-weight:900;color:#fff;
  background:rgba(11,18,32,.65);
  padding:7px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.18)
}
.badge--soft{background:rgba(255,255,255,.90);color:var(--text);border-color:rgba(11,18,32,.10)}
.tourcard__body{padding:16px}
.tourcard__body h3{margin:0 0 6px;font-size:18px;letter-spacing:-.01em}
.details{margin:10px 0 0;border-top:1px solid var(--line);padding-top:10px}
.details summary{cursor:pointer;font-weight:900;color:var(--text)}
.details ul{margin:10px 0 0;padding-left:18px;color:var(--muted);line-height:1.55}
.tourcard__actions{display:flex;gap:10px;margin-top:14px;flex-wrap:wrap}

/* Galería */
.gallery{display:grid;grid-template-columns:repeat(12, 1fr);gap:12px}
.gallery__item{
  border-radius:22px;overflow:hidden;border:1px solid var(--line);
  background:linear-gradient(135deg, rgba(14,165,164,.14), rgba(242,193,78,.12));
  min-height:170px
}
.gallery__item img{width:100%;height:100%;object-fit:cover}
.gallery__item:nth-child(1){grid-column:span 7;min-height:320px}
.gallery__item:nth-child(2){grid-column:span 5;min-height:320px}
.gallery__item:nth-child(3){grid-column:span 4}
.gallery__item:nth-child(4){grid-column:span 4}
.gallery__item:nth-child(5){grid-column:span 4}
.gallery__item:nth-child(6){grid-column:span 12;min-height:260px}

/* About */
.about{display:grid;grid-template-columns: 1.2fr .8fr;gap:18px;align-items:start}
.about__copy p{line-height:1.75;color:var(--muted)}
.about__chips{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.chip{font-size:12px;font-weight:900;padding:8px 10px;border-radius:999px;border:1px solid var(--line);background:#fff}
.aboutcard{border:1px solid var(--line);border-radius:22px;padding:18px;background:linear-gradient(180deg, #fff, rgba(14,165,164,.04));box-shadow:var(--shadow)}
.aboutcard__title{font-weight:1000;margin-bottom:8px}
.aboutcard ul{margin:0;padding-left:18px;color:var(--muted);line-height:1.65}
.aboutcard__cta{margin-top:12px}

/* Contacto */
.contact__box{border:1px solid var(--line);border-radius:26px;padding:18px;background:#fff;box-shadow:var(--shadow)}
.contact__grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px}
.contact__item{border:1px solid var(--line);border-radius:18px;padding:14px;background:rgba(246,247,251,.7)}
.label{font-size:12px;font-weight:900;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.value{font-size:16px;font-weight:1000;margin-top:6px}
.contact__actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}

/* ---------------------------------------
   FOOTER
--------------------------------------- */
.footer{
  position:relative;
  overflow:hidden;
  min-height: 240px;
}
.footer__media{
  position:absolute;inset:0;overflow:hidden;
  background:
    radial-gradient(900px 520px at 20% 20%, rgba(14,165,164,.18), transparent 60%),
    radial-gradient(900px 520px at 85% 40%, rgba(242,193,78,.16), transparent 60%),
    linear-gradient(180deg, rgba(11,18,32,.40), rgba(11,18,32,.78));
}
.footer__img{width:100%;height:100%;object-fit:cover;object-position:center}
.footer__overlay{position:absolute;inset:0;background:linear-gradient(180deg, rgba(11,18,32,.55), rgba(11,18,32,.90))}
.footer__inner{position:relative;z-index:2;padding:56px 0;color:#fff}
.footer__msg p{margin:6px 0 0;opacity:.88}
.footer__small{display:flex;gap:12px;justify-content:space-between;flex-wrap:wrap;margin-top:22px;opacity:.85}
.footer__small a{opacity:.95;text-decoration:underline}

/* WhatsApp flotante */
.wafloat{
  position:fixed;right:16px;bottom:16px;width:56px;height:56px;border-radius:999px;
  background:var(--primary);color:#fff;display:grid;place-items:center;font-weight:1000;
  box-shadow:0 18px 50px rgba(14,165,164,.35);z-index:95
}

/* Modal */
.modal{position:fixed;inset:0;display:none;z-index:120}
.modal.is-open{display:block}
.modal__backdrop{position:absolute;inset:0;background:rgba(11,18,32,.55);backdrop-filter: blur(6px)}
.modal__panel{position:absolute;right:0;top:0;height:100%;width:min(520px, 100%);background:#fff;border-left:1px solid var(--line);padding:16px;overflow:auto}
.modal__head{display:flex;align-items:center;justify-content:space-between;gap:12px;border-bottom:1px solid var(--line);padding-bottom:12px;margin-bottom:12px}
.iconbtn{width:40px;height:40px;border-radius:12px;border:1px solid var(--line);background:#fff;cursor:pointer;font-size:18px}
.form__row{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}
.form__row label{font-size:12px;font-weight:900;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
input,select,textarea{
  width:100%;padding:12px 12px;border-radius:14px;border:1px solid var(--line);
  background:#fff;font-family:var(--font);outline:none
}
input:focus,select:focus,textarea:focus{border-color:rgba(14,165,164,.55);box-shadow:0 0 0 4px rgba(14,165,164,.12)}
.form__grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.form__actions{display:flex;gap:10px;flex-wrap:wrap}
.form__status{margin-top:10px;font-size:13px;color:var(--muted)}
.form__status.ok{color:#0f766e;font-weight:900}
.form__status.err{color:#b42318;font-weight:900}

/* Responsive */
@media (max-width: 980px){
  .hero__content{grid-template-columns:1fr}
  .hero__cards{grid-template-columns:1fr}
  .tourgrid{grid-template-columns:1fr 1fr}
  .about{grid-template-columns:1fr}
  .hero h1{font-size:38px}
}

@media (max-width: 760px){
  .nav,.header__cta{display:none}
  .burger{display:block}
  .tourgrid{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr;display:grid}
  .gallery__item{grid-column:auto !important;min-height:220px !important}
  .contact__grid{grid-template-columns:1fr}

  /* IMPORTANTE: en celular NO recortar hero/footer */
  .hero__img{
    object-fit: contain !important;   /* NO recorta */
    transform:none !important;
    filter: none !important;
    background: rgba(11,18,32,.55);
  }
  .hero__media{
    background: rgba(11,18,32,.70);
  }

  .footer__img{
    object-fit: contain !important;   /* NO recorta */
  }
  .footer__media{
    background: rgba(11,18,32,.88);
  }
}
/* ===========================
   PATCH MOBILE HERO + FOOTER
   (pegar al final del CSS)
=========================== */
@media (max-width: 760px){

  /* 1) HERO: menos “oscuro” arriba y imagen más presente */
  .hero{
    min-height: 92svh; /* mejor que 100vh en móviles modernos */
    padding-top: calc(var(--header-h) + 16px);
    padding-bottom: 28px;
  }

  /* Overlay menos agresivo en móvil (ahora sí se ve la foto) */
  .hero__overlay{
    background:
      linear-gradient(180deg, rgba(11,18,32,.52), rgba(11,18,32,.62));
  }

  /* IMPORTANTE:
     - Para verse como PC: cover
     - Para NO recortar: necesitas hero-mobile.jpg (vertical) con <picture> (paso B)
  */
  .hero__img{
    object-fit: cover !important;
    object-position: 50% 35% !important; /* sube un poco el foco */
    transform: none !important;
    filter: saturate(1.03) contrast(1.02) !important;
  }

  /* 2) Las pricecards en móvil NO deben apilarse transparentes (se ve “horrible”).
        Se vuelven carrusel horizontal (look premium tipo desktop row). */
  .hero__cards{
    display: flex !important;
    gap: 12px !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    padding-bottom: 10px;
    margin-top: 14px;
  }

  .pricecard{
    min-width: 265px;           /* tamaño cómodo */
    scroll-snap-align: start;
    background: rgba(11,18,32,.46);  /* más sólido = más limpio */
    border-color: rgba(255,255,255,.22);
    backdrop-filter: blur(10px);
  }

  /* 3) Booking card (glass) más “compacta” */
  .glass{
    padding: 16px;
  }
  .mini{
    grid-template-columns: 1fr; /* no se apretuja */
  }

  /* 4) FOOTER: mismo enfoque (full-bleed como PC)
        Para NO recorte real, necesitas footer-mobile.jpg con <picture> (paso B) */
  .footer{
    min-height: 320px;
  }
  .footer__overlay{
    background: linear-gradient(180deg, rgba(11,18,32,.42), rgba(11,18,32,.90));
  }
  .footer__img{
    object-fit: cover !important;
    object-position: center !important;
  }
}
/* ===========================
   FIX HEADER EN MOVIL
   Evita que el estado .scrolled lo ponga “blanco/negro” arriba
=========================== */
@media (max-width: 760px){

  /* Mantener header como overlay oscuro en móvil */
  body.scrolled .header{
    background: rgba(11,18,32,.12) !important;
    border-bottom: 1px solid rgba(255,255,255,.14) !important;
    backdrop-filter: blur(10px);
  }

  body.scrolled .brand__text strong{ color:#fff !important; }
  body.scrolled .brand__text span{ color:rgba(255,255,255,.80) !important; }

  body.scrolled .nav a{ color:rgba(255,255,255,.86) !important; }

  body.scrolled .meta-pill{
    border:1px solid rgba(255,255,255,.20) !important;
    background: rgba(255,255,255,.10) !important;
    color:#fff !important;
  }
  body.scrolled .meta-muted{
    color: rgba(255,255,255,.82) !important;
  }

  body.scrolled .burger{
    border:1px solid rgba(255,255,255,.25) !important;
    background: rgba(255,255,255,.10) !important;
  }
  body.scrolled .burger span{
    background:#fff !important;
  }

  /* (Opcional) Mejorar layout de la meta línea en móvil */
  .header__meta{
    height:auto !important;
    padding-bottom: 12px !important;
    flex-wrap: wrap;
    row-gap: 6px;
  }
  .meta-pill,
  .meta-muted{
    width: 100%;
  }
}
/* ===========================
   TOP BAR: mas pequeño en movil
   - Oculta WhatsApp/Instagram (meta)
   - Reduce altura del header
=========================== */
@media (max-width: 760px){

  /* Ocultar la línea meta (WhatsApp/Instagram) */
  .header__meta{ display:none !important; }

  /* Reducir altura del header principal */
  .header__inner{
    height: 56px !important;
    gap: 10px !important;
  }

  /* Logo un poco más compacto */
  .brand img{ height: 34px !important; }

  /* Texto marca más pequeño */
  .brand__text strong{ font-size: 13px !important; }
  .brand__text span{ font-size: 11px !important; }

  /* Botón burger más compacto */
  .burger{
    padding: 8px !important;
    border-radius: 12px !important;
  }

  /* Como la meta ya no existe, bajamos el header-h para que el hero no deje espacio extra */
  :root{ --header-h: 62px; }

  /* Ajuste fino del padding del hero en móvil para que no quede “aire” arriba */
  .hero{
    padding-top: calc(var(--header-h) + 12px) !important;
  }
}
/* ===========================
   HERO pricecards: MOVIL (1 tarjeta por vez)
=========================== */
@media (max-width: 760px){

  /* Carrusel real: 1 tarjeta visible por swipe */
  .hero__cards{
    display:flex !important;
    flex-wrap: nowrap !important;
    gap:12px !important;
    overflow-x:auto !important;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    padding: 6px 2px 12px !important;
    margin-top: 14px !important;
  }
  .hero__cards::-webkit-scrollbar{ height: 0; }

  /* Tarjeta: casi full-width para que NO se vean 2 a la vez */
  .pricecard{
    flex: 0 0 88% !important;     /* <- clave */
    max-width: 88% !important;
    scroll-snap-align: start;
    padding: 12px 14px !important;
    border-radius: 18px !important;
    background: rgba(11,18,32,.52) !important;
    border: 1px solid rgba(255,255,255,.22) !important;
    backdrop-filter: blur(10px);
  }

  /* Título compacto (sin ocupar 2 líneas eternas) */
  .pricecard__title{
    font-size: 11px !important;
    letter-spacing: .06em;
    opacity: .92;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .pricecard__price{
    font-size: 22px !important;
    margin: 6px 0 0 !important;
    line-height: 1.1;
  }
  .pricecard__price span{
    font-size: 11px !important;
    opacity: .85;
  }

  /* Ocultar bullets en móvil */
  .pricecard__list{ display:none !important; }

  /* Mensaje corto */
  .pricecard::after{
    content: "Desliza para ver más • Toca “Reservar”";
    display:block;
    margin-top: 6px;
    font-size: 12px;
    color: rgba(255,255,255,.82);
  }
}
/* ===========================
   HERO: copy diferente en movil vs desktop
=========================== */
.heroCopy--mobile{ display:none; }
.heroCopy--desktop{ display:block; }

@media (max-width: 760px){
  .heroCopy--desktop{ display:none !important; }
  .heroCopy--mobile{ display:block !important; }

  /* Ajustes finos para que el hero se vea "pro" en movil */
  .heroCopy--mobile h1{
    font-size: 34px !important;
    line-height: 1.05 !important;
    margin: 12px 0 10px !important;
  }
  .heroCopy--mobile p{
    font-size: 15px !important;
    line-height: 1.6 !important;
    max-width: 40ch !important;
  }

  /* Importante: en movil no queremos el bloque de pricecards */
  .heroCopy--mobile .hero__cards{ display:none !important; }
}

