.wpcf7 {
  width: 100%;
  max-width: min(100%, 80rem);
}
.wpcf7 .screen-reader-response {
  display: none;
}
.wpcf7-form {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 2.4rem;
}
.form__inner {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 3.6rem;
}
.wpcf7 .form__heading {
  display: flex;
  flex-direction: column;
  width: 100%;
  gap: 2.4rem;
}
.wpcf7 .form__heading .form__title {
  font-size: 3.6rem;
  line-height: 1.2;
  color: #fff;
  text-transform: uppercase;
}
.wpcf7 .form__heading .form__description {
  font-size: 1.8rem;
  line-height: 1.4;
}
.wpcf7 .form__content {
  display: flex;
  flex-direction: column;
  width: 100%;
  gap: 3.6rem;
}
.wpcf7 .form-groups {
  display: flex;
  flex-direction: column;
  width: 100%;
  gap: 3.6rem;
}
.wpcf7 .form-group {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 2.4rem;
}
.wpcf7 .form-group .form-group__heading {
}
.wpcf7 .form-group.portfolio .form-group__heading {
  display: flex;
  width: 100%;
  align-items: center;
  justify-content: space-between;
}
.wpcf7 .form-group.portfolio .form-group__heading .form-group__actions {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  flex-wrap: wrap;
}
.wpcf7 .form-group.portfolio .form-group__heading .form-group__action {
  display: flex;
  align-items: center;
  height: 2.8rem;
  padding: 0 1.6rem;
  border-radius: 20rem;
  cursor: pointer;
  transition: 0.2s;
  font-size: 1.4rem;
  font-weight: 400;
  background-color: #fff;
  transition: 0.3s;
}
.wpcf7 .form-group.portfolio .form-group__heading .form-group__action:hover {
  opacity: 0.7;
}
.wpcf7 .form-group .form-group__heading .form-group__title {
  font-size: 3.6rem;
  color: #fff;
  text-transform: uppercase;
  line-height: 1.2;
  opacity: 0.3;
}
.wpcf7 .form-group .form-group__content {
  display: flex;
  flex-direction: column;
  width: 100%;
  align-items: stretch;
  gap: 3.6rem;
}
.wpcf7 .form-group .form-rows {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 3.6rem;
}
.wpcf7 .form-group .form-row {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 2.4rem;
}
.wpcf7 .form-group .form-row.hidden {
  display: none;
}
.wpcf7 .form-group .form-row .form-row__heading {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0.4rem;
}
.wpcf7 .form-group .form-row .form-row__heading .form-row__label {
  display: block;
  font-size: 2.4rem;
  line-height: 1.2;
  font-weight: 400;
  color: #fff;
  text-transform: lowercase;
}
.wpcf7 .form-group .form-row .form-row__heading .form-row__description {
  display: block;
  font-size: 1.4rem;
  line-height: 1.2;
  opacity: 0.6;
  color: #fff;
}
.wpcf7 .form-group .form-row__content {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 3.6rem;
}
.wpcf7 .form-group .form-row .form-row__field {
  width: 100%;
}

.wpcf7 .form-group .form-row .form-subrows {
  display: flex;
  width: 100%;
  flex-direction: column;
  align-items: stretch;
  gap: 2rem;
  padding-left: 3.2rem;
  position: relative;
}
.wpcf7 .form-group .form-row .form-subrows.hidden {
  display: none;
}
.wpcf7 .form-group .form-row .form-subrows:before {
  content: '';
  position: absolute;
  left: 1.2rem;
  top: 0;
  bottom: 0;
  width: 0.6rem;
  background-color: var(--color-bg-default);
  border-radius: 1rem;
}
.wpcf7 .form-group .form-row .form-subrow {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0.8rem;
}
.wpcf7 .form-group .form-row .form-subrow .form-subrow__heading {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0.4rem;
}
.wpcf7
  .form-group
  .form-row
  .form-subrow
  .form-subrow__heading
  .form-subrow__label {
  display: block;
  font-size: 1.6rem;
  line-height: 1.2;
  color: #fff;
}
.wpcf7 .form-group .form-row .form-subrow .form-subrow__field {
  width: 100%;
}

.wpcf7 .form-actions {
  width: 100%;
  display: flex;
  align-items: stretch;
  gap: 0.6rem;
}
.wpcf7 .form-action.button {
  background: var(--color-accent);
  display: flex;
  align-items: center;
  padding: 0 0.6rem 0 3.6rem;
  gap: 2.4rem;
  height: 7.2rem;
  border-radius: 20rem;
  transition: 0.3s;
  cursor: pointer;
  position: relative;
  pointer-events: auto;
  font-family: inherit;
  font-weight: inherit;
}
.wpcf7 .form-action.button.loading {
  pointer-events: none;
  opacity: 0.7;
}
.wpcf7 .form-action.button:hover {
}
.wpcf7 .form-action.button .button__text {
  display: block;
}
.wpcf7 .form-action.button .button__label {
  font-size: 1.8rem;
  display: block;
  color: #fff;
}
.wpcf7 .form-action.button .button__icons {
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.1);
  width: 6rem;
  height: 6rem;
  position: relative;
  overflow: hidden;
  flex-shrink: 0;
  transition: 0.3s;
}
.wpcf7 .form-action.button:hover .button__icons {
  background-color: rgba(255, 255, 255, 0.2);
}
.wpcf7 .form-action.button .button__icon {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: 0.3s;
  transform: scale(1);
  opacity: 1;
}
.wpcf7 .form-action.button .button__icon.hidden {
  opacity: 0;
  transform: scale(0.5);
}
.wpcf7 .form-action.button .button__icon .icon {
  max-height: 100%;
  fill: #fff;
  display: block;
}
.wpcf7 .form-action.button .button__icon.button__icon--default {
}
.wpcf7 .form-action.button .button__icon.button__icon--default .icon {
  width: 46%;
}
.wpcf7 .form-action.button .button__icon.button__icon--loader {
  animation: spin 2s linear infinite;
}
.wpcf7 .form-action.button .button__icon.button__icon--loader .icon {
  width: 60%;
}
@keyframes spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}

.wpcf7 .wpcf7-form-control-wrap {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  width: 100%;
}
.wpcf7 .form__input {
  display: block;
  font-size: 1.8rem;
  color: inherit;
  padding: 1.4rem 2.4rem;
  font-weight: 400;
  width: 100%;
  border-radius: 1.2rem;
  font-family: inherit;
  resize: none;
  border: 0.2rem solid rgba(255, 255, 255, 0.2);
  color: #fff;
}
.wpcf7 .form__input.wpcf7-textarea {
  line-height: 1.3;
  height: 12rem;
  color: #fff;
}
.wpcf7 .form__input::-webkit-input-placeholder {
  color: rgba(255, 255, 255, 0.5);
}
.wpcf7 .form__input:-ms-input-placeholder {
  color: rgba(255, 255, 255, 0.5);
}
.wpcf7 .form__input::-ms-input-placeholder {
  color: rgba(255, 255, 255, 0.5);
}
.wpcf7 .form__input::placeholder {
  color: rgba(255, 255, 255, 0.5);
}
.wpcf7 .form__input.wpcf7-not-valid {
  border: 0.1rem solid #ff6c6c;
}

.wpcf7 .wpcf7-select {
  display: block;
  font-size: 1.6rem;
  color: inherit;
  padding: 1.2rem 1.2rem;
  font-weight: 400;
  width: 100%;
  border-radius: 1.2rem;
  font-family: inherit;
  resize: none;
}

.wpcf7 .wpcf7-checkbox {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  align-items: flex-start;
  width: 100%;
}
.wpcf7 .wpcf7-checkbox .vertical {
  flex-direction: column;
  align-items: flex-start;
  gap: 0.6rem;
}
.wpcf7 .wpcf7-checkbox .wpcf7-list-item {
}
.wpcf7 .wpcf7-checkbox .wpcf7-list-item label {
}
.wpcf7 .wpcf7-checkbox .wpcf7-list-item input {
  display: none;
}
.wpcf7 .wpcf7-checkbox .wpcf7-list-item .wpcf7-list-item-label {
  display: flex;
  align-items: center;
  height: 5.2rem;
  padding: 0 2.4rem 0 5rem;
  border-radius: 20rem;
  cursor: pointer;
  transition: 0.2s;
  font-size: 1.8rem;
  position: relative;
  font-weight: 400;
  background-color: rgba(255, 255, 255, 0.1);
  transition: 0.3s;
}
.wpcf7 .wpcf7-checkbox .wpcf7-list-item .wpcf7-list-item-label:before {
  content: '';
  display: block;
  width: 2.2rem;
  height: 2.2rem;
  border-radius: 20rem;
  border: 0.2rem solid rgba(255, 255, 255, 0.3);
  flex-shrink: 0;
  position: absolute;
  left: 1.3rem;
  top: 1.3rem;
  transition: 0.3s;
}
.wpcf7 .wpcf7-checkbox .wpcf7-list-item .wpcf7-list-item-label:hover:before {
  border: 0.2rem solid #fff;
}
.wpcf7 .wpcf7-checkbox .wpcf7-list-item .wpcf7-list-item-label:after {
  content: '';
  display: block;
  width: 1.6rem;
  height: 1.6rem;
  border-radius: 20rem;
  background: rgba(255, 255, 255, 0.3);
  flex-shrink: 0;
  position: absolute;
  left: 1.8rem;
  top: 1.8rem;
  transition: 0.3s;
}
.wpcf7 .wpcf7-checkbox .wpcf7-list-item .wpcf7-list-item-label:hover:after {
  background: #fff;
}
.wpcf7
  .wpcf7-checkbox
  .wpcf7-list-item
  input:checked
  + .wpcf7-list-item-label:before {
  border: 0.2rem solid #fff;
}
.wpcf7
  .wpcf7-checkbox
  .wpcf7-list-item
  input:checked
  + .wpcf7-list-item-label:after {
  background: #fff;
}
.wpcf7 .wpcf7-checkbox .wpcf7-list-item input:checked + .wpcf7-list-item-label {
  background: #fff;
}

.wpcf7 .wpcf7-radio {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  align-items: flex-start;
  width: 100%;
}
.wpcf7 .wpcf7-radio.vertical {
  flex-direction: column;
  align-items: flex-start;
  gap: 0.6rem;
}
.wpcf7 .wpcf7-radio .wpcf7-list-item {
}
.wpcf7 .wpcf7-radio .wpcf7-list-item label {
}
.wpcf7 .wpcf7-radio .wpcf7-list-item input {
  display: none;
}
.wpcf7 .wpcf7-radio .wpcf7-list-item .wpcf7-list-item-label {
  display: flex;
  align-items: center;
  height: 5.2rem;
  padding: 0 2.4rem;
  border-radius: 20rem;
  cursor: pointer;
  transition: 0.2s;
  font-size: 1.8rem;
  font-weight: 400;
  background-color: rgba(255, 255, 255, 0.1);
  transition: 0.3s;
  color: #fff;
}
.wpcf7 .wpcf7-radio .wpcf7-list-item input:checked + .wpcf7-list-item-label {
  background: #fff;
  color: var(--color-text);
}

.wpcf7 .wpcf7-acceptance {
  display: flex;
  gap: 1.2rem;
  flex-direction: column;
  width: 100%;
}
.wpcf7 .wpcf7-acceptance .wpcf7-list-item {
}
.wpcf7 .wpcf7-acceptance .wpcf7-list-item label {
}
.wpcf7 .wpcf7-acceptance .wpcf7-list-item input {
  display: none;
}
.wpcf7 .wpcf7-acceptance .wpcf7-list-item .wpcf7-list-item-label {
  line-height: 1.3;
  font-size: 1.4rem;
  position: relative;
  padding-left: 4rem;
  padding-top: 0.3rem;
  cursor: pointer;
  display: block;
  transition: 0.3s;
  color: #fff;
}
.wpcf7 .wpcf7-acceptance .wpcf7-list-item .wpcf7-list-item-label a {
  color: var(--color-bg);
  text-decoration: underline;
}
.wpcf7 .wpcf7-acceptance .wpcf7-list-item .wpcf7-list-item-label:before {
  content: '';
  display: block;
  width: 2.2rem;
  height: 2.2rem;
  border-radius: 20rem;
  border: 0.2rem solid rgba(255, 255, 255, 0.3);
  flex-shrink: 0;
  position: absolute;
  left: 0;
  top: 0;
  transition: 0.2s;
}
.wpcf7 .wpcf7-acceptance .wpcf7-list-item .wpcf7-list-item-label:hover:before {
  border: 0.2rem solid #fff;
}
.wpcf7 .wpcf7-acceptance .wpcf7-list-item .wpcf7-list-item-label:after {
  content: '';
  display: block;
  width: 1.6rem;
  height: 1.6rem;
  border-radius: 20rem;
  background: rgba(255, 255, 255, 0.3);
  flex-shrink: 0;
  position: absolute;
  left: 0.5rem;
  top: 0.5rem;
  transition: 0.2s;
}
.wpcf7 .wpcf7-acceptance .wpcf7-list-item .wpcf7-list-item-label:hover:after {
  background: #fff;
}
.wpcf7
  .wpcf7-acceptance
  .wpcf7-list-item
  input:checked
  + .wpcf7-list-item-label:before {
  border: 0.2rem solid #fff;
}
.wpcf7
  .wpcf7-acceptance
  .wpcf7-list-item
  input:checked
  + .wpcf7-list-item-label:after {
  background: #fff;
}

.wpcf7 .wpcf7-not-valid-tip {
  color: rgba(0, 0, 0, 0.8);
  line-height: 1.2;
  font-size: 1.4rem;
  margin-top: 0.4rem;
  background-color: #ff6c6c;
  border-radius: 1.2rem;
  display: flex;
  height: 2.4rem;
  padding: 0 1.2rem;
  align-items: center;
  align-self: flex-start;
}
.wpcf7 .wpcf7-response-output {
  border-radius: 2.4rem;
  padding: 3.6rem 6rem;
  color: #fff;
  line-height: 1.3;
  display: flex;
  width: 100%;
  gap: 2.4rem;
  align-items: center;
  display: none;

  position: fixed;
  width: min(80rem, 90%);
  left: 50%;
  margin-left: -40rem;
  bottom: 1.2rem;
  z-index: 500;
}
.wpcf7 .wpcf7-form.invalid .wpcf7-response-output,
.wpcf7 .wpcf7-form.unaccepted .wpcf7-response-output {
  display: flex;
  background-color: #ff6c6c;
}
.wpcf7 .wpcf7-form.sent .wpcf7-response-output {
  display: flex;
  background-color: #16a881;
}
