:root{
    --color-sombras: #52525281;
    --color-botones: #1e3838;
    --color-botones-hover: #0f1c1c;
    --color-letra-claro: #78e0e2;
    --color-letra-oscuro: #4b5555;
    --color-fondo-claro: #eefbfb;
    --color-fondo-oscuro: #070e0e;
}

/* Reset de márgenes y paddings */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    color: var(--color-letra-claro);
}



/* Estilos generales para el body */
body {
    font-family: 'Montserrat', sans-serif; /* Aplicar Montserrat como fuente principal */
    background-color: var(--color-fondo-oscuro); /* Fondo gris azul claro */
    background-image: url("../imagenes/fondo-IA-1.jpg");
    backdrop-filter: blur(5px);
    background-size: cover;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 20px;
    height: fit-content;
    min-height: 100vh;
    width: 100%;
}

/* Estilos para el contenedor del formulario */
.container {
    width: 100%;
    max-width: 400px; /* Ancho del formulario reducido */
    height: fit-content;
    display: grid;
    gap: 4px;
    background-color: var(--color-botones-hover); /* Fondo blanco del formulario */
    padding: 20px;
    border-radius: 8px;
    box-shadow: 0 0px 8px var(--color-botones);
    margin-top: 50px;
}

.titulo-principal{
    display: flex;
    flex-direction: column;
    justify-content: space-center;
    align-items: center;
    gap: 10px;
    margin-bottom: 20px;
}


/* Título del formulario */
form h1 {
    font-size: 40px;
    text-align: center;
}

/* Estilos para los labels */
form label {
    display: block;
    margin-bottom: 6px;
    font-weight: bold;
}

label{
    font-size: 14px;
}


form input[type="text"],
form input[type="password"],
form input[type="number"]
{
    font-family: 'Montserrat', sans-serif; /* Aplicar Montserrat como fuente principal */
    width: 100%; /* Asegura que los inputs ocupen el 100% del ancho de su columna */
    padding: 8px 12px;
    border: 1px solid var(--color-botones); /* Borde grisáceo suave */
    border-radius: 4px;
    font-size: 14px;
    margin-bottom: 10px;
    transition: border-color 0.3s ease; /* Transición suave del borde */
    background-color: var(--color-botones);
    color: var(--color-letra-claro);
    opacity: 0.7;
}



/* Estilo para el borde al tener el foco en un campo de entrada */
form input:focus{
    border-color: var(--color-letra-claro); /* Azul profundo para el foco */
    outline: none; /* Eliminar el contorno predeterminado */
}

/* Estilo para el botón */
form button, a {
    width: 100%; /* Asegura que el botón tenga el mismo ancho que los inputs */
    padding: 12px;
    background-color: var(--color-botones-hover); /* Azul Vivo */
    border-radius: 4px; /* Bordes ligeramente redondeados */
    color: var(--color-fondo-claro);
    font-size: 16px;
    font-weight: 600; /* Peso de fuente para mayor claridad */
    cursor: pointer;
    transition: background-color 0.3s ease;
    margin-top: 10px; /* Espacio superior para separar del contenido */
    border: 1px solid var(--color-botones);
    text-align: center;
}

/* Cambia el color de fondo del botón al pasar el cursor sobre él */
form button:hover, a:hover {
    background-color: var(--color-botones); /* Azul más oscuro en hover */
}


.error{
    position: absolute;
    display: flex;
    top: 20px;
    left: 50%;
    transform: translateX(-50%);
    align-items: center;
    background-color: #840909;
    color: var(--color-fondo-claro);
    height: 40px;
    border-radius: 10px;
    padding: 10px 20px;
    font-weight: bold;
    animation: quitar_mensaje 5s ease forwards;
}

@keyframes quitar_mensaje {
    from{
        display: block;
    }
    to {
        display: none;
    }
}


input::placeholder{
    color: var(--color-letra-claro);
    opacity: 0.5;
}

a{
    text-decoration: none;
    width: 35%;
}

.contenedor-botones{
    display: flex;
    gap: 20px;
}

@media (max-width: 768px) {
    body{
        height: 100vh;
        overflow:hidden;
    }
    .container{
        width: 90%;
    }
    form h1 {
        font-size: 30px;
    }
    form input[type="text"],
    form input[type="password"],
    form input[type="number"]
    {
        width: 100%; /* Asegura que los inputs ocupen el 100% del ancho de su columna */
        min-width: 200px;
    }
    .contenedor-botones{
        width: 100%;
        gap: 5px;
        flex-wrap: wrap;
    }
    .contenedor-botones a,  .contenedor-botones button{
        width: 100%;
    }
    .contenedor-botones a{
        order:2;
    }
    .contenedor-botones button{
        order:1;
    }

}