
/* Estilo general del cuerpo de la página */
body {
    font-family: 'Nunito', sans-serif; /* Fuente principal */
    background: linear-gradient(to top, #2c2d4f, #11156b); /* Fondo con degradado */
    color: white; /* Texto blanco */
    width: 100%; /* Ocupa todo el ancho de la ventana */
    height: 100vh; /* Ocupa 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 */
    display: flex; /* Activa Flexbox */
    flex-direction: column; /* Organiza los elementos en columna */
    align-items: center; /* Centra los elementos horizontalmente */
    padding-top: 50px; /* Espaciado superior adicional */
}

/* Estilo del menú de navegación */
#menu {
    position: relative; /* Fija el menú en la parte superior de la ventana */
    top: 0; /* Asegura que esté en la parte superior */
    left: 0; /* Alinea el menú al borde izquierdo */
    width: 100%; /* El menú ocupa todo el ancho de la ventana */
    display: flex; /* Usa Flexbox para alinear los enlaces */
    justify-content: center; /* Centra los enlaces horizontalmente */
    gap: 10px; /* Espacio entre los enlaces */
    padding: 5px 0; /* Espaciado interno */
    z-index: 1000; /* Asegura que el menú esté por encima de otros elementos */
    margin: 20px 0; /* Margen superior e inferior */
}

/* Estilo de los enlaces del menú */
#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 */
}

/* Estilo del título de la sección de materias */
#materiascursando {
    text-align: center; /* Centra el texto */
    font-size: 1.5rem; /* Tamaño de fuente */
    margin: 80px 0 20px; /* Ajusta el margen superior para compensar el menú fijo */
}

/* Contenedor de la tabla de materias */
#cursando {
    display: flex; /* Usa Flexbox para centrar la tabla */
    justify-content: center; /* Centra la tabla horizontalmente */
    margin: 20px; /* Espaciado alrededor del contenedor */
}

/* Estilo de la tabla */
#cursando table {
    width: 100%; /* La tabla ocupa todo el ancho disponible */
    max-width: 800px; /* Ancho máximo de la tabla */
    border-collapse: collapse; /* Elimina los espacios entre bordes */
    font-size: 1rem; /* Tamaño de fuente */
}

/* Estilo de las celdas de la tabla */
#cursando th, #cursando td {
    border: 1px solid white; /* Bordes blancos */
    padding: 10px; /* Espaciado interno */
    text-align: center; /* Centra el texto dentro de las celdas */
}

/* Estilo de las celdas del encabezado */
#cursando th {
    background-color: rgba(255, 255, 255, 0.2); /* Fondo semitransparente */
}

/* Estilo de las celdas del cuerpo */
#cursando td {
    background-color: rgba(255, 255, 255, 0.1); /* Fondo semitransparente */
}

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;
    
}

/* 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;
    top: -50px;;
}

/* Responsive Design */
/* Ajustes para pantallas pequeñas */
@media (max-width: 768px) {

    header {
        flex-wrap: wrap;
        padding: 10px 0 0 10px;
        position: relative;
        top: -50px;
        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;
    }

}