/* =========================================================
   BASE — Estructura y componentes de la invitación (FUENTE ÚNICA)
   Compartido por todas las invitaciones vía assets/invitacion/base.css.
   Mobile-first · BEM · Sin dependencias.
   Los colores/fuentes vienen de temas.css ([data-tema]/[data-fuente]).
   Cárgalo DESPUÉS de temas.css.
   ========================================================= */

/* =========================================================
   TOKENS estructurales + defaults del HERO
   (los tokens de color/fuente viven en temas.css)
   ========================================================= */
:root {
  --color-blanco: #ffffff;
  --peso-titulo: 600;

  /* Espaciado (escala 4·8·16·24·40·64·96) */
  --esp-1: 4px;  --esp-2: 8px;  --esp-3: 16px;
  --esp-4: 24px; --esp-5: 40px; --esp-6: 64px; --esp-7: 96px;

  /* Radios y sombra */
  --radio-sm: 4px;
  --radio-md: 12px;
  --radio-full: 999px;
  --sombra: 0 8px 30px rgba(0, 0, 0, 0.08);

  /* Layout */
  --ancho-max: 720px;
  --transicion: 0.4s ease;

  /* HERO — defaults = arquetipo OSCURO. Las paletas en temas.css
     sobrescriben estas 4 variables para definir su arquetipo
     (claro / oscuro / saturado) sin tocar el HTML. */
  --hero-fondo: var(--color-acento);
  --hero-texto: var(--color-blanco);
  --hero-overlay: linear-gradient(180deg, rgba(0,0,0,.25), rgba(0,0,0,.55));
  --hero-deco: var(--color-primario);
}

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

/* El atributo hidden siempre oculta (evita que reglas con display lo pisen). */
[hidden] { display: none !important; }

html { scroll-behavior: smooth; }

body {
  background-color: var(--color-secundario);
  color: var(--color-texto);
  font-family: var(--fuente-texto);
  font-size: 16px;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
}

img { max-width: 100%; display: block; }
iframe { border: 0; }

/* =========================================================
   UTILIDADES — divisor, títulos, animación fade-up
   ========================================================= */
.divisor {
  display: block;
  text-align: center;
  color: var(--color-primario);
  font-size: 1.5rem;
  margin: 0 auto var(--esp-3);
}

.seccion__titulo {
  font-family: var(--fuente-titulos);
  font-weight: var(--peso-titulo);
  font-size: clamp(1.8rem, 6vw, 2.6rem);
  color: var(--color-acento);
  text-align: center;
  margin-bottom: var(--esp-4);
}

.fade-up {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}
.fade-up.is-visible { opacity: 1; transform: none; }

/* =========================================================
   HERO — lee la capa --hero-* (ver temas.css)
   ========================================================= */
.hero {
  position: relative;
  min-height: 100svh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: var(--esp-5) var(--esp-3);
  background: var(--hero-fondo) center / cover no-repeat;
  color: var(--hero-texto);
}
.hero__overlay {
  position: absolute; inset: 0;
  background: var(--hero-overlay);
}
.hero__contenido { position: relative; z-index: 1; }

.hero__intro {
  font-family: var(--fuente-texto);
  text-transform: uppercase;
  letter-spacing: 0.35em;
  font-size: 0.8rem;
  margin-bottom: var(--esp-3);
  color: var(--hero-deco);
}
.hero__nombres {
  font-family: var(--fuente-nombres);
  font-weight: var(--peso-titulo);
  font-size: clamp(3rem, 16vw, 6rem);
  line-height: 1.05;
  color: inherit;
}
.hero__amp { display: block; font-size: 0.5em; opacity: 0.9; margin: var(--esp-1) 0; color: var(--hero-deco); }
.hero__fecha {
  font-family: var(--fuente-titulos);
  letter-spacing: 0.2em;
  font-size: clamp(1.1rem, 5vw, 1.5rem);
  margin-top: var(--esp-3);
  color: inherit;
}
.hero__scroll {
  display: inline-block;
  margin-top: var(--esp-5);
  color: inherit;
  text-decoration: none;
}
.hero__flecha {
  display: inline-block;
  font-size: 2rem;
  animation: rebote 1.8s infinite;
}
@keyframes rebote { 0%,100%{transform:translateY(0)} 50%{transform:translateY(8px)} }

/* =========================================================
   BIENVENIDA
   ========================================================= */
.bienvenida { text-align: center; padding: var(--esp-6) var(--esp-3) var(--esp-5); }
.bienvenida__titulo {
  font-family: var(--fuente-titulos);
  font-weight: var(--peso-titulo);
  font-size: clamp(1.8rem, 6vw, 2.6rem);
  color: var(--color-acento);
  margin-bottom: var(--esp-3);
}
.bienvenida__texto {
  max-width: var(--ancho-max); margin: 0 auto;
  color: var(--color-texto-suave); font-size: 1.05rem;
}

/* Contenedor general de secciones (la galería va aparte: a sangre) */
.contador, .historia, .evento, .rsvp, .padrinos,
.mesa-regalos, .dress-code, .itinerario, .hospedaje {
  padding: var(--esp-6) var(--esp-3);
  max-width: var(--ancho-max);
  margin: 0 auto;
}

/* =========================================================
   CUENTA REGRESIVA
   ========================================================= */
.contador__lista {
  list-style: none; display: flex; gap: var(--esp-2);
  justify-content: center; flex-wrap: wrap;
}
.contador__item {
  background: var(--color-blanco);
  border-radius: var(--radio-md);
  box-shadow: var(--sombra);
  padding: var(--esp-3) var(--esp-2);
  min-width: 72px; text-align: center;
}
.contador__num {
  display: block;
  font-family: var(--fuente-titulos);
  font-weight: 700; font-size: 2.2rem; color: var(--color-acento);
  line-height: 1;
}
.contador__label {
  display: block; margin-top: var(--esp-1);
  font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.15em;
  color: var(--color-texto-suave);
}

/* =========================================================
   HISTORIA / TIMELINE  (solo bodas)
   ========================================================= */
.historia__linea { list-style: none; position: relative; padding-left: var(--esp-4); }
.historia__linea::before {
  content: ""; position: absolute; left: 7px; top: 4px; bottom: 4px;
  width: 2px; background: var(--color-primario); opacity: 0.4;
}
.historia__item { position: relative; padding-bottom: var(--esp-5); }
.historia__item::before {
  content: ""; position: absolute; left: -22px; top: 6px;
  width: 14px; height: 14px; border-radius: var(--radio-full);
  background: var(--color-primario); box-shadow: 0 0 0 4px var(--color-secundario);
}
.historia__fecha { font-weight: 600; color: var(--color-acento); font-size: 0.9rem; letter-spacing: 0.1em; }
.historia__titulo { font-family: var(--fuente-titulos); font-size: 1.4rem; color: var(--color-acento); margin: var(--esp-1) 0; }
.historia__texto { color: var(--color-texto-suave); }
/* Imagen opcional del momento */
.historia__img {
  width: 100%; max-height: 340px; object-fit: cover; display: block;
  border-radius: var(--radio-md); margin-top: var(--esp-3); box-shadow: var(--sombra);
}

/* =========================================================
   PADRINOS  (propio de XV años)
   ========================================================= */
.padrinos { text-align: center; }
.padrinos__lista {
  list-style: none; display: grid; gap: var(--esp-3);
  grid-template-columns: 1fr;
}
.padrinos__item {
  background: var(--color-blanco);
  border-radius: var(--radio-md);
  box-shadow: var(--sombra);
  padding: var(--esp-4) var(--esp-3);
}
.padrinos__rol {
  font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.18em;
  color: var(--color-primario); font-weight: 700; margin-bottom: var(--esp-1);
}
.padrinos__nombres {
  font-family: var(--fuente-titulos); font-size: 1.3rem; color: var(--color-acento);
  line-height: 1.3;
}

/* =========================================================
   MESA DE REGALOS  (módulo opcional · boda y XV)
   ========================================================= */
.mesa-regalos { text-align: center; }
.mesa-regalos__mensaje {
  max-width: var(--ancho-max); margin: 0 auto var(--esp-4);
  color: var(--color-texto-suave); font-size: 1.05rem;
}
.mesa-regalos__lista {
  display: flex; flex-wrap: wrap; gap: var(--esp-3);
  justify-content: center;
}
.mesa-regalos__link {
  display: inline-block;
  padding: var(--esp-2) var(--esp-4); border: 1.5px solid var(--color-acento);
  border-radius: var(--radio-full); color: var(--color-acento); text-decoration: none;
  font-family: var(--fuente-texto); font-weight: 600; font-size: .95rem;
  transition: background var(--transicion), color var(--transicion);
}
.mesa-regalos__link:hover { background: var(--color-acento); color: var(--color-blanco); }

/* =========================================================
   CÓDIGO DE VESTIMENTA  (módulo opcional · boda y XV)
   ========================================================= */
.dress-code { text-align: center; }
.dress-code__descripcion {
  max-width: var(--ancho-max); margin: 0 auto var(--esp-4);
  color: var(--color-texto-suave); font-size: 1.05rem;
}
.dress-code__colores {
  display: flex; flex-wrap: wrap; gap: var(--esp-2);
  justify-content: center;
}
.dress-code__color {
  width: 36px; height: 36px; border-radius: var(--radio-full);
  box-shadow: var(--sombra); border: 1px solid rgba(0,0,0,0.12);
  display: inline-block;
}

/* =========================================================
   ITINERARIO / CRONOGRAMA  (módulo opcional · boda y XV)
   ========================================================= */
.itinerario { text-align: center; }
.itinerario__lista {
  list-style: none; max-width: 440px; margin: 0 auto; text-align: left;
}
.itinerario__item {
  display: flex; align-items: baseline; gap: var(--esp-3);
  padding: var(--esp-3) 0; border-bottom: 1px solid rgba(0,0,0,0.08);
}
.itinerario__item:last-child { border-bottom: none; }
.itinerario__hora {
  flex: 0 0 auto; min-width: 84px;
  font-family: var(--fuente-titulos); font-weight: 600;
  color: var(--color-primario); letter-spacing: .06em;
}
.itinerario__actividad { color: var(--color-texto); }

/* =========================================================
   HOSPEDAJE / HOTELES SUGERIDOS  (módulo opcional · boda y XV)
   ========================================================= */
.hospedaje { text-align: center; }
.hospedaje__lista {
  list-style: none; display: grid; gap: var(--esp-3);
  grid-template-columns: 1fr;
}
.hospedaje__item {
  background: var(--color-blanco);
  border-radius: var(--radio-md);
  box-shadow: var(--sombra);
  padding: var(--esp-4) var(--esp-3);
  text-align: center;
}
.hospedaje__nombre {
  font-family: var(--fuente-titulos); font-size: 1.3rem; color: var(--color-acento);
  margin-bottom: var(--esp-1);
}
.hospedaje__direccion { color: var(--color-texto-suave); margin-bottom: var(--esp-2); }
.hospedaje__tel {
  display: inline-block; color: var(--color-primario); text-decoration: none;
  font-weight: 600; letter-spacing: .04em;
}
.hospedaje__tel:hover { text-decoration: underline; }
.hospedaje__link {
  display: inline-block; margin-top: var(--esp-3);
  padding: var(--esp-1) var(--esp-3); border: 1.5px solid var(--color-acento);
  border-radius: var(--radio-full); color: var(--color-acento); text-decoration: none;
  font-family: var(--fuente-texto); font-weight: 600; font-size: .9rem;
  transition: background var(--transicion), color var(--transicion);
}
.hospedaje__link:hover { background: var(--color-acento); color: var(--color-blanco); }

/* =========================================================
   GALERÍA — Carrusel inmersivo a sangre (sin título visible)
   Una foto a la vez, edge-to-edge. Móvil: retrato grande.
   PC: paisaje grande, centrado. Tap = pantalla completa.
   ========================================================= */
.galeria { padding: var(--esp-6) 0; }     /* a sangre: sin padding horizontal */
.carrusel { position: relative; }
.carrusel__track {
  display: flex;
  overflow-x: auto; scroll-snap-type: x mandatory; scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch; scrollbar-width: none;
}
.carrusel__track::-webkit-scrollbar { display: none; }
.carrusel__slide { flex: 0 0 100%; scroll-snap-align: center; }
.carrusel__slide img {
  width: 100%; aspect-ratio: 4 / 5; object-fit: cover; display: block;
  cursor: zoom-in;
}
/* Flechas superpuestas sobre la foto */
.carrusel__nav {
  position: absolute; top: 50%; transform: translateY(-50%); z-index: 2;
  width: 44px; height: 44px; border-radius: var(--radio-full); border: none;
  background: rgba(0,0,0,.30); color: #fff; font-size: 1.7rem; line-height: 1;
  cursor: pointer; display: grid; place-items: center;
  -webkit-backdrop-filter: blur(2px); backdrop-filter: blur(2px);
  transition: background var(--transicion);
}
.carrusel__nav:hover { background: rgba(0,0,0,.5); }
.carrusel__nav--prev { left: 12px; }
.carrusel__nav--next { right: 12px; }
.carrusel__dots { display: flex; justify-content: center; gap: 8px; margin-top: var(--esp-3); }
.carrusel__dot {
  width: 8px; height: 8px; border-radius: 50%; border: none; padding: 0;
  background: var(--color-primario); opacity: .35; cursor: pointer;
  transition: opacity var(--transicion), transform var(--transicion);
}
.carrusel__dot.is-active { opacity: 1; transform: scale(1.4); }

/* =========================================================
   LIGHTBOX (ver foto completa al tocar)
   ========================================================= */

.lightbox {
  position: fixed; inset: 0; z-index: 50;
  display: flex; align-items: center; justify-content: center;
  background: rgba(0,0,0,0.9); padding: var(--esp-3);
  opacity: 0; visibility: hidden; transition: opacity var(--transicion);
}
.lightbox.is-open { opacity: 1; visibility: visible; }
.lightbox__img { max-width: 100%; max-height: 85vh; border-radius: var(--radio-sm); }
.lightbox__cerrar {
  position: absolute; top: var(--esp-3); right: var(--esp-3);
  background: none; border: none; color: var(--color-blanco);
  font-size: 2.5rem; cursor: pointer; line-height: 1;
}
.lightbox__nav {
  position: absolute; top: 50%; transform: translateY(-50%);
  background: none; border: none; color: var(--color-blanco);
  font-size: 3rem; cursor: pointer; padding: var(--esp-2);
}
.lightbox__nav--prev { left: var(--esp-1); }
.lightbox__nav--next { right: var(--esp-1); }

/* =========================================================
   EVENTOS (ceremonia / recepción) + MAPA
   ========================================================= */
.evento { text-align: center; }
.evento__hora {
  font-family: var(--fuente-titulos); font-size: 1.2rem; color: var(--color-primario);
  letter-spacing: .08em; margin-bottom: var(--esp-1);
}
.evento__lugar { font-family: var(--fuente-titulos); font-size: 1.5rem; color: var(--color-acento); }
.evento__direccion { color: var(--color-texto-suave); margin: var(--esp-1) 0 var(--esp-4); }
.evento__mapa {
  border-radius: var(--radio-md); overflow: hidden; box-shadow: var(--sombra);
}
.evento__mapa iframe { width: 100%; height: 280px; display: block; }
.evento__boton {
  display: inline-block; margin-top: var(--esp-3);
  padding: var(--esp-2) var(--esp-4); border: 1.5px solid var(--color-acento);
  border-radius: var(--radio-full); color: var(--color-acento); text-decoration: none;
  font-family: var(--fuente-texto); font-weight: 600; font-size: .95rem;
  transition: background var(--transicion), color var(--transicion);
}
.evento__boton:hover { background: var(--color-acento); color: var(--color-blanco); }

/* =========================================================
   RSVP
   ========================================================= */
.rsvp { text-align: center; }
.rsvp__nota { color: var(--color-texto-suave); margin-bottom: var(--esp-4); font-size: 0.95rem; }
.rsvp__form { max-width: 440px; margin: 0 auto; text-align: left; }
/* Nota bajo el nombre (vista previa: el nombre se llena solo con la lista). */
.rsvp__auto { margin: calc(-1 * var(--esp-2)) 0 var(--esp-3); font-size: .78rem; font-style: italic; color: var(--color-texto-suave); }

.campo { margin-bottom: var(--esp-3); border: none; }
.campo__label {
  display: block; margin-bottom: var(--esp-1);
  font-size: 0.85rem; font-weight: 600; color: var(--color-acento);
}
.campo__input {
  width: 100%; padding: var(--esp-2) var(--esp-3);
  font-family: var(--fuente-texto); font-size: 1rem; color: var(--color-texto);
  background: var(--color-blanco);
  border: 1px solid rgba(0,0,0,0.12); border-radius: var(--radio-sm);
}
.campo__input:focus-visible { outline: 2px solid var(--color-primario); outline-offset: 1px; }

.rsvp__opciones { display: flex; flex-direction: column; gap: var(--esp-2); }
.rsvp__radio { display: flex; align-items: center; gap: var(--esp-2); cursor: pointer; }

.boton {
  display: inline-block; width: 100%;
  padding: var(--esp-3); border: none; border-radius: var(--radio-full);
  background: var(--color-acento); color: var(--color-blanco);
  font-family: var(--fuente-texto); font-size: 1rem; font-weight: 600;
  letter-spacing: 0.05em; cursor: pointer;
  transition: filter var(--transicion), transform var(--transicion);
}
.boton:hover { filter: brightness(0.94); }
.boton:active { transform: translateY(1px); }
.boton:disabled { opacity: 0.6; cursor: default; }

.rsvp__estado { margin-top: var(--esp-3); text-align: center; font-weight: 600; min-height: 1.4em; }
.rsvp__estado--ok { color: var(--color-acento); }
.rsvp__estado--error { color: #b3261e; }

/* =========================================================
   MÚSICA (botón flotante)
   ========================================================= */
.musica {
  position: fixed; bottom: var(--esp-3); right: var(--esp-3); z-index: 40;
  width: 52px; height: 52px; border-radius: var(--radio-full); border: none;
  background: var(--color-acento); color: var(--color-blanco);
  box-shadow: var(--sombra); cursor: pointer;
  display: grid; place-items: center; font-size: 1.4rem;
}
.musica[aria-pressed="true"] .musica__icono { animation: girar 4s linear infinite; }
@keyframes girar { to { transform: rotate(360deg); } }

/* =========================================================
   PIE
   ========================================================= */
.pie {
  text-align: center; padding: var(--esp-6) var(--esp-3) calc(var(--esp-6) + 60px);
  background: var(--color-acento); color: var(--color-secundario);
}
.pie__nombres { font-family: var(--fuente-nombres); font-size: 2rem; }
.pie__fecha { letter-spacing: 0.15em; margin: var(--esp-1) 0 var(--esp-3); opacity: 0.85; }
.pie__credito { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.2em; opacity: 0.6; }

/* =========================================================
   BARRA DE PREVIEW (solo dev, ?preview=1)
   ========================================================= */
.preview {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 60;
  background: rgba(20,18,16,0.95); color: #fff;
  padding: var(--esp-2) var(--esp-3);
  display: flex; gap: var(--esp-4); flex-wrap: wrap; justify-content: center;
  font-family: system-ui, sans-serif;
}
.preview__grupo { display: flex; align-items: center; gap: var(--esp-1); flex-wrap: wrap; }
.preview__etiqueta { font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.1em; opacity: 0.6; margin-right: var(--esp-1); }
.preview__chip {
  background: rgba(255,255,255,0.12); color: #fff; border: 1px solid transparent;
  padding: 4px 10px; border-radius: var(--radio-full); font-size: 0.8rem; cursor: pointer;
}
.preview__chip.is-active { background: #fff; color: #111; }

/* =========================================================
   RESPONSIVE — Tablet / Desktop (mobile-first)
   ========================================================= */
@media (min-width: 768px) {
  /* Galería en PC: grande, centrada y con esquinas suaves. */
  .galeria { padding: var(--esp-7) var(--esp-3); }
  .carrusel { max-width: 900px; margin: 0 auto; border-radius: var(--radio-md); overflow: hidden; box-shadow: var(--sombra); }
  .carrusel__slide img { aspect-ratio: 16 / 10; }
  .contador__item { min-width: 96px; padding: var(--esp-4) var(--esp-3); }
  .contador__num { font-size: 3rem; }
  .evento__mapa iframe { height: 360px; }
  .padrinos__lista { grid-template-columns: 1fr 1fr; }
  .hospedaje__lista { grid-template-columns: 1fr 1fr; }
}

/* =========================================================
   ACCESIBILIDAD — prefers-reduced-motion
   ========================================================= */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after {
    animation: none !important;
    transition: none !important;
  }
  .fade-up { opacity: 1; transform: none; }
}
