:root {
            /* Colores de tu logo y combinaciones */
            --color-principal-azul: #1C41CF; /* Azul del logo */
            --color-secundario-negro: #0a0a0a; /* Negro para fondos oscuros */
            --color-fondo-claro: #f8f9fa; /* Gris muy claro para el body */
            --color-texto-oscuro: #343a40; /* Texto principal oscuro */
        }

        body {
            background-color: var(--color-fondo-claro);
            font-family: 'Segoe UI', Arial, sans-serif; /* Fuente un poco más moderna */
            color: var(--color-texto-oscuro);
        }

        /* --- 1. Header y Navegación --- */
        .navbar-logo {
            background-color: var(--color-principal-azul); /* Azul de tu logo */
            padding-top: 0.75rem;
            padding-bottom: 0.75rem;
        }

        .navbar-logo .btn-outline-primary {
            color: #fff;
            border-color: #fff;
            transition: background-color 0.2s ease, color 0.2s ease;
        }
        .navbar-logo .btn-outline-primary:hover {
            background-color: #fff;
            color: var(--color-principal-azul);
        }

        .navbar-categorias {
            background-color: var(--color-secundario-negro); /* Negro */
            box-shadow: 0 2px 5px rgba(0,0,0,0.1);
        }
        .navbar-categorias .nav-link {
            color: #fff;
            font-weight: 600;
            text-transform: uppercase;
            padding: 1rem 1.2rem;
            transition: background-color 0.2s ease;
            letter-spacing: 0.05em;
        }
        .navbar-categorias .nav-link:hover,
        .navbar-categorias .nav-link.active {
            background-color: var(--color-principal-azul);
            color: #fff;
        }
        .navbar-categorias .navbar-toggler {
            border-color: rgba(255,255,255,0.2);
        }
        .navbar-categorias .navbar-toggler-icon {
            filter: brightness(0) invert(1);
        }


        /* --- 3. Hero Grid (Portada) --- */
        .hero-card {
            position: relative;
            border-radius: 0.5rem;
            overflow: hidden;
            border: none;
            box-shadow: 0 6px 20px rgba(0,0,0,0.1); /* Sombra más pronunciada */
            transition: transform 0.2s ease;
        }
        .hero-card:hover {
            transform: translateY(-5px); /* Pequeño efecto al pasar el mouse */
        }
        .hero-card-img {
            width: 100%;
            object-fit: cover;
            display: block;
            filter: brightness(0.9); /* Oscurece un poco la imagen */
        }
        .hero-card-overlay {
            position: absolute;
            bottom: 0;
            left: 0;
            right: 0;
            background: linear-gradient(0deg, rgba(0,0,0,0.9) 0%, rgba(0,0,0,0) 100%);
            padding: 1.5rem;
            color: #fff;
        }
        .hero-card-overlay .card-title {
            color: #fff;
            font-weight: 700;
            line-height: 1.2;
        }
        .hero-card .stretched-link::after {
            content: "";
            position: absolute;
            top: 0;
            right: 0;
            bottom: 0;
            left: 0;
            z-index: 1;
        }

        .hero-card-lg .hero-card-img { height: 500px; }
        .hero-card-lg .card-title { font-size: 2.2rem; }
        .hero-card-md .hero-card-img { height: 242px; }
        .hero-card-md .card-title { font-size: 1.35rem; }
        .hero-card-sm .hero-card-img { height: 242px; }
        .hero-card-sm .card-title { font-size: 1.1rem; }

        /* --- 4. Contenido Principal --- */
        .section-title {
            font-weight: 700;
            color: var(--color-texto-oscuro);
            border-bottom: 3px solid var(--color-principal-azul); /* Línea azul */
            padding-bottom: 0.5rem;
            display: inline-block;
            margin-bottom: 1.5rem;
            font-size: 1.8rem;
        }

        /* Carrusel de Videos */
        .video-card {
            position: relative;
            margin: 0 10px;
            border-radius: 0.5rem;
            overflow: hidden;
            background-color: #000;
        }
        .video-card-img {
            width: 100%;
            aspect-ratio: 16/9;
            object-fit: cover;
            display: block;
            filter: brightness(0.8);
        }
        .video-card .play-icon {
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translate(-50%, -50%);
            font-size: 3.5rem;
            color: rgba(255,255,255,0.9);
            z-index: 2;
            transition: transform 0.2s ease;
        }
        .video-card:hover .play-icon {
            transform: translate(-50%, -50%) scale(1.1);
            color: var(--color-principal-azul);
        }
        .video-card-title {
            position: absolute;
            bottom: 0;
            left: 0;
            right: 0;
            padding: 1rem;
            color: #fff;
            font-weight: 600;
            background: linear-gradient(0deg, rgba(0,0,0,0.8) 0%, rgba(0,0,0,0) 100%);
            z-index: 1;
        }

        /* Feed de "Más Noticias" */
        .news-feed-card {
            background-color: #fff;
            border-radius: 0.5rem;
            box-shadow: 0 3px 10px rgba(0,0,0,0.08);
            border: none;
            transition: transform 0.2s ease;
        }
        .news-feed-card:hover {
            transform: translateY(-3px);
        }
        .news-feed-card .card-img-top {
            border-top-left-radius: 0.5rem;
            border-top-right-radius: 0.5rem;
            height: 180px; /* Altura fija para la imagen */
            object-fit: cover;
        }
        .news-feed-card .card-title a {
            color: var(--color-texto-oscuro);
            text-decoration: none;
            font-weight: 600;
            font-size: 1.15rem;
        }
        .news-feed-card .card-title a:hover {
            color: var(--color-principal-azul);
        }
        .news-feed-card .card-text {
            font-size: 0.9rem;
        }

        /* Sidebar Widgets */
        .sidebar-sticky {
            position: sticky;
            top: 70px;
        }
        .widget {
            background-color: #fff;
            border-radius: 0.5rem;
            box-shadow: 0 3px 10px rgba(0,0,0,0.08);
            margin-bottom: 1.5rem;
            border: none;
        }
        .widget-header {
            background-color: var(--color-secundario-negro); /* Negro para el header del widget */
            color: #fff;
            padding: 0.75rem 1rem;
            border-radius: 0.5rem 0.5rem 0 0;
        }
        .widget-header h5 {
            margin: 0;
            font-weight: 600;
        }
        .widget-body {
            padding: 1rem;
        }
        .widget-body.p-0 {
            padding: 0;
        }

        /* Widget Agenda */
        .agenda-item {
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: 0.75rem 1rem;
            border-bottom: 1px solid #eee;
            color: var(--color-texto-oscuro);
        }
        .agenda-item:last-child { border: 0; }
        .agenda-equipo { font-weight: 600; }
        .agenda-hora { font-weight: 700; color: var(--color-principal-azul); }

        /* Widget Tabla */
        .widget-tabla table {
            margin-bottom: 0;
        }
        .widget-tabla th { 
            font-size: 0.8rem; 
            color: #6c757d;
            border-bottom-color: #dee2e6;
        }
        .widget-tabla td { 
            font-size: 0.9rem; 
            vertical-align: middle;
            color: var(--color-texto-oscuro);
        }
        .widget-tabla .team-name { font-weight: 500; }

        /* --- Footer --- */
        footer {
            background-color: var(--color-secundario-negro) !important; /* Aseguramos el negro */
            color: #f8f9fa !important;
        }
        footer h6 {
            color: var(--color-principal-azul); /* Títulos de footer en azul */
            margin-bottom: 1rem;
        }
        footer p {
            font-size: 0.9rem;
        }
        footer a {
            color: #adb5bd !important; /* Enlaces en un gris claro */
            transition: color 0.2s ease;
        }
        footer a:hover {
            color: var(--color-principal-azul) !important;
        }
        footer .bi {
            color: var(--color-principal-azul);
        }
