/**
 * https://davidhellmann.com/blog/development/sass-breakpoint-mixin
 */
.form-group {
  display: flex;
  flex-direction: column;
  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--xl-50, .form-group--xl-25 {
  flex-direction: row;
  flex-wrap: wrap;
  align-items: flex-start;
}
.form-group--xl-50 .form-item, .form-group--xl-25 .form-item {
  width: calc(var(--form-item-w) - var(--bs-gutter-x) * 0.5);
}
.form-group h3 {
  width: 100%;
  margin: 0;
  margin-top: 3rem;
  font-size: 1.15rem;
}
@media (min-width: 1200px) {
  .form-group--xl-50 {
    --form-item-w: 50%;
  }
  .form-group--xl-25 {
    --form-item-w: 25%;
  }
}

.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 > div, .form-group > label {
  position: relative;
  display: flex;
  flex-direction: column;
  padding: var(--form-input-padding);
  background: var(--form-input-background, inherit);
  border-top: #2c2c2c 1px solid;
/*  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;
  font-size: var(--form-label-font-size);
}
.form-item > div input:not(:placeholder-shown) + label, .form-item > div input:focus + label,
.form-item > div textarea:not(:placeholder-shown) + label,
.form-item > div textarea:focus + label {
  top: calc(var(--form-input-pt) * 0.3332);
  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: 1.4rem;
  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);
}
.form-item button {
  position: absolute;
  right: 1rem;
  transform: translateY(5px);
}
.form-item button img {
  width: 1em;
}
.form-item button:hover img {
  filter: invert(75%) sepia(71%) saturate(3904%) hue-rotate(117deg) brightness(103%) contrast(94%);
}
.form-item.has-btn-left button {
  position: absolute;
  left: 0;
}

#contact-form {
  --form-input-background: var(--color-background-alt-4);
}
