/* ================================================================
   WEDDING WEBSITE — styles.css
   Maria Valeria & Juan David · 21.11.2026
   Mobile-first · BEM · CSS custom properties
   ================================================================ */

/* ----------------------------------------------------------------
   LOCAL FONTS
   ---------------------------------------------------------------- */
@font-face {
  font-family: 'Glift';
  src: url('assets/fonts/Glift-Regular.woff2') format('woff2'),
       url('assetsfonts/Glift-Regular.ttf')   format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'AdriannaExtended';
  src: url('assets/fonts/AdriannaExtended-Regular.woff2') format('woff2'),
       url('assets/fonts/AdriannaExtended-Regular.ttf')   format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

/* ----------------------------------------------------------------
   CUSTOM PROPERTIES
   ---------------------------------------------------------------- */
:root {
  --clr-wine:      #4e1e1e;
  --clr-wine-dk:   #2e0e0e;
  --clr-green:     #666843;
  --clr-cream:     #e5ddd1;
  --clr-cream-lt:  #f2ede6;
  --clr-charcoal:  #1e1a17;
  --clr-white:     #ffffff;
  --clr-stone:     rgba(229,221,209,.25);

  --font-serif:    'Glift', Georgia, serif;
  --font-sans:     'AdriannaExtended', 'Helvetica Neue', sans-serif;

  --sp-xs:  0.5rem;
  --sp-sm:  1rem;
  --sp-md:  2rem;
  --sp-lg:  4rem;
  --sp-xl:  6rem;

  --ease:   cubic-bezier(0.22, 1, 0.36, 1);
  --nav-h:  60px;
}

/* ----------------------------------------------------------------
   RESET
   ---------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  font-family: var(--font-sans);
  color: var(--clr-charcoal);
  background: var(--clr-cream-lt);
  line-height: 1.6;
  overflow-x: hidden;
}
img, iframe { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }

/* ----------------------------------------------------------------
   UTILITIES
   ---------------------------------------------------------------- */
.container {
  width: min(100%, 1100px);
  margin-inline: auto;
  padding-inline: var(--sp-md);
}

/* Section titles */
.section-title {
  font-family: var(--font-serif);
  font-size: clamp(1.4rem, 3vw, 2rem);
  font-weight: 400;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--clr-wine);
  text-align: center;
  margin-bottom: var(--sp-sm);
}
.section-subtitle {
  font-family: var(--font-sans);
  font-size: clamp(.78rem, 1.5vw, .9rem);
  font-weight: 400;
  letter-spacing: .06em;
  color: var(--clr-green);
  text-align: center;
  max-width: 580px;
  margin-inline: auto;
  margin-bottom: var(--sp-lg);
}

/* Buttons */
.btn {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: .65rem;
  font-weight: 400;
  letter-spacing: .2em;
  text-transform: uppercase;
  padding: .7rem 1.8rem;
  cursor: pointer;
  transition: background .25s var(--ease), color .25s var(--ease), transform .2s var(--ease);
  border: 1px solid currentColor;
}
.btn:hover  { transform: translateY(-2px); }
.btn:active { transform: none; }
.btn:focus-visible { outline: 2px solid var(--clr-cream); outline-offset: 3px; }

.btn--cream         { background: var(--clr-cream); color: var(--clr-wine); border-color: var(--clr-cream); }
.btn--cream:hover   { background: transparent; color: var(--clr-cream); }

.btn--outline-cream { background: transparent; color: var(--clr-cream); border-color: rgba(229,221,209,.7); }
.btn--outline-cream:hover { background: rgba(229,221,209,.15); }

.btn--dark-outline  { background: transparent; color: var(--clr-charcoal); border-color: var(--clr-charcoal); }
.btn--dark-outline:hover { background: var(--clr-wine); color: var(--clr-cream); border-color: var(--clr-wine); }

/* ----------------------------------------------------------------
   SCROLL REVEAL
   ---------------------------------------------------------------- */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .7s var(--ease), transform .7s var(--ease);
}
.reveal.is-visible { opacity: 1; transform: none; }

.reveal-left {
  opacity: 0;
  transform: translateX(-28px);
  transition: opacity .7s var(--ease), transform .7s var(--ease);
}
.reveal-right {
  opacity: 0;
  transform: translateX(28px);
  transition: opacity .7s var(--ease), transform .7s var(--ease);
}
.reveal-left.is-visible,
.reveal-right.is-visible { opacity: 1; transform: none; }

/* ----------------------------------------------------------------
   HEADER / NAV
   ---------------------------------------------------------------- */
.site-header {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 100;
  transition: background .3s var(--ease), box-shadow .3s var(--ease);
}
.site-header.scrolled {
  background: rgba(46,14,14,.96);
  box-shadow: 0 2px 20px rgba(0,0,0,.35);
}

.nav {
  display: flex;
  align-items: center;
  justify-content: center;
  height: var(--nav-h);
  padding-inline: var(--sp-md);
  gap: var(--sp-lg);
  position: relative;
}

.nav__list {
  display: flex;
  gap: clamp(.8rem, 2vw, 1.8rem);
  align-items: center;
}

.nav__link {
  font-family: var(--font-sans);
  font-size: .58rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--clr-cream);
  opacity: .8;
  transition: opacity .2s;
  position: relative;
}
.nav__link::after {
  content: '';
  position: absolute;
  bottom: -3px; left: 0;
  width: 0; height: 1px;
  background: var(--clr-cream);
  transition: width .3s var(--ease);
}
.nav__link:hover { opacity: 1; }
.nav__link:hover::after { width: 100%; }

/* Logo imagen en nav */
.nav__logo-img {
  height: 36px;
  width: auto;
  display: block;
  opacity: .9;
  transition: opacity .2s;
}
.nav__logo:hover .nav__logo-img { opacity: 1; }

/* Mantener por compatibilidad si aún se usa en footer */
.nav__monogram {
  font-family: var(--font-serif);
  font-size: 1rem;
  letter-spacing: .12em;
  color: var(--clr-cream);
  border: 1px solid rgba(229,221,209,.45);
  padding: .28rem .55rem;
  transition: border-color .2s;
}
.nav__logo:hover .nav__monogram { border-color: var(--clr-cream); }

/* Hamburger */
.nav__burger {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: .5rem;
  position: absolute;
  right: var(--sp-md);
}
.nav__burger span {
  display: block;
  width: 22px; height: 1px;
  background: var(--clr-cream);
  transition: transform .3s var(--ease), opacity .3s;
}
.nav__burger.is-open span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.nav__burger.is-open span:nth-child(2) { opacity: 0; }
.nav__burger.is-open span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

/* Mobile drawer */
.nav__drawer {
  background: var(--clr-wine-dk);
  max-height: 0;
  overflow: hidden;
  transition: max-height .4s var(--ease);
}
.nav__drawer.is-open { max-height: 360px; }

.nav__drawer-list {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-sm);
  padding: var(--sp-sm) 0 var(--sp-md);
}

.nav__drawer-link {
  font-family: var(--font-sans);
  font-size: .65rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--clr-cream);
  opacity: .8;
  transition: opacity .2s;
}
.nav__drawer-link:hover { opacity: 1; }

/* ----------------------------------------------------------------
   HERO
   ---------------------------------------------------------------- */
.hero {
  position: relative;
  min-height: 100svh;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* FOTO HERO: reemplaza el gradient con background-image: url('img/hero.jpg') */
.hero__bg {
  position: absolute;
  inset: 0;
  background: linear-gradient(160deg, #1a0a0a 0%, #2e1010 40%, #1e1408 100%);
  background-size: cover;
  background-position: center top;
  animation: hero-zoom 20s ease-in-out infinite alternate;
  background-image: url('assets/img/MPH_7083.jpg');
}
@keyframes hero-zoom {
  from { transform: scale(1); }
  to   { transform: scale(1.06); }
}

.hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(20,5,5,.35) 0%, rgba(30,8,8,.55) 55%, rgba(10,3,3,.75) 100%);
  z-index: 1;
}

.hero__content {
  position: relative;
  z-index: 2;
  text-align: center;
  padding: calc(var(--nav-h) + var(--sp-xl)) var(--sp-md) var(--sp-xl);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-md);
  color: var(--clr-cream);
}

.hero__eyebrow {
  font-family: var(--font-sans);
  font-size: .58rem;
  letter-spacing: .4em;
  text-transform: uppercase;
  opacity: .65;
  animation: fade-down .7s var(--ease) .2s both;
}

/* Countdown */
.hero__countdown {
  display: flex;
  align-items: flex-start;
  gap: .4rem;
  animation: fade-down .7s var(--ease) .4s both;
}
.hero__cd-unit {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 2.8rem;
}
.hero__cd-num {
  font-family: var(--font-serif);
  font-size: clamp(1.3rem, 5vw, 2rem);
  line-height: 1;
  letter-spacing: .04em;
}
.hero__cd-label {
  font-family: var(--font-sans);
  font-size: .5rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  opacity: .6;
  margin-top: .2rem;
}
.hero__cd-sep {
  font-size: clamp(1rem, 4vw, 1.6rem);
  line-height: 1;
  opacity: .4;
  padding-top: .05em;
}

/* Names */
.hero__names {
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: clamp(2.6rem, 9vw, 5.5rem);
  line-height: 1.15;
  letter-spacing: .04em;
  animation: fade-up .9s var(--ease) .5s both;
}
.hero__names em {
  font-style: italic;
  font-size: .65em;
  color: rgba(229,221,209,.75);
}

.hero__cta-group {
  display: flex;
  gap: var(--sp-sm);
  flex-wrap: wrap;
  justify-content: center;
  animation: fade-up .7s var(--ease) .75s both;
}

/* ----------------------------------------------------------------
   BODA — timeline sobre fondo oscuro con foto
   ---------------------------------------------------------------- */
.boda {
  position: relative;
  padding: var(--sp-xl) 0;
}

/* FOTO FONDO: agrega background-image: url('img/boda-bg.jpg') */
.boda__bg {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, #1a0808 0%, #0e0505 100%);
  background-size: cover;
  background-position: center;
  background-image: url('assets/img/MPH_6508.jpg');
}
.boda__overlay {
  position: absolute;
  inset: 0;
  background: rgba(10,3,3,.72);
}

.boda__inner {
  position: relative;
  z-index: 2;
}

.boda__intro {
  font-family: var(--font-sans);
  font-size: clamp(.78rem, 1.5vw, .9rem);
  letter-spacing: .08em;
  color: rgba(229,221,209,.7);
  text-align: center;
  max-width: 500px;
  margin-inline: auto;
  margin-bottom: var(--sp-xl);
}

/* Timeline grid: left | 1px line | right */
.boda__timeline {
  display: grid;
  grid-template-columns: 1fr 1px 1fr;
  width: min(100%, 700px);
  margin-inline: auto;
}

.boda__row {
  display: contents; /* children participate in parent grid */
}

.boda__cell {
  padding: var(--sp-md) var(--sp-md);
  min-height: 110px;
  display: flex;
  align-items: center;
}
.boda__cell--left  { justify-content: flex-end; }
.boda__cell--right { justify-content: flex-start; }

/* The thin vertical line column */
.boda__line-col {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
}
.boda__line-seg {
  flex: 1;
  width: 1px;
  background: rgba(229,221,209,.2);
  min-height: 30px;
}
.boda__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--clr-cream);
  flex-shrink: 0;
  transform: scale(0);
  transition: transform .5s var(--ease);
}
.boda__line-col.dot-active .boda__dot { transform: scale(1); }

/* Info content */
.boda__info {
  display: flex;
  flex-direction: column;
  gap: .3rem;
  text-align: right;
}
.boda__cell--right .boda__info { text-align: left; }

.boda__info-label {
  font-family: var(--font-sans);
  font-size: .55rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: rgba(229,221,209,.55);
}
.boda__info-value {
  font-family: var(--font-serif);
  font-size: clamp(1rem, 2.5vw, 1.35rem);
  font-weight: 400;
  color: var(--clr-cream);
  line-height: 1.3;
}
.boda__info-link {
  font-family: var(--font-sans);
  font-size: .55rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: rgba(229,221,209,.5);
  margin-top: .2rem;
  transition: color .2s;
}
.boda__info-link:hover { color: var(--clr-cream); }

/* ----------------------------------------------------------------
   MAPA
   ---------------------------------------------------------------- */
.mapa { background: #111; }
.mapa__inner { overflow: hidden; }
.mapa__inner iframe { display: block; }

/* ----------------------------------------------------------------
   VESTIMENTA
   ---------------------------------------------------------------- */
.vestimenta {
  background: var(--clr-cream-lt);
  padding-top: var(--sp-xl);
}

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

.vestimenta__photo {
  min-height: 420px;
  background-size: cover;
  background-position: center top;
  overflow: hidden;
  transition: transform .6s var(--ease);
}
/* FOTO MUJERES: background-image: url('img/vestimenta-mujeres.jpg') */
/* MUJERES — 3 slides */
.vestimenta__photo--women  { background-image: url('assets/img/mujer1.jpg'); }
.vestimenta__photo--women2 { background-image: url('assets/img/mujer2.jpg'); }
.vestimenta__photo--women3 { background-image: url('assets/img/mujer3.jpg'); }


/* FOTO HOMBRES: background-image: url('img/vestimenta-hombres.jpg') */
/* HOMBRES — 3 slides */
.vestimenta__photo--men    { background-image: url('assets/img/hombre1.jpg'); }
.vestimenta__photo--men2   { background-image: url('assets/img/hombre2.jpg'); }
.vestimenta__photo--men3   { background-image: url('assets/img/hombre3.jpg'); }

.vestimenta__block:hover .vestimenta__photo { transform: scale(1.03); }

.vestimenta__body {
  padding: var(--sp-xl) var(--sp-lg);
  background: var(--clr-cream-lt);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: var(--sp-sm);
}
.vestimenta__body--text-left { text-align: left; }

.vestimenta__heading {
  font-family: var(--font-serif);
  font-size: clamp(.9rem, 2vw, 1.2rem);
  font-weight: 400;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--clr-wine);
}
.vestimenta__desc {
  font-family: var(--font-sans);
  font-size: .82rem;
  letter-spacing: .06em;
  color: var(--clr-charcoal);
}
.vestimenta__rules {
  display: flex;
  flex-direction: column;
  gap: .4rem;
}
.vestimenta__rules li {
  font-family: var(--font-sans);
  font-size: .78rem;
  letter-spacing: .04em;
  color: var(--clr-charcoal);
  padding-left: 1rem;
  position: relative;
}
.vestimenta__rules li::before {
  content: '·';
  position: absolute;
  left: 0;
  color: var(--clr-wine);
}

/* ----------------------------------------------------------------
   HOSPEDAJE
   ---------------------------------------------------------------- */
.hospedaje {
  background: var(--clr-cream);
  padding: var(--sp-xl) 0;
}

.hospedaje__wrap {
  position: relative;
  margin-top: var(--sp-md);
}

.hospedaje__track-clip {
  overflow: hidden;
}

.hospedaje__track {
  display: flex;
  transition: transform .5s var(--ease);
}

.hospedaje__card {
  flex: 0 0 100%;
  display: grid;
  grid-template-columns: 1fr 1.2fr;
}

.hospedaje__card-img {
  min-height: 280px;
  background-size: cover;
  background-position: center;
}
/* FOTO: background-image: url('img/holiday-inn.jpg') */
.hospedaje__card-img--1 { background-image: url('assets/img/holiday-inn.jpg') }
.hospedaje__card-img--2 { background-image: url('assets/img/el-prado.jpg') }

.hospedaje__card-body {
  padding: var(--sp-lg) var(--sp-md);
  background: var(--clr-cream-lt);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: var(--sp-sm);
}
.hospedaje__card-name {
  font-family: var(--font-serif);
  font-size: clamp(.85rem, 1.8vw, 1.1rem);
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--clr-wine);
}
.hospedaje__card-desc {
  font-family: var(--font-sans);
  font-size: .78rem;
  letter-spacing: .04em;
  color: var(--clr-charcoal);
}

.hospedaje__arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(229,221,209,.9);
  border: 1px solid rgba(0,0,0,.12);
  width: 38px; height: 38px;
  cursor: pointer;
  font-size: .9rem;
  color: var(--clr-charcoal);
  transition: background .2s, color .2s;
  z-index: 10;
}
.hospedaje__arrow:hover { background: var(--clr-wine); color: var(--clr-cream); border-color: var(--clr-wine); }
.hospedaje__arrow--prev { left: 4px; }
.hospedaje__arrow--next { right: 4px; }

/* ----------------------------------------------------------------
   BELLEZA — foto centrada única, maquilladoras arriba-der, peinadoras abajo-izq
   ---------------------------------------------------------------- */
.belleza {
  background: var(--clr-wine);
  padding: var(--sp-xl) 0 var(--sp-xl);
}

.belleza__intro {
  font-family: var(--font-sans);
  font-size: clamp(.78rem, 1.5vw, .88rem);
  letter-spacing: .06em;
  color: rgba(229,221,209,.7);
  text-align: left;
  max-width: 560px;
  margin-bottom: var(--sp-lg);
}

/* Layout principal: grid con foto centrada y textos en las esquinas */
.belleza__layout {
  position: relative;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  grid-template-rows: auto auto;
  gap: var(--sp-md);
  align-items: center;
  padding: 0 var(--sp-md);
  max-width: 1100px;
  margin-inline: auto;
}

/* Foto central — ocupa las 2 filas, columna central */
.belleza__center-photo {
  grid-column: 2;
  grid-row: 1 / 3;
  width: clamp(240px, 28vw, 380px);
  aspect-ratio: 3/4;
  background-color: #c0a890;
  background-size: cover;
  background-position: center top;
  background-image: url('assets/img/belleza.jpg')
}

/* Maquilladoras — fila 1, columna 3 (arriba derecha) */
.belleza__group--makeup {
  grid-column: 3;
  grid-row: 1;
  text-align: right;
  align-self: end;
  padding-bottom: var(--sp-md);
}

/* Peinadoras — fila 2, columna 1 (abajo izquierda) */
.belleza__group--hair {
  grid-column: 1;
  grid-row: 2;
  text-align: left;
  align-self: start;
  padding-top: var(--sp-md);
}

.belleza__heading {
  font-family: var(--font-serif);
  font-size: clamp(1.1rem, 2.5vw, 1.6rem);
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--clr-cream);
  margin-bottom: var(--sp-sm);
}

.belleza__handles { display: flex; flex-direction: column; gap: .35rem; }
.belleza__handle {
  font-family: var(--font-sans);
  font-size: .78rem;
  letter-spacing: .06em;
  color: rgba(229,221,209,.75);
  transition: color .2s;
}
.belleza__handle:hover { color: var(--clr-cream); }

/* ----------------------------------------------------------------
   VESTIMENTA — carrusel de fotos
   ---------------------------------------------------------------- */
.vestimenta__carousel {
  position: relative;
  overflow: hidden;
  aspect-ratio: 4 / 5;
  width: 100%;
}

.vest-track {
  display: flex;
  height: 100%;
  transition: transform .5s var(--ease);
}

.vest-slide {
  flex: 0 0 100%;
  aspect-ratio: 4 / 5;
  min-height: unset;
  background-size: cover;
  background-position: center top;
}

/* Placeholder colors — reemplaza con background-image en cada clase */
.vestimenta__photo--women  { background-color: #b8a898; }
.vestimenta__photo--women2 { background-color: #a89888; }
.vestimenta__photo--women3 { background-color: #c8b8a8; }
.vestimenta__photo--men    { background-color: #2a2520; }
.vestimenta__photo--men2   { background-color: #1a1510; }
.vestimenta__photo--men3   { background-color: #3a3530; }

/* Flechas del carrusel de vestimenta */
.vest-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(229,221,209,.85);
  border: none;
  width: 34px; height: 34px;
  cursor: pointer;
  font-size: .85rem;
  color: var(--clr-charcoal);
  transition: background .2s, color .2s;
  z-index: 5;
}
.vest-btn:hover { background: var(--clr-wine); color: var(--clr-cream); }
.vest-btn--prev { left: 0; }
.vest-btn--next { right: 0; }

/* Dots del carrusel de vestimenta */
.vest-dots {
  position: absolute;
  bottom: .7rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: .4rem;
  z-index: 5;
}
.vest-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: rgba(229,221,209,.45);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background .2s, transform .2s;
}
.vest-dot.is-active {
  background: var(--clr-cream);
  transform: scale(1.3);
}

/* ----------------------------------------------------------------
   EXPLORA — carrusel
   ---------------------------------------------------------------- */
.explora {
  background: var(--clr-cream-lt);
  padding: var(--sp-xl) 0 0;
}

.explora__slider-wrap {
  position: relative;
  margin-top: var(--sp-lg);
}

.explora__track-clip {
  overflow: hidden;
  position: relative;
}

.explora__track {
  display: flex;
  transition: transform .5s var(--ease);
}

.explora__card {
  flex: 0 0 100%;
  position: relative;
  overflow: hidden;
}

/* FOTOS: agrega background-image a cada clase */
.explora__img {
  width: 100%;
  height: clamp(280px, 45vw, 520px);
  background-size: cover;
  background-position: center;
  transition: transform .7s var(--ease);
}

.explora__img--1 { background-image: url(assets/img/malecon.jpeg); }
.explora__img--2 { background-image: url(assets/img/varadero.jpg); }
.explora__img--3 { background-image: url(assets/img/ventana-al-mundo.jpg); }

.explora__card:hover .explora__img { transform: scale(1.03); }

.explora__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(10,5,5,.72) 0%, rgba(10,5,5,.35) 55%, transparent 100%);
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-left: clamp(var(--sp-md), 6vw, var(--sp-xl));
  gap: var(--sp-sm);
}

.explora__badge {
  font-family: var(--font-sans);
  font-size: .55rem;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: rgba(229,221,209,.7);
  border: 1px solid rgba(229,221,209,.35);
  padding: .25rem .7rem;
  display: inline-block;
  width: fit-content;
}

/* Botón explora más compacto */
.explora__overlay .btn {
  padding: .5rem 1.2rem;
  font-size: .58rem;
  width: fit-content;
  align-self: flex-start;
}

.explora__place {
  font-family: var(--font-serif);
  font-size: clamp(1.5rem, 4vw, 2.8rem);
  font-weight: 400;
  color: var(--clr-cream);
  max-width: 380px;
  line-height: 1.2;
}

/* Flechas explora — relativas al track-clip */
.explora__track-clip {
  position: relative;
}
.explora__arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(229,221,209,.85);
  border: 1px solid rgba(0,0,0,.1);
  width: 40px; height: 40px;
  cursor: pointer;
  font-size: .9rem;
  color: var(--clr-charcoal);
  transition: background .2s, color .2s;
  z-index: 5;
}
.explora__arrow:hover { background: var(--clr-wine); color: var(--clr-cream); border-color: var(--clr-wine); }
.explora__arrow--prev { left: 0; }
.explora__arrow--next { right: 0; }

/* Dots explora — encima de la imagen, esquina inferior central */
.explora__dots {
  position: absolute;
  bottom: var(--sp-sm);
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  justify-content: center;
  gap: .5rem;
  z-index: 6;
  pointer-events: auto;
}
.explora__dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: rgba(229,221,209,.45);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background .2s, transform .2s;
}
.explora__dot.is-active {
  background: var(--clr-cream);
  transform: scale(1.3);
}

/* ----------------------------------------------------------------
   REGALOS — pantalla completa como sección boda
   ---------------------------------------------------------------- */
.regalos {
  position: relative;
  min-height: 100svh;
  display: flex;
  align-items: center;
  margin-top: 0;
}

/* FOTO FONDO: background-image: url('img/regalos-bg.jpg') */
.regalos__bg {
  position: absolute;
  inset: 0;
  background: linear-gradient(160deg, #1a0505 0%, #0e0202 100%);
  background-size: cover;
  background-position: center;
  background-image: url(assets/img/regalos.jpg);
}
.regalos__overlay {
  position: absolute;
  inset: 0;
  background: rgba(8,2,2,.68);
}

.regalos__inner {
  position: relative;
  z-index: 2;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-md);
  padding: var(--sp-xl) 0;
  width: 100%;
}

.regalos__logo {
  height: 60px;
  width: auto;
  opacity: .85;
  margin-bottom: var(--sp-sm);
}

.regalos__message {
  font-family: var(--font-sans);
  font-size: clamp(.78rem, 1.5vw, .9rem);
  letter-spacing: .06em;
  line-height: 1.8;
  color: rgba(229,221,209,.8);
  max-width: 520px;
}

.regalos__cta-group {
  display: flex;
  gap: var(--sp-sm);
  flex-wrap: wrap;
  justify-content: center;
}

/* ----------------------------------------------------------------
   FOOTER
   ---------------------------------------------------------------- */
.site-footer {
  background: var(--clr-wine-dk);
  padding: var(--sp-lg) 0;
}
.site-footer__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .4rem;
  text-align: center;
  color: var(--clr-cream);
}
.site-footer__logo {
  height: 44px;
  width: auto;
  opacity: .75;
  margin-bottom: .4rem;
}
.site-footer__names {
  font-family: var(--font-serif);
  font-size: .9rem;
  opacity: .75;
}
.site-footer__date {
  font-family: var(--font-sans);
  font-size: .55rem;
  letter-spacing: .28em;
  text-transform: uppercase;
  opacity: .45;
  margin-top: .2rem;
}

/* ----------------------------------------------------------------
   KEYFRAMES
   ---------------------------------------------------------------- */
@keyframes fade-up {
  from { opacity: 0; transform: translateY(18px); }
  to   { opacity: 1; transform: none; }
}
@keyframes fade-down {
  from { opacity: 0; transform: translateY(-14px); }
  to   { opacity: 1; transform: none; }
}

/* ================================================================
   RESPONSIVE
   ================================================================ */

/* Tablet ≥ 640px */
@media (min-width: 640px) {
  .hospedaje__card { flex: 0 0 50%; }
}

/* Mobile < 640px */
@media (max-width: 639px) {
  :root { --nav-h: 54px; }

  /* Nav */
  .nav__list   { display: none; }
  .nav__burger { display: flex; }
  .nav { gap: 0; justify-content: center; }

  /* Hero — más a la izquierda */
  .hero__bg { background-position: 70% center; }

  /* Boda timeline — mantiene 3 columnas, centrado */
  .boda__timeline {
    grid-template-columns: 1fr 1px 1fr;
    width: 100%;
  }
  .boda__cell {
    min-height: 80px;
    padding: var(--sp-sm) var(--sp-xs);
  }
  .boda__cell--left  { justify-content: flex-end; }
  .boda__cell--right { justify-content: flex-start; }
  .boda__info-label  { font-size: .48rem; }
  .boda__info-value  { font-size: .88rem; }

  /* Vestimenta — carrusel se apila */
  .vestimenta__block { grid-template-columns: 1fr; }
  .vestimenta__carousel { aspect-ratio: 4 / 5; min-height: unset; }
  .vest-slide { aspect-ratio: 4 / 5; min-height: unset; }
  .vestimenta__block--men .vestimenta__carousel { order: -1; }
  .vestimenta__body { padding: var(--sp-lg) var(--sp-md); }

  /* Hospedaje — flechas visibles, tarjeta en columna única */
  .hospedaje__card     { grid-template-columns: 1fr; flex: 0 0 100%; }
  .hospedaje__card-img { min-height: 200px; }

  /* Belleza — columna única centrada */
  .belleza__layout {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--sp-lg);
    padding: 0 var(--sp-md);
  }
  .belleza__center-photo {
    width: min(260px, 72vw);
    aspect-ratio: 3/4;
    order: 1;
  }
  .belleza__group--makeup {
    order: 0;
    text-align: center;
    padding: 0;
    width: 100%;
  }
  .belleza__group--hair {
    order: 2;
    text-align: center;
    padding: 0;
    width: 100%;
  }
  .belleza__heading { font-size: 1rem; }
  .belleza__handles { align-items: center; }

  /* Explora */
  .explora__overlay { padding-left: var(--sp-md); }
  .explora__arrow   { display: none; }

  /* Regalos — menos alto, padding generoso */
  .regalos          { min-height: 70svh; }
  .regalos__inner   { padding: var(--sp-xl) var(--sp-lg); }
  .regalos__cta-group { flex-direction: column; align-items: center; }
}
