.contact-form .button-loading {
  border: 1px solid #c4cdd5;
  cursor: default;
  text-shadow: none;
  color: transparent !important;
  position: relative;
  transition: border-color 0.2s ease-out;
}
.contact-form .button-loading, .contact-form .button-loading:hover, .contact-form .button-loading:focus, .contact-form .button-loading:active {
  color: transparent;
}
.contact-form .button-loading:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  border-radius: 50%;
  border-width: 3px;
  border-style: solid;
  margin-top: -9px;
  margin-left: -9px;
  width: 18px;
  height: 18px;
  -webkit-animation: button-loading-spinner 0.7s linear infinite;
  animation: button-loading-spinner 1s linear infinite;
  border-color: #ffffff;
  border-bottom-color: transparent;
}
.contact-form .required:after {
  content: " *";
  color: red;
}
.contact-form .contact-message {
  margin: 0 0 20px 0;
  padding: 15px 30px 15px 15px;
  border-left: 5px solid #eeeeee;
  border-radius: 0;
  display: block;
  width: 100%;
}
.contact-form .contact-message.contact-success-message {
  background-color: #c0edf1;
  border-color: #58d0da;
  color: #000;
}
.contact-form .contact-message.contact-error-message {
  background-color: #faeaa9;
  border-color: #f3cc31;
  color: #000;
}

@-webkit-keyframes button-loading-spinner {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}
@keyframes button-loading-spinner {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}