/* Definimos la animación para el movimiento del gradiente del body */
@keyframes movimiento-gradiente {
    0% {
        background-position: 0% 50%;
    }
    50% {
        background-position: 100% 50%;
    }
    100% {
        background-position: 0% 50%;
    }
}

body {
        background: linear-gradient(135deg, #23445b, #24587c, #133d5c); /* Gradiente de tonos azules más apagados */
    background-size: 400% 400%; /* Fondo más grande para el efecto de movimiento */
    background-attachment: fixed;
    font-family: 'Roboto', sans-serif; /* Fuente más moderna y legible */
    color: #ffffff; /* Cambiar el color del texto a blanco */
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    text-align: center; /* Alinear todo el contenido al centro */
    animation: movimiento-gradiente 10s ease infinite; /* Aplicar animación al body */
}



#taulellContainer {
    text-align: center;
    margin-top: 20px;
    margin-bottom: 7rem; /* Añadir margen inferior de 7rem */
}
h1 {
    color: #ccdd00;
    text-align: center;
    font-size: 37px;
    margin-bottom: 10px;
    font-weight: bold;
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.7);
}
table {
    border: 5px solid #212529;
    border-collapse: collapse;
    margin: 0 auto; /* Centrar la tabla en la página */
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.5); /* Añadir sombra suave para mejor visibilidad */
}

tr, td {
    border: 2px solid #000;
    padding: 0;
    background-color: rgb(58, 58, 58);
    width: 30px;
    height: 30px;
    text-align: center;
    vertical-align: middle;
    font-size: 1rem; /* Usar unidades relativas para la fuente */
    cursor: pointer;
    transition: background-color 0.3s ease; /* Añadir una transición suave al color de fondo */
    color: black;
    position: relative; /* Asegurar que el overlay se posicione correctamente */
}

td span {
    line-height: 30px; /* Alinea el texto verticalmente en el centro */
    z-index: 1; /* Asegurar que el span esté sobre el fondo */
}

td .overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: gray;
    opacity: 1;
    z-index: 2;
    transition: opacity 0.3s ease; /* Añadir transición para desvanecer el overlay */
}

input {
    margin-bottom: 10px;
    width: 70px; /* Ancho del input */
    height: 30px; /* Aumentar la altura para mayor visibilidad */
    color: #212529;
    background-color: #ffffff;
    border-radius: 5px;
    border: solid #ccc 1px;
    padding: 5px;
    font-size: 1rem; /* Usar unidades relativas para el tamaño de la fuente */
    text-align: center;
}

label {
    color: #ffffff;
    font-size: 1.1rem; /* Usar unidades relativas para el tamaño de la fuente */
    margin-right: 10px;
    display: inline-block; /* Asegurar que el label se mantenga alineado */
    margin-bottom: 10px; /* Añadir un margen inferior para dar espacio al input */
}

label:first-of-type {
    margin-top: 60px; /* Añadir un margen superior al primer label */
}

button {
    margin-top: 20px;
    padding: 10px 20px;
    font-weight: bold;
    cursor: pointer;
    border-radius: 5px;
    background: #ffffff;
    color: #212529;
    border: 2px solid #212529;
    font-size: 1rem; /* Usar unidades relativas */
    transition: all 0.3s ease;
}

button:hover {
    background: #212529;
    color: #ffffff;
}

.fondo-mina {
    background-color: rgb(255, 29, 29);
    color: #ffffff;
    font-weight: bold;
}

.fondo-sinmina {
    background-color: rgb(255, 255, 255);
}

.texto-minas {
    background-color: #212529;
    border-radius: 3px;
    color: #ffffff;
    padding: 10px;
    display: inline-block;
    text-align: center;
    margin-top: 20px;
    font-size: 1.1rem; /* Usar unidades relativas */
    font-weight: bold;
}

.numero-a-color {
    color: rgb(255, 0, 0);
}

/* Estilos para los números con fondo de color y número negro */
.numero-bg-1 {
    background-color: blue;
    color: black;
    font-weight: bold;
}

.numero-bg-2 {
    background-color: green;
    color: black;
    font-weight: bold;
}

.numero-bg-3 {
    background-color: red;
    color: black;
    font-weight: bold;
}

.numero-bg-4 {
    background-color: purple;
    color: black;
    font-weight: bold;
}

/* Efecto hover en las celdas para mejorar la usabilidad */
td:hover {
    background-color: rgba(255, 255, 255, 0.8);
}

/* Estilos responsivos */
@media (max-width: 768px) {
    input {
        width: 50px; /* Reducir ancho en pantallas más pequeñas */
        height: 25px; /* Reducir la altura para pantallas más pequeñas */
        font-size: 0.9rem; /* Reducir tamaño de fuente */
    }

    label {
        font-size: 1rem; /* Reducir el tamaño de la fuente en pantallas más pequeñas */
    }

    button {
        font-size: 0.9rem; /* Reducir tamaño de fuente en pantallas más pequeñas */
        padding: 8px 15px; /* Ajustar padding para botones más pequeños */
    }

    table {
        width: 100%;
        max-width: 90vw; /* Limitar el ancho máximo del tablero en pantallas pequeñas */
    }

    td {
        width: 25px;
        height: 25px; /* Hacer las celdas un poco más pequeñas en pantallas más pequeñas */
        font-size: 0.9rem;
    }
}

@media (max-width: 480px) {
    input {
        width: 40px;
        height: 20px;
        font-size: 0.8rem;
    }

    label {
        font-size: 0.9rem;
    }

    button {
        font-size: 0.8rem;
        padding: 6px 10px;
    }

    table {
        width: 100%;
        max-width: 85vw; /* Hacer el tablero más pequeño en pantallas muy pequeñas */
    }

    td {
        width: 20px;
        height: 20px; /* Reducir el tamaño de las celdas aún más */
        font-size: 0.8rem;
    }
}
