/* Mera — Ticker de avisos vigentes (look "neón institucional / LED de tienda") */

.mera-ticker {
  --ticker-duration: 90s;
  --ticker-start: 100vw;
  --ticker-end: -100%;
  --ticker-bg-1: #0E4A26;
  --ticker-bg-2: #1F7A3F;
  --ticker-accent: #F7A823;
  --ticker-glow: rgba(247,168,35,0.55);
  --ticker-text: #ffffff;

  position: relative;
  display: flex;
  align-items: stretch;
  width: 100%;
  margin: 0;
  background:
    linear-gradient(90deg, var(--ticker-bg-1) 0%, var(--ticker-bg-2) 50%, var(--ticker-bg-1) 100%);
  border-top: 2px solid rgba(247,168,35,0.4);
  border-bottom: 2px solid rgba(247,168,35,0.4);
  overflow: hidden;
  isolation: isolate;
  box-shadow:
    0 0 18px rgba(31,122,63,0.4),
    inset 0 0 24px rgba(0,0,0,0.25);
}

/* Líneas neón superior + inferior (efecto LED) */
.mera-ticker::before,
.mera-ticker::after {
  content: "";
  position: absolute;
  left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--ticker-accent), transparent);
  filter: blur(2px);
  z-index: 2;
  animation: mera-ticker-shine 3.5s ease-in-out infinite;
  pointer-events: none;
}
.mera-ticker::before { top: 0; }
.mera-ticker::after  { bottom: 0; animation-delay: 1.75s; }
@keyframes mera-ticker-shine {
  0%, 100% { opacity: 0.35; }
  50%      { opacity: 1;    }
}

/* Chip etiqueta institucional fija a la izquierda */
.mera-ticker__label {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.625rem 1rem;
  background: linear-gradient(135deg, var(--ticker-accent) 0%, #D88A0A 100%);
  color: #0E4A26;
  font-weight: 800;
  font-size: 0.8125rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  position: relative;
  z-index: 3;
  box-shadow: 0 0 14px var(--ticker-glow), inset 0 -2px 0 rgba(0,0,0,0.15);
}
.mera-ticker__label-text { white-space: nowrap; }

/* Punto rojo pulsante "EN VIVO" */
.mera-ticker__pulse {
  width: 10px; height: 10px;
  border-radius: 50%;
  background: #C0392B;
  box-shadow: 0 0 8px #C0392B, 0 0 16px rgba(192,57,43,0.7);
  animation: mera-ticker-pulse 1.4s ease-in-out infinite;
}
@keyframes mera-ticker-pulse {
  0%, 100% { transform: scale(1);   opacity: 1; }
  50%      { transform: scale(1.4); opacity: 0.5; }
}

/* Viewport — recorta lo que sale fuera del área visible */
.mera-ticker__viewport {
  flex: 1 1 auto;
  overflow: hidden;
  position: relative;
  min-height: 48px;
  display: flex;
  align-items: center;
}

/* Track — UNA sola fila con los items reales (sin duplicar).
   Animación: entra por la derecha (translateX = +viewport),
              sale por la izquierda (translateX = -trackWidth).
   El JS mide y setea --ticker-start (= ancho viewport) y --ticker-end (= -ancho track). */
.mera-ticker__track {
  display: inline-flex;
  align-items: center;
  gap: 1rem;
  width: max-content;
  white-space: nowrap;
  will-change: transform;
  transform: translateX(var(--ticker-start, 100%));
  animation: mera-ticker-slide var(--ticker-duration, 40s) linear infinite;
}
@keyframes mera-ticker-slide {
  from { transform: translateX(var(--ticker-start, 100%)); }
  to   { transform: translateX(var(--ticker-end,   -100%)); }
}

/* Pausa solo cuando el user lo pide explícitamente o por reducción de movimiento.
   NO se pausa en hover (el user quiere movimiento continuo siempre). */
.mera-ticker.is-paused .mera-ticker__track {
  animation-play-state: paused;
}

/* Item / botón clickeable */
.mera-ticker__item {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 0.875rem;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(247,168,35,0.25);
  border-radius: 8px;
  color: var(--ticker-text);
  font-size: 0.9375rem;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition: background .2s, border-color .2s, transform .15s, box-shadow .2s;
  font-family: inherit;
  flex: 0 0 auto;
}
.mera-ticker__item:hover,
.mera-ticker__item:focus-visible {
  background: rgba(247,168,35,0.18);
  border-color: var(--ticker-accent);
  transform: translateY(-1px);
  box-shadow: 0 0 14px var(--ticker-glow);
  outline: none;
}

.mera-ticker__icon {
  font-size: 1.0625rem;
  filter: drop-shadow(0 0 3px var(--ticker-glow));
}
.mera-ticker__title {
  text-shadow: 0 0 6px rgba(247,168,35,0.25);
}
.mera-ticker__date {
  font-size: 0.75rem;
  opacity: 0.75;
  font-weight: 500;
  letter-spacing: 0.04em;
  padding: 0.0625rem 0.375rem;
  background: rgba(0,0,0,0.25);
  border-radius: 4px;
}
.mera-ticker__arrow {
  font-size: 1.1rem;
  color: var(--ticker-accent);
  opacity: 0.7;
  transition: transform .2s, opacity .2s;
}
.mera-ticker__item:hover .mera-ticker__arrow {
  transform: translateX(3px);
  opacity: 1;
}

/* Separador ✦ entre items */
.mera-ticker__sep {
  color: var(--ticker-accent);
  opacity: 0.55;
  font-size: 0.875rem;
  user-select: none;
  text-shadow: 0 0 8px var(--ticker-glow);
  animation: mera-ticker-twinkle 2.5s ease-in-out infinite;
  flex: 0 0 auto;
}
@keyframes mera-ticker-twinkle {
  0%, 100% { opacity: 0.35; }
  50%      { opacity: 0.9;  }
}

/* Variantes por tema del aviso (matiz del borde) */
.mera-ticker__item--patrio  { border-color: rgba(255,221,0,0.45); }
.mera-ticker__item--fiesta  { border-color: rgba(247,168,35,0.5); }
.mera-ticker__item--navidad { border-color: rgba(220,20,60,0.45); }
.mera-ticker__item--luto    { border-color: rgba(180,180,180,0.5); }
.mera-ticker__item--cultural{ border-color: rgba(55,169,97,0.5); }
.mera-ticker__item--feriado { border-color: rgba(247,168,35,0.5); }

/* Botón pausa */
.mera-ticker__pause {
  flex: 0 0 auto;
  background: rgba(0,0,0,0.25);
  color: var(--ticker-accent);
  border: 0;
  padding: 0 0.875rem;
  font-size: 1rem;
  cursor: pointer;
  z-index: 3;
  transition: background .15s, color .15s;
}
.mera-ticker__pause:hover {
  background: rgba(247,168,35,0.18);
  color: #fff;
}

@media (max-width: 640px) {
  .mera-ticker__label { padding: 0.5rem 0.75rem; font-size: 0.6875rem; }
  .mera-ticker__label-text { display: none; }
  .mera-ticker__item { font-size: 0.875rem; padding: 0.4375rem 0.75rem; }
  .mera-ticker__date { display: none; }
}

/* Nota: el GADM decidió que el ticker debe estar SIEMPRE en movimiento como
   letrero informativo crítico. No se respeta prefers-reduced-motion para
   la animación principal del track. Sí se atenúan los efectos decorativos
   (parpadeos del fondo / separadores) para usuarios sensibles al movimiento. */
@media (prefers-reduced-motion: reduce) {
  .mera-ticker::before, .mera-ticker::after { animation: none; opacity: 0.6; }
  .mera-ticker__pulse { animation: none; }
  .mera-ticker__sep   { animation: none; opacity: 0.6; }
}

/* Vacío — oculto por completo */
.mera-ticker[hidden] { display: none !important; }
