/* =========================================================
   PLANTILLA "LIGA DE HÉROES" — cumpleaños infantil, estilo cómic.
   Original (sin marca). Hoja de estilo AUTOCONTENIDA: NO depende de
   base.css/temas.css. Comparte el mismo contrato de datos (clases/IDs/
   data-rol/data-modulo) que el motor (motor.js) ya manipula.
   Mobile-first · accesible · sin dependencias.
   ========================================================= */

:root {
  --rojo:    #e63525;
  --rojo-d:  #c41f10;
  --azul:    #1f5fd0;
  --azul-d:  #173f8c;
  --amarillo:#ffd23e;
  --tinta:   #141a2e;
  --papel:   #fff7ec;
  --blanco:  #ffffff;
  --texto:   #20283f;

  --comic-display: "Bangers", system-ui, cursive;
  --comic-text: "Fredoka", system-ui, -apple-system, sans-serif;

  --esp-1:4px; --esp-2:8px; --esp-3:16px; --esp-4:24px; --esp-5:40px; --esp-6:64px; --esp-7:88px;
  --borde: 3px solid var(--tinta);
  --pop: 6px 6px 0 var(--tinta);
  --pop-sm: 3px 3px 0 var(--tinta);
  --radio: 10px;
  --transicion: .15s ease;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
[hidden] { display: none !important; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--comic-text);
  font-size: 16px; line-height: 1.6;
  color: var(--texto);
  background-color: var(--papel);
  /* trama de medios tonos muy tenue en toda la página */
  background-image: radial-gradient(var(--azul) 1.4px, transparent 1.5px);
  background-size: 16px 16px;
  background-attachment: fixed;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  /* leve deriva de la trama de medios tonos */
  animation: trama-deriva 24s linear infinite;
}
@keyframes trama-deriva {
  0%   { background-position: 0 0; }
  100% { background-position: 32px 32px; }
}
img { max-width: 100%; display: block; }
iframe { border: 0; }

/* Reveal al hacer scroll */
.fade-up { opacity: 0; transform: translateY(22px); transition: opacity .6s ease, transform .6s ease; }
.fade-up.is-visible { opacity: 1; transform: none; }

/* =========================================================
   HERO — portada de cómic
   ========================================================= */
.hero {
  position: relative; isolation: isolate;
  min-height: 100svh;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center; text-align: center;
  padding: var(--esp-6) var(--esp-3);
  background: var(--azul);
  color: var(--blanco);
  overflow: hidden;
}
/* estallido de rayos (sunburst) */
.hero::before {
  content: ""; position: absolute; inset: -20%; z-index: -2;
  background: repeating-conic-gradient(from 0deg at 50% 40%,
    var(--azul) 0 6deg, var(--azul-d) 6deg 12deg);
  animation: girar-lento 90s linear infinite;
}
/* viñeta + medios tonos sobre el estallido */
.hero::after {
  content: ""; position: absolute; inset: 0; z-index: -1; pointer-events: none;
  background:
    radial-gradient(circle at 50% 38%, transparent 38%, rgba(10,14,30,.55) 100%),
    radial-gradient(rgba(255,255,255,.16) 1.5px, transparent 1.6px);
  background-size: 100% 100%, 14px 14px;
}
.hero__overlay { display: none; } /* el motor/markup puede traerlo; aquí no se usa */

.hero__contenido { position: relative; display: flex; flex-direction: column; align-items: center; }

/* emblema con la inicial (lo llena motor.js → data-rol="hero-sello") */
.emblema {
  width: 76px; height: 76px; margin-bottom: var(--esp-3);
  display: grid; place-items: center;
  background: var(--amarillo); color: var(--tinta);
  border: var(--borde); border-radius: 50%;
  box-shadow: var(--pop-sm), inset 0 0 0 4px var(--blanco);
  font-family: var(--comic-display); font-size: 2.4rem; line-height: 1;
  transform: rotate(-4deg);
}
.emblema:empty { display: none; }
/* el emblema late suave (vida cómic) */
.emblema { animation: emblema-late 2.6s ease-in-out infinite; }
@keyframes emblema-late {
  0%, 100% { transform: rotate(-4deg) scale(1); }
  50%      { transform: rotate(-4deg) scale(1.08); box-shadow: var(--pop), inset 0 0 0 4px var(--blanco); }
}

.hero__intro {
  display: inline-block;
  font-family: var(--comic-display); font-size: clamp(1.1rem, 5vw, 1.6rem);
  letter-spacing: 1px; color: var(--tinta);
  background: var(--amarillo); border: var(--borde); border-radius: 8px;
  padding: .1em .7em; box-shadow: var(--pop-sm);
  transform: rotate(-2deg);
}
.hero__nombres {
  font-family: var(--comic-display); font-weight: 400;
  font-size: clamp(3.6rem, 19vw, 7.5rem); line-height: .92;
  letter-spacing: 2px; color: var(--amarillo);
  margin: var(--esp-4) 0 var(--esp-3);
  -webkit-text-stroke: 3px var(--tinta);
  paint-order: stroke fill;
  text-shadow: 4px 4px 0 var(--rojo), 8px 8px 0 var(--tinta);
  transform: rotate(-3deg);
}
.hero__amp { display: block; font-size: .4em; color: var(--blanco); }
.hero__sub {
  font-family: var(--comic-text); font-weight: 600;
  font-size: clamp(1rem, 4.4vw, 1.25rem);
  color: var(--blanco); text-shadow: 2px 2px 0 var(--tinta);
  margin-bottom: var(--esp-4);
}
/* fecha en banner */
.hero__fecha {
  display: inline-block; font-family: var(--comic-text); font-weight: 700;
  font-size: clamp(.95rem, 4vw, 1.15rem); letter-spacing: 1px;
  color: var(--blanco); background: var(--rojo);
  border: var(--borde); border-radius: 8px;
  padding: .35em .9em; box-shadow: var(--pop-sm);
}
.hero__scroll {
  margin-top: var(--esp-5);
  font-family: var(--comic-display); font-size: 1.2rem; letter-spacing: 1px;
  color: var(--amarillo); text-decoration: none; text-shadow: 2px 2px 0 var(--tinta);
}
.hero__flecha { display: inline-block; animation: rebote 1.6s infinite; }
@keyframes rebote { 0%,100%{transform:translateY(0)} 50%{transform:translateY(7px)} }
@keyframes girar-lento { to { transform: rotate(360deg); } }

/* =========================================================
   ESTRUCTURA GENERAL — paneles de cómic
   ========================================================= */
main { padding: var(--esp-5) var(--esp-3) var(--esp-6); }
.panel {
  position: relative;
  max-width: 560px; margin: 0 auto var(--esp-5);
  background: var(--blanco);
  border: var(--borde); border-radius: var(--radio);
  box-shadow: var(--pop);
  padding: var(--esp-5) var(--esp-4);
  text-align: center;
}
/* trama de medios tonos en una esquina del panel */
.panel::after {
  content: ""; position: absolute; top: 10px; right: 10px;
  width: 54px; height: 54px; border-radius: 6px; pointer-events: none;
  background-image: radial-gradient(var(--rojo) 2px, transparent 2.2px);
  background-size: 9px 9px; opacity: .3;
}
.galeria.panel { padding-left: 0; padding-right: 0; overflow: hidden; }

/* título de sección = caja de rótulo (caption box) */
.seccion__titulo {
  display: inline-block;
  font-family: var(--comic-display); font-weight: 400;
  font-size: clamp(1.8rem, 7vw, 2.6rem); letter-spacing: 1px; line-height: 1.05;
  color: var(--tinta); background: var(--amarillo);
  border: var(--borde); border-radius: 8px;
  padding: .12em .55em; box-shadow: var(--pop-sm);
  transform: rotate(-1.5deg);
  margin-bottom: var(--esp-4);
}
/* el divisor del esqueleto no se usa en esta plantilla */
.divisor { display: none; }

/* =========================================================
   BIENVENIDA
   ========================================================= */
.bienvenida { text-align: center; }
.bienvenida__titulo {
  display: inline-block;
  font-family: var(--comic-display); font-size: clamp(2rem, 8vw, 3rem);
  color: var(--blanco); background: var(--rojo);
  border: var(--borde); border-radius: 8px; padding: .1em .5em;
  box-shadow: var(--pop-sm); transform: rotate(-2deg);
  text-shadow: 2px 2px 0 var(--tinta); margin-bottom: var(--esp-3);
}
.bienvenida__texto {
  max-width: 480px; margin: 0 auto; font-size: 1.12rem; font-weight: 500;
  color: var(--texto);
}

/* =========================================================
   CUENTA REGRESIVA — fichas
   ========================================================= */
.contador__lista { list-style: none; display: flex; gap: var(--esp-2); justify-content: center; flex-wrap: wrap; }
.contador__item {
  background: var(--azul); color: var(--blanco);
  border: var(--borde); border-radius: 8px; box-shadow: var(--pop-sm);
  min-width: 66px; padding: var(--esp-2) var(--esp-2) var(--esp-1);
}
.contador__num {
  display: block; font-family: var(--comic-display); font-size: clamp(1.9rem, 8vw, 2.6rem);
  line-height: 1; color: var(--amarillo);
  -webkit-text-stroke: 1.5px var(--tinta); paint-order: stroke fill;
}
.contador__label {
  display: block; margin-top: 2px; font-family: var(--comic-text); font-weight: 600;
  font-size: .62rem; text-transform: uppercase; letter-spacing: .1em; color: var(--blanco);
}

/* =========================================================
   EVENTO (La gran fiesta) + MAPA
   ========================================================= */
.evento__hora {
  display: inline-block; font-family: var(--comic-text); font-weight: 700;
  font-size: 1rem; letter-spacing: .04em; color: var(--blanco);
  background: var(--azul); border: var(--borde); border-radius: 6px;
  padding: .15em .6em; box-shadow: var(--pop-sm); margin-bottom: var(--esp-3);
}
.evento__lugar { font-family: var(--comic-display); font-size: clamp(1.6rem, 6vw, 2.2rem); color: var(--rojo); line-height: 1.05; -webkit-text-stroke: .8px var(--tinta); paint-order: stroke fill; }
.evento__direccion { font-weight: 500; color: var(--texto); margin: var(--esp-2) 0 var(--esp-4); }
.evento__mapa { border: var(--borde); border-radius: 8px; overflow: hidden; box-shadow: var(--pop-sm); }
.evento__mapa iframe { width: 100%; height: 280px; display: block; }
.boton-accion, .evento__boton, .mesa-regalos__link, .hospedaje__link {
  display: inline-block; margin-top: var(--esp-4);
  font-family: var(--comic-display); font-size: 1.1rem; letter-spacing: 1px;
  color: var(--blanco); background: var(--rojo); text-decoration: none;
  border: var(--borde); border-radius: 8px; padding: .3em .9em;
  box-shadow: var(--pop-sm); transition: transform var(--transicion), box-shadow var(--transicion);
}
.boton-accion:hover, .evento__boton:hover, .mesa-regalos__link:hover, .hospedaje__link:hover { transform: translate(-1px,-1px); box-shadow: 5px 5px 0 var(--tinta); }
.boton-accion:active, .evento__boton:active, .mesa-regalos__link:active, .hospedaje__link:active { transform: translate(2px,2px); box-shadow: 1px 1px 0 var(--tinta); }

/* =========================================================
   ITINERARIO — "plan de la misión" numerado
   ========================================================= */
.itinerario__lista { list-style: none; max-width: 440px; margin: 0 auto; text-align: left; counter-reset: mis; }
.itinerario__item {
  display: grid; grid-template-columns: 40px 86px 1fr; align-items: center; gap: var(--esp-2);
  padding: var(--esp-3) 0; border-bottom: 2px dashed var(--azul);
}
.itinerario__item:last-child { border-bottom: none; }
.itinerario__item::before {
  counter-increment: mis; content: counter(mis);
  width: 34px; height: 34px; display: grid; place-items: center;
  font-family: var(--comic-display); font-size: 1.2rem; color: var(--tinta);
  background: var(--amarillo); border: var(--borde); border-radius: 50%;
  box-shadow: var(--pop-sm);
}
.itinerario__hora { font-family: var(--comic-display); font-size: 1.15rem; color: var(--azul); }
.itinerario__actividad { font-weight: 500; color: var(--texto); }

/* =========================================================
   DRESS CODE — "tu disfraz"
   ========================================================= */
.dress-code__descripcion { max-width: 460px; margin: 0 auto var(--esp-4); font-weight: 500; }
.dress-code__colores { display: flex; flex-wrap: wrap; gap: var(--esp-2); justify-content: center; }
.dress-code__color { width: 42px; height: 42px; border-radius: 50%; border: var(--borde); box-shadow: var(--pop-sm); display: inline-block; }

/* =========================================================
   MESA DE REGALOS
   ========================================================= */
.mesa-regalos__mensaje { max-width: 460px; margin: 0 auto var(--esp-4); font-weight: 500; }
.mesa-regalos__lista { display: flex; flex-wrap: wrap; gap: var(--esp-3); justify-content: center; }
.mesa-regalos__link { margin-top: 0; background: var(--azul); }

/* =========================================================
   GALERÍA — tira de cómic
   ========================================================= */
.galeria { }
.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 86%; scroll-snap-align: center; padding: 0 var(--esp-1); }
.carrusel__slide img { width: 100%; aspect-ratio: 4/5; object-fit: cover; border: var(--borde); border-radius: 8px; box-shadow: var(--pop-sm); cursor: zoom-in; }
.carrusel__nav {
  position: absolute; top: 50%; transform: translateY(-50%); z-index: 2;
  width: 44px; height: 44px; border-radius: 50%; border: var(--borde);
  background: var(--amarillo); color: var(--tinta); font-family: var(--comic-display); font-size: 1.5rem; line-height: 1;
  cursor: pointer; display: grid; place-items: center; box-shadow: var(--pop-sm);
}
.carrusel__nav--prev { left: 8px; }
.carrusel__nav--next { right: 8px; }
.carrusel__dots { display: flex; justify-content: center; gap: 8px; margin-top: var(--esp-4); }
.carrusel__dot { width: 12px; height: 12px; border: 2px solid var(--tinta); background: var(--blanco); border-radius: 50%; padding: 0; cursor: pointer; }
.carrusel__dot.is-active { background: var(--rojo); }

/* Lightbox */
.lightbox { position: fixed; inset: 0; z-index: 50; display: flex; align-items: center; justify-content: center; background: rgba(10,14,30,.92); 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: var(--borde); border-radius: 8px; }
.lightbox__cerrar { position: absolute; top: var(--esp-3); right: var(--esp-3); background: var(--amarillo); border: var(--borde); border-radius: 50%; width: 44px; height: 44px; color: var(--tinta); font-size: 1.6rem; cursor: pointer; line-height: 1; }
.lightbox__nav { position: absolute; top: 50%; transform: translateY(-50%); background: var(--amarillo); border: var(--borde); border-radius: 50%; width: 44px; height: 44px; color: var(--tinta); font-size: 1.6rem; cursor: pointer; }
.lightbox__nav--prev { left: var(--esp-2); }
.lightbox__nav--next { right: var(--esp-2); }

/* =========================================================
   RSVP — "¿aceptas la misión?"
   ========================================================= */
.rsvp__nota { font-weight: 500; color: var(--texto); margin-bottom: var(--esp-4); }
.rsvp__form { max-width: 420px; margin: 0 auto; text-align: left; }
.rsvp__auto { margin: calc(-1 * var(--esp-2)) 0 var(--esp-3); font-size: .82rem; font-weight: 500; color: var(--azul); }
.campo { margin-bottom: var(--esp-3); border: none; }
.campo__label { display: block; margin-bottom: var(--esp-1); font-family: var(--comic-text); font-weight: 700; font-size: .9rem; color: var(--tinta); }
.campo__input {
  width: 100%; padding: var(--esp-2) var(--esp-3); font-family: var(--comic-text); font-size: 1rem; color: var(--texto);
  background: var(--papel); border: var(--borde); border-radius: 8px;
}
.campo__input:focus-visible { outline: 3px solid var(--azul); 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; font-weight: 500; }
.rsvp__radio input { accent-color: var(--rojo); width: 18px; height: 18px; }
.boton {
  display: block; width: 100%; margin-top: var(--esp-3);
  font-family: var(--comic-display); font-size: 1.5rem; letter-spacing: 1px;
  color: var(--blanco); background: var(--rojo);
  border: var(--borde); border-radius: var(--radio); padding: .4em;
  box-shadow: var(--pop); cursor: pointer;
  transition: transform var(--transicion), box-shadow var(--transicion);
}
.boton:hover { transform: translate(-1px,-1px); }
.boton:active { transform: translate(3px,3px); box-shadow: 2px 2px 0 var(--tinta); }
.boton:disabled { opacity: .6; cursor: default; }
.rsvp__estado { margin-top: var(--esp-3); text-align: center; font-weight: 700; min-height: 1.4em; }
.rsvp__estado--ok { color: var(--azul); }
.rsvp__estado--error { color: var(--rojo-d); }

/* =========================================================
   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: 50%; border: var(--borde); background: var(--amarillo); color: var(--tinta); box-shadow: var(--pop-sm); cursor: pointer; display: grid; place-items: center; font-size: 1.4rem; }
.musica[aria-pressed="true"] .musica__icono { animation: girar 3s linear infinite; }
@keyframes girar { to { transform: rotate(360deg); } }

/* =========================================================
   PIE — colofón de cómic
   ========================================================= */
.pie {
  text-align: center; padding: var(--esp-6) var(--esp-3) calc(var(--esp-6) + 60px);
  background: var(--tinta); color: var(--blanco);
  background-image: radial-gradient(rgba(255,255,255,.10) 1.5px, transparent 1.6px);
  background-size: 14px 14px;
}
.pie__nombres { font-family: var(--comic-display); font-size: 2.6rem; color: var(--amarillo); -webkit-text-stroke: 2px #000; paint-order: stroke fill; letter-spacing: 1px; }
.pie__fecha { font-family: var(--comic-text); font-weight: 600; letter-spacing: .04em; margin: var(--esp-2) 0 var(--esp-3); }
.pie__credito { font-family: var(--comic-display); font-size: 1.1rem; letter-spacing: 1px; color: var(--rojo); }

/* =========================================================
   BARRA DE PREVIEW (dev)
   ========================================================= */
.preview { position: fixed; bottom: 0; left: 0; right: 0; z-index: 60; background: rgba(20,18,16,.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__chip { background: rgba(255,255,255,.12); color: #fff; border: 1px solid transparent; padding: 4px 10px; border-radius: 999px; font-size: .8rem; cursor: pointer; }
.preview__chip.is-active { background: #fff; color: #111; }

/* =========================================================
   ESTALLIDOS DE ACCIÓN — "POW! / ZAP! / BOOM!"
   Markup decorativo (aria-hidden) en los paneles. Aparecen con
   POP (scale + rotación) cuando la sección entra (.fade-up.is-visible).
   ========================================================= */
.estallido {
  position: absolute; z-index: 3; pointer-events: none;
  display: grid; place-items: center;
  width: 84px; height: 84px;
  font-family: var(--comic-display); font-weight: 400; line-height: 1;
  font-size: 1.45rem; letter-spacing: .5px; text-align: center;
  color: var(--amarillo); background: var(--rojo);
  border: var(--borde);
  -webkit-text-stroke: 1px var(--tinta); paint-order: stroke fill;
  text-shadow: 1.5px 1.5px 0 var(--tinta);
  /* forma de estrella/estallido recortada */
  clip-path: polygon(50% 0%, 61% 22%, 86% 13%, 78% 39%, 100% 50%, 78% 61%, 86% 87%, 61% 78%, 50% 100%, 39% 78%, 14% 87%, 22% 61%, 0% 50%, 22% 39%, 14% 13%, 39% 22%);
  /* estado de reposo: oculto y "desinflado" hasta que la sección se revela */
  opacity: 0; transform: scale(.2) rotate(-18deg);
  transition: opacity .35s ease, transform .45s cubic-bezier(.34, 1.56, .64, 1);
}
.estallido--azul     { background: var(--azul);     color: var(--blanco); }
.estallido--amarillo { background: var(--amarillo); color: var(--tinta); text-shadow: 1.5px 1.5px 0 var(--blanco); }
/* posiciones (se asoman fuera del panel, contenidas por overflow-x del body) */
.estallido--tl { top: -26px; left: -18px; }
.estallido--tr { top: -22px; right: -14px; }
.estallido--br { bottom: -24px; right: -10px; }
.estallido--bl { bottom: -22px; left: -14px; }
.estallido--sm { width: 64px; height: 64px; font-size: 1.05rem; }
/* POP al revelar la sección */
.fade-up.is-visible .estallido {
  opacity: 1;
  transform: scale(1) rotate(var(--giro, -8deg));
  animation: estallido-vibra 2.8s ease-in-out .5s infinite;
}
.estallido--tr, .estallido--br { --giro: 7deg; }
@keyframes estallido-vibra {
  0%, 92%, 100% { transform: scale(1) rotate(var(--giro, -8deg)); }
  95%           { transform: scale(1.1) rotate(calc(var(--giro, -8deg) - 4deg)); }
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (min-width: 768px) {
  main { padding-top: var(--esp-6); }
  .panel { max-width: 620px; padding: var(--esp-6) var(--esp-5); }
  .carrusel__slide { flex: 0 0 60%; }
  .carrusel__slide img { aspect-ratio: 16/10; }
  .evento__mapa iframe { height: 340px; }
}

/* =========================================================
   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; }
  .emblema { transform: rotate(-4deg); }
  /* los estallidos quedan visibles y quietos (POW estáticos) */
  .estallido { opacity: 1; transform: scale(1) rotate(var(--giro, -8deg)); }
}
