/**
 * @file
 * Visual styles for form components.
 */

form .field-multiple-table {
  margin: 0;
}

form .field-multiple-table .field-multiple-drag {
  width: 30px;
  padding-right: 0; /* LTR */
}

form .field-multiple-table .field-multiple-drag .tabledrag-handle {
  padding-right: 0.5em; /* LTR */
}

form .field-add-more-submit {
  margin: 0.5em 0 0;
}

/**
 * Markup generated by Form API.
 */
.form-item,
.form-actions {
  margin-top: 2rem;
  margin-bottom: 2rem;
}

.fieldset-legend {
  font-size: 24px;
  font-weight: 700;
}

fieldset.form-wrapper {
  border: 1px solid var(--color-gray-200);
  border-radius: 8px;
  padding: 16px 32px;
  transition: box-shadow 0.5s;

  &:hover {
    box-shadow: 0px 0px 20px -10px rgba(0, 0, 0, 0.25);
  }

  @media (min-width: 768px) {
    padding: 16px 48px;
  }
}

tr.odd .form-item,
tr.even .form-item {
  margin-top: 0;
  margin-bottom: 0;
}

.form-composite > .fieldset-wrapper > .description,
.form-item .description {
  font-size: 0.85em;
}

label.option {
  display: inline;
  font-weight: normal;
}

.form-composite > legend,
.label {
  display: inline;
  margin: 0;
  padding: 0;
  font-size: inherit;
  font-weight: bold;
}

.form-checkboxes .form-item,
.form-radios .form-item {
  margin-top: 0.4em;
  margin-bottom: 0.4em;
}

.form-type-radio .description,
.form-type-checkbox .description {
  margin-left: 2.4em; /* LTR */
}

.marker {
  color: #e00;
}

.form-required::after {
  display: inline-block;
  width: 7px;
  height: 7px;
  margin: 0 4px;
  content: "";
  vertical-align: super;
  /* Use a background image to prevent screen readers from announcing the text. */
  background-image: url(../../images/icons/required.svg);
  background-repeat: no-repeat;
  background-size: 7px 7px;
}

abbr.tabledrag-changed,
abbr.ajax-changed {
  border-bottom: none;
}
.form-item input.error,
.form-item textarea.error,
.form-item select.error {
  border: 2px solid red;
}

/* Inline error messages. */
.form-item--error-message::before {
  display: inline-block;
  width: 14px;
  height: 14px;
  content: "";
  vertical-align: sub;
  background: url(../../images/icons/error.svg) no-repeat;
  background-size: contain;
}

/* Theme Form styles  */
.form-item input[type="text"],
.form-item input[type="tel"],
.form-item input[type="number"],
.form-item input[type="email"],
.form-item input[type="password"],
.form-item textarea,
.form-item select {
  border: 1px solid var(--color-gray-300);
  padding: 18px 12px;
  border-radius: 8px;

  &:placeholder {
    color: var(--color-gray-600);
  }
}

.form-item input[type="checkbox"] {
  transform: scale(1.5);
}

.form-submit {
  min-width: 120px;
  background-color: var(--color-brand-700);
  color: var(--color-white);
  border: none;
  padding: 16px 24px;
  border-radius: 5px;
  cursor: pointer;
  transition: background-color 0.3s;
  font-size: 16px;

  &:hover {
    background-color: var(--color-brand-900);
  }
}

.form-item label {
  display: block;
  margin-bottom: 6px;
  color: var(--color-gray-600);
}

.form-type-checkbox label {
  display: inline-block;
  margin: 0;
}

.form-item input[type="text"],
.form-item input[type="tel"],
.form-item input[type="number"],
.form-item input[type="email"],
.form-item input[type="password"],
.form-item textarea,
.form-item select {
  width: 100%;

  @media screen and (min-width: 769px) {
    width: 60%;
  }
}

.user-form-page .form-item input[type="text"],
.user-form-page .form-item input[type="tel"],
.user-form-page .form-item input[type="number"],
.user-form-page .form-item input[type="email"],
.user-form-page .form-item input[type="password"],
.user-form-page .form-item textarea {
  width: 100%;
}

.form-item input.error {
  border: solid 1px var(--color--red);
}

/* Form tweaks */

.progress-title {
  font-size: 16px;
}

.progress-marker::after {
  top: 14px;
}

.progress-marker::before {
  width: 32px;
  height: 32px;
}

.webform-type-checkbox {
  display: flex;
}

.webform-type-checkbox .js-form-required {
  font-size: 14px;
  margin-left: 12px;
}
