/**
 * @file
 * Global form element styles.
 */

/* ==========================================================================
   Form items and actions.
   ========================================================================== */

.form-item {
  margin-top: 0;
  margin-bottom: 1.25rem;
}

.form-actions {
  margin-top: 1.5rem;
  margin-bottom: 1rem;
}

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

/* ==========================================================================
   Labels.
   ========================================================================== */

label {
  display: block;
  font-family: var(--font-base);
  font-size: var(--font-size-small);
  font-weight: 600;
  color: var(--color-heading);
  margin-bottom: 0.35rem;
}

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

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

/* Checkbox and radio labels should be inline. */
.form-type-checkbox label,
.form-type-radio label {
  display: inline;
  font-weight: normal;
  font-size: var(--font-size-small);
  margin-left: 0.35rem;
}

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

/* ==========================================================================
   Text inputs, selects, and textareas.
   ========================================================================== */

input[type="text"],
input[type="password"],
input[type="email"],
input[type="number"],
input[type="tel"],
input[type="url"],
input[type="search"],
input[type="date"],
textarea,
select {
  display: block;
  width: 100%;
  padding: 0.75rem;
  border: var(--border);
  border-radius: 0.25rem;
  font-family: var(--font-base);
  font-size: var(--font-size-medium);
  color: var(--color-text);
  background-color: var(--color-white);
  box-sizing: border-box;
}

input[type="text"]:focus,
input[type="password"]:focus,
input[type="email"]:focus,
input[type="number"]:focus,
input[type="tel"]:focus,
input[type="url"]:focus,
input[type="search"]:focus,
input[type="date"]:focus,
textarea:focus,
select:focus {
  outline: 2px solid var(--color-blue-tq);
  outline-offset: -1px;
  border-color: var(--color-blue-tq);
}

textarea {
  min-height: 6rem;
  resize: vertical;
}

/* ==========================================================================
   Submit buttons.
   ========================================================================== */

input[type="submit"],
button.form-submit {
  display: block;
  width: 100%;
  padding: 0.85rem 1rem;
  background-color: var(--color-blue-dk);
  color: var(--color-white);
  border: none;
  border-radius: 0.5rem;
  font-family: var(--font-base);
  font-size: var(--font-size-medium);
  font-weight: 700;
  cursor: pointer;
  text-align: center;
}

input[type="submit"]:hover,
button.form-submit:hover {
  background-color: var(--color-blue-tq-text);
}

/* ==========================================================================
   Description / help text.
   ========================================================================== */

.form-item .description {
  font-size: var(--font-size-smaller);
  color: var(--color-dark-grey);
  margin-top: 0.35rem;
  line-height: 1.4;
}

.form-item .description a {
  color: var(--color-blue-tq-text);
}

.form-item .description a:hover {
  color: var(--color-blue-dk);
}

.form-composite > .fieldset-wrapper > .description {
  font-size: var(--font-size-smaller);
  color: var(--color-dark-grey);
}

/* ==========================================================================
   Required marker.
   ========================================================================== */

.form-required::after {
  display: inline-block;
  width: 6px;
  height: 6px;
  margin: 0 0.3em;
  content: "";
  vertical-align: super;
  background-image: url(../../images/icons/required.svg);
  background-repeat: no-repeat;
  background-size: 6px 6px;
}

/* ==========================================================================
   Error states.
   ========================================================================== */

.form-item input.error,
.form-item textarea.error,
.form-item select.error {
  border: 2px solid var(--color-red);
}

.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;
}

/* ==========================================================================
   Misc form utilities.
   ========================================================================== */

.marker {
  color: var(--color-red);
}

abbr.tabledrag-changed,
abbr.ajax-changed {
  border-bottom: none;
}

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

[dir="rtl"] .form-type-radio .description,
[dir="rtl"] .form-type-checkbox .description {
  margin-right: 2.4em;
  margin-left: 0;
}

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

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

[dir="rtl"] form .field-multiple-table .field-multiple-drag {
  padding-left: 0;
}

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

[dir="rtl"] form .field-multiple-table .field-multiple-drag .tabledrag-handle {
  padding-right: 0;
  padding-left: 0.5em;
}

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