:root {
  --form-group-gap: 1.275rem;
  --form-item-w: 100%;
  --form-input-group-col-w: 100%;
  --form-input-pt: var(--number-space-2);
  --form-input-pe: var(--number-space-3);
  --form-input-pb: var(--number-space-2);
  --form-input-ps: var(--number-space-3);
  --form-input-padding: calc(var(--form-input-pt) + 1.25rem) var(--form-input-pe) var(--form-input-pb) var(--form-input-ps);
  --form-checkbox-dimensions: 22px;
  --form-checkbox-group-col-w: 33%;
  --form-radio-group-col-w: 50%;
  --form-input-background: var(--color-background-alt-4);
  --form-label-font-size: var(--font-size-default);
  --form-label-active-font-size: var(--font-size-extra-small);
  --form-label-checked-color: var(--color-secondary);
  --form-input-label-color: var(--color-on-background-flexible);
  --form-input-checked-color: var(--color-secondary);
  --form-input-border-color: var(--color-gray-medium);
  --form-input-border-bottom-color: var(--form-input-border-color);
  --form-placeholder-color: var(--form-input-label-color);
  --form-input-color: var(--color-on-background);
}

.form-group {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--form-group-gap) var(--bs-gutter-x);
}
.form-group.no-gap {
  gap: unset;
}
.form-group.no-gap h3 {
  margin-bottom: 0.25rem;
}
.form-group--lg-50, .form-group--lg-25, .form-group--xl-50, .form-group--xl-25 {
  align-items: flex-start;
  grid-template-columns: repeat(1, 1fr);
}
.form-group h3 {
  width: 100%;
  margin: 0;
  margin-top: 3rem;
  font-size: 1.15rem;
}
@media (min-width: 992px) {
  .form-group--lg-50 {
    grid-template-columns: repeat(2, 1fr);
  }
  .form-group--lg-25 {
    grid-template-columns: repeat(4, 1fr);
  }
}
@media (min-width: 1200px) {
  .form-group--xl-50 {
    grid-template-columns: repeat(2, 1fr);
  }
  .form-group--xl-25 {
    grid-template-columns: repeat(4, 1fr);
  }
}

.checkbox-group,
.radio-group {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(var(--form-input-group-col-w), 1fr));
  gap: 0.5rem 0;
  width: 100%;
  /* Center text on input */
}
.checkbox-group .form-item div,
.radio-group .form-item div {
  align-items: center;
}

.checkbox-group {
  --form-input-group-col-w: var(--form-checkbox-group-col-w);
}
@media (min-width: 768px) {
  .checkbox-group--md-25 {
    --form-checkbox-group-col-w: 25%;
  }
}

.radio-group {
  --form-input-group-col-w: var(--form-radio-group-col-w);
}
@media (min-width: 1200px) {
  .radio-group--md-25 {
    --form-radio-group-col-w: 25%;
  }
}

.form-item {
  position: relative;
  display: flex;
  flex-direction: column;
  place-content: center;
  gap: 0.5rem;
}
.form-item--headline {
  grid-column: 1/-1; /* Span from first to last column line */
}
.form-item > div {
  position: relative;
  display: flex;
  flex-direction: column;
  padding: var(--form-input-padding);
  background: var(--form-input-background, inherit);
  border-bottom: 1px solid var(--form-input-border-bottom-color);
}
.form-item > div.no-padding {
  padding: unset;
}
.form-item > div.has-checkbox, .form-item > div.has-radio {
  flex-direction: row;
  gap: 0.75rem;
  background: transparent;
}
.form-item > div.has-checkbox.group-reversed, .form-item > div.has-radio.group-reversed {
  flex-direction: row-reverse;
  justify-content: flex-end;
}
.form-item > div.has-checkbox input, .form-item > div.has-radio input {
  position: relative;
  flex: 1 0 auto;
  width: var(--form-checkbox-dimensions);
  height: var(--form-checkbox-dimensions);
  background: var(--color-background-alt-4);
  cursor: pointer;
}
.form-item > div.has-checkbox input[type=checkbox], .form-item > div.has-checkbox input[type=radio], .form-item > div.has-radio input[type=checkbox], .form-item > div.has-radio input[type=radio] {
  border: 1px solid var(--form-input-border-color);
}
.form-item > div.has-checkbox input[type=checkbox]::before, .form-item > div.has-checkbox input[type=radio]::before, .form-item > div.has-radio input[type=checkbox]::before, .form-item > div.has-radio input[type=radio]::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate3d(-50%, -50%, 0);
  display: block;
  width: 16px;
  height: 16px;
  transition: var(--transition-fast) all;
}
.form-item > div.has-checkbox input[type=checkbox]:checked::before, .form-item > div.has-checkbox input[type=radio]:checked::before, .form-item > div.has-radio input[type=checkbox]:checked::before, .form-item > div.has-radio input[type=radio]:checked::before {
  background: var(--form-input-checked-color);
}
.form-item > div.has-checkbox input[type=checkbox]:checked + label, .form-item > div.has-checkbox input[type=radio]:checked + label, .form-item > div.has-radio input[type=checkbox]:checked + label, .form-item > div.has-radio input[type=radio]:checked + label {
  color: var(--form-label-checked-color);
}
.form-item > div.has-checkbox label, .form-item > div.has-radio label {
  top: unset !important;
  pointer-events: auto;
  cursor: pointer;
  position: relative;
  color: var(--color-on-background);
  top: 0;
  left: 0;
  font-size: 12px;
  font-family: var(--font-text-regular) !important;
}
.form-item > div.has-checkbox label:hover, .form-item > div.has-radio label:hover {
  color: var(--form-input-checked-color);
}
.form-item > div.has-checkbox label img, .form-item > div.has-radio label img {
  max-width: 2rem;
  max-height: 2rem;
}
.form-item > div.has-radio input[type=radio] {
  border-radius: 50%;
}
.form-item > div.has-radio input[type=radio]::before {
  border-radius: 50%;
}
.form-item > div input,
.form-item > div textarea {
  width: 100%;
  background: transparent;
  border: none;
  color: var(--form-input-color);
}
.form-item > div input::placeholder,
.form-item > div textarea::placeholder {
  color: var(--form-placeholder-color);
}
.form-item > div input[placeholder]:not([placeholder=""]) ~ label, .form-item > div input:not(:placeholder-shown) ~ label, .form-item > div input:focus ~ label,
.form-item > div textarea[placeholder]:not([placeholder=""]) ~ label,
.form-item > div textarea:not(:placeholder-shown) ~ label,
.form-item > div textarea:focus ~ label {
  top: calc(var(--form-input-pt) + 0.25em);
  font-size: var(--form-label-active-font-size);
  font-family: var(--font-text-bold);
}
.form-item > div input:required ~ label:after,
.form-item > div textarea:required ~ label:after {
  content: "*";
}
.form-item > div label {
  pointer-events: none;
  cursor: text;
  position: absolute;
  top: calc(var(--form-input-pt) + 0.9rem);
  left: var(--form-input-ps);
  margin-bottom: 0;
  font-family: var(--font-text-regular);
  color: var(--form-input-label-color);
  transition: var(--transition-fast) all 0s;
}
.form-item label {
  font-size: var(--form-label-font-size);
}

#contact-form {
  --form-input-background: var(--color-background-alt-4);
}
