/* ===== 43. GRAVITY FORMS ===== */

/* --- Wrapper & Reset --- */
.gform_wrapper {
  max-width: 100%;
  padding: var(--space-8) 0;
}
.gform_wrapper *,
.gform_wrapper *::before,
.gform_wrapper *::after {
  box-sizing: border-box;
}
/* Reset fieldset/legend (GF wraps compound fields like Name/Address in <fieldset>) */
.gform_wrapper fieldset {
  border: 0;
  margin: 0;
  padding: 0;
  min-width: 0;
}
.gform_wrapper legend {
  padding: 0;
  margin: 0;
  display: block;
  width: 100%;
}

/* --- Field list reset --- */
.gform_wrapper .gform_fields {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-6) var(--space-8);
}
.gform_wrapper .gform_fields .gfield {
  grid-column: span 2;
  margin: 0;
  padding: 0;
}
.gform_wrapper .gform_fields .gfield--width-half {
  grid-column: span 1;
}

/* --- Labels --- */
.gform_wrapper .gfield_label {
  display: block;
  font-family: var(--font-subheading);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-charcoal);
  margin-bottom: var(--space-2);
}

/* --- Required asterisk --- */
.gform_wrapper .gfield_required {
  color: var(--color-bronze);
  font-weight: 400;
  margin-left: 2px;
}

/* --- Text inputs (scoped broadly to catch sub-inputs in compound fields) --- */
.gform_wrapper input[type="text"],
.gform_wrapper input[type="email"],
.gform_wrapper input[type="tel"],
.gform_wrapper input[type="url"],
.gform_wrapper input[type="number"],
.gform_wrapper input[type="password"],
.gform_wrapper input[type="date"],
.gform_wrapper input[type="time"],
.gform_wrapper input[type="datetime-local"],
.gform_wrapper input[type="search"],
.gform_wrapper textarea {
  width: 100%;
  font-family: var(--font-body);
  font-size: var(--text-base);
  padding: var(--space-3) 0;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--color-grey-400);
  border-radius: 0;
  color: var(--color-charcoal);
  transition: border-color 200ms ease-out;
  outline: none;
  -webkit-appearance: none;
}
.gform_wrapper input[type="text"]:focus,
.gform_wrapper input[type="email"]:focus,
.gform_wrapper input[type="tel"]:focus,
.gform_wrapper input[type="url"]:focus,
.gform_wrapper input[type="number"]:focus,
.gform_wrapper input[type="password"]:focus,
.gform_wrapper input[type="date"]:focus,
.gform_wrapper input[type="time"]:focus,
.gform_wrapper input[type="datetime-local"]:focus,
.gform_wrapper input[type="search"]:focus,
.gform_wrapper textarea:focus {
  border-bottom-color: var(--color-bronze);
}
.gform_wrapper input::placeholder,
.gform_wrapper textarea::placeholder {
  color: var(--color-grey-400);
}

/* --- Textareas — honour GF's `rows` attribute (small/medium/large field
   sizes set rows automatically). No min-height override; tighten line-height
   so 5 rows looks like 5 lines of text rather than 5 paragraphs. --- */
.gform_wrapper textarea {
  resize: vertical;
  line-height: 1.5;
  padding: var(--space-3) 0;
}

/* --- Suppress browser autofill yellow/blue --- */
.gform_wrapper input:-webkit-autofill,
.gform_wrapper input:-webkit-autofill:hover,
.gform_wrapper input:-webkit-autofill:focus,
.gform_wrapper textarea:-webkit-autofill {
  -webkit-text-fill-color: var(--color-charcoal);
  -webkit-box-shadow: 0 0 0 1000px transparent inset;
  box-shadow: 0 0 0 1000px transparent inset;
  transition: background-color 9999s ease-in-out 0s;
}

/* --- Compound fields: Name, Address (2-column on desktop, stack on mobile) --- */
.gform_wrapper .ginput_complex {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4) var(--space-6);
}
.gform_wrapper .ginput_complex > span {
  display: block;
  min-width: 0;
}
/* Name field: hide sub-labels (placeholders cover them) */
.gform_wrapper .ginput_container_name > span > label {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0;
}
/* Address field: show sub-labels as small helper text under each input */
.gform_wrapper .ginput_container_address > span > label {
  display: block;
  font-family: var(--font-body-alt);
  font-size: var(--text-xs);
  color: var(--color-grey-600);
  margin-top: var(--space-1);
}
/* Address: street fields full width */
.gform_wrapper .ginput_container_address .address_line_1,
.gform_wrapper .ginput_container_address .address_line_2 {
  grid-column: 1 / -1;
}

/* --- Selects --- */
.gform_wrapper .ginput_container select {
  width: 100%;
  font-family: var(--font-body);
  font-size: var(--text-base);
  padding: var(--space-3) 0;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--color-grey-400);
  border-radius: 0;
  color: var(--color-charcoal);
  cursor: pointer;
  outline: none;
  transition: border-color 200ms ease-out;
  -webkit-appearance: none;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='%23333' stroke-width='1.5'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right center;
}
.gform_wrapper .ginput_container select:focus {
  border-bottom-color: var(--color-bronze);
}

/* --- Field descriptions / help text --- */
.gform_wrapper .gfield_description {
  font-family: var(--font-body-alt);
  font-size: var(--text-sm);
  color: var(--color-grey-600);
  margin-top: var(--space-1);
}

/* --- Checkboxes & Radios --- */
.gform_wrapper .gchoice {
  display: flex;
  align-items: flex-start;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
}
.gform_wrapper .gchoice input[type="checkbox"],
.gform_wrapper .gchoice input[type="radio"] {
  width: 18px;
  height: 18px;
  margin: 2px 0 0;
  accent-color: var(--color-bronze);
  cursor: pointer;
  flex-shrink: 0;
}
.gform_wrapper .gchoice label {
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--color-charcoal);
  cursor: pointer;
  line-height: 1.5;
}

/* --- Consent (GDPR) --- */
.gform_wrapper .gfield--type-consent .gfield_consent_label {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--color-grey-600);
  line-height: 1.6;
}
.gform_wrapper .gfield--type-consent input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--color-bronze);
  cursor: pointer;
}

/* --- Validation: per-field --- */
.gform_wrapper .gfield_validation_message {
  font-family: var(--font-body-alt);
  font-size: var(--text-xs);
  color: var(--color-error);
  margin-top: var(--space-1);
  letter-spacing: 0.02em;
}
.gform_wrapper .gfield.gfield_error .ginput_container input,
.gform_wrapper .gfield.gfield_error .ginput_container textarea,
.gform_wrapper .gfield.gfield_error .ginput_container select {
  border-color: var(--color-error);
}
.gform_wrapper .gfield.gfield_error .gfield_label {
  color: var(--color-charcoal);
}

/* --- Validation: form-level --- */
.gform_wrapper .validation_error {
  font-family: var(--font-body-alt);
  font-size: var(--text-sm);
  color: var(--color-error);
  background: rgba(160, 64, 64, 0.06);
  border: 1px solid rgba(160, 64, 64, 0.2);
  padding: var(--space-4);
  margin-bottom: var(--space-6);
}

/* --- Success / confirmation --- */
.gform_wrapper .gform_confirmation_message {
  font-family: var(--font-body);
  font-size: var(--text-lg);
  color: var(--color-success);
  background: rgba(90, 122, 90, 0.06);
  border: 1px solid rgba(90, 122, 90, 0.2);
  padding: var(--space-6);
  text-align: center;
}

/* --- Submit button --- */
.gform_wrapper .gform_footer {
  margin-top: var(--space-8);
  padding: 0;
}
.gform_wrapper .gform_button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 16px 40px;
  font-family: var(--font-subheading);
  font-size: 0.875rem;
  font-weight: 500;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  line-height: 1.4;
  border: 2px solid var(--color-charcoal);
  border-radius: var(--btn-radius);
  cursor: pointer;
  text-decoration: none;
  transition: all 300ms var(--ease-out-expo);
  background: var(--color-charcoal);
  color: var(--color-offwhite);
}
.gform_wrapper .gform_button:hover {
  background: var(--color-charcoal-dark);
  border-color: var(--color-charcoal-dark);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
}

/* --- Multi-step progress bar --- */
.gform_wrapper .gf_progressbar {
  margin-bottom: var(--space-8);
}
.gform_wrapper .gf_progressbar_percentage {
  background: var(--color-bronze);
  height: 4px;
  transition: width 400ms ease-out;
}
.gform_wrapper .gf_progressbar_wrapper {
  background: var(--color-grey-300);
  height: 4px;
  overflow: hidden;
}
.gform_wrapper .gf_step {
  font-family: var(--font-subheading);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-grey-500);
}
.gform_wrapper .gf_step_active {
  color: var(--color-bronze);
  font-weight: 600;
}
.gform_wrapper .gf_step_completed {
  color: var(--color-charcoal);
}

/* --- File upload --- */
.gform_wrapper .ginput_container_fileupload input[type="file"] {
  display: block;
  width: 100%;
  font-family: var(--font-body-alt);
  font-size: var(--text-sm);
  color: var(--color-grey-600);
  padding: var(--space-3) 0;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--color-grey-400);
  border-radius: 0;
  cursor: pointer;
}
.gform_wrapper .ginput_container_fileupload input[type="file"]::file-selector-button {
  display: inline-block;
  padding: var(--space-2) var(--space-4);
  margin-right: var(--space-4);
  font-family: var(--font-subheading);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-charcoal);
  background: transparent;
  border: 1px solid var(--color-charcoal);
  border-radius: var(--btn-radius);
  cursor: pointer;
  transition: all 200ms ease-out;
}
.gform_wrapper .ginput_container_fileupload input[type="file"]::file-selector-button:hover {
  background: var(--color-charcoal);
  color: var(--color-offwhite);
}
.gform_wrapper .ginput_container_multifileupload .gform_drop_area {
  padding: var(--space-8);
  border: 1px dashed var(--color-grey-400);
  text-align: center;
  font-family: var(--font-body-alt);
  font-size: var(--text-sm);
  color: var(--color-grey-600);
  transition: border-color 200ms ease-out, background 200ms ease-out;
}
.gform_wrapper .ginput_container_multifileupload .gform_drop_area.gform_drop_area_hover {
  border-color: var(--color-bronze);
  background: rgba(175, 152, 123, 0.04);
}

/* --- Section break --- */
.gform_wrapper .gsection {
  grid-column: 1 / -1;
  border: 0;
  border-top: 1px solid var(--color-grey-300);
  margin: var(--space-6) 0 var(--space-2);
  padding: var(--space-6) 0 0;
}
.gform_wrapper .gsection .gsection_title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 500;
  letter-spacing: 0.02em;
  margin: 0 0 var(--space-2);
  color: var(--color-charcoal);
}
.gform_wrapper .gsection .gsection_description {
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--color-grey-700, #555);
  margin: 0;
}

/* --- HTML field --- */
.gform_wrapper .gfield--type-html {
  grid-column: 1 / -1;
}
.gform_wrapper .gfield--type-html p:last-child {
  margin-bottom: 0;
}

/* --- List field --- */
.gform_wrapper .gfield_list {
  width: 100%;
  border-collapse: collapse;
}
.gform_wrapper .gfield_list th {
  font-family: var(--font-subheading);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-align: left;
  padding: var(--space-2) var(--space-2) var(--space-2) 0;
  color: var(--color-charcoal);
}
.gform_wrapper .gfield_list td {
  padding: var(--space-1) var(--space-2) var(--space-1) 0;
  vertical-align: middle;
}
.gform_wrapper .gfield_list .gfield_list_icons button {
  background: transparent;
  border: none;
  color: var(--color-grey-600);
  cursor: pointer;
  padding: 4px 6px;
}
.gform_wrapper .gfield_list .gfield_list_icons button:hover {
  color: var(--color-bronze);
}

/* --- Date picker (jQuery UI parity) --- */
.gform_wrapper .ginput_container_date {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.gform_wrapper .ginput_container_date img.ui-datepicker-trigger {
  width: 20px;
  height: 20px;
  cursor: pointer;
  opacity: 0.6;
  transition: opacity 200ms ease-out;
}
.gform_wrapper .ginput_container_date img.ui-datepicker-trigger:hover {
  opacity: 1;
}

/* --- Legacy wrapper parity --- */
.gform_legacy_markup_wrapper .gform_fields {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-6);
}
.gform_legacy_markup_wrapper .gfield {
  width: 100%;
}

/* --- Responsive: stack on mobile --- */
@media (max-width: 768px) {
  .gform_wrapper .gform_fields {
    grid-template-columns: 1fr;
  }
  .gform_wrapper .gform_fields .gfield--width-half {
    grid-column: span 1;
  }
  .gform_wrapper .ginput_complex {
    grid-template-columns: 1fr;
  }
  .gform_wrapper .gform_button {
    width: 100%;
  }
}

/* ==========================================================================
   Choices.js — branded select dropdowns inside Gravity Forms
   Overrides choices.min.css to match the underlined-input aesthetic.
   ========================================================================== */

.gform_wrapper .choices {
  margin-bottom: 0;
}

/* Closed control — match other inputs (transparent, bottom border only) */
.gform_wrapper .choices__inner {
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--color-grey-400);
  border-radius: 0;
  padding: var(--space-3) 0;
  min-height: 0;
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--color-charcoal);
  transition: border-color 200ms ease-out;
}
.gform_wrapper .choices.is-focused .choices__inner,
.gform_wrapper .choices.is-open .choices__inner {
  border-bottom-color: var(--color-bronze);
}

/* Custom chevron — replace Choices' triangle with our SVG arrow */
.gform_wrapper .choices[data-type*="select-one"]::after {
  content: "";
  border: none;
  width: 12px;
  height: 8px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='%23333' stroke-width='1.5'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  margin-top: -4px;
  right: 0;
  pointer-events: none;
  transition: transform 200ms ease-out;
}
.gform_wrapper .choices[data-type*="select-one"].is-open::after {
  transform: rotate(180deg);
  margin-top: -4px;
}

/* Selected item text */
.gform_wrapper .choices__list--single .choices__item {
  padding: 0;
}
.gform_wrapper .choices__placeholder {
  opacity: 0.6;
}

/* Dropdown popup */
.gform_wrapper .choices__list--dropdown,
.gform_wrapper .choices__list[aria-expanded] {
  background: #fff;
  border: 1px solid var(--color-grey-300);
  border-radius: 0;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
  margin-top: 4px;
  word-break: normal;
}
.gform_wrapper .choices__list--dropdown .choices__list,
.gform_wrapper .choices__list[aria-expanded] .choices__list {
  max-height: 320px;
}
.gform_wrapper .choices__list--dropdown .choices__item,
.gform_wrapper .choices__list[aria-expanded] .choices__item {
  padding: var(--space-2) var(--space-4);
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--color-charcoal);
}
.gform_wrapper .choices__list--dropdown .choices__item--selectable.is-highlighted,
.gform_wrapper .choices__list[aria-expanded] .choices__item--selectable.is-highlighted {
  background: var(--color-bronze-10);
  color: var(--color-bronze-dark);
}

/* Search input inside dropdown (appears when >8 options) */
.gform_wrapper .choices__list--dropdown .choices__input {
  background: var(--color-offwhite);
  border: none;
  padding: var(--space-3) var(--space-4);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  margin: 0;
}

/* Multi-select tags */
.gform_wrapper .choices__list--multiple .choices__item {
  background: var(--color-bronze);
  border-color: var(--color-bronze);
  border-radius: 0;
  font-family: var(--font-body);
  font-size: var(--text-sm);
  padding: 4px 10px;
}
.gform_wrapper .choices__list--multiple .choices__item.is-highlighted {
  background: var(--color-bronze-dark);
  border-color: var(--color-bronze-dark);
}

/* Hide native select once Choices wraps it (Choices already does this, but be explicit) */
.gform_wrapper .choices select {
  display: none;
}

/* Error state — keep red border-bottom on the wrapper */
.gform_wrapper .gfield.gfield_error .choices__inner {
  border-bottom-color: var(--color-danger, #c0392b);
}

