/* ****************** Verificación Campos ******************* */
.alerta {
    position: absolute;
    top: 25%;
    left: 22%;
    width: auto;
    height: auto;
    padding: 5px 5px 5px 5px;
    background-color: rgb(0, 0, 0);
    color: #FFF;
}
.formulario__grupo{
    /* height: 85px; */
    /* height: 50px; */
    height: auto;
    margin-top: auto;
    margin-bottom: auto;
}
.formulario__grupo#grupo__terminos{
    height: 20px;
}
.formulario__grupo.formulario__grupo-btn-enviar{
    height: 40px;
}
.formulario__usr-crear {
    position: relative;
    /* left: 28vw; */
    width: 800px;
    height: 800px;
    background-color: rgb(255, 255, 255);
    border: 10px double cornflowerblue;
    border-radius: 10px;
    box-shadow: 10px 10px 15px cornflowerblue;
    transition: .3s ease all;

}
@media (max-width: 1830px) {
    .formulario__usr-crear {
        width: 750px;
        height: 700px;
    }
}
@media (max-width: 1707px) {
    .formulario__usr-crear {
        width: 720px;
        height: 680px;
    }
}
@media (max-width: 1530px) {
    .formulario__usr-crear {
        width: 1200px;
        height: 650px;
    }
}
@media (max-width: 1450px) {
    .formulario__usr-crear {
        width: 1200px;
        height: 610px;
    }
}
@media (max-width: 1370px) {
    .formulario__usr-crear {
        width: 1200px;
        height: 580px;
    }
}
@media (max-width: 1260px) {
    .formulario__usr-crear {
        width: 900px;
        height: 500px;
    }
}


.formulario__label{
    display: block;
    font-weight: 500;
    padding: 10px;
    cursor: pointer;
}
/* .formulario__grupo-input {
    position: relative;
} */

.formulario__input {
    width: 100%;
    background: #fff;
    /* Usamos el color de borde estándar y sutil de Bootstrap */
    border: 1px solid #ced4da; 
    border-radius: 6px; /* Un redondeo más moderno, tipo Bootstrap 5 */
    padding: 0.375rem 0.75rem; /* Padding dinámico en lugar de height fijo */
    min-height: 40px; /* Usamos min-height para que no corte el texto */
    transition: border-color .15s ease-in-out, box-shadow .15s ease-in-out;
}

/* Para los textareas, mantenemos tu lógica pero más limpia */
textarea.formulario__input {
    min-height: 100px;
    height: auto;
}

.formulario__input:focus {
    /* Quitamos el border: 3px que hace saltar el diseño */
    border-color: #86b7fe; 
    outline: none;
    /* Usamos el "resplandor" azul suave nativo de Bootstrap */
    box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25); 
}
/* --- Textos de error --- */
.formulario__input-error {
    font-size: 0.8rem !important; /* Igualamos al tamaño de los mensajes nuevos */
    color: #dc3545 !important;
    margin-top: 4px !important; /* Obligamos a usar un margen pequeño... */
    margin-bottom: 0 !important; /* ...y eliminamos el margen de abajo, ignorando el my-3 */
    line-height: 1.2 !important; /* Mantiene el texto ajustado si ocupa dos líneas */
    display: none;
}
.formulario__input-error-activo {
    display: block;
}

/* --- Mensajes Generales --- */
.formulario__mensaje {
    background: #f8d7da; /* Fondo rojizo suave */
    color: #842029; /* Texto rojo oscuro para buen contraste */
    border: 1px solid #f5c2c7;
    padding: 10px 15px;
    border-radius: 6px; /* Borde redondeado moderno */
    display: none;
}
.formulario__mensaje-activo {
    display: block;
}

.formulario__mensaje-exito {
    font-size: 14px;
    color: #0f5132; 
    background: #d1e7dd; /* Fondo verdoso suave */
    border: 1px solid #badbcc;
    padding: 10px 15px;
    border-radius: 6px;
    display: none;
    margin-top: 15px;
}
.formulario__mensaje-exito-activo {
    display: block;
}

/* --- Botones --- */
.formulario__grupo-btn-enviar {
    display: flex;
    flex-direction: column;
    align-items: center;
}
.formulario__btn {
    height: 45px;
    width: 30%;
    background-color: #0d6efd; /* Azul primario moderno */
    color: #FFF;
    font-weight: bold;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    transition: background-color 0.2s ease, box-shadow 0.2s ease;
}
.formulario__btn:hover {
    background-color: #0b5ed7;
    box-shadow: 0 4px 10px rgba(13, 110, 253, 0.3); /* Sombra moderna */
}

.formulario__btn_salir {
    height: 45px;
    width: 30%;
    background-color: #6c757d; /* Gris secundario moderno */
    color: #FFF;
    font-weight: bold;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    transition: background-color 0.2s ease, box-shadow 0.2s ease;
}
.formulario__btn_salir:hover {
    background-color: #5c636a;
    box-shadow: 0 4px 10px rgba(108, 117, 125, 0.3);
}

/* **************************************************** */
/* --- ESTILOS PARA VALIDACIÓN (LA MAGIA ESTÁ AQUÍ) --- */
/* **************************************************** */

/* .formulario__grupo-incorrecto .formulario__label {
    color: #dc3545; 
} 
*/

.formulario__grupo-incorrecto .formulario__input {
    /* Quitamos el border 3px y usamos la misma sombra de nuestro JS */
    border: 1px solid #dc3545;
    box-shadow: 0 0 0 2px rgba(255, 0, 25, 0.25);
}

.formulario__grupo.formulario__grupo-incorrecto {
    height: auto;
}

.formulario__grupo-correcto .formulario__input {
    /* Quitamos el border 3px y usamos la misma sombra verde de nuestro JS */
    border: 1px solid #198754;
    box-shadow: 0 0 0 2px rgba(18, 102, 1, 0.99);
}