:root {
  --viewport-width: min(100vw, 1600px);
  --b: calc(var(--viewport-width) / 160);
}

/*
Theme Name: Twenty Twenty-one Child
Version: 1.0
Template: twentytwentyone
*/
#formContact .form__preface {
  margin-bottom: max(10rem, 50px);
}
#formContact .form__preface p {
  font-size: max(1.6rem, 14px);
  font-weight: 400;
  line-height: 2.2;
  letter-spacing: 0.05em;
}
#formContact .form__preface span.attention {
  font-size: max(1.4rem, 12px);
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.05em;
  margin-top: max(1.5rem, 15px);
}
#formContact .form__preface span.attention small {
  display: block;
}
#formContact .form__preface__title {
  display: grid;
  align-items: center;
  gap: max(1.5rem, 10px);
  grid-template-columns: auto 1fr;
  margin-bottom: max(3rem, 20px);
}
#formContact .form__preface__title--icon {
  width: max(2.4rem, 24px);
  height: auto;
  aspect-ratio: 2/1;
  background: #3A9447;
  clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
}
#formContact .form__preface__title--text {
  font-size: max(3rem, 21px);
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.05em;
}
#formContact .form__messages {
  padding: 20px;
  margin-bottom: 30px;
  border-radius: 10px;
}
#formContact .form__messages--error {
  background: #ffe5e5;
  border: 2px solid #ff0000;
}
#formContact .form__progress {
  display: grid;
  align-items: center;
  grid-template-columns: 1fr auto 1fr auto 1fr;
  gap: max(1.5rem, 5px);
  margin-top: max(10rem, 50px);
  margin-bottom: max(9rem, 50px);
}
#formContact .form__progress__arrow {
  flex-shrink: 0;
  width: auto;
  height: max(30%, 8px);
  aspect-ratio: 0.866/1;
  background: #3A9447;
  clip-path: polygon(0 0, 0% 100%, 100% 50%);
}
#formContact .form__progress__item {
  display: grid;
  place-items: center;
  padding: max(3rem, 15px) 5%;
  background: rgba(54, 54, 54, 0.15);
  border-radius: max(0.5rem, 3px);
  overflow: hidden;
}
#formContact .form__progress__item span {
  font-size: max(1.6rem, 14px);
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.05em;
}
#formContact .form__progress__item.active {
  background: rgba(105, 222, 123, 0.15);
}
#formContact .form__progress__item.active span {
  color: #3A9447;
}
#formContact .form__content__section {
  padding: max(13rem, 60px) 10%;
  border-radius: max(1.2rem, 10px);
  border: max(0.1rem, 1px) solid #3A9447;
  background: rgba(105, 222, 123, 0.15);
  box-shadow: 0 0 26px rgba(0, 0, 0, 0.15);
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  #formContact .form__content__section {
    padding: max(13rem, 60px) 5%;
  }
}
#formContact .form__content__section__body {
  display: grid;
  grid-template-columns: auto 1fr;
  margin-bottom: max(6rem, 30px);
}
#formContact .form__content__section__privacy {
  text-align: center;
}
#formContact .form__content__section__privacy__consent input[type=checkbox] {
  position: relative;
  width: 1.75em;
  height: 1.75em;
  background: #fff;
  appearance: none;
  margin-right: 10px;
  cursor: pointer;
}
#formContact .form__content__section__privacy__consent input[type=checkbox]::before {
  content: "";
  position: absolute;
  inset: 0;
  top: 50%;
  left: 50%;
  width: 60%;
  height: 60%;
  background: #1a5f26;
  border-radius: 2px;
  transform: translate(-50%, -50%) scale(0);
  transition: transform 0.2s;
}
#formContact .form__content__section__privacy__consent input[type=checkbox]:checked::before {
  transform: translate(-50%, -50%) scale(1);
}
#formContact .form__content__section__privacy__consent span {
  display: inline-block;
  font-size: max(1.6rem, 14px);
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.05em;
}
#formContact .form__content__section__privacy a {
  display: inline-block;
  margin-top: max(3.5rem, 30px);
  border-bottom: max(0.1rem, 1px) solid #000;
  font-size: max(1.4rem, 12px);
  font-weight: 500;
  line-height: 1.1;
  letter-spacing: 0.05em;
}
#formContact .form__group {
  display: grid;
  grid-template-columns: subgrid;
  grid-column: span 2;
  column-gap: 30px;
}
@media (max-width: 768px) {
  #formContact .form__group {
    grid-template-columns: 1fr;
    row-gap: 10px;
  }
}
#formContact .form__group:not(:last-of-type) {
  margin-bottom: max(2.5rem, 20px);
}
#formContact .form__label {
  font-size: max(1.6rem, 14px);
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.05em;
}
#formContact .form__label--required {
  color: #3A9447;
}
#formContact .form__field.grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: max(1rem, 5px);
}
#formContact .form__field.grid input {
  width: 100%;
}
#formContact .form__field__inner {
  position: relative;
}
#formContact .form__field__label {
  display: block;
  font-size: clamp(13px, 1.6rem, 16px);
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.05em;
  margin-bottom: clamp(10px, 1rem, 12px);
}
#formContact .form__field input[type=text],
#formContact .form__field input[type=email],
#formContact .form__field select,
#formContact .form__field textarea {
  width: 100%;
  background: #fff;
  padding: max(2rem, 10px) 2.5%;
  font-size: max(1.6rem, 14px);
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.05em;
  transition: all 0.1s;
}
#formContact .form__field input[type=text]::placeholder,
#formContact .form__field input[type=email]::placeholder,
#formContact .form__field select::placeholder,
#formContact .form__field textarea::placeholder {
  color: rgba(0, 0, 0, 0.3);
  font-size: max(1.6rem, 14px);
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.05em;
}
#formContact .form__field input[type=text]:focus,
#formContact .form__field input[type=email]:focus,
#formContact .form__field select:focus,
#formContact .form__field textarea:focus {
  outline: 2px solid #3A9447;
  background: #fff;
}
#formContact .form__field textarea {
  min-height: 150px;
  resize: vertical;
}
#formContact .form__field .select__outer {
  position: relative;
}
#formContact .form__field .select__outer::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 5%;
  transform: translateY(-75%) rotate(45deg);
  width: clamp(10px, 1.2rem, 12px);
  height: clamp(10px, 1.2rem, 12px);
  border-right: 2px solid #1a5f26;
  border-bottom: 2px solid #1a5f26;
  pointer-events: none;
}
#formContact .form__field .select__outer select {
  appearance: none;
  padding-right: 40px;
}
#formContact .form__error {
  color: #ff0000;
  width: 100%;
  font-size: max(1.4rem, 12px);
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.05em;
  margin-top: 8px;
}
#formContact .form__actions {
  display: grid;
  margin-top: max(9.5rem, 50px);
}
#formContact .form__actions .viewmore {
  margin: 0 auto;
}
#formContact .form__actions .form__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: clamp(18px, 2.5rem, 25px) clamp(80px, 12rem, 120px);
  margin: 0 auto;
  border-radius: 50px;
  font-size: clamp(16px, 2rem, 20px);
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.1em;
  box-shadow: 6px 6px 0 rgba(26, 95, 38, 0.2);
  transition: transform 0.3s, box-shadow 0.3s;
  cursor: pointer;
  border: none;
}
@media (max-width: 768px) {
  #formContact .form__actions .form__button {
    width: 100%;
    max-width: 400px;
  }
}
#formContact .form__actions .form__button--primary {
  color: #fff;
  background: #1a5f26;
}
#formContact .form__actions .form__button--secondary {
  color: #1a5f26;
  background: #f5f9f6;
}
#formContact .form__actions .form__button:hover {
  transform: translate(6px, 6px);
  box-shadow: 0px 0px rgba(26, 95, 38, 0.2);
}
#formContact .form__actions__recaptcha {
  display: flex;
  justify-content: center;
  margin-top: max(6rem, 30px);
}
#formContact .form__wrapper {
  margin-bottom: max(18rem, 100px);
}
#formContact .form__wrapper--confirm .form__content__section__body {
  row-gap: max(4rem, 30px);
}
#formContact .form__wrapper--confirm .form__confirm__list {
  display: grid;
  grid-template-columns: subgrid;
  grid-column: span 2;
  column-gap: max(7rem, 30px);
}
@media (max-width: 768px) {
  #formContact .form__wrapper--confirm .form__confirm__list {
    grid-template-columns: 1fr;
    row-gap: 10px;
  }
}
#formContact .form__wrapper--confirm .form__confirm__list dt,
#formContact .form__wrapper--confirm .form__confirm__list dd {
  font-size: max(1.6rem, 14px);
  font-weight: 500;
  line-height: 2;
  letter-spacing: 0.05em;
}
#formContact .form__wrapper--confirm .form__actions {
  grid-template-columns: 1fr 1fr;
  width: max(80%, 600px);
  gap: 20px;
  margin: max(10rem, 50px) auto;
}
@media screen and (max-width: 768px) {
  #formContact .form__wrapper--confirm .form__actions {
    width: 100%;
  }
}
#formContact .form__wrapper--confirm .form__actions .viewmore--secondary {
  background: rgba(54, 54, 54, 0.3);
}
#formContact .form__wrapper--confirm .form__actions .viewmore--secondary::before {
  display: none;
}
#formContact .form__wrapper--confirm .form__actions .viewmore--secondary:hover * {
  color: #fff !important;
}
#formContact .form__wrapper--confirm .form__actions .viewmore--secondary:hover * .rhombus {
  background-color: #fff !important;
  clip-path: polygon(80% 0, 80% 50%, 80% 100%, 0 50%);
}
#formContact .form__wrapper--complete {
  text-align: left;
}