
/* 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, #190828da, #3b1911); /* 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 */
}

#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 */
}


/* Header */
/* Estilo del título principal de la página */
h1#aviso {
    text-align: center; /* Centra el texto */
    font-size: 2rem; /* Tamaño de fuente */
    margin: 20px 0; /* Margen superior e inferior */
    margin-bottom: 50px; /* Margen inferior adicional */
    margin-top: 50px; /* Margen superior adicional */

}


/* Contenedor de la tabla de avisos */
#tabla {
    display: flex; /* Usa Flexbox para centrar la tabla */
    justify-content: center; /* Centra la tabla horizontalmente */
    margin: 20px; /* Margen alrededor del contenedor */
}

#tabla 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 */
#tabla th, #tabla td {
    border: 1px solid white; /* Bordes blancos */
    padding: 10px; /* Espaciado interno */
    text-align: center; /* Centra el texto dentro de las celdas */
    font-weight: 300;
}

/* Estilo de las celdas del encabezado */
#tabla th {
    background-color: rgba(255, 255, 255, 0.2); /* Fondo semitransparente */
}

/* Estilo de las celdas del cuerpo */
#tabla td {
    background-color: rgba(255, 255, 255, 0.1); /* Fondo semitransparente */
}


/* Estilo del contenedor de recordatorio */
#recordatorio {
    margin: 20px; /* Margen alrededor del contenedor */
    padding: 20px; /* Espaciado interno */
    background-color: rgba(0, 0, 0, 0.3); /* Fondo semitransparente */
    border-radius: 10px; /* Bordes redondeados */
    font-size: 1rem; /* Tamaño de fuente */
    text-align: center; /* Centra el texto */
}


a,
a:visited,
a:hover,
a:active {
    color:coral; /* Hereda el color del elemento padre */
    text-decoration: none; /* Elimina el subrayado */
}

/* 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 */
}

/* Estilo de los círculos */
.circles li {
    position: absolute; /* Posición absoluta para animarlos individualmente */
    display: block; /* Se comportan como bloques */
    list-style: none; /* Elimina los estilos de lista */
    width: 20px; /* Ancho del círculo */
    height: 20px; /* Alto del círculo */
    background: rgba(255, 255, 255, 0.2); /* Fondo semitransparente */
    animation: animate 25s linear infinite; /* Animación infinita */
    bottom: -150px; /* Posición inicial fuera de la pantalla */
}

/* Configuración específica para cada círculo */
.circles li:nth-child(1) { left: 25%; width: 80px; height: 80px; animation-delay: 0s; }
.circles li:nth-child(2) { left: 10%; width: 20px; height: 20px; animation-delay: 2s; animation-duration: 12s; }
.circles li:nth-child(3) { left: 70%; width: 20px; height: 20px; animation-delay: 4s; }
.circles li:nth-child(4) { left: 40%; width: 60px; height: 60px; animation-delay: 0s; animation-duration: 18s; }
.circles li:nth-child(5) { left: 65%; width: 20px; height: 20px; animation-delay: 0s; }
.circles li:nth-child(6) { left: 75%; width: 110px; height: 110px; animation-delay: 3s; }
.circles li:nth-child(7) { left: 35%; width: 150px; height: 150px; animation-delay: 7s; }
.circles li:nth-child(8) { left: 50%; width: 25px; height: 25px; animation-delay: 15s; animation-duration: 45s; }
.circles li:nth-child(9) { left: 20%; width: 15px; height: 15px; animation-delay: 2s; animation-duration: 35s; }
.circles li:nth-child(10) { left: 85%; width: 150px; height: 150px; animation-delay: 0s; animation-duration: 11s; }

/* Animación de los círculos */
@keyframes animate {
    0% {
        transform: translateY(0) rotate(0deg); /* Posición inicial */
        opacity: 1; /* Totalmente visible */
        border-radius: 0; /* Sin bordes redondeados */
    }
    100% {
        transform: translateY(-1000px) rotate(720deg); /* Se mueve hacia arriba y rota */
        opacity: 0; /* Se desvanece */
        border-radius: 50%; /* Se convierte en un círculo perfecto */
    }
}

/* 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 */
    }

    #tabla table {
        font-size: 0.9rem; /* Reduce el tamaño de la fuente */
    }

    #recordatorio {
        font-size: 0.9rem; /* Reduce el tamaño del texto */
    }

    h1#aviso {
        font-size: 1.5rem; /* Reduce el tamaño del título */
    }
}