/* ═══════════════════════════════════════════════════
   El Rufino — portal.css v2
   Tema hijo de Hello Elementor
   elrufino.com.ar — Rufino, Santa Fe
═══════════════════════════════════════════════════ */

/* ── GOOGLE FONTS (cargadas desde functions.php) ── */

/* ── VARIABLES ── */
:root {
  --rojo:       #c8102e;
  --rojo-dark:  #9e0a22;
  --rojo-light: #fdf2f4;
  --negro:      #111111;
  --gris-1:     #222222;
  --gris-2:     #444444;
  --gris-3:     #777777;
  --gris-4:     #aaaaaa;
  --gris-5:     #cccccc;
  --gris-6:     #f5f5f5;
  --gris-7:     #fafafa;
  --blanco:     #ffffff;
  --linea:      #e8e8e8;
  --linea-suave:#f0f0f0;
  --verde:      #16a34a;
  --naranja:    #ea580c;
  --azul:       #1d4ed8;
  --morado:     #7c3aed;

  --f-serif: 'Libre Baskerville', Georgia, serif;
  --f-cond:  'Barlow Condensed', 'Arial Narrow', sans-serif;
  --f-sans:  'Barlow', system-ui, sans-serif;

  --sombra-xs: 0 1px 3px rgba(0,0,0,.06);
  --sombra-sm: 0 2px 8px rgba(0,0,0,.08);
  --sombra-md: 0 4px 16px rgba(0,0,0,.10);
}

/* ── RESET SOBRE HELLO ELEMENTOR ── */
*, *::before, *::after { box-sizing: border-box; }

/* Hello Elementor y Elementor pueden agregar margin/padding al body */
body.elementor-page,
body {
  font-family: var(--f-sans) !important;
  background: var(--blanco) !important;
  color: var(--negro) !important;
  font-size: 15px !important;
  line-height: 1.6 !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Neutralizar elementos nativos de Hello que interfieren */
.site-header,
.main-navigation,
.nav-links,
.site-footer,
header.entry-header,
.elementor-section-wrap > header { display: none !important; }

/* Reset de anchors */
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }

/* ══════════════════════════════════════════════════
   TOPBAR — CLARA, NO OSCURA
══════════════════════════════════════════════════ */
.er-topbar {
  background: var(--blanco);
  border-bottom: 1px solid var(--linea);
  font-family: var(--f-cond);
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: var(--gris-3);
}
.er-topbar-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 1.25rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 32px;
  gap: 1rem;
}
.er-topbar-left  { display: flex; align-items: center; gap: 1.5rem; }
.er-topbar-item  { display: flex; align-items: center; gap: 0.4rem; }
.er-topbar-right { display: flex; align-items: center; gap: 0.75rem; }
.er-admin-btn {
  background: var(--rojo);
  color: var(--blanco) !important;
  padding: 0.18rem 0.65rem;
  font-family: var(--f-cond);
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  border-radius: 3px;
  border: none;
  cursor: pointer;
  transition: background 0.15s;
  text-decoration: none;
  display: inline-block;
}
.er-admin-btn:hover { background: var(--rojo-dark); color: var(--blanco) !important; }

/* ══════════════════════════════════════════════════
   AD SLOT — LEADERBOARD SUPERIOR
══════════════════════════════════════════════════ */
.er-ad-slot {
  background: var(--gris-7);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  position: relative;
}
.er-ad-top    { height: 90px; border-bottom: 1px solid var(--linea); }
.er-ad-mid    { height: 90px; margin: 1.5rem 0; }
.er-ad-banner { height: 90px; margin-bottom: 1.75rem; }
.er-ad-final  { height: 120px; margin: 1.5rem 0; }
.er-ad-footer { height: 90px; }
.er-ad-sidebar{ width: 100%; height: 250px; }
.er-ad-hdr-r  { width: 300px; height: 80px; flex-shrink: 0; }

.er-ad-slot img { width: 100%; height: 100%; object-fit: cover; cursor: pointer; display: block; }
.er-ad-link { display: block; width: 100%; height: 100%; position: relative; }
.er-ad-fallback {
  width: 100%; height: 100%;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 0.25rem;
  font-family: var(--f-cond);
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--gris-5);
  background: var(--gris-6);
  cursor: pointer;
  transition: background 0.15s;
  border: 1px dashed var(--linea);
}
.er-ad-fallback:hover { background: #efefef; }
.er-ad-fallback .ad-sub { font-size: 0.5rem; color: var(--gris-5); }
.er-ad-clics {
  position: absolute; top: 4px; right: 6px;
  background: rgba(200,16,46,0.85);
  color: #fff;
  font-family: var(--f-cond); font-size: 0.5rem; font-weight: 700;
  padding: 1px 5px; border-radius: 2px;
}

/* ══════════════════════════════════════════════════
   HEADER — LIMPIO Y EDITORIAL
══════════════════════════════════════════════════ */
.er-header {
  background: var(--blanco);
  border-bottom: 3px solid var(--negro);
  padding: 1.25rem 0 1rem;
}
.er-header-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 1.25rem;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 1.5rem;
}
.er-header-left { display: flex; flex-direction: column; gap: 0.3rem; }
.er-header-sub {
  font-family: var(--f-cond);
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gris-4);
}
.er-header-meta { font-family: var(--f-cond); font-size: 0.6rem; color: var(--gris-5); letter-spacing: 0.04em; }

/* LOGO */
.er-logo { text-align: center; }
.er-logo a { text-decoration: none; display: inline-block; }
.er-logo-el {
  font-family: var(--f-cond);
  font-size: 1.1rem;
  font-weight: 600;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--gris-3);
  display: block;
  margin-bottom: -0.1rem;
}
.er-logo-rufino {
  font-family: var(--f-serif);
  font-size: 3rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.03em;
  color: var(--rojo);
  display: block;
}
.er-logo-tagline {
  font-family: var(--f-cond);
  font-size: 0.58rem;
  font-weight: 600;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--gris-4);
  margin-top: 0.3rem;
}
.er-header-right { display: flex; justify-content: flex-end; align-items: center; }

/* ══════════════════════════════════════════════════
   TICKER — SUTIL, CLARO
══════════════════════════════════════════════════ */
.er-ticker {
  background: var(--rojo-light);
  border-bottom: 1px solid #f0c0c6;
  height: 30px;
  display: flex;
  align-items: center;
  overflow: hidden;
}
.er-ticker-label {
  background: var(--rojo);
  color: var(--blanco);
  font-family: var(--f-cond);
  font-size: 0.62rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 0 1rem;
  height: 100%;
  display: flex;
  align-items: center;
  white-space: nowrap;
  flex-shrink: 0;
}
.er-ticker-track { flex: 1; overflow: hidden; height: 100%; position: relative; }
.er-ticker-content {
  display: flex;
  align-items: center;
  height: 100%;
  animation: er-ticker 45s linear infinite;
  white-space: nowrap;
}
.er-ticker-content:hover { animation-play-state: paused; }
@keyframes er-ticker { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }
.er-ticker-item {
  font-family: var(--f-cond);
  font-size: 0.7rem;
  font-weight: 600;
  color: var(--gris-1);
  padding: 0 2rem;
  letter-spacing: 0.02em;
}
.er-ticker-item::after { content: '·'; margin-left: 2rem; color: var(--rojo); }

/* ══════════════════════════════════════════════════
   NAVBAR — STICKY. BUG FIX: usa box-shadow en vez
   de border-bottom para evitar el salto de layout
══════════════════════════════════════════════════ */
.er-navbar {
  background: var(--blanco);
  border-bottom: 1px solid var(--linea);
  position: sticky;
  top: 0;
  z-index: 200;
  box-shadow: var(--sombra-sm);
}
.er-navbar-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 1.25rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 44px;
  /* Altura fija garantiza que el navbar no cambie de tamaño */
}
.er-nav-links {
  display: flex;
  align-items: stretch; /* stretch para que cada link ocupe el alto completo */
  height: 100%;
  gap: 0;
}

/*
  FIX DEL MENU QUE SE DESACOMODA:
  El problema era usar border-bottom en el <a> que cambia
  de transparent a colored y desplaza el layout 3px.
  Solución: box-shadow inset no afecta el box model.
*/
.er-nav-link {
  font-family: var(--f-cond);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--gris-2);
  padding: 0 0.85rem;
  display: flex;
  align-items: center;
  text-decoration: none;
  white-space: nowrap;
  /* Indicador inset — no afecta el layout en absoluto */
  box-shadow: inset 0 -3px 0 transparent;
  transition: color 0.15s, box-shadow 0.15s;
  /* Sin border, sin outline, sin nada que cambie dimensiones */
  border: none;
  outline: none;
  background: none;
}
.er-nav-link:hover {
  color: var(--rojo);
  box-shadow: inset 0 -3px 0 var(--rojo);
}
.er-nav-link.active {
  color: var(--rojo);
  box-shadow: inset 0 -3px 0 var(--rojo);
}

/* ══════════════════════════════════════════════════
   CONTENEDOR Y LAYOUT
══════════════════════════════════════════════════ */
.er-container { max-width: 1200px; margin: 0 auto; padding: 0 1.25rem; }
.er-main { display: grid; grid-template-columns: 1fr 300px; gap: 2.5rem; padding: 2rem 0 3rem; }

/* ── SECTION LABELS ── */
.er-section-label {
  font-family: var(--f-cond);
  font-size: 0.65rem;
  font-weight: 800;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--rojo);
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1.1rem;
  margin-top: 0.25rem;
}
.er-section-label::after { content: ''; flex: 1; height: 1px; background: var(--linea); }

/* ══════════════════════════════════════════════════
   EDITORIAL BLOCK
══════════════════════════════════════════════════ */
.er-editorial {
  border-left: 4px solid var(--rojo);
  padding: 1.1rem 1.4rem;
  background: var(--gris-7);
  margin-bottom: 2rem;
  border-radius: 0 4px 4px 0;
}
.er-editorial-kicker {
  font-family: var(--f-cond);
  font-size: 0.6rem;
  font-weight: 800;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--rojo);
  margin-bottom: 0.4rem;
}
.er-editorial-titulo {
  font-family: var(--f-serif);
  font-size: 1.1rem;
  font-weight: 700;
  line-height: 1.35;
  color: var(--negro);
  margin-bottom: 0.55rem;
}
.er-editorial-cuerpo { font-size: 0.85rem; color: var(--gris-2); line-height: 1.7; }

/* ══════════════════════════════════════════════════
   HERO GRID — ENTREVISTAS DESTACADAS
══════════════════════════════════════════════════ */
.er-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--linea);
  margin-bottom: 2rem;
  border: 1px solid var(--linea);
}
.er-hero-main { grid-row: 1 / 3; background: var(--blanco); }
.er-hero-sec  { background: var(--blanco); }

/* ── CARDS ── */
.er-card { display: flex; flex-direction: column; height: 100%; overflow: hidden; }
.er-card-img { position: relative; overflow: hidden; flex-shrink: 0; }
.er-card-img-main { height: 280px; }
.er-card-img-sec  { height: 160px; }
.er-card-img img, .er-post-thumb { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.3s; }
.er-card:hover .er-card-img img,
.er-card:hover .er-post-thumb { transform: scale(1.02); }

.er-card-badge {
  position: absolute; top: 0.5rem; left: 0.5rem;
  font-family: var(--f-cond); font-size: 0.52rem; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase;
  padding: 0.15rem 0.45rem; border-radius: 2px; color: var(--blanco);
}
.er-badge-revisado    { background: #16a34a; }
.er-badge-pendiente   { background: #ea580c; }
.er-badge-digitalizar { background: #7c3aed; }

.er-card-body      { padding: 1rem; flex: 1; }
.er-card-body-main { padding: 1.25rem; }

.er-card-cat {
  font-family: var(--f-cond);
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 0.4rem;
  display: inline-flex;
  align-items: center;
  padding-bottom: 0.12rem;
  border-bottom: 2px solid currentColor;
}
.er-card-titulo {
  font-family: var(--f-serif);
  font-weight: 700;
  line-height: 1.3;
  color: var(--negro);
  margin-bottom: 0.4rem;
}
.er-card-titulo a { color: inherit; text-decoration: none; }
.er-card-titulo a:hover { color: var(--rojo); }
.er-card-titulo-main { font-size: 1.15rem; }
.er-card-titulo-sec  { font-size: 0.88rem; }

.er-card-quien {
  font-family: var(--f-cond);
  font-size: 0.68rem;
  font-weight: 600;
  color: var(--gris-3);
  letter-spacing: 0.03em;
  margin-bottom: 0.3rem;
}
.er-card-extracto {
  font-size: 0.8rem;
  color: var(--gris-2);
  line-height: 1.55;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.er-card-meta {
  font-family: var(--f-cond);
  font-size: 0.6rem;
  color: var(--gris-4);
  letter-spacing: 0.03em;
  margin-top: 0.6rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.er-card-id { color: var(--gris-5); font-size: 0.56rem; }
.er-audio-wrap { margin-top: 0.75rem; padding-top: 0.75rem; border-top: 1px solid var(--linea-suave); }
.er-audio-lbl { font-family: var(--f-cond); font-size: 0.56rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gris-4); margin-bottom: 0.3rem; }
.er-audio-wrap audio { width: 100%; height: 28px; }

/* ══════════════════════════════════════════════════
   STRIP — ÚLTIMAS INCORPORACIONES
══════════════════════════════════════════════════ */
.er-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--linea);
  border: 1px solid var(--linea);
  margin-bottom: 2rem;
}
.er-strip-item {
  background: var(--blanco);
  padding: 0.9rem;
  display: flex;
  gap: 0.65rem;
  align-items: flex-start;
  transition: background 0.15s;
}
.er-strip-item:hover { background: var(--gris-7); }
.er-strip-n {
  font-family: var(--f-serif);
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--linea);
  line-height: 1;
  min-width: 2rem;
  text-align: right;
  flex-shrink: 0;
}
.er-strip-titulo {
  font-family: var(--f-serif);
  font-size: 0.8rem;
  font-weight: 700;
  line-height: 1.35;
  color: var(--negro);
  margin-bottom: 0.2rem;
}
.er-strip-titulo a { color: inherit; text-decoration: none; }
.er-strip-titulo a:hover { color: var(--rojo); }
.er-strip-meta { font-family: var(--f-cond); font-size: 0.58rem; color: var(--gris-4); letter-spacing: 0.02em; }

/* ══════════════════════════════════════════════════
   FILTROS — CHIPS
══════════════════════════════════════════════════ */
.er-filtros { margin-bottom: 1.25rem; display: flex; flex-direction: column; gap: 0.6rem; }
.er-filtros-row { display: flex; align-items: center; flex-wrap: wrap; gap: 0.35rem; }
.er-filtro-lbl {
  font-family: var(--f-cond); font-size: 0.6rem; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase; color: var(--gris-4);
  min-width: 60px;
}
.er-chip {
  font-family: var(--f-cond); font-size: 0.62rem; font-weight: 700;
  letter-spacing: 0.07em; text-transform: uppercase;
  padding: 0.22rem 0.7rem; border-radius: 20px;
  border: 1.5px solid var(--linea);
  background: var(--blanco); color: var(--gris-2);
  cursor: pointer; transition: all 0.15s; text-decoration: none;
  display: inline-block;
}
.er-chip:hover { border-color: var(--rojo); color: var(--rojo); background: var(--rojo-light); }
.er-chip.active { background: var(--rojo); color: var(--blanco); border-color: var(--rojo); }

/* ══════════════════════════════════════════════════
   GRILLA ARCHIVO
══════════════════════════════════════════════════ */
.er-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--linea);
  border: 1px solid var(--linea);
  margin-bottom: 2rem;
}
.er-grid-card {
  background: var(--blanco);
  padding: 0.9rem;
  cursor: pointer;
  transition: background 0.15s;
}
.er-grid-card:hover { background: var(--gris-7); }
.er-grid-card .er-card-img { margin: -0.9rem -0.9rem 0.8rem; }
.er-grid-card .er-card-img img,
.er-grid-card .er-card-img .er-post-thumb { height: 125px; }
.er-grid-card audio { width: 100%; height: 26px; margin-top: 0.5rem; }

/* ══════════════════════════════════════════════════
   GRILLA FINAL 3 COLUMNAS
══════════════════════════════════════════════════ */
.er-grilla-final {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--linea);
  border: 1px solid var(--linea);
  margin: 1.75rem 0;
}
.er-grilla-art { background: var(--gris-7); padding: 1rem; }
.er-grilla-titulo { font-family: var(--f-serif); font-size: 0.82rem; font-weight: 700; line-height: 1.3; color: var(--negro); margin: 0.3rem 0 0.25rem; }
.er-grilla-titulo a { color: inherit; text-decoration: none; }
.er-grilla-titulo a:hover { color: var(--rojo); }
.er-grilla-meta { font-family: var(--f-cond); font-size: 0.6rem; color: var(--gris-4); }

/* ══════════════════════════════════════════════════
   SIDEBAR
══════════════════════════════════════════════════ */
.er-sidebar { display: flex; flex-direction: column; gap: 1.75rem; }

.er-widget { border-top: 3px solid var(--negro); padding-top: 0.9rem; }
.er-widget-titulo {
  font-family: var(--f-cond);
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--negro);
  margin-bottom: 0.9rem;
}
.er-stat-row {
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--f-cond); font-size: 0.7rem; color: var(--gris-2);
  padding: 0.4rem 0; border-bottom: 1px solid var(--linea-suave);
}
.er-stat-row:last-child { border-bottom: none; }
.er-stat-num { font-weight: 800; font-size: 0.82rem; color: var(--negro); }

.er-top-item {
  display: flex; gap: 0.6rem; align-items: flex-start;
  padding: 0.6rem 0; border-bottom: 1px solid var(--linea-suave); cursor: pointer;
  transition: background 0.12s;
}
.er-top-item:last-child { border-bottom: none; }
.er-top-item:hover { background: var(--gris-7); margin: 0 -0.5rem; padding: 0.6rem 0.5rem; border-radius: 4px; }
.er-top-n {
  font-family: var(--f-serif); font-size: 1.05rem; font-weight: 700;
  color: var(--linea); line-height: 1; min-width: 1.5rem; text-align: right; flex-shrink: 0;
}
.er-top-titulo { font-size: 0.77rem; font-weight: 600; line-height: 1.3; color: var(--negro); margin-bottom: 0.1rem; }
.er-top-titulo a { color: inherit; text-decoration: none; }
.er-top-titulo a:hover { color: var(--rojo); }
.er-top-meta { font-family: var(--f-cond); font-size: 0.58rem; color: var(--gris-4); }

.er-columna {
  font-size: 0.82rem; color: var(--gris-2); line-height: 1.7;
  border-left: 3px solid var(--rojo);
  padding-left: 0.9rem;
  font-style: italic;
}
.er-columna-firma {
  font-family: var(--f-cond); font-size: 0.6rem; font-weight: 700;
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--gris-4); margin-top: 0.6rem;
}

/* ══════════════════════════════════════════════════
   SINGLE ENTREVISTA
══════════════════════════════════════════════════ */
.er-single { max-width: 820px; margin: 0 auto; padding: 2rem 1.25rem; }
.er-single-kicker {
  font-family: var(--f-cond); font-size: 0.62rem; font-weight: 800;
  letter-spacing: 0.22em; text-transform: uppercase; color: var(--rojo); margin-bottom: 0.75rem;
}
.er-single-titulo {
  font-family: var(--f-serif); font-size: 1.9rem; font-weight: 700;
  line-height: 1.25; color: var(--negro); margin-bottom: 1rem;
}
.er-single-quien {
  font-family: var(--f-cond); font-size: 0.85rem; font-weight: 600;
  color: var(--gris-2); margin-bottom: 0.25rem;
}
.er-single-meta {
  font-family: var(--f-cond); font-size: 0.65rem; color: var(--gris-4);
  letter-spacing: 0.04em; margin-bottom: 1.5rem;
  padding-bottom: 1rem; border-bottom: 1px solid var(--linea);
  display: flex; gap: 1rem; flex-wrap: wrap; align-items: center;
}
.er-single-audio { background: var(--gris-7); padding: 1rem; margin-bottom: 1.5rem; border-radius: 4px; border: 1px solid var(--linea); }
.er-single-audio-lbl { font-family: var(--f-cond); font-size: 0.6rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gris-3); margin-bottom: 0.5rem; }
.er-single-audio audio { width: 100%; }
.er-single-body { font-size: 1rem; line-height: 1.8; color: var(--gris-1); }
.er-single-body p { margin-bottom: 1.25rem; }

/* ══════════════════════════════════════════════════
   FOOTER
══════════════════════════════════════════════════ */
.er-footer {
  background: var(--gris-7);
  color: var(--gris-2);
  padding: 2.5rem 0 1.25rem;
  border-top: 3px solid var(--negro);
  margin-top: 2rem;
}
.er-footer-inner { max-width: 1200px; margin: 0 auto; padding: 0 1.25rem; }
.er-footer-grid {
  display: grid; grid-template-columns: 2fr 1fr 1fr;
  gap: 2.5rem; margin-bottom: 2rem;
  padding-bottom: 1.75rem; border-bottom: 1px solid var(--linea);
}
.er-footer-logo { font-family: var(--f-serif); font-size: 1.3rem; color: var(--negro); margin-bottom: 0.5rem; }
.er-footer-logo span { color: var(--rojo); }
.er-footer-desc { font-size: 0.8rem; line-height: 1.65; color: var(--gris-3); }
.er-footer-heading {
  font-family: var(--f-cond); font-size: 0.6rem; font-weight: 800;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--negro); margin-bottom: 0.8rem;
}
.er-footer-links { display: flex; flex-direction: column; gap: 0.35rem; }
.er-footer-links a { font-size: 0.8rem; color: var(--gris-3); transition: color 0.15s; text-decoration: none; }
.er-footer-links a:hover { color: var(--rojo); }
.er-footer-bottom {
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--f-cond); font-size: 0.6rem; letter-spacing: 0.05em; color: var(--gris-4);
}
.er-footer-issn { font-family: var(--f-cond); font-size: 0.58rem; color: var(--gris-5); }

/* ══════════════════════════════════════════════════
   SIN RESULTADOS
══════════════════════════════════════════════════ */
.er-no-results {
  grid-column: 1 / -1;
  padding: 3rem;
  text-align: center;
  font-family: var(--f-cond);
  font-size: 0.75rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--gris-4);
}

/* ══════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════ */
@media (max-width: 1024px) {
  .er-main { grid-template-columns: 1fr; }
  .er-sidebar { display: none; }
  .er-footer-grid { grid-template-columns: 1fr 1fr; }
  .er-header-inner { grid-template-columns: 1fr; text-align: center; }
  .er-ad-hdr-r { display: none; }
  .er-header-left { display: none; }
}
@media (max-width: 768px) {
  .er-hero { grid-template-columns: 1fr; }
  .er-hero-main { grid-row: auto; }
  .er-strip { grid-template-columns: 1fr 1fr; }
  .er-grid { grid-template-columns: 1fr 1fr; }
  .er-grilla-final { grid-template-columns: 1fr; }
  .er-footer-grid { grid-template-columns: 1fr; }
  .er-logo-rufino { font-size: 2.2rem; }
  /* Navbar en mobile: scroll horizontal */
  .er-navbar-inner { overflow-x: auto; justify-content: flex-start; }
  .er-nav-links { flex-shrink: 0; }
  .er-nav-link { padding: 0 0.7rem; font-size: 0.68rem; }
}
@media (max-width: 480px) {
  .er-strip { grid-template-columns: 1fr; }
  .er-grid { grid-template-columns: 1fr; }
}
