/*######################################################################

		Contact

************************************************************************/

.contact-contents {
  margin-bottom: 40px;
}

.contact-form {
  display: grid;
  gap: 24px;
  width: min(800px, 100%);
}

.contact-form[aria-busy="true"] {
  cursor: progress;
}

.contact-form__bot-field {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.contact-form__group {
  display: grid;
  gap: 8px;
}

.contact-form__conditional[hidden] {
  display: none;
}

.contact-form__label {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  font-size: var(--font-size-16);
  font-weight: 600;
  line-height: 1.6;
}

.contact-form__label-required,
.contact-form__label-optional {
  color: #5b5b57;
  font-size: var(--font-size-14);
  font-weight: 400;
}

.contact-form__input,
.contact-form__select,
.contact-form__textarea {
  width: 100%;
  padding: 14px 16px;
  border: none;
  border-radius: 8px;
  background-color: #f8f8f8;
  color: #111;
  font-size: var(--font-size-16);
  line-height: 1.6;
  outline: none;
  appearance: none;
  -webkit-appearance: none;
  transition: border-color .2s ease;
}

.contact-form__input:focus,
.contact-form__select:focus,
.contact-form__textarea:focus {
  border-color: #1D6BBF;
}

.contact-form__textarea {
  min-height: 192px;
  resize: vertical;
}

.contact-form__select-wrap {
  position: relative;
}

.contact-form__select-wrap::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 18px;
  width: 10px;
  height: 10px;
  border-right: 1.5px solid #5b5b57;
  border-bottom: 1.5px solid #5b5b57;
  transform: translateY(-65%) rotate(45deg);
  pointer-events: none;
}

.contact-form__hint {
  color: #5b5b57;
  font-size: var(--font-size-14);
  line-height: 1.7;
}

.contact-form__turnstile {
  display: flex;
  justify-content: flex-start;
}

.contact-form__status {
  color: #111;
  font-size: var(--font-size-14);
  font-weight: 600;
  line-height: 1.7;
}

.contact-form__status[hidden] {
  display: none;
}

.contact-form__status--success {
  color: #0f7a43;
}

.contact-form__status--error {
  color: #b42318;
}

.contact-form__submit {
  justify-self: start;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 16px 32px;
  color: #fff;
  font-size: var(--font-size-18);
  font-weight: 700;
  line-height: 1.4;
  background-color: #1D6BBF;
  border: none;
  border-radius: 8px;
  transition: background-color .3s;
}

.contact-form__submit:hover:not(:disabled) {
  background-color: #2478d4;
}

.contact-form__submit:disabled {
  cursor: not-allowed;
  opacity: .65;
}

@media not all and (min-width: 768px){
  .contact-form {
    gap: 20px;
  }
}

@media not all and (min-width: 468px){
  .contact-form {
    gap: 16px;
  }

  .contact-form__label,
  .contact-form__input,
  .contact-form__select,
  .contact-form__textarea {
    font-size: var(--font-size-14);
  }

  .contact-form__submit {
    justify-self: stretch;
    width: 100%;
    min-width: 0;
    padding: 16px 24px;
    font-size: var(--font-size-14);
  }
}
