/* ================================================================
   PRODUCCIONES INTERFAZ — Campaña Mundial 2026 (campaign.css)
   Landing cinematográfica · renta pantallas LED · Monterrey
   Prefijo .mun- para evitar colisiones con el ecommerce.
   ================================================================ */

.mun-page {
  --mun-red: #e50914;
  --mun-gold: #ffc24b;
  background: #060606;
  color: #fff;
  overflow: hidden;
}

/* ── Reveal (self-contained, init en campaign.js) ────────────── */
.mun-page .reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.7s cubic-bezier(0.22,1,0.36,1), transform 0.7s cubic-bezier(0.22,1,0.36,1);
  will-change: opacity, transform;
}
.mun-page .reveal.visible {
  opacity: 1;
  transform: none;
}
@media (prefers-reduced-motion: reduce) {
  .mun-page .reveal { opacity: 1; transform: none; transition: none; }
}

/* ════════════════════════════════════════════════════════════
   HERO CINEMATOGRÁFICO
   ════════════════════════════════════════════════════════════ */
.mun-hero {
  position: relative;
  min-height: 100vh;
  min-height: 100svh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: calc(var(--nav-h, 110px) + 40px) 24px 80px;
  overflow: hidden;
}
.mun-hero-media { position: absolute; inset: 0; z-index: 0; }
.mun-hero-img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  opacity: 0.42;
  transform: scale(1.08);
  animation: munKenBurns 26s ease-in-out infinite alternate;
}
@keyframes munKenBurns {
  from { transform: scale(1.08) translate(0, 0); }
  to   { transform: scale(1.18) translate(-1.5%, -2%); }
}
/* Fallback cuando la imagen falla */
.mun-hero-media.mun-noimg {
  background:
    radial-gradient(ellipse 70% 60% at 30% 20%, rgba(229,9,20,0.28), transparent 60%),
    radial-gradient(ellipse 60% 60% at 80% 80%, rgba(10,127,212,0.22), transparent 60%),
    #070707;
}

/* LED pixel grid sutil */
.mun-hero-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px);
  background-size: 26px 26px;
  mask-image: radial-gradient(ellipse at center, black 30%, transparent 78%);
  -webkit-mask-image: radial-gradient(ellipse at center, black 30%, transparent 78%);
  animation: munGridDrift 30s linear infinite;
  opacity: 0.6;
}
@keyframes munGridDrift {
  from { background-position: 0 0; }
  to   { background-position: 26px 26px; }
}

/* Haces de luz tipo escenario */
.mun-hero-beam {
  position: absolute;
  top: -30%;
  width: 50vw; height: 120%;
  filter: blur(40px);
  opacity: 0.5;
  pointer-events: none;
  mix-blend-mode: screen;
}
.mun-beam-1 {
  left: -10%;
  background: radial-gradient(ellipse 40% 60% at 50% 0%, rgba(229,9,20,0.5), transparent 70%);
  transform: rotate(14deg);
  animation: munBeam 9s ease-in-out infinite alternate;
}
.mun-beam-2 {
  right: -10%;
  background: radial-gradient(ellipse 40% 60% at 50% 0%, rgba(255,194,75,0.4), transparent 70%);
  transform: rotate(-14deg);
  animation: munBeam 11s ease-in-out infinite alternate-reverse;
}
@keyframes munBeam {
  from { opacity: 0.32; transform: translateX(-4%) rotate(14deg); }
  to   { opacity: 0.6;  transform: translateX(4%) rotate(10deg); }
}

.mun-hero-vignette {
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(6,6,6,0.55) 0%, rgba(6,6,6,0.15) 35%, rgba(6,6,6,0.7) 80%, #060606 100%);
}

.mun-hero-inner { position: relative; z-index: 2; max-width: 920px; }

.mun-badge {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 8px 16px;
  border-radius: 100px;
  background: rgba(229,9,20,0.12);
  border: 1px solid rgba(229,9,20,0.32);
  backdrop-filter: blur(10px);
  font-family: var(--font-condensed, sans-serif);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #fff;
  margin-bottom: 26px;
}
.mun-badge-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--mun-red);
  box-shadow: 0 0 10px var(--mun-red);
  animation: munPulse 1.8s ease-in-out infinite;
}
@keyframes munPulse { 0%,100%{opacity:1;transform:scale(1);} 50%{opacity:0.4;transform:scale(0.7);} }

.mun-hero-title {
  font-family: var(--font-display, 'Bebas Neue', sans-serif);
  font-size: clamp(48px, 9vw, 124px);
  line-height: 0.92;
  letter-spacing: 0.01em;
  text-transform: uppercase;
  margin: 0 0 22px;
  text-shadow: 0 8px 50px rgba(0,0,0,0.6);
}
.mun-accent {
  background: linear-gradient(120deg, #ff2030 0%, #e50914 50%, #ffc24b 120%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  filter: drop-shadow(0 0 28px rgba(229,9,20,0.4));
}
.mun-hero-sub {
  font-size: clamp(15px, 2vw, 19px);
  line-height: 1.6;
  color: rgba(255,255,255,0.78);
  max-width: 680px;
  margin: 0 auto 34px;
}
.mun-hero-sub strong { color: #fff; font-weight: 700; }

.mun-hero-ctas {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  justify-content: center;
  margin-bottom: 30px;
}

/* Botones */
.mun-btn {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 14px 26px;
  border: none;
  border-radius: 12px;
  font-family: var(--font-condensed, sans-serif);
  font-size: 15px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
  transition: transform 0.16s ease, box-shadow 0.25s ease, filter 0.2s ease, background 0.2s ease;
}
.mun-btn-lg { padding: 16px 32px; font-size: 16px; }
.mun-btn-primary {
  background: linear-gradient(135deg, #e50914, #b0060f);
  color: #fff;
  box-shadow: 0 8px 30px rgba(229,9,20,0.45);
}
.mun-btn-primary:hover { transform: translateY(-2px); box-shadow: 0 12px 40px rgba(229,9,20,0.6); filter: brightness(1.08); }
.mun-btn-wa {
  background: #25d366;
  color: #053;
  box-shadow: 0 8px 26px rgba(37,211,102,0.35);
}
.mun-btn-wa:hover { transform: translateY(-2px); background: #2eea73; }
.mun-btn-ghost {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.2);
  color: #fff;
  backdrop-filter: blur(8px);
}
.mun-btn-ghost:hover { background: rgba(255,255,255,0.13); transform: translateY(-2px); }

.mun-hero-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 16px;
  justify-content: center;
  font-size: 13px;
  color: rgba(255,255,255,0.55);
  font-family: var(--font-condensed, sans-serif);
  letter-spacing: 0.03em;
}

.mun-scroll-cue {
  position: absolute;
  bottom: 26px; left: 50%;
  transform: translateX(-50%);
  width: 26px; height: 42px;
  border: 2px solid rgba(255,255,255,0.25);
  border-radius: 16px;
  z-index: 2;
}
.mun-scroll-cue span {
  position: absolute;
  top: 8px; left: 50%;
  width: 4px; height: 8px;
  margin-left: -2px;
  background: #fff;
  border-radius: 2px;
  animation: munScroll 1.8s ease-in-out infinite;
}
@keyframes munScroll { 0%{opacity:0;transform:translateY(0);} 40%{opacity:1;} 80%{opacity:0;transform:translateY(14px);} 100%{opacity:0;} }

/* ════════════════════════════════════════════════════════════
   MANIFIESTO
   ════════════════════════════════════════════════════════════ */
.mun-manifesto {
  max-width: 860px;
  margin: 0 auto;
  padding: 90px 24px 70px;
  text-align: center;
}
.mun-mani-eyebrow, .mun-eyebrow {
  font-family: var(--font-condensed, sans-serif);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--mun-red);
  margin: 0 0 14px;
}
.mun-mani-title {
  font-family: var(--font-display, sans-serif);
  font-size: clamp(30px, 5vw, 56px);
  line-height: 1.02;
  text-transform: uppercase;
  margin: 0 0 22px;
}
.mun-mani-text {
  font-size: clamp(15px, 1.8vw, 18px);
  line-height: 1.7;
  color: rgba(255,255,255,0.62);
  max-width: 680px;
  margin: 0 auto;
}

/* ════════════════════════════════════════════════════════════
   SECCIONES GENÉRICAS
   ════════════════════════════════════════════════════════════ */
.mun-section { max-width: 1240px; margin: 0 auto; padding: 40px 32px 70px; }
.mun-section-head { text-align: center; margin-bottom: 44px; }
.mun-h2 {
  font-family: var(--font-display, sans-serif);
  font-size: clamp(32px, 5vw, 60px);
  line-height: 1;
  text-transform: uppercase;
  margin: 0 0 14px;
}
.mun-section-sub {
  font-size: 15px;
  color: rgba(255,255,255,0.5);
  max-width: 560px;
  margin: 0 auto;
  line-height: 1.6;
}

/* ── Experiencias grid ──────────────────────────────────────── */
.mun-exp-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(266px, 1fr));
  gap: 16px;
}
.mun-exp-card {
  position: relative;
  display: block;
  height: 280px;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.08);
  background: #131313;
  cursor: pointer;
  text-align: left;
  padding: 0;
  isolation: isolate;
  transition: transform 0.45s cubic-bezier(0.22,1,0.36,1), box-shadow 0.45s ease, border-color 0.3s ease;
}
.mun-exp-card img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  z-index: 0;
  opacity: 0.78;
  transform: scale(1.05);
  transition: transform 0.8s cubic-bezier(0.22,1,0.36,1), opacity 0.4s ease;
}
.mun-exp-card.mun-noimg {
  background:
    radial-gradient(ellipse 90% 70% at 70% 10%, rgba(229,9,20,0.22), transparent 60%),
    linear-gradient(160deg, #1c1c1c, #0e0e0e);
}
.mun-exp-shade {
  position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(180deg, rgba(6,6,6,0.1) 0%, rgba(6,6,6,0.25) 45%, rgba(6,6,6,0.92) 100%);
  transition: background 0.4s ease;
}
.mun-exp-body {
  position: absolute; left: 0; right: 0; bottom: 0; z-index: 2;
  padding: 20px;
  transition: transform 0.4s cubic-bezier(0.22,1,0.36,1);
}
.mun-exp-body h3 {
  font-family: var(--font-display, sans-serif);
  font-size: 27px;
  line-height: 1;
  text-transform: uppercase;
  margin: 0 0 5px;
}
.mun-exp-body p {
  font-size: 13px;
  color: rgba(255,255,255,0.66);
  line-height: 1.4;
  margin: 0;
}
.mun-exp-cta {
  display: block;
  z-index: 3;
  font-family: var(--font-condensed, sans-serif);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--mun-gold);
  opacity: 0;
  max-height: 0;
  margin-top: 0;
  overflow: hidden;
  transition: opacity 0.3s ease, max-height 0.35s ease, margin-top 0.35s ease;
}
.mun-exp-card:hover { transform: translateY(-6px); border-color: rgba(229,9,20,0.4); box-shadow: 0 26px 60px rgba(0,0,0,0.6); }
.mun-exp-card:hover img { transform: scale(1.13); opacity: 0.9; }
.mun-exp-card:hover .mun-exp-cta { opacity: 1; max-height: 24px; margin-top: 9px; }
@media (hover: none) {
  .mun-exp-cta { opacity: 1; max-height: 24px; margin-top: 9px; }
}

/* ── Paquetes / tamaños LED ─────────────────────────────────── */
.mun-pkg-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  align-items: stretch;
}
.mun-pkg {
  position: relative;
  display: flex;
  flex-direction: column;
  padding: 28px 24px 26px;
  border-radius: 20px;
  background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.015));
  border: 1px solid rgba(255,255,255,0.08);
  transition: transform 0.4s cubic-bezier(0.22,1,0.36,1), border-color 0.3s ease, box-shadow 0.4s ease;
}
.mun-pkg:hover {
  transform: translateY(-6px);
  border-color: rgba(255,255,255,0.16);
  box-shadow: 0 26px 60px rgba(0,0,0,0.5);
}
.mun-pkg-feat {
  border-color: rgba(229,9,20,0.45);
  background:
    radial-gradient(ellipse 90% 60% at 50% 0%, rgba(229,9,20,0.14), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.02));
  box-shadow: 0 20px 50px rgba(229,9,20,0.18);
}
.mun-pkg-feat:hover {
  border-color: rgba(229,9,20,0.7);
  box-shadow: 0 30px 70px rgba(229,9,20,0.28);
}
.mun-pkg-ribbon {
  position: absolute;
  top: 0; left: 50%;
  transform: translate(-50%, -50%);
  padding: 5px 16px;
  border-radius: 100px;
  background: linear-gradient(135deg, #e50914, #ff2030);
  color: #fff;
  font-family: var(--font-condensed, sans-serif);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  white-space: nowrap;
  box-shadow: 0 6px 20px rgba(229,9,20,0.5);
}
.mun-pkg-head { margin-bottom: 18px; }
.mun-pkg-tag {
  display: inline-block;
  font-family: var(--font-display, sans-serif);
  font-size: 30px;
  line-height: 1;
  text-transform: uppercase;
  color: #fff;
}
.mun-pkg-feat .mun-pkg-tag { color: var(--mun-gold); }
.mun-pkg-ideal {
  margin: 8px 0 0;
  font-size: 13px;
  color: rgba(255,255,255,0.55);
  line-height: 1.4;
}
.mun-pkg-size {
  display: flex;
  align-items: baseline;
  gap: 10px;
  padding: 16px 0;
  margin-bottom: 18px;
  border-top: 1px solid rgba(255,255,255,0.08);
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.mun-pkg-dim {
  font-family: var(--font-display, sans-serif);
  font-size: clamp(34px, 4vw, 46px);
  line-height: 1;
  background: linear-gradient(180deg, #fff 35%, rgba(255,255,255,0.55));
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.mun-pkg-unit {
  font-family: var(--font-condensed, sans-serif);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.45);
}
.mun-pkg-specs {
  list-style: none;
  margin: 0 0 18px;
  padding: 0;
  display: grid;
  gap: 9px;
}
.mun-pkg-specs li {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  font-size: 13px;
}
.mun-pkg-k { color: rgba(255,255,255,0.5); }
.mun-pkg-v { color: #fff; font-weight: 600; text-align: right; }
.mun-pkg-feats {
  list-style: none;
  margin: 0 0 22px;
  padding: 0;
  display: grid;
  gap: 10px;
  flex: 1 1 auto;
}
.mun-pkg-feats li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13.5px;
  color: rgba(255,255,255,0.78);
  line-height: 1.35;
}
.mun-pkg-feats .mun-check { width: 22px; height: 22px; font-size: 11px; }
.mun-pkg-cta { width: 100%; justify-content: center; }
.mun-pkg-note {
  text-align: center;
  margin: 34px auto 0;
  max-width: 620px;
  font-size: 14px;
  color: rgba(255,255,255,0.5);
  line-height: 1.6;
}
.mun-pkg-note a { color: var(--mun-gold); text-decoration: none; font-weight: 600; }
.mun-pkg-note a:hover { text-decoration: underline; }

/* ── Check icon (compartido por paquetes) ───────────────────── */
.mun-check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px; height: 26px;
  flex-shrink: 0;
  border-radius: 50%;
  background: rgba(229,9,20,0.16);
  border: 1px solid rgba(229,9,20,0.4);
  color: #ff5a63;
  font-weight: 700;
  font-size: 13px;
}

/* ── Stats ──────────────────────────────────────────────────── */
.mun-stats {
  max-width: 1000px;
  margin: 70px auto;
  padding: 0 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 18px;
  flex-wrap: wrap;
}
.mun-stat { text-align: center; min-width: 120px; }
.mun-stat-n {
  display: block;
  font-family: var(--font-display, sans-serif);
  font-size: clamp(36px, 5vw, 58px);
  line-height: 1;
  background: linear-gradient(180deg, #fff 30%, rgba(255,255,255,0.5));
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.mun-stat-l {
  display: block;
  margin-top: 6px;
  font-family: var(--font-condensed, sans-serif);
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.45);
}
.mun-stat-div { width: 1px; height: 44px; background: rgba(255,255,255,0.12); }

/* ── CTA final ──────────────────────────────────────────────── */
.mun-final {
  position: relative;
  padding: 90px 24px 100px;
  text-align: center;
  overflow: hidden;
}
.mun-final-bg {
  position: absolute; inset: 0; z-index: 0;
  background:
    radial-gradient(ellipse 60% 80% at 50% 120%, rgba(229,9,20,0.3), transparent 60%),
    radial-gradient(ellipse 50% 60% at 15% 0%, rgba(255,194,75,0.1), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,0.02), transparent);
}
.mun-final-inner { position: relative; z-index: 1; max-width: 760px; margin: 0 auto; }
.mun-final-title {
  font-family: var(--font-display, sans-serif);
  font-size: clamp(34px, 6vw, 72px);
  line-height: 0.98;
  text-transform: uppercase;
  margin: 0 0 18px;
}
.mun-final-sub {
  font-size: clamp(15px, 1.8vw, 18px);
  line-height: 1.65;
  color: rgba(255,255,255,0.66);
  max-width: 580px;
  margin: 0 auto 32px;
}
.mun-final .mun-hero-ctas { margin-bottom: 26px; }
.mun-final-loc {
  font-size: 12px;
  color: rgba(255,255,255,0.32);
  letter-spacing: 0.04em;
  max-width: 600px;
  margin: 0 auto;
  line-height: 1.5;
}

/* ════════════════════════════════════════════════════════════
   NAV — link destacado de campaña
   ════════════════════════════════════════════════════════════ */
.nav-mundial-link {
  position: relative;
  color: #fff !important;
}
.nav-mundial-badge {
  display: inline-block;
  margin-left: 6px;
  padding: 2px 7px;
  border-radius: 5px;
  background: linear-gradient(135deg, #e50914, #ff2030);
  color: #fff !important;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.5px;
  vertical-align: middle;
  box-shadow: 0 0 12px rgba(229,9,20,0.5);
  animation: munPulse 2.4s ease-in-out infinite;
}

/* ════════════════════════════════════════════════════════════
   HOME — ANUNCIO MUNDIAL 2026 (banda cinematográfica)
   ════════════════════════════════════════════════════════════ */
.hmun {
  position: relative;
  margin: 56px auto;
  max-width: 1240px;
  border-radius: 28px;
  overflow: hidden;
  isolation: isolate;
  background: #070707;
  border: 1px solid rgba(229,9,20,0.22);
  box-shadow: 0 30px 80px rgba(0,0,0,0.45);
}
.hmun-media { position: absolute; inset: 0; z-index: 0; }
.hmun-img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  opacity: 0.5;
  transform: scale(1.06);
  animation: hmunKen 28s ease-in-out infinite alternate;
}
@keyframes hmunKen {
  from { transform: scale(1.06) translate(0,0); }
  to   { transform: scale(1.16) translate(-2%,-2%); }
}
.hmun-media.hmun-noimg {
  background:
    radial-gradient(ellipse 70% 70% at 25% 15%, rgba(229,9,20,0.32), transparent 60%),
    radial-gradient(ellipse 60% 60% at 85% 90%, rgba(10,127,212,0.22), transparent 60%),
    #070707;
}
.hmun-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.045) 1px, transparent 1px);
  background-size: 24px 24px;
  mask-image: radial-gradient(ellipse at 70% 50%, black 20%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse at 70% 50%, black 20%, transparent 75%);
  opacity: 0.5;
}
.hmun-beam {
  position: absolute; top: -40%;
  width: 45%; height: 150%;
  filter: blur(45px);
  mix-blend-mode: screen;
  pointer-events: none;
}
.hmun-beam-1 {
  left: -8%;
  background: radial-gradient(ellipse 40% 60% at 50% 0%, rgba(229,9,20,0.55), transparent 70%);
  transform: rotate(16deg);
  animation: hmunBeam 9s ease-in-out infinite alternate;
}
.hmun-beam-2 {
  right: -8%;
  background: radial-gradient(ellipse 40% 60% at 50% 0%, rgba(255,194,75,0.4), transparent 70%);
  transform: rotate(-16deg);
  animation: hmunBeam 11s ease-in-out infinite alternate-reverse;
}
@keyframes hmunBeam {
  from { opacity: 0.3; transform: translateX(-5%) rotate(16deg); }
  to   { opacity: 0.6; transform: translateX(5%) rotate(12deg); }
}
.hmun-shade {
  position: absolute; inset: 0;
  background:
    linear-gradient(100deg, rgba(7,7,7,0.92) 0%, rgba(7,7,7,0.78) 38%, rgba(7,7,7,0.35) 70%, rgba(7,7,7,0.55) 100%);
}

.hmun-inner {
  position: relative;
  z-index: 1;
  max-width: 640px;
  padding: 64px 56px;
  color: #fff;
}
.hmun-badge {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 7px 15px;
  border-radius: 100px;
  background: rgba(229,9,20,0.14);
  border: 1px solid rgba(229,9,20,0.34);
  backdrop-filter: blur(8px);
  font-family: var(--font-condensed, sans-serif);
  font-size: 11.5px;
  font-weight: 600;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  margin-bottom: 20px;
}
.hmun-badge-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: #e50914;
  box-shadow: 0 0 10px #e50914;
  animation: munPulse 1.8s ease-in-out infinite;
}
.hmun-title {
  font-family: var(--font-display, 'Bebas Neue', sans-serif);
  font-size: clamp(38px, 5.5vw, 76px);
  line-height: 0.94;
  text-transform: uppercase;
  margin: 0 0 18px;
  text-shadow: 0 8px 40px rgba(0,0,0,0.5);
}
.hmun-accent {
  background: linear-gradient(120deg, #ff2030 0%, #e50914 50%, #ffc24b 120%);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
  filter: drop-shadow(0 0 24px rgba(229,9,20,0.4));
}
.hmun-sub {
  font-size: clamp(14px, 1.6vw, 17px);
  line-height: 1.6;
  color: rgba(255,255,255,0.8);
  max-width: 520px;
  margin: 0 0 24px;
}
.hmun-sub strong { color: #fff; font-weight: 700; }

.hmun-feats {
  list-style: none;
  margin: 0 0 30px;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 10px 14px;
}
.hmun-feats li {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-condensed, sans-serif);
  font-size: 13.5px;
  letter-spacing: 0.02em;
  color: rgba(255,255,255,0.85);
}
.hmun-feat-ico {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px; height: 30px;
  border-radius: 9px;
  background: rgba(229,9,20,0.16);
  border: 1px solid rgba(229,9,20,0.34);
  color: #ff5a63;
  flex-shrink: 0;
}
.hmun-ctas { display: flex; flex-wrap: wrap; gap: 12px; }
.hmun-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 13px 24px;
  border: none;
  border-radius: 12px;
  font-family: var(--font-condensed, sans-serif);
  font-size: 14.5px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
  transition: transform 0.16s ease, box-shadow 0.25s ease, filter 0.2s ease, background 0.2s ease;
}
.hmun-btn-primary {
  background: linear-gradient(135deg, #e50914, #b0060f);
  color: #fff;
  box-shadow: 0 8px 28px rgba(229,9,20,0.45);
}
.hmun-btn-primary:hover { transform: translateY(-2px); box-shadow: 0 12px 38px rgba(229,9,20,0.6); filter: brightness(1.08); }
.hmun-btn-ghost {
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.22);
  color: #fff;
  backdrop-filter: blur(8px);
}
.hmun-btn-ghost:hover { background: rgba(255,255,255,0.14); transform: translateY(-2px); }
.hmun-btn-wa {
  background: #25d366;
  color: #053;
  box-shadow: 0 8px 24px rgba(37,211,102,0.32);
}
.hmun-btn-wa:hover { transform: translateY(-2px); background: #2eea73; }

@media (max-width: 720px) {
  .hmun { margin: 40px 16px; border-radius: 22px; }
  .hmun-inner { padding: 44px 26px; max-width: none; }
  .hmun-shade {
    background: linear-gradient(180deg, rgba(7,7,7,0.6) 0%, rgba(7,7,7,0.82) 55%, rgba(7,7,7,0.92) 100%);
  }
  .hmun-img { opacity: 0.4; }
  .hmun-ctas .hmun-btn { flex: 1 1 auto; justify-content: center; }
}

/* ════════════════════════════════════════════════════════════
   POPUP INTELIGENTE (once-per-session)
   ════════════════════════════════════════════════════════════ */
.mun-promo {
  position: fixed;
  left: 22px; bottom: 22px;
  z-index: 1400;
  width: 320px;
  max-width: calc(100vw - 44px);
  background: rgba(14,14,16,0.96);
  border: 1px solid rgba(229,9,20,0.3);
  border-radius: 16px;
  box-shadow: 0 24px 70px rgba(0,0,0,0.7), 0 0 0 1px rgba(255,255,255,0.04);
  backdrop-filter: blur(16px);
  padding: 18px 18px 16px;
  transform: translateY(140%);
  opacity: 0;
  transition: transform 0.5s cubic-bezier(0.22,1,0.36,1), opacity 0.4s ease;
}
.mun-promo.show { transform: translateY(0); opacity: 1; }
.mun-promo-eyebrow {
  font-family: var(--font-condensed, sans-serif);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--mun-red);
  margin-bottom: 6px;
}
.mun-promo-title {
  font-family: var(--font-display, sans-serif);
  font-size: 23px;
  line-height: 1.05;
  text-transform: uppercase;
  color: #fff;
  margin: 0 0 8px;
}
.mun-promo-text { font-size: 13px; color: rgba(255,255,255,0.6); line-height: 1.45; margin: 0 0 14px; }
.mun-promo-actions { display: flex; gap: 8px; }
.mun-promo-cta {
  flex: 1;
  display: inline-flex; align-items: center; justify-content: center;
  padding: 9px 14px;
  border: none;
  border-radius: 9px;
  background: linear-gradient(135deg, #e50914, #b0060f);
  color: #fff;
  font-family: var(--font-condensed, sans-serif);
  font-size: 13px; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase;
  cursor: pointer;
  transition: filter 0.18s, transform 0.15s;
}
.mun-promo-cta:hover { filter: brightness(1.1); transform: translateY(-1px); }
.mun-promo-close {
  flex-shrink: 0;
  width: 36px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 9px;
  color: rgba(255,255,255,0.6);
  font-size: 18px; line-height: 1;
  cursor: pointer;
  transition: background 0.18s, color 0.18s;
}
.mun-promo-close:hover { background: rgba(255,255,255,0.12); color: #fff; }

/* ════════════════════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════════════════════ */
@media (max-width: 900px) {
  .mun-pkg-grid { grid-template-columns: 1fr; max-width: 440px; margin: 0 auto; gap: 16px; }
  .mun-pkg-feat { order: -1; }
}
@media (max-width: 600px) {
  .mun-hero { padding: calc(var(--nav-h, 96px) + 24px) 18px 70px; }
  .mun-section { padding: 30px 18px 56px; }
  .mun-manifesto { padding: 64px 18px 50px; }
  .mun-exp-grid { grid-template-columns: 1fr 1fr; gap: 11px; }
  .mun-exp-card { height: 210px; }
  .mun-exp-body { padding: 14px; }
  .mun-exp-body h3 { font-size: 21px; }
  .mun-exp-body p { font-size: 12px; }
  .mun-exp-cta { left: 14px; bottom: 14px; }
  .mun-stats { gap: 12px; }
  .mun-stat-div { display: none; }
  .mun-stat { min-width: 40%; flex: 1 1 40%; }
  .mun-hero-ctas .mun-btn { flex: 1 1 auto; justify-content: center; }
  .mun-promo { left: 12px; right: 12px; bottom: 12px; width: auto; }
}
@media (max-width: 380px) {
  .mun-exp-grid { grid-template-columns: 1fr; }
}
