/* 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, #292410, #eb9c26cf); /* 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 */
}


/* 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 */
}

/* Contenido Principal */
/* Estilo del contenedor principal */
#contenido {
    display: flex; /* Usa Flexbox para alinear los elementos */
    align-items: center; /* Alinea los elementos verticalmente */
    justify-content: space-between; /* Distribuye los elementos con espacio entre ellos */
    flex-wrap: wrap; /* Permite que los elementos se ajusten en pantallas pequeñas */
    padding: 20px; /* Espaciado interno */
    margin: 20px; /* Margen alrededor del contenedor */
}

/* Estilo de la sección de presentación */
#presentacion {
    flex: 1; /* Ocupa el mismo espacio que la imagen */
    font-size: 1rem; /* Tamaño de fuente */
    font-weight: 200; /* Peso de la fuente */
    text-align: justify; /* Justifica el texto */
    line-height: 1.5; /* Altura de línea */
    margin-right: 20px; /* Margen derecho */
    padding: 20px; /* Espaciado interno */
    background-color: rgba(0, 0, 0, 0.22); /* Fondo semitransparente */
    border-radius: 10px; /* Bordes redondeados */
}

/* Estilo de la imagen */
#contenido img {
    flex: 1; /* Ocupa el mismo espacio que la sección de presentación */
    max-width: 400px; /* Ancho máximo de la imagen */
    height: auto; /* Ajusta la altura automáticamente */
    border-radius: 10px; /* Bordes redondeados */
    margin: 20px; /* Margen alrededor de la imagen */
    border: 5px solid rgba(255, 255, 255, 0.22); /* Borde blanco semitransparente */
}


/* Contenedor de los círculos animados */
.circles {
    position: absolute; /* Posición absoluta para que se superponga al fondo */
    top: 0;
    left: 0;
    width: 100%; /* Ocupa todo el ancho */
    height: 100%; /* Ocupa toda la altura */
    overflow: hidden; /* Oculta los círculos que se salen del contenedor */
    z-index: -1; /* Envía los círculos al fondo */
}

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) {
    #menu {
        flex-direction: column; /* Cambia el menú a una columna */
        align-items: center; /* Centra los enlaces */
    }

    #menu a {
        width: 80%; /* Los enlaces ocupan el 80% del ancho */
    }

    #contenido {
        flex-direction: column; /* Cambia el diseño a una columna */
        align-items: center; /* Centra los elementos */
    }

    #presentacion {
        margin-right: 0; /* Elimina el margen derecho */
        margin-bottom: 20px; /* Agrega margen inferior */
        text-align:justify; /* Centra el texto */
    }

    #contenido img {
        max-width: 100%; /* La imagen ocupa todo el ancho disponible */
    }
}