
/* Elimina márgenes y rellenos predeterminados de todos los elementos y configura el modelo de caja */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

/* Body */
/* Estilo general del cuerpo de la página */
body {
    font-family: 'Nunito', sans-serif; /* Fuente principal */
    background: linear-gradient(to top, #1c2910, #133476cf); /* Fondo con degradado */
    color: white; /* Texto blanco */
    width: 100%; /* Ocupa todo el ancho de la ventana */
    min-height: 100vh; /* Ocupa al menos toda la altura de la ventana */
    background-size: cover; /* Ajusta el fondo para cubrir toda la pantalla */
    background-repeat: no-repeat; /* Evita que el fondo se repita */
    background-position: center; /* Centra el fondo */
    overflow-x: hidden; /* Oculta el desplazamiento horizontal */
}

/* Navigation Menu */
/* Estilo del menú de navegación */
#menu {
    display: flex; /* Usa Flexbox para alinear los enlaces */
    justify-content: center; /* Centra los enlaces horizontalmente */
    gap: 10px; /* Espacio entre los enlaces */
    margin: 20px 0; /* Margen superior e inferior */
}

#menu a {
    background-color: rgba(0, 0, 0, 0.22); /* Fondo semitransparente */
    color: white; /* Texto blanco */
    font-size: 1rem; /* Tamaño de fuente */
    text-align: center; /* Centra el texto dentro del enlace */
    padding: 10px 20px; /* Espaciado interno */
    border-radius: 15px; /* Bordes redondeados */
    text-decoration: none; /* Elimina el subrayado */
    transition: background-color 0.3s ease; /* Transición suave al pasar el mouse */
}

#menu a:hover {
    background-color: rgba(255, 255, 255, 0.2); /* Cambia el fondo al pasar el mouse */
}

/* Header */
/* Estilo del título principal de la página */
h3 {
    text-align: center; /* Centra el texto del título */
    font-size: 1.5rem; /* Tamaño de fuente */
    margin: 40px; /* Margen superior e inferior */
    padding: 10px; /* Espaciado interno */
    font-weight: 200; /* Peso de la fuente */
}

/* Main Container */
/* Estilo del contenedor principal */
#contenedor {
    display: grid; /* Activa CSS Grid */
    grid-template-areas: 
        "fechas actividades"
        "bibliografia actividades"; /* Define las áreas del grid */
    grid-template-columns: 1fr 1fr; /* Dos columnas de igual ancho */
    gap: 20px; /* Espacio entre las secciones */
    margin: 20px; /* Margen alrededor del contenedor */
    text-align: center; /* Centra el texto dentro de las secciones */

}

#fechasexamenes {
    grid-area: fechas; /* Asigna esta sección al área "fechas" */
}

#bibliografia {
    grid-area: bibliografia; /* Asigna esta sección al área "bibliografia" */
}

#actividades {
    grid-area: actividades; /* Asigna esta sección al área "actividades" */
}

#fechasexamenes,
#bibliografia,
#actividades {
    list-style: none; /* Elimina los estilos de lista */
    margin: 0; /* Elimina márgenes adicionales */
    padding: 10px; /* Espaciado interno */
    background-color: rgba(0, 0, 0, 0.5); /* Fondo semitransparente */
    border-radius: 10px; /* Bordes redondeados */
    box-shadow: 5px 4px 8px rgba(0, 0, 0, 0.2); /* Sombra para darle profundidad */
    font-size: 1.2rem; /* Tamaño de fuente */
    font-weight: 200; /* Peso de la fuente */
}

a,
a:visited,
a:hover,
a:active {
    color:coral; /* Hereda el color del elemento padre */
    text-decoration: none; /* Elimina el subrayado */
}

/* Footer */
/* Estilo del pie de página */
footer {
    text-align: center; /* Centra el texto */
    font-size: 0.8rem; /* Tamaño de fuente más pequeño */
    margin: 0; /* Elimina márgenes adicionales */
    padding: 10px; /* Espaciado interno */
    color: rgba(255, 255, 255, 0.7); /* Color del texto */
    background-color: rgba(0, 0, 0, 0.5); /* Fondo semitransparente */
    border-radius: 20px; /* Bordes redondeados */
}



body.light-mode::before {
    content: "";
    position: fixed;
    inset: 0;
    background: rgba(255, 255, 255, 0.188); /* Blanco semitransparente */
    z-index: 0;
    pointer-events: none;
}

/* Capa semitransparente para modo oscuro */
body.dark-mode::before {
    content: "";
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.562); /* Negro semitransparente */
    z-index: 0;
    pointer-events: none;
    padding-top: 110px; /* Espacio suficiente para header + menú */

}

/* Asegura que el contenido esté por encima de la capa */
body > * {
    position: relative;
    z-index: 1;
}


body.light-mode table, body.light-mode th, body.light-mode td {
    background: #fff;
    color: #222;
}

body.dark-mode table, body.dark-mode th, body.dark-mode td {
    background: #222;
    color: #f5f5f5;
}


#lightModeBtn, #darkModeBtn {
    width: auto;
    height: auto;
    padding: 10px 20px;
    border-radius: 10px;
    background: transparent;
    border: none;
    font-size: 1rem;
    cursor: pointer;
    margin: 0;
    box-shadow: none;
    display: inline-block;
}



#lightModeBtn { background: #e0e0e0; color: #222; }
#darkModeBtn { background: #333; color: #f5f5f5; }

header {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 10px;
    padding: 0 0 0 10px;
    width: 100%;
    position: relative;
    top: 0;
    left: 0;
    background: transparent;
    z-index: 1200;
}

/* Responsive Design */
/* Ajustes para pantallas pequeñas */
@media (max-width: 768px) {

    header {
        flex-wrap: wrap;
        padding: 10px 0 0 10px;
        position: relative;
        top: 0;
        left: 0;
        width: 100%;
        z-index: 1200;
        background: transparent;
    }

    #menu {
        position: relative;
        top: 20px;
        left: 0;
        width: 100%;
        flex-direction: column;
        align-items: center;
        padding: 5px 0;
        margin-top: 0;
        z-index: 1100;
        background: transparent;
    }

    #menu a {
        width: 90%;
        font-size: 0.9rem;
        padding: 8px;
    }

}