/* =============================================
   1 SHORTCODE — HERO
   ============================================= */
.mppeu-hero {
    position: relative;
    width: 100%;
}

/* --- Modo Slider --- */
.mppeu-hero-slider-mode { background: #0d1117; }

.mppeu-slider-full {
    position: relative;
    width: 100%;
    height: 100vh;
    min-height: 500px;
    max-height: 800px;
    overflow: hidden;
}

.mppeu-slide-full {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    opacity: 0;
    transition: opacity 0.6s ease;
    display: flex;
    align-items: flex-end;
}

.mppeu-slide-full.activo { opacity: 1; }

.mppeu-slide-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to top,
        rgba(0, 0, 0, 0.75) 0%,
        rgba(0, 0, 0, 0.3)  50%,
        rgba(0, 0, 0, 0.1)  100%
    );
}

.mppeu-slide-body {
    position: relative;
    z-index: 2;
    padding-bottom: calc(var(--espacio-3xl) + 80px);
    width: 100%;
}

.mppeu-slide-texto {
    max-width: 640px;
}

.mppeu-slide-h {
    font-size: var(--texto-3xl);
    font-weight: 800;
    color: var(--color-blanco);
    line-height: 1.2;
    margin: 0 0 var(--espacio-md);
    text-shadow: 0 2px 8px rgba(0,0,0,0.4);
}

.mppeu-slide-p {
    font-size: var(--texto-md);
    color: rgba(255,255,255,0.85);
    line-height: 1.7;
    margin: 0 0 var(--espacio-lg);
    text-shadow: 0 1px 4px rgba(0,0,0,0.3);
}

.mppeu-slide-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--espacio-sm);
}

/* Navegación */
.mppeu-slider-nav {
    position: absolute;
    bottom: calc(var(--espacio-2xl) + 20px);
    right: var(--padding-lateral);
    display: flex;
    align-items: center;
    gap: var(--espacio-md);
    z-index: 20;

}

.mppeu-slider-arrow {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: rgba(255,255,255,0.15);
    border: 1px solid rgba(255,255,255,0.25);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    color: var(--color-blanco);
    transition: var(--transicion-rapida);
    backdrop-filter: blur(4px);
}

.mppeu-slider-arrow:hover {
    background: var(--color-amarillo);
    border-color: var(--color-amarillo);
    color: var(--color-azul-oscuro);
}

.mppeu-slider-arrow svg {
    stroke: var(--color-blanco);
    display: block;
    flex-shrink: 0;
}

.mppeu-dots-wrap {
    display: flex;
    gap: var(--espacio-xs);
    align-items: center;
}

.mppeu-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: rgba(255,255,255,0.4);
    border: none;
    cursor: pointer;
    transition: var(--transicion-rapida);
    padding: 0;
}

.mppeu-dot.activo {
    background: var(--color-amarillo);
    width: 22px;
    border-radius: 4px;
}

/* --- Modo Fallback --- */
.mppeu-hero-fallback-mode {
    background: linear-gradient(135deg, #001f5c 0%, var(--color-azul) 60%, var(--color-azul-claro) 100%);
    padding-top: calc(var(--espacio-3xl) + var(--alto-header) + var(--alto-sintillo));
    padding-bottom: calc(var(--espacio-3xl) + 80px);
}

.mppeu-hero-fallback { max-width: 640px; }

.mppeu-hero-tag {
    display: inline-block;
    background: rgba(252,209,22,0.15);
    border: 1px solid rgba(252,209,22,0.4);
    color: var(--color-amarillo);
    font-size: var(--texto-xs);
    font-weight: 600;
    padding: 4px 14px;
    border-radius: 20px;
    margin-bottom: var(--espacio-md);
    letter-spacing: 0.6px;
    text-transform: uppercase;
}

.mppeu-hero-titulo {
    font-size: var(--texto-3xl);
    font-weight: 800;
    color: var(--color-blanco);
    line-height: 1.2;
    margin: 0 0 var(--espacio-md);
}

.mppeu-hero-subtitulo {
    font-size: var(--texto-base);
    color: rgba(255,255,255,0.7);
    line-height: 1.7;
    margin: 0 0 var(--espacio-xl);
}

.mppeu-hero-btns {
    display: flex;
    gap: var(--espacio-md);
    flex-wrap: wrap;
}

/* Servicios superpuestos */
.mppeu-hero-servicios {
    position: absolute;
    bottom: -50px;
    left: 0;
    right: 0;
    padding-inline: var(--padding-lateral);
    z-index: 10;
}
.mppeu-seccion-post-hero {
    padding-top: calc(var(--espacio-2xl) + 50px);
}

/* =============================================
   2 SHORTCODE — SERVICIOS
   ============================================= */
.mppeu-servicios-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--espacio-md);
}

.mppeu-srv-card {
    background: var(--color-blanco);
    border-radius: var(--radio-lg);
    border: 1px solid rgba(0,0,0,0.06);
    box-shadow: 0 4px 24px rgba(0,56,147,0.1);
    padding: var(--espacio-lg) var(--espacio-md);
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: var(--espacio-sm);
    transition: var(--transicion-media);
}

.mppeu-srv-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 32px rgba(0,56,147,0.15);
}

.mppeu-srv-card.mppeu-srv-proximamente {
    opacity: 0.6;
    pointer-events: none;
}

.mppeu-srv-icon {
    width: 48px;
    height: 48px;
    border-radius: var(--radio-lg);
    background: rgba(0,56,147,0.08);
    display: flex;
    align-items: center;
    justify-content: center;
}

.mppeu-srv-icon svg {
    width: 22px;
    height: 22px;
    stroke: var(--color-azul);
}

.mppeu-srv-card.mppeu-srv-proximamente .mppeu-srv-icon {
    background: var(--color-gris-claro);
}

.mppeu-srv-card.mppeu-srv-proximamente .mppeu-srv-icon svg {
    stroke: var(--color-gris-medio);
}

.mppeu-srv-nombre {
    font-size: var(--texto-sm);
    font-weight: 700;
    color: var(--color-texto);
}

.mppeu-srv-desc {
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
    line-height: 1.5;
}

.mppeu-srv-link {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: rgba(0,56,147,0.08);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: var(--transicion-rapida);
    margin-top: var(--espacio-xs);
}

.mppeu-srv-link svg {
    width: 14px;
    height: 14px;
    stroke: var(--color-azul);
}

.mppeu-srv-link:hover {
    background: var(--color-azul);
}

.mppeu-srv-link:hover svg {
    stroke: var(--color-blanco);
}

.mppeu-srv-prox {
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
    margin-top: var(--espacio-xs);
}

/* =============================================
   3 SHORTCODE — CIFRAS
   ============================================= */
.mppeu-cifras {
    background: var(--color-azul-oscuro);
    padding: var(--espacio-2xl) 0;
}

.mppeu-cifras-grid {
    display: flex;
    align-items: center;
    justify-content: center;
}

.mppeu-cifra {
    flex: 1;
    text-align: center;
    padding: var(--espacio-lg) var(--espacio-xl);
}

.mppeu-cifra-num {
    display: flex;
    align-items: baseline;
    justify-content: center;
    gap: 2px;
    margin-bottom: var(--espacio-sm);
}

.mppeu-cifra-valor {
    font-size: var(--texto-3xl);
    font-weight: 800;
    color: var(--color-amarillo);
    line-height: 1;
    font-variant-numeric: tabular-nums;
}

.mppeu-cifra-sufijo {
    font-size: var(--texto-xl);
    font-weight: 700;
    color: var(--color-amarillo);
}

.mppeu-cifra-label {
    font-size: var(--texto-sm);
    font-weight: 600;
    color: var(--color-blanco);
    margin-bottom: var(--espacio-xs);
}

.mppeu-cifra-sub {
    font-size: var(--texto-xs);
    color: rgba(255,255,255,0.45);
    line-height: 1.5;
}

.mppeu-cifra-sep {
    width: 1px;
    height: 60px;
    background: rgba(255,255,255,0.12);
    flex-shrink: 0;
}

/* =============================================
   SHORTCODE — NOTICIAS
   ============================================= */
.mppeu-noticias {
    position: relative;
    overflow: hidden;
    background: 
        radial-gradient(circle at 20% 50%, rgba(0,56,147,0.08) 0%, transparent 60%),
        radial-gradient(circle at 80% 20%, rgba(207,9,33,0.05) 0%, transparent 50%),
        #f0f4ff;
    padding: var(--espacio-2xl) 0;
}

.mppeu-noticias::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: radial-gradient(circle, rgba(0,56,147,0.1) 1px, transparent 1px);
    background-size: 24px 24px;
    pointer-events: none;
}

.mppeu-aviso {
    display: flex;
    align-items: center;
    gap: var(--espacio-sm);
    background: #FFF9E6;
    border-left: 3px solid var(--color-amarillo);
    border-radius: var(--radio-md);
    padding: var(--espacio-sm) var(--espacio-md);
    margin-bottom: var(--espacio-xl);
}

.mppeu-aviso svg { stroke: #BA7517; flex-shrink: 0; }
.mppeu-aviso-txt { font-size: var(--texto-sm); color: #412402; flex: 1; }

.mppeu-noticias-grid {
    display: grid;
    grid-template-columns: 1.8fr 1fr;
    gap: var(--espacio-lg);
}

/* Noticia grande */
.mppeu-noticia-grande {
    background: var(--color-blanco);
    border-radius: var(--radio-lg);
    border: 1px solid var(--color-gris-borde);
    overflow: hidden;
    box-shadow: var(--sombra-suave);
    transition: var(--transicion-media);
}

.mppeu-noticia-grande:hover {
    box-shadow: var(--sombra-media);
    transform: translateY(-2px);
}

.mppeu-noticia-img-wrap {
    display: block;
    height: 220px;
    overflow: hidden;
}

.mppeu-noticia-img-wrap img { transition: transform 0.4s ease; }
.mppeu-noticia-img-wrap:hover img { transform: scale(1.04); }

.mppeu-noticia-placeholder {
    width: 100%;
    height: 100%;
    background: var(--color-gris-claro);
}

.mppeu-noticia-body {
    padding: var(--espacio-lg);
    display: flex;
    flex-direction: column;
    gap: var(--espacio-sm);
}

.mppeu-noticia-titulo {
    font-size: var(--texto-md);
    font-weight: 700;
    color: var(--color-texto);
    margin: 0;
    line-height: 1.4;
}

.mppeu-noticia-titulo a {
    color: inherit;
    transition: var(--transicion-rapida);
}

.mppeu-noticia-titulo a:hover { color: var(--color-azul); }

.mppeu-noticia-fecha {
    display: flex;
    align-items: center;
    gap: var(--espacio-xs);
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
}

.mppeu-noticia-fecha svg { stroke: var(--color-gris-medio); flex-shrink: 0; }

/* Noticias pequeñas */
.mppeu-noticias-chicas {
    display: flex;
    flex-direction: column;
    gap: var(--espacio-md);
}

.mppeu-noticia-chica {
    background: var(--color-blanco);
    border-radius: var(--radio-lg);
    border: 1px solid var(--color-gris-borde);
    overflow: hidden;
    display: flex;
    box-shadow: var(--sombra-suave);
    transition: var(--transicion-media);
    flex: 1;
}

.mppeu-noticia-chica:hover {
    box-shadow: var(--sombra-media);
    transform: translateY(-1px);
}

.mppeu-noticia-chica-img {
    width: 35%;
    flex-shrink: 0;
    overflow: hidden;
    display: block;
}

.mppeu-noticia-chica-img img { transition: transform 0.4s ease; }
.mppeu-noticia-chica-img:hover img { transform: scale(1.06); }

.mppeu-noticia-chica-body {
    padding: var(--espacio-md);
    display: flex;
    flex-direction: column;
    gap: var(--espacio-xs);
    flex: 1;
}

.mppeu-noticia-chica-titulo {
    font-size: var(--texto-sm);
    font-weight: 600;
    color: var(--color-texto);
    margin: 0;
    line-height: 1.4;
}

.mppeu-noticia-chica-titulo a {
    color: inherit;
    transition: var(--transicion-rapida);
}

.mppeu-noticia-chica-titulo a:hover { color: var(--color-azul); }

/* =============================================
   SHORTCODE — UNIVERSIDADES (carrusel)
   ============================================= */
.mppeu-unis {
    background: linear-gradient(135deg, var(--color-blanco) 0%, #f0f4ff 50%, #e8eeff 100%);
    border-top: 3px solid var(--color-azul);
    padding: var(--espacio-2xl) 0;
}

/* Contenedor con los botones a los lados */
.mppeu-unis-wrap {
    display: flex;
    align-items: center;
    gap: var(--espacio-sm);
    position: relative;
}

/* Botones de navegación */
.mppeu-unis-btn {
    flex-shrink: 0;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: var(--color-blanco);
    border: 1.5px solid var(--color-gris-borde);
    box-shadow: var(--sombra-suave);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: var(--transicion-rapida);
    color: var(--color-azul);
    padding: 0;
}

.mppeu-unis-btn svg {
    display: block;
    flex-shrink: 0;
    stroke: var(--color-azul);
}

.mppeu-unis-btn:hover {
    background: var(--color-azul);
    border-color: var(--color-azul);
    box-shadow: var(--sombra-media);
}

.mppeu-unis-btn:hover svg {
    stroke: var(--color-blanco);
}

.mppeu-unis-btn:disabled {
    cursor: default;
    pointer-events: none;
}

/* Track desplazable */
.mppeu-unis-track {
    flex: 1;
    display: flex;
    gap: var(--espacio-md);
    overflow-x: auto;
    scroll-behavior: smooth;
    scrollbar-width: none;
    -ms-overflow-style: none;
    padding: var(--espacio-sm) 2px;
}

.mppeu-unis-track::-webkit-scrollbar {
    display: none;
}

/* Tarjeta */
.mppeu-uni-card {
    display: flex;
    align-items: center;
    gap: var(--espacio-md);
    padding: var(--espacio-md) var(--espacio-lg);
    border: 1px solid var(--color-gris-borde);
    border-radius: var(--radio-lg);
    background: var(--color-blanco);
    min-width: 190px;
    max-width: 230px;
    flex-shrink: 0;
    text-decoration: none;
    transition: var(--transicion-media);
    box-shadow: var(--sombra-suave);
}

.mppeu-uni-card:hover {
    border-color: var(--color-azul);
    box-shadow: var(--sombra-media);
    transform: translateY(-2px);
    color: inherit;
}

.mppeu-uni-logo {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: var(--color-gris-claro);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    overflow: hidden;
}

.mppeu-uni-logo img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.mppeu-uni-inicial {
    font-size: var(--texto-sm);
    font-weight: 800;
    color: var(--color-azul);
    line-height: 1;
}

.mppeu-uni-siglas {
    font-size: var(--texto-sm);
    font-weight: 700;
    color: var(--color-texto);
    line-height: 1.3;
}

.mppeu-uni-tipo {
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
    margin-top: 3px;
}



/* =============================================
   SHORTCODE — BIBLIOTECA / PUBLICACIONES
   ============================================= */
.mppeu-biblioteca {
    background: var(--color-blanco);
    border-left: 4px solid var(--color-azul);
    position: relative;
    padding: var(--espacio-2xl) 0;
}

.mppeu-biblioteca::after {
    content: '';
    position: absolute;
    top: 0; right: 0; bottom: 0;
    width: 30%;
    background: linear-gradient(to left, rgba(0,56,147,0.03), transparent);
    pointer-events: none;
}

.mppeu-biblioteca-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--espacio-lg);
    align-items: start;
}

/* Columna izquierda */
.mppeu-bib-hero {
    position: relative;
    border-radius: var(--radio-xl);
    overflow: hidden;
    background: linear-gradient(135deg, #0a1628 0%, #1a3a6b 60%, #0d2444 100%);
    padding: var(--espacio-xl);
    min-height: 420px;
    display: flex;
    align-items: flex-end;
}

.mppeu-bib-patron {
    position: absolute;
    inset: 0;
    opacity: 0.04;
    background-image:
        repeating-linear-gradient(45deg, #fff 0, #fff 1px, transparent 0, transparent 50%),
        repeating-linear-gradient(-45deg, #fff 0, #fff 1px, transparent 0, transparent 50%);
    background-size: 20px 20px;
}

/* Libros decorativos */
.mppeu-bib-libros {
    position: absolute;
    top: var(--espacio-lg);
    right: var(--espacio-lg);
    display: flex;
    align-items: flex-end;
    gap: 6px;
    opacity: 0.2;
}

.mppeu-bib-libro {
    width: 16px;
    border-radius: 2px;
    flex-shrink: 0;
}

.mppeu-bib-hero-content {
    position: relative;
    z-index: 1;
    width: 100%;
}

.mppeu-bib-titulo {
    font-size: var(--texto-xl);
    font-weight: 800;
    color: var(--color-blanco);
    line-height: 1.25;
    margin: var(--espacio-xs) 0 var(--espacio-sm);
}

.mppeu-bib-sub {
    font-size: var(--texto-sm);
    color: rgba(255,255,255,0.55);
    line-height: 1.6;
    margin-bottom: var(--espacio-lg);
}

/* Buscador */
.mppeu-bib-form {
    display: flex;
    gap: var(--espacio-sm);
    margin-bottom: var(--espacio-md);
}

.mppeu-bib-input-wrap {
    position: relative;
    flex: 1;
}

.mppeu-bib-ico {
    position: absolute;
    left: 10px;
    top: 50%;
    transform: translateY(-50%);
    stroke: rgba(255,255,255,0.5);
}

.mppeu-bib-input {
    width: 100%;
    height: 40px;
    padding: 0 var(--espacio-md) 0 36px;
    background: rgba(255,255,255,0.1);
    border: 1px solid rgba(255,255,255,0.15);
    border-radius: var(--radio-md);
    color: var(--color-blanco);
    font-size: var(--texto-sm);
    font-family: var(--fuente-principal);
    outline: none;
    transition: var(--transicion-rapida);
}

.mppeu-bib-input::placeholder { color: rgba(255,255,255,0.4); }
.mppeu-bib-input:focus { border-color: var(--color-amarillo); background: rgba(255,255,255,0.15); }

/* Filtros */
.mppeu-bib-filtros {
    display: flex;
    flex-wrap: wrap;
    gap: var(--espacio-xs);
}

.mppeu-bib-filtro {
    padding: 4px 12px;
    border-radius: 20px;
    font-size: var(--texto-xs);
    font-weight: 500;
    cursor: pointer;
    border: 1px solid rgba(255,255,255,0.2);
    color: rgba(255,255,255,0.65);
    background: transparent;
    transition: var(--transicion-rapida);
    font-family: var(--fuente-principal);
}

.mppeu-bib-filtro:hover {
    border-color: rgba(255,255,255,0.5);
    color: var(--color-blanco);
}

.mppeu-bib-filtro.activo {
    background: rgba(252,209,22,0.15);
    border-color: var(--color-amarillo);
    color: var(--color-amarillo);
}

/* Columna derecha */
.mppeu-bib-derecha {
    display: flex;
    flex-direction: column;
    gap: var(--espacio-md);
}

.mppeu-bib-lista-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.mppeu-bib-lista-titulo {
    font-size: var(--texto-md);
    font-weight: 700;
    color: var(--color-texto);
}

.mppeu-bib-lista {
    display: flex;
    flex-direction: column;
    gap: var(--espacio-sm);
}

.mppeu-bib-item {
    background: var(--color-blanco);
    border: 1px solid var(--color-gris-borde);
    border-radius: var(--radio-lg);
    padding: var(--espacio-md);
    display: flex;
    align-items: center;
    gap: var(--espacio-md);
    transition: var(--transicion-media);
}

.mppeu-bib-item:hover {
    border-color: var(--color-azul);
    box-shadow: var(--sombra-suave);
    transform: translateX(3px);
}

.mppeu-bib-portada {
    width: 44px;
    height: 56px;
    border-radius: var(--radio-sm);
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}


.mppeu-bib-tipo {
    font-size: var(--texto-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 3px;
}

.mppeu-bib-info {
    flex: 1;
    min-width: 0; 
    overflow: hidden; /* Corta lo que sobresalga */
}

.mppeu-bib-nombre {
    font-size: var(--texto-sm);
    font-weight: 600;
    color: var(--color-texto);
    line-height: 1.4;
    margin-bottom: 4px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    display: block;
    max-width: 300px;
    min-width: 100%;    
    transition: transform 2s ease-in-out; 
}

.mppeu-bib-item:hover .mppeu-bib-nombre {
    text-overflow: clip;
    overflow: visible;
    transform: translateX(calc(-100% + 200px)); 
}

@keyframes scroll-text {
    0% { transform: translateX(0); }
    100% { transform: translateX(-50%); } 
}

.mppeu-bib-item:hover .mppeu-bib-nombre {
    display: inline-block;
    animation: marquee 8s linear infinite;
    padding-right: 50px;
}

@keyframes marquee {
    0% { transform: translateX(0); }
    100% { transform: translateX(calc(-100% + 150px)); } 
}

.mppeu-bib-meta {
    display: flex;
    gap: var(--espacio-sm);
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
    flex-wrap: wrap;
}

.mppeu-bib-btn-dl {
    width: 34px;
    height: 34px;
    border-radius: var(--radio-md);
    border: 1px solid var(--color-gris-borde);
    background: transparent;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-azul);
    flex-shrink: 0;
    transition: var(--transicion-rapida);
    text-decoration: none;
}

.mppeu-bib-btn-dl:hover {
    background: var(--color-azul);
    border-color: var(--color-azul);
    color: var(--color-blanco);
}

.mppeu-bib-btn-dl svg { stroke: currentColor; }


/* Noticias stats */
.noticias-stats {
    margin-bottom: var(--espacio-lg);
    padding: var(--espacio-sm) var(--espacio-md);
    background: #f8fafc;
    border-radius: var(--radio-md);
    font-size: var(--texto-sm);
    color: var(--color-gris-medio);
}

.noticias-stats .stats-count {
    font-weight: 600;
    color: var(--color-azul);
}

/* =============================================
   SHORTCODE — VIDEOS
   ============================================= */
.mppeu-videos {
    position: relative;
    overflow: hidden;
    background: #0d1117;
    padding: var(--espacio-2xl) 0;
}

.mppeu-videos::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: repeating-linear-gradient(
        -45deg,
        transparent,
        transparent 20px,
        rgba(255,255,255,0.02) 20px,
        rgba(255,255,255,0.02) 21px
    );
    pointer-events: none;
}

.mppeu-videos-grid {
    display: grid;
    grid-template-columns: 1.6fr 1fr 1fr;
    gap: var(--espacio-md);
}

.mppeu-video-card {
    border-radius: var(--radio-lg);
    overflow: hidden;
    position: relative;
    cursor: pointer;
    margin:auto;
}

.mppeu-video-thumb {
    position: relative;
    width: 100%;
    aspect-ratio: 16/9;
    overflow: hidden;
    background: #1a1f2e;
}

.mppeu-video-grande .mppeu-video-thumb {
    aspect-ratio: 16/9;
}

.mppeu-video-placeholder {
    width: 100%;
    height: 100%;
    background: #1e2435;
}

.mppeu-video-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to top,
        rgba(0,0,0,0.7) 0%,
        rgba(0,0,0,0.2) 50%,
        transparent 100%
    );
    transition: var(--transicion-media);
}

.mppeu-video-card:hover .mppeu-video-overlay {
    background: linear-gradient(
        to top,
        rgba(0,0,0,0.8) 0%,
        rgba(0,0,0,0.3) 60%,
        rgba(0,0,0,0.1) 100%
    );
}

.mppeu-video-play {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 52px;
    height: 52px;
    border-radius: 50%;
    background: rgba(255,255,255,0.15);
    border: 2px solid rgba(255,255,255,0.4);
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    cursor: pointer;
    transition: var(--transicion-media);
    backdrop-filter: blur(4px);
    z-index: 2;
    padding-left: 3px;
}

.mppeu-video-card:hover .mppeu-video-play {
    background: var(--color-amarillo);
    border-color: var(--color-amarillo);
    color: var(--color-azul-oscuro);
    transform: translate(-50%, -50%) scale(1.1);
}

.mppeu-video-info {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: var(--espacio-md);
    z-index: 2;
}

.mppeu-video-titulo {
    font-size: var(--texto-sm);
    font-weight: 600;
    color: var(--color-blanco);
    line-height: 1.4;
}

.mppeu-video-grande .mppeu-video-titulo {
    font-size: var(--texto-md);
}

/* Lightbox */
.mppeu-lightbox {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
}

.mppeu-lightbox-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.9);
    cursor: pointer;
}

.mppeu-lightbox-inner {
    position: relative;
    z-index: 1;
    width: 90vw;
    max-width: 900px;
    aspect-ratio: 16/9;
}

.mppeu-lightbox-cerrar {
    position: absolute;
    top: -40px;
    right: 0;
    background: transparent;
    border: none;
    color: white;
    cursor: pointer;
    padding: 4px;
}

.mppeu-lightbox-content {
    width: 100%;
    height: 100%;
    border-radius: var(--radio-lg);
    overflow: hidden;
    background: #000;
}


/* =============================================
   SHORTCODE — ENTES ADSCRITOS
   ============================================= */
.mppeu-entes {
    position: relative;
    overflow: hidden;
    background: linear-gradient(135deg, #e8eeff 0%, #f0f4ff 50%, #e8f0fe 100%);
    padding: var(--espacio-2xl) 0;
}

.mppeu-entes::before {
    content: '';
    position: absolute;
    top: -60px; right: -60px;
    width: 220px; height: 220px;
    border-radius: 50%;
    background: rgba(0,56,147,0.06);
    pointer-events: none;
}

.mppeu-entes::after {
    content: '';
    position: absolute;
    bottom: -40px; left: -40px;
    width: 150px; height: 150px;
    border-radius: 50%;
    background: rgba(0,56,147,0.04);
    pointer-events: none;
}

.mppeu-entes-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--espacio-md);
    margin-bottom: var(--espacio-xl);
}

.mppeu-ente-card {
    background: var(--color-blanco);
    border: 1px solid rgba(0,56,147,0.08);
    border-radius: var(--radio-lg);
    padding: var(--espacio-lg) var(--espacio-md);
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: var(--espacio-md);
    text-decoration: none;
    transition: var(--transicion-media);
    box-shadow: 0 2px 12px rgba(0,56,147,0.06);
}

.mppeu-ente-card:hover {
    border-color: var(--color-azul);
    box-shadow: 0 4px 20px rgba(0,56,147,0.12);
    transform: translateY(-3px);
}

.mppeu-ente-logo {
    width: 80px;
    height: 80px;
    border-radius: var(--radio-lg);
    background: #EEF3FF;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    overflow: hidden;
    padding: var(--espacio-sm);
}

.mppeu-ente-inicial {
    font-size: var(--texto-lg);
    font-weight: 800;
    color: var(--color-azul);
}

.mppeu-ente-info { width: 100%; }

.mppeu-ente-nombre {
    font-size: var(--texto-sm);
    font-weight: 700;
    color: var(--color-texto);
    line-height: 1.3;
    margin-bottom: 2px;
}

.mppeu-ente-desc {
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.mppeu-ente-arrow {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: #EEF3FF;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: var(--transicion-rapida);
    color: var(--color-azul);
    margin-top: auto;
}

.mppeu-ente-card:hover .mppeu-ente-arrow {
    background: var(--color-azul);
    color: var(--color-blanco);
}

.mppeu-ente-arrow svg { stroke: currentColor; }

/* Botón alineado a la derecha */
.mppeu-entes-footer {
    display: flex;
    justify-content: flex-end;
}

/* =============================================
   SHORTCODE — COMUNICADOS (ticker)
   ============================================= */
.mppeu-coms {
    padding: var(--espacio-2xl) 0 0;
    background: var(--color-blanco);
    border-top: 3px solid var(--color-azul);
    overflow: hidden;
}

/* Ticker wrap */
.mppeu-coms-ticker-wrap {
    position: relative;
    margin-top: var(--espacio-lg);
    padding-bottom: var(--espacio-xl);
}

.mppeu-coms-ticker {
    display: flex;
    gap: 12px;
    width: max-content;
    will-change: transform;
    cursor: pointer;
    padding: 4px 0 8px;
}

/* Degradados laterales */
.mppeu-coms-fade-left,
.mppeu-coms-fade-right {
    position: absolute;
    top: 0;
    bottom: 0;
    width: 80px;
    pointer-events: none;
    z-index: 2;
}
.mppeu-coms-fade-left {
    left: 0;
    background: linear-gradient(to right, var(--color-blanco), transparent);
}
.mppeu-coms-fade-right {
    right: 0;
    background: linear-gradient(to left, var(--color-blanco), transparent);
}

/* Tarjeta individual */
.mppeu-com-card {
    width: 130px;
    flex-shrink: 0;
    border-radius: var(--radio-lg);
    border: 1px solid var(--color-gris-borde);
    overflow: hidden;
    background: var(--color-blanco);
    transition: var(--transicion-media);
    box-shadow: var(--sombra-suave);
}

.mppeu-com-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--sombra-media);
    border-color: var(--color-azul);
}

/* Thumbnail */
.mppeu-com-thumb {
    position: relative;
    width: 130px;
    height: 184px;
    overflow: hidden;
    background: var(--color-gris-claro);
}

.mppeu-com-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top;
    display: block;
    transition: transform 0.4s ease;
}

.mppeu-com-card:hover .mppeu-com-thumb img {
    transform: scale(1.03);
}

/* Placeholder cuando no hay imagen */
.mppeu-com-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    background: #fafbff;
    padding: 8px;
}

.mppeu-com-placeholder-header {
    display: flex;
    align-items: center;
    gap: 6px;
    padding-bottom: 6px;
    border-bottom: 1px solid var(--color-gris-borde);
    margin-bottom: 6px;
}

.mppeu-com-placeholder-logo {
    width: 18px;
    height: 18px;
    background: var(--color-azul);
    border-radius: 2px;
    flex-shrink: 0;
}

.mppeu-com-placeholder-lineas {
    display: flex;
    flex-direction: column;
    gap: 3px;
    flex: 1;
}

.mppeu-com-placeholder-lineas span {
    display: block;
    height: 4px;
    background: var(--color-gris-borde);
    border-radius: 2px;
}

.mppeu-com-placeholder-lineas span:last-child {
    width: 60%;
}

.mppeu-com-placeholder-body {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.mppeu-com-placeholder-body span {
    display: block;
    height: 4px;
    background: var(--color-gris-borde);
    border-radius: 2px;
    width: 100%;
    opacity: 0.7;
}

.mppeu-com-placeholder-body span.w75 { width: 75%; }
.mppeu-com-placeholder-body span.w60 { width: 60%; }
.mppeu-com-placeholder-body span.w85 { width: 85%; }

.mppeu-com-placeholder-footer {
    background: var(--color-azul);
    color: var(--color-blanco);
    font-size: 8px;
    font-weight: 700;
    text-align: center;
    padding: 4px;
    border-radius: 2px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-top: 4px;
}

/* Overlay hover */
.mppeu-com-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 56, 147, 0.6);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity 0.25s ease;
}

.mppeu-com-card:hover .mppeu-com-overlay {
    opacity: 1;
}

/* Info debajo de la miniatura */
.mppeu-com-info {
    padding: 8px;
}

.mppeu-com-titulo {
    font-size: 11px;
    font-weight: 600;
    color: var(--color-texto);
    margin: 0 0 4px;
    line-height: 1.35;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.mppeu-com-fecha {
    font-size: 10px;
    color: var(--color-gris-medio);
    display: block;
    margin-bottom: 4px;
}

.mppeu-com-pdf-badge {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    font-size: 9px;
    font-weight: 700;
    color: var(--color-azul);
    background: rgba(0, 56, 147, 0.08);
    padding: 2px 6px;
    border-radius: 3px;
}

/* ── Lightbox ───────────────────────────────── */
.mppeu-com-lightbox {
    position: fixed;
    inset: 0;
    z-index: 99999;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.15s ease;
}
.mppeu-com-lightbox.visible {
    opacity: 1;
    pointer-events: auto;
}


.mppeu-com-lb-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 10, 30, 0.88);
    /* Sin backdrop-filter — ese es el culpable del lag */
}

.mppeu-com-lb-inner {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--espacio-md);
    padding: var(--espacio-xl);
    max-width: 480px;
    width: 90%;
}

.mppeu-com-lb-cerrar {
    position: absolute;
    top: 2px;
    right: -190px;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: rgba(255,255,255,0.15);
    border: 1px solid rgba(255,255,255,0.25);
    color: white; /* ← ya estaba */
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background 0.2s;
}

.mppeu-com-lb-cerrar svg {
    stroke: white; /* ← agregar esto */
    display: block;
    flex-shrink: 0;
}

.mppeu-com-lb-cerrar:hover {
    background: rgba(255,255,255,0.25);
}

/* Imagen en lightbox */
.mppeu-com-lb-img-wrap {
    width: 100%;
    min-width: var(--ancho-minimo-image);
    min-height: 600px;
    max-height: 75vh;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radio-lg);
    overflow: hidden;
    background: rgba(255,255,255,0.05);
}

.mppeu-com-lb-img-wrap img {
    min-width: var(--ancho-minimo-image);
    max-width: 100%;
    min-height: 600px;
    max-height: 75vh;
    object-fit: contain;
    border-radius: var(--radio-md);
    display: block;
}

.mppeu-com-lb-noimg {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding: 40px;
    color: rgba(255,255,255,0.4);
    font-size: 13px;
}

/* Datos en lightbox */
.mppeu-com-lb-datos {
    text-align: center;
    width: 100%;
}

.mppeu-com-lb-cat {
    display: inline-block;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--color-amarillo);
    margin-bottom: 6px;
}

.mppeu-com-lb-titulo {
    font-size: 16px;
    font-weight: 700;
    color: white;
    margin: 0 0 6px;
    line-height: 1.4;
}

.mppeu-com-lb-fecha {
    font-size: 12px;
    color: rgba(255,255,255,0.5);
    display: block;
    margin-bottom: var(--espacio-md);
}

.mppeu-com-lb-acciones {
    display: flex;
    justify-content: center;
}

.mppeu-com-lb-btn-dl {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--color-amarillo);
    color: #412402;
    font-size: 13px;
    font-weight: 700;
    padding: 10px 22px;
    border-radius: var(--radio-md);
    text-decoration: none;
    transition: var(--transicion-rapida);
}

.mppeu-com-lb-btn-dl:hover {
    background: #e8be00;
    color: #412402;
    transform: translateY(-1px);
}

/* Responsive */
@media (max-width: 600px) {
    .mppeu-com-card { width: 110px; }
    .mppeu-com-thumb { width: 110px; height: 155px; }
    .mppeu-com-lb-img-wrap,  .mppeu-com-lb-img-wrap img { min-width: 300px; }

}
   
/* =============================================
   SHORTCODE — PROGRAMAS
   ============================================= */
.mppeu-programas {
    background: #f0f4ff;
    padding: var(--espacio-2xl) 0;
    position: relative;
    overflow: hidden;
}

.mppeu-programas::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: repeating-linear-gradient(
        -55deg,
        transparent,
        transparent 30px,
        rgba(0,56,147,0.02) 30px,
        rgba(0,56,147,0.02) 31px
    );
    pointer-events: none;
}

.mppeu-prog-wrap {
    overflow-x: hidden;
    overflow-y: visible;
    padding-bottom: var(--espacio-sm);
    padding-top: var(--espacio-sm);
}

.mppeu-prog-track {
    display: grid;
    grid-template-columns: repeat(4, calc(33.333% - 11px));
    gap: var(--espacio-md);
    transition: transform 0.4s ease;
}

.mppeu-prog-card {
    min-width: calc((100% - 32px) / 3);
    flex-shrink: 0;
    border-radius: var(--radio-xl);
    padding: var(--espacio-xl) var(--espacio-lg);
    display: flex;
    flex-direction: column;
    gap: var(--espacio-md);
    text-decoration: none;
    position: relative;
    overflow: hidden;
    min-height: 260px;
    transition: var(--transicion-media);
}

.mppeu-prog-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 16px 40px rgba(0,0,0,0.2);
}

.mppeu-prog-deco {
    position: absolute;
    bottom: -30px; right: -30px;
    width: 120px; height: 120px;
    border-radius: 50%;
    background: rgba(255,255,255,0.06);
    pointer-events: none;
}

.mppeu-prog-icon {
    width: 52px;
    height: 52px;
    border-radius: var(--radio-lg);
    background: rgba(255,255,255,0.15);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 26px;
    backdrop-filter: blur(4px);
}

.mppeu-prog-meta {
    display: flex;
    align-items: center;
    gap: var(--espacio-sm);
    flex-wrap: wrap;
}

.mppeu-prog-estado {
    font-size: var(--texto-xs);
    font-weight: 600;
    padding: 3px 8px;
    border-radius: 20px;
}

.est-activo     { background: rgba(74,222,128,0.2); color: #4ade80; border: 1px solid rgba(74,222,128,0.3); }
.est-desarrollo { background: rgba(251,191,36,0.2); color: #fbbf24; border: 1px solid rgba(251,191,36,0.3); }
.est-finalizado { background: rgba(255,255,255,0.1); color: rgba(255,255,255,0.5); border: 1px solid rgba(255,255,255,0.15); }

.mppeu-prog-tipo {
    font-size: var(--texto-xs);
    font-weight: 600;
    color: rgba(255,255,255,0.6);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.mppeu-prog-nombre {
    font-size: var(--texto-md);
    font-weight: 800;
    color: var(--color-blanco);
    line-height: 1.3;
    flex: 1;
}

.mppeu-prog-link {
    display: flex;
    align-items: center;
    gap: var(--espacio-xs);
    font-size: var(--texto-xs);
    font-weight: 600;
    color: rgba(255,255,255,0.75);
    margin-top: auto;
    transition: var(--transicion-rapida);
}

.mppeu-prog-card:hover .mppeu-prog-link {
    color: var(--color-blanco);
    gap: var(--espacio-sm);
}

.mppeu-prog-link svg { stroke: currentColor; }

/* Navegación */
.mppeu-prog-nav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--espacio-md);
    margin-top: var(--espacio-xl);
}

.mppeu-prog-arrow {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--color-blanco);
    border: 1px solid rgba(0,56,147,0.15);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    color: var(--color-azul);
    box-shadow: var(--sombra-suave);
    transition: var(--transicion-rapida);
}

.mppeu-prog-arrow:hover {
    background: var(--color-azul);
    color: var(--color-blanco);
    border-color: var(--color-azul);
}

.mppeu-prog-arrow svg {
    stroke: currentColor;
    display: block;
    flex-shrink: 0;
}

.mppeu-prog-dots {
    display: flex;
    gap: var(--espacio-xs);
    align-items: center;
}

.mppeu-prog-dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    background: rgba(0,56,147,0.2);
    border: none;
    cursor: pointer;
    transition: var(--transicion-rapida);
    padding: 0;
}

.mppeu-prog-dot.activo {
    background: var(--color-azul);
    width: 22px;
    border-radius: 4px;
}

@media (max-width: 480px) {
    .mppeu-slide-h { font-size: var(--texto-xl); }
    .mppeu-servicios-grid{ grid-template-columns: 1fr 1fr; }
    .mppeu-entes-grid  { grid-template-columns: 1fr; }
    .mppeu-prog-card { min-width: calc(100% - 10px); }
    .mppeu-uni-card {min-width: 160px; padding: var(--espacio-sm) var(--espacio-md);}
    .mppeu-uni-logo { width: 40px; height: 40px; }
}

/* --- Responsive móvil --- */
@media (max-width: 768px) {
    .mppeu-slider-full {
        height: 70vh;
        min-height: 400px;
    }

    .mppeu-slide-h  { font-size: var(--texto-2xl); }
    .mppeu-slide-p  { font-size: var(--texto-sm); }

    .mppeu-slide-body {
        padding-bottom: calc(var(--espacio-2xl) + 100px);
    }

    .mppeu-slider-nav {
        bottom: calc(var(--espacio-xl) + 20px);
        right: var(--espacio-md);

    }

    .mppeu-hero-servicios {
        position: static;
        background: var(--color-gris-claro);
        padding: var(--espacio-lg) var(--padding-lateral);
        bottom: auto;

    }

    .mppeu-servicios-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .mppeu-hero-fallback-mode {
        padding-top: calc(var(--espacio-2xl) + var(--alto-header));
        padding-bottom: var(--espacio-2xl);
    }

    .mppeu-cifras-grid {
        flex-direction: column;
        gap: 0;
    }
    .gal-sticky-filtros{ flex-wrap: wrap;}
    .mppeu-cifra { padding: var(--espacio-lg); }
    .mppeu-cifra-sep {
        width: 60px;
        height: 1px;
    }
    .mppeu-cifras {
        margin-top: 0;
    }

    .mppeu-noticias-grid {
        grid-template-columns: 1fr;
    }
    .mppeu-noticia-img-wrap { height: 200px; }

    .mppeu-biblioteca-grid {
        grid-template-columns: 1fr;
    }
    .mppeu-bib-izquierda, .mppeu-bib-derecha {
        max-width: 80%;
    }
    .uni-main {
        padding:  var(--padding-lateral) var(--espacio-md) !important;
    }
    .mppeu-hero-interno, .arc-hero-sec, .srv-hero, .gal-hero, .uni-hero-sec{
        min-height: auto; padding: calc(var(--espacio-2xl) + var(--padding-lateral) + var(--alto-header)) 0  !important;
    }
    .mppeu-ml-card-footer { flex-direction: column; gap: var(--espacio-sm); align-items: stretch; }
    .mppeu-bib-hero { min-height: auto; }

    .mppeu-videos-grid {
        grid-template-columns: 1fr;
    }
    .mppeu-entes-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    .mppeu-prog-wrap {
        overflow-x: auto;
        overflow-y: visible;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        padding-bottom: var(--espacio-sm);
    }

    .mppeu-prog-wrap::-webkit-scrollbar {
        display: none;
    }

    .mppeu-prog-track {
        display: flex;
        transform: none !important; /* desactiva el JS en móvil */
        width: max-content;
    }

    .mppeu-prog-card {
        min-width: 220px;
        min-height: 280px;
        flex-shrink: 0;
        max-width: 400px;
    }

    .mppeu-prog-nav {
        display: none; /* en móvil se desliza con el dedo */
    }
}

/* =============================================
   HERO INTERNO — páginas internas
   ============================================= */
.mppeu-hero-interno {
    padding: calc(var(--espacio-3xl) + var(--alto-header));
    position: relative;
    overflow: hidden;
}

.mppeu-hero-interno-content {
    max-width: 700px;
    position: relative;
    z-index: 2;
}

.mppeu-hero-interno-titulo {
    font-size: var(--texto-3xl);
    font-weight: 800;
    color: var(--color-blanco);
    line-height: 1.2;
    margin: 0 0 var(--espacio-md);
}

.mppeu-hero-interno-sub {
    font-size: var(--texto-md);
    color: rgba(255,255,255,0.72);
    line-height: 1.7;
    margin: 0;
    max-width: 560px;
}

/* Breadcrumb */
.mppeu-breadcrumb {
    display: flex;
    align-items: center;
    gap: var(--espacio-sm);
    font-size: var(--texto-xs);
    color: rgba(255,255,255,0.55);
    margin-bottom: var(--espacio-lg);
}

.mppeu-breadcrumb a { color: rgba(255,255,255,0.55); transition: var(--transicion-rapida); }
.mppeu-breadcrumb a:hover { color: var(--color-blanco); }
.mppeu-breadcrumb span { color: var(--color-amarillo); }

/* Decoración vm-hero */
.vm-hero-patron {
    position: absolute;
    inset: 0;
    background-image: repeating-linear-gradient(
        -45deg,
        transparent, transparent 20px,
        rgba(255,255,255,0.015) 20px,
        rgba(255,255,255,0.015) 21px
    );
    pointer-events: none;
    z-index: 0;
}

.vm-hero-deco {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    z-index: 0;
}

.vm-deco-1 {
    width: 320px; height: 320px;
    border: 2px solid rgba(255,255,255,0.08);
    top: -80px; right: -60px;
}

.vm-deco-2 {
    width: 220px; height: 220px;
    border: 2px solid rgba(255,255,255,0.06);
    top: -20px; right: 80px;
}

.vm-deco-3 {
    width: 140px; height: 140px;
    border: 2px solid rgba(255,255,255,0.05);
    top: 20px; right: 180px;
}

.vm-deco-4 {
    width: 80px; height: 80px;
    background: rgba(252,209,22,0.06);
    bottom: -10px; left: 45%;
}


/* =============================================
   SHORTCODE — AUTORIDADES
   ============================================= */
.mppeu-autoridades {
    background: var(--color-blanco);
    padding: var(--espacio-2xl) 0;
}

.mppeu-aut-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: var(--espacio-xl);
}

.mppeu-aut-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: var(--espacio-md);
}

.mppeu-aut-foto-wrap {
    position: relative;
}

.mppeu-aut-foto {
    width: 120px;
    height: 120px;
    border-radius: 50%;
    object-fit: cover;
    border: 4px solid var(--color-gris-claro);
    box-shadow: var(--sombra-media);
}

.mppeu-aut-foto-placeholder {
    width: 120px;
    height: 120px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--color-azul), var(--color-azul-claro));
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--texto-2xl);
    font-weight: 800;
    color: var(--color-blanco);
    box-shadow: var(--sombra-media);
}

.mppeu-aut-nombre {
    font-size: var(--texto-md);
    font-weight: 700;
    color: var(--color-texto);
}

.mppeu-aut-cargo {
    font-size: var(--texto-sm);
    color: var(--color-azul);
    font-weight: 500;
}

.mppeu-aut-desc {
    font-size: var(--texto-sm);
    color: var(--color-gris-medio);
    line-height: 1.6;
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.mppeu-aut-redes {
    display: flex;
    gap: var(--espacio-sm);
    justify-content: center;
}

.mppeu-aut-red {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--color-gris-claro);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-azul);
    transition: var(--transicion-rapida);
    text-decoration: none;
}

.mppeu-aut-red:hover {
    background: var(--color-azul);
    color: var(--color-blanco);
}

/* =============================================
   SHORTCODE — VICEMINISTERIOS
   ============================================= */
.mppeu-vms {
    background: #f4f6fa;
}

/* Tabs */
/* .mppeu-vm-tabs {
    background: var(--color-blanco);
    border-bottom: 2px solid #f0f4ff;
    padding: var(--espacio-md) 0;
    display: flex;
    gap: 4px;
    top: calc(var(--alto-header) + var(--alto-sintillo));
    z-index: 10;
    overflow-x: auto;
    scrollbar-width: none;
    justify-content: center;
    position: sticky;
    box-shadow: var(--sombra-suave);
    max-width: var(--ancho-maximo);
} */

.mppeu-vm-tabs::-webkit-scrollbar { display: none; }

.mppeu-vm-tab {
    padding: var(--espacio-lg) var(--espacio-xl);
    font-size: var(--texto-sm);
    font-weight: 600;
    color: var(--color-gris-medio);
    cursor: pointer;
    border: none;
    background: transparent;
    border-bottom: 3px solid transparent;
    transition: var(--transicion-rapida);
    white-space: nowrap;
    font-family: var(--fuente-principal);
    margin-bottom: -2px;
}

.mppeu-vm-tab:hover {
    color: var(--color-azul);
    background: rgba(0,56,147,0.04);
}

.mppeu-vm-tab.activo {
    color: var(--color-azul);
    border-bottom: 3px solid;
    border-image: linear-gradient(
        90deg,
        var(--color-azul) 60%,
        var(--color-rojo) 80%,
        var(--color-amarillo) 100%
    ) 1;
    background: rgba(0,56,147,0.04);
}

.mppeu-vm-tab:focus {
    outline: none;
    color: var(--color-azul);
    background: rgba(0,56,147,0.04);
}


/* Panel */
.mppeu-vm-panel {
    display: none;
    padding: var(--espacio-2xl) var(--padding-lateral);
    max-width: var(--ancho-maximo);
    margin-inline: auto;
}

.mppeu-vm-panel.activo { display: block; }

/* Header */
.mppeu-vm-header {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--espacio-xl);
    margin-bottom: var(--espacio-xl);
    align-items: center;
}

.mppeu-vm-nombre {
    font-size: var(--texto-xl);
    font-weight: 800;
    color: var(--color-texto);
    margin: var(--espacio-sm) 0 var(--espacio-lg);
    line-height: 1.2;
}

.mppeu-vm-autoridad {
    display: flex;
    align-items: center;
    gap: var(--espacio-md);
    background: #f0f4ff;
    border-radius: var(--radio-lg);
    padding: var(--espacio-md) var(--espacio-lg);
    border-left: 3px solid var(--color-azul);
}

.mppeu-vm-aut-foto {
    width: 52px; height: 52px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--color-azul), var(--color-azul-claro));
    display: flex; align-items: center; justify-content: center;
    font-size: var(--texto-lg); font-weight: 800;
    color: var(--color-blanco);
    flex-shrink: 0;
    overflow: hidden;
    border: 2px solid var(--color-blanco);
    box-shadow: var(--sombra-suave);
}

.mppeu-vm-aut-nombre {
    font-size: var(--texto-sm);
    font-weight: 700;
    color: var(--color-texto);
}

.mppeu-vm-aut-cargo {
    font-size: var(--texto-xs);
    color: var(--color-azul);
    font-weight: 500;
}

.mppeu-vm-header-right {
    background: linear-gradient(135deg, #001f5c, var(--color-azul));
    border-radius: var(--radio-xl);
    padding: var(--espacio-xl);
    position: relative;
    overflow: hidden;
}

.mppeu-vm-header-right::before {
    content: '';
    position: absolute;
    bottom: -20px; right: -20px;
    width: 100px; height: 100px;
    border-radius: 50%;
    background: rgba(255,255,255,0.05);
}

.mppeu-vm-quote {
    font-size: var(--texto-sm);
    color: rgba(255,255,255,0.8);
    line-height: 1.7;
    font-style: italic;
    position: relative;
    z-index: 1;
}

.mppeu-vm-quote::before {
    content: '"';
    font-size: 56px;
    color: rgba(252,209,22,0.25);
    position: absolute;
    top: -14px; left: -8px;
    font-style: normal;
    line-height: 1;
}

/* Misión y Visión */
.mppeu-vm-mv-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--espacio-lg);
    margin-bottom: var(--espacio-xl);
}

.mppeu-vm-mv-card {
    border-radius: var(--radio-xl);
    padding: var(--espacio-xl);
    position: relative;
    overflow: hidden;
}

.mppeu-vm-mision {
    background: linear-gradient(135deg, #001f5c 0%, var(--color-azul) 100%);
}

.mppeu-vm-vision {
    background: var(--color-blanco);
    border: 1px solid rgba(0,56,147,0.1);
    box-shadow: var(--sombra-media);
}

.mppeu-vm-mv-deco {
    position: absolute;
    bottom: -30px; right: -30px;
    width: 120px; height: 120px;
    border-radius: 50%;
    background: rgba(255,255,255,0.05);
    pointer-events: none;
}

.mppeu-vm-mv-icon {
    font-size: 28px;
    display: block;
    margin-bottom: var(--espacio-md);
}

.mppeu-vm-mv-label {
    font-size: var(--texto-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: rgba(252,209,22,0.85);
    margin-bottom: var(--espacio-sm);
}

.mppeu-vm-mv-label-claro { color: var(--color-azul); }

.mppeu-vm-mv-titulo {
    font-size: var(--texto-md);
    font-weight: 800;
    color: var(--color-blanco);
    margin: 0 0 var(--espacio-md);
}

.mppeu-vm-mv-titulo-claro { color: var(--color-texto); }

.mppeu-vm-mv-texto {
    font-size: var(--texto-sm);
    color: rgba(255,255,255,0.75);
    line-height: 1.8;
    margin: 0;
}

.mppeu-vm-mv-texto-claro { color: var(--color-gris-medio); }

/* Objetivos */
.mppeu-vm-objetivos { }

.mppeu-vm-obj-titulo {
    display: flex;
    align-items: center;
    gap: var(--espacio-sm);
    font-size: var(--texto-md);
    font-weight: 800;
    color: var(--color-texto);
    margin-bottom: var(--espacio-lg);
}

.mppeu-vm-obj-titulo svg { stroke: var(--color-azul); }

.mppeu-vm-obj-lista {
    display: flex;
    flex-direction: column;
    gap: var(--espacio-sm);
}

.mppeu-vm-obj-item {
    display: flex;
    align-items: flex-start;
    gap: var(--espacio-md);
    background: var(--color-blanco);
    border: 1px solid rgba(0,56,147,0.08);
    border-radius: var(--radio-lg);
    padding: var(--espacio-md) var(--espacio-lg);
    transition: var(--transicion-media);
}

.mppeu-vm-obj-item:hover {
    border-color: var(--color-azul);
    box-shadow: var(--sombra-suave);
    transform: translateX(4px);
}

.mppeu-vm-obj-num {
    width: 28px; height: 28px;
    border-radius: 50%;
    background: var(--color-azul);
    color: var(--color-blanco);
    font-size: var(--texto-xs);
    font-weight: 800;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
    margin-top: 2px;
}

.mppeu-vm-obj-txt {
    font-size: var(--texto-sm);
    color: var(--color-gris-medio);
    line-height: 1.7;
}

/* =============================================
   SHORTCODE — MARCO LEGAL
   ============================================= */
.mppeu-marco-legal {
    background: #f4f6fa;
    padding: var(--espacio-2xl) 0;
}

/* Stats bar */
.mppeu-ml-stats {
    display: flex;
    gap: var(--espacio-xl);
    background: var(--color-blanco);
    border-radius: var(--radio-lg);
    padding: var(--espacio-lg) var(--espacio-xl);
    margin-bottom: var(--espacio-xl);
    border: 1px solid var(--color-gris-borde);
    box-shadow: var(--sombra-suave);
}

.mppeu-ml-stat {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.mppeu-ml-stat-num {
    font-size: var(--texto-xl);
    font-weight: 800;
    color: var(--color-azul);
    line-height: 1;
}

.mppeu-ml-stat-txt {
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
}

/* Filtros */
.mppeu-ml-filtros {
    display: flex;
    gap: var(--espacio-sm);
    flex-wrap: wrap;
    margin-bottom: var(--espacio-xl);
}

.mppeu-ml-filtro {
    padding: 6px 16px;
    border-radius: 20px;
    font-size: var(--texto-sm);
    font-weight: 500;
    cursor: pointer;
    border: 1.5px solid var(--color-gris-borde);
    color: var(--color-gris-medio);
    background: var(--color-blanco);
    transition: var(--transicion-rapida);
    font-family: var(--fuente-principal);
}

.mppeu-ml-filtro:hover {
    border-color: var(--color-azul);
    color: var(--color-azul);
}

.mppeu-ml-filtro.activo {
    background: var(--color-azul);
    border-color: var(--color-azul);
    color: var(--color-blanco);
}

/* Layout grid + sidebar */
.mppeu-ml-layout {
    display: grid;
    grid-template-columns: 1fr 280px;
    gap: var(--espacio-xl);
    align-items: start;
}

/* Grid de documentos */
.mppeu-ml-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--espacio-md);
}

.mppeu-ml-card {
    background: var(--color-blanco);
    border: 1px solid var(--color-gris-borde);
    border-radius: var(--radio-lg);
    padding: var(--espacio-lg);
    display: flex;
    flex-direction: column;
    gap: var(--espacio-md);
    transition: var(--transicion-media);
}

.mppeu-ml-card:hover {
    border-color: var(--color-azul);
    box-shadow: var(--sombra-media);
    transform: translateY(-2px);
}

.mppeu-ml-card-header {
    display: flex;
    align-items: center;
    gap: var(--espacio-md);
}

.mppeu-ml-card-icono {
    width: 44px;
    height: 44px;
    border-radius: var(--radio-md);
    background: rgba(0,56,147,0.08);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: var(--color-azul);
}

.mppeu-ml-card-icono svg { stroke: currentColor; }

.mppeu-ml-card-meta {
    display: flex;
    align-items: center;
    gap: var(--espacio-sm);
    flex-wrap: wrap;
}

.mppeu-ml-fecha {
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
}

.mppeu-ml-card-body { flex: 1; }

.mppeu-ml-card-titulo {
    font-size: var(--texto-sm);
    font-weight: 700;
    color: var(--color-texto);
    margin: 0 0 var(--espacio-sm);
    line-height: 1.4;
}

.mppeu-ml-card-info {
    display: flex;
    gap: var(--espacio-md);
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
    margin-bottom: var(--espacio-sm);
}

.mppeu-ml-card-desc {
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
    line-height: 1.6;
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.mppeu-ml-card-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: var(--espacio-md);
    border-top: 1px solid var(--color-gris-borde);
}

.mppeu-ml-descargas {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
}

.mppeu-ml-descargas svg { stroke: currentColor; }

.mppeu-ml-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--espacio-xs);
    padding: 6px 14px;
    border-radius: var(--radio-md);
    background: var(--color-azul);
    color: var(--color-blanco);
    font-size: var(--texto-xs);
    font-weight: 600;
    text-decoration: none;
    transition: var(--transicion-rapida);
    flex-shrink: 0;
}

.mppeu-ml-btn:hover {
    background: var(--color-azul-oscuro);
    color: var(--color-blanco);
}

.mppeu-ml-btn svg { stroke: currentColor; }

/* Sidebar */
.mppeu-ml-sidebar {
    display: flex;
    flex-direction: column;
    gap: var(--espacio-lg);
    position: sticky;
    top: calc(var(--alto-header) + var(--alto-sintillo) + var(--espacio-lg));
}

.mppeu-ml-sidebar-box {
    background: var(--color-blanco);
    border: 1px solid var(--color-gris-borde);
    border-radius: var(--radio-lg);
    padding: var(--espacio-lg);
    box-shadow: var(--sombra-suave);
}

.mppeu-ml-sidebar-titulo {
    display: flex;
    align-items: center;
    gap: var(--espacio-sm);
    font-size: var(--texto-sm);
    font-weight: 700;
    color: var(--color-texto);
    margin-bottom: var(--espacio-md);
    padding-bottom: var(--espacio-md);
    border-bottom: 1px solid var(--color-gris-borde);
}

.mppeu-ml-sidebar-titulo svg { stroke: var(--color-azul); }

.mppeu-ml-sidebar-lista {
    display: flex;
    flex-direction: column;
    gap: var(--espacio-md);
}

.mppeu-ml-sidebar-item {
    display: flex;
    align-items: center;
    gap: var(--espacio-sm);
}

.mppeu-ml-sidebar-item-info { flex: 1; min-width: 0; }

.mppeu-ml-sidebar-item-nombre {
    font-size: var(--texto-xs);
    font-weight: 600;
    color: var(--color-texto);
    line-height: 1.3;
    margin-bottom: 2px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.mppeu-ml-sidebar-item-meta {
    font-size: 10px;
    color: var(--color-gris-medio);
}

.mppeu-ml-sidebar-btn {
    width: 30px;
    height: 30px;
    border-radius: var(--radio-md);
    background: rgba(0,56,147,0.08);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-azul);
    text-decoration: none;
    flex-shrink: 0;
    transition: var(--transicion-rapida);
}

.mppeu-ml-sidebar-btn:hover {
    background: var(--color-azul);
    color: var(--color-blanco);
}

.mppeu-ml-sidebar-btn svg { stroke: currentColor; }

.mppeu-ml-sidebar-tipos {
    display: flex;
    flex-direction: column;
    gap: var(--espacio-xs);
}

.mppeu-ml-filtro-side {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    border-radius: var(--radio-md) !important;
    text-align: left;
}

.mppeu-ml-filtro-side span {
    background: var(--color-gris-claro);
    border-radius: 10px;
    padding: 1px 7px;
    font-size: var(--texto-xs);
}

.mppeu-ml-filtro-side.activo span {
    background: rgba(255,255,255,0.2);
}

.mppeu-ml-paginacion {
    display: flex;
    gap: var(--espacio-sm);
    justify-content: center;
    margin-top: var(--espacio-xl);
    grid-column: 1 / -1;
}

.mppeu-ml-pag-btn {
    width: 36px;
    height: 36px;
    border-radius: var(--radio-md);
    background: var(--color-blanco);
    border: 1px solid var(--color-gris-borde);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--texto-sm);
    font-weight: 600;
    color: var(--color-texto);
    text-decoration: none;
    transition: var(--transicion-rapida);
}

.mppeu-ml-pag-btn:hover {
    border-color: var(--color-azul);
    color: var(--color-azul);
}

.mppeu-ml-pag-btn.activo {
    background: var(--color-azul);
    border-color: var(--color-azul);
    color: var(--color-blanco);
}
@media (max-width: 480px) {
    .mppeu-ml-layout { grid-template-columns: 1fr; }
    .mppeu-ml-grid { grid-template-columns: 1fr; }
    .mppeu-ml-sidebar { position: static; }
}

/* =============================================
   SHORTCODE — QUIÉNES SOMOS
   ============================================= */

/* Acerca */
.mppeu-acerca {
    background: var(--color-blanco);
    padding: var(--espacio-2xl) 0;
}

.mppeu-acerca-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--espacio-2xl);
    align-items: center;
}

.mppeu-acerca-titulo {
    font-size: var(--texto-2xl);
    font-weight: 800;
    color: var(--color-texto);
    line-height: 1.2;
    margin: var(--espacio-sm) 0 var(--espacio-md);
}

.mppeu-acerca-sep {
    width: 48px;
    height: 4px;
    background: linear-gradient(90deg, var(--color-azul), var(--color-rojo));
    border-radius: var(--radio-sm);
    margin-bottom: var(--espacio-lg);
}

.mppeu-acerca-texto {
    font-size: var(--texto-base);
    color: var(--color-gris-medio);
    line-height: 1.8;
}

.mppeu-acerca-img-wrap {
    border-radius: var(--radio-xl);
    overflow: hidden;
    aspect-ratio: 4/3;
    background: linear-gradient(135deg, #001f5c, var(--color-azul));
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    box-shadow: var(--sombra-fuerte);
}

.mppeu-acerca-placeholder {
    font-size: 80px;
    opacity: 0.12;
}

.mppeu-acerca-badge {
    position: absolute;
    bottom: var(--espacio-lg);
    left: var(--espacio-lg);
    background: rgba(255,255,255,0.95);
    border-radius: var(--radio-lg);
    padding: var(--espacio-md) var(--espacio-lg);
    display: flex;
    gap: var(--espacio-md);
    align-items: center;
    box-shadow: var(--sombra-media);
    backdrop-filter: blur(8px);
}

.mppeu-acerca-badge-num {
    font-size: var(--texto-2xl);
    font-weight: 800;
    color: var(--color-azul);
    line-height: 1;
}

.mppeu-acerca-badge-txt {
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
    line-height: 1.4;
}

/* Misión y Visión */
.mppeu-mv {
    background: #f0f4ff;
    padding: var(--espacio-2xl) 0;
}

.mppeu-mv-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--espacio-lg);
}

.mppeu-mv-card {
    border-radius: var(--radio-xl);
    padding: var(--espacio-xl);
    position: relative;
    overflow: hidden;
}

.mppeu-mv-mision {
    background: linear-gradient(135deg, #001f5c 0%, var(--color-azul) 100%);
}

.mppeu-mv-vision {
    background: var(--color-blanco);
    border: 1px solid rgba(0,56,147,0.1);
    box-shadow: var(--sombra-media);
}

.mppeu-mv-deco {
    position: absolute;
    bottom: -40px; right: -40px;
    width: 140px; height: 140px;
    border-radius: 50%;
    background: rgba(255,255,255,0.05);
    pointer-events: none;
}

.mppeu-mv-icon {
    font-size: 32px;
    margin-bottom: var(--espacio-md);
    display: block;
}

.mppeu-mv-label {
    font-size: var(--texto-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: rgba(252,209,22,0.85);
    margin-bottom: var(--espacio-sm);
}

.mppeu-mv-label-claro { color: var(--color-azul); }

.mppeu-mv-titulo {
    font-size: var(--texto-xl);
    font-weight: 800;
    color: var(--color-blanco);
    margin: 0 0 var(--espacio-md);
}

.mppeu-mv-titulo-claro { color: var(--color-texto); }

.mppeu-mv-texto {
    font-size: var(--texto-sm);
    color: rgba(255,255,255,0.75);
    line-height: 1.8;
    margin: 0;
}

.mppeu-mv-texto-claro { color: var(--color-gris-medio); }

/* =============================================
   VALORES + DIMENSIONES — Quiénes somos
   ============================================= */
.mppeu-valores-dims {
    background: linear-gradient(180deg, #e8eeff 0%, #dde6ff 100%);
    padding: var(--espacio-2xl) 0;
}

.mppeu-vd-grid {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    gap: var(--espacio-xl);
    align-items: start;
}

.mppeu-vd-divisor {
    width: 1px;
    background: rgba(0,56,147,0.1);
    align-self: stretch;
    margin-top: 48px;
}

.mppeu-sep {
    width: 36px;
    height: 3px;
    background: linear-gradient(90deg, var(--color-azul), var(--color-rojo));
    border-radius: var(--radio-sm);
    margin-bottom: var(--espacio-lg);
    margin-top: var(--espacio-sm);
}

/* Valores 2x2 */
.mppeu-valores-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--espacio-md);
}

.mppeu-valor-card {
    background: var(--color-gris-claro);
    border: 1px solid rgba(0,56,147,0.08);
    border-radius: var(--radio-lg);
    padding: var(--espacio-lg) var(--espacio-md);
    text-align: center;
    transition: var(--transicion-media);
}

.mppeu-valor-card:hover {
    border-color: var(--color-azul);
    background: var(--color-blanco);
    box-shadow: var(--sombra-media);
    transform: translateY(-2px);
}

.mppeu-valor-icon {
    font-size: 28px;
    display: block;
    margin-bottom: var(--espacio-sm);
}

.mppeu-valor-nombre {
    font-size: var(--texto-sm);
    font-weight: 700;
    color: var(--color-texto);
    margin-bottom: var(--espacio-xs);
}

.mppeu-valor-desc {
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
    line-height: 1.5;
}

.mppeu-valores-sub {
    font-size: var(--texto-sm);
    color: var(--color-gris-medio);
    margin-bottom: var(--espacio-xs);
}

/* Dimensiones */
.mppeu-dims-lista {
    display: flex;
    flex-direction: column;
    gap: var(--espacio-md);
}

.mppeu-dim-item {
    display: flex;
    align-items: center;
    gap: var(--espacio-lg);
    background: var(--color-blanco);
    border-radius: var(--radio-lg);
    padding: var(--espacio-lg);
    border: 1px solid rgba(0,0,0,0.06);
    border-left: 4px solid var(--accent);
    box-shadow: var(--sombra-suave);
    transition: var(--transicion-media);
}

.mppeu-dim-item:hover {
    box-shadow: var(--sombra-media);
    transform: translateX(4px);
}

.mppeu-dim-icon {
    width: 50px;
    height: 50px;
    border-radius: var(--radio-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    flex-shrink: 0;
}

.mppeu-dim-nombre {
    font-size: var(--texto-md);
    font-weight: 700;
    color: var(--color-texto);
}

/* =============================================
   SHORTCODE — SERVICIO
   ============================================= */

/* Hero */
.srv-hero {
    background: linear-gradient(135deg, #001f5c 0%, var(--color-azul) 100%);
    padding: calc(var(--espacio-3xl) + var(--alto-header));
    position: relative;
    overflow: hidden;
    min-height: 500px;
    max-height: 800px;
    display: flex;
    align-items: center;
}

.srv-hero::before {
    content: '';
    position: absolute;
    top: -40px; right: -40px;
    width: 200px; height: 200px;
    border-radius: 50%;
    background: rgba(255,255,255,0.04);
    pointer-events: none;
}

.srv-hero-inner {
    display: flex;
    align-items: center;
    gap: var(--espacio-xl);
}

.srv-hero-icon {
    width: 80px; height: 80px;
    border-radius: 20px;
    background: rgba(255,255,255,0.12);
    display: flex; align-items: center; justify-content: center;
    font-size: 40px; flex-shrink: 0;
    backdrop-filter: blur(8px);
    border: 1px solid rgba(255,255,255,0.2);
}

.srv-hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: rgba(252,209,22,0.15);
    border: 1px solid rgba(252,209,22,0.3);
    color: var(--color-amarillo);
    font-size: var(--texto-xs);
    font-weight: 600;
    padding: 4px 14px;
    border-radius: 20px;
    margin-bottom: var(--espacio-sm);
    letter-spacing: 0.5px;
    text-transform: uppercase;
}

.srv-hero-titulo {
    font-size: var(--texto-2xl);
    font-weight: 800;
    color: var(--color-blanco);
    margin: 0 0 var(--espacio-sm);
    line-height: 1.2;
}

.srv-hero-sub {
    font-size: var(--texto-base);
    color: rgba(255,255,255,0.65);
    line-height: 1.6;
    margin: 0;
    max-width: 560px;
}

/* Qué es */
.srv-que-es {
    background: var(--color-blanco);
    padding: var(--espacio-2xl) 0;
}

.srv-que-es-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--espacio-2xl);
    align-items: center;
}

.srv-sec-titulo {
    font-size: var(--texto-xl);
    font-weight: 800;
    color: var(--color-texto);
    margin: var(--espacio-sm) 0 var(--espacio-md);
}

.srv-sep {
    width: 40px; height: 3px;
    background: linear-gradient(90deg, var(--color-azul), var(--color-rojo));
    border-radius: var(--radio-sm);
    margin-bottom: var(--espacio-lg);
}

.srv-texto {
    font-size: var(--texto-base);
    color: var(--color-gris-medio);
    line-height: 1.8;
    margin: 0;
}

.srv-img-wrap {
    border-radius: var(--radio-xl);
    overflow: hidden;
    aspect-ratio: 4/3;
    border: 1px solid var(--color-gris-borde);
    box-shadow: var(--sombra-media);
}

.srv-img-placeholder {
    width: 100%; height: 100%;
    background: linear-gradient(135deg, #f0f4ff, #e8eeff);
    display: flex; align-items: center; justify-content: center;
    font-size: 80px; opacity: 0.3;
}

/* Dirigido a */
.srv-dirigido {
    background: #f0f4ff;
    padding: var(--espacio-2xl) 0;
}

.srv-chips {
    display: flex;
    flex-wrap: wrap;
    gap: var(--espacio-md);
    margin-top: var(--espacio-lg);
}

.srv-chip {
    display: flex; align-items: center; gap: var(--espacio-sm);
    background: var(--color-blanco);
    border: 1px solid rgba(0,56,147,0.12);
    border-radius: 30px;
    padding: var(--espacio-sm) var(--espacio-lg);
    font-size: var(--texto-sm);
    font-weight: 500;
    color: var(--color-texto);
    box-shadow: var(--sombra-suave);
    transition: var(--transicion-rapida);
}

.srv-chip:hover {
    border-color: var(--color-azul);
    box-shadow: var(--sombra-media);
}

.srv-chip-icon { font-size: var(--texto-lg); }

/* Cómo funciona */
.srv-pasos {
    background: var(--color-blanco);
    padding: var(--espacio-2xl) 0;
}

.srv-pasos-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--espacio-lg);
    margin-top: var(--espacio-xl);
}

.srv-paso {
    background: #f8faff;
    border: 1px solid rgba(0,56,147,0.08);
    border-radius: var(--radio-lg);
    padding: var(--espacio-xl) var(--espacio-lg);
    transition: var(--transicion-media);
}

.srv-paso:hover {
    transform: translateY(-4px);
    border-color: var(--color-azul);
    box-shadow: var(--sombra-media);
}

.srv-paso-num {
    width: 36px; height: 36px;
    border-radius: 50%;
    background: var(--color-azul);
    color: var(--color-blanco);
    font-size: var(--texto-sm);
    font-weight: 800;
    display: flex; align-items: center; justify-content: center;
    margin-bottom: var(--espacio-md);
}

.srv-paso-titulo {
    font-size: var(--texto-sm);
    font-weight: 700;
    color: var(--color-texto);
    margin-bottom: var(--espacio-sm);
}

.srv-paso-desc {
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
    line-height: 1.6;
}

/* CTA */
.srv-cta {
    background: linear-gradient(135deg, #8B0000 0%, var(--color-rojo) 60%, #e8102a 100%);
    padding: var(--espacio-2xl) 0;
    text-align: center;
    position: relative;
    overflow: hidden;
}

.srv-cta::before {
    content: '';
    position: absolute;
    top: -60px; left: -60px;
    width: 200px; height: 200px;
    border-radius: 50%;
    border: 35px solid rgba(255,255,255,0.06);
    pointer-events: none;
}

.srv-cta::after {
    content: '';
    position: absolute;
    bottom: -40px; right: -40px;
    width: 150px; height: 150px;
    border-radius: 50%;
    border: 25px solid rgba(252,209,22,0.1);
    pointer-events: none;
}

.srv-cta-pattern {
    position: absolute; inset: 0;
    background-image: repeating-linear-gradient(
        -45deg, transparent, transparent 20px,
        rgba(255,255,255,0.02) 20px, rgba(255,255,255,0.02) 21px
    );
    pointer-events: none;
}

.srv-cta-inner { position: relative; z-index: 1; }

.srv-cta-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: rgba(255,255,255,0.12);
    border: 1px solid rgba(255,255,255,0.2);
    color: rgba(255,255,255,0.9);
    font-size: var(--texto-xs);
    font-weight: 600;
    padding: 4px 14px;
    border-radius: 20px;
    margin-bottom: var(--espacio-lg);
    letter-spacing: 0.5px;
    text-transform: uppercase;
}

.srv-cta-titulo {
    font-size: var(--texto-2xl);
    font-weight: 800;
    color: var(--color-blanco);
    margin-bottom: var(--espacio-sm);
    line-height: 1.2;
}

.srv-cta-sub {
    font-size: var(--texto-base);
    color: rgba(255,255,255,0.65);
    margin-bottom: var(--espacio-xl);
    max-width: 440px;
    margin-inline: auto;
    line-height: 1.6;
}

.srv-cta-btns {
    display: flex;
    gap: var(--espacio-md);
    justify-content: center;
    flex-wrap: wrap;
}

.srv-cta-btn-primario {
    display: inline-flex; align-items: center; gap: var(--espacio-sm);
    background: var(--color-amarillo);
    color: var(--color-azul-oscuro);
    font-size: var(--texto-sm);
    font-weight: 700;
    padding: 13px var(--espacio-xl);
    border-radius: var(--radio-md);
    text-decoration: none;
    box-shadow: 0 4px 20px rgba(252,209,22,0.35);
    transition: var(--transicion-media);
}

.srv-cta-btn-primario:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 28px rgba(252,209,22,0.45);
    color: var(--color-azul-oscuro);
}

.srv-cta-btn-primario svg { stroke: currentColor; }

.srv-cta-btn-secundario {
    display: inline-flex; align-items: center; gap: var(--espacio-sm);
    background: transparent;
    color: var(--color-blanco);
    font-size: var(--texto-sm);
    font-weight: 600;
    padding: 13px var(--espacio-xl);
    border-radius: var(--radio-md);
    border: 1.5px solid rgba(255,255,255,0.35);
    text-decoration: none;
    transition: var(--transicion-rapida);
}

.srv-cta-btn-secundario:hover {
    background: rgba(255,255,255,0.1);
    border-color: rgba(255,255,255,0.6);
    color: var(--color-blanco);
}

@media (max-width: 768px) {
    .mppeu-hero-interno-titulo { font-size: var(--texto-2xl); }
    .vm-deco-1, .vm-deco-2, .vm-deco-3 { display: none; }
    .mppeu-aut-grid {  grid-template-columns: repeat(2, 1fr); }
    .mppeu-ml-item { flex-wrap: wrap; }
    .mppeu-ml-btn { width: 100%; justify-content: center;}
    .mppeu-acerca-grid { grid-template-columns: 1fr; }
    .mppeu-acerca-imagen { display: none; }
    .mppeu-mv-grid { grid-template-columns: 1fr; }
    .mppeu-valores-grid { grid-template-columns: repeat(2, 1fr); }
    .mppeu-cifras-qs-grid { flex-direction: column; }
    .mppeu-cifra-qs-sep { width: 60px; height: 1px; }
    .mppeu-ml-layout { grid-template-columns: 1fr; }
    .mppeu-ml-grid { grid-template-columns: 1fr; }
    .mppeu-ml-sidebar { position: static; }
    .srv-hero-inner { flex-direction: column; text-align: center; }
    .srv-hero-sub { margin-inline: auto; }
    .srv-que-es-grid { grid-template-columns: 1fr; }
    .srv-img-wrap { display: none; }
    .srv-pasos-grid { grid-template-columns: 1fr; }
    .srv-cta-btns { flex-direction: column; align-items: center; }
    .mppeu-vm-header { grid-template-columns: 1fr; }
    .mppeu-vm-mv-grid { grid-template-columns: 1fr; }
    .mppeu-vm-panel { padding: var(--espacio-xl) var(--espacio-md); }
    .mppeu-vd-grid { grid-template-columns: 1fr; }
    .mppeu-valores-grid {  grid-template-columns: 1fr 1fr; }
    .mppeu-vd-divisor {
        width: 100%;
        height: 1px;
        margin-top: 0;
    }
}





/* =============================================
   ARCHIVE + SINGLE — NOTICIAS
   ============================================= */

/* Hero del archive */
.arc-hero-sec {
    background: linear-gradient(135deg, #001f5c 0%, var(--color-azul) 100%);
    padding: calc(var(--espacio-3xl) + var(--alto-header));
    position: relative;
    overflow: hidden;
}

.arc-hero-deco-1 {
    position: absolute;
    top: -60px; right: -60px;
    width: 250px; height: 250px;
    border-radius: 50%;
    border: 40px solid rgba(255,255,255,0.04);
    pointer-events: none;
}

.arc-hero-deco-2 {
    position: absolute;
    bottom: -30px; left: 30%;
    width: 120px; height: 120px;
    border-radius: 50%;
    background: rgba(252,209,22,0.05);
    pointer-events: none;
}

.arc-hero-tricolor {
    position: absolute;
    bottom: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--color-azul) 60%, var(--color-rojo) 80%, var(--color-amarillo) 100%);
}

.arc-hero-eyebrow {
    font-size: var(--texto-xs);
    font-weight: 600;
    color: rgba(252,209,22,0.8);
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: var(--espacio-sm);
}

.arc-hero-titulo {
    font-size: var(--texto-3xl);
    font-weight: 800;
    color: var(--color-blanco);
    margin: 0 0 var(--espacio-sm);
}

.arc-hero-sub {
    font-size: var(--texto-base);
    color: rgba(255,255,255,0.65);
    max-width: 560px;
    line-height: 1.6;
    margin: 0;
}

/* Filtros */
.arc-filtros-sec, .bib-filtros-sec, .mppeu-vm-tabs   {
    background: var(--color-blanco);
    border-bottom: 1px solid var(--color-gris-borde);
    padding: var(--espacio-md) 0;
    position: sticky;
    top: calc(var(--alto-header) + var(--alto-sintillo));
    z-index: 9;
    box-shadow: var(--sombra-suave);
    max-width: var(--ancho-maximo);
    margin: 0 auto;
}
 

.arc-filtros-inner {
    display: flex;
    align-items: center;
    gap: var(--espacio-lg);
    flex-wrap: wrap;
}

.arc-search-form {
    display: flex;
    gap: var(--espacio-sm);
    align-items: center;
}

.arc-search-wrap {
    position: relative;
    display: flex;
    align-items: center;
}

.arc-search-wrap svg {
    position: absolute;
    left: 10px;
    stroke: var(--color-gris-medio);
}

.arc-search-input {
    height: 38px;
    padding: 0 var(--espacio-md) 0 36px;
    border: 1.5px solid var(--color-gris-borde);
    border-radius: 20px;
    font-size: var(--texto-sm);
    font-family: var(--fuente-principal);
    outline: none;
    width: 220px;
    transition: var(--transicion-rapida);
}

.arc-search-input:focus {
    border-color: var(--color-azul);
    box-shadow: 0 0 0 3px rgba(0,56,147,0.08);
}

.arc-cats {
    display: flex;
    gap: var(--espacio-sm);
    flex-wrap: wrap;
}

.arc-cat-btn {
    padding: 5px 14px;
    border-radius: 20px;
    font-size: var(--texto-xs);
    font-weight: 500;
    border: 1.5px solid var(--color-gris-borde);
    color: var(--color-gris-medio);
    background: transparent;
    text-decoration: none;
    transition: var(--transicion-rapida);
}

.arc-cat-btn:hover { border-color: var(--color-azul); color: var(--color-azul); }
.arc-cat-btn.activo { background: var(--color-azul); border-color: var(--color-azul); color: var(--color-blanco); }

/* Contenido */
.arc-contenido {
    background: var(--color-gris-claro);
    padding: var(--espacio-2xl) 0;
}

.arc-layout {
    display: grid;
    grid-template-columns: 1fr 280px;
    gap: var(--espacio-xl);
    align-items: start;
}

/* Grid noticias */
.arc-noticias-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr); 
    gap: var(--espacio-lg);
    margin-bottom: var(--espacio-xl);
}

.arc-noticias-chicas {
    display: flex;
    flex-direction: column;
    gap: var(--espacio-md);
}

/* Noticia grande */
.arc-noticia-grande {
    grid-column: span 2; 
    display: flex; 
    flex-direction: column; 
    background: var(--color-blanco);
    border-radius: var(--radio-lg);
    overflow: hidden;
    box-shadow: var(--sombra-suave);
    border: 1px solid var(--color-gris-borde);
}

.arc-noticia-grande:hover {
    box-shadow: var(--sombra-media);
    transform: translateY(-2px);
}

.arc-noticia-img-wrap {
    display: block;
    height: 240px;
    overflow: hidden;
    position: relative;
}

.arc-noticia-img-wrap img { transition: transform 0.4s ease; }
.arc-noticia-img-wrap:hover img { transform: scale(1.04); }

.arc-noticia-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,0.3), transparent);
}

.arc-noticia-placeholder {
    width: 100%; height: 100%;
    background: var(--color-gris-claro);
    display: flex; align-items: center; justify-content: center;
    font-size: 48px; opacity: 0.3;
}

.arc-noticia-badge {
    position: absolute;
    margin-top: var(--espacio-xs);
    margin-left: var(--espacio-xs);
    background: var(--color-azul);
    color: var(--color-blanco);
    font-size: var(--texto-xs);
    font-weight: 600;
    padding: 3px 10px;
    border-radius: 20px;
    text-decoration: none;
}

.arc-noticia-body {
    padding: var(--espacio-lg);
    display: flex;
    flex-direction: column;
    gap: var(--espacio-sm);
}

.arc-noticia-titulo {
    font-size: var(--texto-md);
    font-weight: 700;
    color: var(--color-texto);
    margin: 0;
    line-height: 1.4;
}

.arc-noticia-titulo a { color: inherit; }
.arc-noticia-titulo a:hover { color: var(--color-azul); }

.arc-noticia-fecha {
    display: flex;
    align-items: center;
    gap: var(--espacio-xs);
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
}

.arc-noticia-fecha svg { stroke: var(--color-gris-medio); }

/* Noticia chica */
.arc-noticia-chica {
    background: var(--color-blanco);
    border-radius: var(--radio-lg);
    border: 1px solid var(--color-gris-borde);
    overflow: hidden;
    display: flex;
    box-shadow: var(--sombra-suave);
    transition: var(--transicion-media);
    flex: 1;
    flex-direction: column; /* Cambiado a columna para que no se vea tan apretado */
    height: 100%;
}

.arc-noticia-chica:hover {
    box-shadow: var(--sombra-media);
    border-color: var(--color-azul);
    transform: translateX(3px);
}

.arc-noticia-chica-img {
    width: 100%;
    height: 180px; /* Altura fija para uniformidad */
    flex-shrink: 0;
    overflow: hidden;
    display: block;
}

.arc-noticia-chica-img img { transition: transform 0.4s ease; height: 100%; }
.arc-noticia-chica-img:hover img { transform: scale(1.06); }

.arc-noticia-chica-body {
    padding: var(--espacio-md);
    display: flex;
    flex-direction: column;
    gap: var(--espacio-xs);
}

.arc-noticia-chica-titulo {
    font-size: var(--texto-sm);
    font-weight: 600;
    color: var(--color-texto);
    margin: 0;
    line-height: 1.4;
}

.arc-noticia-chica-titulo a { color: inherit; }
.arc-noticia-chica-titulo a:hover { color: var(--color-azul); }

/* Paginación */
.arc-paginacion { margin-top: var(--espacio-xl); }

.arc-paginacion .page-numbers {
    display: inline-flex;
    align-items: center;
    gap: var(--espacio-sm);
}

.arc-paginacion ul { list-style: none; display: flex; gap: var(--espacio-sm); padding: 0; margin: 0; justify-content: center; }
.arc-paginacion ul li a,
.arc-paginacion ul li span {
    width: 36px; height: 36px;
    border-radius: var(--radio-md);
    border: 1px solid var(--color-gris-borde);
    display: flex; align-items: center; justify-content: center;
    font-size: var(--texto-sm);
    font-weight: 600;
    color: var(--color-texto);
    text-decoration: none;
    transition: var(--transicion-rapida);
}

.arc-paginacion ul li a:hover { border-color: var(--color-azul); color: var(--color-azul); }
.arc-paginacion ul li span.current { background: var(--color-azul); border-color: var(--color-azul); color: var(--color-blanco); }

/* Vacío */
.arc-vacio { text-align: center; padding: var(--espacio-3xl); color: var(--color-gris-medio); }
.arc-vacio-icon { font-size: 48px; margin-bottom: var(--espacio-md); }

/* Sidebar */
.arc-sidebar {
    display: flex;
    flex-direction: column;
    gap: var(--espacio-lg);
    position: sticky;
    top: calc(var(--alto-header) + var(--alto-sintillo) + var(--espacio-3xl));
}

.arc-sidebar-box {
    background: var(--color-blanco);
    border: 1px solid var(--color-gris-borde);
    border-radius: var(--radio-lg);
    padding: var(--espacio-lg);
    box-shadow: var(--sombra-suave);
}

.arc-sidebar-titulo {
    display: flex;
    align-items: center;
    gap: var(--espacio-sm);
    font-size: var(--texto-sm);
    font-weight: 700;
    color: var(--color-texto);
    margin-bottom: var(--espacio-md);
    padding-bottom: var(--espacio-md);
    border-bottom: 1px solid var(--color-gris-borde);
}

.arc-sidebar-titulo svg { stroke: var(--color-azul); }

.arc-sidebar-cats { display: flex; flex-direction: column; gap: var(--espacio-xs); }

.arc-sidebar-cat {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--espacio-sm) var(--espacio-md);
    border-radius: var(--radio-md);
    font-size: var(--texto-sm);
    color: var(--color-gris-medio);
    text-decoration: none;
    transition: var(--transicion-rapida);
}

.arc-sidebar-cat:hover { background: var(--color-gris-claro); color: var(--color-azul); }
.arc-sidebar-cat.activo { background: rgba(0,56,147,0.08); color: var(--color-azul); font-weight: 600; }

.arc-sidebar-cat span {
    background: var(--color-gris-claro);
    border-radius: 10px;
    padding: 1px 7px;
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
}

.arc-sidebar-prog {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--espacio-sm) 0;
    border-bottom: 1px solid var(--color-gris-borde);
    text-decoration: none;
    transition: var(--transicion-rapida);
}

.arc-sidebar-prog:last-of-type { border-bottom: none; }
.arc-sidebar-prog:hover { padding-left: var(--espacio-sm); }
.arc-sidebar-prog svg { stroke: var(--color-azul); flex-shrink: 0; }

.arc-sidebar-prog-nombre {
    font-size: var(--texto-sm);
    font-weight: 600;
    color: var(--color-texto);
    margin-bottom: 2px;
}

.arc-sidebar-prog-tipo {
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
}

/* ---- SINGLE ---- */
.single-hero-sec {
    padding: calc(var(--espacio-3xl) + var(--alto-header) + var(--alto-sintillo))
             0 var(--espacio-2xl);
    position: relative;
    min-height: 600px;
    display: flex;
    align-items: flex-end;
}

.single-hero-content { position: relative; z-index: 2; max-width: 760px; }

.single-hero-meta {
    display: flex;
    align-items: center;
    gap: var(--espacio-md);
    margin-bottom: var(--espacio-md);
}

.single-hero-badge {
    background: rgba(0,56,147,0.8);
    color: var(--color-blanco);
    font-size: var(--texto-xs);
    font-weight: 600;
    padding: 4px 12px;
    border-radius: 20px;
    text-decoration: none;
    backdrop-filter: blur(4px);
}

.single-hero-fecha {
    font-size: var(--texto-xs);
    color: rgba(255,255,255,0.65);
}

.single-hero-titulo {
    font-size: var(--texto-2xl);
    font-weight: 800;
    color: var(--color-blanco);
    line-height: 1.25;
    margin: 0;
    text-shadow: 0 2px 8px rgba(0,0,0,0.3);
}

.single-contenido-sec {
    background: var(--color-gris-claro);
    padding: var(--espacio-2xl) 0;
}

.single-layout {
    display: grid;
    grid-template-columns: 1fr 280px;
    gap: var(--espacio-xl);
    align-items: start;
}

.single-main {
    background: var(--color-blanco);
    border-radius: var(--radio-lg);
    padding: var(--espacio-xl);
    box-shadow: var(--sombra-suave);
    border: 1px solid var(--color-gris-borde);
}

.single-breadcrumb {
    display: flex;
    align-items: center;
    gap: var(--espacio-sm);
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
    margin-bottom: var(--espacio-xl);
    flex-wrap: wrap;
}

.single-breadcrumb a { color: var(--color-azul); text-decoration: none; }
.single-breadcrumb a:hover { text-decoration: underline; }

.single-texto {
    font-size: var(--texto-base);
    color: var(--color-texto);
    line-height: 1.9;
}

.single-texto p { margin-bottom: var(--espacio-lg); }
.single-texto h2 { font-size: var(--texto-xl); font-weight: 700; color: var(--color-texto); margin: var(--espacio-xl) 0 var(--espacio-md); }
.single-texto h3 { font-size: var(--texto-lg); font-weight: 700; color: var(--color-texto); margin: var(--espacio-lg) 0 var(--espacio-md); }
.single-texto img { max-width: 100%; border-radius: var(--radio-md); margin: var(--espacio-lg) 0; }

.single-compartir {
    display: flex;
    align-items: center;
    gap: var(--espacio-md);
}

.single-compartir-label {
    font-size: var(--texto-sm);
    font-weight: 600;
    color: var(--color-gris-medio);
}

.single-share-btn {
    width: 36px; height: 36px;
    border-radius: 50%;
    background: var(--color-gris-claro);
    display: flex; align-items: center; justify-content: center;
    color: var(--color-azul);
    text-decoration: none;
    transition: var(--transicion-rapida);
}

.single-share-btn:hover { background: var(--color-azul); color: var(--color-blanco); }

.single-sidebar {
    display: flex;
    flex-direction: column;
    gap: var(--espacio-lg);
    position: sticky;
    top: calc(var(--alto-header) + var(--alto-sintillo) + var(--espacio-lg));
}

.arc-sidebar-noticia {
    display: flex;
    gap: var(--espacio-md);
    padding: var(--espacio-sm) 0;
    border-bottom: 1px solid var(--color-gris-borde);
    text-decoration: none;
    transition: var(--transicion-rapida);
}

.arc-sidebar-noticia:last-of-type { border-bottom: none; }
.arc-sidebar-noticia:hover { padding-left: var(--espacio-sm); }

.arc-sidebar-noticia-img {
    width: 52px; height: 52px;
    border-radius: var(--radio-md);
    overflow: hidden;
    flex-shrink: 0;
}

.arc-sidebar-noticia-titulo {
    font-size: var(--texto-xs);
    font-weight: 600;
    color: var(--color-texto);
    line-height: 1.4;
    margin-bottom: 3px;
}

.arc-sidebar-noticia-fecha {
    font-size: 10px;
    color: var(--color-gris-medio);
}

/* Responsive */
@media (max-width: 768px) {
    .arc-layout { grid-template-columns: 1fr; }
    .arc-noticias-grid { grid-template-columns: 1fr; }
    .single-layout { grid-template-columns: 1fr; }
    .arc-sidebar { position: static; }
    .single-sidebar { position: static; }
    .arc-hero-titulo { font-size: var(--texto-2xl); }
    .single-hero-titulo { font-size: var(--texto-xl); }
    .arc-filtros-inner { flex-direction: column; align-items: flex-start; }
    .arc-noticia-grande { grid-column: span 1; flex-direction: column;}
}



/* =============================================
   UNIVERSIDADES ARCHIVE
   ============================================= */

/* Stats */
.universidades-stats {
    margin-bottom: var(--espacio-lg);
    padding: var(--espacio-sm) var(--espacio-md);
    background: #f8fafc;
    border-radius: var(--radio-md);
    font-size: var(--texto-sm);
    color: var(--color-gris-medio);
}

.stats-count {
    font-weight: 600;
    color: var(--color-azul);
}

.universidades-stats {
    margin-bottom: var(--espacio-lg);
    padding: var(--espacio-sm) var(--espacio-md);
    background: #f8fafc;
    border-radius: var(--radio-md);
    font-size: var(--texto-sm);
    color: var(--color-gris-medio);
}

.stats-count {
    font-weight: 600;
    color: var(--color-azul);
}

/* Grid de universidades */
.universidades-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--espacio-lg);
    margin-bottom: var(--espacio-xl);
}

.universidad-card {
    background: var(--color-blanco);
    border-radius: var(--radio-lg);
    overflow: hidden;
    transition: var(--transicion-media);
    box-shadow: var(--sombra-suave);
    border: 1px solid var(--color-gris-borde);
}

.universidad-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--sombra-media);
}

.universidad-card-link {
    text-decoration: none;
    display: block;
}

.universidad-card-header {
    height: 140px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}

.universidad-card-logo-wrapper {
    width: 100px;
    height: 100px;
    background: var(--color-blanco);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
    padding: 2px;
}

.universidad-card-logo-placeholder {
    font-size: 48px;
}

.universidad-card-body {
    padding: var(--espacio-lg);
    text-align: center;
}

.universidad-card-siglas {
    font-size: var(--texto-xs);
    font-weight: 600;
    color: var(--color-azul);
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: var(--espacio-xs);
}

.universidad-card-title {
    font-size: var(--texto-md);
    font-weight: 700;
    color: var(--color-texto);
    margin: 0 0 var(--espacio-sm);
    line-height: 1.4;
}

.universidad-card-tipo {
    margin-bottom: var(--espacio-md);
}

.universidad-card-tipo .badge {
    background: #eff6ff;
    color: var(--color-azul);
    padding: 4px 12px;
    border-radius: 20px;
    font-size: var(--texto-xs);
    font-weight: 500;
}

.universidad-card-footer {
    display: inline-flex;
    align-items: center;
    gap: var(--espacio-xs);
    font-size: var(--texto-sm);
    font-weight: 500;
    color: var(--color-azul);
    transition: var(--transicion-rapida);
}

.universidad-card-link:hover .universidad-card-footer {
    gap: var(--espacio-md);
}

.ver-mas-link {
    text-decoration: none;
}

/* =============================================
   SINGLE UNIVERSIDAD
   ============================================= */

.uni-hero-sec {
    padding: calc(var(--espacio-3xl) + var(--alto-header));
    position: relative;
    min-height: 380px;
    display: flex;
    align-items: flex-end;
}

.uni-hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0,0,0,0.3) 0%, rgba(0,0,0,0.7) 100%);
}

.uni-hero-content {
    position: relative;
    z-index: 2;
    max-width: 760px;
}

.uni-hero-badge {
    margin-bottom: var(--espacio-sm);
}

.uni-tipo-badge {
    background: rgba(252,209,22,0.9);
    color: #001f5c;
    font-size: var(--texto-xs);
    font-weight: 600;
    padding: 4px 12px;
    border-radius: 20px;
    text-decoration: none;
}

.uni-hero-siglas {
    font-size: var(--texto-sm);
    font-weight: 600;
    color: rgba(252,209,22,0.9);
    text-transform: uppercase;
    letter-spacing: 2px;
    margin-bottom: var(--espacio-xs);
}

.uni-hero-titulo {
    font-size: var(--texto-2xl);
    font-weight: 800;
    color: var(--color-blanco);
    margin: 0 0 var(--espacio-sm);
    line-height: 1.2;
}

.uni-hero-fundacion {
    font-size: var(--texto-sm);
    color: rgba(255,255,255,0.8);
}

/* Contenido principal */
.uni-contenido-sec {
    background: var(--color-gris-claro);
    padding: var(--espacio-2xl) 0;
}

.uni-layout {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: var(--espacio-xl);
    align-items: start;
}

.uni-main {
    background: var(--color-blanco);
    border-radius: var(--radio-lg);
    padding: var(--espacio-xl);
    box-shadow: var(--sombra-suave);
    position: relative;
}

/* Logo flotante */
.uni-logo-flotante {
    position: absolute;
    top: -50px;
    right: var(--espacio-xl);
    width: 100px;
    height: 100px;
    background: var(--color-blanco);
    border-radius: 50%;
    box-shadow: var(--sombra-media);
    display: flex;
    align-items: center;
    justify-content: center;
    border: 4px solid var(--color-blanco);
}

.uni-logo-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%;
}

.uni-logo-placeholder {
    font-size: 48px;
}

/* Grid de información */
.uni-info-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--espacio-md);
    margin-bottom: var(--espacio-xl);
    margin-top: var(--espacio-md);
}

.uni-info-card {
    background: #f8fafc;
    padding: var(--espacio-md);
    border-radius: var(--radio-md);
    display: flex;
    align-items: center;
    gap: var(--espacio-sm);
    transition: var(--transicion-rapida);
}

.uni-info-card:hover {
    background: #f1f5f9;
}

.uni-info-icon {
    font-size: 24px;
}

.uni-info-content {
    flex: 1;
}

.uni-info-label {
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
    margin-bottom: 2px;
}

.uni-info-value {
    font-size: var(--texto-sm);
    font-weight: 600;
    color: var(--color-texto);
    word-break: break-all;
}

.uni-info-value a {
    color: var(--color-azul);
    text-decoration: none;
}

.uni-info-value a:hover {
    text-decoration: underline;
}

/* Secciones */
.uni-section-title {
    font-size: var(--texto-lg);
    font-weight: 700;
    color: var(--color-texto);
    margin: var(--espacio-xl) 0 var(--espacio-lg);
    padding-bottom: var(--espacio-sm);
    border-bottom: 2px solid var(--color-azul);
    display: inline-block;
}

.title-icon {
    margin-right: var(--espacio-sm);
}

.uni-descripcion {
    margin-bottom: var(--espacio-xl);
}

.uni-texto {
    font-size: var(--texto-base);
    color: var(--color-texto);
    line-height: 1.8;
}

.uni-texto p {
    margin-bottom: var(--espacio-md);
}

/* Sedes grid */
.uni-sedes-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: var(--espacio-md);
    margin-top: var(--espacio-md);
}

.uni-sede-card {
    background: #f8fafc;
    padding: var(--espacio-md);
    border-radius: var(--radio-md);
    text-align: center;
    transition: var(--transicion-rapida);
}

.uni-sede-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--sombra-suave);
}

.uni-sede-icon {
    font-size: 28px;
    margin-bottom: var(--espacio-sm);
}

.uni-sede-nombre {
    font-size: var(--texto-sm);
    font-weight: 600;
    color: var(--color-texto);
    margin-bottom: var(--espacio-xs);
}

.uni-sede-estado {
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
}

/* Dirección */
.uni-direccion-contenido {
    background: #f8fafc;
    padding: var(--espacio-lg);
    border-radius: var(--radio-md);
    border-left: 3px solid var(--color-azul);
}

/* Sidebar */
.uni-sidebar {
    display: flex;
    flex-direction: column;
    gap: var(--espacio-lg);
    position: sticky;
    top: calc(var(--alto-header) + var(--alto-sintillo) + var(--espacio-lg));
}

.uni-sidebar-box {
    background: var(--color-blanco);
    border: 1px solid var(--color-gris-borde);
    border-radius: var(--radio-lg);
    padding: var(--espacio-lg);
    box-shadow: var(--sombra-suave);
}

.uni-sidebar-titulo {
    font-size: var(--texto-sm);
    font-weight: 700;
    color: var(--color-texto);
    margin-bottom: var(--espacio-md);
    padding-bottom: var(--espacio-sm);
    border-bottom: 1px solid var(--color-gris-borde);
}

/* Stats box */
.uni-stats-list {
    display: flex;
    flex-direction: column;
    gap: var(--espacio-sm);
}

.uni-stat-item {
    display: flex;
    justify-content: space-between;
    font-size: var(--texto-sm);
}

.stat-label {
    color: var(--color-gris-medio);
}

.stat-value {
    font-weight: 600;
    color: var(--color-texto);
}

/* Compartir */
.uni-compartir {
    display: flex;
    gap: var(--espacio-sm);
}

.uni-share-btn {
    flex: 1;
    text-align: center;
    padding: var(--espacio-sm);
    background: var(--color-gris-claro);
    border-radius: var(--radio-md);
    text-decoration: none;
    font-size: var(--texto-sm);
    font-weight: 500;
    color: var(--color-texto);
    transition: var(--transicion-rapida);
}

.uni-share-btn:hover {
    background: var(--color-azul);
    color: var(--color-blanco);
}

/* Universidades relacionadas */
.uni-sidebar-relacionada {
    display: flex;
    align-items: center;
    gap: var(--espacio-md);
    padding: var(--espacio-sm) 0;
    border-bottom: 1px solid var(--color-gris-borde);
    text-decoration: none;
    transition: var(--transicion-rapida);
}

.uni-sidebar-relacionada:last-child {
    border-bottom: none;
}

.uni-sidebar-relacionada:hover {
    transform: translateX(4px);
}

.uni-rel-logo {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    object-fit: cover;
    background: #f8fafc;
}

.uni-rel-info {
    flex: 1;
}

.uni-rel-siglas {
    font-size: var(--texto-xs);
    font-weight: 600;
    color: var(--color-azul);
    text-transform: uppercase;
}

.uni-rel-nombre {
    font-size: var(--texto-xs);
    color: var(--color-texto);
    line-height: 1.3;
}

/* Grid de universidades relacionadas */
.uni-relacionadas-grid {
    background: var(--color-gris-claro);
    /* padding: var(--espacio-2xl) 0; */
}

/* Responsive */
@media (max-width: 768px) {
    .uni-layout {
        grid-template-columns: 1fr;
    }
    
    .uni-sidebar {
        position: static;
    }
    
    .uni-logo-flotante {
        position: relative;
        top: -70px;
        margin-bottom: -40px;
        left: 50%;
        transform: translateX(-50%);
        right: auto;
    }
    
    .uni-info-grid {
        margin-top: 0;
    }
    
    .uni-hero-titulo {
        font-size: var(--texto-xl);
    }
    
    .universidades-grid {
        grid-template-columns: 1fr;
    }
    
}


/* =============================================
   BÚSQUEDA GLOBAL
   ============================================= */

/* Filtros CPT en el hero */
.sh-cpt-filtros {
    display: flex;
    gap: var(--espacio-sm);
    flex-wrap: wrap;
    margin-top: var(--espacio-lg);
}

.sh-cpt-btn {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 6px 14px;
    border-radius: 20px;
    font-size: var(--texto-xs);
    font-weight: 600;
    cursor: pointer;
    border: 1px solid rgba(255,255,255,0.2);
    color: rgba(255,255,255,0.7);
    background: rgba(255,255,255,0.08);
    text-decoration: none;
    transition: var(--transicion-rapida);
}

.sh-cpt-btn:hover {
    background: rgba(255,255,255,0.15);
    color: var(--color-blanco);
}

.sh-cpt-btn.activo {
    background: rgba(255,255,255,0.95);
    color: var(--color-azul);
    border-color: transparent;
}

.sh-cpt-count {
    background: rgba(255,255,255,0.2);
    border-radius: 10px;
    padding: 0 6px;
    font-size: 10px;
}

.sh-cpt-btn.activo .sh-cpt-count {
    background: rgba(0,56,147,0.12);
}

/* Grupo de resultados */
.sh-grupo {
    background: var(--color-blanco);
    border-radius: var(--radio-lg);
    overflow: hidden;
    border: 1px solid var(--color-gris-borde);
    margin-bottom: var(--espacio-xl);
    box-shadow: var(--sombra-suave);
}

.sh-grupo-header {
    display: flex;
    align-items: center;
    gap: var(--espacio-md);
    padding: var(--espacio-md) var(--espacio-lg);
    border-bottom: 1px solid var(--color-gris-borde);
    background: #f8faff;
}

.sh-grupo-icon { font-size: var(--texto-xl); }

.sh-grupo-titulo {
    font-size: var(--texto-md);
    font-weight: 800;
    color: var(--color-texto);
    margin: 0;
    flex: 1;
}

.sh-grupo-badge {
    background: var(--color-azul);
    color: var(--color-blanco);
    font-size: var(--texto-xs);
    font-weight: 700;
    padding: 2px 10px;
    border-radius: 20px;
}

.sh-grupo-ver {
    font-size: var(--texto-xs);
    color: var(--color-azul);
    font-weight: 600;
    text-decoration: none;
}

/* Grid de cards */
.sh-cards-wrap {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--espacio-md);
    padding: var(--espacio-lg);
}

/* Card base */
.sh-card {
    border-radius: var(--radio-lg);
    border: 1px solid var(--color-gris-borde);
    overflow: hidden;
    text-decoration: none;
    transition: var(--transicion-media);
    display: flex;
    flex-direction: column;
    background: var(--color-blanco);
}

.sh-card:hover {
    border-color: var(--color-azul);
    box-shadow: var(--sombra-media);
    transform: translateY(-2px);
}

.sh-card-body {
    padding: var(--espacio-md);
    display: flex;
    flex-direction: column;
    gap: var(--espacio-xs);
    flex: 1;
}

.sh-card-titulo {
    font-size: var(--texto-sm);
    font-weight: 600;
    color: var(--color-texto);
    line-height: 1.4;
}

/* Noticia */
.sh-noticia-img {
    height: var(--alto-card-imagen);
    position: relative;
    overflow: hidden;
    background: var(--color-gris-claro);
}

.sh-img-placeholder {
    width: 100%; height: 100%;
    display: flex; align-items: center; justify-content: center;
    font-size: 32px; opacity: 0.3;
    background: linear-gradient(135deg, #1a3a6b, #003893);
}

.sh-noticia-cat {
    position: absolute;
    top: var(--espacio-sm);
    left: var(--espacio-sm);
    background: var(--color-azul);
    color: var(--color-blanco);
    font-size: 9px;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 10px;
    z-index: 1;
}

.sh-noticia-meta {
    display: flex;
    gap: var(--espacio-xs);
    flex-wrap: wrap;
    align-items: center;
}

.sh-tag {
    background: #f0f4ff;
    color: var(--color-azul);
    font-size: 9px;
    font-weight: 500;
    padding: 1px 7px;
    border-radius: 8px;
}

.sh-fecha {
    font-size: 10px;
    color: var(--color-gris-medio);
}

/* Universidad */
.sh-uni-header {
    height: var(--alto-card-imagen);
    display: flex;
    align-items: center;
    justify-content: center;
}

.sh-uni-logo {
    width: 120px; 
    height: 120px;
    border-radius: 50%;
    background: rgba(255,255,255,0.15);
    display: flex; align-items: center; justify-content: center;
    font-size: 22px;
    overflow: hidden;
    border: 2px solid rgba(255,255,255,0.3);
}

.sh-uni-siglas {
    font-size: var(--texto-md);
    font-weight: 800;
    color: var(--color-azul);
}

.sh-uni-tipo {
    display: inline-block;
    background: rgba(0,56,147,0.08);
    color: var(--color-azul);
    font-size: 9px;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 8px;
    margin-top: var(--espacio-xs);
}

/* Programa */
.sh-prog-header {
    height: var(--alto-card-imagen);
    display: flex;
    align-items: flex-end;
    padding: var(--espacio-sm);
    position: relative;
    overflow: hidden;
}

.sh-prog-bg { opacity: 0.3; }

.sh-prog-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,0.4), transparent);
}

.sh-prog-estado {
    font-size: 9px;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 10px;
    position: relative;
    z-index: 1;
}

.sh-est-activo     { background: rgba(74,222,128,0.2); color: #4ade80; border: 1px solid rgba(74,222,128,0.3); }
.sh-est-desarrollo { background: rgba(251,191,36,0.2); color: #fbbf24; border: 1px solid rgba(251,191,36,0.3); }
.sh-est-finalizado { background: rgba(255,255,255,0.1); color: rgba(255,255,255,0.6); border: 1px solid rgba(255,255,255,0.2); }

.sh-prog-tipo {
    font-size: 9px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Publicación */
.sh-card-pub { flex-direction: row; }

.sh-pub-portada {
    width: 50px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    font-weight: 700;
    color: var(--color-blanco);
    writing-mode: vertical-rl;
    letter-spacing: 1px;
}

.sh-pub-tipo {
    font-size: 9px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.sh-pub-meta {
    font-size: 10px;
    color: var(--color-gris-medio);
}

/* Comunicado */
.sh-com-img {
    height: var(--alto-card-imagen);;
    position: relative;
    overflow: hidden;
    background: var(--color-gris-claro);
}

/* Responsive */
@media (max-width: 768px) {
    .sh-cards-wrap { grid-template-columns: 1fr; }
    .sh-cpt-filtros { gap: var(--espacio-xs); }
    .sh-card-pub { flex-direction: column; }
    .sh-pub-portada { width: 100%; height: 50px; writing-mode: horizontal-tb; }
}

/* =============================================
   BIBLIOTECA DIGITAL - PUBLICACIONES
   ============================================= */

/* Hero */
.bib-hero-sec {
    background: linear-gradient(135deg, #0a1628 0%, #1a3a6b 100%);
    padding: calc(var(--espacio-3xl) + var(--alto-header) + var(--alto-sintillo)) 0 var(--espacio-2xl);
    position: relative;
    overflow: hidden;
}

.bib-hero-sec.hero-biblioteca-digital { background: linear-gradient(135deg, #1e3a5f 0%, #2c5282 100%); }
.bib-hero-sec.hero-universidades { background: linear-gradient(135deg, #1a4731 0%, #276749 100%); }
.bib-hero-sec.hero-otros-documentos { background: linear-gradient(135deg, #4a3a6e 0%, #6b46c1 100%); }

.bib-hero-deco-libros {
    position: absolute;
    right: 5%;
    bottom: 0;
    display: flex;
    align-items: flex-end;
    gap: 8px;
    opacity: 0.15;
    pointer-events: none;
}

.bib-libro-deco {
    width: 40px;
    border-radius: 4px 4px 0 0;
}

.arc-hero-tricolor {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--color-azul) 60%, var(--color-rojo) 80%, var(--color-amarillo) 100%);
}

.bib-hero-eyebrow {
    font-size: var(--texto-xs);
    font-weight: 600;
    color: rgba(252, 209, 22, 0.8);
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: var(--espacio-sm);
}

.bib-hero-titulo {
    font-size: var(--texto-3xl);
    font-weight: 800;
    color: var(--color-blanco);
    margin: 0 0 var(--espacio-sm);
}

.bib-hero-sub {
    font-size: var(--texto-base);
    color: rgba(255, 255, 255, 0.65);
    max-width: 560px;
    line-height: 1.6;
    margin-bottom: var(--espacio-xl);
}

/* Buscador hero */
.bib-hero-search-form {
    display: flex;
    gap: var(--espacio-sm);
    max-width: 560px;
}

.bib-hero-search-wrapper {
    flex: 1;
    position: relative;
}

.bib-hero-search-wrapper svg {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    stroke: #94a3b8;
}

.bib-hero-search-input {
    width: 100%;
    height: 44px;
    padding: 0 16px 0 40px;
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 30px;
    font-size: var(--texto-sm);
    background: rgba(255, 255, 255, 0.1);
    backdrop-filter: blur(4px);
    color: var(--color-blanco);
}

.bib-hero-search-input::placeholder {
    color: rgba(255, 255, 255, 0.5);
}

.bib-hero-search-input:focus {
    outline: none;
    border-color: #FCD116;
    background: rgba(255, 255, 255, 0.15);
}

.bib-hero-search-btn {
    background: #FCD116;
    color: #001f5c;
    border: none;
    padding: 0 24px;
    height: 44px;
    border-radius: 30px;
    font-weight: 700;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    transition: var(--transicion-rapida);
}

.bib-hero-search-btn:hover {
    background: #ffdd44;
    transform: translateY(-2px);
}

/* Stats bar */
.bib-stats-bar {
    background: var(--color-blanco);
    border-bottom: 1px solid var(--color-gris-borde);
    padding: var(--espacio-md) 0;
}

.bib-stats-grid {
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap;
    gap: var(--espacio-lg);
}

.bib-stat {
    text-align: center;
}

.bib-stat-num {
    font-size: var(--texto-xl);
    font-weight: 800;
    color: var(--color-azul);
    display: block;
    line-height: 1.2;
}

.bib-stat-txt {
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
}

/* Filtros */
.bib-filtros-sec {
    background: var(--color-blanco);
    border-bottom: 1px solid var(--color-gris-borde);
    padding: var(--espacio-md) 0;
    position: sticky;
    top: calc(var(--alto-header) + var(--alto-sintillo));
    z-index: 9;
    box-shadow: var(--sombra-suave);
}

.bib-filtros-wrapper {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--espacio-md);
}

.bib-filtro-grupo {
    display: flex;
    align-items: center;
    gap: var(--espacio-md);
    flex-wrap: wrap;
}

.bib-filtro-label {
    font-size: var(--texto-xs);
    font-weight: 600;
    color: var(--color-gris-medio);
    text-transform: uppercase;
}

.bib-filtros-tipos {
    display: flex;
    gap: var(--espacio-sm);
    flex-wrap: wrap;
}

.bib-tipo-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 5px 14px;
    border-radius: 20px;
    font-size: var(--texto-xs);
    font-weight: 500;
    border: 1.5px solid var(--color-gris-borde);
    color: var(--color-gris-medio);
    background: transparent;
    text-decoration: none;
    transition: var(--transicion-rapida);
}

.bib-tipo-btn:hover {
    border-color: var(--color-azul);
    color: var(--color-azul);
}

.bib-tipo-btn.activo {
    background: var(--color-azul);
    border-color: var(--color-azul);
    color: var(--color-blanco);
}

.tipo-icon {
    font-size: 12px;
}

.bib-tipo-count {
    background: rgba(0, 0, 0, 0.08);
    border-radius: 20px;
    padding: 1px 6px;
    font-size: 10px;
    font-weight: 600;
    margin-left: 4px;
}

.bib-tipo-btn.activo .bib-tipo-count {
    background: rgba(255, 255, 255, 0.2);
    color: white;
}

.bib-limpiar-filtros {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 5px 14px;
    border-radius: 20px;
    font-size: var(--texto-xs);
    font-weight: 500;
    background: #fef2f2;
    color: #dc2626;
    text-decoration: none;
    transition: var(--transicion-rapida);
}

.bib-limpiar-filtros:hover {
    background: #fee2e2;
}

/* Layout principal */
.bib-layout {
    display: grid;
    grid-template-columns: 1fr 280px;
    gap: var(--espacio-xl);
    align-items: start;
    background: var(--color-gris-claro);
    padding: var(--espacio-2xl) 0;
}

/* Grid de publicaciones */
.bib-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: var(--espacio-lg);
    margin-bottom: var(--espacio-xl);
}

/* Tarjetas */
.bib-publicacion-card {
    background: var(--color-blanco);
    border-radius: var(--radio-lg);
    overflow: hidden;
    transition: var(--transicion-media);
    box-shadow: var(--sombra-suave);
    border: 1px solid var(--color-gris-borde);
    height: 100%;
    display: flex;
    flex-direction: column;
}

.bib-publicacion-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--sombra-media);
    border-color: var(--color-azul);
}

.bib-publicacion-portada {
    height: 200px;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    flex-shrink: 0;
}

.bib-publicacion-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease;
}

.bib-publicacion-card:hover .bib-publicacion-img {
    transform: scale(1.05);
}

.bib-publicacion-placeholder {
    font-size: 48px;
    opacity: 0.5;
}

.bib-publicacion-info {
    padding: var(--espacio-lg);
    display: flex;
    flex-direction: column;
    gap: var(--espacio-sm);
    flex: 1;
}

/* Taxonomías */
.bib-publicacion-taxonomias {
    display: flex;
    flex-wrap: wrap;
    gap: var(--espacio-xs);
    margin-bottom: var(--espacio-xs);
}

.bib-tax-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 10px;
    border-radius: 20px;
    font-size: var(--texto-xs);
    font-weight: 500;
    text-decoration: none;
    transition: var(--transicion-rapida);
}

.bib-tax-badge.tipo {
    background: rgba(0, 56, 147, 0.1);
    color: var(--color-azul);
}

.bib-tax-badge.tipo:hover {
    background: var(--color-azul);
    color: var(--color-blanco);
}

.bib-tax-badge.categoria {
    background: var(--color-gris-claro);
    color: var(--color-gris-medio);
}

.bib-tax-badge.categoria:hover {
    background: #e2e8f0;
    color: var(--color-texto);
}

/* Títulos */
.bib-publicacion-titulo {
    font-size: var(--texto-md);
    font-weight: 700;
    color: var(--color-texto);
    margin: 0;
    line-height: 1.4;
}

.bib-publicacion-titulo a {
    color: inherit;
    text-decoration: none;
}

.bib-publicacion-titulo a:hover {
    color: var(--color-azul);
}

/* Metadata */
.bib-publicacion-metadata {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--espacio-md);
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
}

.bib-publicacion-autor,
.bib-publicacion-anio,
.bib-publicacion-descargas {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.bib-publicacion-autor svg,
.bib-publicacion-anio svg,
.bib-publicacion-descargas svg {
    stroke: var(--color-gris-medio);
}

/* Resumen */
.bib-publicacion-resumen {
    font-size: var(--texto-sm);
    color: var(--color-gris-medio);
    line-height: 1.5;
    margin: 0;
}

/* Botón descarga */
.bib-publicacion-actions {
    margin-top: auto;
    padding-top: var(--espacio-md);
}

.bib-btn-download {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    padding: 10px 16px;
    background: var(--color-azul);
    color: var(--color-blanco);
    border: none;
    border-radius: var(--radio-md);
    font-size: var(--texto-sm);
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;
    transition: var(--transicion-rapida);
}

.bib-btn-download:hover {
    background: #135e96;
    transform: translateY(-2px);
}

.btn-download-size {
    font-size: 10px;
    opacity: 0.8;
    font-weight: 400;
}

.bib-no-disponible {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    padding: 10px 16px;
    background: var(--color-gris-claro);
    color: var(--color-gris-medio);
    border-radius: var(--radio-md);
    font-size: var(--texto-sm);
}

/* Sidebar - idéntico a noticias */
.bib-sidebar {
    display: flex;
    flex-direction: column;
    gap: var(--espacio-lg);
    position: sticky;
    top: calc(var(--alto-header) + var(--alto-sintillo) + var(--espacio-3xl));
}

.arc-sidebar-box {
    background: var(--color-blanco);
    border: 1px solid var(--color-gris-borde);
    border-radius: var(--radio-lg);
    padding: var(--espacio-lg);
    box-shadow: var(--sombra-suave);
}

.arc-sidebar-titulo {
    display: flex;
    align-items: center;
    gap: var(--espacio-sm);
    font-size: var(--texto-sm);
    font-weight: 700;
    color: var(--color-texto);
    margin-bottom: var(--espacio-md);
    padding-bottom: var(--espacio-md);
    border-bottom: 1px solid var(--color-gris-borde);
}

.arc-sidebar-titulo svg {
    stroke: var(--color-azul);
}

.arc-sidebar-lista {
    display: flex;
    flex-direction: column;
    gap: var(--espacio-xs);
}

.arc-sidebar-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--espacio-sm) var(--espacio-md);
    border-radius: var(--radio-md);
    font-size: var(--texto-sm);
    color: var(--color-gris-medio);
    text-decoration: none;
    transition: var(--transicion-rapida);
}

.arc-sidebar-item:hover {
    background: var(--color-gris-claro);
    color: var(--color-azul);
}

.arc-sidebar-item.activo {
    background: rgba(0, 56, 147, 0.08);
    color: var(--color-azul);
    font-weight: 600;
}

.arc-sidebar-count {
    background: var(--color-gris-claro);
    border-radius: 10px;
    padding: 1px 7px;
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
}

.arc-sidebar-destacado {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--espacio-sm) 0;
    border-bottom: 1px solid var(--color-gris-borde);
    text-decoration: none;
    transition: var(--transicion-rapida);
}

.arc-sidebar-destacado:last-child {
    border-bottom: none;
}

.arc-sidebar-destacado:hover {
    padding-left: var(--espacio-sm);
}

.arc-sidebar-destacado-info {
    flex: 1;
}

.arc-sidebar-destacado-titulo {
    font-size: var(--texto-sm);
    font-weight: 600;
    color: var(--color-texto);
    margin-bottom: 2px;
}

.arc-sidebar-destacado-meta {
    display: flex;
    align-items: center;
    gap: var(--espacio-sm);
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
}

.arc-sidebar-destacado-meta .badge {
    background: rgba(0, 56, 147, 0.1);
    color: var(--color-azul);
    padding: 2px 8px;
    border-radius: 12px;
}

.arc-sidebar-download {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--color-gris-claro);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-azul);
    text-decoration: none;
    transition: var(--transicion-rapida);
    flex-shrink: 0;
}

.arc-sidebar-download:hover {
    background: var(--color-azul);
    color: var(--color-blanco);
}

/* Paginación */
.arc-paginacion {
    margin-top: var(--espacio-xl);
}

.arc-paginacion ul {
    list-style: none;
    display: flex;
    gap: var(--espacio-sm);
    padding: 0;
    margin: 0;
    justify-content: center;
}

.arc-paginacion ul li a,
.arc-paginacion ul li span {
    width: 36px;
    height: 36px;
    border-radius: var(--radio-md);
    border: 1px solid var(--color-gris-borde);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--texto-sm);
    font-weight: 600;
    color: var(--color-texto);
    text-decoration: none;
    transition: var(--transicion-rapida);
}

.arc-paginacion ul li a:hover {
    border-color: var(--color-azul);
    color: var(--color-azul);
}

.arc-paginacion ul li span.current {
    background: var(--color-azul);
    border-color: var(--color-azul);
    color: var(--color-blanco);
}

/* Vacío */
.bib-vacio {
    text-align: center;
    padding: var(--espacio-3xl);
    background: var(--color-blanco);
    border-radius: var(--radio-lg);
    color: var(--color-gris-medio);
}

.bib-vacio-icon {
    font-size: 48px;
    margin-bottom: var(--espacio-md);
}


/* Publicaciones stats */
.publicaciones-stats {
    margin-bottom: var(--espacio-lg);
    padding: var(--espacio-sm) var(--espacio-md);
    background: #f8fafc;
    border-radius: var(--radio-md);
    font-size: var(--texto-sm);
    color: var(--color-gris-medio);
}

.publicaciones-stats .stats-count {
    font-weight: 600;
    color: var(--color-azul);
}
/* Responsive */
@media (max-width: 768px) {
    .bib-layout {
        grid-template-columns: 1fr;
    }
    
    .bib-sidebar {
        position: static;
    }
    
    .bib-hero-titulo {
        font-size: var(--texto-2xl);
    }
    
    .bib-hero-sub {
        font-size: var(--texto-sm);
    }
    
    .bib-filtros-wrapper {
        flex-direction: column;
        align-items: flex-start;
    }
    
    .bib-filtro-grupo {
        flex-direction: column;
        align-items: flex-start;
    }
    
    .bib-grid {
        grid-template-columns: 1fr;
    }
    
    .bib-stats-grid {
        gap: var(--espacio-md);
    }
    
    .bib-hero-deco-libros {
        display: none;
    }
    
    .bib-hero-search-form {
        flex-direction: column;
    }
}

/* =============================================
   ARCHIVE — ENTES ADSCRITOS
   ============================================= */

/* Hero */
.entes-hero {
    background: linear-gradient(135deg, #001838 0%, #002d7a 100%);
    padding: calc(var(--espacio-3xl) + var(--alto-header) + var(--alto-sintillo))
             0 var(--espacio-2xl);
    position: relative;
    overflow: hidden;
    min-height: 360px;
    display: flex;
    align-items: center;
}

.entes-hero-deco {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
}

.entes-hero-content {
    position: relative;
    z-index: 2;
    max-width: var(--ancho-maximo);
}

.entes-hero-eyebrow {
    font-size: var(--texto-xs);
    font-weight: 700;
    color: rgba(252,209,22,0.8);
    text-transform: uppercase;
    letter-spacing: 1.5px;
    margin-bottom: var(--espacio-sm);
}

.entes-hero-titulo {
    font-size: var(--texto-3xl);
    font-weight: 800;
    color: var(--color-blanco);
    margin: 0 0 var(--espacio-md);
    line-height: 1.15;
}

.entes-hero-sub {
    font-size: var(--texto-base);
    color: rgba(255,255,255,0.65);
    line-height: 1.7;
    margin: 0 0 var(--espacio-lg);
    max-width: 500px;
}

.entes-hero-count {
    display: inline-flex;
    align-items: center;
    gap: var(--espacio-sm);
    background: rgba(252,209,22,0.12);
    border: 1px solid rgba(252,209,22,0.25);
    border-radius: 20px;
    padding: 5px 16px;
    font-size: var(--texto-sm);
    color: rgba(255,255,255,0.8);
}

.entes-hero-count span {
    font-size: var(--texto-md);
    font-weight: 800;
    color: var(--color-amarillo);
}

/* Contenido */
.entes-contenido {
    background: var(--color-gris-claro);
    padding: var(--espacio-2xl) 0;
}

/* Grid */
.entes-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--espacio-lg);
    margin-bottom: var(--espacio-xl);
}

/* Entes Hero Search */
.entes-hero-search {
    margin-top: var(--espacio-xl);
}

.entes-search-form {
    display: flex;
    gap: var(--espacio-sm);
    flex-wrap: wrap;
    align-items: center;
}

.entes-search-wrap {
    position: relative;
    flex: 1;
    min-width: 200px;
}

.entes-search-wrap svg {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    stroke: #94a3b8;
}

.entes-search-input {
    width: 100%;
    height: 44px;
    padding: 0 16px 0 40px;
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 30px;
    font-size: var(--texto-sm);
    background: rgba(255, 255, 255, 0.1);
    backdrop-filter: blur(4px);
    color: var(--color-blanco);
}

.entes-search-input::placeholder {
    color: rgba(255, 255, 255, 0.5);
}

.entes-search-input:focus {
    outline: none;
    border-color: #FCD116;
    background: rgba(255, 255, 255, 0.15);
}

.entes-search-btn {
    background: #FCD116;
    color: #001f5c;
    border: none;
    padding: 0 24px;
    height: 44px;
    border-radius: 30px;
    font-weight: 700;
    cursor: pointer;
    transition: var(--transicion-rapida);
}

.entes-search-btn:hover {
    background: #ffdd44;
    transform: translateY(-2px);
}

.entes-clear-btn {
    display: inline-flex;
    align-items: center;
    padding: 0 20px;
    height: 44px;
    border-radius: 30px;
    font-size: var(--texto-sm);
    font-weight: 500;
    background: rgba(255, 255, 255, 0.1);
    color: white;
    text-decoration: none;
    transition: var(--transicion-rapida);
}

.entes-clear-btn:hover {
    background: rgba(255, 255, 255, 0.2);
}

/* Paginación entes */
.entes-paginacion ul {
    list-style: none;
    display: flex;
    gap: var(--espacio-sm);
    justify-content: center;
    margin-top: var(--espacio-xl);
}

.entes-paginacion ul li a {
    width: 36px;
    height: 36px;
    border-radius: var(--radio-md);
    border: 1px solid var(--color-gris-borde);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--texto-sm);
    font-weight: 600;
    color: var(--color-texto);
    text-decoration: none;
    transition: var(--transicion-rapida);
}

.entes-paginacion ul li a:hover {
    border-color: var(--color-azul);
    color: var(--color-azul);
}

.entes-paginacion ul li a.current {
    background: var(--color-azul);
    border-color: var(--color-azul);
    color: var(--color-blanco);
}

/* Tarjeta */
.ente-card {
    background: var(--color-blanco);
    border: 1px solid var(--color-gris-borde);
    border-radius: var(--radio-lg);
    padding: var(--espacio-xl) var(--espacio-lg);
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: var(--espacio-md);
    box-shadow: var(--sombra-suave);
    transition: var(--transicion-media);
}

.ente-card:hover {
    border-color: var(--color-azul);
    box-shadow: var(--sombra-media);
    transform: translateY(-3px);
}

.ente-card-logo {
    width: 90px;
    height: 90px;
    border-radius: var(--radio-lg);
    background: #EEF3FF;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--espacio-sm);
    overflow: hidden;
    flex-shrink: 0;
}

.ente-card-inicial {
    font-size: var(--texto-2xl);
    font-weight: 800;
    color: var(--color-azul);
}

.ente-card-info { flex: 1; width: 100%; }

.ente-card-nombre {
    font-size: var(--texto-sm);
    font-weight: 700;
    color: var(--color-texto);
    line-height: 1.4;
    margin: 0 0 var(--espacio-xs);
}

.ente-card-desc {
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
    line-height: 1.5;
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.ente-card-link {
    display: inline-flex;
    align-items: center;
    gap: var(--espacio-xs);
    font-size: var(--texto-xs);
    font-weight: 600;
    color: var(--color-azul);
    padding: 5px 14px;
    border: 1.5px solid var(--color-azul);
    border-radius: 20px;
    text-decoration: none;
    transition: var(--transicion-rapida);
    margin-top: auto;
}

.ente-card-link:hover {
    background: var(--color-azul);
    color: var(--color-blanco);
}

.ente-card-link svg { stroke: currentColor; }

/* Paginación */
.entes-paginacion {
    display: flex;
    justify-content: center;
}

.entes-paginacion ul {
    list-style: none;
    display: flex;
    gap: var(--espacio-sm);
    padding: 0;
    margin: 0;
}

.entes-paginacion ul li a,
.entes-paginacion ul li span {
    width: 38px;
    height: 38px;
    border-radius: var(--radio-md);
    border: 1px solid var(--color-gris-borde);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--texto-sm);
    font-weight: 600;
    color: var(--color-texto);
    text-decoration: none;
    transition: var(--transicion-rapida);
}

.entes-paginacion ul li a:hover {
    border-color: var(--color-azul);
    color: var(--color-azul);
}

.entes-paginacion ul li span.current {
    background: var(--color-azul);
    border-color: var(--color-azul);
    color: var(--color-blanco);
}

/* Responsive */
@media (max-width: 768px) {
    .entes-grid { grid-template-columns: repeat(2, 1fr); }
    .entes-hero-titulo { font-size: var(--texto-2xl); }
}

@media (max-width: 480px) {
    .entes-grid { grid-template-columns: 1fr; }
}

/* =============================================
   ARCHIVE — VIDEOS
   ============================================= */

/* Hero — mismo fondo oscuro que el shortcode */
.videos-arc-hero {
    background: #0d1117;
    padding: calc(var(--espacio-3xl) + var(--alto-header) + var(--alto-sintillo))
             0 var(--espacio-2xl);
    position: relative;
    overflow: hidden;
}

.videos-arc-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: repeating-linear-gradient(
        -45deg,
        transparent, transparent 20px,
        rgba(255,255,255,0.02) 20px,
        rgba(255,255,255,0.02) 21px
    );
    pointer-events: none;
}

.videos-arc-hero-content {
    position: relative;
    z-index: 2;
    max-width: 600px;
}

.videos-arc-eyebrow {
    font-size: var(--texto-xs);
    font-weight: 700;
    color: rgba(252,209,22,0.8);
    text-transform: uppercase;
    letter-spacing: 1.5px;
    margin-bottom: var(--espacio-sm);
}

.videos-arc-titulo {
    font-size: var(--texto-3xl);
    font-weight: 800;
    color: var(--color-blanco);
    margin: 0 0 var(--espacio-md);
    line-height: 1.15;
}

.videos-arc-sub {
    font-size: var(--texto-base);
    color: rgba(255,255,255,0.55);
    line-height: 1.7;
    margin: 0 0 var(--espacio-lg);
    max-width: 500px;
}

.videos-arc-count {
    display: inline-flex;
    align-items: center;
    gap: var(--espacio-sm);
    background: rgba(252,209,22,0.1);
    border: 1px solid rgba(252,209,22,0.2);
    border-radius: 20px;
    padding: 5px 16px;
    font-size: var(--texto-sm);
    color: rgba(255,255,255,0.7);
}

.videos-arc-count span {
    font-size: var(--texto-md);
    font-weight: 800;
    color: var(--color-amarillo);
}

/* Contenido — mismo fondo oscuro */
.videos-arc-contenido {
    background: var(--color-gris-claro);
    padding: var(--espacio-2xl) 0;
    position: relative;
}

.videos-arc-contenido .mppeu-wrap { position: relative; z-index: 1; }

/* Grid */
.videos-arc-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--espacio-lg);
    margin-bottom: var(--espacio-xl);
}

/* Tarjeta */
.videos-arc-card {
    border-radius: var(--radio-lg);
    overflow: hidden;
    cursor: pointer;
    background: #1a1f2e;
    border: 1px solid rgba(255,255,255,0.06);
    transition: var(--transicion-media);
}

.videos-arc-card:hover {
    border-color: rgba(255,255,255,0.15);
    transform: translateY(-4px);
    box-shadow: 0 12px 32px rgba(0,0,0,0.4);
}

.videos-arc-card:hover .videos-arc-play {
    background: var(--color-amarillo);
    color: var(--color-azul-oscuro);
    transform: translate(-50%, -50%) scale(1.1);
}

/* Thumbnail */
.videos-arc-thumb {
    position: relative;
    width: 100%;
    aspect-ratio: 16/9;
    overflow: hidden;
    background: #1e2435;
}

.videos-arc-placeholder {
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, #1a1f2e, #0d1117);
}

.videos-arc-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to top,
        rgba(0,0,0,0.6) 0%,
        rgba(0,0,0,0.15) 50%,
        transparent 100%
    );
    transition: var(--transicion-media);
}

.videos-arc-card:hover .videos-arc-overlay {
    background: linear-gradient(
        to top,
        rgba(0,0,0,0.75) 0%,
        rgba(0,0,0,0.3) 60%,
        rgba(0,0,0,0.1) 100%
    );
}

/* Play */
.videos-arc-play {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 52px;
    height: 52px;
    border-radius: 50%;
    background: rgba(255,255,255,0.15);
    border: 2px solid rgba(255,255,255,0.35);
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    padding-left: 3px;
    transition: var(--transicion-media);
    backdrop-filter: blur(4px);
}

/* Fecha */
.videos-arc-fecha {
    position: absolute;
    bottom: var(--espacio-sm);
    right: var(--espacio-sm);
    font-size: 10px;
    color: rgba(255,255,255,0.6);
    background: rgba(0,0,0,0.4);
    padding: 2px 8px;
    border-radius: 10px;
    backdrop-filter: blur(4px);
}

/* Info */
.videos-arc-info {
    padding: var(--espacio-md);
}

.videos-arc-card-titulo {
    font-size: var(--texto-sm);
    font-weight: 600;
    color: rgba(255,255,255,0.85);
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Paginación sobre fondo oscuro */
.videos-arc-contenido .entes-paginacion ul li a,
.videos-arc-contenido .entes-paginacion ul li span {
    background: rgba(255,255,255,0.05);
    border-color: rgba(255,255,255,0.12);
    color: rgba(255,255,255,0.7);
}

.videos-arc-contenido .entes-paginacion ul li a:hover {
    border-color: var(--color-amarillo);
    color: var(--color-amarillo);
    background: rgba(252,209,22,0.08);
}

.videos-arc-contenido .entes-paginacion ul li span.current {
    background: var(--color-amarillo);
    border-color: var(--color-amarillo);
    color: var(--color-azul-oscuro);
}

/* Responsive */
@media (max-width: 768px) {
    .videos-arc-grid { grid-template-columns: repeat(2, 1fr); }
    .videos-arc-titulo { font-size: var(--texto-2xl); }
}

@media (max-width: 480px) {
    .videos-arc-grid { grid-template-columns: 1fr; }
}

/* =============================================
   SHORTCODE — GALERÍA MULTIMEDIA
   ============================================= */

/* Hero */
.gal-hero {
    background: linear-gradient(135deg, #001f5c 0%, var(--color-azul) 100%);
    padding: calc(var(--espacio-3xl) + var(--alto-header));
    position: relative;
    overflow: hidden;
}


.gal-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: repeating-linear-gradient(
        -45deg, transparent, transparent 20px,
        rgba(255,255,255,0.015) 20px,
        rgba(255,255,255,0.015) 21px
    );
    pointer-events: none;
}

.gal-hero-content {
    position: relative;
    z-index: 2;
    max-width: 800px;
}

.gal-eyebrow {
    font-size: var(--texto-xs);
    font-weight: 700;
    color: rgba(252,209,22,0.8);
    text-transform: uppercase;
    letter-spacing: 1.5px;
    margin-bottom: var(--espacio-sm);
}

.gal-titulo {
    font-size: var(--texto-3xl);
    font-weight: 800;
    color: var(--color-blanco);
    margin: 0 0 var(--espacio-sm);
}

.gal-sub {
    font-size: var(--texto-base);
    color: rgba(255,255,255,0.65);
    margin: 0 0 var(--espacio-xl);
    line-height: 1.6;
}

/* Filtros de tipo */
.gal-filtros-tipo {
    display: flex;
    gap: var(--espacio-sm);
    flex-wrap: wrap;
    margin-bottom: var(--espacio-lg);
}

.gal-filtro-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--espacio-xs);
    padding: 8px 18px;
    border-radius: 24px;
    font-size: var(--texto-sm);
    font-weight: 600;
    border: 1.5px solid rgba(255,255,255,0.25);
    color: rgba(255,255,255,0.75);
    background: rgba(255,255,255,0.06);
    text-decoration: none;
    transition: var(--transicion-rapida);
}

.gal-filtro-btn:hover {
    background: rgba(255,255,255,0.12);
    color: var(--color-blanco);
    border-color: rgba(255,255,255,0.4);
}

.gal-filtro-btn.activo {
    background: var(--color-blanco);
    color: var(--color-azul);
    border-color: transparent;
}

.gal-filtro-btn svg { stroke: currentColor; }

.gal-count {
    background: rgba(255,255,255,0.2);
    color: inherit;
    font-size: 10px;
    font-weight: 700;
    padding: 1px 7px;
    border-radius: 10px;
}

.gal-filtro-btn.activo .gal-count {
    background: rgba(0,56,147,0.12);
    color: var(--color-azul);
}

/* Buscador */
.gal-search {
    display: flex;
    gap: var(--espacio-sm);
    align-items: center;
    flex-wrap: wrap;
}

.gal-search-wrap {
    position: relative;
    display: flex;
    align-items: center;
    flex: 1;
    max-width: 420px;
}

.gal-search-wrap svg {
    position: absolute;
    left: 12px;
    stroke: rgba(255,255,255,0.5);
}

.gal-search-input {
    width: 100%;
    height: 40px;
    padding: 0 var(--espacio-md) 0 40px;
    background: rgba(255,255,255,0.1);
    border: 1.5px solid rgba(255,255,255,0.2);
    border-radius: 20px;
    font-size: var(--texto-sm);
    font-family: var(--fuente-principal);
    color: var(--color-blanco);
    outline: none;
    transition: var(--transicion-rapida);
}

.gal-search-input::placeholder { color: rgba(255,255,255,0.45); }
.gal-search-input:focus {
    border-color: var(--color-amarillo);
    background: rgba(255,255,255,0.15);
}

/* Contenido */
.gal-contenido {
    background: var(--color-gris-claro);
    padding: var(--espacio-2xl) 0;
}

.gal-resultados-info {
    font-size: var(--texto-sm);
    color: var(--color-gris-medio);
    margin-bottom: var(--espacio-lg);
}

/* Grid */
.gal-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--espacio-lg);
}

/* Card base */
.gal-card {
    border-radius: var(--radio-lg);
    overflow: hidden;
    background: var(--color-blanco);
    border: 1px solid var(--color-gris-borde);
    box-shadow: var(--sombra-suave);
    transition: var(--transicion-media);
    display: flex;
    flex-direction: column;
    text-decoration: none;
    color: inherit;
}

.gal-card:hover {
    box-shadow: var(--sombra-media);
    transform: translateY(-3px);
    border-color: var(--color-azul);
}

/* Media */
.gal-card-media {
    position: relative;
    width: 100%;
    aspect-ratio: 16/9;
    overflow: hidden;
    background: var(--color-gris-claro);
    flex-shrink: 0;
}

.gal-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,0.45), transparent 60%);
    transition: var(--transicion-media);
}

.gal-card:hover .gal-overlay {
    background: linear-gradient(to top, rgba(0,0,0,0.6), rgba(0,0,0,0.1) 70%);
}

/* Badges */
.gal-badge {
    position: absolute;
    top: var(--espacio-sm);
    left: var(--espacio-sm);
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 9px;
    font-weight: 700;
    padding: 3px 8px;
    border-radius: 10px;
    text-transform: uppercase;
    letter-spacing: 0.4px;
}

.gal-badge-video   { background: rgba(207,9,33,0.85);   color: white; }
.gal-badge-imagen  { background: rgba(0,56,147,0.85);   color: white; }
.gal-badge-doc     { background: rgba(107,114,128,0.85); color: white; }

/* Play btn video */
.gal-play-btn {
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    width: 48px; height: 48px;
    border-radius: 50%;
    background: rgba(255,255,255,0.15);
    border: 2px solid rgba(255,255,255,0.35);
    display: flex; align-items: center; justify-content: center;
    color: white;
    padding-left: 3px;
    transition: var(--transicion-media);
    backdrop-filter: blur(4px);
}

.gal-card-video { cursor: pointer; }

.gal-card-video:hover .gal-play-btn {
    background: var(--color-rojo);
    border-color: var(--color-rojo);
    transform: translate(-50%, -50%) scale(1.1);
}

/* Zoom btn imagen */
.gal-zoom-btn {
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    width: 44px; height: 44px;
    border-radius: 50%;
    background: rgba(0,0,0,0.3);
    display: flex; align-items: center; justify-content: center;
    color: white;
    opacity: 0;
    transition: var(--transicion-media);
    backdrop-filter: blur(4px);
}

.gal-card-imagen:hover .gal-zoom-btn { opacity: 1; }

/* Placeholder video */
.gal-placeholder-video {
    width: 100%; height: 100%;
    background: linear-gradient(135deg, #1a1f2e, #0d1117);
}

/* Documento */
.gal-card-doc-media {
    background: #f0f4ff;
    display: flex;
    align-items: center;
    justify-content: center;
}

.gal-doc-icon {
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    color: var(--color-azul);
    opacity: 0.5;
    z-index: 1;
}

/* Info */
.gal-card-info {
    padding: var(--espacio-md);
    display: flex;
    flex-direction: column;
    gap: var(--espacio-xs);
    flex: 1;
}

.gal-card-titulo {
    font-size: var(--texto-sm);
    font-weight: 700;
    color: var(--color-texto);
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.gal-card-desc {
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
    line-height: 1.5;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.gal-card-fecha {
    font-size: 10px;
    color: var(--color-gris-medio);
    margin-top: auto;
}

/* Tags */
.gal-tags {
    display: flex;
    gap: 4px;
    flex-wrap: wrap;
}

.gal-tag {
    background: #f0f4ff;
    color: var(--color-azul);
    font-size: 9px;
    font-weight: 500;
    padding: 2px 7px;
    border-radius: 8px;
}

/* Acciones documento */
.gal-doc-acciones {
    display: flex;
    gap: var(--espacio-sm);
    margin-top: var(--espacio-sm);
}

.gal-doc-btn {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: var(--texto-xs);
    font-weight: 600;
    color: var(--color-azul);
    padding: 4px 12px;
    border: 1px solid var(--color-azul);
    border-radius: 20px;
    text-decoration: none;
    transition: var(--transicion-rapida);
}

.gal-doc-btn:hover {
    background: var(--color-azul);
    color: var(--color-blanco);
}

.gal-doc-btn-dl { background: var(--color-azul); color: var(--color-blanco); }
.gal-doc-btn-dl:hover { background: var(--color-azul-oscuro); }

.gal-sticky-bar {
    background: var(--color-blanco);
    border-bottom: 1px solid var(--color-gris-borde);
    padding: var(--espacio-md) 0;
    position: sticky;
    top: calc(var(--alto-header) + var(--alto-sintillo));
    z-index: 9;
    box-shadow: var(--sombra-suave);
    max-width: var(--ancho-maximo);
    margin: 0 auto;
}
.gal-sticky-bar.visible {
    transform: translateY(0);
    opacity: 1;
    pointer-events: auto;
}

.gal-sticky-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--espacio-lg);
    padding: var(--espacio-sm) 0;
}

.gal-sticky-filtros {
    display: flex;
    gap: var(--espacio-sm);
}

.gal-sticky-btn {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 5px 14px;
    border-radius: 20px;
    font-size: var(--texto-xs);
    font-weight: 500;
    border: 1.5px solid var(--color-gris-borde);
    color: var(--color-gris-medio);
    text-decoration: none;
    transition: var(--transicion-rapida);
}

.gal-sticky-btn svg { stroke: currentColor; }
.gal-sticky-btn:hover { border-color: var(--color-azul); color: var(--color-azul); }
.gal-sticky-btn.activo { background: var(--color-azul); border-color: var(--color-azul); color: var(--color-blanco); }

.gal-sticky-estado {
    display: flex;
    align-items: center;
    gap: var(--espacio-md);
}

.gal-sticky-tag {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    background: rgba(0,56,147,0.08);
    color: var(--color-azul);
    font-size: var(--texto-xs);
    font-weight: 600;
    padding: 4px 10px;
    border-radius: 20px;
}

.gal-sticky-tag svg { stroke: currentColor; }

.gal-sticky-tag-x {
    color: var(--color-azul);
    font-size: 14px;
    line-height: 1;
    font-weight: 700;
    text-decoration: none;
    opacity: 0.6;
}
.gal-sticky-tag-x:hover { opacity: 1; }

.gal-sticky-info {
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
}

/* Lightbox modo imagen */
.gal-lb-imagen-mode { max-width: 860px; background: rgba(0,0,0,0.9); }
.gal-lb-imagen-mode .mppeu-lightbox-content {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--espacio-lg);
    aspect-ratio: unset;
    min-height: 300px;
}

#gal-lb-footer {
    display: flex;
    justify-content: center;
    padding: var(--espacio-md) var(--espacio-lg);
    border-top: 1px solid rgba(255,255,255,0.1);
}

.gal-lb-ir-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--espacio-sm);
    color: rgba(255,255,255,0.8);
    font-size: var(--texto-sm);
    font-weight: 600;
    text-decoration: none;
    transition: var(--transicion-rapida);
}

.gal-lb-ir-btn:hover { color: var(--color-amarillo); }
.gal-lb-ir-btn svg { stroke: currentColor; }

/* Paginación galería */
.gal-paginacion {
    display: flex;
    justify-content: center;
    gap: var(--espacio-sm);
    margin-top: var(--espacio-xl);
}

.gal-pag-btn {
    width: 38px; height: 38px;
    border-radius: var(--radio-md);
    border: 1px solid var(--color-gris-borde);
    display: flex; align-items: center; justify-content: center;
    font-size: var(--texto-sm);
    font-weight: 600;
    color: var(--color-texto);
    text-decoration: none;
    background: var(--color-blanco);
    transition: var(--transicion-rapida);
}

.gal-pag-btn:hover { border-color: var(--color-azul); color: var(--color-azul); }
.gal-pag-btn.activo { background: var(--color-azul); border-color: var(--color-azul); color: var(--color-blanco); }

/* Placeholder video */
.gal-placeholder-video {
    width: 100%; height: 100%;
    background: linear-gradient(135deg, #1a1f2e, #0d1117);
}

/* Responsive */
@media (max-width: 768px) {
    .gal-grid { grid-template-columns: repeat(2, 1fr); }
    .gal-titulo { font-size: var(--texto-2xl); }
    .gal-filtros-tipo { gap: var(--espacio-xs); }
}

@media (max-width: 480px) {
    .gal-grid { grid-template-columns: 1fr; }
    .gal-filtro-btn { font-size: var(--texto-xs); padding: 6px 12px; }
}

/* =============================================
   PROGRAMAS ARCHIVE
   ============================================= */

/* Stats bar */
.prog-stats-bar {
    background: var(--color-blanco);
    border-bottom: 1px solid var(--color-gris-borde);
    padding: var(--espacio-md) 0;
}

.prog-stats-grid {
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap;
    gap: var(--espacio-lg);
}

.prog-stat {
    text-align: center;
}

.prog-stat-num {
    font-size: var(--texto-xl);
    font-weight: 800;
    color: var(--color-azul);
    display: block;
    line-height: 1.2;
}

.prog-stat-txt {
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
}

/* Filtros de estado */
.prog-estados-filtros {
    display: flex;
    gap: var(--espacio-sm);
    flex-wrap: wrap;
    margin-left: auto;
}

.prog-estado-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 5px 14px;
    border-radius: 20px;
    font-size: var(--texto-xs);
    font-weight: 500;
    border: 1.5px solid;
    background: transparent;
    text-decoration: none;
    transition: var(--transicion-rapida);
}

.prog-estado-badge:hover {
    opacity: 0.8;
    transform: translateY(-1px);
}

.estado-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    display: inline-block;
}

/* Grid de programas */
.programas-stats {
    margin-bottom: var(--espacio-lg);
    padding: var(--espacio-sm) var(--espacio-md);
    background: #f8fafc;
    border-radius: var(--radio-md);
    font-size: var(--texto-sm);
    color: var(--color-gris-medio);
}

.programas-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: var(--espacio-lg);
    margin-bottom: var(--espacio-xl);
}

.programa-card {
    background: var(--color-blanco);
    border-radius: var(--radio-lg);
    overflow: hidden;
    transition: var(--transicion-media);
    box-shadow: var(--sombra-suave);
    border: 1px solid var(--color-gris-borde);
    height: 100%;
}

.programa-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--sombra-media);
    border-color: var(--color-azul);
}

.programa-card-link {
    text-decoration: none;
    display: block;
    height: 100%;
}

.programa-card-img {
    height: 200px;
    position: relative;
    overflow: hidden;
    background: linear-gradient(135deg, #001f5c, #003893);
    display: flex;
    align-items: center;
    justify-content: center;
}

.programa-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease;
}

.programa-card:hover .programa-img {
    transform: scale(1.05);
}

.programa-img-placeholder {
    font-size: 48px;
    opacity: 0.5;
    color: white;
}

.programa-estado-badge {
    position: absolute;
    top: var(--espacio-sm);
    right: var(--espacio-sm);
    padding: 4px 12px;
    border-radius: 20px;
    font-size: var(--texto-xs);
    font-weight: 600;
    color: white;
}

.programa-card-body {
    padding: var(--espacio-lg);
}

.programa-card-tipo {
    font-size: var(--texto-xs);
    font-weight: 600;
    color: var(--color-azul);
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: var(--espacio-xs);
}

.programa-card-title {
    font-size: var(--texto-md);
    font-weight: 700;
    color: var(--color-texto);
    margin: 0 0 var(--espacio-sm);
    line-height: 1.4;
}

.programa-card-desc {
    font-size: var(--texto-sm);
    color: var(--color-gris-medio);
    line-height: 1.5;
    margin-bottom: var(--espacio-md);
}

.programa-card-footer {
    display: inline-flex;
    align-items: center;
    gap: var(--espacio-xs);
    font-size: var(--texto-sm);
    font-weight: 500;
    color: var(--color-azul);
    transition: var(--transicion-rapida);
}

.programa-card-link:hover .programa-card-footer {
    gap: var(--espacio-md);
}

/* SINGLE PROGRAMA */
.single-hero-estado {
    background: rgba(0,56,147,0.8);
    color: var(--color-blanco);
    font-size: var(--texto-xs);
    font-weight: 600;
    padding: 4px 12px;
    border-radius: 20px;
    backdrop-filter: blur(4px);
}

.single-section-title {
    display: flex;
    align-items: center;
    gap: var(--espacio-sm);
    font-size: var(--texto-lg);
    font-weight: 700;
    color: var(--color-texto);
    margin: var(--espacio-xl) 0 var(--espacio-lg);
    padding-bottom: var(--espacio-sm);
    border-bottom: 2px solid var(--color-azul);
}

/* Recursos grid */
.recursos-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--espacio-md);
    margin-top: var(--espacio-md);
}

.recurso-card {
    display: flex;
    align-items: center;
    gap: var(--espacio-md);
    padding: var(--espacio-md);
    background: #f8fafc;
    border-radius: var(--radio-md);
    text-decoration: none;
    transition: var(--transicion-rapida);
    border: 1px solid var(--color-gris-borde);
}

.recurso-card:hover {
    background: #f1f5f9;
    transform: translateX(4px);
    border-color: var(--color-azul);
}

.recurso-icon {
    font-size: 24px;
}

.recurso-info {
    flex: 1;
}

.recurso-titulo {
    font-size: var(--texto-sm);
    font-weight: 600;
    color: var(--color-texto);
    margin-bottom: 2px;
}

.recurso-desc {
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
}

.recurso-card svg {
    stroke: var(--color-azul);
    flex-shrink: 0;
}

/* Video wrapper */
.single-video {
    margin-top: var(--espacio-xl);
}

.video-wrapper {
    position: relative;
    padding-bottom: 56.25%;
    height: 0;
    overflow: hidden;
    border-radius: var(--radio-lg);
}

.video-wrapper iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border: none;
}

/* Sidebar stats */
.sidebar-stats {
    display: flex;
    flex-direction: column;
    gap: var(--espacio-md);
}

.sidebar-stat {
    display: flex;
    align-items: center;
    gap: var(--espacio-md);
    padding: var(--espacio-sm) 0;
    border-bottom: 1px solid var(--color-gris-borde);
}

.sidebar-stat:last-child {
    border-bottom: none;
}

.stat-icon {
    font-size: 20px;
}

.stat-label {
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
    margin-bottom: 2px;
}

.stat-value {
    font-size: var(--texto-sm);
    font-weight: 600;
    color: var(--color-texto);
}

/* Responsive */
@media (max-width: 768px) {
    .programas-grid {
        grid-template-columns: 1fr;
    }
    
    .prog-estados-filtros {
        margin-left: 0;
        width: 100%;
        justify-content: flex-start;
    }
    
    .arc-filtros-inner {
        flex-direction: column;
        align-items: flex-start;
    }
    
    .recursos-grid {
        grid-template-columns: 1fr;
    }
}

/* =============================================
   COMUNICADOS ARCHIVE
   ============================================= */

/* Stats bar */
.com-stats-bar {
    background: var(--color-blanco);
    border-bottom: 1px solid var(--color-gris-borde);
    padding: var(--espacio-md) 0;
}

.com-stats-grid {
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap;
    gap: var(--espacio-lg);
}

.com-stat {
    text-align: center;
}

.com-stat-num {
    font-size: var(--texto-xl);
    font-weight: 800;
    color: var(--color-azul);
    display: block;
    line-height: 1.2;
}

.com-stat-txt {
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
}

/* Grid de comunicados */
.comunicados-stats {
    margin-bottom: var(--espacio-lg);
    padding: var(--espacio-sm) var(--espacio-md);
    background: #f8fafc;
    border-radius: var(--radio-md);
    font-size: var(--texto-sm);
    color: var(--color-gris-medio);
}

.comunicados-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--espacio-md);
    margin-bottom: var(--espacio-xl);
}

@media (max-width: 1024px) {
    .comunicados-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 768px) {
    .comunicados-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 480px) {
    .comunicados-grid { grid-template-columns: 1fr; }
}


/* Tarjeta de comunicado */
.comunicado-card {
    background: var(--color-blanco);
    border-radius: var(--radio-lg);
    overflow: hidden;
    transition: var(--transicion-media);
    box-shadow: var(--sombra-suave);
    border: 1px solid var(--color-gris-borde);
    height: 100%;
    display: flex;
    flex-direction: column;
}

.comunicado-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--sombra-media);
    border-color: var(--color-azul);
}

.comunicado-card-img {
    height: 200px;
    position: relative;
    overflow: hidden;
    background: linear-gradient(135deg, #1a3a6b, #003893);
    display: flex;
    align-items: center;
    justify-content: center;
}

.comunicado-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease;
}

.comunicado-card:hover .comunicado-img {
    transform: scale(1.05);
}

.comunicado-img-placeholder {
    font-size: 48px;
    opacity: 0.5;
    color: white;
}

.comunicado-categoria-badge {
    position: absolute;
    top: var(--espacio-sm);
    left: var(--espacio-sm);
    background: rgba(0, 56, 147, 0.9);
    color: white;
    font-size: var(--texto-xs);
    font-weight: 600;
    padding: 4px 12px;
    border-radius: 20px;
    text-decoration: none;
    backdrop-filter: blur(4px);
    transition: var(--transicion-rapida);
}

.comunicado-categoria-badge:hover {
    background: var(--color-azul);
    transform: translateY(-2px);
}

.comunicado-card-body {
    padding: var(--espacio-lg);
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: var(--espacio-sm);
}

.comunicado-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--espacio-xs);
}

.comunicado-fecha {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
}

.comunicado-card-title {
    font-size: var(--texto-sm);
    font-weight: 700;
    color: var(--color-texto);
    margin: 0;
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.comunicado-card-desc {
display: none; /* Ocultar descripción en grid denso */
}

.comunicado-card-actions {
    display: flex;
    gap: var(--espacio-sm);
    margin-top: auto;
    padding-top: var(--espacio-md);
    flex-wrap: wrap;
}

.com-btn-ver-imagen,
.com-btn-descargar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 8px 16px;
    border-radius: var(--radio-md);
    font-size: var(--texto-sm);
    font-weight: 500;
    text-decoration: none;
    cursor: pointer;
    transition: var(--transicion-rapida);
    flex: 1;
}

.com-btn-ver-imagen {
    background: #f1f5f9;
    color: var(--color-azul);
    border: none;
}

.com-btn-ver-imagen:hover {
    background: var(--color-azul);
    color: white;
}

.com-btn-descargar {
    background: var(--color-azul);
    color: white;
}

.com-btn-descargar:hover {
    background: #135e96;
    transform: translateY(-2px);
}

.com-sin-recurso {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 8px 16px;
    background: #f1f5f9;
    color: #94a3b8;
    border-radius: var(--radio-md);
    font-size: var(--texto-sm);
    flex: 1;
}

.mppeu-com-lb-inner {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--espacio-md);
    padding: var(--espacio-xl);
    max-width: 650px; /* más ancho que antes */
    width: 95%;
    max-height: 95vh;
    overflow-y: none;
}
/* Sidebar items */
.arc-sidebar-lista {
    display: flex;
    flex-direction: column;
    gap: var(--espacio-sm);
}

.arc-sidebar-item {
    padding: var(--espacio-sm) 0;
    border-bottom: 1px solid var(--color-gris-borde);
}

.arc-sidebar-item:last-child {
    border-bottom: none;
}

.arc-sidebar-item-info {
    flex: 1;
}

.arc-sidebar-item-titulo {
    font-size: var(--texto-sm);
    font-weight: 600;
    color: var(--color-texto);
    margin-bottom: 4px;
    line-height: 1.4;
}

.arc-sidebar-item-meta {
    display: flex;
    align-items: center;
    gap: var(--espacio-sm);
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
}

.arc-sidebar-item-meta .badge {
    background: rgba(0, 56, 147, 0.1);
    color: var(--color-azul);
    padding: 2px 8px;
    border-radius: 12px;
}

 
.gal-paginacion ul {
    list-style: none;
    display: flex;
    gap: 8px;
    justify-content: center;
    margin-top: 40px;
    padding: 0;
}

.gal-paginacion ul li a {
    width: 38px;
    height: 38px;
    border-radius: 8px;
    border: 1px solid var(--color-gris-borde);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    font-weight: 600;
    color: var(--color-texto);
    text-decoration: none;
    transition: all 0.2s ease;
}

.gal-paginacion ul li a:hover {
    border-color: var(--color-azul);
    color: var(--color-azul);
}

.gal-paginacion ul li a.active {
    background: var(--color-azul);
    border-color: var(--color-azul);
    color: white;
}

.gal-pag-sep {
    width: 38px;
    height: 38px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    color: var(--color-gris-medio);
}

/* =============================================
   SHORTCODE — CONTACTO
   ============================================= */

/* Hero */
.cont-hero {
    position: relative;
    overflow: hidden;
    background: #001f5c;
    padding: calc(var(--espacio-3xl) + var(--alto-header) + var(--alto-sintillo))
             0 var(--espacio-2xl);
}

.cont-hero-svg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
}

.cont-hero-content {
    position: relative;
    z-index: 1;
    max-width: 560px;
}

.cont-eyebrow {
    font-size: 11px;
    font-weight: 700;
    color: var(--color-amarillo);
    text-transform: uppercase;
    letter-spacing: 2px;
    margin-bottom: 14px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.cont-eyebrow::before {
    content: '';
    width: 20px;
    height: 2px;
    background: var(--color-amarillo);
    display: block;
}

.cont-hero-titulo {
    font-size: clamp(28px, 4vw, 40px);
    font-weight: 800;
    color: white;
    line-height: 1.15;
    margin-bottom: 14px;
}

.cont-hero-sub {
    font-size: var(--texto-md);
    color: rgba(255,255,255,0.72);
    line-height: 1.65;
    max-width: 480px;
}

/* Cuerpo */
.cont-body {
    background: #f4f7fc;
    padding: var(--espacio-3xl) 0 var(--espacio-3xl);
}

.cont-layout {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: var(--espacio-xl);
    margin-top: calc(-1 * var(--espacio-xl));
}

@media (max-width: 900px) {
    .cont-layout { grid-template-columns: 1fr; }
}

/* Card del formulario */
.cont-form-card {
    background: var(--color-blanco);
    border-radius: var(--radio-xl);
    border: 1px solid var(--color-gris-borde);
    box-shadow: 0 4px 24px rgba(0,0,0,0.07);
    overflow: hidden;
}

.cont-form-header {
    background: linear-gradient(135deg, #f8faff 0%, #eff4ff 100%);
    border-bottom: 1px solid var(--color-gris-borde);
    padding: var(--espacio-lg) var(--espacio-xl);
    display: flex;
    align-items: center;
    gap: var(--espacio-md);
}

.cont-form-header-icon {
    width: 42px;
    height: 42px;
    background: var(--color-azul);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.cont-form-header h2 {
    font-size: var(--texto-lg);
    font-weight: 700;
    color: var(--color-texto);
    margin: 0 0 3px;
}

.cont-form-header p {
    font-size: var(--texto-xs);
    color: var(--color-gris-medio);
    margin: 0;
}

.cont-form { padding: var(--espacio-xl); }

/* Error */
.cont-error {
    display: flex;
    align-items: center;
    gap: 10px;
    background: #fef2f2;
    border-left: 4px solid #ef4444;
    color: #7f1d1d;
    padding: 12px 16px;
    border-radius: 0 8px 8px 0;
    font-size: var(--texto-sm);
    margin: 0 var(--espacio-xl) var(--espacio-md);
}

/* Sección título */
.cont-seccion-titulo {
    font-size: 11px;
    font-weight: 700;
    color: var(--color-azul);
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: var(--espacio-md);
    display: flex;
    align-items: center;
    gap: var(--espacio-sm);
}

.cont-seccion-titulo::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--color-gris-borde);
}

/* Grid de campos */
.cont-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--espacio-md);
    margin-bottom: var(--espacio-md);
}

.cont-full { grid-column: 1 / -1; }

@media (max-width: 600px) {
    .cont-grid { grid-template-columns: 1fr; }
    .cont-full { grid-column: 1; }
}

/* Campos */
.cont-field {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.cont-label {
    font-size: 12px;
    font-weight: 600;
    color: #374151;
}

.cont-req { color: #ef4444; }

.cont-input {
    height: 42px;
    padding: 0 12px;
    border: 1.5px solid var(--color-gris-borde);
    border-radius: var(--radio-md);
    font-size: var(--texto-sm);
    font-family: inherit;
    color: var(--color-texto);
    background: #fafafa;
    transition: border-color 0.2s, background 0.2s;
    width: 100%;
}

.cont-input:focus {
    border-color: var(--color-azul);
    background: var(--color-blanco);
    outline: none;
    box-shadow: 0 0 0 3px rgba(0,56,147,0.08);
}

.cont-select { appearance: none; cursor: pointer; }

.cont-textarea {
    height: auto;
    min-height: 110px;
    padding: 10px 12px;
    resize: vertical;
}

/* Captcha */
.cont-captcha {
    background: #f0f6ff;
    border: 1.5px solid #bfdbfe;
    border-radius: var(--radio-md);
    padding: var(--espacio-md) var(--espacio-lg);
    margin-bottom: var(--espacio-lg);
}

.cont-captcha-inner {
    display: flex;
    align-items: center;
    gap: var(--espacio-md);
    flex-wrap: wrap;
}

.cont-captcha-pregunta {
    font-size: var(--texto-sm);
    color: #1e3a6e;
    display: flex;
    align-items: center;
    gap: 6px;
}

.cont-captcha-pregunta strong {
    font-size: var(--texto-lg);
    color: var(--color-azul);
    font-weight: 800;
}

.cont-captcha-input {
    width: 70px;
    height: 42px;
    border: 1.5px solid #93c5fd;
    border-radius: var(--radio-md);
    text-align: center;
    font-size: var(--texto-lg);
    font-weight: 700;
    color: var(--color-azul);
    background: var(--color-blanco);
    padding: 0;
}

.cont-captcha-input:focus {
    border-color: var(--color-azul);
    outline: none;
    box-shadow: 0 0 0 3px rgba(0,56,147,0.1);
}

.cont-captcha-hint {
    font-size: 11px;
    color: #6b7280;
    display: block;
    margin-top: 6px;
}

/* Botón submit */
.cont-submit-btn {
    width: 100%;
    height: 52px;
    background: var(--color-azul);
    color: white;
    border: none;
    border-radius: var(--radio-lg);
    font-size: var(--texto-md);
    font-weight: 700;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    transition: background 0.2s, transform 0.15s;
    font-family: inherit;
}

.cont-submit-btn:hover {
    background: #002570;
    transform: translateY(-1px);
}

.cont-submit-btn:active {
    transform: translateY(0);
}

/* Éxito */
.cont-exito {
    text-align: center;
    padding: var(--espacio-3xl) var(--espacio-xl);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--espacio-md);
}

.cont-exito-icono {
    width: 72px;
    height: 72px;
    background: #f0fdf4;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 2px solid #86efac;
}

.cont-exito h2 {
    font-size: var(--texto-xl);
    font-weight: 800;
    color: var(--color-texto);
}

.cont-exito p {
    font-size: var(--texto-md);
    color: var(--color-gris-medio);
    line-height: 1.6;
    max-width: 400px;
}

.cont-exito-ref {
    background: #f8fafc;
    border: 1px solid var(--color-gris-borde);
    border-radius: var(--radio-md);
    padding: 10px 20px;
    font-size: var(--texto-sm);
    color: var(--color-gris-medio);
    display: flex;
    align-items: center;
    gap: 8px;
}

.cont-exito-ref strong {
    color: var(--color-texto);
    font-weight: 700;
}

/* Sidebar */
.cont-sidebar {
    display: flex;
    flex-direction: column;
    gap: var(--espacio-md);
}

/* Card info */
.cont-info-card {
    background: var(--color-blanco);
    border-radius: var(--radio-lg);
    border: 1px solid var(--color-gris-borde);
    overflow: hidden;
    box-shadow: var(--sombra-suave);
}

.cont-info-header {
    background: var(--color-azul);
    padding: 14px 18px;
    color: white;
    font-size: var(--texto-sm);
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: 8px;
}

.cont-info-body { padding: var(--espacio-md) var(--espacio-lg); }

.cont-info-item {
    display: flex;
    gap: var(--espacio-md);
    align-items: flex-start;
    padding: var(--espacio-sm) 0;
    border-bottom: 1px solid var(--color-gris-borde);
}

.cont-info-item:last-child { border-bottom: none; }

.cont-info-icono {
    width: 34px;
    height: 34px;
    background: #eff6ff;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.cont-info-label {
    display: block;
    font-size: 10px;
    font-weight: 700;
    color: #94a3b8;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 2px;
}

.cont-info-val {
    font-size: var(--texto-sm);
    color: var(--color-texto);
    font-weight: 500;
    line-height: 1.4;
}

/* Horario */
.cont-horario-card {
    background: linear-gradient(135deg, #001f5c, #003893);
    border-radius: var(--radio-lg);
    padding: var(--espacio-lg);
    color: white;
}

.cont-horario-titulo {
    font-size: var(--texto-sm);
    font-weight: 700;
    margin-bottom: var(--espacio-md);
    opacity: 0.85;
    display: flex;
    color: var(--color-amarillo);
    align-items: center;
    gap: 8px;
}

.cont-horario-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 8px 0;
    border-bottom: 1px solid rgba(255,255,255,0.08);
    font-size: var(--texto-sm);
}

.cont-horario-item:last-of-type { border-bottom: none; }
.cont-horario-dia { opacity: 0.7; }
.cont-horario-hora { font-weight: 700; }

.cont-horario-online {
    margin-top: var(--espacio-md);
    padding-top: var(--espacio-md);
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    color: rgba(255,255,255,0.6);
}

.cont-horario-badge {
    background: var(--color-amarillo);
    color: #412402;
    font-size: 10px;
    font-weight: 700;
    padding: 3px 10px;
    border-radius: 20px;
    white-space: nowrap;
}

/* Privacidad */
.cont-privacidad {
    display: flex;
    gap: 10px;
    align-items: flex-start;
    background: #f0f6ff;
    border: 1px solid #bfdbfe;
    border-radius: var(--radio-md);
    padding: var(--espacio-md);
}

.cont-privacidad svg { flex-shrink: 0; margin-top: 2px; }

.cont-privacidad p {
    font-size: 11px;
    color: #1e3a6e;
    line-height: 1.55;
    margin: 0;
}
 