/* ==========================================================================
   HEIMISH TRAVEL — Listing Search Form (Homepage / Hero)
   Selector: .hp-form--listing-search
   Standalone — matches the pill bar style used on the listings search page
   inside .ht-listings-search-wrapper.
   
   If the form is INSIDE .ht-listings-search-wrapper on the listings page,
   that wrapper's styles (in hivepress-listings-page.css) take precedence.
   This file styles the form when used OUTSIDE that wrapper (e.g. homepage hero).
   ========================================================================== */


/* ==========================================================================
   FORM CONTAINER — pill bar
   ========================================================================== */

.hp-form--listing-search {
  background: var(--primary-light) !important;
  border: none !important;
  border-radius: 999px !important;
  padding: var(--space-3xs, 0.3rem) var(--space-3xs, 0.3rem) var(--space-3xs, 0.3rem) var(--space-s, 1rem) !important;
  display: flex !important;
  align-items: center !important;
  box-shadow: none !important;
  margin-bottom: 0 !important;
}

.hp-form--listing-search:focus-within {
  box-shadow: 0 0 0 2px var(--primary) !important;
}

.hp-form--listing-search .hp-form__messages { display: none !important; }


/* ==========================================================================
   FIELDS ROW
   ========================================================================== */

.hp-form--listing-search .hp-form__fields {
  display: flex !important;
  align-items: center !important;
  gap: 0 !important;
  flex: 1 !important;
  min-width: 0 !important;
  margin-bottom: 0 !important;
}

.hp-form--listing-search .hp-form__field {
  flex: 1 !important;
  min-width: 0 !important;
  padding: var(--space-3xs, 0.25rem) var(--space-s, 0.75rem) !important;
  margin-bottom: 0 !important;
}

/* Vertical dividers between fields */
.hp-form--listing-search .hp-form__field + .hp-form__field {
  border-left: 1px solid var(--neutral, rgba(0, 0, 0, 0.15)) !important;
}


/* ==========================================================================
   TEXT INPUTS — clean, no borders
   ========================================================================== */

.hp-form--listing-search .hp-field--text {
  border: none !important;
  background: transparent !important;
  box-shadow: none !important;
  outline: none !important;
  font-size: var(--text-s) !important;
  font-weight: 500 !important;
  color: var(--primary) !important;
  padding: 0 !important;
  height: auto !important;
  line-height: 1.4 !important;
  width: 100% !important;
}

.hp-form--listing-search .hp-field--text::placeholder {
  color: var(--neutral) !important;
  font-weight: 400 !important;
}


/* ==========================================================================
   LOCATION FIELD
   ========================================================================== */

.hp-form--listing-search .hp-field--location {
  display: flex !important;
  align-items: center !important;
  gap: var(--space-s) !important;
}

.hp-form--listing-search .hp-field--location .mapboxgl-ctrl {
  background: transparent !important;
  box-shadow: none !important;
  border: none !important;
  max-width: 100% !important;
  width: 100% !important;
}

.hp-form--listing-search .hp-field--location .mapboxgl-ctrl .hp-field--text {
  padding-left: 1.75rem !important;
}

.hp-form--listing-search .mapboxgl-ctrl-geocoder--icon-search {
  fill: var(--neutral) !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
}

.hp-form--listing-search .hp-field--location a {
  color: var(--neutral) !important;
  font-size: var(--text-s) !important;
  flex-shrink: 0 !important;
  transition: color 0.15s ease !important;
  text-decoration: none !important;
}

.hp-form--listing-search .hp-field--location a:hover {
  color: var(--primary) !important;
}

/* Suggestions dropdown */
.hp-form--listing-search .suggestions {
  background: var(--white, #fff) !important;
  border: 1px solid rgba(0, 0, 0, 0.08) !important;
  border-radius: var(--radius) !important;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1) !important;
  margin-top: 2px !important;
  overflow: hidden !important;
}

.hp-form--listing-search .suggestions li {
  padding: var(--space-xs) var(--space-s) !important;
  font-size: var(--text-s) !important;
  color: var(--primary) !important;
  cursor: pointer !important;
}

.hp-form--listing-search .suggestions li:hover,
.hp-form--listing-search .suggestions li.active {
  background: var(--primary-light) !important;
}


/* ==========================================================================
   DATE RANGE FIELD
   ========================================================================== */

.hp-form--listing-search .hp-field--date-range {
  display: flex !important;
  align-items: center !important;
  width: 100% !important;
}

.hp-form--listing-search .hp-field--date {
  display: flex !important;
  align-items: center !important;
  width: 100% !important;
}

.hp-form--listing-search .hp-field--date a[data-clear] {
  color: var(--neutral) !important;
  font-size: var(--text-xs) !important;
  opacity: 0.5 !important;
  transition: opacity 0.15s ease !important;
}

.hp-form--listing-search .hp-field--date a[data-clear]:hover {
  opacity: 1 !important;
}


/* ==========================================================================
   CATEGORY SELECT
   ========================================================================== */

.hp-form--listing-search .select2-selection--single {
  border: none !important;
  background: transparent !important;
  height: auto !important;
  min-height: unset !important;
  padding: 0 !important;
}

.hp-form--listing-search .select2-selection__rendered {
  font-size: var(--text-s) !important;
  font-weight: 500 !important;
  color: var(--primary) !important;
  line-height: 1.4 !important;
  padding: 0 !important;
}

.hp-form--listing-search .select2-selection__arrow {
  display: none !important;
}


/* ==========================================================================
   SEARCH BUTTON — circle icon
   ========================================================================== */

.hp-form--listing-search .hp-form__footer {
  flex-shrink: 0 !important;
}

.hp-form--listing-search .hp-form__button {
  width: 3.5rem !important;
  height: 3.5rem !important;
  border-radius: 50% !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: var(--primary) !important;
  color: var(--white, #fff) !important;
  border: none !important;
  cursor: pointer !important;
  transition: opacity 0.15s ease, transform 0.15s ease !important;
}

.hp-form--listing-search .hp-form__button::before {
  content: "\f002" !important;
  font-family: "Font Awesome 5 Free" !important;
  font-weight: 900 !important;
  font-size: var(--text-m, 1rem) !important;
}

.hp-form--listing-search .hp-form__button span {
  display: none !important;
}

.hp-form--listing-search .hp-form__button:hover {
  opacity: 0.85 !important;
  transform: scale(1.05) !important;
}


/* ==========================================================================
   MOBILE
   ========================================================================== */

@media only screen and (max-width: 768px) {

  .hp-form--listing-search {
    border-radius: var(--radius) !important;
    flex-direction: column !important;
    padding: var(--space-xs) !important;
    gap: 0 !important;
    width: 100% !important;
  }

  .hp-form--listing-search .hp-form__fields {
    flex-direction: column !important;
    width: 100% !important;
  }

  .hp-form--listing-search .hp-form__field {
    padding: var(--space-xs) 0 !important;
    flex: none !important;
    width: 100% !important;
  }

  .hp-form--listing-search .hp-form__field + .hp-form__field {
    border-left: none !important;
    border-top: 1px solid var(--neutral, rgba(0, 0, 0, 0.08)) !important;
  }

  .hp-form--listing-search .hp-form__footer {
    width: 100% !important;
    margin-top: var(--space-xs) !important;
  }

  .hp-form--listing-search .hp-form__button {
    width: 100% !important;
    height: auto !important;
    border-radius: var(--radius) !important;
    padding: var(--space-xs) !important;
    font-size: var(--text-s) !important;
  }

  .hp-form--listing-search .hp-form__button::before {
    content: "Search" !important;
    font-family: inherit !important;
    font-weight: 600 !important;
    font-size: var(--text-s) !important;
  }
}
