/* ==========================================
   CPE Theme - Cooperativa Popular de Electricidad
   ========================================== */
/* Variables CSS */
:root {
    /* Colores principales CPE */
    --cpe-azul-primario: #00a0e4;
    --cpe-azul-oscuro: #0077b3;
    --cpe-azul-claro: #e6f4fa;
    --cpe-amarillo: #c4d600;
    --cpe-verde: #7ab800;
    /* Fondos */
    --cpe-fondo-claro: #f5f0e8;
    --cpe-fondo-beige: #f8f5ef;
    --cpe-fondo-oscuro: #333333;
    --cpe-blanco: #ffffff;
    /* Textos */
    --cpe-texto-oscuro: #333333;
    --cpe-texto-gris: #666666;
    --cpe-texto-claro: #999999;
    --cpe-texto-azul-primario: #00a0e4;
    --cpe-texto-azul-oscuro: #0077b3;
    --cpe-texto-blanco: #e6e6e6;
    /* Alertas */
    --cpe-alerta-rojo: #dc3545;
    --cpe-alerta-amarillo: #ffc107;
    /* Espaciados */
    --cpe-spacing-xs: 0.25rem;
    --cpe-spacing-sm: 0.5rem;
    --cpe-spacing-md: 1rem;
    --cpe-spacing-lg: 1.5rem;
    --cpe-spacing-xl: 2rem;
    --cpe-spacing-xxl: 3rem;
    /* Bordes */
    --cpe-border-radius: 12px;
    --cpe-border-radius-lg: 20px;
    /* Sombras */
    --cpe-shadow-sm: 0 2px 4px rgba(0, 0, 0, 0.1);
    --cpe-shadow-md: 0 4px 8px rgba(0, 0, 0, 0.12);
    --cpe-shadow-lg: 0 8px 16px rgba(0, 0, 0, 0.15);
    /* Transiciones */
    --cpe-transition: all 0.3s ease;
}

/* Reset y base */
*, *::before, *::after {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    font-family: 'Lato', sans-serif;
    color: var(--cpe-texto-oscuro);
    background-color: var(--cpe-blanco);
    line-height: 1.6;
    margin: 0;
    padding: 0;
}

/* ==========================================
   Header
   ========================================== */
.cpe-header {
    background-color: var(--cpe-blanco);
    box-shadow: var(--cpe-shadow-sm);
    position: sticky;
    top: 0;
    z-index: 1000;
}

    .cpe-header .navbar {
        padding: var(--cpe-spacing-sm) 0;
    }

    .cpe-header .navbar-brand {
        display: flex;
        align-items: center;
        gap: var(--cpe-spacing-sm);
    }

        .cpe-header .navbar-brand img {
            height: 50px;
            width: auto;
        }

    .cpe-header .navbar-brand-text {
        font-size: 0.75rem;
        color: var(--cpe-texto-gris);
        line-height: 1.2;
        max-width: 200px;
    }

    .cpe-header .nav-link {
        color: var(--cpe-texto-azul-primario);
        font-weight: 300;
        padding: var(--cpe-spacing-sm) var(--cpe-spacing-md) !important;
        transition: var(--cpe-transition);
        font-size: small;
    }

        .cpe-header .nav-link:hover {
            color: var(--cpe-azul-primario);
        }

        .cpe-header .nav-link i {
            margin-right: var(--cpe-spacing-xs);
        }

    /* Ocultar flecha del dropdown */
    .cpe-header .dropdown-toggle::after {
        display: none;
    }

    .cpe-header .btn-usuario {
        background-color: transparent;
        border: none;
        color: var(--cpe-texto-azul-primario);
    }

        .cpe-header .btn-usuario:hover {
            color: var(--cpe-azul-primario);
        }

    /* Dropdown menu de servicios */
    .cpe-header .dropdown-menu {
        border: none;
        box-shadow: var(--cpe-shadow-lg);
        border-radius: var(--cpe-border-radius);
        padding: var(--cpe-spacing-md);
        min-width: 220px;
        font-size: small
    }

    .cpe-header .dropdown-item {
        padding: var(--cpe-spacing-sm) var(--cpe-spacing-md);
        border-radius: var(--cpe-border-radius);
        transition: var(--cpe-transition);
        font-weight: 300;
        font-style: normal;
    }

        .cpe-header .dropdown-item:hover {
            color: var(--cpe-azul-primario);
        }

/* Header mobile - Menu overlay */
@media (max-width: 991.98px) {
    .cpe-header .navbar > .container {
        position: relative;
    }

    .cpe-header .navbar-collapse {
        position: absolute;
        top: 100%;
        left: var(--cpe-spacing-md);
        right: var(--cpe-spacing-md);
        background-color: var(--cpe-blanco);
        padding: var(--cpe-spacing-md);
        border-radius: 0 0 var(--cpe-border-radius) var(--cpe-border-radius);
        box-shadow: 0 8px 30px rgba(0, 0, 0, 0.15);
        z-index: 1000;
        max-height: 75vh;
        overflow-y: auto;
    }

    .cpe-header .navbar-nav {
        gap: var(--cpe-spacing-xs);
    }

    .cpe-header .nav-link {
        padding: var(--cpe-spacing-md) var(--cpe-spacing-sm) !important;
        border-bottom: 1px solid var(--cpe-azul-claro);
        font-weight: 300;
    }

    .cpe-header .dropdown-menu {
        position: static !important;
        border: none;
        box-shadow: none;
        padding-left: var(--cpe-spacing-lg);
        background-color: var(--cpe-fondo-beige);
        transform: none !important;
    }

    .cpe-header .btn-usuario {
        width: 100%;
        text-align: left;
        padding: var(--cpe-spacing-md) var(--cpe-spacing-sm) !important;
    }
}

/* ==========================================
   Hero / Slider (legacy)
   ========================================== */
.cpe-hero {
    position: relative;
    overflow: hidden;
}

    .cpe-hero .carousel-item {
        height: 400px;
    }

@media (max-width: 768px) {
    .cpe-hero .carousel-item {
        height: 300px;
    }
}

.cpe-hero .carousel-item img,
.cpe-hero .carousel-item video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.cpe-hero .carousel-caption {
    background: linear-gradient(transparent, rgba(0, 0, 0, 0.7));
    left: 0;
    right: 0;
    bottom: 0;
    padding: var(--cpe-spacing-xl);
    text-align: left;
}

    .cpe-hero .carousel-caption h2 {
        font-size: 2.5rem;
        font-weight: 700;
        text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5);
        margin-bottom: var(--cpe-spacing-sm);
    }

@media (max-width: 768px) {
    .cpe-hero .carousel-caption h2 {
        font-size: 1.5rem;
    }
}

.cpe-hero .carousel-control-prev,
.cpe-hero .carousel-control-next {
    width: 50px;
    opacity: 0.8;
}

.cpe-hero .carousel-indicators {
    margin-bottom: var(--cpe-spacing-md);
}

    .cpe-hero .carousel-indicators button {
        width: 12px;
        height: 12px;
        border-radius: 50%;
        margin: 0 4px;
    }

/* ==========================================
   Banner Superior (nuevo diseño)
   ========================================== */
.cpe-banner-superior {
    width: 100%;
    padding: var(--cpe-spacing-lg);
    background: var(--cpe-fondo-claro);
}

.banner-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--cpe-spacing-md);
}

/* --- Video institucional --- */
.banner-video {
    border-radius: var(--cpe-border-radius-lg);
    overflow: hidden;
    position: relative;
    background: #000;
    min-height: 600px
}

    .banner-video video {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

/* --- Columna derecha --- */
.banner-derecha {
    display: flex;
    flex-direction: column;
    gap: var(--cpe-spacing-sm);
    height: 100%;
}

/* --- Rotador de frases --- */
.banner-rotador {
    flex: 1;
    position: relative;
    border-radius: var(--cpe-border-radius-lg);
    overflow: hidden;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    text-decoration: none;
    background: url('/media/hero/OficinaVirtual.jpg') center / cover no-repeat;
    cursor: pointer;
}

    .banner-rotador:hover {
        text-decoration: none;
    }

.rotador-glass {
    margin-top: var(--cpe-spacing-lg);
    padding: var(--cpe-spacing-lg) var(--cpe-spacing-xl);
    background: rgba(255, 255, 255, 0.15);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(255, 255, 255, 0.3);
    border-radius: var(--cpe-border-radius-lg);
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--cpe-spacing-md);
    width: 500px;
    max-width: 90%;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1);
    transition: background 0.3s ease, box-shadow 0.3s ease;
}

    .banner-rotador:hover .rotador-glass {
        background: rgba(255, 255, 255, 0.25);
        box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
    }

.rotador-frase {
    flex: 1;
    color: var(--cpe-azul-oscuro);
    font-weight: 500;
    font-size: 1.5rem;
    letter-spacing: 0.5px;
    line-height: 1.3;
    text-align: left;
    opacity: 1;
    transition: opacity 0.5s ease;
}

    .rotador-frase.fade-in {
        animation: fadeInUp 0.5s ease forwards;
    }

.rotador-flecha {
    flex-shrink: 0;
    color: var(--cpe-azul-oscuro);
    font-size: 1.2rem;
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(15px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.rotador-ingresar {
    color: var(--cpe-azul-oscuro);
    font-size: 2rem;
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: var(--cpe-spacing-md);
    animation: fadeInUp 0.3s ease forwards;
}

    .rotador-ingresar i {
        font-size: 2.5rem;
    }

/* --- Fila inferior: Memoria + WhatsApp --- */
.banner-inferior-fila {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--cpe-spacing-sm);
    height: 140px;
}

/* --- Cards Memoria y WhatsApp (estilo compartido) --- */
.banner-memoria-card,
.banner-whatsapp-bloque {
    position: relative;
    border-radius: var(--cpe-border-radius-lg);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: var(--cpe-spacing-lg);
    text-decoration: none;
    cursor: pointer;
    overflow: hidden;
    transition: background-color 0.3s ease;
}

.card-icono-svg {
    display: inline-block;
    width: 32px;
    height: 32px;
    background-color: #FFFFFF;
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    align-self: flex-start;
    transition: width 0.3s ease, height 0.3s ease;
}

.banner-memoria-card:hover .card-icono-svg,
.banner-whatsapp-bloque:hover .card-icono-svg {
    width: 24px;
    height: 24px;
}

.card-titulo {
    color: #FFFFFF;
    font-size: 1.1rem;
    font-weight: 500;
    margin-top: auto;
    transition: opacity 0.3s ease;
}

.banner-memoria-card:hover .card-titulo,
.banner-whatsapp-bloque:hover .card-titulo {
    opacity: 0;
}

.card-descripcion {
    color: #FFFFFF;
    font-size: 0.8rem;
    font-weight: 400;
    line-height: 1.4;
    max-height: 0;
    opacity: 0;
    overflow: hidden;
    transition: max-height 0.3s ease, opacity 0.3s ease, margin 0.3s ease;
    margin-top: 0;
}

.banner-memoria-card:hover .card-descripcion,
.banner-whatsapp-bloque:hover .card-descripcion {
    max-height: 80px;
    opacity: 1;
    margin-top: var(--cpe-spacing-xs);
}

.card-flecha {
    position: absolute;
    bottom: var(--cpe-spacing-lg);
    right: var(--cpe-spacing-lg);
    color: rgba(255, 255, 255, 0.7);
    font-size: 1rem;
    transition: color 0.3s ease;
}

.card-indicador-mas {
    position: absolute;
    top: 50%;
    right: var(--cpe-spacing-lg);
    transform: translateY(-50%);
    color: #FFFFFF;
    font-size: 1.5rem;
    opacity: 0;
    transition: opacity 0.3s ease;
}

.banner-memoria-card:hover .card-indicador-mas {
    opacity: 1;
}

/* --- Memoria y Balance --- */
.banner-memoria-card {
    background-color: #1199EF;
}

    .banner-memoria-card:hover {
        background-color: #91D8F6;
        text-decoration: none;
    }

/* --- WhatsApp --- */
.banner-whatsapp-bloque {
    background-color: #3865B8;
}

    .banner-whatsapp-bloque:hover {
        background-color: #03B362;
        text-decoration: none;
    }

/* ===== Banner Superior — Responsive ===== */

/* Tablet grande y menor */
@media (max-width: 992px) {
    .cpe-banner-superior {
        height: auto;
        min-height: auto;
    }

    .banner-grid {
        grid-template-columns: 1fr;
        height: auto;
    }

    .banner-video {
        height: 50vh;
    }

    .banner-rotador {
        min-height: 200px;
    }

    .rotador-frase {
        font-size: 1.3rem;
    }

    .rotador-ingresar {
        font-size: 1.5rem;
    }

    .rotador-glass {
        padding: var(--cpe-spacing-sm) var(--cpe-spacing-lg);
    }

    .banner-inferior-fila {
        height: auto;
    }
}

/* Mobile */
@media (max-width: 576px) {
    .cpe-banner-superior {
        padding: var(--cpe-spacing-xs);
    }

    .banner-grid {
        gap: var(--cpe-spacing-xs);
    }

    .banner-video {
        height: 40vh;
    }

    .banner-rotador {
        min-height: 160px;
    }

    .rotador-frase {
        font-size: 1.05rem;
    }

    .rotador-ingresar {
        font-size: 1.2rem;
    }

    .rotador-glass {
        margin-top: var(--cpe-spacing-sm);
        padding: var(--cpe-spacing-xs) var(--cpe-spacing-md);
        min-height: 46px;
    }

    .banner-inferior-fila {
        grid-template-columns: 1fr;
        height: auto;
    }

    .banner-memoria-card,
    .banner-whatsapp-bloque {
        padding: var(--cpe-spacing-md);
    }

    .card-titulo {
        font-size: 0.95rem;
    }

    .card-icono-svg {
        width: 26px;
        height: 26px;
    }
}

/* ==========================================
   Barra de Cortes
   ========================================== */
.cpe-barra-cortes {
    padding: var(--cpe-spacing-sm) 0;
    text-align: center;
    font-weight: 500;
    font-size: 0.9rem;
}

    .cpe-barra-cortes.alerta-roja {
        background-color: var(--cpe-alerta-rojo);
        color: white;
    }

    .cpe-barra-cortes.alerta-amarilla {
        background-color: var(--cpe-alerta-amarillo);
        color: var(--cpe-texto-oscuro);
    }

    .cpe-barra-cortes i {
        margin-right: var(--cpe-spacing-sm);
    }

    .cpe-barra-cortes a {
        color: inherit;
        text-decoration: underline;
    }

/* ==========================================
   Accesos Rapidos
   ========================================== */
.cpe-accesos-rapidos {
    background: #f0f0f0;
    padding: var(--cpe-spacing-xxl) 0;
}

    .cpe-accesos-rapidos .section-title {
        color: var(--cpe-texto-azul-oscuro);
        font-size: 1.9rem;
        font-weight: 300;
        margin-bottom: var(--cpe-spacing-xl);
        line-height: 40px;
    }

        .cpe-accesos-rapidos .section-title strong {
            font-weight: 700;
        }

.cpe-acceso-item {
    position: relative;
    display: flex;
    flex-direction: column;
    padding: var(--cpe-spacing-lg);
    background: var(--cpe-blanco);
    border-radius: var(--cpe-border-radius-lg);
    box-shadow: var(--cpe-shadow-sm);
    text-decoration: none;
    color: var(--cpe-texto-azul-oscuro);
    aspect-ratio: 1;
    overflow: hidden;
    transition: background-color 0.3s ease, box-shadow 0.3s ease;
}

    .cpe-acceso-item:hover {
        background-color: #91D8F7;
        box-shadow: var(--cpe-shadow-md);
        text-decoration: none;
    }

.acceso-header {
    display: flex;
    align-items: center;
    gap: var(--cpe-spacing-sm);
}

    .cpe-acceso-item .acceso-icono {
        flex-shrink: 0;
        font-size: 2rem;
        color: #7fc7e6;
        line-height: 1;
    }

        .cpe-acceso-item .acceso-icono .icono-svg {
            display: inline-block;
            width: 32px;
            height: 32px;
            background-color: #7fc7e6;
            -webkit-mask-size: contain;
            mask-size: contain;
            -webkit-mask-repeat: no-repeat;
            mask-repeat: no-repeat;
            -webkit-mask-position: center;
            mask-position: center;
            transition: background-color 0.3s ease;
        }

    .cpe-acceso-item:hover .acceso-icono .icono-svg {
        background-color: var(--cpe-texto-azul-oscuro);
    }

    .cpe-acceso-item .acceso-titulo {
        font-size: 0.9rem;
        font-weight: 600;
        line-height: 1.2;
        color: var(--cpe-texto-azul-oscuro);
    }

    .cpe-acceso-item .acceso-descripcion {
        font-size: 0.72rem;
        font-weight: 400;
        line-height: 1.3;
        color: var(--cpe-texto-azul-oscuro);
        text-align: left;
        margin-top: var(--cpe-spacing-sm);
        max-height: 0;
        opacity: 0;
        overflow: hidden;
        transition: max-height 0.3s ease, opacity 0.3s ease;
    }

    .cpe-acceso-item:hover .acceso-descripcion {
        max-height: 60px;
        opacity: 1;
    }

    .cpe-acceso-item .acceso-flecha {
        position: absolute;
        bottom: var(--cpe-spacing-md);
        right: var(--cpe-spacing-md);
        color: var(--cpe-texto-azul-oscuro);
        font-size: 1rem;
        opacity: 0;
        transition: opacity 0.3s ease;
    }

    .cpe-acceso-item:hover .acceso-flecha {
        opacity: 1;
    }

/* ==========================================
   Nuestros Sectores
   ========================================== */
.cpe-nuestros-sectores {
    padding: var(--cpe-spacing-xxl) 0;
    background: var(--cpe-blanco);
}

    .cpe-nuestros-sectores .section-title {
        color: var(--cpe-texto-azul-oscuro);
        font-size: 1.9rem;
        font-weight: 300;
        margin-bottom: var(--cpe-spacing-xl);
    }

        .cpe-nuestros-sectores .section-title strong {
            font-weight: 700;
        }

.sectores-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--cpe-spacing-md);
}

.sector-card {
    position: relative;
    border-radius: var(--cpe-border-radius-lg);
    overflow: hidden;
    aspect-ratio: 4 / 3;
    display: flex;
    align-items: flex-end;
    text-decoration: none;
    cursor: pointer;
}

    .sector-card img {
        position: absolute;
        inset: 0;
        width: 100%;
        height: 100%;
        object-fit: cover;
        transition: transform 0.4s ease;
    }

    .sector-card:hover img {
        transform: scale(1.05);
    }

.sector-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 40%, rgba(0, 0, 0, 0.55) 100%);
    transition: background 0.3s ease;
}

    .sector-card:hover .sector-overlay {
        background: linear-gradient(180deg, transparent 20%, rgba(0, 0, 0, 0.65) 100%);
    }

.sector-nombre {
    position: relative;
    z-index: 1;
    color: #fff;
    font-size: 1.1rem;
    font-weight: 600;
    padding: var(--cpe-spacing-md) var(--cpe-spacing-lg);
}

/* Responsive - Tablet */
@media (max-width: 992px) {
    .sectores-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* Responsive - Mobile */
@media (max-width: 576px) {
    .cpe-nuestros-sectores {
        padding: var(--cpe-spacing-xl) 0;
    }

    .cpe-nuestros-sectores .section-title {
        font-size: 1.4rem;
        margin-bottom: var(--cpe-spacing-md);
    }

    .sectores-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--cpe-spacing-sm);
    }

    .sector-nombre {
        font-size: 0.9rem;
        padding: var(--cpe-spacing-sm) var(--cpe-spacing-md);
    }
}

/* ==========================================
   Banner Memoria y Balance
   ========================================== */
.cpe-banner-memoria {
    background-color: var(--cpe-fondo-oscuro);
    color: white;
    padding: var(--cpe-spacing-sm) 0;
}

@media (max-width: 576px) {
    .cpe-banner-memoria {
        padding: var(--cpe-spacing-sm) 0;
    }
}

.cpe-banner-memoria .container {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--cpe-spacing-lg);
    text-align: left;
}

.cpe-banner-memoria .icono {
    font-size: 2.5rem;
    opacity: 0.9;
}

.cpe-banner-memoria h3 {
    margin: 0;
    font-size: 1.2rem;
    font-weight: 700;
}

.cpe-banner-memoria p {
    margin: 0;
    font-size: 0.9rem;
    opacity: 0.9;
}

.cpe-banner-memoria a {
    color: white;
    text-decoration: none;
}

    .cpe-banner-memoria a:hover {
        text-decoration: underline;
    }

/* ==========================================
   Seccion Noticias
   ========================================== */
.cpe-noticias {
    padding: var(--cpe-spacing-xxl) 0;
    background-color: var(--cpe-blanco);
}

    .cpe-noticias .section-header {
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin-bottom: var(--cpe-spacing-xl);
    }

    .cpe-noticias .section-title {
        color: var(--cpe-azul-oscuro);
        font-size: 1.8rem;
        font-weight: 300;
        margin: 0;
    }

    .cpe-noticias .ver-todas {
        color: var(--cpe-azul-primario);
        text-decoration: none;
        font-size: 0.9rem;
    }

        .cpe-noticias .ver-todas:hover {
            text-decoration: underline;
        }

/* Noticia destacada */
.cpe-noticia-destacada {
    background-color: var(--cpe-azul-claro);
    border-radius: var(--cpe-border-radius-lg);
    overflow: hidden;
    height: 100%;
}

    .cpe-noticia-destacada img {
        width: 100%;
        height: 300px;
        object-fit: cover;
    }

    .cpe-noticia-destacada .contenido {
        padding: var(--cpe-spacing-lg);
    }

    .cpe-noticia-destacada .categoria {
        color: var(--cpe-azul-primario);
        font-size: 0.8rem;
        font-weight: 600;
        text-transform: uppercase;
        margin-bottom: var(--cpe-spacing-sm);
    }

    .cpe-noticia-destacada h3 {
        font-size: 1.2rem;
        margin-bottom: var(--cpe-spacing-sm);
    }

        .cpe-noticia-destacada h3 a {
            color: var(--cpe-texto-oscuro);
            text-decoration: none;
        }

            .cpe-noticia-destacada h3 a:hover {
                color: var(--cpe-azul-primario);
            }

    .cpe-noticia-destacada .extracto {
        font-size: 0.9rem;
        color: var(--cpe-texto-gris);
        margin-bottom: var(--cpe-spacing-md);
    }

    .cpe-noticia-destacada .leer-mas {
        color: var(--cpe-azul-primario);
        text-decoration: none;
        font-weight: 500;
    }

/* Lista de noticias lateral */
.cpe-noticias-lista {
    background-color: var(--cpe-azul-claro);
    border-radius: var(--cpe-border-radius-lg);
    padding: var(--cpe-spacing-lg);
    height: 100%;
}

    .cpe-noticias-lista .noticia-item {
        padding: var(--cpe-spacing-md) 0;
        border-bottom: 1px solid rgba(0, 119, 179, 0.15);
    }

        .cpe-noticias-lista .noticia-item:last-child {
            border-bottom: none;
        }

    .cpe-noticias-lista .fecha {
        font-size: 0.75rem;
        color: var(--cpe-texto-gris);
        margin-bottom: var(--cpe-spacing-xs);
    }

    .cpe-noticias-lista .titulo a {
        color: var(--cpe-azul-oscuro);
        text-decoration: none;
        font-size: 0.9rem;
        font-weight: 600;
        line-height: 1.3;
    }

        .cpe-noticias-lista .titulo a:hover {
            color: var(--cpe-azul-primario);
            text-decoration: underline;
        }

/* Noticias secundarias */
.cpe-noticia-secundaria {
    margin-top: var(--cpe-spacing-lg);
}

    .cpe-noticia-secundaria h4 {
        font-size: 1rem;
        margin-bottom: var(--cpe-spacing-xs);
    }

        .cpe-noticia-secundaria h4 a {
            color: var(--cpe-texto-oscuro);
            text-decoration: none;
        }

            .cpe-noticia-secundaria h4 a:hover {
                color: var(--cpe-azul-primario);
            }

    .cpe-noticia-secundaria .leer-mas {
        color: var(--cpe-azul-primario);
        text-decoration: none;
        font-size: 0.85rem;
    }

/* ==========================================
   Detalle de Nota de Prensa
   ========================================== */
.noticia-detalle {
    padding: var(--cpe-spacing-xxl) 0;
    background-color: var(--cpe-blanco);
}

.noticia-articulo {
    max-width: 800px;
    margin: 0 auto;
}

.noticia-meta {
    display: flex;
    align-items: center;
    gap: var(--cpe-spacing-md);
    margin-bottom: var(--cpe-spacing-md);
    flex-wrap: wrap;
}

    .noticia-meta .noticia-fecha {
        color: var(--cpe-texto-gris);
        font-size: 0.9rem;
        display: flex;
        align-items: center;
        gap: var(--cpe-spacing-xs);
    }

    .noticia-meta .noticia-categoria {
        background-color: var(--cpe-azul-claro);
        color: var(--cpe-azul-oscuro);
        padding: 0.2rem 0.75rem;
        border-radius: 20px;
        font-size: 0.8rem;
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 0.5px;
    }

.noticia-titulo {
    font-size: 2rem;
    font-weight: 700;
    color: var(--cpe-texto-oscuro);
    line-height: 1.3;
    margin-bottom: var(--cpe-spacing-lg);
}

.noticia-copete {
    font-size: 1.15rem;
    color: var(--cpe-texto-gris);
    line-height: 1.6;
    border-left: 4px solid var(--cpe-azul-primario);
    padding-left: var(--cpe-spacing-lg);
    margin-bottom: var(--cpe-spacing-xl);
    font-style: italic;
}

.noticia-imagen {
    margin: 0 0 var(--cpe-spacing-xl) 0;
    border-radius: var(--cpe-border-radius-lg);
    overflow: hidden;
    box-shadow: var(--cpe-shadow-md);
}

    .noticia-imagen img {
        width: 100%;
        height: auto;
        display: block;
    }

    .noticia-imagen figcaption {
        padding: var(--cpe-spacing-sm) var(--cpe-spacing-md);
        font-size: 0.85rem;
        color: var(--cpe-texto-gris);
        background-color: var(--cpe-fondo-beige);
        text-align: center;
    }

.noticia-cuerpo {
    font-size: 1.05rem;
    line-height: 1.8;
    color: var(--cpe-texto-oscuro);
}

    .noticia-cuerpo p {
        margin-bottom: var(--cpe-spacing-lg);
    }

    .noticia-cuerpo img {
        max-width: 100%;
        height: auto;
        border-radius: var(--cpe-border-radius);
        margin: var(--cpe-spacing-md) 0;
    }

    .noticia-cuerpo a {
        color: var(--cpe-azul-primario);
        text-decoration: underline;
    }

        .noticia-cuerpo a:hover {
            color: var(--cpe-azul-oscuro);
        }

/* Nota no encontrada */
.noticia-no-encontrada {
    text-align: center;
    padding: var(--cpe-spacing-xxl) 0;
}

    .noticia-no-encontrada i {
        font-size: 3rem;
        color: var(--cpe-texto-claro);
        margin-bottom: var(--cpe-spacing-md);
    }

    .noticia-no-encontrada h2 {
        color: var(--cpe-texto-oscuro);
        margin-bottom: var(--cpe-spacing-sm);
    }

    .noticia-no-encontrada p {
        color: var(--cpe-texto-gris);
        margin-bottom: var(--cpe-spacing-xl);
    }

.btn-volver-inicio {
    display: inline-flex;
    align-items: center;
    gap: var(--cpe-spacing-xs);
    background-color: var(--cpe-azul-primario);
    color: white;
    padding: 0.6rem 1.5rem;
    border-radius: var(--cpe-border-radius);
    text-decoration: none;
    font-weight: 600;
    transition: var(--cpe-transition);
}

    .btn-volver-inicio:hover {
        background-color: var(--cpe-azul-oscuro);
        color: white;
    }

/* Noticias relacionadas */
.noticia-relacionadas {
    max-width: 800px;
    margin: var(--cpe-spacing-xxl) auto 0;
    padding-top: var(--cpe-spacing-xl);
    border-top: 1px solid #e0e0e0;
}

    .noticia-relacionadas h3 {
        font-size: 1.3rem;
        font-weight: 700;
        color: var(--cpe-texto-oscuro);
        margin-bottom: var(--cpe-spacing-lg);
    }

.noticia-relacionadas-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--cpe-spacing-lg);
}

.noticia-relacionada-card {
    text-decoration: none;
    color: inherit;
    border-radius: var(--cpe-border-radius);
    overflow: hidden;
    box-shadow: var(--cpe-shadow-sm);
    transition: var(--cpe-transition);
    background: var(--cpe-blanco);
}

    .noticia-relacionada-card:hover {
        box-shadow: var(--cpe-shadow-md);
        transform: translateY(-2px);
        color: inherit;
    }

    .noticia-relacionada-card img {
        width: 100%;
        height: 140px;
        object-fit: cover;
    }

.noticia-relacionada-info {
    padding: var(--cpe-spacing-md);
}

    .noticia-relacionada-info .fecha {
        font-size: 0.8rem;
        color: var(--cpe-texto-claro);
    }

    .noticia-relacionada-info h4 {
        font-size: 0.9rem;
        font-weight: 600;
        color: var(--cpe-texto-oscuro);
        margin: var(--cpe-spacing-xs) 0 0;
        line-height: 1.4;
    }

/* Boton volver */
.noticia-volver {
    max-width: 800px;
    margin: var(--cpe-spacing-xl) auto 0;
}

.btn-volver {
    display: inline-flex;
    align-items: center;
    gap: var(--cpe-spacing-xs);
    color: var(--cpe-azul-primario);
    text-decoration: none;
    font-weight: 600;
    font-size: 0.95rem;
    transition: var(--cpe-transition);
}

    .btn-volver:hover {
        color: var(--cpe-azul-oscuro);
        gap: var(--cpe-spacing-sm);
    }

/* Responsive - Detalle de nota */
@media (max-width: 768px) {
    .noticia-titulo {
        font-size: 1.5rem;
    }

    .noticia-copete {
        font-size: 1rem;
    }

    .noticia-relacionadas-grid {
        grid-template-columns: 1fr;
    }

    .noticia-relacionada-card img {
        height: 180px;
    }
}

/* ==========================================
   Seccion Videos
   ========================================== */
.cpe-videos {
    background-color: var(--cpe-azul-primario);
    padding: var(--cpe-spacing-xxl) 0;
    color: white;
}

    .cpe-videos .section-header {
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin-bottom: var(--cpe-spacing-xl);
    }

    .cpe-videos .section-title {
        font-size: 1.5rem;
        font-weight: 500;
        margin: 0;
        display: flex;
        align-items: center;
        gap: var(--cpe-spacing-sm);
    }

        .cpe-videos .section-title img {
            height: 30px;
        }

    .cpe-videos .ver-mas {
        color: white;
        text-decoration: none;
        font-size: 0.9rem;
    }

        .cpe-videos .ver-mas:hover {
            text-decoration: underline;
        }

.cpe-video-item {
    position: relative;
    border-radius: var(--cpe-border-radius);
    overflow: hidden;
}

    .cpe-video-item img {
        width: 100%;
        height: 180px;
        object-fit: cover;
    }

    .cpe-video-item .play-overlay {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        width: 60px;
        height: 60px;
        background-color: rgba(255, 255, 255, 0.9);
        border-radius: 50%;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 1.5rem;
        color: var(--cpe-azul-primario);
        transition: var(--cpe-transition);
    }

    .cpe-video-item:hover .play-overlay {
        transform: translate(-50%, -50%) scale(1.1);
    }

/* ==========================================
   Botones Inferiores
   ========================================== */
.cpe-botones-inferiores {
    background-color: var(--cpe-azul-primario);
    padding: var(--cpe-spacing-lg) 0;
}

.cpe-boton-inferior {
    display: flex;
    align-items: center;
    gap: var(--cpe-spacing-md);
    padding: var(--cpe-spacing-md) var(--cpe-spacing-lg);
    background-color: rgba(255, 255, 255, 0.1);
    border-radius: var(--cpe-border-radius);
    color: white;
    text-decoration: none;
    transition: var(--cpe-transition);
}

    .cpe-boton-inferior:hover {
        background-color: rgba(255, 255, 255, 0.2);
        color: white;
    }

    .cpe-boton-inferior i {
        font-size: 1.5rem;
    }

    .cpe-boton-inferior .texto {
        font-size: 0.85rem;
        font-weight: 500;
    }

    /* Boton naranja (Denuncia anonima) */
    .cpe-boton-inferior.naranja {
        background-color: #ff6b35;
    }

        .cpe-boton-inferior.naranja:hover {
            background-color: #e55a2b;
        }

    /* Boton amarillo (Talleres) */
    .cpe-boton-inferior.amarillo {
        background-color: var(--cpe-amarillo);
        color: var(--cpe-texto-oscuro);
    }

        .cpe-boton-inferior.amarillo:hover {
            background-color: #b3c400;
            color: var(--cpe-texto-oscuro);
        }

/* ==========================================
   Footer
   ========================================== */
.cpe-footer {
    background-color: #2c3e50;
    color: white;
    padding: var(--cpe-spacing-xxl) 0 var(--cpe-spacing-lg);
}

    .cpe-footer h5 {
        font-size: 1rem;
        font-weight: 600;
        margin-bottom: var(--cpe-spacing-md);
    }

    .cpe-footer p {
        font-size: 0.9rem;
        color: rgba(255, 255, 255, 0.8);
        margin-bottom: var(--cpe-spacing-sm);
    }

    .cpe-footer a {
        color: rgba(255, 255, 255, 0.8);
        text-decoration: none;
    }

        .cpe-footer a:hover {
            color: white;
        }

    .cpe-footer .footer-links {
        list-style: none;
        padding: 0;
        margin: 0;
    }

        .cpe-footer .footer-links li {
            margin-bottom: var(--cpe-spacing-sm);
        }

        .cpe-footer .footer-links a {
            font-size: 0.9rem;
        }

    .cpe-footer .social-links {
        display: flex;
        gap: var(--cpe-spacing-md);
        margin-top: var(--cpe-spacing-md);
    }

        .cpe-footer .social-links a {
            width: 40px;
            height: 40px;
            background-color: rgba(255, 255, 255, 0.1);
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 1.2rem;
            transition: var(--cpe-transition);
        }

            .cpe-footer .social-links a:hover {
                background-color: var(--cpe-azul-primario);
            }

.cpe-footer-bottom {
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    padding-top: var(--cpe-spacing-lg);
    margin-top: var(--cpe-spacing-xl);
    text-align: center;
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.6);
}

/* ==========================================
   Modal de Busqueda
   ========================================== */
#modalBusqueda .modal-content {
    border: none;
    border-radius: var(--cpe-border-radius-lg);
    box-shadow: var(--cpe-shadow-lg);
}

#modalBusqueda .modal-header {
    padding: var(--cpe-spacing-lg) var(--cpe-spacing-lg) var(--cpe-spacing-sm);
}

#modalBusqueda .modal-title {
    color: var(--cpe-azul-primario);
    font-weight: 600;
}

#modalBusqueda .form-control-lg {
    border-radius: var(--cpe-border-radius);
    border: 2px solid var(--cpe-azul-claro);
    padding: var(--cpe-spacing-md) var(--cpe-spacing-lg);
}

    #modalBusqueda .form-control-lg:focus {
        border-color: var(--cpe-azul-primario);
        box-shadow: 0 0 0 0.2rem rgba(0, 160, 228, 0.15);
    }

#modalBusqueda .search-results {
    max-height: 400px;
    overflow-y: auto;
}

#modalBusqueda .list-group-item {
    border: none;
    border-bottom: 1px solid var(--cpe-azul-claro);
    padding: var(--cpe-spacing-md);
    transition: var(--cpe-transition);
}

    #modalBusqueda .list-group-item:last-child {
        border-bottom: none;
    }

    #modalBusqueda .list-group-item:hover {
        background-color: var(--cpe-azul-claro);
    }

#modalBusqueda .search-result-icon {
    width: 40px;
    height: 40px;
    background-color: var(--cpe-azul-claro);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--cpe-azul-primario);
    font-size: 1.1rem;
}

#modalBusqueda .list-group-item:hover .search-result-icon {
    background-color: var(--cpe-azul-primario);
    color: white;
}

#modalBusqueda .list-group-item h6 {
    color: var(--cpe-texto-oscuro);
    font-weight: 600;
}

#modalBusqueda .list-group-item:hover h6 {
    color: var(--cpe-azul-primario);
}

/* ==========================================
   Page Header (hero para paginas internas)
   ========================================== */
.cpe-page-header {
    background: linear-gradient(135deg, var(--cpe-azul-primario), var(--cpe-azul-oscuro));
    color: white;
    padding: var(--cpe-spacing-xxl) 0 var(--cpe-spacing-xl);
    text-align: center;
}

    .cpe-page-header h1 {
        font-size: 2.2rem;
        font-weight: 700;
        margin-bottom: var(--cpe-spacing-sm);
    }

    .cpe-page-header .breadcrumb {
        justify-content: center;
        margin-bottom: 0;
        font-size: 0.9rem;
    }

        .cpe-page-header .breadcrumb a {
            color: rgba(255, 255, 255, 0.8);
            text-decoration: none;
        }

            .cpe-page-header .breadcrumb a:hover {
                color: white;
            }

    .cpe-page-header .breadcrumb-item.active {
        color: rgba(255, 255, 255, 0.6);
    }

    .cpe-page-header .breadcrumb-item + .breadcrumb-item::before {
        color: rgba(255, 255, 255, 0.5);
    }
    .cpe-page-header .icono-heder {
        color: var(--cpe-blanco)
    }
    @media (max-width: 576px) {
        .cpe-page-header {
            padding: var(--cpe-spacing-xl) 0 var(--cpe-spacing-lg);
        }

            .cpe-page-header h1 {
                font-size: 1.5rem;
            }

            .cpe-page-header .breadcrumb {
                font-size: 0.8rem;
            }
    }

/* ==========================================
   Utilidades
   ========================================== */
.text-cpe-azul {
    color: var(--cpe-azul-primario) !important;
}

.bg-cpe-azul {
    background-color: var(--cpe-azul-primario) !important;
}

.bg-cpe-beige {
    background-color: var(--cpe-fondo-beige) !important;
}

/* Ocultar elementos en mobile/desktop */
@media (max-width: 768px) {
    .d-mobile-none {
        display: none !important;
    }
}

@media (min-width: 769px) {
    .d-desktop-none {
        display: none !important;
    }
}

/* ==========================================
   RESPONSIVE - Mobile First Adjustments
   ========================================== */

/* Mobile: hasta 576px */
@media (max-width: 576px) {
    /* Header */
    .cpe-header .navbar-brand img {
        height: 40px;
    }

    .cpe-header .navbar-brand-text {
        display: none;
    }

    /* Hero */
    .cpe-hero .carousel-item {
        height: 250px;
    }

    .cpe-hero .carousel-caption {
        padding: var(--cpe-spacing-md);
    }

        .cpe-hero .carousel-caption h2 {
            font-size: 1.2rem;
        }

    /* Barra de cortes */
    .cpe-barra-cortes {
        font-size: 0.8rem;
        padding: var(--cpe-spacing-sm) var(--cpe-spacing-md);
    }

    /* Accesos rapidos */
    .cpe-accesos-rapidos {
        padding: var(--cpe-spacing-xl) 0;
    }

        .cpe-accesos-rapidos .section-title {
            font-size: 1rem;
            text-align: center;
            margin-bottom: var(--cpe-spacing-lg);
            padding: 5px 2px 0 2px;
        }

    .cpe-acceso-item {
        padding: var(--cpe-spacing-md);
    }

        .cpe-acceso-item .acceso-icono .icono-svg {
            width: 24px;
            height: 24px;
        }

        .cpe-acceso-item .acceso-titulo {
            font-size: 0.75rem;
        }

    /* Banner memoria */
    .cpe-banner-memoria .container {
        flex-direction: column;
        text-align: center;
        gap: var(--cpe-spacing-md);
    }

    .cpe-banner-memoria .icono {
        font-size: 2rem;
    }

    .cpe-banner-memoria h3 {
        font-size: 1rem;
    }

    .cpe-banner-memoria p {
        font-size: 0.8rem;
    }

    /* Noticias */
    .cpe-noticias {
        padding: var(--cpe-spacing-xl) 0;
    }

        .cpe-noticias .section-header {
            flex-direction: column;
            align-items: flex-start;
            gap: var(--cpe-spacing-sm);
        }

        .cpe-noticias .section-title {
            font-size: 1.3rem;
        }

    .cpe-noticia-destacada img {
        height: 150px;
    }

    .cpe-noticia-destacada .contenido {
        padding: var(--cpe-spacing-md);
    }

    .cpe-noticia-destacada h3 {
        font-size: 1rem;
    }

    .cpe-noticias-lista {
        padding: var(--cpe-spacing-md);
        margin-top: var(--cpe-spacing-md);
    }

        .cpe-noticias-lista .titulo a {
            font-size: 0.85rem;
        }

    /* Videos */
    .cpe-videos {
        padding: var(--cpe-spacing-xl) 0;
    }

        .cpe-videos .section-header {
            flex-direction: column;
            align-items: flex-start;
            gap: var(--cpe-spacing-sm);
        }

        .cpe-videos .section-title {
            font-size: 1.2rem;
        }

    .cpe-video-item img {
        height: 120px;
    }

    .cpe-video-item .play-overlay {
        width: 40px;
        height: 40px;
        font-size: 1rem;
    }

    /* Botones inferiores */
    .cpe-boton-inferior {
        padding: var(--cpe-spacing-sm) var(--cpe-spacing-md);
        font-size: 0.8rem;
    }

        .cpe-boton-inferior i {
            font-size: 1.2rem;
        }

        .cpe-boton-inferior .texto {
            font-size: 0.75rem;
        }

    /* Footer */
    .cpe-footer {
        padding: var(--cpe-spacing-xl) 0 var(--cpe-spacing-md);
    }

        .cpe-footer h5 {
            font-size: 0.95rem;
            margin-top: var(--cpe-spacing-md);
        }

        .cpe-footer p {
            font-size: 0.85rem;
        }

        .cpe-footer .social-links {
            justify-content: center;
        }

            .cpe-footer .social-links a {
                width: 35px;
                height: 35px;
                font-size: 1rem;
            }

    .cpe-footer-bottom {
        font-size: 0.75rem;
    }

        .cpe-footer-bottom p {
            margin-bottom: var(--cpe-spacing-xs);
        }
}

/* Tablet: 577px a 768px */
@media (min-width: 577px) and (max-width: 768px) {
    .cpe-hero .carousel-item {
        height: 300px;
    }

    .cpe-noticia-destacada img {
        height: 180px;
    }

    .cpe-video-item img {
        height: 150px;
    }
}

/* Tablet grande: 769px a 992px */
@media (min-width: 769px) and (max-width: 992px) {
    .cpe-hero .carousel-item {
        height: 350px;
    }

    .cpe-hero .carousel-caption h2 {
        font-size: 2rem;
    }
}

/* Asegurar que el video del hero se vea bien */
.cpe-hero video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Mejoras para touch en movil */
@media (hover: none) and (pointer: coarse) {
    .cpe-acceso-item:hover .acceso-descripcion {
        opacity: 0;
    }

    .cpe-acceso-item:hover .acceso-flecha {
        opacity: 0;
    }

    .cpe-video-item:hover .play-overlay {
        transform: translate(-50%, -50%);
    }
}

/* ==========================================
   GRILLA DE CANALES
   ========================================== */
.gc-localidades {
    padding: var(--cpe-spacing-xl) 0 var(--cpe-spacing-md);
    background: var(--cpe-fondo-claro);
}

    .gc-localidades p {
        color: var(--cpe-texto-gris);
        margin-bottom: var(--cpe-spacing-md);
    }

.gc-tabs {
    display: flex;
    gap: var(--cpe-spacing-sm);
    flex-wrap: wrap;
}

.gc-tab {
    padding: 0.6rem 1.2rem;
    border: 2px solid var(--cpe-azul-primario);
    border-radius: 2rem;
    background: var(--cpe-blanco);
    color: var(--cpe-azul-primario);
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
}

    .gc-tab:hover {
        background: var(--cpe-azul-claro);
    }

.gc-tab-activo {
    background: var(--cpe-azul-primario);
    color: var(--cpe-blanco);
}

    .gc-tab-activo:hover {
        background: var(--cpe-azul-oscuro);
    }

.gc-paquetes {
    padding: var(--cpe-spacing-xl) 0 var(--cpe-spacing-xxl);
}

.gc-instruccion {
    color: var(--cpe-texto-gris);
    margin-bottom: var(--cpe-spacing-lg);
}

/* Paquete tabs */
.gc-paquetes-tabs {
    display: flex;
    gap: var(--cpe-spacing-sm);
    flex-wrap: wrap;
    margin-bottom: var(--cpe-spacing-lg);
}

.gc-paquete-tab {
    padding: 0.7rem 1.4rem;
    border: 2px solid var(--cpe-azul-primario);
    border-radius: 0.5rem;
    background: var(--cpe-blanco);
    color: var(--cpe-azul-primario);
    font-weight: 600;
    font-size: 0.95rem;
    cursor: pointer;
    transition: all 0.2s;
}

    .gc-paquete-tab i {
        margin-right: 0.4rem;
    }

    .gc-paquete-tab:hover {
        background: var(--cpe-azul-claro);
    }

.gc-paquete-tab-activo {
    background: var(--cpe-azul-primario);
    color: var(--cpe-blanco);
}

    .gc-paquete-tab-activo:hover {
        background: var(--cpe-azul-oscuro);
    }

/* Categoría filter tabs */
.gc-categorias-tabs {
    display: flex;
    gap: var(--cpe-spacing-xs);
    flex-wrap: wrap;
    margin-bottom: var(--cpe-spacing-lg);
    padding-bottom: var(--cpe-spacing-md);
    border-bottom: 2px solid #e0e0e0;
}

.gc-cat-tab {
    padding: 0.4rem 0.9rem;
    border: 1px solid #ccc;
    border-radius: 1.5rem;
    background: var(--cpe-blanco);
    color: var(--cpe-texto-gris);
    font-size: 0.85rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s;
}

    .gc-cat-tab:hover {
        border-color: var(--cpe-azul-primario);
        color: var(--cpe-azul-primario);
    }

.gc-cat-tab-activo {
    background: var(--cpe-azul-primario);
    color: var(--cpe-blanco);
    border-color: var(--cpe-azul-primario);
}

    .gc-cat-tab-activo:hover {
        background: var(--cpe-azul-oscuro);
        border-color: var(--cpe-azul-oscuro);
    }

.gc-cat-tab-premium.gc-cat-tab-activo {
    background: #c3954e;
    border-color: #c3954e;
}

    .gc-cat-tab-premium.gc-cat-tab-activo:hover {
        background: #a87a3a;
        border-color: #a87a3a;
    }

.gc-cat-tab-premium:hover {
    border-color: #c3954e;
    color: #c3954e;
}

/* Contenido canales */
.gc-contenido {
    background: #f8f8f8;
    border-radius: 0.5rem;
    padding: var(--cpe-spacing-lg);
}

.gc-categoria {
    margin-bottom: var(--cpe-spacing-lg);
    border-top: 1px solid #ccc;
    padding-top: var(--cpe-spacing-md);
}

    .gc-categoria:first-child {
        border-top: none;
        padding-top: 0;
    }

.gc-categoria-header {
    margin-bottom: var(--cpe-spacing-md);
}

    .gc-categoria-header span {
        font-weight: 600;
        font-size: 0.95rem;
        color: var(--cpe-texto-oscuro);
        padding: 3px 10px;
    }

.gc-categoria-header-premium span {
    color: #c3954e;
}

.gc-canales {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: var(--cpe-spacing-xs);
}

.gc-canal {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    padding: 6px;
    text-align: center;
    min-width: 70px;
}

    .gc-canal img {
        max-width: 64px;
        max-height: 48px;
        object-fit: contain;
        transition: transform 0.2s;
    }

    .gc-canal a:hover img {
        transform: scale(1.1);
    }

.gc-canal-num {
    font-size: 0.75rem;
    color: var(--cpe-texto-gris);
    margin-top: 2px;
}

.gc-notas {
    margin-top: var(--cpe-spacing-xl);
}

    .gc-notas p {
        font-size: 0.85rem;
        color: var(--cpe-texto-claro);
    }

@media (max-width: 576px) {
    .gc-canal {
        min-width: 55px;
        padding: 4px;
    }

        .gc-canal img {
            max-width: 50px;
            max-height: 38px;
        }

    .gc-tabs {
        gap: var(--cpe-spacing-xs);
    }

    .gc-tab {
        padding: 0.4rem 0.8rem;
        font-size: 0.9rem;
    }

    .gc-paquete-tab {
        padding: 0.5rem 0.8rem;
        font-size: 0.85rem;
    }

    .gc-cat-tab {
        padding: 0.3rem 0.6rem;
        font-size: 0.8rem;
    }

    .gc-contenido {
        padding: var(--cpe-spacing-md);
    }
}

/* ============================================================
   TARIFAS NET (tn-*)
   Estilo de tarjetas de planes de internet, basado en el legacy
   ============================================================ */

.tn-planes {
    padding: var(--cpe-spacing-xl) 0;
}

.tn-seccion {
    margin-bottom: var(--cpe-spacing-xl);
}

.tn-categoria-titulo {
    color: #727377;
    font-weight: 700;
    margin-bottom: var(--cpe-spacing-lg);
}

.tn-sin-datos {
    text-align: center;
    padding: var(--cpe-spacing-xl);
    color: var(--cpe-texto-gris);
}

    .tn-sin-datos i {
        font-size: 3rem;
        display: block;
        margin-bottom: var(--cpe-spacing-sm);
    }

/* Plan Card */
.tn-plan-card {
    border: 1px solid #ccc;
    border-radius: 8px;
    overflow: hidden;
    height: 100%;
    display: flex;
    flex-direction: column;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

    .tn-plan-card:hover {
        transform: translateY(-5px);
        box-shadow: 0 5px 20px rgba(0, 0, 0, 0.15);
    }

/* Plan Header */
.tn-plan-header {
    padding: 25px 15px;
    border-radius: 8px 8px 0 0;
    text-align: center;
    color: white;
}

    .tn-plan-header h3 {
        font-size: 1.5rem;
        margin-bottom: 10px;
    }

    .tn-plan-header h2 {
        font-size: 2rem;
        margin: 0;
    }

.tn-header-violeta {
    background-color: #741FD2;
}

.tn-header-azul {
    background-color: var(--cpe-azul-primario, #0d6efd);
}

/* Plan Discount Badge */
.tn-plan-discount {
    background-color: #BAD554;
    display: inline-block;
    position: relative;
    top: -15px;
    padding: 8px 20px;
    border-radius: 4px;
    font-weight: bold;
    font-size: 0.9rem;
    line-height: 1.3;
}

/* Plan Body */
.tn-plan-body {
    padding: 15px;
    border-left: 1px solid #e0e0e0;
    border-right: 1px solid #e0e0e0;
    flex: 1;
    min-height: 60px;
}

.tn-precio-lista {
    color: #98999B;
}

.tn-plan-descripcion {
    color: #98999B;
    font-size: 0.95rem;
    margin: 0;
}

/* Plan Footer */
.tn-plan-footer {
    padding: 20px 15px;
    border-left: 1px solid #e0e0e0;
    border-right: 1px solid #e0e0e0;
    border-bottom: 1px solid #e0e0e0;
    border-radius: 0 0 8px 8px;
}

/* WhatsApp Button */
.tn-btn-whatsapp {
    background-color: #00C2FF;
    color: white !important;
    text-decoration: none;
    padding: 12px 25px;
    border-radius: 25px;
    display: inline-block;
    font-size: 1rem;
    font-weight: bold;
    transition: background-color 0.3s ease;
    border: 2px solid #00C2FF;
}

    .tn-btn-whatsapp:hover {
        background-color: #00aee6;
        color: white !important;
        text-decoration: none;
        border-color: #00aee6;
    }

    .tn-btn-whatsapp i {
        margin-right: 5px;
    }

/* Nota Legal */
.tn-nota-legal {
    padding: var(--cpe-spacing-lg) 0;
    font-size: 0.875rem;
    color: #6c757d;
}

    .tn-nota-legal h6 {
        font-weight: 600;
        margin-bottom: var(--cpe-spacing-sm);
    }

/* Mobile Responsive */
@media (max-width: 767px) {
    .tn-plan-card {
        margin-bottom: 10px;
    }

    .tn-plan-header h3 {
        font-size: 1.3rem;
    }

    .tn-plan-header h2 {
        font-size: 1.8rem;
    }

    .tn-plan-body {
        font-size: 1.1rem;
    }
}
