/* ============================================================
   MORAIRA BEACH 1 — Sistema de diseño "Lightship"
   Mobile-first · Vanilla CSS · Sin frameworks
   ============================================================ */

/* === TOKENS === */
:root {
  --color-warm-cream:   #faf6ef;
  --color-pure-white:   #ffffff;
  --color-obsidian:     #000000;
  --color-pebble:       #999999;
  --color-driftwood:    #a1a1a1;
  --color-mist:         #d9d9d9;
  --color-ember-orange: #fa5c40;
  --color-ember-deep:   #e8492c;
  --color-whatsapp:     #25d366;
  --color-ink-soft:     #666666;

  --font-primary: 'DM Sans', ui-sans-serif, system-ui, -apple-system,
    BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;

  --text-caption:      12px; --leading-caption:      1.2;  --tracking-caption:      -0.36px;
  --text-body-sm:      14px; --leading-body-sm:      1.2;  --tracking-body-sm:      -0.42px;
  --text-body:         16px; --leading-body:         1.25; --tracking-body:         -0.48px;
  --text-body-lg:      20px; --leading-body-lg:      1.25; --tracking-body-lg:      -0.60px;
  --text-subheading:   22px; --leading-subheading:   1.2;  --tracking-subheading:   -0.66px;
  --text-heading-sm:   24px; --leading-heading-sm:   1.2;  --tracking-heading-sm:   -0.72px;
  --text-heading:      34px; --leading-heading:      1.2;  --tracking-heading:      -1.02px;
  --text-heading-lg:   48px; --leading-heading-lg:   1;    --tracking-heading-lg:   -2.40px;
  --text-display:      72px; --leading-display:      1;    --tracking-display:      -3.60px;

  --fw-regular: 400;
  --fw-bold:    700;

  --sp-4:   4px;
  --sp-8:   8px;
  --sp-12:  12px;
  --sp-16:  16px;
  --sp-20:  20px;
  --sp-24:  24px;
  --sp-28:  28px;
  --sp-32:  32px;
  --sp-40:  40px;
  --sp-48:  48px;
  --sp-64:  64px;
  --sp-100: 100px;

  --max-w:        1440px;
  --section-gap:  100px;
  --radius-card:  20px;
  --radius-pill:  100px;

  --nav-h:   64px;
  --ease-ui: 280ms ease;
  --ease-in: 600ms cubic-bezier(0.16, 1, 0.3, 1);
}


/* === RESET === */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font-primary);
  font-size: var(--text-body);
  line-height: var(--leading-body);
  letter-spacing: var(--tracking-body);
  background-color: var(--color-warm-cream);
  color: var(--color-obsidian);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  /* clip (no hidden) recorta el desbordamiento horizontal SIN crear contexto de
     scroll, para no romper el position:sticky de la nav de secciones (jump-nav) */
  overflow-x: clip;
}

img { display: block; width: 100%; height: 100%; object-fit: cover; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
figure { margin: 0; }
button { background: none; border: none; cursor: pointer; font-family: inherit; }

/* Foco visible por teclado (invisible para el ratón) — anillo de marca */
:where(a, button, input, textarea, select):focus-visible {
  outline: 2px solid var(--color-ember-orange);
  outline-offset: 3px;
  border-radius: 4px;
}


/* === CONTAINER === */
.container {
  width: 100%;
  max-width: var(--max-w);
  margin-inline: auto;
  padding-inline: var(--sp-20);
}

@media (min-width: 768px)  { .container { padding-inline: var(--sp-40); } }
@media (min-width: 1200px) { .container { padding-inline: var(--sp-64); } }


/* ============================================================
   NAVIGATION
   ============================================================ */
.nav {
  position: fixed;
  inset-block-start: 0;
  inset-inline: 0;
  z-index: 100;
  height: var(--nav-h);
  transition: background-color var(--ease-ui), border-color var(--ease-ui), transform var(--ease-ui);
}

/* Oculto al bajar; reaparece al subir */
.nav--hidden {
  transform: translateY(-100%);
}

.nav--scrolled {
  background-color: var(--color-warm-cream);
  border-bottom: 1px solid var(--color-mist);
}

.nav__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
  padding-inline: var(--sp-20);
  max-width: var(--max-w);
  margin-inline: auto;
}

/* Desktop: three-zone grid */
@media (min-width: 1024px) {
  .nav__inner {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    padding-inline: var(--sp-40);
  }
}

/* ---- Wordmark ---- */
.nav__wordmark {
  font-size: 13px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--color-pure-white);
  transition: color var(--ease-ui);
}

.nav--scrolled .nav__wordmark { color: var(--color-obsidian); }

/* ---- Desktop links (left) ---- */
.nav__left { display: none; }

@media (min-width: 1024px) { .nav__left { display: flex; } }

.nav__links {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
}

.nav__link {
  font-size: var(--text-body-sm);
  letter-spacing: var(--tracking-body-sm);
  font-weight: var(--fw-regular);
  color: rgba(255, 255, 255, 0.85);
  padding: var(--sp-8) var(--sp-12);
  border-radius: var(--radius-pill);
  transition: color var(--ease-ui), background-color var(--ease-ui);
}

.nav--scrolled .nav__link { color: var(--color-obsidian); }

.nav__link:hover { background-color: rgba(128, 128, 128, 0.1); }

/* Sección actual: en negrita */
.nav__link.is-active {
  font-weight: var(--fw-bold);
  color: var(--color-pure-white);
}

.nav--scrolled .nav__link.is-active {
  color: var(--color-obsidian);
}

/* ---- Desktop CTA (right) ---- */
.nav__right { display: none; justify-content: flex-end; }

@media (min-width: 1024px) { .nav__right { display: flex; } }

.nav__cta {
  font-size: var(--text-body-sm);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-body-sm);
  color: var(--color-pure-white);
  background-color: var(--color-ember-orange);
  padding: var(--sp-8) var(--sp-20);
  border: 1px solid var(--color-ember-orange);
  border-radius: var(--radius-pill);
  transition: background-color var(--ease-ui), border-color var(--ease-ui), transform var(--ease-ui);
}

.nav__cta:hover {
  background-color: var(--color-ember-deep);
  border-color: var(--color-ember-deep);
}

/* ---- Hamburger ---- */
.nav__hamburger {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: var(--sp-12);
  border-radius: var(--radius-pill);
  order: 3;
}

@media (min-width: 1024px) { .nav__hamburger { display: none; } }

.nav__hamburger-line {
  display: block;
  width: 24px;
  height: 1.5px;
  background-color: var(--color-pure-white);
  border-radius: 2px;
  transition: background-color var(--ease-ui), transform var(--ease-ui), opacity var(--ease-ui);
  transform-origin: center;
}

.nav--scrolled .nav__hamburger-line { background-color: var(--color-obsidian); }

/* Menú abierto (fondo crema): wordmark y X siempre en oscuro para que se lean */
.nav--menu-open .nav__wordmark { color: var(--color-obsidian); }
.nav__hamburger[aria-expanded="true"] .nav__hamburger-line { background-color: var(--color-obsidian); }

.nav__hamburger[aria-expanded="true"] .nav__hamburger-line:nth-child(1) {
  transform: translateY(7.5px) rotate(45deg);
}
.nav__hamburger[aria-expanded="true"] .nav__hamburger-line:nth-child(2) {
  transform: translateY(-7.5px) rotate(-45deg);
}


/* ============================================================
   MOBILE MENU
   ============================================================ */
.mobile-menu {
  position: fixed;
  inset: 0;
  z-index: 99;
  background-color: var(--color-warm-cream);
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-inline: var(--sp-20);
  padding-top: var(--nav-h);
  transform: translateX(100%);
  transition: transform var(--ease-in);
  pointer-events: none;
  visibility: hidden;
}

.mobile-menu.is-open {
  transform: translateX(0);
  pointer-events: all;
  visibility: visible;
}

@media (min-width: 1024px) { .mobile-menu { display: none !important; } }

.mobile-menu__nav {
  display: flex;
  flex-direction: column;
}

.mobile-menu__link {
  display: block;
  font-size: clamp(36px, 9vw, 52px);
  font-weight: var(--fw-bold);
  letter-spacing: -2px;
  line-height: 1.1;
  color: var(--color-obsidian);
  padding-block: var(--sp-16);
  border-bottom: 1px solid var(--color-mist);
  transition: color var(--ease-ui);
}

.mobile-menu__link:last-child { border-bottom: none; }
.mobile-menu__link:hover { color: var(--color-pebble); }


/* ============================================================
   HERO — Scroll morph: foto full-screen que encoge revelando galería
   ============================================================ */

/* 200vh = espacio de scroll para la animación */
.hero {
  height: 200vh;
  position: relative;
}

/* Contenedor sticky: siempre ocupa el viewport mientras animamos */
.hero__sticky {
  position: sticky;
  top: 0;
  height: 100svh;
  min-height: 600px;
  overflow: hidden;
  background-color: var(--color-warm-cream);
}

/* Canvas: fotos del apartamento posicionadas alrededor del frame */
.hero__canvas {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.hero__canvas-item {
  position: absolute;
  overflow: hidden;
  border-radius: var(--radius-card);
  opacity: 0;
  will-change: opacity;
}

.hero__canvas-item img {
  width: 100%; height: 100%;
  object-fit: cover;
}

/* Mobile: frame arriba (60%), 2 fotos abajo lado a lado */
.hero__canvas-item:nth-child(1) {
  top: calc(62% + 4px);
  left: 12px;
  right: calc(50% + 4px);
  bottom: 12px;
}
.hero__canvas-item:nth-child(2) {
  top: calc(62% + 4px);
  left: calc(50% + 4px);
  right: 12px;
  bottom: 12px;
}
.hero__canvas-item:nth-child(3),
.hero__canvas-item:nth-child(4) {
  display: none;
}

/* Desktop: 3 columnas — izquierda (28%) | centro (44%) | derecha (28%) */
@media (min-width: 768px) {
  .hero__canvas-item:nth-child(3),
  .hero__canvas-item:nth-child(4) {
    display: block;
  }
  /* Columna izquierda — top */
  .hero__canvas-item:nth-child(1) {
    top: 12px;
    left: 12px;
    right: calc(72% + 4px);
    bottom: calc(50% + 4px);
  }
  /* Columna izquierda — bottom */
  .hero__canvas-item:nth-child(2) {
    top: calc(50% + 4px);
    left: 12px;
    right: calc(72% + 4px);
    bottom: 12px;
  }
  /* Columna derecha — top */
  .hero__canvas-item:nth-child(3) {
    top: 12px;
    left: calc(72% + 4px);
    right: 12px;
    bottom: calc(50% + 4px);
  }
  /* Columna derecha — bottom */
  .hero__canvas-item:nth-child(4) {
    top: calc(50% + 4px);
    left: calc(72% + 4px);
    right: 12px;
    bottom: 12px;
  }
}

/* Frame principal: empieza full-screen, JS anima top/right/bottom/left */
.hero__frame {
  position: absolute;
  top: 0; right: 0; bottom: 0; left: 0;
  overflow: hidden;
  border-radius: 0;
  z-index: 2;
  will-change: top, right, bottom, left, border-radius;
}

.hero__image {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center;
}

/* Vignette para legibilidad del texto */
.hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(0, 0, 0, 0.15) 0%,
    transparent 35%,
    rgba(0, 0, 0, 0.42) 100%
  );
  pointer-events: none;
  z-index: 1;
}

/* Texto: parte inferior del frame */
.hero__content {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  z-index: 2;
  padding: var(--sp-20);
  padding-bottom: var(--sp-64);
}

@media (min-width: 768px) {
  .hero__content { padding-inline: var(--sp-40); padding-bottom: var(--sp-100); }
}

@media (min-width: 1200px) {
  .hero__content { padding-inline: var(--sp-64); }
}

.hero__tagline {
  display: block;
  font-size: var(--text-caption);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.65);
  margin-bottom: var(--sp-12);
}

.hero__title {
  font-size: clamp(40px, 11vw, 90px);
  font-weight: var(--fw-bold);
  letter-spacing: clamp(-2px, -0.04em, -4.5px);
  line-height: 1;
  color: var(--color-pure-white);
}

.hero__subtitle {
  font-size: clamp(var(--text-body), 2vw, var(--text-body-lg));
  line-height: 1.45;
  letter-spacing: var(--tracking-body-lg);
  color: rgba(255, 255, 255, 0.72);
  margin-top: var(--sp-16);
}

/* Indicador de scroll — dentro del sticky, posición absoluta */
.hero__scroll {
  position: absolute;
  bottom: var(--sp-24);
  left: 50%;
  transform: translateX(-50%);
  z-index: 10;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-8);
  color: rgba(255, 255, 255, 0.65);
  font-size: var(--text-caption);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  animation: pulse 2.4s ease-in-out infinite;
  white-space: nowrap;
}

/* Solo mueve (bob); la opacidad la controla el JS para que el indicador
   se funda al hacer scroll y no quede visible al reducirse la ventana */
@keyframes pulse {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50%      { transform: translateX(-50%) translateY(5px); }
}


/* ============================================================
   SECTIONS — Base
   ============================================================ */
.section {
  padding-block: var(--sp-64);
}

@media (min-width: 768px) { .section { padding-block: var(--sp-100); } }

.section--tinted { background-color: rgba(250, 92, 64, 0.05); }
.section--dark   { background-color: var(--color-obsidian); }

/* Section header */
.section__header {
  max-width: 640px;
  margin-bottom: var(--sp-40);
}

@media (min-width: 768px) { .section__header { margin-bottom: var(--sp-64); } }

.section__title {
  font-size: clamp(var(--text-heading), 4.5vw, var(--text-heading-lg));
  font-weight: var(--fw-bold);
  line-height: 1.08;
  letter-spacing: clamp(-1px, -0.03em, -2.4px);
  color: var(--color-obsidian);
  margin-bottom: var(--sp-24);
}

.section__title--light { color: var(--color-pure-white); }

.section__body {
  font-size: var(--text-body-lg);
  line-height: 1.65;
  letter-spacing: var(--tracking-body-lg);
  color: var(--color-ink-soft);
  max-width: 520px;
}

.section__body + .section__body { margin-top: var(--sp-16); }
.section__body--light { color: rgba(255, 255, 255, 0.55); }


/* ============================================================
   GALLERY — shared image style
   ============================================================ */
.gallery__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: var(--radius-card);
  display: block;
}

/* ============================================================
   GALLERY — Index preview (6 fotos, sin huecos en ningún ancho)
   ============================================================ */
.gallery--preview {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-12);
}

/* Móvil y tablet: celdas uniformes (proporción fija) => nunca hay huecos */
.gallery--preview .gallery__item { aspect-ratio: 4 / 3; }

@media (min-width: 640px) {
  .gallery--preview {
    grid-template-columns: repeat(2, 1fr);   /* 6 fotos => 3 filas exactas */
    gap: var(--sp-12);
  }
}

/* Escritorio: foto destacada 2×2 + 5 fotos => 9 celdas, 6 fotos, sin huecos */
@media (min-width: 1024px) {
  .gallery--preview {
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: 270px 270px 270px;
    grid-template-areas:
      "big big c"
      "big big d"
      "e   f   g";
    gap: var(--sp-16);
  }
  .gallery--preview .gallery__item { aspect-ratio: auto; height: auto; }
  .gallery--preview .gallery__item:nth-child(1) { grid-area: big; }
  .gallery--preview .gallery__item:nth-child(2) { grid-area: c; }
  .gallery--preview .gallery__item:nth-child(3) { grid-area: d; }
  .gallery--preview .gallery__item:nth-child(4) { grid-area: e; }
  .gallery--preview .gallery__item:nth-child(5) { grid-area: f; }
  .gallery--preview .gallery__item:nth-child(6) { grid-area: g; }
}

.gallery-cta { margin-top: var(--sp-24); }


/* ============================================================
   FEATURES BAR
   ============================================================ */
.features {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-32) var(--sp-20);
  margin-top: var(--sp-40);
}

@media (min-width: 640px) {
  .features {
    grid-template-columns: repeat(5, 1fr);
    margin-top: var(--sp-64);
  }
}

.feature {
  display: flex;
  flex-direction: column;
  gap: var(--sp-8);
}

.feature__value {
  font-size: var(--text-heading);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-heading);
  line-height: 1;
  color: var(--color-obsidian);
}

.feature__label {
  font-size: var(--text-caption);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-obsidian);
}

/* Equipamiento — estilo Airbnb: icono de línea + texto, sin separadores ni puntos */
.equip {
  margin-top: var(--sp-48, 48px);
}

.equip__list {
  list-style: none;
  margin: var(--sp-24) 0 0;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-8) var(--sp-40);
}

@media (min-width: 640px) {
  .equip__list { grid-template-columns: repeat(2, 1fr); }
}

.equip__item {
  display: flex;
  align-items: center;
  gap: var(--sp-16);
  font-size: var(--text-body);
  letter-spacing: var(--tracking-body);
  color: var(--color-obsidian);
  padding: var(--sp-12) 0;
}

.equip__icon {
  flex: 0 0 auto;
  width: 26px;
  height: 26px;
  color: var(--color-obsidian);
}


/* ============================================================
   FULL-BLEED SEPARATOR
   ============================================================ */
.fullbleed {
  width: 100%;
  height: clamp(240px, 45vw, 560px);
  overflow: hidden;
}

.fullbleed__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 35%;
}


/* ============================================================
   ZONA — Stacking cards sobre "MORAIRA" backdrop
   ============================================================ */

.zona {
  position: relative;
  background: var(--color-warm-cream);
  /* clip (no hidden) recorta la palabra que sangra por los lados SIN romper el sticky de las fotos */
  overflow-x: clip;
}

/* Palabra gigante fija detrás — se mantiene anclada mientras las fotos pasan por delante */
.zona__word {
  position: sticky;
  top: 0;
  height: 100svh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;            /* arriba, no centrada */
  padding-top: clamp(56px, 9vh, 130px);   /* la deja en el tercio superior, visible sobre las fotos */
  text-align: center;
  pointer-events: none;
  z-index: 0;
}

.zona__word-text {
  display: block;
  font-size: clamp(72px, 21vw, 320px);
  font-weight: var(--fw-bold);
  letter-spacing: -0.045em;
  line-height: 0.85;
  white-space: nowrap; /* deja que sangre por los lados como en lightship */
  color: var(--color-obsidian);
}

.zona__word-sub {
  display: block;
  font-size: var(--text-caption);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-pebble);
  margin-top: var(--sp-20);
}

/* Flujo de fotos: tirado hacia arriba para solaparse con la palabra fija */
.zona__stream {
  position: relative;
  z-index: 1;
  margin-top: -100svh;       /* arranca sobre la palabra */
  padding-bottom: 44vh;      /* runway para que la última carta siga anclada hasta el final */
}

/* Cada foto se ANCLA centrada (sticky); la siguiente sube y la va cubriendo
   a medida que haces scroll. En orden de DOM => las posteriores pintan encima. */
.zona__item {
  position: sticky;
  top: 14vh;                  /* 14 + 58 = 72vh => cabe entera con margen amplio, incluso a media animación */
  width: min(60vw, 960px);    /* fotos grandes (anchas) */
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 24vh;        /* distancia de scroll antes de que llegue la siguiente */
  transform-origin: center center;
  will-change: transform, opacity;
}

.zona__item:first-child {
  margin-top: 54vh;           /* deja ver la palabra sola al entrar */
}

/* La última carta se despega la ÚLTIMA (margin-bottom mínimo) => cubre todo lo de atrás */
.zona__item:last-child {
  margin-bottom: 0;
}

.zona__fig {
  position: relative;
  width: 100%;
  height: 58vh;               /* cabe entera con top:14vh (14+58=72vh) */
  border-radius: var(--radius-card);
  overflow: hidden;
  isolation: isolate;         /* contexto propio => recorta bien bajo el transform del padre */
  margin: 0;
  /* sombra sutil => cada carta proyecta sobre la de debajo: lectura de profundidad */
  box-shadow: 0 34px 80px -30px rgba(16, 14, 12, 0.55);
}

/* Cada capa se redondea por sí misma => las esquinas nunca se ven cuadradas
   aunque el recorte del contenedor falle bajo el transform animado del padre */
.zona__fig img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-radius: var(--radius-card);
}

/* Pie DENTRO de la foto: abajo, sobre degradado => legible y se autocubre
   al apilarse la siguiente carta */
.zona__cap {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: clamp(56px, 12vh, 120px) clamp(24px, 3vw, 44px) clamp(26px, 4vh, 44px);
  background: linear-gradient(
    to top,
    rgba(16,14,12,0.86) 0%,
    rgba(16,14,12,0.52) 34%,
    rgba(16,14,12,0) 100%
  );
  border-radius: 0 0 var(--radius-card) var(--radius-card);  /* esquinas inferiores redondeadas */
  color: var(--color-pure-white);
}

.zona__ttl {
  font-size: clamp(26px, 2.7vw, 42px);
  font-weight: var(--fw-bold);
  letter-spacing: -0.02em;
  line-height: 1.05;
  color: var(--color-pure-white);
  margin-bottom: var(--sp-12);
}

/* Última carta: CTA "¿Vienes?" centrado sobre la foto */
.zona__item--cta .zona__fig { position: relative; }

.zona__cta {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: var(--sp-40);
  background: linear-gradient(
    to top,
    rgba(16,14,12,0.7) 0%,
    rgba(16,14,12,0.4) 55%,
    rgba(16,14,12,0.45) 100%
  );
  border-radius: var(--radius-card);
}

.zona__cta-ttl {
  font-size: clamp(52px, 7vw, 108px);
  font-weight: var(--fw-bold);
  letter-spacing: -0.035em;
  line-height: 0.95;
  color: var(--color-pure-white);
  margin-bottom: var(--sp-28);
}

.zona__cta-btn {
  display: inline-block;
  font-size: var(--text-body);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-body);
  color: var(--color-pure-white);
  background: var(--color-ember-orange);
  border: 1px solid var(--color-ember-orange);
  padding: var(--sp-16) var(--sp-40);
  border-radius: var(--radius-pill);
  transition: background-color var(--ease-ui), border-color var(--ease-ui), transform var(--ease-ui);
}

.zona__cta-btn:hover {
  background: var(--color-ember-deep);
  border-color: var(--color-ember-deep);
}

/* Móvil/tablet estrecho: fotos casi a ancho completo */
@media (max-width: 900px) {
  .zona__item {
    width: min(92vw, 640px);
    top: 12vh;
    margin-bottom: 18vh;
  }
  .zona__item:first-child { margin-top: 42vh; }
  .zona__item:last-child  { margin-bottom: 0; }

  .zona__fig { height: 56vh; }
  .zona__ttl { font-size: clamp(26px, 7vw, 36px); }
}

.highlight__title {
  font-size: var(--text-subheading);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-subheading);
  color: var(--color-obsidian);
  margin-bottom: var(--sp-12);
}

.highlight__body {
  font-size: var(--text-body);
  line-height: 1.65;
  color: var(--color-ink-soft);
}


/* ============================================================
   RULES (normas)
   ============================================================ */
.rules {
  display: grid;
  grid-template-columns: 1fr;
  margin-bottom: var(--sp-40);
}

@media (min-width: 640px)  { .rules { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .rules { grid-template-columns: repeat(3, 1fr); } }

.rule {
  display: flex;
  gap: var(--sp-16);
  align-items: baseline;
  padding-block: var(--sp-20);
  border-bottom: 1px solid var(--color-mist);
}

.rule__marker {
  font-size: var(--text-body-sm);
  color: var(--color-pebble);
  min-width: 56px;
  flex-shrink: 0;
  font-weight: var(--fw-regular);
}

.rule__marker--accent {
  font-size: var(--text-caption);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-ember-orange);
}

.rule__text {
  font-size: var(--text-body);
  line-height: var(--leading-body);
  color: var(--color-obsidian);
}

.rule__text strong { font-weight: var(--fw-bold); }

/* Text link */
.text-link {
  display: inline-block;
  font-size: var(--text-body);
  letter-spacing: var(--tracking-body);
  color: var(--color-obsidian);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: var(--color-mist);
  transition: text-decoration-color var(--ease-ui);
}

.text-link:hover { text-decoration-color: var(--color-ember-orange); }


/* ============================================================
   GESTOR
   ============================================================ */
.gestor {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-40);
}

@media (min-width: 768px) {
  .gestor {
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-64);
    align-items: center;
  }
}

@media (min-width: 1100px) {
  .gestor { grid-template-columns: 1.15fr 1fr; }
}

.gestor__img {
  height: clamp(300px, 50vw, 520px);
  border-radius: var(--radius-card);
  width: 100%;
}

.gestor__content {
  display: flex;
  flex-direction: column;
  gap: var(--sp-16);
}

.gestor__content .section__title {
  font-size: clamp(var(--text-heading-sm), 3.2vw, var(--text-heading));
  margin-bottom: var(--sp-8);
}

.gestor__content .section__body { max-width: none; }


/* ============================================================
   CONTACT
   ============================================================ */
.contact {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-16);
}

@media (min-width: 540px) {
  .contact { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 1024px) {
  .contact { max-width: 600px; }
}

.contact__card {
  display: flex;
  align-items: center;
  gap: var(--sp-20);
  padding: var(--sp-24);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-card);
  transition: border-color var(--ease-ui), background-color var(--ease-ui);
}

.contact__card:hover {
  border-color: rgba(255, 255, 255, 0.25);
  background-color: rgba(255, 255, 255, 0.04);
}

.contact__icon {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.contact__icon--wa    { background-color: var(--color-whatsapp); }
.contact__icon--email { background-color: rgba(255, 255, 255, 0.08); }
.contact__icon--ig    {
  background-image: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%);
}

.contact__text {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
}

.contact__method {
  font-size: var(--text-body-sm);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-body-sm);
  color: var(--color-pure-white);
}

.contact__detail {
  font-size: var(--text-body);
  letter-spacing: var(--tracking-body);
  color: rgba(255, 255, 255, 0.45);
}


/* ============================================================
   FOOTER
   ============================================================ */
.footer {
  background-color: var(--color-obsidian);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  padding-block: var(--sp-24);
}

.footer__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-12);
  text-align: center;
}

@media (min-width: 640px) {
  .footer__inner {
    flex-direction: row;
    justify-content: space-between;
    text-align: left;
  }
}

.footer__brand {
  font-size: 12px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.22em;
  color: var(--color-pure-white);
}

.footer__copy {
  font-size: var(--text-caption);
  color: rgba(255, 255, 255, 0.35);
}

.footer__link {
  font-size: var(--text-caption);
  color: rgba(255, 255, 255, 0.45);
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color var(--ease-ui);
}

.footer__link:hover { color: rgba(255, 255, 255, 0.8); }


/* ============================================================
   FLOATING WHATSAPP
   ============================================================ */
.wa-float {
  position: fixed;
  bottom: var(--sp-20);
  right: var(--sp-20);
  z-index: 90;
  width: 54px;
  height: 54px;
  background-color: var(--color-whatsapp);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 20px rgba(37, 211, 102, 0.28);
  transition: transform var(--ease-ui), box-shadow var(--ease-ui);
}

.wa-float:hover {
  transform: scale(1.08);
  box-shadow: 0 6px 28px rgba(37, 211, 102, 0.42);
}

@media (min-width: 768px) {
  .wa-float { bottom: var(--sp-24); right: var(--sp-24); }
}

/* En escritorio el botón "Reservar" (naranja) ya está en la barra:
   ocultamos el WhatsApp flotante mientras ese botón sea visible. Cuando la nav
   se auto-oculta al bajar (Reservar deja de verse), el flotante reaparece. */
@media (min-width: 1024px) {
  .wa-float { display: none; }
  .nav--hidden ~ .wa-float { display: flex; }
}


/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 680ms ease, transform 680ms ease;
}

.reveal.delay-1 { transition-delay: 110ms; }
.reveal.delay-2 { transition-delay: 220ms; }

.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}


/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }

  .reveal {
    opacity: 1;
    transform: none;
    transition: none;
  }

  .hero__scroll { animation: none; opacity: 0.65; }

  .hero__image { transform: none !important; will-change: auto; }
}


/* ============================================================
   PAGE HEADER (apartamento.html — smaller hero)
   ============================================================ */
.page-header {
  position: relative;
  width: 100%;
  height: clamp(320px, 55vh, 560px);
  margin-top: var(--nav-h);
  overflow: hidden;
}

.page-header__media {
  position: absolute;
  inset: 0;
}

.page-header__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 30%;
}

.page-header__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(0, 0, 0, 0.1) 0%,
    transparent 30%,
    rgba(0, 0, 0, 0.45) 100%
  );
  pointer-events: none;
}

.page-header__content {
  position: relative;
  z-index: 2;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding-block: var(--sp-24) var(--sp-40);
}

@media (min-width: 768px) {
  .page-header__content { padding-bottom: var(--sp-64); }
}

.page-header__back {
  display: inline-block;
  font-size: var(--text-body-sm);
  letter-spacing: var(--tracking-body-sm);
  color: var(--color-obsidian);
  background: rgba(255, 255, 255, 0.85);
  padding: 7px 16px;
  border-radius: var(--radius-pill);
  -webkit-backdrop-filter: blur(4px);
  backdrop-filter: blur(4px);
  transition: background-color var(--ease-ui), color var(--ease-ui);
}

.page-header__back:hover { background: var(--color-pure-white); }

.page-header__text { align-self: flex-end; }

.page-header__title {
  font-size: clamp(36px, 9vw, 72px);
  font-weight: var(--fw-bold);
  letter-spacing: clamp(-1.5px, -0.04em, -3.6px);
  line-height: 1;
  color: var(--color-pure-white);
  margin-bottom: var(--sp-12);
}

.page-header__sub {
  font-size: var(--text-body-lg);
  line-height: 1.4;
  letter-spacing: var(--tracking-body-lg);
  color: rgba(255, 255, 255, 0.7);
}


/* ============================================================
   JUMP NAV (sticky section links inside apartamento.html)
   ============================================================ */
.jump-nav {
  position: sticky;
  top: 0;                 /* siempre pegada al borde superior (zona amarilla) */
  z-index: 101;           /* por encima de la nav de marca: nunca deja ver fotos por encima */
  background-color: var(--color-warm-cream);
  border-bottom: 1px solid var(--color-mist);
}

.jump-nav__inner {
  display: flex;
  gap: var(--sp-4);
  overflow-x: auto;
  padding-block: var(--sp-12);
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.jump-nav__inner::-webkit-scrollbar { display: none; }

.jump-nav__link {
  font-size: var(--text-body-sm);
  letter-spacing: var(--tracking-body-sm);
  color: var(--color-pebble);
  white-space: nowrap;
  padding: var(--sp-8) var(--sp-16);
  border-radius: var(--radius-pill);
  transition: color var(--ease-ui), background-color var(--ease-ui);
  flex-shrink: 0;
}

.jump-nav__link:hover { color: var(--color-obsidian); }

.jump-nav__link.is-active {
  color: var(--color-obsidian);
  font-weight: var(--fw-bold);
  background-color: rgba(0, 0, 0, 0.07);
}


/* ============================================================
   ROOM SECTIONS (apartamento.html)
   ============================================================ */
.room {
  padding-block: var(--sp-64);
  border-bottom: 1px solid var(--color-mist);
}

@media (min-width: 768px) { .room { padding-block: var(--sp-100); } }

.room--alt { background-color: rgba(0, 0, 0, 0.018); }

.room__header {
  margin-bottom: var(--sp-40);
}

@media (min-width: 768px) { .room__header { margin-bottom: var(--sp-64); } }

.room__title {
  font-size: clamp(var(--text-heading), 5vw, var(--text-heading-lg));
  font-weight: var(--fw-bold);
  line-height: 1.08;
  letter-spacing: clamp(-1px, -0.03em, -2.4px);
  color: var(--color-obsidian);
}

/* Room gallery — grid flexible "justificado": las fotos de la última fila
   crecen para llenar el ancho => sin huecos con cualquier nº de fotos */
.room__gallery {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-12);
}

.room__item {
  height: 280px;
  flex: 1 1 100%;
}

@media (min-width: 640px) {
  .room__item {
    height: 300px;
    flex: 1 1 calc(50% - var(--sp-12));
  }
  /* La primera foto destaca ocupando una fila completa */
  .room__item--wide { flex-basis: 100%; }
}

@media (min-width: 1024px) {
  .room__gallery { gap: var(--sp-16); }
  .room__item {
    height: 320px;
    flex: 1 1 calc(33.333% - var(--sp-16));
  }
  /* La primera foto ocupa 2/3 (resalta sin descuadrar la fila) */
  .room__item--wide { flex-basis: calc(66.666% - var(--sp-16)); }
}


/* ============================================================
   ROOM CTA
   ============================================================ */
.room-cta {
  padding-block: var(--sp-64);
  background-color: var(--color-obsidian);
}

@media (min-width: 768px) { .room-cta { padding-block: var(--sp-100); } }

.room-cta__inner {
  display: flex;
  flex-direction: column;
  gap: var(--sp-28);
}

@media (min-width: 768px) {
  .room-cta__inner {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
  }
}

.room-cta__text {
  font-size: clamp(var(--text-heading-sm), 3.5vw, var(--text-heading));
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-heading);
  color: var(--color-pure-white);
  line-height: 1.2;
}

.room-cta__actions {
  display: flex;
  flex-direction: column;
  gap: var(--sp-16);
  align-items: flex-start;
}

@media (min-width: 768px) {
  .room-cta__actions { align-items: flex-end; }
}

.room-cta__btn {
  display: inline-block;
  font-size: var(--text-body);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-body);
  color: var(--color-pure-white);
  background: var(--color-ember-orange);
  border: 1px solid var(--color-ember-orange);
  padding: var(--sp-16) var(--sp-40);
  border-radius: var(--radius-pill);
  white-space: nowrap;
  transition: background-color var(--ease-ui), border-color var(--ease-ui), transform var(--ease-ui);
}

.room-cta__btn:hover {
  background: var(--color-ember-deep);
  border-color: var(--color-ember-deep);
}

.room-cta__actions .text-link {
  color: rgba(255, 255, 255, 0.55);
  text-decoration-color: rgba(255, 255, 255, 0.2);
}

.room-cta__actions .text-link:hover {
  color: rgba(255, 255, 255, 0.85);
  text-decoration-color: rgba(255, 255, 255, 0.5);
}


/* ============================================================
   CALENDARIO
   ============================================================ */

/* Controles: tabs de año + leyenda en una fila */
.cal-controls {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-20);
  margin-bottom: var(--sp-64);
}

.cal-tabs {
  display: inline-flex;
  gap: 4px;
  padding: 4px;
  background: var(--color-pure-white);
  border: 1px solid var(--color-mist);
  border-radius: var(--radius-pill);
}

.cal-tab {
  appearance: none;
  border: 0;
  background: transparent;
  font-family: inherit;
  font-size: var(--text-body-sm);
  font-weight: var(--fw-bold);
  letter-spacing: 0.04em;
  color: var(--color-pebble);
  padding: 8px 22px;
  border-radius: var(--radius-pill);
  cursor: pointer;
  transition: color var(--ease-ui), background-color var(--ease-ui);
}

.cal-tab:hover { color: var(--color-obsidian); }

.cal-tab.is-active {
  background: var(--color-obsidian);
  color: var(--color-pure-white);
}

.cal-legend {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-20);
}

.cal-legend__item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: var(--text-body-sm);
  color: var(--color-pebble);
  letter-spacing: var(--tracking-body-sm);
}

.cal-legend__dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}

.cal-legend__dot--n { background-color: var(--color-ember-orange); }
.cal-legend__dot--r { background-color: #f0b89a; }

/* Grid: auto-fill, ajuste automático de columnas */
.cal-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: var(--sp-20);
  margin-bottom: var(--sp-40);
}

.cal-grid[hidden] { display: none; }

/* Tarjeta de mes */
.cal-month {
  background: var(--color-pure-white);
  border-radius: var(--radius-card);
  padding: var(--sp-20);
}

.cal-month__name {
  font-size: var(--text-body-sm);
  font-weight: var(--fw-bold);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-obsidian);
  margin-bottom: var(--sp-16);
}

/* Cabecera días de la semana */
.cal-weekdays {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  margin-bottom: 4px;
}

.cal-wday {
  text-align: center;
  font-size: 11px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.06em;
  color: var(--color-mist);
  padding-bottom: 6px;
}

.cal-wday:last-child,
.cal-wday:nth-last-child(2) {
  color: var(--color-driftwood);
}

/* Celdas de días */
.cal-days {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
}

.cal-day {
  position: relative;
  aspect-ratio: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  letter-spacing: -0.01em;
  color: var(--color-obsidian);
  border-radius: 50%;
}

.cal-day--empty { visibility: hidden; }

.cal-day--weekend { color: var(--color-driftwood); }

/* Festivo nacional — naranja Lightship */
.cal-day--n {
  color: var(--color-ember-orange);
  font-weight: var(--fw-bold);
}

/* Festivo autonómico / local — naranja suave */
.cal-day--r {
  color: #e8845c;
  font-weight: var(--fw-bold);
}

/* Días festivos: resaltan al pasar el ratón */
.cal-day[data-fiesta] {
  cursor: help;
  transition: background-color var(--ease-ui);
}

.cal-day[data-fiesta]:hover {
  background-color: var(--color-blush, #fbeee6);
}

/* Tooltip con el nombre de la fiesta */
.cal-day[data-fiesta]::after {
  content: attr(data-fiesta);
  position: absolute;
  bottom: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%) translateY(4px);
  background: var(--color-obsidian);
  color: var(--color-pure-white);
  font-size: 12px;
  font-weight: var(--fw-regular);
  letter-spacing: 0.01em;
  line-height: 1.2;
  white-space: nowrap;
  padding: 7px 11px;
  border-radius: 8px;
  pointer-events: none;
  opacity: 0;
  z-index: 20;
  transition: opacity var(--ease-ui), transform var(--ease-ui);
}

/* Flecha del tooltip */
.cal-day[data-fiesta]::before {
  content: "";
  position: absolute;
  bottom: calc(100% + 3px);
  left: 50%;
  transform: translateX(-50%) translateY(4px);
  border: 5px solid transparent;
  border-top-color: var(--color-obsidian);
  pointer-events: none;
  opacity: 0;
  z-index: 20;
  transition: opacity var(--ease-ui), transform var(--ease-ui);
}

.cal-day[data-fiesta]:hover::after,
.cal-day[data-fiesta]:hover::before {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

/* Hoy */
.cal-day--today {
  background-color: var(--color-obsidian);
  color: var(--color-pure-white) !important;
  font-weight: var(--fw-bold);
}

/* Nota al pie */
.cal-note {
  font-size: var(--text-caption);
  color: var(--color-pebble);
  letter-spacing: var(--tracking-caption);
  line-height: 1.6;
  max-width: 560px;
}


/* ============================================================
   PÁGINAS LEGALES (aviso-legal.html, privacidad.html)
   ============================================================ */
.legal {
  padding-top: 140px;
  padding-bottom: var(--sp-64);
}

@media (min-width: 768px) {
  .legal { padding-top: 168px; }
}

.legal__back {
  display: inline-block;
  font-size: var(--text-body-sm);
  letter-spacing: var(--tracking-body-sm);
  color: var(--color-pebble);
  margin-bottom: var(--sp-40);
  transition: color var(--ease-ui);
}

.legal__back:hover { color: var(--color-obsidian); }

.legal__title {
  font-size: var(--text-heading);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-heading);
  line-height: 1.05;
  color: var(--color-obsidian);
}

.legal__updated {
  font-size: var(--text-caption);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-pebble);
  margin-top: var(--sp-12);
}

.legal__body {
  max-width: 760px;
  margin-top: var(--sp-48, 48px);
}

.legal__body h2 {
  font-size: var(--text-subheading);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-subheading);
  color: var(--color-obsidian);
  margin-top: var(--sp-40);
  margin-bottom: var(--sp-16);
}

.legal__body h2:first-child { margin-top: 0; }

.legal__body p,
.legal__body li {
  font-size: var(--text-body);
  line-height: 1.7;
  letter-spacing: var(--tracking-body);
  color: var(--color-ink-soft);
}

.legal__body p { margin-bottom: var(--sp-16); }

.legal__body ul {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--sp-16);
}

.legal__body li {
  position: relative;
  padding-left: var(--sp-20);
  margin-bottom: var(--sp-8);
}

.legal__body li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.65em;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background-color: var(--color-ember-orange);
}

.legal__body strong { color: var(--color-obsidian); }

.legal__body a {
  color: var(--color-obsidian);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.legal__placeholder {
  color: var(--color-ember-orange);
  font-weight: var(--fw-bold);
}

/* Documento de normas completo (normas.html) */
.rules-doc {
  max-width: 760px;
  margin-top: var(--sp-48, 48px);
}

.rules-doc__lead {
  font-size: var(--text-subheading);
  line-height: 1.5;
  letter-spacing: var(--tracking-subheading);
  color: var(--color-obsidian);
  margin-bottom: var(--sp-20);
}

.rules-doc__note {
  font-size: var(--text-body);
  line-height: 1.6;
  color: var(--color-ink-soft);
  margin-bottom: var(--sp-48);
}

.rules-doc ol {
  list-style: none;
  counter-reset: rule;
  margin: 0;
  padding: 0;
}

.rules-doc li {
  counter-increment: rule;
  position: relative;
  padding-left: 64px;
  padding-bottom: var(--sp-28);
  margin-bottom: var(--sp-28);
  border-bottom: 1px solid var(--color-mist);
}

.rules-doc li:last-child {
  border-bottom: 0;
  margin-bottom: 0;
  padding-bottom: 0;
}

.rules-doc li::before {
  content: counter(rule, decimal-leading-zero);
  position: absolute;
  left: 0;
  top: -2px;
  font-size: var(--text-subheading);
  font-weight: var(--fw-bold);
  letter-spacing: -0.02em;
  color: var(--color-ember-orange);
}

.rules-doc li h3 {
  font-size: var(--text-body);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-body);
  color: var(--color-obsidian);
  margin-bottom: var(--sp-4);
}

.rules-doc li p {
  font-size: var(--text-body);
  line-height: 1.65;
  letter-spacing: var(--tracking-body);
  color: var(--color-ink-soft);
}

.rules-doc__quote {
  margin-top: var(--sp-48, 48px);
  padding-left: var(--sp-20);
  border-left: 2px solid var(--color-ember-orange);
  font-size: var(--text-body);
  line-height: 1.6;
  font-style: italic;
  color: var(--color-pebble);
}


/* ============================================================
   CARRUSEL — fotos y calendario en ventana reducida (≤768px)
   Las flechas y el desplazamiento horizontal solo aparecen en móvil;
   en escritorio se mantiene la rejilla original.
   ============================================================ */
.carousel { position: relative; }

.carousel__arrow {
  display: none;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 6;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: var(--color-pure-white);
  color: var(--color-obsidian);
  border: 1px solid var(--color-mist);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.18);
  font-size: 26px;
  line-height: 1;
  align-items: center;
  justify-content: center;
  padding: 0 0 3px;
  transition: opacity var(--ease-ui);
}

.carousel__arrow--prev { left: 8px; }
.carousel__arrow--next { right: 8px; }
.carousel__arrow:disabled { opacity: 0; pointer-events: none; }

@media (max-width: 768px) {
  .carousel__arrow { display: flex; }

  .carousel-track {
    display: flex !important;
    grid-template-columns: none !important;
    grid-template-rows: none !important;
    grid-template-areas: none !important;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    gap: var(--sp-12);
    margin: 0;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }

  .carousel-track::-webkit-scrollbar { display: none; }

  .carousel-track > * {
    flex: 0 0 86%;
    scroll-snap-align: center;
    margin: 0 !important;
  }

  /* dentro del carrusel los items se ven siempre (no dependen del scroll-reveal vertical) */
  .carousel-track.reveal,
  .carousel-track .reveal { opacity: 1 !important; transform: none !important; }

  /* altura uniforme para las fotos */
  .carousel-track .gallery__item,
  .carousel-track .room__item {
    aspect-ratio: 4 / 3;
    height: auto !important;
  }

  /* grid del año no activo: ni track ni flechas */
  .carousel-track[hidden] { display: none !important; }
  .carousel-track[hidden] ~ .carousel__arrow { display: none !important; }
}


/* ============================================================
   TELÉFONOS ÚTILES Y DE EMERGENCIA (normas.html)
   ============================================================ */
.phones {
  max-width: 760px;
  margin-top: var(--sp-64);
}

.phones__title {
  font-size: var(--text-subheading);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-subheading);
  color: var(--color-obsidian);
  margin-bottom: var(--sp-12);
}

.phones__note {
  font-size: var(--text-body);
  line-height: 1.6;
  letter-spacing: var(--tracking-body);
  color: var(--color-ink-soft);
  margin-bottom: var(--sp-24);
}

.phones__note strong { color: var(--color-ember-orange); }

.phones__list {
  display: grid;
  grid-template-columns: 1fr;
}

@media (min-width: 600px) {
  .phones__list { grid-template-columns: 1fr 1fr; column-gap: var(--sp-40); }
}

.phone {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--sp-16);
  padding: var(--sp-16) 0;
  border-bottom: 1px solid var(--color-mist);
}

.phone__name {
  font-size: var(--text-body);
  letter-spacing: var(--tracking-body);
  color: var(--color-obsidian);
}

.phone__num {
  font-size: var(--text-body);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-body);
  color: var(--color-obsidian);
  white-space: nowrap;
  transition: color var(--ease-ui);
}

.phone__num:hover { color: var(--color-ember-orange); }
