/* --- auth-bootstrap.css --- */
/* Ajusta formularios generados automáticamente por web2py a Bootstrap 5 */

/* Contenedor base */
.web2py_form, form, .auth-form {
  width: 100%;
}

/* Etiquetas */
.web2py_form label,
form label {
  display: block;
  margin-bottom: 0.25rem;
  font-weight: 500;
}

/* Inputs y selects */
.web2py_form input[type="text"],
.web2py_form input[type="password"],
.web2py_form input[type="email"],
.web2py_form input[type="number"],
.web2py_form select,
.web2py_form textarea,
form input[type="text"],
form input[type="password"],
form input[type="email"],
form input[type="number"],
form select,
form textarea {
  display: block;
  width: 100%;
  padding: 0.5rem 0.75rem;
  font-size: 1rem;
  border: 1px solid #ced4da;
  border-radius: 0.375rem;
  box-sizing: border-box;
  margin-bottom: 0.75rem;
}

/* Botones */
.web2py_form input[type="submit"],
form input[type="submit"],
button[type="submit"] {
  display: inline-block;
  width: 100%;
  background-color: #0d6efd;
  border: 1px solid #0d6efd;
  color: #fff;
  padding: 0.5rem;
  font-size: 1rem;
  border-radius: 0.375rem;
  transition: background-color 0.2s ease-in-out;
}

.web2py_form input[type="submit"]:hover,
form input[type="submit"]:hover,
button[type="submit"]:hover {
  background-color: #0b5ed7;
}

/* Mensajes de error */
.web2py_form .error,
form .error {
  color: #dc3545;
  font-size: 0.875rem;
}

/* Ajustes para los formularios auth() */
.auth-form form table {
  width: 100%;
}
.auth-form td, .auth-form th {
  border: none !important;
  padding: 0;
}

/* Mensajes flash */
.flash {
  margin-bottom: 1rem;
  padding: 0.75rem;
  border-radius: 0.375rem;
  text-align: center;
}
.flash.success {
  background-color: #d1e7dd;
  color: #0f5132;
}
.flash.error {
  background-color: #f8d7da;
  color: #842029;
}

/* --- fin de auth-bootstrap.css --- */
