/* ===== Login ===== */
.login {
  max-width: 45rem;
  background-color: var(--blanco);
  padding: 3rem 4rem;
  border-radius: 1rem;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.1);
}

/* Título */
.login h2 {
  color: var(--negro);
  font-size: 4rem;
  margin-bottom: 2rem;
}

/* Campos del formulario */
.form-login {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.campo {
  display: flex;
  flex-direction: column;
}

.campo label {
  font-weight: bold;
  margin-bottom: 0.5rem;
  color: var(--grisOscuro);
}

.campo input {
  padding: 1rem;
  border: 1px solid var(--grisClaro);
  border-radius: 0.5rem;
  font-size: 1.6rem;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

.campo input:focus {
  outline: none;
  border-color: var(--azul);
  box-shadow: 0 0 0 2px rgba(0, 165, 226, 0.2);
}

/* Botón */
.btn-login {
  background-color: var(--amarilloTenis);
  color: var(--negro);
  cursor: pointer;
  transition: background-color 0.3s ease, transform 0.2s ease;
}

.btn-login:hover {
  background-color: var(--amarilloTenisOscuro);
  transform: translateY(-2px);
}

/* Alerta de error */
.alerta-error {
  background-color: #ffe5e5;
  color: #b30000;
  border: 1px solid #f5a8a8;
  padding: 1rem 1.5rem;
  border-radius: 0.5rem;
  margin-bottom: 2rem;
  font-size: 1.5rem;
}
.alerta-exito {
  background-color: rgb(207, 250, 207);
  color: rgb(0, 99, 0);
  border: 1px solid rgb(180, 249, 180);
}

/* ===== Responsive ===== */
@media (max-width: 480px) {
  .login {
    padding: 2rem;
  }

  .btn-login {
    width: 100%;
  }
}
