.login.login-2 .login-signin,
.login.login-2 .login-signup,
.login.login-2 .login-forgot {
  display: none;
}
.login.login-2.login-signin-on .login-signup {
  display: none;
}
.login.login-2.login-signin-on .login-signin {
  display: block;
}
.login.login-2.login-signin-on .login-forgot {
  display: none;
}
.login.login-2.login-signup-on .login-signup {
  display: block;
}
.login.login-2.login-signup-on .login-signin {
  display: none;
}
.login.login-2.login-signup-on .login-forgot {
  display: none;
}
.login.login-2.login-forgot-on .login-signup {
  display: none;
}
.login.login-2.login-forgot-on .login-signin {
  display: none;
}
.login.login-2.login-forgot-on .login-forgot {
  display: block;
}
.login.login-2 .content .content-img {
  min-height: 450px;
}

@media (min-width: 992px) {
  .login.login-2 .login-aside {
    width: 100%;
    max-width: 600px;
  }
  .login.login-2 .content .content-img {
    min-height: 600px !important;
  }
  .login.login-2 .login-form {
    width: 100%;
    max-width: 450px;
  }
}
@media (min-width: 992px) and (max-width: 1399.98px) {
  .login.login-2 .login-aside {
    width: 100%;
    max-width: 600px;
  }
}
@media (max-width: 991.98px) {
  .login.login-2 .content .content-img {
    min-height: 470px !important;
    background-size: 700px;
  }
  .login.login-2 .login-form {
    width: 100%;
    max-width: 400px;
  }
}
@media (max-width: 575.98px) {
  .login.login-2 .content .content-img {
    min-height: 280px !important;
    background-size: 400px;
  }
  .login.login-2 .login-form {
    width: 100%;
    max-width: 100%;
  }
}

.swal2-container .swal2-html-container {
  max-height: max-content !important;
}

.swal2-icon-success.swal2-modal.swal2-popup.swal2-show {
  width: 450px !important;
}



/* BASE: Estilos para mensagem container */
.fv-plugins-message-container {
  margin-top: 5px;
  font-size: 0.9rem;
  font-weight: 500;
}

  /* ERRO: Estilos para mensagens de erro (vermelho) */
  .fv-plugins-message-container .fv-help-block:not(.success-message) {
    color: #f65668 !important;
  }

/* ERRO: Estilo para borda do input quando inválido */
.form-group:has(.fv-plugins-message-container .fv-help-block:not(.success-message)) input,
.form-group:has(.fv-plugins-icon-invalid) input {
  border-color: #f65668 !important;
  border-width: 1px !important;
}

/* ERRO: Estilo para o label quando há erro de validação */
.form-group:has(.fv-plugins-message-container .fv-help-block:not(.success-message)) .font-size-h6.font-weight-bolder.text-dark,
.form-group:has(.fv-plugins-icon-invalid) .font-size-h6.font-weight-bolder.text-dark {
  color: #f65668 !important;
}

/* SUCESSO: Estilos para mensagens de sucesso (verde) */
.fv-plugins-message-container .fv-help-block.success-message {
  color: #1bc5bd !important;
}

/* SUCESSO: Estilos para borda em caso de sucesso */
.form-group:has(.fv-plugins-message-container .success-message) input {
  border-color: #1bc5bd !important;
  border-width: 1px !important;
}

/* SUCESSO: Estilos para label em caso de sucesso */
.form-group:has(.fv-plugins-message-container .success-message) .font-size-h6.font-weight-bolder.text-dark {
  color: #1bc5bd !important;
}

/* PRIORIDADE: Garantir que o estilo de sucesso tenha prioridade sobre o de erro quando ambos estiverem presentes */
.form-group:has(.fv-plugins-message-container .success-message) input {
  border-color: #1bc5bd !important;
}

.form-group:has(.fv-plugins-message-container .success-message) .font-size-h6.font-weight-bolder.text-dark {
  color: #1bc5bd !important;
}