/* ===================================================================
   OASIS — Layout por sección (un patrón distinto en cada una)
   =================================================================== */

section[id] { scroll-margin-top: 84px; }   /* compensa el nav fijo */

/* ---------- 1 · Hero ---------- */
.hero {
  position: relative;
  min-height: min(94vh, 840px);
  display: flex; align-items: flex-end;
  overflow: hidden;
  padding: 7rem 0 clamp(3rem, 9vh, 6rem);
}
.hero__bg, .hero__velo { position: absolute; inset: 0; }
.hero__bg { width: 100%; height: 100%; object-fit: cover; object-position: center 38%; }
.hero__velo {
  background: linear-gradient(180deg,
    rgba(13,69,51,.42) 0%, rgba(13,69,51,.04) 28%,
    rgba(13,18,33,.30) 62%, rgba(13,18,33,.84) 100%);
}
.hero__contenido { position: relative; color: var(--texto-claro); max-width: 720px; }
.hero__eyebrow {
  font-size: var(--txt-xs); font-weight: var(--peso-fuerte);
  letter-spacing: var(--tracking-mayus); text-transform: uppercase;
  color: var(--c-oro-claro);
}
.hero__titulo {
  font-size: var(--txt-hero); color: #fff; margin-top: .7rem;
  font-weight: var(--peso-titulo); letter-spacing: -0.015em;
  text-shadow: 0 2px 36px rgba(0,0,0,.38);
}
.hero__sub {
  font-size: var(--txt-lg); margin-top: 1.2rem; max-width: 44ch;
  color: rgba(255,255,255,.92);
}
.hero__cta { display: flex; flex-wrap: wrap; gap: .9rem; margin-top: 2rem; }
.hero__scroll {
  position: absolute; left: 50%; bottom: 1.3rem; transform: translateX(-50%);
  color: rgba(255,255,255,.78);
  animation: flota 2.2s ease-in-out infinite;
}
@keyframes flota { 0%,100%{transform:translate(-50%,0)} 50%{transform:translate(-50%,9px)} }
@media (prefers-reduced-motion: reduce) { .hero__scroll { animation: none; } }

/* ---------- 2 · Barra de confianza ---------- */
.confianza { background: linear-gradient(100deg, var(--c-verde-hondo), var(--c-verde)); }
.confianza__pista {
  width: var(--ancho); margin-inline: auto;
  display: flex; align-items: center; gap: clamp(1.3rem, 3.2vw, 2.8rem);
  padding-block: 1.35rem;
  overflow-x: auto; scrollbar-width: none; -webkit-overflow-scrolling: touch;
  scroll-snap-type: x proximity;
}
.confianza__pista::-webkit-scrollbar { display: none; }
.confianza__item { scroll-snap-align: start; }
@media (min-width: 1080px) { .confianza__pista { justify-content: space-between; } }

/* ---------- 3 · Cabinas ---------- */
.cabinas__mosaico {
  margin-top: var(--s-6);
  display: grid; gap: var(--s-3);
  grid-template-columns: repeat(2, 1fr);
}
.cabinas__mosaico .foto { aspect-ratio: 4/3; border-radius: var(--r-md); }
.cabinas__grande { grid-column: 1 / -1; aspect-ratio: 16/10; border-radius: var(--r-lg); }
@media (min-width: 820px) {
  .cabinas__mosaico {
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: repeat(2, 1fr);
    aspect-ratio: 2 / 1;
  }
  .cabinas__mosaico .foto { aspect-ratio: auto; height: 100%; }
  .cabinas__grande { grid-column: 1 / 3; grid-row: 1 / 3; aspect-ratio: auto; }
}
.cabinas__incluye {
  list-style: none; padding: 0; margin: var(--s-5) 0 0;
  display: flex; flex-wrap: wrap; justify-content: center;
  gap: var(--s-3) var(--s-5);
}
.cabinas__incluye li { display: flex; align-items: center; gap: .55rem; color: var(--texto-suave); font-weight: var(--peso-medio); font-size: var(--txt-sm); }
.cabinas__incluye svg { width: 22px; height: 22px; color: var(--c-verde); flex: none; }

/* ---------- 4 · Restaurante ---------- */
.restaurante__intro { display: grid; gap: var(--s-4); }
@media (min-width: 820px) {
  .restaurante__intro { grid-template-columns: 1fr 1fr; align-items: end; gap: var(--s-6); }
}
.restaurante__grid {
  margin-top: var(--s-6);
  display: grid; gap: var(--s-3); grid-template-columns: 1fr;
}
.plato { position: relative; aspect-ratio: 4/3; border-radius: var(--r-md); }
.plato figcaption {
  position: absolute; inset: auto 0 0 0;
  padding: 1.6rem 1.1rem .9rem;
  background: linear-gradient(180deg, transparent, rgba(28,14,10,.88));
  color: var(--c-lino);
  font-family: var(--fuente-titulo); font-size: var(--txt-base); font-weight: var(--peso-medio);
}
@media (min-width: 680px) {
  .restaurante__grid { grid-template-columns: repeat(2, 1fr); }
  .plato--destacado { grid-column: 1 / -1; aspect-ratio: 16/7; }
}
@media (min-width: 980px) {
  .restaurante__grid { grid-template-columns: repeat(3, 1fr); grid-auto-rows: clamp(220px, 22vw, 300px); }
  .plato { aspect-ratio: auto; }
  .plato--destacado { grid-column: 1 / 3; grid-row: span 1; aspect-ratio: auto; }
}

/* ---------- 5 · Ubicación / frontera ---------- */
.ubicacion__grid { display: grid; gap: var(--s-5); }
@media (min-width: 880px) {
  .ubicacion__grid { grid-template-columns: 1.1fr .9fr; align-items: center; gap: var(--s-7); }
}
.ubicacion__mapa {
  border-radius: var(--r-lg); overflow: hidden;
  box-shadow: var(--sombra-card); aspect-ratio: 4/3; background: var(--c-arena);
}
@media (min-width: 880px) { .ubicacion__mapa { aspect-ratio: 1/1; } }
.ubicacion__mapa iframe { width: 100%; height: 100%; border: 0; display: block; }
.ubicacion__lista { list-style: none; padding: 0; margin: var(--s-4) 0 0; display: grid; gap: var(--s-3); }
.ubicacion__lista li { display: flex; gap: .9rem; align-items: center; }
.ubicacion__pin {
  display: grid; place-items: center; width: 44px; height: 44px; flex: none;
  border-radius: 50%; background: rgba(18,92,68,.10); color: var(--c-verde);
}
.ubicacion__pin svg { width: 22px; height: 22px; }
.ubicacion__lista strong { display: block; font-family: var(--fuente-titulo); font-size: var(--txt-lg); font-weight: var(--peso-titulo); }
.ubicacion__lista small { display: block; color: var(--texto-tenue); font-size: var(--txt-sm); }
.ubicacion__nota { margin-top: var(--s-4); font-style: italic; color: var(--texto-suave); }

/* ---------- 6 · Por qué Oasis ---------- */
.porque__grid { margin-top: var(--s-6); display: grid; gap: var(--s-4); grid-template-columns: 1fr; }
@media (min-width: 560px) { .porque__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px) { .porque__grid { grid-template-columns: repeat(4, 1fr); } }
.card--motivo:hover { transform: translateY(-4px); box-shadow: var(--sombra-md); }

/* ---------- 7 · Galería noche ---------- */
.galeria__masonry {
  margin-top: var(--s-6);
  display: grid; gap: var(--s-3);
  grid-template-columns: repeat(2, 1fr); grid-auto-rows: 165px;
}
.galeria__masonry .foto { height: 100%; border-radius: var(--r-md); }
.galeria__alta  { grid-row: span 2; }
.galeria__ancha { grid-column: span 2; }
@media (min-width: 820px) {
  .galeria__masonry { grid-template-columns: repeat(3, 1fr); grid-auto-rows: 205px; }
  .galeria__alta  { grid-column: 1; grid-row: span 2; }
  .galeria__ancha { grid-column: span 2; grid-row: span 1; }
}

/* ---------- 8 · Reservar ---------- */
.reservar__grid { display: grid; gap: var(--s-5); }
@media (min-width: 880px) {
  .reservar__grid { grid-template-columns: .82fr 1.18fr; gap: var(--s-7); align-items: start; }
  .reservar__intro { position: sticky; top: 100px; }
}
.reservar__tel {
  display: inline-flex; align-items: center; gap: .6rem; margin-top: var(--s-4);
  font-family: var(--fuente-titulo); font-size: var(--txt-xl); color: var(--c-oro-claro);
  transition: color var(--t-rapido);
}
.reservar__tel:hover { color: #fff; }
.reservar .form.card { padding: clamp(1.4rem, 4vw, 2.4rem); background: var(--c-lino); color: var(--texto); }

/* ---------- 9 · Footer ---------- */
.footer { background: var(--c-verde-hondo); color: var(--texto-claro-suave); padding-top: var(--seccion-y); }
.footer__grid { display: grid; gap: var(--s-5); grid-template-columns: 1fr; }
@media (min-width: 720px) { .footer__grid { grid-template-columns: 1.5fr 1fr 1fr 1.1fr; gap: var(--s-5); } }
.footer__marca img { width: 72px; height: 72px; border-radius: 50%; }
.footer__lema { font-family: var(--fuente-titulo); font-size: var(--txt-lg); color: var(--texto-claro); margin-top: var(--s-3); max-width: 24ch; }
.footer__col h4 { color: #fff; font-size: var(--txt-base); margin-bottom: var(--s-2); }
.footer__col a, .footer__col p { color: var(--texto-claro-suave); font-size: var(--txt-sm); padding: .28rem 0; transition: color var(--t-rapido); }
.footer__col a { display: flex; align-items: center; gap: .55rem; }
.footer__col a:hover { color: var(--c-oro-claro); }
.footer__col svg { width: 18px; height: 18px; flex: none; color: var(--c-oro-claro); }
.footer__base {
  display: flex; flex-wrap: wrap; justify-content: space-between; gap: var(--s-2);
  margin-top: var(--s-6); padding-top: var(--s-4); padding-bottom: var(--s-5);
  border-top: 1px solid rgba(255,255,255,.12);
  font-size: var(--txt-xs);
}
.footer__hecho { color: var(--c-oro-claro); }
.footer__base a { color: var(--texto-claro-suave); text-decoration: underline; transition: color var(--t-rapido); }
.footer__base a:hover { color: var(--c-oro-claro); }
