
/* ============================================================
   BREAKING TICKER (barra en vivo superior)
   ============================================================ */
.ticker-bar {
  background: var(--blanco);
  border-bottom: 1px solid var(--borde);
  display: flex;
  align-items: center;
  height: 38px;
  overflow: hidden;
  position: sticky;
  top: 0;
  z-index: 1000;
}
.ticker-label {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 6px;
  background: var(--blanco);
  color: var(--rojo);
  font-family: var(--font-b);
  font-size: 11px;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 0 14px 0 16px;
  border-right: 1px solid var(--borde);
  height: 100%;
  white-space: nowrap;
}
.ticker-dot {
  width: 8px; height: 8px;
  background: var(--rojo);
  border-radius: 50%;
  animation: blink 1.2s ease-in-out infinite;
}
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:0} }

.ticker-track-wrap {
  flex: 1;
  overflow: hidden;
  height: 100%;
  display: flex;
  align-items: center;
  mask-image: linear-gradient(to right, transparent 0, black 40px, black calc(100% - 40px), transparent 100%);
}
.ticker-track {
  display: flex;
  gap: 0;
  animation: tickerMove 40s linear infinite;
  white-space: nowrap;
}
.ticker-track:hover { animation-play-state: paused; }
@keyframes tickerMove { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }
.ticker-item {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-serif);
  font-size: 12.5px;
  color: var(--dark);
  padding: 0 24px;
  border-right: 1px solid var(--borde);
  white-space: nowrap;
  cursor: pointer;
}
.ticker-item:hover { color: var(--azul); }
.ticker-item .ti-cat {
  font-family: var(--font-b);
  font-size: 10px;
  text-transform: uppercase;
  color: var(--cyan);
  margin-right: 6px;
  letter-spacing: .06em;
}

/* ============================================================
   CONTENEDOR PRINCIPAL
   ============================================================ */
.site-main {
  max-width: var(--max);
  margin: 0 auto;
  padding: 20px 20px;
}


/* ============================================================
   RESPONSIVE — TABLET (737px–1190px)
   ============================================================ */
@media (max-width: 1190px) {
  .main-nav a { font-size: 13px; padding: 4px 8px; }
  .opinion-grid { grid-template-columns: repeat(3, 1fr); }
  .footer-inner { grid-template-columns: 180px 1fr; }
  .footer-inner .footer-col:last-child { grid-column: 2; }
}

@media (max-width: 920px) {
  .hero-section { grid-template-columns: 1fr; }
  .hero-main .hero-img { height: 280px; }
  .two-col { grid-template-columns: 1fr; }
  .news-grid { grid-template-columns: repeat(2, 1fr); }
  .news-grid.col4 { grid-template-columns: repeat(2, 1fr); }
  .mm-featured { grid-template-columns: 1fr; }
  .mm-sidebar { border-left: none; border-top: 1px solid var(--borde); }
  .opinion-grid { grid-template-columns: repeat(3, 1fr); }
  .footer-inner { grid-template-columns: 1fr 1fr; gap: 28px; }
  .footer-inner .footer-brand { grid-column: 1 / -1; }
}

/* ============================================================
   RESPONSIVE — MÓVIL (max 736px)
   ============================================================ */
@media (max-width: 736px) {
  :root { --gap: 14px; }
  body { font-size: 15px; }

  /* Ticker */
  .ticker-bar { top: 0; height: 34px; }
  .ticker-item { font-size: 11.5px; padding: 0 16px; }
  .ticker-label { padding: 0 10px 0 12px; font-size: 10px; }

  /* Main padding */
  .site-main { padding: 14px 14px; }
  .section-header .sh-title { font-size: 17px; }
}