/* 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, #0c220d, #4a7c2fe5); /* 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 */
}


/* 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 */
    padding: 5px 0; /* Espaciado interno */
}

#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 formulario */
form {
    display: flex; /* Usa Flexbox para organizar los elementos */
    flex-direction: column; /* Alinea los elementos en una columna */
    align-items: center; /* Centra los elementos horizontalmente */
    margin: 20px auto; /* Centra el formulario verticalmente */
    padding: 20px; /* Espaciado interno */
    width: 90%; /* Ajusta el ancho del formulario */
    max-width: 500px; /* Limita el ancho máximo */
    background-color: rgba(0, 0, 0, 0.5); /* Fondo semitransparente */
    border-radius: 10px; /* Bordes redondeados */
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2); /* Sombra para darle profundidad */
}

/* Estilo de los campos del formulario */
form input,
form textarea,
form button {
    width: 100%; /* Ocupa todo el ancho del formulario */
    margin-bottom: 15px; /* Espacio entre los elementos */
    padding: 10px; /* Espaciado interno */
    font-size: 1rem; /* Tamaño de fuente */
    border: 1px solid rgba(255, 255, 255, 0.3); /* Borde claro */
    border-radius: 5px; /* Bordes redondeados */
    background-color: rgba(255, 255, 255, 0.1); /* Fondo semitransparente */
    color: white; /* Texto blanco */
}

/* Estilo del texto de los placeholders */
form input::placeholder,
form textarea::placeholder {
    color: rgba(255, 255, 255, 0.5); /* Color del texto del placeholder */
}

/* Estilo del botón */
form button {
    background-color: rgba(0, 0, 255, 0.7); /* Fondo azul */
    color: white; /* Texto blanco */
    font-weight: bold; /* Texto en negrita */
    cursor: pointer; /* Cambia el cursor al pasar sobre el botón */
    transition: background-color 0.3s ease; /* Transición suave al pasar el mouse */
}

form button:hover {
    background-color: rgba(0, 0, 255, 0.9); /* Fondo más oscuro al pasar el mouse */
}


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; }


/* Responsive Design */
/* Ajustes para pantallas pequeñas */
@media (max-width: 768px) {
    body {
        height: auto;
    }
    #menu {
        flex-direction: column; /* Cambia el menú a una disposición vertical */
        align-items: center; /* Centra los enlaces */
        gap: 15px; /* Aumenta el espacio entre los enlaces */
        padding: 10px; /* Ajusta el espaciado interno */
        
    }

    #menu a {
        width: 90%; /* Los enlaces ocupan el 90% del ancho */
        font-size: 0.9rem; /* Reduce el tamaño de la fuente */
        padding: 10px; /* Ajusta el espaciado interno */
    }

    form {
        width: 100%; /* Ocupa todo el ancho disponible */
        padding: 15px;
    }

    form input,
    form textarea,
    form button {
        font-size: 0.9rem; /* Reduce el tamaño de fuente */
    }
}