/* ============================================================
   GOBIERNO AUTÓNOMO MUNICIPAL DE COROICO
   Hoja de estilos institucional — Estilo presidencial
   Paleta: verde institucional + blanco + marfil (sobrio, formal).
   Accesible (WCAG), responsive y elegante.
   ============================================================ */

/* ---------- 1. TOKENS / VARIABLES DE DISEÑO ---------- */
:root {
  /* Paleta institucional (verde + blanco) */
  --verde:        #0B5D34;   /* Verde institucional principal (anillo del logo) */
  --verde-oscuro: #08341E;   /* Verde profundo (header, footer, hero)          */
  --verde-medio:  #0E6E3E;
  --verde-claro:  #15924F;   /* Verde luminoso para acentos                    */
  --verde-tinte:  #EAF1EC;   /* Verde muy claro para fondos suaves de ícono    */
  --marfil:       #F7F5EF;   /* Fondo marfil (fondo del logo)                  */
  --marfil-2:     #FBFAF6;
  --blanco:       #FFFFFF;
  --tinta:        #1F2A24;   /* Texto principal (casi negro verdoso)           */
  --gris-texto:   #2B3530;
  --gris-medio:   #5E6B64;   /* Texto secundario                               */
  --linea:        #E3E6E2;   /* Bordes / separadores                           */
  --sello:        #1E9C57;   /* Filete verde para detalles ornamentales        */
  --sello-claro:  #BFE3CD;   /* Filete claro para fondos oscuros               */

  /* Tipografía */
  --font-titulo: "Playfair Display", "Libre Baskerville", Georgia, serif;
  --font-texto:  "Inter", "Segoe UI", system-ui, -apple-system, sans-serif;

  /* Métricas */
  --max-ancho: 1240px;
  --radio: 10px;
  --radio-sm: 6px;

  /* Sombras (sutiles, presidenciales) */
  --sombra-sm: 0 1px 2px rgba(8, 52, 30, .06);
  --sombra:    0 10px 30px rgba(8, 52, 30, .08);
  --sombra-lg: 0 24px 60px rgba(8, 52, 30, .14);

  --z-header: 50;
  --z-menu: 45;
  --z-top: 60;
  --t: 220ms cubic-bezier(.4, 0, .2, 1);

  --alto-header: 124px; /* recalculado por JS según el header real */
}

/* ---------- 2. RESET ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; scroll-padding-top: 130px; }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .001ms !important; transition-duration: .001ms !important; }
}

body {
  font-family: var(--font-texto);
  color: var(--gris-texto);
  background: var(--blanco);
  line-height: 1.7;
  font-size: 17px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

img { max-width: 100%; display: block; height: auto; }
/* Tamaño base de los íconos SVG (las reglas de cada componente lo sobrescriben) */
svg { width: 1.2em; height: 1.2em; flex: none; vertical-align: -0.18em; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; padding: 0; }
button { font-family: inherit; cursor: pointer; }

/* ---------- 3. TIPOGRAFÍA ---------- */
h1, h2, h3, h4 {
  font-family: var(--font-titulo);
  color: var(--verde-oscuro);
  line-height: 1.2;
  font-weight: 700;
  letter-spacing: -0.01em;
}
h1 { font-size: clamp(2.1rem, 4.4vw, 3.5rem); }
h2 { font-size: clamp(1.7rem, 3vw, 2.5rem); }
h3 { font-size: clamp(1.2rem, 2vw, 1.45rem); }
p  { max-width: 70ch; }

.text-center { text-align: center; }
.mx-auto { margin-left: auto; margin-right: auto; }

/* ---------- 4. LAYOUT ---------- */
.contenedor { width: 100%; max-width: var(--max-ancho); margin-inline: auto; padding-inline: 28px; }
.seccion { padding: clamp(64px, 8vw, 104px) 0; }
.seccion--marfil { background: var(--marfil); }
.seccion--blanco { background: var(--blanco); }
.seccion--verde {
  background:
    radial-gradient(120% 120% at 50% -20%, var(--verde-medio), transparent 60%),
    linear-gradient(180deg, var(--verde-oscuro), #062817);
  color: var(--blanco);
}
.seccion--verde h2, .seccion--verde h3 { color: var(--blanco); }

/* Salto al contenido (accesibilidad) */
.skip-link {
  position: absolute; left: -999px; top: 0;
  background: var(--verde); color: #fff; padding: 12px 20px;
  z-index: var(--z-top); font-weight: 600; border-radius: 0 0 var(--radio-sm) 0;
}
.skip-link:focus { left: 0; }

a:focus-visible, button:focus-visible, input:focus-visible,
textarea:focus-visible, select:focus-visible {
  outline: 3px solid var(--verde-claro); outline-offset: 2px; border-radius: 3px;
}

/* ---------- 5. ENCABEZADO DE SECCIÓN ---------- */
.encabezado-seccion { text-align: center; max-width: 780px; margin: 0 auto 56px; }
.encabezado-seccion .kicker {
  display: inline-flex; align-items: center; gap: 12px;
  font-family: var(--font-texto); text-transform: uppercase;
  letter-spacing: .26em; font-size: .72rem; font-weight: 700;
  color: var(--verde); margin-bottom: 16px;
}
.encabezado-seccion .kicker::before,
.encabezado-seccion .kicker::after { content: ""; width: 30px; height: 1px; background: var(--sello); }
.encabezado-seccion p { margin: 18px auto 0; color: var(--gris-medio); }
.seccion--verde .kicker { color: #BFE3CD; }
.seccion--verde .kicker::before, .seccion--verde .kicker::after { background: rgba(255,255,255,.4); }

/* Filete ornamental */
.ornamento {
  width: 64px; height: 2px; background: var(--sello);
  margin: 20px auto 0; position: relative;
}
.ornamento::after {
  content: ""; position: absolute; left: 50%; top: 50%;
  width: 7px; height: 7px; background: var(--sello); border-radius: 50%;
  transform: translate(-50%, -50%);
}
.ornamento--izq { margin-left: 0; }
.ornamento--izq::after { left: 28px; }

/* ---------- 6. BOTONES ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  min-height: 50px; padding: 0 28px; border-radius: var(--radio-sm);
  font-family: var(--font-texto); font-weight: 600; font-size: .96rem;
  border: 1.5px solid transparent; letter-spacing: .01em;
  transition: background var(--t), color var(--t), border-color var(--t), box-shadow var(--t);
  text-align: center; line-height: 1.1;
}
.btn svg { width: 18px; height: 18px; flex: none; }
.btn:active { transform: translateY(1px); }

.btn--primario { background: var(--verde); color: #fff; box-shadow: var(--sombra-sm); }
.btn--primario:hover { background: var(--verde-oscuro); }

/* Botón claro (sobre fondos verdes/oscuros) */
.btn--dorado { background: #fff; color: var(--verde-oscuro); }
.btn--dorado:hover { background: var(--marfil); }

.btn--linea { background: transparent; color: var(--verde); border-color: var(--verde); }
.btn--linea:hover { background: var(--verde); color: #fff; }

.btn--linea-claro { background: transparent; color: #fff; border-color: rgba(255,255,255,.55); }
.btn--linea-claro:hover { background: #fff; color: var(--verde-oscuro); border-color: #fff; }

.btn--bloque { width: 100%; }
.btn--sm { min-height: 42px; padding: 0 18px; font-size: .9rem; }

/* ---------- 7. HEADER (premium, con profundidad) ---------- */
/* Barra superior de utilidades */
.barra-superior {
  background: linear-gradient(90deg, #062817, var(--verde-oscuro) 55%, #062817);
  color: rgba(255,255,255,.8); font-size: .8rem; position: relative; z-index: calc(var(--z-header) + 1);
}
.barra-superior .contenedor {
  display: flex; justify-content: space-between; align-items: center;
  gap: 20px; min-height: 40px; flex-wrap: wrap;
}
.barra-superior a { transition: color var(--t); }
.barra-superior a:hover { color: #fff; }
.barra-superior .barra-info { display: flex; gap: 26px; align-items: center; }
.barra-superior .barra-info span { display: inline-flex; align-items: center; gap: 8px; white-space: nowrap; }
.barra-superior svg { width: 15px; height: 15px; color: var(--sello-claro); }
.barra-derecha { display: flex; align-items: center; gap: 18px; }
.barra-gestion {
  font-size: .68rem; font-weight: 700; letter-spacing: .22em; text-transform: uppercase;
  color: var(--sello-claro); padding-right: 18px; border-right: 1px solid rgba(255,255,255,.18);
}
.barra-superior .barra-redes { display: flex; gap: 14px; align-items: center; }
.barra-superior .barra-redes a { color: rgba(255,255,255,.75); }
.barra-superior .barra-redes svg { color: inherit; }

/* Encabezado principal con profundidad */
.site-header {
  position: sticky; top: 0; z-index: var(--z-header);
  background: rgba(255,255,255,.92);
  backdrop-filter: saturate(180%) blur(12px);
  border-bottom: 1px solid var(--linea);
  transition: box-shadow var(--t), background var(--t);
}
.site-header::after { /* filete institucional inferior */
  content: ""; display: block; height: 3px;
  background: linear-gradient(90deg, var(--verde-oscuro), var(--verde) 35%, var(--sello-claro) 50%, var(--verde) 65%, var(--verde-oscuro));
}
.site-header.desplazado {
  background: rgba(255,255,255,.98);
  box-shadow: 0 12px 34px rgba(8,52,30,.12);
}
.nav-principal { display: flex; align-items: center; justify-content: space-between; gap: 24px; min-height: 90px; transition: min-height var(--t); }
.site-header.desplazado .nav-principal { min-height: 74px; }

/* Logo institucional refinado */
.logo { display: flex; align-items: center; gap: 16px; }
.logo .escudo {
  width: 56px; height: 56px; flex: none; border-radius: 50%;
  overflow: hidden; background: var(--marfil);
  box-shadow: 0 0 0 1px var(--linea), 0 6px 16px rgba(8,52,30,.14);
  display: grid; place-items: center; transition: transform var(--t);
}
.logo:hover .escudo { transform: scale(1.04); }
.logo .escudo img { width: 100%; height: 100%; object-fit: cover; }
.logo .logo-text { padding-left: 16px; border-left: 1px solid var(--linea); }
.logo .logo-text strong {
  display: block; font-family: var(--font-titulo); color: var(--verde-oscuro);
  font-size: 1.16rem; line-height: 1.1; font-weight: 700; letter-spacing: -0.01em;
}
.logo .logo-text span {
  display: block; font-size: .64rem; letter-spacing: .2em;
  text-transform: uppercase; color: var(--gris-medio); margin-top: 4px;
}

/* Menú principal */
.menu { display: flex; align-items: center; gap: 4px; }
.menu-item { position: relative; }
.menu-link {
  position: relative; display: inline-flex; align-items: center; gap: 6px;
  padding: 11px 15px; border-radius: 8px; background: transparent; border: none;
  font-family: var(--font-texto); font-weight: 500; font-size: .94rem; color: var(--gris-texto);
  transition: color var(--t), background var(--t); cursor: pointer; white-space: nowrap;
}
.menu-link .caret { display: inline-grid; transition: transform var(--t); }
.menu-link .caret svg { width: 16px; height: 16px; }
.menu-link::after {
  content: ""; position: absolute; left: 15px; right: 15px; bottom: 6px; height: 2px;
  background: var(--verde); border-radius: 2px;
  transform: scaleX(0); transform-origin: center; transition: transform var(--t);
}
.menu-link:hover { color: var(--verde); background: var(--verde-tinte); }
.menu-link:hover::after, .menu-link[aria-current="page"]::after { transform: scaleX(.7); }
.menu-link[aria-current="page"] { color: var(--verde); font-weight: 600; }
.menu-item.activo > .menu-link { color: var(--verde); font-weight: 600; }
.menu-item.abierta > .menu-link { color: var(--verde); background: var(--verde-tinte); }
.menu-item.abierta > .menu-link .caret { transform: rotate(180deg); }

/* Mega-menú desplegable (profundidad) */
.dropdown {
  position: absolute; top: calc(100% + 12px); left: 50%; transform: translateX(-50%) translateY(8px);
  min-width: 340px; background: #fff; border: 1px solid var(--linea); border-radius: 14px;
  box-shadow: 0 28px 60px rgba(8,52,30,.18); padding: 12px;
  opacity: 0; visibility: hidden; transition: opacity var(--t), transform var(--t); z-index: var(--z-menu);
}
.dropdown::before { /* puente invisible para no perder el hover */
  content: ""; position: absolute; top: -14px; left: 0; right: 0; height: 16px;
}
.dropdown::after { /* flechita superior */
  content: ""; position: absolute; top: -7px; left: 50%; transform: translateX(-50%) rotate(45deg);
  width: 14px; height: 14px; background: #fff; border-left: 1px solid var(--linea); border-top: 1px solid var(--linea);
}
.menu-item.tiene-sub:hover > .dropdown,
.menu-item.tiene-sub:focus-within > .dropdown,
.menu-item.abierta > .dropdown { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
.dropdown ul { display: grid; gap: 4px; }
.dropdown a {
  display: flex; gap: 14px; align-items: flex-start; padding: 14px; border-radius: 10px;
  transition: background var(--t);
}
.dropdown a:hover { background: var(--marfil); }
.dropdown a[aria-current="page"] { background: var(--verde-tinte); }
.dropdown .mm-ico {
  width: 42px; height: 42px; flex: none; border-radius: 10px; display: grid; place-items: center;
  background: var(--verde-tinte); color: var(--verde); border: 1px solid #d9e6dd;
}
.dropdown .mm-ico svg { width: 22px; height: 22px; }
.dropdown a:hover .mm-ico { background: var(--verde); color: #fff; }
.dropdown .mm-txt strong { display: block; font-family: var(--font-titulo); color: var(--verde-oscuro); font-size: 1rem; }
.dropdown .mm-txt span { display: block; font-size: .82rem; color: var(--gris-medio); margin-top: 2px; line-height: 1.4; }

/* La opción "Transparencia" dentro del menú solo se ve en móvil */
.menu-item.solo-movil { display: none; }

.nav-acciones { display: flex; align-items: center; gap: 12px; }
.btn--transparencia { box-shadow: 0 8px 20px rgba(11,93,52,.22); }
.menu-toggle {
  display: none; background: transparent; border: 1.5px solid var(--linea);
  width: 48px; height: 48px; border-radius: 10px; color: var(--verde); place-items: center;
}
.menu-toggle svg { width: 24px; height: 24px; }

/* ---------- 8. HERO (presidencial, centrado) ---------- */
.hero {
  position: relative; color: #fff; text-align: center;
  background:
    radial-gradient(130% 110% at 50% -10%, var(--verde-medio), transparent 55%),
    linear-gradient(180deg, var(--verde-oscuro), #052414);
  padding: clamp(64px, 10vw, 110px) 0 clamp(72px, 11vw, 120px);
  overflow: hidden;
}
/* Marca de agua geométrica sutil (no distrae) */
.hero::before {
  content: ""; position: absolute; inset: 0; z-index: 1;
  background-image:
    radial-gradient(circle at 50% 36%, rgba(255,255,255,.06) 0 1px, transparent 1px);
  background-size: 26px 26px; opacity: .5; pointer-events: none;
}

/* Carrusel de fondo (marca de agua giratoria) */
.hero-fondo { position: absolute; inset: 0; z-index: 0; overflow: hidden; }
.hero-slide {
  position: absolute; inset: 0; background-position: center; background-size: cover; background-repeat: no-repeat;
  opacity: 0; transform: scale(1.06); transition: opacity 1.8s ease;
}
.hero-slide.activa { opacity: 1; animation: heroKenBurns 9s ease-out forwards; }
@keyframes heroKenBurns { from { transform: scale(1.06); } to { transform: scale(1.16); } }
.hero-velo {
  position: absolute; inset: 0;
  background:
    radial-gradient(130% 110% at 50% -10%, rgba(20,146,79,.22), transparent 55%),
    linear-gradient(180deg, rgba(6,40,23,.40), rgba(4,26,15,.60));
}
@media (prefers-reduced-motion: reduce) {
  .hero-slide { transition: none; }
  .hero-slide.activa { animation: none; transform: none; }
}

.hero .contenedor { position: relative; z-index: 2; max-width: 900px; }

.hero .gestion {
  display: inline-flex; align-items: center; gap: 10px;
  border: 1px solid rgba(201,224,210,.4); color: var(--sello-claro);
  background: rgba(255,255,255,.04);
  padding: 9px 22px; border-radius: 100px; text-transform: uppercase;
  letter-spacing: .24em; font-size: .72rem; font-weight: 700; margin-bottom: 28px;
}
.hero h1 { color: #fff; margin-bottom: 0; font-weight: 800; letter-spacing: -0.015em; }
/* Filete bajo el título (sello presidencial) */
.hero-rule {
  display: block; width: 90px; height: 3px; margin: 24px auto 26px;
  background: var(--sello-claro); position: relative; border-radius: 3px;
}
.hero-rule::before, .hero-rule::after {
  content: ""; position: absolute; top: 50%; transform: translateY(-50%);
  width: 36px; height: 1px; background: rgba(255,255,255,.35);
}
.hero-rule::before { right: calc(100% + 14px); }
.hero-rule::after { left: calc(100% + 14px); }
.hero .subtitulo { font-size: clamp(1.05rem, 2vw, 1.28rem); color: rgba(255,255,255,.9); max-width: 620px; margin: 0 auto; }
.hero .alcalde-linea {
  display: inline-flex; align-items: center; justify-content: center; gap: 14px;
  flex-wrap: wrap; max-width: 100%; margin: 28px auto 34px;
  font-family: var(--font-titulo); font-style: italic; font-size: 1.12rem; color: #DCEFE3;
}
.hero .alcalde-linea::before, .hero .alcalde-linea::after { content: ""; width: 30px; height: 1px; background: var(--sello-claro); }
.hero-botones { display: flex; gap: 14px; flex-wrap: wrap; justify-content: center; }

/* Cinta institucional inferior del hero */
.hero-cinta {
  background: var(--marfil); color: var(--verde-oscuro);
  font-family: var(--font-titulo); font-style: italic; text-align: center;
  padding: 16px 24px; font-size: clamp(1rem, 2vw, 1.22rem);
  border-bottom: 1px solid var(--linea);
}

/* ---------- 9. TARJETAS / GRIDS ---------- */
.grid { display: grid; gap: 26px; }
.grid--2 { grid-template-columns: repeat(2, 1fr); }
.grid--3 { grid-template-columns: repeat(3, 1fr); }
.grid--4 { grid-template-columns: repeat(4, 1fr); }
.grid--auto { grid-template-columns: repeat(auto-fill, minmax(290px, 1fr)); }

.tarjeta {
  background: var(--blanco); border: 1px solid var(--linea); border-radius: var(--radio);
  padding: 32px; box-shadow: var(--sombra-sm); position: relative; overflow: hidden; height: 100%;
  transition: transform var(--t), box-shadow var(--t), border-color var(--t);
}
.tarjeta::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: var(--verde); transform: scaleX(0); transform-origin: left; transition: transform var(--t);
}
.tarjeta:hover { transform: translateY(-5px); box-shadow: var(--sombra); border-color: #d4dad5; }
.tarjeta:hover::before { transform: scaleX(1); }

.icono-circulo {
  width: 58px; height: 58px; border-radius: 12px; display: grid; place-items: center;
  margin-bottom: 20px; background: var(--verde-tinte); color: var(--verde);
  border: 1px solid #d9e6dd; transition: background var(--t), color var(--t);
}
.icono-circulo svg { width: 28px; height: 28px; }
.tarjeta:hover .icono-circulo { background: var(--verde); color: #fff; }
.tarjeta h3 { margin-bottom: 10px; }
.tarjeta p { color: var(--gris-medio); font-size: .96rem; }
.tarjeta .responsable {
  display: inline-flex; align-items: center; gap: 8px; margin-top: 16px;
  font-size: .86rem; color: var(--verde); font-weight: 600;
}
.tarjeta .responsable svg { width: 16px; height: 16px; }
.tarjeta-pie { margin-top: 22px; }

/* Accesos rápidos */
.acceso {
  display: flex; align-items: center; gap: 16px; background: var(--blanco);
  border: 1px solid var(--linea); border-radius: var(--radio); padding: 22px;
  transition: transform var(--t), box-shadow var(--t), border-color var(--t);
}
.acceso:hover { transform: translateY(-4px); box-shadow: var(--sombra); border-color: var(--verde); }
.acceso .icono-circulo { margin: 0; width: 50px; height: 50px; }
.acceso .icono-circulo svg { width: 24px; height: 24px; }
.acceso strong { display: block; color: var(--verde-oscuro); font-family: var(--font-titulo); font-size: 1.05rem; }
.acceso .sub { font-size: .85rem; color: var(--gris-medio); }
.acceso .flecha { margin-left: auto; color: var(--verde); display: grid; transition: transform var(--t); }
.acceso .flecha svg { width: 20px; height: 20px; }
.acceso:hover .flecha { transform: translateX(4px); }

/* ---------- 10. NOTICIAS ---------- */
.noticia-card { display: flex; flex-direction: column; padding: 0; }
.noticia-card .img-wrap { aspect-ratio: 16 / 10; overflow: hidden; display: block; }
.noticia-card .img-wrap img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s ease; }
.noticia-card:hover .img-wrap img { transform: scale(1.05); }
.noticia-card .cuerpo { padding: 26px 28px 30px; display: flex; flex-direction: column; flex: 1; }
.etiqueta {
  display: inline-flex; align-items: center; gap: 6px; align-self: flex-start;
  background: var(--verde-tinte); color: var(--verde); font-size: .7rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .08em; padding: 6px 13px; border-radius: 100px;
}
.etiqueta--claro { background: rgba(255,255,255,.16); color: #fff; }
.noticia-card .fecha { font-size: .82rem; color: var(--gris-medio); margin: 16px 0 8px; display: flex; align-items: center; gap: 7px; }
.noticia-card .fecha svg { width: 15px; height: 15px; }
.noticia-card h3 { font-size: 1.22rem; }
.noticia-card p { color: var(--gris-medio); font-size: .95rem; margin-top: 10px; }
.noticia-card .leer-mas {
  margin-top: auto; padding-top: 20px; display: inline-flex; align-items: center; gap: 8px;
  color: var(--verde); font-weight: 600; font-size: .92rem;
}
.noticia-card .leer-mas svg { width: 16px; height: 16px; transition: transform var(--t); }
.noticia-card:hover .leer-mas svg { transform: translateX(4px); }

/* ---------- 11. GACETA ---------- */
.filtros {
  display: flex; gap: 18px; flex-wrap: wrap; align-items: flex-end;
  background: var(--blanco); border: 1px solid var(--linea); border-radius: var(--radio);
  padding: 24px; margin-bottom: 40px; box-shadow: var(--sombra-sm);
}
.campo { display: flex; flex-direction: column; gap: 8px; flex: 1; min-width: 190px; }
.campo label { font-size: .82rem; font-weight: 600; color: var(--verde-oscuro); }
.campo input, .campo select, .campo textarea {
  font-family: inherit; font-size: .96rem; padding: 13px 14px; border: 1.5px solid var(--linea);
  border-radius: var(--radio-sm); background: var(--blanco); color: var(--gris-texto);
  min-height: 50px; transition: border-color var(--t), box-shadow var(--t); width: 100%;
}
.campo textarea { min-height: 140px; resize: vertical; }
.campo input:focus, .campo select:focus, .campo textarea:focus {
  border-color: var(--verde); box-shadow: 0 0 0 3px rgba(11,93,52,.12); outline: none;
}
.campo .obligatorio { color: #b91c1c; }
.campo-busqueda { position: relative; }
.campo-busqueda .lupa { position: absolute; left: 14px; top: 39px; width: 20px; height: 20px; color: var(--gris-medio); pointer-events: none; }
.campo-busqueda .lupa svg { width: 20px; height: 20px; }
.campo-busqueda input { padding-left: 44px; }

.doc-card { display: flex; gap: 22px; align-items: flex-start; }
.doc-card .doc-icono {
  width: 56px; height: 66px; flex: none; border-radius: var(--radio-sm);
  background: var(--verde-tinte); color: var(--verde); display: grid; place-items: center; border: 1px solid #d9e6dd;
}
.doc-card .doc-icono svg { width: 28px; height: 28px; }
.doc-card .doc-info { flex: 1; min-width: 0; }
.doc-card .doc-meta { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; margin-bottom: 12px; }
.doc-card .codigo { font-size: .78rem; color: var(--gris-medio); font-weight: 600; }
.doc-card h3 { font-size: 1.12rem; margin-bottom: 8px; }
.doc-card p { font-size: .92rem; color: var(--gris-medio); }
.doc-card .doc-acciones { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 20px; }
.sin-resultados { text-align: center; padding: 64px 20px; color: var(--gris-medio); grid-column: 1 / -1; }
.sin-resultados svg { width: 40px; height: 40px; color: var(--linea); }

/* ---------- 12. RADIO ---------- */
.reproductor {
  background:
    radial-gradient(120% 120% at 80% -10%, var(--verde-medio), transparent 55%),
    linear-gradient(140deg, var(--verde-oscuro), #052414);
  color: #fff; border-radius: var(--radio); padding: 42px; box-shadow: var(--sombra-lg);
  position: relative; overflow: hidden;
}
.reproductor .en-vivo {
  display: inline-flex; align-items: center; gap: 9px; background: rgba(255,255,255,.1);
  padding: 6px 15px; border-radius: 100px; font-size: .76rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .14em; margin-bottom: 20px;
}
.reproductor .punto-vivo {
  width: 9px; height: 9px; border-radius: 50%; background: #ff5a5a;
  box-shadow: 0 0 0 0 rgba(255,90,90,.6); animation: pulso 1.8s infinite;
}
@keyframes pulso { 0%{box-shadow:0 0 0 0 rgba(255,90,90,.6)} 70%{box-shadow:0 0 0 12px rgba(255,90,90,0)} 100%{box-shadow:0 0 0 0 rgba(255,90,90,0)} }
.reproductor h3 { color: #fff; font-size: 1.8rem; }
.reproductor p { color: rgba(255,255,255,.85); }
.reproductor-controles { display: flex; align-items: center; gap: 22px; margin-top: 28px; flex-wrap: wrap; }
.btn-play {
  width: 76px; height: 76px; border-radius: 50%; flex: none; background: #fff; color: var(--verde-oscuro);
  border: none; display: grid; place-items: center; box-shadow: var(--sombra); transition: transform var(--t), background var(--t);
}
.btn-play:hover { background: var(--marfil); transform: scale(1.05); }
.btn-play svg { width: 34px; height: 34px; }
.btn-play .icon-pause { display: none; }
.btn-play[aria-pressed="true"] .icon-play { display: none; }
.btn-play[aria-pressed="true"] .icon-pause { display: block; }
.ondas { display: flex; align-items: center; gap: 4px; height: 40px; }
.ondas span { width: 4px; background: #BFE3CD; border-radius: 4px; height: 30%; }
.reproductor.sonando .ondas span { animation: onda 1s ease-in-out infinite; }
.ondas span:nth-child(1){animation-delay:0s} .ondas span:nth-child(2){animation-delay:.15s}
.ondas span:nth-child(3){animation-delay:.3s} .ondas span:nth-child(4){animation-delay:.45s}
.ondas span:nth-child(5){animation-delay:.2s} .ondas span:nth-child(6){animation-delay:.5s} .ondas span:nth-child(7){animation-delay:.35s}
@keyframes onda { 0%,100%{height:25%} 50%{height:95%} }
.volumen { display: flex; align-items: center; gap: 10px; }
.volumen input[type="range"] { accent-color: #BFE3CD; width: 130px; }

.programa-item { display: flex; gap: 18px; align-items: center; padding: 16px 0; border-bottom: 1px solid var(--linea); }
.programa-item:last-child { border-bottom: none; }
.programa-item .hora { font-family: var(--font-titulo); color: var(--verde); font-weight: 700; min-width: 116px; font-size: .95rem; }
.programa-item strong { display: block; color: var(--verde-oscuro); }
.programa-item span { font-size: .88rem; color: var(--gris-medio); }

/* ---------- 13. QUIÉNES SOMOS ---------- */
.bloque-alcalde { display: grid; grid-template-columns: 340px 1fr; gap: 48px; align-items: center; }
.bloque-alcalde .retrato {
  border-radius: var(--radio); overflow: hidden; box-shadow: var(--sombra-lg);
  border: 5px solid #fff; position: relative; outline: 1px solid var(--linea);
}
.bloque-alcalde .cargo { color: var(--verde); font-weight: 700; letter-spacing: .14em; text-transform: uppercase; font-size: .78rem; }
.cita {
  font-family: var(--font-titulo); font-style: italic; font-size: clamp(1.15rem, 2vw, 1.5rem);
  color: var(--verde-oscuro); border-left: 3px solid var(--sello); padding-left: 26px; line-height: 1.55;
}
.firma { margin-top: 24px; font-family: var(--font-titulo); }
.firma strong { display: block; color: var(--verde-oscuro); font-size: 1.1rem; }
.firma span { color: var(--gris-medio); font-size: .9rem; font-family: var(--font-texto); }

.mv-card .icono-circulo { background: var(--verde-tinte); color: var(--verde); }
.valor-item { display: flex; gap: 14px; align-items: flex-start; }
.valor-item .check { width: 38px; height: 38px; border-radius: 9px; flex: none; background: var(--verde); color: #fff; display: grid; place-items: center; }
.valor-item .check svg { width: 20px; height: 20px; }
.valor-item strong { display: block; color: var(--verde-oscuro); }
.valor-item p { font-size: .92rem; color: var(--gris-medio); margin-top: 2px; }

/* ---------- 14. CONTACTO ---------- */
.contacto-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start; }
.dato-contacto { display: flex; gap: 16px; align-items: flex-start; padding: 18px 0; border-bottom: 1px solid var(--linea); }
.dato-contacto:last-child { border-bottom: none; }
.dato-contacto .icono-circulo { margin: 0; width: 48px; height: 48px; flex: none; }
.dato-contacto .icono-circulo svg { width: 22px; height: 22px; }
.dato-contacto strong { display: block; color: var(--verde-oscuro); font-family: var(--font-titulo); }
.dato-contacto a, .dato-contacto p { color: var(--gris-medio); font-size: .95rem; }
.dato-contacto a:hover { color: var(--verde); }
.mapa-wrap { border-radius: var(--radio); overflow: hidden; box-shadow: var(--sombra); border: 1px solid var(--linea); }
.mapa-wrap iframe { width: 100%; height: 320px; border: 0; display: block; }

.aviso-form {
  display: none; align-items: center; gap: 12px; background: var(--verde-tinte);
  color: var(--verde-oscuro); border: 1px solid #cfe2d6; border-radius: var(--radio-sm);
  padding: 16px 18px; margin-top: 18px; font-size: .95rem;
}
.aviso-form.visible { display: flex; }
.aviso-form svg { width: 24px; height: 24px; color: var(--verde); flex: none; }

.whatsapp-flotante {
  position: fixed; right: 22px; bottom: 22px; z-index: var(--z-top);
  width: 58px; height: 58px; border-radius: 50%; background: #1FA855; color: #fff;
  display: grid; place-items: center; box-shadow: 0 10px 28px rgba(31,168,85,.4); transition: transform var(--t);
}
.whatsapp-flotante:hover { transform: scale(1.07); }
.whatsapp-flotante svg { width: 30px; height: 30px; }

/* ---------- 15. TRANSPARENCIA ---------- */
.transp-card { text-align: left; }

/* Banda de estadísticas */
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; text-align: center; }
.stat .numero { font-family: var(--font-titulo); font-size: clamp(2.2rem, 4vw, 3rem); color: #fff; font-weight: 700; }
.stat .numero small { color: #BFE3CD; }
.stat .etiqueta-stat { color: rgba(255,255,255,.85); font-size: .95rem; margin-top: 6px; }
.stat { position: relative; padding: 0 10px; }
.stat:not(:last-child)::after { content: ""; position: absolute; right: 0; top: 10%; height: 80%; width: 1px; background: rgba(255,255,255,.18); }

/* ---------- 16. BANNER PÁGINA INTERIOR ---------- */
.banner-pagina {
  background:
    radial-gradient(120% 130% at 50% -30%, var(--verde-medio), transparent 55%),
    linear-gradient(180deg, var(--verde-oscuro), #062817);
  color: #fff; padding: clamp(60px, 9vw, 100px) 0 clamp(52px, 7vw, 76px); position: relative; overflow: hidden;
}
.banner-pagina::before {
  content: ""; position: absolute; inset: 0;
  background-image: radial-gradient(circle at 50% 30%, rgba(255,255,255,.05) 0 1px, transparent 1px);
  background-size: 26px 26px; opacity: .5;
}
.banner-pagina .contenedor { position: relative; z-index: 1; }
.banner-pagina h1 { color: #fff; }
.banner-pagina p { color: rgba(255,255,255,.9); max-width: 680px; margin-top: 14px; }
.migas { display: flex; gap: 9px; align-items: center; font-size: .85rem; color: rgba(255,255,255,.72); margin-bottom: 20px; flex-wrap: wrap; }
.migas a:hover { color: #fff; }
.migas svg { width: 14px; height: 14px; }

/* ---------- 17. FOOTER ---------- */
.site-footer { background: var(--verde-oscuro); color: rgba(255,255,255,.78); }
.footer-top { padding: 68px 0 50px; }
.footer-grid { display: grid; grid-template-columns: 1.7fr 1fr 1fr 1.2fr; gap: 44px; }
.site-footer .logo .logo-text strong, .site-footer h4 { color: #fff; }
.site-footer .logo .logo-text span { color: rgba(255,255,255,.6); }
.site-footer .logo .escudo { width: 52px; height: 52px; border-color: rgba(255,255,255,.2); }
.site-footer h4 { font-family: var(--font-titulo); font-size: 1.12rem; margin-bottom: 22px; position: relative; padding-bottom: 12px; }
.site-footer h4::after { content: ""; position: absolute; left: 0; bottom: 0; width: 42px; height: 2px; background: var(--sello-claro); }
.footer-desc { margin-top: 18px; font-size: .92rem; max-width: 330px; line-height: 1.75; }
.footer-links li { margin-bottom: 11px; }
.footer-links a { font-size: .93rem; transition: color var(--t), padding-left var(--t); display: inline-flex; align-items: center; gap: 8px; }
.footer-links a svg { width: 14px; height: 14px; color: var(--verde-claro); }
.footer-links a:hover { color: #fff; padding-left: 4px; }
.footer-contacto li { display: flex; gap: 11px; align-items: flex-start; margin-bottom: 14px; font-size: .92rem; }
.footer-contacto svg { width: 18px; height: 18px; color: #BFE3CD; flex: none; margin-top: 3px; }
.footer-redes { display: flex; gap: 12px; margin-top: 22px; }
.footer-redes a {
  width: 42px; height: 42px; border-radius: 50%; display: grid; place-items: center;
  background: rgba(255,255,255,.08); transition: background var(--t), transform var(--t);
}
.footer-redes a:hover { background: var(--verde-claro); transform: translateY(-3px); }
.footer-redes svg { width: 20px; height: 20px; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.12); }
.footer-bottom .contenedor {
  display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap;
  padding-top: 22px; padding-bottom: 22px; font-size: .85rem; color: rgba(255,255,255,.62);
}

/* ---------- 17b. MODAL (detalle de dirección) ---------- */
.modal-overlay {
  position: fixed; inset: 0; z-index: var(--z-top); background: rgba(6,33,20,.6);
  backdrop-filter: blur(3px); display: grid; place-items: center; padding: 24px;
  opacity: 0; transition: opacity var(--t);
}
.modal-overlay.abierto { opacity: 1; }
.modal {
  background: #fff; border-radius: var(--radio); max-width: 580px; width: 100%; max-height: 88vh;
  overflow-y: auto; padding: 42px; box-shadow: var(--sombra-lg); border-top: 4px solid var(--verde);
  transform: translateY(20px) scale(.98); transition: transform var(--t); position: relative;
}
.modal-overlay.abierto .modal { transform: none; }
.modal-cerrar {
  position: absolute; top: 16px; right: 16px; width: 42px; height: 42px; border-radius: 50%;
  border: 1px solid var(--linea); background: var(--marfil); color: var(--verde-oscuro);
  display: grid; place-items: center; transition: background var(--t);
}
.modal-cerrar:hover { background: var(--linea); }
.modal-cerrar svg { width: 22px; height: 22px; }
.modal-contacto { display: flex; flex-direction: column; gap: 10px; margin-top: 26px; padding-top: 22px; border-top: 1px solid var(--linea); }

/* ---------- 18. ANIMACIONES AL SCROLL ---------- */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity .7s ease, transform .7s ease; }
.reveal.visible { opacity: 1; transform: none; }
.reveal.d1 { transition-delay: .08s; } .reveal.d2 { transition-delay: .16s; }
.reveal.d3 { transition-delay: .24s; } .reveal.d4 { transition-delay: .32s; }
@media (prefers-reduced-motion: reduce) { .reveal { opacity: 1; transform: none; } }

/* ---------- 18a. MODO MANTENIMIENTO ---------- */
body.mant-activo { overflow: hidden; }
.mant-screen {
  position: fixed; inset: 0; z-index: 9999;
  background-size: cover; background-position: center; background-repeat: no-repeat;
  display: grid; place-items: center; padding: 24px; color: #fff;
}
.mant-screen::before {
  content: ""; position: absolute; inset: 0;
  background-image: radial-gradient(circle at 50% 30%, rgba(255,255,255,.05) 0 1px, transparent 1px);
  background-size: 26px 26px; opacity: .5; pointer-events: none;
}
.mant-box {
  position: relative; z-index: 1; max-width: 620px; text-align: center;
  background: rgba(255,255,255,.06); backdrop-filter: blur(4px);
  border: 1px solid rgba(255,255,255,.16); border-radius: 20px;
  padding: clamp(34px, 6vw, 56px); box-shadow: 0 30px 70px rgba(0,0,0,.35);
}
.mant-logo {
  width: 110px; height: 110px; display: inline-grid; place-items: center; margin-bottom: 24px;
  background: var(--marfil); border-radius: 50%; padding: 6px;
  box-shadow: 0 0 0 1px rgba(255,255,255,.25), var(--sombra-lg);
}
.mant-logo img { width: 100%; height: 100%; border-radius: 50%; object-fit: cover; }
.mant-box h1 { color: #fff; font-size: clamp(1.7rem, 4vw, 2.6rem); margin: 0; text-shadow: 0 2px 16px rgba(0,0,0,.4); }
.mant-sep { display: block; width: 80px; height: 3px; background: var(--sello-claro); border-radius: 3px; margin: 20px auto; }
.mant-box p { color: rgba(255,255,255,.92); font-size: clamp(1rem, 2vw, 1.18rem); line-height: 1.7; margin: 0 auto; max-width: 48ch; }
.mant-pie { display: block; margin-top: 28px; font-family: var(--font-titulo); font-style: italic; color: var(--sello-claro); font-size: .95rem; }

/* ---------- 18b. DETALLES PREMIUM (secciones internas) ---------- */

/* Noticias: etiqueta de categoría sobre la imagen + degradado */
.noticia-card .img-wrap { position: relative; }
.noticia-card .img-wrap::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(6,33,20,.58), rgba(6,33,20,.05) 48%, transparent 70%);
  pointer-events: none;
}
.etiqueta--overlay {
  position: absolute; left: 16px; bottom: 14px; z-index: 1;
  background: rgba(255,255,255,.94); color: var(--verde);
  box-shadow: 0 6px 16px rgba(6,33,20,.28);
  border: 1px solid rgba(255,255,255,.5);
}
.noticia-card .cuerpo { padding-top: 24px; }
.noticia-card h3 a { background: linear-gradient(var(--verde), var(--verde)) no-repeat 0 100% / 0 2px; transition: background-size var(--t), color var(--t); padding-bottom: 2px; }
.noticia-card:hover h3 a { background-size: 100% 2px; color: var(--verde); }

/* Direcciones: numeración tipo expediente institucional */
.direccion-card { overflow: hidden; }
.dir-num {
  position: absolute; top: 18px; right: 24px; line-height: 1; pointer-events: none;
  font-family: var(--font-titulo); font-size: 3.4rem; font-weight: 800;
  color: var(--verde); opacity: .07; transition: opacity var(--t), transform var(--t);
}
.direccion-card:hover .dir-num { opacity: .13; transform: translateY(-2px); }
.direccion-card h3 { padding-right: 48px; }

/* Gaceta: documentos con insignia PDF y jerarquía refinada */
.doc-card { transition: transform var(--t), box-shadow var(--t), border-color var(--t); }
.doc-card .doc-icono { position: relative; overflow: visible; }
.doc-card .doc-icono::before { /* esquina doblada de hoja */
  content: ""; position: absolute; top: 0; right: 0; width: 16px; height: 16px;
  background: linear-gradient(225deg, #fff 0 50%, transparent 50%);
  border-top-right-radius: var(--radio-sm);
}
.doc-formato {
  position: absolute; bottom: -9px; left: 50%; transform: translateX(-50%);
  background: var(--verde); color: #fff; font-size: .58rem; font-weight: 700;
  letter-spacing: .1em; padding: 3px 8px; border-radius: 5px; box-shadow: var(--sombra-sm);
}
.doc-fecha { margin-top: 10px; display: inline-flex; align-items: center; gap: 6px; }
.doc-card h3 { transition: color var(--t); }
.doc-card:hover h3 { color: var(--verde); }

/* Apartado App / Play Store */
.app-promo-sec {
  background:
    radial-gradient(120% 120% at 80% -10%, var(--verde-medio), transparent 55%),
    linear-gradient(180deg, var(--verde-oscuro), #052414);
  color: #fff;
}
.app-promo { display: grid; grid-template-columns: 360px 1fr; gap: 48px; align-items: center; }
.app-promo .app-img { display: block; }
.app-promo .app-img img { width: 100%; max-width: 360px; margin: 0 auto; display: block; filter: drop-shadow(0 24px 50px rgba(0,0,0,.35)); transition: transform var(--t); }
.app-promo .app-img:hover img { transform: translateY(-6px); }
.app-promo .kicker { color: var(--sello-claro); }
.app-promo .app-txt h2 { color: #fff; font-size: clamp(1.7rem, 3.5vw, 2.6rem); margin: 6px 0 14px; }
.app-promo .app-txt p { color: rgba(255,255,255,.9); font-size: 1.08rem; max-width: 48ch; margin-bottom: 26px; }
.btn-playstore {
  display: inline-flex; align-items: center; gap: 12px;
  background: #0b0d10; color: #fff; border: 1px solid rgba(255,255,255,.18);
  padding: 12px 22px; border-radius: 12px; transition: transform var(--t), background var(--t);
}
.btn-playstore:hover { transform: translateY(-2px); background: #16181c; }
.btn-playstore span { display: flex; flex-direction: column; line-height: 1.1; text-align: left; }
.btn-playstore small { font-size: .62rem; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.75); }
.btn-playstore strong { font-family: var(--font-titulo); font-size: 1.2rem; font-weight: 700; }
@media (max-width: 820px) {
  .app-promo { grid-template-columns: 1fr; gap: 28px; text-align: center; }
  .app-promo .kicker { justify-content: center; }
  .app-promo .app-txt p { margin-left: auto; margin-right: auto; }
  .app-promo .app-img img { max-width: 260px; }
}

/* Compartir en tarjetas del listado */
.card-pie { margin-top: auto; padding-top: 18px; display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.noticia-card .card-pie .leer-mas { margin-top: 0; padding-top: 0; }
.card-share { display: inline-flex; gap: 8px; }
.card-share .cs { width: 34px; height: 34px; border-radius: 50%; display: grid; place-items: center; color: #fff; transition: transform var(--t), filter var(--t); }
.card-share .cs svg { width: 17px; height: 17px; }
.card-share .cs:hover { transform: translateY(-2px); filter: brightness(1.08); }
.card-share .cs-fb { background: #1877F2; }
.card-share .cs-wa { background: #25D366; }

/* Compartir en redes (página de noticia) */
.compartir {
  margin-top: 34px; padding: 22px 24px; border: 1px solid var(--linea);
  border-radius: var(--radio); background: var(--marfil);
  display: flex; align-items: center; gap: 18px; flex-wrap: wrap;
}
.compartir-tit { font-family: var(--font-titulo); font-weight: 700; color: var(--verde-oscuro); }
.compartir-botones { display: flex; gap: 10px; flex-wrap: wrap; }
.btn-share {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 16px; border-radius: var(--radio-sm); border: none;
  font-family: var(--font-texto); font-weight: 600; font-size: .9rem; color: #fff;
  cursor: pointer; transition: transform var(--t), filter var(--t), background var(--t);
}
.btn-share:hover { transform: translateY(-2px); filter: brightness(1.06); }
.btn-share svg { width: 18px; height: 18px; }
.btn-fb { background: #1877F2; }
.btn-wa { background: #25D366; }
.btn-copiar { background: var(--verde); }
@media (max-width: 560px) {
  .compartir { flex-direction: column; align-items: stretch; }
  .compartir-botones { display: grid; grid-template-columns: 1fr; }
  .btn-share { justify-content: center; }
}

/* Hero: tono más rico y título con presencia */
.hero { box-shadow: inset 0 -90px 120px -70px rgba(0,0,0,.45); }
.hero h1 { font-size: clamp(2.2rem, 4.8vw, 3.75rem); text-shadow: 0 2px 18px rgba(4,26,15,.55), 0 1px 4px rgba(4,26,15,.5); }
.hero .subtitulo { line-height: 1.7; }

/* ---------- 19. RESPONSIVE ---------- */
@media (max-width: 1180px) {
  .menu-link { padding: 10px 11px; font-size: .9rem; }
  .menu { gap: 0; }
  .nav-principal { gap: 16px; }
}
@media (max-width: 1010px) {
  .logo .logo-text strong { font-size: 1.02rem; }
  .barra-gestion { display: none; }
}
@media (max-width: 1024px) {
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 38px; }
  .stats { grid-template-columns: repeat(2, 1fr); gap: 38px; }
  .stat:nth-child(2)::after { display: none; }
  .grid--4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 920px) {
  /* ---- Menú móvil (panel deslizante + acordeón) ---- */
  .menu-toggle { display: grid; }
  .nav-acciones .btn--transparencia { display: none; }
  .menu {
    position: fixed; top: var(--alto-header); left: 0; right: 0; flex-direction: column;
    align-items: stretch; gap: 0; background: #fff; padding: 14px 24px 32px;
    border-bottom: 3px solid var(--verde); box-shadow: var(--sombra-lg);
    transform: translateY(-145%); transition: transform var(--t); z-index: var(--z-menu);
    max-height: calc(100dvh - var(--alto-header)); overflow-y: auto;
  }
  .menu.abierto { transform: translateY(0); }
  .menu-item { border-bottom: 1px solid var(--linea); }
  .menu-item.solo-movil { display: block; border: none; }
  .menu-link {
    width: 100%; justify-content: space-between; padding: 16px 6px; font-size: 1.02rem; border-radius: 0;
  }
  .menu-link::after { display: none; }
  .menu-link:hover { background: transparent; }

  /* Mega-menú como acordeón en móvil */
  .dropdown {
    position: static; transform: none; opacity: 1; visibility: visible;
    min-width: 0; border: none; box-shadow: none; padding: 0 0 10px;
    display: none; border-radius: 0;
  }
  .dropdown::before, .dropdown::after { display: none; }
  .menu-item.abierta > .dropdown { display: block; }
  .dropdown a { padding: 12px 6px 12px 14px; border-radius: 8px; }
  .dropdown .mm-ico { width: 36px; height: 36px; }

  .btn--transparencia-movil {
    display: inline-flex; margin-top: 20px; justify-content: center;
    padding: 0 18px; min-height: 46px; color: #fff; width: 100%;
  }
}
@media (max-width: 860px) {
  .grid--3, .grid--2 { grid-template-columns: 1fr; }
  .bloque-alcalde { grid-template-columns: 1fr; gap: 30px; }
  .bloque-alcalde .retrato { max-width: 320px; }
  .contacto-grid { grid-template-columns: 1fr; gap: 34px; }
}
@media (max-width: 620px) {
  body { font-size: 16px; }
  .contenedor { padding-inline: 20px; }
  .grid--4 { grid-template-columns: 1fr; }
  .stats { grid-template-columns: 1fr 1fr; gap: 28px; }
  .stat::after { display: none !important; }
  .hero-botones .btn { width: 100%; }
  .hero h1 { font-size: clamp(1.6rem, 6.6vw, 2.4rem); }
  .hero .subtitulo { font-size: 1.02rem; overflow-wrap: break-word; }
  .hero .alcalde-linea { display: block; font-size: 1.02rem; }
  .hero .alcalde-linea::before, .hero .alcalde-linea::after { display: none; }
  .hero .emblema { width: 96px; height: 96px; }
  .tarjeta { padding: 26px; }
  .reproductor { padding: 28px; }
  .barra-superior .barra-info span.ocultar-movil { display: none; }
  .footer-grid { grid-template-columns: 1fr; }
  .doc-card { flex-direction: column; }
  .logo .logo-text span { display: none; }
}
