@charset "utf-8";

/* ==========================================
   File: /css/gamblexpress-local-search.css
   GambleXpress Local Search Widget
   No API / No Dataset Search Launcher
   Updated Window / Container Version
========================================== */

/* ==========================================
   OUTER WINDOW / FRAME
========================================== */
.gx-local-search-wrap,
.gx-local-search,
.gx-local-search-panel {
  text-align: initial !important;
}


.gx-local-search-wrap {
  display: block !important;
  width: calc(100% - 24px) !important;
  max-width: 1220px !important;
  margin: 30px auto !important;
  padding: 14px !important;
  box-sizing: border-box !important;
  clear: both !important;
  background: #0d3b66 !important;
  border: 1px solid #092d4a !important;
  border-radius: 22px !important;
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.22) !important;
  overflow: visible !important;
}

/* Main widget section */
.gx-local-search {
  display: block !important;
  width: 100% !important;
  max-width: 1180px !important;
  margin: 0 auto !important;
  padding: 0 !important;
  box-sizing: border-box !important;
  clear: both !important;
  overflow: visible !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

/* Inner white panel */
.gx-local-search-panel {
  display: block !important;
  width: 100% !important;
  margin: 0 auto !important;
  padding: 26px !important;
  box-sizing: border-box !important;
  font-family: Arial, Helvetica, sans-serif !important;
  background: linear-gradient(135deg, #ffffff 0%, #f7f9fc 100%) !important;
  border: 1px solid #d8e0ea !important;
  border-radius: 18px !important;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.65) !important;
  overflow: visible !important;
}

/* Reset children inside widget */
.gx-local-search *,
.gx-local-search *::before,
.gx-local-search *::after,
.gx-local-search-wrap *,
.gx-local-search-wrap *::before,
.gx-local-search-wrap *::after {
  box-sizing: border-box !important;
}

.gx-local-search .gx-local-search-field label {
  white-space: normal !important;
  min-height: 34px !important;
}

/* ==========================================
   HEADER
========================================== */

.gx-local-search .gx-local-search-header {
  display: block !important;
  width: 100% !important;
  margin: 0 0 20px 0 !important;
  padding: 0 !important;
  text-align: center !important;
}

.gx-local-search .gx-local-search-title {
  display: block !important;
  margin: 0 0 8px 0 !important;
  padding: 0 !important;
  font-family: Arial, Helvetica, sans-serif !important;
  font-size: 28px !important;
  line-height: 1.2 !important;
  color: #FF6633; !important;
  font-weight: 700 !important;
  text-align: center !important;
}

.gx-local-search .gx-local-search-subtitle {
  display: block !important;
  max-width: 850px !important;
  margin: 0 auto !important;
  padding: 0 !important;
  font-family: Arial, Helvetica, sans-serif !important;
  font-size: 15px !important;
  line-height: 1.55 !important;
  color: #000000; !important;
  text-align: center !important;
}

/* ==========================================
   FORM LAYOUT
========================================== */

.gx-local-search .gx-local-search-form {
  display: grid !important;
  grid-template-columns:
    minmax(240px, 1.4fr)
    minmax(130px, 0.6fr)
    minmax(220px, 1fr)
    minmax(170px, auto) !important;
  gap: 14px !important;
  align-items: end !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 20px 0 0 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  float: none !important;
  clear: both !important;
}

/* Field wrappers */
.gx-local-search .gx-local-search-field {
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  width: 100% !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  float: none !important;
  clear: none !important;
}

/* Labels */
.gx-local-search .gx-local-search-field label {
  display: block !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  font-family: Arial, Helvetica, sans-serif !important;
  font-size: 13px !important;
  line-height: 1.3 !important;
  font-weight: 700 !important;
  color: #12324a !important;
  text-align: left !important;
}

/* Inputs and selects */
.gx-local-search .gx-local-location,
.gx-local-search .gx-local-radius,
.gx-local-search .gx-local-type {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  height: auto !important;
  min-height: 44px !important;
  margin: 0 !important;
  padding: 10px 12px !important;
  font-family: Arial, Helvetica, sans-serif !important;
  font-size: 15px !important;
  line-height: 1.3 !important;
  color: #1e1e1e !important;
  background: #ffffff !important;
  border: 1px solid #bfcbd9 !important;
  border-radius: 10px !important;
  outline: none !important;
  box-shadow: none !important;
  appearance: auto !important;
}

/* Placeholder */
.gx-local-search .gx-local-location::placeholder {
  color: #777777 !important;
  opacity: 1 !important;
}

.gx-local-search .gx-local-location:focus,
.gx-local-search .gx-local-radius:focus,
.gx-local-search .gx-local-type:focus {
  border-color: #1477b8 !important;
  box-shadow: 0 0 0 3px rgba(20, 119, 184, 0.16) !important;
}

/* ==========================================
   MAIN SEARCH BUTTON
========================================== */

.gx-local-search .gx-local-search-action {
  display: flex !important;
  align-items: end !important;
  justify-content: flex-start !important;
  width: auto !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  float: none !important;
}

.gx-local-search .gx-local-search-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: auto !important;
  min-width: 170px !important;
  min-height: 44px !important;
  margin: 0 !important;
  padding: 10px 22px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: #00cc33 !important;
  color: #ffffff !important;
  font-family: Arial, Helvetica, sans-serif !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  text-align: center !important;
  text-decoration: none !important;
  cursor: pointer !important;
  white-space: nowrap !important;
  box-shadow: 0 4px 12px rgba(0, 153, 51, 0.28) !important;
  transition: background 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease !important;
}

.gx-local-search .gx-local-search-btn:hover,
.gx-local-search .gx-local-search-btn:focus {
  background: #0d5f94 !important;
  color: #ffffff !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 5px 14px rgba(13, 95, 148, 0.25) !important;
}

/* ==========================================
   QUERY OUTPUT
========================================== */

.gx-local-search .gx-local-search-output {
  display: none !important;
  width: 100% !important;
  max-width: 850px !important;
  margin: 18px auto 0 auto !important;
  padding: 12px 14px !important;
  background: #ffffff !important;
  border: 1px solid #d9e2ec !important;
  border-radius: 12px !important;
  text-align: center !important;
}

.gx-local-search.has-results .gx-local-search-output {
  display: block !important;
}

.gx-local-search .gx-local-query-label {
  display: block !important;
  margin: 0 0 4px 0 !important;
  padding: 0 !important;
  color: #0d3b66 !important;
  font-family: Arial, Helvetica, sans-serif !important;
  font-size: 13px !important;
  line-height: 1.3 !important;
  font-weight: 700 !important;
  text-align: center !important;
}

.gx-local-search .gx-local-query-text {
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
  color: #333333 !important;
  font-family: Arial, Helvetica, sans-serif !important;
  font-size: 14px !important;
  line-height: 1.45 !important;
  text-align: center !important;
  word-break: break-word !important;
}

/* ==========================================
   EXTERNAL SEARCH LINKS
========================================== */

.gx-local-search .gx-local-search-links {
  display: none !important;
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  gap: 12px !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 20px 0 0 0 !important;
  padding: 0 !important;
}

.gx-local-search.has-results .gx-local-search-links {
  display: grid !important;
}

.gx-local-search .gx-local-link {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 42px !important;
  margin: 0 !important;
  padding: 10px 14px !important;
  border-radius: 999px !important;
  background: #0d3b66 !important;
  color: #ffffff !important;
  font-family: Arial, Helvetica, sans-serif !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  line-height: 1.25 !important;
  text-align: center !important;
  text-decoration: none !important;
  white-space: normal !important;
  transition: background 0.18s ease, transform 0.18s ease !important;
}

.gx-local-search .gx-local-link:visited {
  color: #ffffff !important;
}

.gx-local-search .gx-local-link:hover,
.gx-local-search .gx-local-link:focus {
  background: #00cc33 !important;
  color: #ffffff !important;
  transform: translateY(-1px) !important;
}

/* ==========================================
   NOTE
========================================== */

.gx-local-search .gx-local-search-note {
  display: none !important;
  max-width: 760px !important;
  margin: 16px auto 0 auto !important;
  padding: 0 !important;
  color: #555555 !important;
  font-family: Arial, Helvetica, sans-serif !important;
  font-size: 13px !important;
  line-height: 1.45 !important;
  text-align: center !important;
}

.gx-local-search.has-results .gx-local-search-note {
  display: block !important;
}

/* ==========================================
   MEDIUM / NARROW DESKTOP
========================================== */

@media screen and (max-width: 1100px) {
  .gx-local-search .gx-local-search-form {
    grid-template-columns: 1fr 1fr !important;
  }

  .gx-local-search .gx-local-search-action {
    grid-column: 1 / -1 !important;
    justify-content: center !important;
  }

  .gx-local-search .gx-local-search-btn {
    width: 240px !important;
  }

  .gx-local-search .gx-local-search-links {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

/* ==========================================
   MOBILE
========================================== */

@media screen and (max-width: 640px) {
  .gx-local-search-wrap {
    width: calc(100% - 12px) !important;
    margin: 20px auto !important;
    padding: 8px !important;
    border-radius: 16px !important;
  }

  .gx-local-search-panel {
    padding: 18px !important;
    border-radius: 12px !important;
  }

  .gx-local-search .gx-local-search-title {
    font-size: 23px !important;
  }

  .gx-local-search .gx-local-search-subtitle {
    font-size: 14px !important;
  }

  .gx-local-search .gx-local-search-form {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }

  .gx-local-search .gx-local-search-action {
    justify-content: stretch !important;
  }

  .gx-local-search .gx-local-search-btn {
    width: 100% !important;
    min-width: 0 !important;
  }

  .gx-local-search .gx-local-search-links {
    grid-template-columns: 1fr !important;
  }
}

/* ==========================================
   GambleXpress General CSS Conflict Patch
========================================== */

.gx-local-search-wrap,
.gx-local-search,
.gx-local-search-panel {
  text-align: initial !important;
  flex: none !important;
  align-self: center !important;
}

.gx-local-search-wrap {
  min-width: 0 !important;
}

.gx-local-search form,
.gx-local-search input,
.gx-local-search select,
.gx-local-search button {
  max-width: 100% !important;
}

.gx-local-search a,
.gx-local-search a:link,
.gx-local-search a:visited {
  color: #ffffff !important;
}

.gx-local-search .gx-local-search-title,
.gx-local-search .gx-local-search-subtitle,
.gx-local-search .gx-local-query-label,
.gx-local-search .gx-local-query-text,
.gx-local-search .gx-local-search-note {
  text-align: center !important;
}

.gx-local-search .gx-local-search-field label {
  text-align: left !important;
}

/* ==========================================
   Local Search Input Alignment Patch
   Keeps labels and input boxes left-aligned
========================================== */

.gx-local-search .gx-local-search-form {
  justify-items: stretch !important;
  text-align: left !important;
}

.gx-local-search .gx-local-search-field {
  align-items: stretch !important;
  text-align: left !important;
}

.gx-local-search .gx-local-search-field label {
  display: block !important;
  width: 100% !important;
  min-height: 18px !important;
  margin: 0 0 6px 0 !important;
  padding: 0 !important;
  text-align: left !important;
  white-space: nowrap !important;
}

.gx-local-search .gx-local-location,
.gx-local-search .gx-local-radius,
.gx-local-search .gx-local-type {
  display: block !important;
  width: 100% !important;
  text-align: left !important;
}

.gx-local-search .gx-local-search-action {
  align-items: flex-end !important;
  justify-content: flex-start !important;
  text-align: left !important;
}

.gx-local-search .gx-local-search-btn {
  align-self: flex-end !important;
}

/* ==========================================
   GambleXpress General CSS Compatibility Patch
========================================== */

.gx-local-search-wrap,
.gx-local-search,
.gx-local-search-panel {
  text-align: left !important;
  flex: none !important;
  align-self: center !important;
  min-width: 0 !important;
}

.gx-local-search .gx-local-search-header,
.gx-local-search .gx-local-search-title,
.gx-local-search .gx-local-search-subtitle {
  text-align: center !important;
}

.gx-local-search .gx-local-search-form {
  justify-items: stretch !important;
  align-items: end !important;
  text-align: left !important;
}

.gx-local-search .gx-local-search-field {
  align-items: stretch !important;
  text-align: left !important;
  min-width: 0 !important;
}

.gx-local-search .gx-local-search-field label {
  display: block !important;
  width: 100% !important;
  min-height: 34px !important;
  margin: 0 0 6px 0 !important;
  padding: 0 !important;
  text-align: left !important;
  white-space: normal !important;
  line-height: 1.25 !important;
}

.gx-local-search form,
.gx-local-search input,
.gx-local-search select,
.gx-local-search button {
  max-width: 100% !important;
}

.gx-local-search .gx-local-location,
.gx-local-search .gx-local-radius,
.gx-local-search .gx-local-type {
  text-align: left !important;
}

.gx-local-search .gx-local-link,
.gx-local-search .gx-local-link:link,
.gx-local-search .gx-local-link:visited {
  color: #ffffff !important;
  text-decoration: none !important;
}

.gx-local-search .gx-local-link:hover,
.gx-local-search .gx-local-link:focus {
  color: #ffffff !important;
}