/* ============================================================
   STAF GROS — searchbar.css  v2.0
   Redesigned: Montserrat/Open Sans fonts, hero-matched palette,
   fixed z-index stacking via JS body-teleport pattern
   ============================================================ */

/* ── Theme variables ──────────────────────────────────────── */
/* Scoped CSS vars */
.sg-search, .sg-searchbar {
  --sg-red:        #D42B2B;
  --sg-red2:       #b52020;
  --sg-red-bg:     rgba(212,43,43,0.07);
  --sg-red-soft:   rgba(212,43,43,0.12);
  --sg-navy:       #0d1b2a;
  --sg-navy2:      #162535;
  --sg-dark:       #1e2d3d;
  --sg-mid:        #4a5568;
  --sg-muted:      #7a8898;
  --sg-border:     #e4e0d9;
  --sg-bg:         #f7f5f1;
  --sg-white:      #ffffff;
  --sg-green:      #0ea970;
}

/* ── Theme-proof reset ────────────────────────────────────── */
.sg-search,
.sg-search *,
.sg-search *::before,
.sg-search *::after { box-sizing: border-box !important; }
.sg-search button,
.sg-search input,
.sg-search a {
  font-family: 'Open Sans', -apple-system, BlinkMacSystemFont, sans-serif !important;
  letter-spacing: normal !important; text-transform: none !important; text-decoration: none !important;
}
.sg-search button {
  border: none !important; border-radius: 0 !important; background: none !important;
  padding: 0 !important; margin: 0 !important; cursor: pointer !important;
  -webkit-appearance: none !important; box-shadow: none !important;
}

/* ── Container ────────────────────────────────────────────── */
.sg-search {
  position: relative;
  width: 100%;
  font-family: 'Open Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  font-size: 14px;
  z-index: 10;
}

/* ── PORTAL MODE — teleported to body on mobile ── */
.sg-search.sg-search--portal {
  position: fixed !important;
  inset: 0 !important;
  z-index: 99999 !important;
  margin: 0 !important;
  max-width: 100% !important;
  display: flex !important;
  flex-direction: column !important;
  background: var(--sg-white) !important;
  padding: 16px 14px 0 !important;
  animation: sg-portal-in .2s cubic-bezier(.4,0,.2,1) both;
}
@keyframes sg-portal-in {
  from { opacity: 0; transform: translateY(-10px); }
  to   { opacity: 1; transform: none; }
}

/* ── Input wrapper ────────────────────────────────────────── */
.sg-search__input-wrap {
  position: relative; display: flex; align-items: center;
  background: var(--sg-white) !important;
  border: 2px solid var(--sg-border) !important;
  border-radius: 12px !important;
  transition: border-color .2s, box-shadow .2s;
  overflow: hidden; flex-shrink: 0;
}
.sg-search__input-wrap:focus-within {
  border-color: var(--sg-red) !important;
  box-shadow: 0 0 0 3px rgba(212,43,43,0.1), 0 4px 16px rgba(0,0,0,.06) !important;
}
.sg-search.is-open .sg-search__input-wrap {
  border-bottom-left-radius: 0 !important;
  border-bottom-right-radius: 0 !important;
  border-bottom-color: transparent !important;
}
/* Portal: always fully rounded since dropdown is in-flow */
.sg-search.sg-search--portal .sg-search__input-wrap {
  border-radius: 12px !important;
  border-bottom-left-radius: 12px !important;
  border-bottom-right-radius: 12px !important;
  border-bottom-color: var(--sg-border) !important;
}
.sg-search.sg-search--portal .sg-search__input-wrap:focus-within {
  border-bottom-color: var(--sg-red) !important;
}

.sg-search__icon {
  position: absolute; left: 16px;
  color: var(--sg-muted); pointer-events: none; flex-shrink: 0; transition: color .2s;
}
.sg-search__input-wrap:focus-within .sg-search__icon { color: var(--sg-red); }

.sg-search__input {
  width: 100% !important; padding: 14px 90px 14px 48px !important;
  border: none !important; background: transparent !important;
  font-size: 15px !important; font-weight: 500 !important;
  color: var(--sg-dark) !important; outline: none !important;
  box-shadow: none !important; -webkit-appearance: none !important;
}
.sg-search__input::placeholder { color: var(--sg-muted) !important; font-weight: 400 !important; }
.sg-search__input::-webkit-search-cancel-button,
.sg-search__input::-webkit-search-decoration { -webkit-appearance: none !important; display: none !important; }

.sg-search__spinner {
  display: none; position: absolute; right: 48px;
  align-items: center; justify-content: center;
}
.sg-search__spinner svg { animation: sg-search-spin .8s linear infinite; color: var(--sg-red); }
@keyframes sg-search-spin { to { transform: rotate(360deg); } }

.sg-search__clear {
  position: absolute !important; right: 14px !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  width: 28px !important; height: 28px !important; border-radius: 50% !important;
  background: var(--sg-bg) !important; color: var(--sg-muted) !important;
  transition: background .15s, color .15s !important;
  -webkit-tap-highlight-color: transparent; z-index: 2;
}
.sg-search__clear:hover { background: var(--sg-red-bg) !important; color: var(--sg-red) !important; }

/* ── Voice Search ─────────────────────────────────────────── */
.sg-search--has-voice .sg-search__input { padding-right: 120px !important; }
.sg-search__mic {
  position: absolute !important; right: 48px !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  width: 32px !important; height: 32px !important; border-radius: 50% !important;
  background: var(--sg-bg) !important; color: var(--sg-muted) !important;
  border: none !important; padding: 0 !important; cursor: pointer !important;
  transition: background .2s, color .2s, transform .15s, box-shadow .2s !important;
  z-index: 2; -webkit-tap-highlight-color: transparent;
}
@media (hover: hover) {
  .sg-search__mic:hover { background: var(--sg-red-bg) !important; color: var(--sg-red) !important; transform: scale(1.08); }
}
.sg-search__mic:active { transform: scale(.92) !important; }
.sg-search__mic:focus-visible { outline: 2px solid var(--sg-red) !important; outline-offset: 2px; }
.sg-search__mic-icon { display: block; transition: opacity .2s; }
.sg-search__mic-pulse {
  display: none; position: absolute; top: 4px; right: 4px;
  width: 8px; height: 8px; border-radius: 50%; background: var(--sg-red);
}
.sg-search.is-listening .sg-search__mic {
  background: var(--sg-red) !important; color: #fff !important;
  box-shadow: 0 0 0 4px rgba(212,43,43,0.2) !important;
  animation: sg-mic-breathe 1.5s ease-in-out infinite !important;
}
.sg-search.is-listening .sg-search__mic-pulse {
  display: block; background: #fff; animation: sg-mic-dot-pulse 1s ease-in-out infinite;
}
@keyframes sg-mic-breathe {
  0%,100% { transform: scale(1); box-shadow: 0 0 0 4px rgba(212,43,43,0.2); }
  50%      { transform: scale(1.06); box-shadow: 0 0 0 8px rgba(212,43,43,0.1); }
}
@keyframes sg-mic-dot-pulse {
  0%,100% { opacity: 1; transform: scale(1); }
  50%      { opacity: .4; transform: scale(.7); }
}
.sg-search.is-listening .sg-search__input-wrap {
  border-color: var(--sg-red) !important;
  box-shadow: 0 0 0 3px rgba(212,43,43,0.08) !important;
}
.sg-search--has-voice .sg-search__spinner { right: 86px; }
.sg-search .sg-sr-only {
  position: absolute !important; width: 1px !important; height: 1px !important;
  padding: 0 !important; margin: -1px !important; overflow: hidden !important;
  clip: rect(0,0,0,0) !important; border: 0 !important;
}

/* ── Camera / Image Search ────────────────────────────────── */
.sg-search__cam {
  position: absolute !important; right: 48px !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  width: 32px !important; height: 32px !important; border-radius: 50% !important;
  background: var(--sg-bg) !important; color: var(--sg-muted) !important;
  border: none !important; padding: 0 !important; cursor: pointer !important;
  transition: background .2s, color .2s, transform .15s !important;
  z-index: 2; -webkit-tap-highlight-color: transparent;
}
@media (hover: hover) {
  .sg-search__cam:hover { background: var(--sg-red-bg) !important; color: var(--sg-red) !important; transform: scale(1.08); }
}
.sg-search__cam:active { transform: scale(.92) !important; }
.sg-search__cam:focus-visible { outline: 2px solid var(--sg-red) !important; outline-offset: 2px; }
.sg-search__cam-icon { display: block; }
.sg-search--has-camera .sg-search__input { padding-right: 120px !important; }
.sg-search--has-camera .sg-search__cam { right: 48px !important; }
.sg-search--has-camera .sg-search__spinner { right: 86px; }
.sg-search--has-camera.sg-search--has-voice .sg-search__input { padding-right: 156px !important; }
.sg-search--has-camera.sg-search--has-voice .sg-search__cam { right: 84px !important; }
.sg-search--has-camera.sg-search--has-voice .sg-search__spinner { right: 120px; }

.sg-search__cam-menu {
  position: absolute; z-index: 200;
  background: var(--sg-white); border: 1px solid var(--sg-border);
  border-radius: 12px;
  box-shadow: 0 8px 32px rgba(13,27,42,.14), 0 2px 8px rgba(13,27,42,.06);
  padding: 6px; min-width: 200px;
}
.sg-search__cam-option {
  display: flex !important; align-items: center !important; gap: 10px !important;
  width: 100% !important; padding: 10px 14px !important; border-radius: 8px !important;
  font-size: 13.5px !important; font-weight: 500 !important;
  color: var(--sg-dark) !important; background: none !important;
  border: none !important; cursor: pointer !important; transition: background .15s !important;
}
.sg-search__cam-option:hover { background: var(--sg-bg) !important; }
.sg-search__cam-option svg { flex-shrink: 0; color: var(--sg-muted); }
.sg-search__file-input {
  position: absolute !important; width: 1px !important; height: 1px !important;
  overflow: hidden !important; clip: rect(0,0,0,0) !important; border: 0 !important;
}

/* Image preview bar */
.sg-search__imgbar {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 14px; border-bottom: 1px solid var(--sg-border); background: var(--sg-bg);
}
.sg-search__imgbar-thumb {
  width: 48px; height: 48px; object-fit: cover;
  border-radius: 8px; border: 2px solid var(--sg-border); flex-shrink: 0;
}
.sg-search__imgbar-status { flex: 1; min-width: 0; }
.sg-search__imgbar-text {
  display: block; font-size: 12.5px; font-weight: 500;
  color: var(--sg-mid); margin-top: 4px; line-height: 1.4; word-break: break-word;
}
.sg-search__imgbar-text.is-error { color: var(--sg-red); font-size: 11.5px; }
.sg-search__imgbar-progress {
  width: 100%; height: 3px; background: var(--sg-border); border-radius: 2px; overflow: hidden;
}
.sg-search__imgbar-progress-bar {
  height: 100%; background: var(--sg-red); border-radius: 2px; width: 0%; transition: width .3s;
}
.sg-search__imgbar-remove {
  flex-shrink: 0; display: flex !important; align-items: center !important; justify-content: center !important;
  width: 28px !important; height: 28px !important; border-radius: 50% !important;
  background: transparent !important; color: var(--sg-muted) !important;
  transition: background .15s, color .15s !important;
}
.sg-search__imgbar-remove:hover { background: var(--sg-red-bg) !important; color: var(--sg-red) !important; }

.sg-search.is-analyzing .sg-search__input-wrap {
  border-color: var(--sg-red) !important;
  animation: sg-analyze-pulse 1.5s ease-in-out infinite !important;
}
@keyframes sg-analyze-pulse {
  0%,100% { box-shadow: 0 0 0 0px rgba(212,43,43,0.1); }
  50%      { box-shadow: 0 0 0 6px rgba(212,43,43,0.08); }
}
.sg-search.is-analyzing .sg-search__cam { background: var(--sg-red) !important; color: #fff !important; }

.sg-search__labels { padding: 10px 14px 6px; border-bottom: 1px solid var(--sg-border); }
.sg-search__labels-title {
  display: block; font-size: 10px; font-weight: 700; color: var(--sg-muted);
  text-transform: uppercase; letter-spacing: .1em; margin-bottom: 8px;
  font-family: 'Montserrat', sans-serif !important;
}
.sg-search__labels-list { display: flex; flex-wrap: wrap; gap: 6px; padding-bottom: 6px; }
.sg-search__label-pill {
  display: inline-flex !important; align-items: center !important;
  padding: 4px 12px !important; border-radius: 20px !important;
  border: 1.5px solid var(--sg-red) !important; background: transparent !important;
  color: var(--sg-red) !important; font-size: 12px !important; font-weight: 600 !important;
  cursor: pointer !important; transition: background .15s, color .15s !important; white-space: nowrap;
}
.sg-search__label-pill:hover { background: var(--sg-red) !important; color: #fff !important; }
.sg-search__label-pill--logo { border-color: var(--sg-navy) !important; color: var(--sg-navy) !important; }
.sg-search__label-pill--logo:hover { background: var(--sg-navy) !important; color: #fff !important; }
.sg-search__color-swatch {
  display: inline-block; width: 22px; height: 22px; border-radius: 50%;
  border: 2px solid var(--sg-white); box-shadow: 0 0 0 1px var(--sg-border); flex-shrink: 0;
}
.sg-search__sim { display: flex; align-items: center; gap: 6px; margin-top: 4px; }
.sg-search__sim-bar { flex: 1; height: 3px; background: var(--sg-red); border-radius: 2px; max-width: 80px; }
.sg-search__sim-text { font-size: 10.5px; font-weight: 700; color: var(--sg-red); white-space: nowrap; }

/* ══════════════════════════════════════════════════════════════
   DROPDOWN
   ══════════════════════════════════════════════════════════════ */
.sg-search__dropdown {
  position: absolute; top: 100%; left: 0; right: 0;
  background: var(--sg-white);
  border: 2px solid var(--sg-red); border-top: none;
  border-radius: 0 0 14px 14px;
  box-shadow: 0 12px 40px rgba(13,27,42,.12), 0 4px 12px rgba(13,27,42,.06);
  max-height: 70vh; overflow-y: auto; overscroll-behavior: contain;
  scrollbar-width: thin; scrollbar-color: var(--sg-border) transparent;
  z-index: 9999;
}
.sg-search__dropdown::-webkit-scrollbar { width: 4px; }
.sg-search__dropdown::-webkit-scrollbar-thumb { background: var(--sg-border); border-radius: 4px; }

/* Portal: dropdown flows in-document */
.sg-search.sg-search--portal .sg-search__dropdown {
  position: relative !important; top: 0 !important;
  border: none !important; border-top: 1px solid var(--sg-border) !important;
  border-radius: 0 !important; box-shadow: none !important;
  max-height: none !important; flex: 1 !important;
  overflow-y: auto !important; z-index: auto !important; margin-top: 10px;
}

/* Section titles */
.sg-search__section-title {
  display: flex; align-items: center; gap: 6px;
  padding: 10px 16px 6px;
  font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .1em;
  color: var(--sg-muted); font-family: 'Montserrat', sans-serif !important;
}
.sg-search__section-title svg { flex-shrink: 0; opacity: .6; }

/* Category pills */
.sg-search__cat-list { display: flex; flex-wrap: wrap; gap: 6px; padding: 4px 16px 12px; }
.sg-search__cat-pill {
  display: inline-flex !important; align-items: center !important; gap: 5px !important;
  padding: 6px 14px !important; background: var(--sg-bg) !important;
  border: 1.5px solid var(--sg-border) !important; border-radius: 999px !important;
  font-size: 12px !important; font-weight: 700 !important; color: var(--sg-mid) !important;
  transition: all .15s !important; white-space: nowrap;
  font-family: 'Montserrat', sans-serif !important;
}
.sg-search__cat-pill:hover, .sg-search__cat-pill.is-focused {
  border-color: var(--sg-red) !important; color: var(--sg-red) !important;
  background: var(--sg-red-bg) !important;
}
.sg-search__cat-pill--brand { border-color: var(--sg-navy) !important; background: rgba(13,27,42,.04) !important; }
.sg-search__cat-pill--brand:hover, .sg-search__cat-pill--brand.is-focused {
  border-color: var(--sg-navy) !important; background: rgba(13,27,42,.1) !important; color: var(--sg-navy) !important;
}
.sg-search__cat-count {
  font-size: 10px; font-weight: 700; color: var(--sg-muted);
  background: var(--sg-white); padding: 1px 6px; border-radius: 999px; min-width: 18px; text-align: center;
}

/* Product rows */
.sg-search__product-row {
  display: flex !important; align-items: center !important; gap: 12px !important;
  padding: 10px 16px !important; color: var(--sg-dark) !important;
  border-bottom: 1px solid rgba(0,0,0,.04); transition: background .12s !important;
}
.sg-search__product-row:last-child { border-bottom: none; }
.sg-search__product-row:hover, .sg-search__product-row.is-focused { background: var(--sg-bg) !important; }

.sg-search__result-img {
  position: relative; width: 52px; height: 52px; flex-shrink: 0;
  border-radius: 8px; overflow: hidden; background: var(--sg-bg); border: 1px solid var(--sg-border);
}
.sg-search__result-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.sg-search__badge {
  position: absolute; top: 2px; left: 2px; padding: 1px 5px;
  font-size: 8px; font-weight: 800; text-transform: uppercase;
  background: var(--sg-red); color: #fff; border-radius: 4px; letter-spacing: .03em;
  font-family: 'Montserrat', sans-serif !important;
}
.sg-search__result-body { flex: 1; min-width: 0; }
.sg-search__result-meta { display: flex; gap: 6px; margin-bottom: 2px; }
.sg-search__result-cat, .sg-search__result-brand {
  font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em;
  color: var(--sg-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  font-family: 'Montserrat', sans-serif !important;
}
.sg-search__result-brand { color: var(--sg-red); }
.sg-search__result-name {
  font-size: 13.5px; font-weight: 600; color: var(--sg-dark); line-height: 1.35;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.sg-search__result-sku { font-size: 11px; color: var(--sg-muted); margin-top: 1px; }
.sg-search__result-price {
  text-align: right; font-size: 14px; font-weight: 700; color: var(--sg-navy);
  white-space: nowrap; flex-shrink: 0; font-family: 'Montserrat', sans-serif !important;
}
.sg-search__result-price del { font-size: 11px; font-weight: 400; color: var(--sg-muted); display: block; }
.sg-search__result-price ins { text-decoration: none; color: var(--sg-red); }
.sg-search__oos { display: block; font-size: 10px; font-weight: 600; color: var(--sg-muted); margin-top: 2px; }
.sg-search__result-right { display: flex; flex-direction: column; align-items: flex-end; gap: 4px; flex-shrink: 0; }
.sg-search__score { width: 40px; height: 3px; background: var(--sg-border); border-radius: 2px; overflow: hidden; }
.sg-search__score-bar { height: 100%; background: var(--sg-green); border-radius: 2px; transition: width .3s ease; min-width: 2px; }

/* Suggestions */
.sg-search__suggest { padding: 12px 16px 14px; border-top: 1px solid rgba(0,0,0,.04); }
.sg-search__suggest-label {
  display: block; font-size: 10px; font-weight: 700; color: var(--sg-muted); margin-bottom: 8px;
  text-transform: uppercase; letter-spacing: .1em; font-family: 'Montserrat', sans-serif !important;
}
.sg-search__suggest-list { display: flex; flex-wrap: wrap; gap: 6px; }
.sg-search__suggest-link {
  display: inline-flex !important; align-items: center !important;
  padding: 7px 16px !important; background: var(--sg-red-bg) !important;
  border: 1.5px solid var(--sg-red-soft) !important; border-radius: 999px !important;
  font-size: 13px !important; font-weight: 600 !important; color: var(--sg-red) !important;
  transition: all .15s !important; white-space: nowrap;
}
.sg-search__suggest-link:hover, .sg-search__suggest-link.is-focused {
  background: var(--sg-red) !important; color: #fff !important; border-color: var(--sg-red) !important;
}

/* Highlight */
.sg-search__highlight {
  background: rgba(212,43,43,0.12); color: var(--sg-red); font-weight: 700; border-radius: 2px; padding: 0 1px;
}

/* Empty state */
.sg-search__empty {
  padding: 32px 20px; text-align: center; display: flex; flex-direction: column; align-items: center; gap: 10px;
}
.sg-search__empty svg { color: var(--sg-border); }
.sg-search__empty p { margin: 0; font-size: 13.5px; font-weight: 500; color: var(--sg-muted); }

/* View all */
.sg-search__view-all {
  display: flex !important; align-items: center !important; justify-content: center !important;
  gap: 6px !important; padding: 13px 16px !important;
  background: var(--sg-bg) !important; border-top: 1.5px solid var(--sg-border) !important;
  border-radius: 0 0 12px 12px !important;
  font-size: 11px !important; font-weight: 800 !important; color: var(--sg-red) !important;
  transition: background .15s !important; letter-spacing: .06em; text-transform: uppercase;
  font-family: 'Montserrat', sans-serif !important;
}
.sg-search__view-all:hover, .sg-search__view-all.is-focused { background: var(--sg-red-bg) !important; }
.sg-search__view-all svg { transition: transform .2s; }
.sg-search__view-all:hover svg { transform: translateX(3px); }

/* ── History ──────────────────────────────────────────────── */
.sg-search__section-head {
  display: flex; align-items: center; justify-content: space-between; padding: 10px 16px 4px;
}
.sg-search__section-head .sg-search__section-title { padding: 0; }
.sg-search__history-clear {
  font-size: 10px !important; color: var(--sg-muted) !important; cursor: pointer !important;
  transition: color .15s !important; font-family: 'Montserrat', sans-serif !important;
  font-weight: 700 !important; letter-spacing: .06em !important; text-transform: uppercase !important;
}
.sg-search__history-clear:hover { color: var(--sg-red) !important; }
.sg-search__history-list { padding: 0 8px 8px; }
.sg-search__history-item {
  display: flex !important; align-items: center !important; gap: 10px !important;
  width: 100% !important; padding: 9px 12px !important; border-radius: 8px !important;
  font-size: 13.5px !important; color: var(--sg-dark) !important;
  cursor: pointer !important; transition: background .15s !important; text-align: left !important;
}
.sg-search__history-item:hover, .sg-search__history-item.is-focused { background: var(--sg-red-bg) !important; }
.sg-search__history-item svg { color: var(--sg-muted); flex-shrink: 0; }
.sg-search__history-item span { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.sg-search__history-arrow { color: var(--sg-border); flex-shrink: 0; margin-left: auto; }
.sg-search__history-item:hover .sg-search__history-arrow { color: var(--sg-red); }

/* ── Trending ─────────────────────────────────────────────── */
.sg-search__trending { padding-bottom: 6px; }
.sg-search__trending-terms { display: flex; flex-wrap: wrap; gap: 6px; padding: 6px 16px 10px; }
.sg-search__trending-term {
  display: inline-flex !important; align-items: center !important; gap: 5px !important;
  padding: 5px 12px !important; border-radius: 999px !important;
  font-size: 11px !important; font-weight: 700 !important; color: var(--sg-mid) !important;
  background: var(--sg-bg) !important; border: 1px solid var(--sg-border) !important;
  cursor: pointer !important; transition: all .15s !important; white-space: nowrap !important;
  font-family: 'Montserrat', sans-serif !important;
}
.sg-search__trending-term:hover, .sg-search__trending-term.is-focused {
  color: var(--sg-red) !important; border-color: var(--sg-red) !important; background: var(--sg-red-bg) !important;
}
.sg-search__trending-term svg { flex-shrink: 0; opacity: .5; }
.sg-search__trending-products { padding: 0 8px; }
.sg-search__trending-product {
  display: flex !important; align-items: center !important; gap: 12px !important;
  padding: 8px 12px !important; border-radius: 8px !important;
  transition: background .15s !important; text-decoration: none !important; color: var(--sg-dark) !important;
}
.sg-search__trending-product:hover, .sg-search__trending-product.is-focused { background: var(--sg-red-bg) !important; }

/* ══════════════════════════════════════════════════════════════
   BACKDROP — separate element injected at body level by JS
   z-index: 99998 (just below portal at 99999)
   ══════════════════════════════════════════════════════════════ */
#sg-search-backdrop {
  display: none;
  position: fixed; inset: 0;
  background: rgba(13,27,42,0.55);
  z-index: 99998;
  -webkit-backdrop-filter: blur(3px);
  backdrop-filter: blur(3px);
  transition: opacity .25s ease;
  opacity: 0;
}
#sg-search-backdrop.is-active { display: block; opacity: 1; }

/* Hide old inline overlay — replaced by body-level backdrop */
.sg-search__overlay { display: none !important; }

/* Portal nav header — back arrow + label above the input.
   Replaces the old sg-search__portal-close which overlapped
   the sg-search__clear (X) button causing the double-X bug. */
.sg-search__portal-nav {
  display: none; /* hidden in normal mode */
  align-items: center;
  gap: 10px;
  padding: 0 0 12px;
  flex-shrink: 0;
}
.sg-search.sg-search--portal .sg-search__portal-nav {
  display: flex;
}
.sg-search__portal-back {
  display: flex !important; align-items: center !important; justify-content: center !important;
  width: 38px !important; height: 38px !important; border-radius: 50% !important;
  background: var(--sg-bg) !important; color: var(--sg-mid) !important;
  border: none !important; cursor: pointer !important; flex-shrink: 0 !important;
  transition: background .15s, color .15s !important;
  -webkit-tap-highlight-color: transparent;
}
.sg-search__portal-back:hover { background: var(--sg-red-bg) !important; color: var(--sg-red) !important; }
.sg-search__portal-label {
  font-family: 'Montserrat', sans-serif;
  font-size: 15px; font-weight: 700; color: var(--sg-navy);
  letter-spacing: .01em;
}

/* ── Animations ───────────────────────────────────────────── */
@keyframes sg-search-fadein {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: none; }
}
.sg-search__dropdown:not([hidden]) { animation: sg-search-fadein .15s ease both; }
.sg-search.sg-search--portal .sg-search__dropdown:not([hidden]) { animation: none; }

/* ── Responsive (non-portal mobile) ──────────────────────── */
@media (max-width: 768px) {
  .sg-search { max-width: 100%; }
  .sg-search__input { padding: 12px 80px 12px 44px !important; font-size: 16px !important; }
  .sg-search--has-voice .sg-search__input { padding-right: 110px !important; }
  .sg-search--has-camera .sg-search__input { padding-right: 110px !important; }
  .sg-search--has-camera.sg-search--has-voice .sg-search__input { padding-right: 142px !important; }
  .sg-search__icon { left: 14px; width: 16px; height: 16px; }
  .sg-search__mic { width: 30px !important; height: 30px !important; right: 44px !important; }
  .sg-search__cam { width: 30px !important; height: 30px !important; }
  .sg-search--has-camera .sg-search__cam { right: 44px !important; }
  .sg-search--has-camera.sg-search--has-voice .sg-search__cam { right: 78px !important; }
  .sg-search--has-voice .sg-search__spinner { right: 78px; }
  .sg-search--has-camera .sg-search__spinner { right: 78px; }
  .sg-search--has-camera.sg-search--has-voice .sg-search__spinner { right: 112px; }
  .sg-search__dropdown { max-height: 60vh; }
  .sg-search__product-row { padding: 8px 12px !important; gap: 10px !important; }
  .sg-search__result-img { width: 44px; height: 44px; border-radius: 6px; }
  .sg-search__result-name { font-size: 12.5px; }
  .sg-search__result-price { font-size: 13px; }
  .sg-search__labels-list { flex-wrap: nowrap; overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; padding-bottom: 8px; }
  .sg-search__labels-list::-webkit-scrollbar { display: none; }
}

/* Portal-specific responsive tweaks */
.sg-search.sg-search--portal .sg-search__input { font-size: 16px !important; padding: 14px 80px 14px 48px !important; }
.sg-search.sg-search--portal.sg-search--has-voice .sg-search__input { padding-right: 116px !important; }
.sg-search.sg-search--portal.sg-search--has-camera .sg-search__input { padding-right: 116px !important; }
.sg-search.sg-search--portal.sg-search--has-camera.sg-search--has-voice .sg-search__input { padding-right: 152px !important; }
.sg-search.sg-search--portal .sg-search__mic, .sg-search.sg-search--portal .sg-search__cam { width: 40px !important; height: 40px !important; }
.sg-search.sg-search--portal .sg-search__history-item { padding: 12px 14px !important; min-height: 48px !important; font-size: 14.5px !important; }
.sg-search.sg-search--portal .sg-search__trending-term { padding: 8px 14px !important; font-size: 13px !important; min-height: 36px !important; }
.sg-search.sg-search--portal .sg-search__product-row, .sg-search.sg-search--portal .sg-search__trending-product { padding: 10px 14px !important; min-height: 52px !important; }

@media (max-width: 480px) {
  .sg-search__input-wrap { border-radius: 10px !important; }
  .sg-search.is-open .sg-search__input-wrap { border-bottom-left-radius: 0 !important; border-bottom-right-radius: 0 !important; }
  .sg-search__cat-pill { padding: 5px 10px !important; font-size: 11px !important; }
  .sg-search__result-img { width: 40px; height: 40px; }
  .sg-search__imgbar-thumb { width: 40px; height: 40px; }
  .sg-search__label-pill { padding: 3px 10px !important; font-size: 11px !important; }
  .sg-search__dropdown { border-radius: 0 0 10px 10px; max-height: 55vh; }
}

@media (prefers-reduced-motion: reduce) {
  .sg-search__dropdown:not([hidden]) { animation: none; }
  .sg-search__spinner svg { animation-duration: .01ms !important; }
  .sg-search.is-listening .sg-search__mic { animation: none !important; }
  .sg-search__mic-pulse { animation: none !important; }
  .sg-search.is-analyzing .sg-search__input-wrap { animation: none !important; }
  .sg-search__imgbar-progress-bar { transition: none !important; }
  .sg-search.sg-search--portal { animation: none; }
}


/* ════════════════════════════════════════════════════════════════
   IMAGE SEARCH v8.0 — Mobile overlay, AI badge, similarity chips
   ════════════════════════════════════════════════════════════════ */

/* AI badge on camera button */
.sg-search__cam { position: relative; }
.sg-cam-ai-badge { display: none; }

/* Google Vision badge on overlay header */
.sg-vision-badge {
  background: #e8f0fe; color: #1a73e8;
  font-size: 10px; font-weight: 700;
  padding: 2px 8px; border-radius: 20px; letter-spacing: .03em;
  white-space: nowrap;
}

/* ── Full-screen mobile overlay ─────────────────────────────── */
.sg-img-overlay {
  position: fixed; inset: 0; z-index: 99999;
  display: flex; align-items: flex-end; justify-content: center;
}
.sg-img-overlay[hidden] { display: none !important; }

.sg-img-overlay__backdrop {
  position: absolute; inset: 0;
  background: rgba(13,27,42,.55);
  backdrop-filter: blur(4px);
  animation: sg-fade-in .2s ease;
}
@keyframes sg-fade-in { from { opacity:0 } to { opacity:1 } }

.sg-img-overlay__panel {
  position: relative; z-index: 1;
  background: var(--sg-white,#fff);
  border-radius: 24px 24px 0 0;
  width: 100%; max-width: 520px;
  max-height: 90vh; overflow-y: auto;
  padding: 0 0 env(safe-area-inset-bottom,0);
  animation: sg-slide-up .28s cubic-bezier(.34,1.28,.64,1);
  box-shadow: 0 -8px 48px rgba(13,27,42,.18);
}
@keyframes sg-slide-up {
  from { transform: translateY(120%); opacity:0 }
  to   { transform: translateY(0);    opacity:1 }
}
@media (min-width: 768px) {
  .sg-img-overlay { align-items: center; }
  .sg-img-overlay__panel { border-radius: 20px; max-height: 80vh; }
  @keyframes sg-slide-up {
    from { transform: translateY(20px) scale(.97); opacity:0 }
    to   { transform: none; opacity:1 }
  }
}

/* Header */
.sg-img-overlay__header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 20px 14px;
  border-bottom: 1px solid var(--sg-border,#e5e7eb);
}
.sg-img-overlay__title {
  display: flex; align-items: center; gap: 8px;
  font-size: 15px; font-weight: 700; color: var(--sg-dark,#0d1b2a);
}
.sg-img-overlay__close {
  width: 32px; height: 32px; border: none; background: var(--sg-bg,#f7f9fb);
  border-radius: 50%; cursor: pointer; display: flex; align-items: center;
  justify-content: center; color: var(--sg-muted,#6b7280);
  transition: background .15s;
}
.sg-img-overlay__close:hover { background: var(--sg-border,#e5e7eb); }

/* AI chip */
.sg-ai-chip, .sg-vision-badge {
  background: #e8f0fe; color: #1a73e8;
  font-size: 10px; font-weight: 700;
  padding: 2px 8px; border-radius: 20px; letter-spacing: .03em;
}

/* Body */
.sg-img-overlay__body { padding: 20px; }

/* Option cards */
.sg-img-overlay__options {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
  margin-bottom: 16px;
}
.sg-img-opt {
  display: flex; flex-direction: column; align-items: center;
  gap: 10px; padding: 20px 12px; border-radius: 16px;
  border: 2px solid var(--sg-border,#e5e7eb);
  background: var(--sg-bg,#f7f9fb);
  cursor: pointer; transition: all .18s;
  text-align: center;
}
.sg-img-opt:hover, .sg-img-opt:active {
  border-color: var(--sg-primary,#e63128);
  background: #fff5f5;
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(230,49,40,.12);
}
.sg-img-opt__icon {
  width: 56px; height: 56px; border-radius: 16px;
  background: #fff; display: flex; align-items: center; justify-content: center;
  color: var(--sg-primary,#e63128);
  box-shadow: 0 2px 8px rgba(13,27,42,.08);
}
.sg-img-opt__label { font-size: 13px; font-weight: 600; color: var(--sg-dark,#0d1b2a); }
.sg-img-opt__sub   { font-size: 11px; color: var(--sg-muted,#6b7280); }

.sg-img-overlay__hint {
  text-align: center; font-size: 12px; color: var(--sg-muted,#6b7280);
  line-height: 1.5; padding: 0 4px;
}

/* ── Analyzing state ─────────────────────────────────────────── */
.sg-img-overlay__analyzing { padding: 24px 20px; }

.sg-img-preview-wrap {
  position: relative; margin: 0 auto 24px;
  width: 120px; height: 120px; border-radius: 16px;
  overflow: hidden; box-shadow: 0 4px 20px rgba(13,27,42,.15);
}
.sg-img-preview {
  width: 100%; height: 100%; object-fit: cover;
}
.sg-img-preview__scan {
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, transparent, var(--sg-primary,#e63128), transparent);
  animation: sg-scan 1.8s ease-in-out infinite;
}
@keyframes sg-scan {
  0%   { top: 0; opacity: 1 }
  50%  { opacity: 1 }
  100% { top: calc(100% - 3px); opacity: 0 }
}

.sg-analyzing-steps {
  display: flex; flex-direction: column; gap: 12px;
}
.sg-step {
  display: flex; align-items: center; gap: 12px;
  font-size: 13.5px; color: var(--sg-muted,#6b7280);
  transition: color .3s;
}
.sg-step.is-active { color: var(--sg-dark,#0d1b2a); font-weight: 600; }
.sg-step.is-done   { color: #22c55e; }
.sg-step__dot {
  width: 20px; height: 20px; border-radius: 50%;
  border: 2px solid var(--sg-border,#e5e7eb);
  flex-shrink: 0; transition: all .3s;
  display: flex; align-items: center; justify-content: center;
}
.sg-step.is-active .sg-step__dot {
  border-color: var(--sg-primary,#e63128);
  background: var(--sg-primary,#e63128);
  box-shadow: 0 0 0 4px rgba(230,49,40,.15);
  animation: sg-pulse 1s ease infinite;
}
@keyframes sg-pulse { 50% { box-shadow: 0 0 0 8px rgba(230,49,40,.08) } }
.sg-step.is-done .sg-step__dot {
  border-color: #22c55e; background: #22c55e;
}
.sg-step.is-done .sg-step__dot::after {
  content: ''; display: block; width: 6px; height: 4px;
  border-left: 2px solid #fff; border-bottom: 2px solid #fff;
  transform: rotate(-45deg) translateY(-1px);
}

/* ── Results state ───────────────────────────────────────────── */
.sg-img-overlay__results { padding: 0 0 20px; }

.sg-img-result-header {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 20px; border-bottom: 1px solid var(--sg-border,#e5e7eb);
}
.sg-img-result-thumb {
  width: 52px; height: 52px; border-radius: 10px; object-fit: cover;
  border: 2px solid var(--sg-border,#e5e7eb); flex-shrink: 0;
}
.sg-img-result-info { flex: 1; min-width: 0; }
.sg-img-result-type {
  font-size: 14px; font-weight: 700; color: var(--sg-dark,#0d1b2a);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.sg-ai-source {
  font-size: 10px; font-weight: 600; color: #8b5cf6;
  background: #f5f3ff; padding: 1px 6px; border-radius: 8px; margin-left: 4px;
}
.sg-img-result-count { font-size: 12px; color: var(--sg-muted,#6b7280); margin-top: 2px; }
.sg-img-result-clear {
  width: 28px; height: 28px; border: none;
  background: var(--sg-bg,#f7f9fb); border-radius: 50%;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  color: var(--sg-muted,#6b7280); flex-shrink: 0;
}

/* Pills row */
.sg-img-pills {
  display: flex; flex-wrap: wrap; gap: 6px;
  padding: 12px 20px 4px;
}

/* Categories */
.sg-img-cats {
  display: flex; flex-wrap: wrap; gap: 6px;
  padding: 4px 20px 8px;
}

/* Product cards in overlay */
.sg-img-products {
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px;
  padding: 8px 20px 4px;
}
@media (min-width: 420px) {
  .sg-img-products { grid-template-columns: repeat(3,1fr); }
}

.sg-img-prod-card {
  display: flex; flex-direction: column;
  border-radius: 12px; overflow: hidden;
  border: 1px solid var(--sg-border,#e5e7eb);
  background: #fff; text-decoration: none;
  transition: transform .15s, box-shadow .15s;
}
.sg-img-prod-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(13,27,42,.1);
}
.sg-img-prod-card__img {
  position: relative; aspect-ratio: 1; overflow: hidden;
  background: var(--sg-bg,#f7f9fb);
}
.sg-img-prod-card__img img {
  width: 100%; height: 100%; object-fit: cover;
}
.sg-img-prod-card__body {
  padding: 8px; display: flex; flex-direction: column; gap: 3px;
}
.sg-img-prod-card__name {
  font-size: 11.5px; font-weight: 600; color: var(--sg-dark,#0d1b2a);
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.sg-img-prod-card__cat {
  font-size: 10px; color: var(--sg-muted,#6b7280);
}
.sg-img-prod-card__price {
  font-size: 12px; font-weight: 700; color: var(--sg-primary,#e63128);
  margin-top: 2px;
}

/* Similarity chip */
.sg-sim-chip {
  display: inline-flex; align-items: center;
  font-size: 9.5px; font-weight: 700; letter-spacing: .02em;
  padding: 2px 7px; border-radius: 20px; line-height: 1.4;
  margin-bottom: 2px; width: fit-content;
}
.sg-sim-chip--high { background: #dcfce7; color: #15803d; }
.sg-sim-chip--mid  { background: #dbeafe; color: #1d4ed8; }
.sg-sim-chip--low  { background: #f3f4f6; color: #4b5563; }

/* No results */
.sg-img-noresult {
  padding: 32px 20px; text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  color: var(--sg-muted,#6b7280);
}
.sg-img-noresult p { font-size: 13.5px; font-weight: 600; margin: 0; color: var(--sg-dark,#0d1b2a); }
.sg-img-noresult__sub { font-size: 12px !important; color: var(--sg-muted,#6b7280) !important; font-weight: 400 !important; }

/* Label pill types */
.sg-search__label-pill.is-type { background: #fff5f5; color: var(--sg-primary,#e63128); border-color: rgba(230,49,40,.3); }
.sg-search__label-pill.is-color { background: #f5f3ff; color: #7c3aed; border-color: rgba(124,58,237,.3); }
.sg-search__label-pill.is-material { background: #f0fdf4; color: #15803d; border-color: rgba(21,128,61,.3); }
