:root {
  --gen-color: #651e60; }

.btn {
  font-weight: 500; }

.btn-primary {
  border: 1px solid var(--gen-color);
  background-color: var(--gen-color); }

.btn-primary:hover {
  /*border: 1px solid var(--gen-color);*/
  background-color: transparent;
  color: var(--gen-color); }


.form-wrap {
  max-width: 580px;
  margin: auto;
  text-align: center; 
  border-radius: 6px;
  border: 1px solid #e6eaf1;
  padding: 30px 40px;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
  transition: .2s ease;
}

.form-wrap:hover {
  box-shadow: 0 3px 12px rgba(0, 0, 0, 0.15);
}

.form-wrap .btn-primary {
  position: relative;
  white-space: normal !important;
  line-height: initial;
}
.form-wrap .btn-primary img {
  position: absolute;
  left: -65px;
  top: 50%;
  transform: translate(0, -50%);
  max-width: 50px;
  opacity: 0;
  visibility: hidden;
}

.form-wrap .btn-primary.active img {
  opacity: 1;
  visibility: visible;
}

.success-btn {
  position: absolute;
  opacity: 0;
  visibility: hidden;
}