@media (min-width: 300px) {
  .login-clean {
    padding: 80px 20px;
  }
}

@media (min-width: 768px) {
  .login-clean {
    padding: 80px 20px;
    max-width: 45vw;
  }
}

@media (min-width: 992px) {
  .login-clean form {
    max-width: 25vw;
    width: 100%;
    margin: 0 auto;
  }
}

@media (min-width: 768px) {
  .login-clean form {
    width: 100%;
    margin: 0 auto;
  }
}

.login-clean .illustration {
  text-align: center;
  padding: 0 0 20px;
  font-size: 12px;
  color: #DC433A;
}

.login-clean form .form-control {
  background: #f7f9fc;
  border: none;
  border-bottom: 1px solid #dfe7f1;
  border-radius: 0;
  box-shadow: none;
  outline: none;
  color: black;
  text-indent: 8px;
  height: 42px;
}

.login-clean form .form-control.is-invalid{
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' width='12' height='12' fill='none' stroke='%23e74a3b'%3e%3ccircle cx='6' cy='6' r='4.5'/%3e%3cpath stroke-linejoin='round' d='M5.8 3.6h.4L6 6.5z'/%3e%3ccircle cx='6' cy='8.2' r='.6' fill='%23e74a3b' stroke='none'/%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right calc(0.375em + 0.1875rem) center;
  background-size: calc(0.75em + 0.375rem) calc(0.75em + 0.375rem);
}

.login-clean form .btn-primary {
  background: #DC433A;
  border: none;
  border-radius: 4px;
  padding: 11px;
  box-shadow: none;
  margin-top: 26px;
  text-shadow: none;
  outline: none !important;
}

.login-clean form .btn-primary:hover, .login-clean form .btn-primary:active {
  background: #DC433A;
}

.login-clean form .btn-primary:active {
  transform: translateY(1px);
}

.login-clean form .forgot {
  display: block;
  text-align: center;
  font-size: 12px;
  color: #6f7a85;
  opacity: 0.9;
  text-decoration: none;
}

.login-clean form .forgot:hover, .login-clean form .forgot:active {
  opacity: 1;
  text-decoration: none;
}

