/* =========================================================
   Ship2Buy - visual upgrade exposed filters
   Targets current custom Twig structure:
   .s2b-exposed / .s2b-topgrid / .s2b-advanced / .s2b-actions
   ========================================================= */

.s2b-exposed.card {
  --s2b-navy: #1E2B3A;
  --s2b-navy-2: #24354a;
  --s2b-gold: #C7A14A;
  --s2b-gold-2: #E0BF6D;
  --s2b-text: #1E2B3A;
  --s2b-muted: #6C7A8A;
  --s2b-border: #D8DEE8;
  --s2b-soft: #F7F9FC;
  --s2b-white: #FFFFFF;

  background: linear-gradient(180deg, #fbfcfe 0%, #f7f9fc 100%);
  border: 1px solid #dbe3ed !important;
  border-radius: 30px !important;
  box-shadow: 0 12px 30px rgba(18, 33, 52, 0.08) !important;
  overflow: hidden;
  position: relative;
  margin: 18px 0 24px;
}

.s2b-exposed.card::before {
  content: "";
  display: block;
  height: 5px;
  background: linear-gradient(90deg, var(--s2b-gold) 0%, var(--s2b-gold-2) 35%, rgba(199,161,74,0.1) 100%);
}

.s2b-exposed .card-body {
  padding: 24px !important;
}

.s2b-exposed .s2b-topbar {
  margin-bottom: 8px;
}

.s2b-exposed .s2b-topgrid {
  display: grid;
  grid-template-columns: 1.45fr repeat(5, minmax(130px, 1fr));
  gap: 16px;
  align-items: end;
}

.s2b-exposed .s2b-cell,
.s2b-exposed .s2b-range {
  min-width: 0;
}

.s2b-exposed .s2b-cell label,
.s2b-exposed .s2b-range label,
.s2b-exposed .s2b-cell .form-item > label,
.s2b-exposed .s2b-range .form-item > label {
  display: block !important;
  font-size: 14px !important;
  line-height: 1.2 !important;
  font-weight: 800 !important;
  letter-spacing: 0.01em;
  color: var(--s2b-text) !important;
  margin: 0 0 9px !important;
}

.s2b-exposed input[type="text"],
.s2b-exposed input[type="search"],
.s2b-exposed input[type="number"],
.s2b-exposed .form-text,
.s2b-exposed .form-search,
.s2b-exposed select,
.s2b-exposed .form-select {
  width: 100%;
  min-height: 58px;
  border-radius: 18px !important;
  border: 1.5px solid var(--s2b-border) !important;
  background: #fff !important;
  color: var(--s2b-text) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.85);
  padding: 15px 18px !important;
  font-size: 16px !important;
  font-weight: 500;
  transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}

.s2b-exposed input::placeholder {
  color: #788596 !important;
  opacity: 1;
}

.s2b-exposed input:focus,
.s2b-exposed select:focus,
.s2b-exposed .form-text:focus,
.s2b-exposed .form-search:focus,
.s2b-exposed .form-select:focus {
  border-color: var(--s2b-gold) !important;
  box-shadow: 0 0 0 4px rgba(199,161,74,.16) !important;
  outline: none !important;
  transform: translateY(-1px);
}

.s2b-exposed select,
.s2b-exposed .form-select {
  appearance: none;
  -webkit-appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, #6f7c8c 50%),
    linear-gradient(135deg, #6f7c8c 50%, transparent 50%);
  background-position:
    calc(100% - 22px) calc(50% - 3px),
    calc(100% - 16px) calc(50% - 3px);
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
  padding-right: 38px !important;
}

/* Search field a bit more dominant */
.s2b-exposed .s2b-cell--search input,
.s2b-exposed .s2b-cell--search .form-text,
.s2b-exposed .s2b-cell--search .form-search {
  padding-left: 18px !important;
  font-size: 17px !important;
}

/* Advanced filters block */
.s2b-exposed .s2b-advanced {
  margin-top: 18px;
  border-top: 1px solid rgba(30,43,58,.08);
  padding-top: 18px;
}

.s2b-exposed .s2b-ranges {
  display: grid;
  grid-template-columns: repeat(3, minmax(180px, 1fr));
  gap: 16px;
}

.s2b-exposed .s2b-range {
  background: rgba(255,255,255,.7);
  border: 1px solid rgba(216,222,232,.8);
  border-radius: 20px;
  padding: 14px;
}

/* Buttons / actions */
.s2b-exposed .s2b-actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 18px;
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid rgba(30,43,58,.08);
}

.s2b-exposed .s2b-actions__left,
.s2b-exposed .s2b-actions__right,
.s2b-exposed .form-actions {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 14px;
}

.s2b-exposed .form-actions input[type="submit"],
.s2b-exposed .form-actions .form-submit,
.s2b-exposed .form-actions button.form-submit,
.s2b-exposed .form-actions .btn-primary {
  min-height: 56px;
  padding: 0 28px;
  border-radius: 18px !important;
  border: 0 !important;
  background: linear-gradient(180deg, var(--s2b-navy-2) 0%, var(--s2b-navy) 100%) !important;
  color: #fff !important;
  font-size: 18px !important;
  font-weight: 800 !important;
  letter-spacing: .01em;
  box-shadow: 0 8px 20px rgba(30,43,58,.18);
  transition: transform .18s ease, box-shadow .18s ease, opacity .18s ease;
}

.s2b-exposed .form-actions input[type="submit"]:hover,
.s2b-exposed .form-actions .form-submit:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 24px rgba(30,43,58,.22);
}

.s2b-exposed .s2b-clear,
.s2b-exposed .s2b-toggle {
  min-height: 56px;
  padding: 0 24px;
  border-radius: 18px !important;
  font-size: 17px !important;
  font-weight: 800 !important;
  border-width: 2px !important;
  transition: transform .18s ease, background .18s ease, border-color .18s ease;
}

.s2b-exposed .s2b-clear {
  background: #fff !important;
  color: var(--s2b-text) !important;
  border-color: var(--s2b-navy) !important;
}

.s2b-exposed .s2b-toggle {
  background: #fff !important;
  color: var(--s2b-text) !important;
  border-color: var(--s2b-navy) !important;
}

.s2b-exposed .s2b-clear:hover,
.s2b-exposed .s2b-toggle:hover {
  background: #f3f7fb !important;
  transform: translateY(-1px);
}

/* Inline items produced by Drupal/TomSelect */
.s2b-exposed .ts-wrapper,
.s2b-exposed .form-item {
  margin-bottom: 0 !important;
}

.s2b-exposed .ts-control,
.s2b-exposed .ts-control.input-active,
.s2b-exposed .ts-wrapper.single .ts-control {
  min-height: 58px;
  border-radius: 18px !important;
  border: 1.5px solid var(--s2b-border) !important;
  background: #fff !important;
  padding: 14px 18px !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.85) !important;
}

.s2b-exposed .ts-wrapper.focus .ts-control {
  border-color: var(--s2b-gold) !important;
  box-shadow: 0 0 0 4px rgba(199,161,74,.16) !important;
}

.s2b-exposed .description {
  display: none !important;
}

/* Desktop medium */
@media (max-width: 1180px) {
  .s2b-exposed .s2b-topgrid {
    grid-template-columns: repeat(3, minmax(180px, 1fr));
  }

  .s2b-exposed .s2b-cell--search {
    grid-column: 1 / -1;
  }

  .s2b-exposed .s2b-ranges {
    grid-template-columns: repeat(2, minmax(180px, 1fr));
  }
}

/* Mobile */
@media (max-width: 767px) {
  .s2b-exposed.card {
    border-radius: 26px !important;
    margin: 14px 0 18px;
  }

  .s2b-exposed .card-body {
    padding: 18px 16px 96px !important;
  }

  .s2b-exposed .s2b-topgrid {
    grid-template-columns: 1fr 1fr;
    gap: 12px;
  }

  .s2b-exposed .s2b-cell--search {
    grid-column: 1 / -1;
  }

  .s2b-exposed input[type="text"],
  .s2b-exposed input[type="search"],
  .s2b-exposed input[type="number"],
  .s2b-exposed .form-text,
  .s2b-exposed .form-search,
  .s2b-exposed select,
  .s2b-exposed .form-select,
  .s2b-exposed .ts-control,
  .s2b-exposed .ts-wrapper.single .ts-control {
    min-height: 54px;
    border-radius: 16px !important;
    font-size: 15px !important;
    padding: 14px 16px !important;
  }

  .s2b-exposed .s2b-cell label,
  .s2b-exposed .s2b-range label,
  .s2b-exposed .s2b-cell .form-item > label,
  .s2b-exposed .s2b-range .form-item > label {
    font-size: 13px !important;
    margin-bottom: 7px !important;
  }

  .s2b-exposed .s2b-ranges {
    grid-template-columns: 1fr 1fr;
    gap: 12px;
  }

  .s2b-exposed .s2b-range {
    border-radius: 16px;
    padding: 12px;
  }

  .s2b-exposed .s2b-actions {
    position: relative;
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
    margin-top: 16px;
    padding-top: 16px;
  }

  .s2b-exposed .s2b-actions__left,
  .s2b-exposed .s2b-actions__right,
  .s2b-exposed .form-actions {
    width: 100%;
  }

  .s2b-exposed .form-actions {
    display: grid;
    grid-template-columns: 1fr 1.3fr;
    gap: 12px;
  }

  .s2b-exposed .form-actions input[type="submit"],
  .s2b-exposed .form-actions .form-submit,
  .s2b-exposed .form-actions button.form-submit {
    width: 100%;
    min-width: 0;
    order: 2;
    background: linear-gradient(180deg, #d7b15c 0%, var(--s2b-gold) 100%) !important;
    color: #122033 !important;
    box-shadow: 0 8px 20px rgba(199,161,74,.22);
  }

  .s2b-exposed .s2b-clear {
    width: 100%;
    min-width: 0;
    order: 1;
    text-align: center;
    justify-content: center;
    display: inline-flex;
    align-items: center;
  }

  .s2b-exposed .s2b-actions__right {
    display: block;
  }

  .s2b-exposed .s2b-toggle {
    width: 100%;
    justify-content: center;
    display: inline-flex;
    align-items: center;
  }
}

/* Very small phones */
@media (max-width: 520px) {
  .s2b-exposed .s2b-topgrid {
    grid-template-columns: 1fr;
  }

  .s2b-exposed .s2b-ranges {
    grid-template-columns: 1fr;
  }

  .s2b-exposed .form-actions {
    grid-template-columns: 1fr 1.25fr;
  }
}
