.error {
  border: 2px solid var(--generic-red) !important;
  /* margin: 0.5rem -3px; */
}

/* .success { */
/*   border: 3px solid #00e600 !important; */
/* } */

.error-message {
  font-style: italic;
  color: var(--generic-red);
  padding: 0.2rem;
  margin-bottom: 1rem;
}

.error-message.hidden {
  display: none;
}

.success-message,
.sending-message {
  font-weight: bold;
  font-size: 1.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  /* margin: auto; */
  padding: 0.6rem;
  margin-top: 1rem;
}

.confirmation-message-info {
  font-size: 1rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 0.6rem;
}

.sending-details,
.back-link {
  margin: auto;
  padding: 0.6rem;
  font-size: 1rem;
}

.sending-message.hidden,
.confirmation-message-info.hidden,
.back-link.hidden,
.sending-rotate.hidden,
.sending-details.hidden {
  display: none;
  visibility: hidden;
  width: 0px;
  height: 0px;
  padding: 0px;
}

.sending-message.sending:before {
  content: "Sending";
}

.sending-message.send-failure:before {
  content: "Failed to send. Please try again later.";
}

.sending-message.send-success:before {
  content: "Your form has been submitted.";
}

.sending-message.validation-failure:before {
  content: "Please correct form entries.";
}

.sending-rotate {
  border-bottom: 2px solid #0a8a51;
  border-left: 2px solid #0a8a51;
  border-radius: 50%;
  padding: 0.5rem;
  -webkit-animation: rotate 1200ms infinite cubic-bezier(0.5, 0.5, 0.3, 0.7);
  animation: rotate 1200ms infinite cubic-bezier(0.5, 0.5, 0.3, 0.7);
  margin-top: 0.4rem;
  margin-left: 0.5rem;
}

@-webkit-keyframes rotate {
  from {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  to {
    -webkit-transform: rotate(359deg);
    transform: rotate(359deg);
  }
}

@keyframes rotate {
  from {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  to {
    -webkit-transform: rotate(359deg);
    transform: rotate(359deg);
  }
}
