/* ============================================================
   SEARCH FORM v7 — Prestige Real Estate
   2026 · Realtor.com / Zillow / Homes.com tier
   Underlined tabs · Floating card · Inline bar · Zero toy UI
   CSS-var driven · Customizer-ready · Full responsive
   ============================================================ */

/* ─── OUTER WRAPPER ─── */
.sf {
  width: 100%;
  max-width: 1080px;
  margin: 36px auto 0;
  padding-inline: clamp(12px, 3vw, 24px);
  box-sizing: border-box;
}

/* ─── TABS — underline style ─── */
.sf-tabs {
  display: flex;
  align-items: stretch;
  gap: 0;
  margin-bottom: 0;
  overflow-x: auto;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  border-bottom: 2px solid color-mix(in srgb, var(--search-border, #e5e7eb) 50%, transparent);
  padding: 0;
}
.sf-tabs::-webkit-scrollbar { display: none; }

.sf-tab {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 22px;
  font-family: inherit;
  font-size: var(--search-tab-size, .78rem);
  font-weight: var(--search-tab-weight, 600);
  letter-spacing: .005em;
  white-space: nowrap;
  cursor: pointer;
  border: none;
  background: transparent;
  color: var(--search-tab-color, var(--color-gray-400, #9ca3af));
  transition: color .25s ease, background .25s ease;
  flex-shrink: 0;
  border-radius: 0;
}
.sf-tab:hover {
  color: var(--search-tab-active-color, var(--search-text, var(--color-primary, #1a1a2e)));
  background: color-mix(in srgb, var(--search-border, #e5e7eb) 15%, transparent);
}
.sf-tab::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: -2px;
  height: 2.5px;
  border-radius: 2px 2px 0 0;
  background: transparent;
  transition: background .25s ease, box-shadow .25s ease;
}
.sf-tab.active {
  color: var(--search-tab-active-color, var(--search-text, var(--color-primary, #1a1a2e)));
  font-weight: 700;
}
.sf-tab.active::after {
  background: var(--search-accent, var(--color-accent, #c9a96e));
  box-shadow: 0 1px 8px color-mix(in srgb, var(--search-accent, #c9a96e) 30%, transparent);
}

/* ─── CARD ─── */
.sf-card {
  background: var(--search-bg, #fff);
  border: 1px solid color-mix(in srgb, var(--search-border, #e5e7eb) 60%, transparent);
  border-top: none;
  border-radius: 0 0 16px 16px;
  padding: var(--search-card-padding, 6px);
  box-shadow: var(--search-card-shadow,
    0 1px 2px rgba(0,0,0,.03),
    0 4px 16px -2px rgba(0,0,0,.06),
    0 16px 48px -8px rgba(0,0,0,.06));
  transition: box-shadow .35s ease, border-color .35s ease;
}
.sf-card:focus-within {
  border-color: color-mix(in srgb, var(--search-accent, #c9a96e) 18%, var(--search-border, #e5e7eb));
  box-shadow:
    0 1px 2px rgba(0,0,0,.03),
    0 8px 24px -2px rgba(0,0,0,.08),
    0 24px 64px -8px rgba(0,0,0,.08);
}

/* ─── ROW — inline bar layout ─── */
.sf-row {
  display: flex;
  flex-direction: column;
  gap: 0;
}

/* ─── FIELD GROUP ─── */
.sf-group {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 10px 14px;
  border-radius: 10px;
  transition: background .25s ease, box-shadow .25s ease;
  position: relative;
  cursor: pointer;
}
.sf-group:hover {
  background: color-mix(in srgb, var(--search-border, #e5e7eb) 25%, transparent);
}
.sf-group:focus-within {
  background: color-mix(in srgb, var(--search-accent, #c9a96e) 5%, var(--search-bg, #fff));
  box-shadow: inset 0 0 0 1.5px color-mix(in srgb, var(--search-accent, #c9a96e) 15%, transparent);
}

.sf-label {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: var(--search-label-size, .75rem);
  font-weight: var(--search-label-weight, 700);
  text-transform: var(--search-label-transform, uppercase);
  letter-spacing: var(--search-label-spacing, .1em);
  color: var(--search-label-color, var(--color-gray-400, #aaa));
  transition: color .25s;
}
.sf-label svg {
  width: 14px; height: 14px;
  opacity: .35;
  flex-shrink: 0;
  transition: opacity .25s, color .25s;
}
.sf-group:focus-within .sf-label {
  color: var(--search-accent, var(--color-accent, #c9a96e));
}
.sf-group:focus-within .sf-label svg {
  opacity: .9;
  color: var(--search-accent, var(--color-accent, #c9a96e));
}

/* ─── SELECT / INPUT ─── */
.sf-select,
.sf-input {
  width: 100%;
  font-family: inherit;
  font-size: var(--search-input-size, 1rem);
  font-weight: var(--search-input-weight, 600);
  color: var(--search-input-color, var(--search-text, #1a1a2e));
  background: transparent;
  border: none;
  padding: 3px 0;
  outline: none;
  appearance: none;
  -webkit-appearance: none;
  cursor: pointer;
  transition: color .25s;
}
.sf-select option {
  background: var(--search-bg, #fff);
  color: var(--search-text, #1a1a2e);
}
.sf-input::placeholder { color: var(--color-gray-300, #ccc); font-weight: 500; }
.sf-select:disabled { opacity: .3; cursor: not-allowed; }

/* ─── PRICE ROW ─── */
.sf-price {
  padding: 4px 14px 10px;
  margin-top: 2px;
  border-top: 1px solid color-mix(in srgb, var(--search-border, #e5e7eb) 40%, transparent);
}
.sf-price > .sf-label {
  margin-bottom: 7px;
}
.sf-price-grid {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 8px;
  align-items: center;
}
.sf-price-grid .sf-input {
  text-align: center;
  font-weight: 600;
  font-size: .8rem;
  background: color-mix(in srgb, var(--search-border, #e5e7eb) 22%, transparent);
  border: 1.5px solid transparent;
  border-radius: 8px;
  padding: 9px 12px;
  box-sizing: border-box;
  transition: all .25s ease;
}
.sf-price-grid .sf-input:focus {
  border-color: var(--search-accent, var(--color-accent, #c9a96e));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--search-accent, #c9a96e) 10%, transparent);
  background: var(--search-bg, #fff);
}
.sf-price-dash {
  color: var(--color-gray-300, #d1d5db);
  font-size: .9rem;
  font-weight: 300;
}

/* ─── ACTIONS ─── */
.sf-actions {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 4px 6px 6px;
}

/* toggle */
.sf-adv-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 9px 16px;
  font-family: inherit;
  font-size: .72rem;
  font-weight: 600;
  color: var(--color-gray-500, #888);
  background: transparent;
  border: 1.5px solid color-mix(in srgb, var(--search-border, #e5e7eb) 65%, transparent);
  border-radius: var(--radius-full, 100px);
  cursor: pointer;
  transition: all .3s cubic-bezier(.4,0,.2,1);
  width: 100%;
  order: 2;
}
.sf-adv-toggle svg {
  width: 13px; height: 13px;
  transition: transform .35s cubic-bezier(.4,0,.2,1);
}
.sf-adv-toggle:hover {
  border-color: var(--search-accent, var(--color-accent, #c9a96e));
  color: var(--search-accent, var(--color-accent, #c9a96e));
  background: color-mix(in srgb, var(--search-accent, #c9a96e) 4%, transparent);
}
.sf-adv-toggle.open {
  border-color: var(--search-accent, var(--color-accent, #c9a96e));
  color: var(--search-accent, var(--color-accent, #c9a96e));
  background: color-mix(in srgb, var(--search-accent, #c9a96e) 6%, transparent);
}
.sf-adv-toggle.open svg { transform: rotate(180deg); }

/* submit */
.sf-submit {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 12px 24px;
  font-family: inherit;
  font-size: var(--search-btn-size, .82rem);
  font-weight: var(--search-btn-weight, 700);
  letter-spacing: .01em;
  color: var(--search-btn-text, #fff);
  background: var(--search-btn-bg, var(--search-accent, var(--color-accent, #c9a96e)));
  border: none;
  border-radius: var(--radius-full, 100px);
  cursor: pointer;
  transition: all .25s ease;
  order: 1;
  position: relative;
  overflow: hidden;
}
.sf-submit svg { width: 15px; height: 15px; }
.sf-submit:hover {
  background: color-mix(in srgb, var(--search-accent, #c9a96e) 88%, #000);
  transform: translateY(-1px);
  box-shadow:
    0 4px 12px -2px color-mix(in srgb, var(--search-accent, #c9a96e) 35%, transparent),
    0 8px 24px -6px color-mix(in srgb, var(--search-accent, #c9a96e) 20%, transparent);
}
.sf-submit:active { transform: translateY(0); box-shadow: none; }

/* ─── ADVANCED PANEL ─── */
.sf-advanced {
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition: max-height .45s cubic-bezier(.4,0,.2,1), opacity .3s, margin .35s;
  background: var(--search-bg, #fff);
  border: 1px solid color-mix(in srgb, var(--search-border, #e5e7eb) 80%, transparent);
  border-radius: 16px;
  margin-top: 0;
  padding: 0 20px;
}
.sf-advanced.open {
  max-height: 700px;
  overflow-y: auto;
  opacity: 1;
  padding: 20px;
  margin-top: 10px;
  box-shadow:
    0 0 0 1px rgba(0,0,0,.02),
    0 4px 20px -4px rgba(0,0,0,.05),
    0 12px 40px -8px rgba(0,0,0,.05);
}

/* mini grid */
.sf-adv-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.sf-mini { display: flex; flex-direction: column; }
.sf-mini-label {
  font-size: .52rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--color-gray-400, #aaa);
  margin-bottom: 4px;
}
.sf-mini-select,
.sf-mini-input {
  width: 100%;
  box-sizing: border-box;
  font-family: inherit;
  font-size: .72rem;
  font-weight: 500;
  color: var(--search-text, #1a1a2e);
  background: color-mix(in srgb, var(--search-border, #e5e7eb) 25%, transparent);
  border: 1px solid transparent;
  border-radius: var(--radius-sm, 8px);
  padding: 7px 9px;
  outline: none;
  appearance: none;
  -webkit-appearance: none;
  transition: border-color .2s, box-shadow .2s, background .2s;
}
.sf-mini-select:focus,
.sf-mini-input:focus {
  border-color: var(--search-accent, var(--color-accent, #c9a96e));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--search-accent, #c9a96e) 10%, transparent);
  background: var(--search-bg, #fff);
}
.sf-mini-select option {
  background: var(--search-bg, #fff);
  color: var(--search-text, #1a1a2e);
}
.sf-mini-input::placeholder { color: var(--color-gray-400, #aaa); }
.sf-mini-select:disabled { opacity: .3; cursor: not-allowed; }

/* ============================================================
   SF CUSTOM SELECT — DS 3.0 inspired dropdown
   ============================================================ */

/* Wrapper — positioned relative for dropdown */
.sfs-wrap {
  position: relative;
  width: 100%;
}

/* Hide native select inside wrapper */
.sfs-wrap > select {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
  pointer-events: none;
  overflow: hidden;
}

/* Trigger — replaces native select visually */
.sfs-trigger {
  display: flex;
  align-items: center;
  gap: 6px;
  width: 100%;
  padding: 3px 0;
  font-family: inherit;
  font-size: var(--search-input-size, 1rem);
  font-weight: var(--search-input-weight, 600);
  color: var(--search-input-color, var(--search-text, #1a1a2e));
  background: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  user-select: none;
  -webkit-user-select: none;
  transition: color .25s;
  line-height: 1.4;
}

.sfs-text {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sfs-text.is-placeholder {
  color: var(--color-gray-400, #9ca3af);
  font-weight: 500;
}

/* Arrow */
.sfs-arrow {
  flex-shrink: 0;
  width: 16px;
  height: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-gray-300, #d1d5db);
  transition: transform .25s ease, color .25s ease;
}
.sfs-arrow svg { width: 14px; height: 14px; }

.sfs-wrap.open .sfs-arrow {
  transform: rotate(180deg);
  color: var(--search-accent, var(--color-accent, #c9a96e));
}

/* Clear button */
.sfs-clear {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  display: none;
  align-items: center;
  justify-content: center;
  color: var(--color-gray-300, #d1d5db);
  cursor: pointer;
  border-radius: 50%;
  transition: all .2s ease;
}
.sfs-clear svg { width: 12px; height: 12px; }
.sfs-clear:hover {
  color: #ef4444;
  background: rgba(239,68,68,.08);
}
.sfs-wrap.has-value .sfs-clear {
  display: flex;
}

/* Disabled state */
.sfs-wrap.disabled .sfs-trigger {
  opacity: .3;
  pointer-events: none;
  cursor: not-allowed;
}

/* ── Dropdown — portaled to body with position:fixed ── */
.sfs-dropdown {
  position: fixed;
  background: var(--search-bg, #fff);
  border: 1px solid color-mix(in srgb, var(--search-border, #e5e7eb) 80%, transparent);
  border-radius: 12px;
  box-shadow:
    0 4px 16px -2px rgba(0,0,0,.08),
    0 12px 40px -8px rgba(0,0,0,.1),
    0 0 0 1px rgba(0,0,0,.02);
  z-index: 9999;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  transition: opacity .18s ease, visibility .18s ease, transform .18s ease;
  max-height: 260px;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  pointer-events: none;
}

.sfs-dropdown.sfs-open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

/* Dropup (when near bottom of viewport) */
.sfs-dropdown.sfs-dropup {
  transform: translateY(8px);
}
.sfs-dropdown.sfs-dropup.sfs-open {
  transform: translateY(0);
}

/* ── Search inside dropdown ── */
.sfs-search {
  padding: 6px;
  border-bottom: 1px solid color-mix(in srgb, var(--search-border, #e5e7eb) 50%, transparent);
  flex-shrink: 0;
  position: relative;
}

.sfs-search > svg {
  position: absolute;
  left: 16px;
  top: 50%;
  transform: translateY(-50%);
  width: 14px;
  height: 14px;
  color: var(--color-gray-300, #d1d5db);
  pointer-events: none;
}

.sfs-search-input {
  width: 100%;
  padding: 8px 10px 8px 32px;
  font-family: inherit;
  font-size: .84rem;
  font-weight: 500;
  color: var(--search-text, #1a1a2e);
  background: color-mix(in srgb, var(--search-border, #e5e7eb) 18%, transparent);
  border: 1.5px solid transparent;
  border-radius: 8px;
  outline: none;
  box-sizing: border-box;
  transition: all .2s ease;
}
.sfs-search-input:focus {
  border-color: var(--search-accent, var(--color-accent, #c9a96e));
  background: var(--search-bg, #fff);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--search-accent, #c9a96e) 10%, transparent);
}
.sfs-search-input::placeholder {
  color: var(--color-gray-300, #ccc);
  font-weight: 400;
}

/* ── Options list ── */
.sfs-options {
  overflow-y: auto;
  overscroll-behavior: contain;
  flex: 1;
  padding: 4px;
}
.sfs-options::-webkit-scrollbar { width: 5px; }
.sfs-options::-webkit-scrollbar-track { background: transparent; }
.sfs-options::-webkit-scrollbar-thumb { background: color-mix(in srgb, var(--search-border, #e5e7eb) 80%, transparent); border-radius: 3px; }
.sfs-options::-webkit-scrollbar-thumb:hover { background: var(--color-gray-300, #d1d5db); }

/* Option item */
.sfs-option {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  font-size: .88rem;
  font-weight: 600;
  color: var(--color-gray-600, #6b6b6b);
  border-radius: 8px;
  cursor: pointer;
  transition: all .12s ease;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.sfs-option:hover,
.sfs-option.focused {
  background: color-mix(in srgb, var(--search-border, #e5e7eb) 35%, transparent);
  color: var(--search-text, #1a1a2e);
}

.sfs-option.selected {
  background: color-mix(in srgb, var(--search-accent, #c9a96e) 10%, transparent);
  color: var(--search-accent, var(--color-accent, #c9a96e));
  font-weight: 600;
}
.sfs-option.selected::after {
  content: '';
  margin-left: auto;
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23c9a96e' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 12px;
}

.sfs-option.disabled {
  opacity: .35;
  pointer-events: none;
}

/* Group label */
.sfs-group-label {
  padding: 8px 12px 4px;
  font-size: .68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--color-gray-400, #aaa);
  pointer-events: none;
}

/* Empty state */
.sfs-empty {
  padding: 16px 10px;
  text-align: center;
  color: var(--color-gray-400, #aaa);
  font-size: .84rem;
  font-weight: 500;
}

/* ── Glass variant overrides ── */
.sf.search-glass .sfs-dropdown {
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(20px) saturate(1.4);
  -webkit-backdrop-filter: blur(20px) saturate(1.4);
  border-color: rgba(255,255,255,.5);
  box-shadow:
    0 4px 24px -2px rgba(0,0,0,.12),
    0 12px 48px -8px rgba(0,0,0,.1),
    inset 0 1px 0 rgba(255,255,255,.6);
}

/* ─── STYLE VARIANTS ─── */
.sf.search-glass .sf-card {
  background: rgba(255,255,255,.6);
  backdrop-filter: blur(28px) saturate(1.6);
  -webkit-backdrop-filter: blur(28px) saturate(1.6);
  border-color: rgba(255,255,255,.4);
  box-shadow:
    0 8px 40px rgba(0,0,0,.05),
    0 20px 60px -12px rgba(0,0,0,.06),
    inset 0 1px 0 rgba(255,255,255,.6);
}
.sf.search-glass .sf-card:focus-within {
  border-color: rgba(255,255,255,.55);
  box-shadow:
    0 12px 48px rgba(0,0,0,.07),
    0 24px 72px -12px rgba(0,0,0,.08),
    inset 0 1px 0 rgba(255,255,255,.6);
}
.sf.search-glass .sf-tabs {
  border-bottom-color: rgba(255,255,255,.2);
}
.sf.search-glass .sf-tab {
  background: transparent;
  border: none;
  color: rgba(255,255,255,.55);
}
.sf.search-glass .sf-tab:hover {
  color: rgba(255,255,255,.8);
}
.sf.search-glass .sf-tab.active {
  color: #fff;
}
.sf.search-glass .sf-tab.active::after {
  background: #fff;
}
.sf.search-glass .sf-advanced {
  background: rgba(255,255,255,.5);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-color: rgba(255,255,255,.35);
}

.sf.search-flat .sf-card,
.sf.search-flat .sf-advanced { border: none; box-shadow: none; }
.sf.search-flat .sf-tabs { border-bottom-color: var(--search-border, #e5e7eb); }

.sf.search-bordered .sf-card,
.sf.search-bordered .sf-advanced { border-width: 2px; box-shadow: none; }

.sf.search-shadow .sf-card {
  border: none;
  border-top: none;
  box-shadow: 0 25px 80px -12px rgba(0,0,0,.12), 0 8px 24px -4px rgba(0,0,0,.05), 0 0 0 1px rgba(0,0,0,.03);
}
.sf.search-shadow .sf-advanced {
  border: none;
  box-shadow: 0 20px 60px -12px rgba(0,0,0,.1), 0 8px 24px -4px rgba(0,0,0,.04), 0 0 0 1px rgba(0,0,0,.03);
}

/* ============================================================
   RESPONSIVE — 2026 fluid progressive enhancement
   ============================================================ */

/* ≥ 481 — small tablet */
@media (min-width: 481px) {
  .sf-adv-grid { grid-template-columns: repeat(3, 1fr); }
}

/* ≥ 769 — tablet / small desktop */
@media (min-width: 769px) {
  .sf {
    max-width: 1080px;
  }
  .sf-tabs { overflow: visible; }
  .sf-tab { padding: 10px 26px; font-size: .78rem; }

  .sf-card { padding: 6px; border-radius: 0 0 16px 16px; }

  /* inline bar: fields in a row */
  .sf-row {
    flex-direction: row;
    align-items: stretch;
  }

  .sf-group {
    flex: 1;
    padding: 12px 16px;
    border-radius: 10px;
  }

  /* subtle vertical separators */
  .sf-group + .sf-group::before {
    content: '';
    position: absolute;
    left: 0;
    top: 18%;
    bottom: 18%;
    width: 1px;
    background: color-mix(in srgb, var(--search-border, #e5e7eb) 50%, transparent);
  }

  .sf-select, .sf-input { font-size: var(--search-input-size, 1rem); }
  .sfs-trigger { font-size: var(--search-input-size, 1rem); }

  /* price inline */
  .sf-price { padding: 4px 16px 12px; }
  .sf-price-grid .sf-input { padding: 9px 14px; font-size: .88rem; }

  /* actions inline */
  .sf-actions {
    flex-direction: row;
    align-items: center;
    gap: 10px;
    padding: 4px 6px 6px;
  }
  .sf-adv-toggle { width: auto; order: 0; flex-shrink: 0; }
  .sf-submit {
    width: auto;
    order: 0;
    padding: 12px 36px;
    min-width: 150px;
    flex-shrink: 0;
    margin-left: auto;
  }

  .sf-advanced { padding: 0 22px; }
  .sf-advanced.open { padding: 22px; }
  .sf-adv-grid { grid-template-columns: repeat(4, 1fr); }
}

/* ≥ 1025 — desktop */
@media (min-width: 1025px) {
  .sf {
    max-width: 1080px;
    margin-top: 40px;
  }

  .sf-tab { padding: 11px 28px; font-size: var(--search-tab-size, .8rem); }

  .sf-card {
    padding: var(--search-card-padding, 6px);
    border-radius: 0 0 18px 18px;
  }

  .sf-group { padding: 14px 18px; border-radius: 12px; }

  .sf-label { font-size: var(--search-label-size, .75rem); margin-bottom: 2px; }
  .sf-select, .sf-input { font-size: var(--search-input-size, 1rem); }
  .sfs-trigger { font-size: var(--search-input-size, 1rem); }

  .sf-price { padding: 5px 18px 12px; }
  .sf-price-grid .sf-input { padding: 9px 14px; border-radius: 8px; font-size: .92rem; }

  .sf-actions { padding: 5px 6px 6px; }
  .sf-submit {
    padding: 12px 44px;
    font-size: var(--search-btn-size, .88rem);
    border-radius: var(--radius-full, 100px);
    min-width: 170px;
  }
  .sf-adv-toggle { padding: 10px 20px; font-size: .75rem; }

  .sf-advanced { padding: 0 24px; border-radius: 18px; }
  .sf-advanced.open { padding: 22px 24px; }
  .sf-adv-grid { grid-template-columns: repeat(7, 1fr); gap: 12px; }
  .sf-mini-label { font-size: .55rem; }
  .sf-mini-select, .sf-mini-input { padding: 8px 10px; font-size: .75rem; border-radius: 8px; }
}

/* ≥ 1400 — ultrawide */
@media (min-width: 1400px) {
  .sf { max-width: 1080px; }
  .sf-group { padding: 16px 20px; }
  .sf-card { padding: 8px; border-radius: 0 0 20px 20px; }
  .sf-advanced { border-radius: 20px; }
}

/* ═══ Location mode toggle (Türkiye / KKTC / Yurtdışı) ═══ */
.sf-location-mode {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 16px 8px;
  flex-wrap: wrap;
}
.sf-mode-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 7px 16px;
  border: 1.5px solid var(--search-border, #e5e7eb);
  border-radius: 50px;
  background: transparent;
  color: var(--color-gray-500, #6b7280);
  font-size: .8rem;
  font-weight: 600;
  letter-spacing: .01em;
  cursor: pointer;
  transition: all .25s cubic-bezier(.4,0,.2,1);
  white-space: nowrap;
}
.sf-mode-count {
  font-size: .65rem;
  font-weight: 700;
  background: color-mix(in srgb, var(--search-accent, var(--color-accent, #c9a96e)) 15%, transparent);
  color: var(--search-accent, var(--color-accent, #c9a96e));
  padding: 1px 7px;
  border-radius: 20px;
  min-width: 18px;
  text-align: center;
  line-height: 1.4;
}
.sf-mode-btn:hover {
  border-color: var(--search-accent, var(--color-accent, #c9a96e));
  color: var(--search-accent, var(--color-accent, #c9a96e));
  background: color-mix(in srgb, var(--search-accent, var(--color-accent, #c9a96e)) 4%, transparent);
}
.sf-mode-btn.active {
  background: var(--search-accent, var(--color-accent, #c9a96e));
  border-color: var(--search-accent, var(--color-accent, #c9a96e));
  color: #fff;
  box-shadow: 0 2px 8px color-mix(in srgb, var(--search-accent, var(--color-accent, #c9a96e)) 35%, transparent);
}
.sf-mode-btn.active .sf-mode-count {
  background: rgba(255,255,255,.25);
  color: #fff;
}
