/**
 * Smart Store Locator — SCORCHED EARTH Theme
 * Bebas Neue (display) · Plus Jakarta Sans (body)
 * Palette: Fire Red #E8321A · Flame Orange #F97316 · Ember #FBB040
 *
 * @package SmartStoreLocator
 */

/* ── Design Tokens (scoped to plugin wrapper) ────────────────────────────── */
.ssl-wrapper,
.ssl-single-main {
  --fire:        #E8321A;
  --fire-deep:   #C4200C;
  --flame:       #F97316;
  --ember:       #FBB040;
  --smoke:       #0D0B0A;
  --ash:         #1A1310;
  --cinder:      #251C18;
  --cinder-mid:  #312520;
  --glass:       rgba(20, 14, 11, 0.88);
  --glass-light: rgba(30, 22, 17, 0.72);
  --glow-red:    rgba(232, 50, 26, 0.18);
  --glow-orange: rgba(249, 115, 22, 0.14);
  --border:      rgba(232, 50, 26, 0.22);
  --border-hot:  rgba(249, 115, 22, 0.5);
  --text:        #F5EDE8;
  --text-muted:  rgba(245, 237, 232, 0.5);
  --text-dim:    rgba(245, 237, 232, 0.28);
  --panel-w:     390px;
  --font-display: 'Bebas Neue', Impact, sans-serif;
  --font-body:    'Plus Jakarta Sans', system-ui, sans-serif;
  --ease: cubic-bezier(.4, 0, .2, 1);
}

/* ── Base Reset (scoped — excludes Leaflet internals) ─────────────────────── */
.ssl-wrapper,
.ssl-wrapper *,
.ssl-wrapper *::before,
.ssl-wrapper *::after {
  box-sizing: border-box !important;
}

/* Restore Leaflet's own box-sizing to prevent layout breakage */
.ssl-wrapper .leaflet-pane,
.ssl-wrapper .leaflet-pane *,
.ssl-wrapper .leaflet-control-container,
.ssl-wrapper .leaflet-control-container * {
  box-sizing: content-box !important;
}

/* Reset margin/padding only on OUR elements, not Leaflet's */
.ssl-wrapper > .ssl-topbar,
.ssl-wrapper > .ssl-panel,
.ssl-wrapper > .ssl-coord-toast,
.ssl-panel *,
.ssl-panel *::before,
.ssl-panel *::after {
  margin: 0 !important;
  padding: 0 !important;
}

.ssl-wrapper {
  font-family: var(--font-body) !important;
  font-size: 14px !important;
  color: var(--text) !important;
  line-height: 1.5 !important;
  -webkit-font-smoothing: antialiased !important;
  -moz-osx-font-smoothing: grayscale !important;
  position: relative !important;
  background: var(--smoke) !important;
  overflow: hidden !important;
  width: 100% !important;
  height: 600px !important; /* Default; shortcode height="" attr uses inline style to override */
  min-height: 400px !important;
  border-radius: 12px !important;
}

/* Override WordPress theme link colors & text-decoration globally */
.ssl-wrapper a,
.ssl-wrapper a:link,
.ssl-wrapper a:visited,
.ssl-wrapper a:hover,
.ssl-wrapper a:focus,
.fire-popup a,
.fire-popup a:link,
.fire-popup a:visited,
.fire-popup a:hover,
.fire-popup a:focus {
  color: inherit !important;
  text-decoration: none !important;
  text-decoration-thickness: 0 !important;
}

/* Override WP block theme heading sizes & weights inside our wrapper */
.ssl-wrapper h1,
.ssl-wrapper h2,
.ssl-wrapper h3,
.ssl-wrapper h4,
.ssl-wrapper h5,
.ssl-wrapper h6 {
  font-family: var(--font-body) !important;
  font-size: inherit !important;
  font-weight: inherit !important;
  line-height: inherit !important;
  letter-spacing: inherit !important;
  margin: 0 !important;
}

/* ── WP Admin Bar offset — no-op, wrapper is container-based ─────────────── */

/* ── TOPBAR ───────────────────────────────────────────────────────────────── */
.ssl-topbar {
  position: absolute !important;
  top: 0 !important; left: var(--panel-w) !important; right: 0 !important;
  height: 52px !important;
  z-index: 1000 !important;
  background: linear-gradient(180deg, rgba(13,11,10,0.98) 0%, rgba(13,11,10,0.0) 100%) !important;
  display: flex !important;
  align-items: center !important;
  padding: 0 20px !important;
  pointer-events: none !important;
}

.ssl-topbar-brand {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  pointer-events: all !important;
}

.ssl-brand-flame {
  width: 32px !important; height: 32px !important;
  position: relative !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
}

.ssl-brand-flame svg {
  filter: drop-shadow(0 0 6px var(--flame)) !important;
  animation: ssl-flicker 2.8s ease-in-out infinite alternate !important;
}

@keyframes ssl-flicker {
  0%   { filter: drop-shadow(0 0 4px var(--flame)) brightness(1) !important; }
  40%  { filter: drop-shadow(0 0 10px var(--fire)) brightness(1.1) !important; }
  70%  { filter: drop-shadow(0 0 6px var(--ember)) brightness(1.05) !important; }
  100% { filter: drop-shadow(0 0 14px var(--flame)) brightness(1.15) !important; }
}

.ssl-brand-name {
  font-family: var(--font-display) !important;
  font-size: 22px !important;
  letter-spacing: .06em !important;
  line-height: 1 !important;
  background: linear-gradient(135deg, var(--text) 0%, var(--ember) 100%) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
}

/* ── PANEL ────────────────────────────────────────────────────────────────── */
.ssl-panel {
  position: absolute !important;
  top: 0 !important; left: 0 !important; bottom: 0 !important;
  width: var(--panel-w) !important;
  z-index: 900 !important;
  display: flex !important;
  flex-direction: column !important;
  background: var(--glass) !important;
  backdrop-filter: blur(24px) saturate(1.4) !important;
  -webkit-backdrop-filter: blur(24px) saturate(1.4) !important;
  border-right: 1px solid var(--border) !important;
  box-shadow: 4px 0 40px rgba(0,0,0,.6), inset -1px 0 0 var(--glow-red) !important;
}

.ssl-panel::after {
  content: '' !important;
  position: absolute !important;
  top: 0 !important; right: -1px !important; bottom: 0 !important;
  width: 1px !important;
  background: linear-gradient(180deg,
    transparent 0%,
    var(--fire) 25%,
    var(--flame) 50%,
    var(--fire) 75%,
    transparent 100%
  ) !important;
  opacity: 0.6 !important;
  animation: ssl-edgePulse 3s ease-in-out infinite alternate !important;
}

@keyframes ssl-edgePulse {
  from { opacity: 0.3 !important; transform: scaleY(.95) !important; }
  to   { opacity: 0.8 !important; transform: scaleY(1.02) !important; }
}

/* ── PANEL HEADER ─────────────────────────────────────────────────────────── */
.ssl-panel-header {
  padding: 52px 20px 0 !important;
  flex-shrink: 0 !important;
}

.ssl-panel-title {
  font-family: var(--font-display) !important;
  font-size: 40px !important;
  letter-spacing: .04em !important;
  line-height: .95 !important;
  margin: 0 0 4px !important;
  font-weight: 400 !important;
  color: var(--text) !important;
  text-transform: uppercase !important;
}

.ssl-panel-title span {
  display: block !important;
  background: linear-gradient(90deg, var(--fire) 0%, var(--flame) 60%, var(--ember) 100%) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
}

.ssl-panel-subtitle {
  font-size: 12px !important;
  font-weight: 500 !important;
  color: var(--text-muted) !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  margin-bottom: 18px !important;
}

/* ── SEARCH ───────────────────────────────────────────────────────────────── */
.ssl-search-wrap {
  padding: 0 20px !important;
  flex-shrink: 0 !important;
}

.ssl-search-field {
  position: relative !important;
  margin-bottom: 10px !important;
}

.ssl-search-icon {
  position: absolute !important;
  left: 13px !important; top: 50% !important;
  transform: translateY(-50%) !important;
  color: var(--text-dim) !important;
  pointer-events: none !important;
  transition: color .2s var(--ease) !important;
}

.ssl-search-input {
  width: 100% !important;
  height: 46px !important;
  padding: 0 44px 0 42px !important;
  background: var(--cinder) !important;
  border: 1.5px solid rgba(232,50,26,.18) !important;
  border-radius: 10px !important;
  font-family: var(--font-body) !important;
  font-size: 14px !important;
  color: var(--text) !important;
  outline: none !important;
  transition: border-color .2s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease) !important;
}

.ssl-search-input::placeholder { color: var(--text-dim) !important; }

.ssl-search-input:focus {
  border-color: var(--flame) !important;
  background: var(--cinder-mid) !important;
  box-shadow: 0 0 0 3px rgba(249,115,22,.12), 0 0 20px rgba(249,115,22,.08) !important;
}

.ssl-search-input:focus ~ .ssl-search-icon { color: var(--flame) !important; }
.ssl-search-field:focus-within .ssl-search-icon { color: var(--flame) !important; }

.ssl-locate-btn {
  position: absolute !important;
  right: 8px !important; top: 50% !important;
  transform: translateY(-50%) !important;
  width: 30px !important; height: 30px !important;
  background: transparent !important;
  border: none !important;
  cursor: pointer !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  color: var(--text-dim) !important;
  border-radius: 6px !important;
  transition: color .2s var(--ease), background .2s var(--ease) !important;
}

.ssl-locate-btn:hover { color: var(--flame) !important; background: rgba(249,115,22,.1) !important; }
.ssl-locate-btn.is-loading { color: var(--flame) !important; animation: ssl-spin .8s linear infinite !important; }

@keyframes ssl-spin { to { transform: translateY(-50%) rotate(360deg) !important; } }

/* ── FILTERS ROW ──────────────────────────────────────────────────────────── */
.ssl-filters-row {
  display: flex !important;
  gap: 8px !important;
  margin-bottom: 14px !important;
}

.ssl-filter-select {
  flex: 1 !important;
  height: 38px !important;
  padding: 0 28px 0 11px !important;
  background: var(--cinder) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='rgba(245,237,232,0.35)' d='M5 6L0 0h10z'/%3E%3C/svg%3E") no-repeat right 9px center !important;
  border: 1.5px solid rgba(232,50,26,.18) !important;
  border-radius: 8px !important;
  font-family: var(--font-body) !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  color: var(--text-muted) !important;
  appearance: none !important;
  outline: none !important;
  cursor: pointer !important;
  transition: border-color .2s var(--ease) !important;
  min-width: 0 !important;
}

.ssl-filter-select:focus { border-color: var(--flame) !important; }

.ssl-filter-select option {
  color: #1A1310 !important;
  background: #fff !important;
}

.ssl-search-btn {
  flex-shrink: 0 !important;
  height: 38px !important;
  padding: 0 16px !important;
  background: linear-gradient(135deg, var(--fire) 0%, var(--flame) 100%) !important;
  border: none !important;
  border-radius: 8px !important;
  font-family: var(--font-body) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  color: #fff !important;
  cursor: pointer !important;
  display: flex !important; align-items: center !important; gap: 6px !important;
  transition: opacity .2s var(--ease), transform .15s var(--ease), box-shadow .2s var(--ease) !important;
  box-shadow: 0 4px 16px rgba(232,50,26,.4) !important;
  white-space: nowrap !important;
  letter-spacing: .02em !important;
}

.ssl-search-btn:hover { opacity: .92 !important; transform: translateY(-1px) !important; box-shadow: 0 6px 22px rgba(232,50,26,.5) !important; }
.ssl-search-btn:active { transform: translateY(0) !important; }
.ssl-search-btn:disabled,
.ssl-search-btn.is-loading { opacity: .6 !important; cursor: wait !important; }

/* ── DIVIDER ──────────────────────────────────────────────────────────────── */
.ssl-panel-divider {
  height: 1px !important;
  background: linear-gradient(90deg, transparent, var(--border) 30%, var(--border) 70%, transparent) !important;
  margin: 0 20px 14px !important;
  flex-shrink: 0 !important;
}

/* ── RESULTS HEADER ───────────────────────────────────────────────────────── */
.ssl-results-header {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 0 20px 10px !important;
  flex-shrink: 0 !important;
}

.ssl-results-count {
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .1em !important;
  color: var(--text-dim) !important;
}

.ssl-results-count strong {
  color: var(--flame) !important;
  font-size: 14px !important;
  font-weight: 700 !important;
}

.ssl-reset-btn {
  font-family: var(--font-body) !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  color: var(--text-dim) !important;
  background: transparent !important;
  border: none !important;
  cursor: pointer !important;
  display: none !important;
  align-items: center !important;
  gap: 4px !important;
  padding: 4px 8px !important;
  border-radius: 5px !important;
  transition: color .2s var(--ease), background .2s var(--ease) !important;
  letter-spacing: .04em !important;
  text-transform: uppercase !important;
}

.ssl-reset-btn.visible { display: flex !important; }
.ssl-reset-btn:hover { color: var(--fire) !important; background: var(--glow-red) !important; }

/* ── STATUS MSG ───────────────────────────────────────────────────────────── */
.ssl-status-msg {
  margin: 0 20px 10px !important;
  padding: 10px 14px !important;
  background: rgba(232,50,26,.08) !important;
  border: 1px solid rgba(232,50,26,.2) !important;
  border-radius: 8px !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  color: rgba(249,115,22,.9) !important;
  display: none !important;
  flex-shrink: 0 !important;
}

.ssl-status-msg.visible { display: block !important; }

/* ── RESULTS LIST ─────────────────────────────────────────────────────────── */
.ssl-results-list {
  flex: 1 !important;
  overflow-y: auto !important;
  padding: 0 20px 20px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
  scrollbar-width: thin !important;
  scrollbar-color: var(--cinder-mid) transparent !important;
}

.ssl-results-list::-webkit-scrollbar { width: 3px !important; }
.ssl-results-list::-webkit-scrollbar-track { background: transparent !important; }
.ssl-results-list::-webkit-scrollbar-thumb { background: var(--cinder-mid) !important; border-radius: 99px !important; }

/* ── STORE CARD ───────────────────────────────────────────────────────────── */
.ssl-card {
  background: var(--cinder) !important;
  border: 1.5px solid rgba(232,50,26,.14) !important;
  border-radius: 12px !important;
  padding: 14px 16px !important;
  cursor: pointer !important;
  transition: border-color .2s var(--ease), box-shadow .2s var(--ease), transform .2s var(--ease), background .2s var(--ease) !important;
  position: relative !important;
  overflow: hidden !important;
  animation: ssl-slideIn .25s var(--ease) both !important;
  flex-shrink: 0 !important;
}

@keyframes ssl-slideIn {
  from { opacity: 0 !important; transform: translateX(-14px) !important; }
  to   { opacity: 1 !important; transform: translateX(0) !important; }
}

.ssl-card:nth-child(1)  { animation-delay: .02s !important; }
.ssl-card:nth-child(2)  { animation-delay: .04s !important; }
.ssl-card:nth-child(3)  { animation-delay: .06s !important; }
.ssl-card:nth-child(4)  { animation-delay: .08s !important; }
.ssl-card:nth-child(5)  { animation-delay: .10s !important; }
.ssl-card:nth-child(6)  { animation-delay: .12s !important; }
.ssl-card:nth-child(7)  { animation-delay: .14s !important; }
.ssl-card:nth-child(8)  { animation-delay: .16s !important; }
.ssl-card:nth-child(9)  { animation-delay: .18s !important; }
.ssl-card:nth-child(10) { animation-delay: .20s !important; }

/* Heat shimmer line at top on hover */
.ssl-card::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important; left: 0 !important; right: 0 !important;
  height: 2px !important;
  background: linear-gradient(90deg, var(--fire), var(--flame), var(--ember)) !important;
  opacity: 0 !important;
  transition: opacity .2s var(--ease) !important;
  border-radius: 12px 12px 0 0 !important;
}

.ssl-card:hover {
  border-color: rgba(249,115,22,.4) !important;
  background: var(--cinder-mid) !important;
  box-shadow: 0 4px 24px rgba(0,0,0,.4), 0 0 0 1px rgba(249,115,22,.15) !important;
  transform: translateX(3px) !important;
}

.ssl-card:hover::before { opacity: 1 !important; }

.ssl-card.is-active {
  border-color: var(--flame) !important;
  background: linear-gradient(135deg, rgba(232,50,26,.1) 0%, rgba(249,115,22,.06) 100%) !important;
  box-shadow: 0 0 0 1px rgba(249,115,22,.3), 0 4px 20px rgba(232,50,26,.2), 0 8px 32px rgba(0,0,0,.4) !important;
  transform: translateX(4px) !important;
}

.ssl-card.is-active::before { opacity: 1 !important; }

/* Active left accent bar */
.ssl-card.is-active::after {
  content: '' !important;
  position: absolute !important;
  left: 0 !important; top: 0 !important; bottom: 0 !important;
  width: 3px !important;
  background: linear-gradient(180deg, var(--fire), var(--flame)) !important;
  border-radius: 12px 0 0 12px !important;
}

.ssl-card:focus-visible {
  outline: 2px solid var(--flame) !important;
  outline-offset: 2px !important;
}

.ssl-card-header {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 8px !important;
  margin-bottom: 5px !important;
}

.ssl-card-name {
  font-size: 14px !important;
  font-weight: 700 !important;
  line-height: 1.3 !important;
  color: var(--text) !important;
  letter-spacing: -.01em !important;
  margin: 0 !important;
  font-family: var(--font-body) !important;
}

.ssl-card-dist {
  font-size: 10px !important;
  font-weight: 800 !important;
  letter-spacing: .06em !important;
  text-transform: uppercase !important;
  color: var(--flame) !important;
  background: rgba(249,115,22,.12) !important;
  border: 1px solid rgba(249,115,22,.25) !important;
  padding: 2px 8px !important;
  border-radius: 99px !important;
  white-space: nowrap !important;
  flex-shrink: 0 !important;
}

.ssl-card-addr {
  font-size: 12px !important;
  color: var(--text-muted) !important;
  margin: 0 0 10px !important;
  line-height: 1.45 !important;
}

.ssl-card-phone {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  font-size: 12px !important;
  color: var(--text-dim) !important;
  margin-bottom: 10px !important;
}

.ssl-card-phone svg { width: 11px !important; height: 11px !important; flex-shrink: 0 !important; }

.ssl-card-actions {
  display: flex !important;
  gap: 7px !important;
  padding-top: 10px !important;
  border-top: 1px solid rgba(232,50,26,.12) !important;
}

.ssl-card-btn {
  flex: 1 !important;
  height: 33px !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  gap: 5px !important;
  font-family: var(--font-body) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  border-radius: 7px !important;
  text-decoration: none !important;
  cursor: pointer !important;
  transition: all .18s var(--ease) !important;
  border: none !important;
  letter-spacing: .02em !important;
}

.ssl-card-btn svg { width: 11px !important; height: 11px !important; }

.ssl-card-btn-fire,
.ssl-card-btn-fire:link,
.ssl-card-btn-fire:visited {
  background: linear-gradient(135deg, var(--fire), var(--flame)) !important;
  color: #fff !important;
  box-shadow: 0 2px 10px rgba(232,50,26,.3) !important;
}

.ssl-card-btn-fire:hover,
.ssl-card-btn-fire:focus {
  box-shadow: 0 4px 16px rgba(232,50,26,.5) !important;
  color: #fff !important;
  transform: translateY(-1px) !important;
}

.ssl-card-btn-ghost,
.ssl-card-btn-ghost:link,
.ssl-card-btn-ghost:visited {
  background: transparent !important;
  color: var(--text-muted) !important;
  border: 1.5px solid rgba(245,237,232,.1) !important;
}

.ssl-card-btn-ghost:hover,
.ssl-card-btn-ghost:focus {
  border-color: rgba(249,115,22,.4) !important;
  color: var(--flame) !important;
  background: rgba(249,115,22,.06) !important;
}

/* ── EMPTY STATE ──────────────────────────────────────────────────────────── */
.ssl-empty-state {
  padding: 40px 0 !important;
  display: flex !important; flex-direction: column !important;
  align-items: center !important; text-align: center !important;
  gap: 12px !important;
}

.ssl-empty-icon {
  font-size: 42px !important;
  filter: grayscale(1) opacity(.3) !important;
}

.ssl-empty-state h4 { font-size: 15px !important; font-weight: 700 !important; color: var(--text-muted) !important; }
.ssl-empty-state p  { font-size: 12px !important; color: var(--text-dim) !important; max-width: 220px !important; line-height: 1.5 !important; margin: 0 !important; }

/* ── LOAD MORE ────────────────────────────────────────────────────────────── */
.ssl-load-more-wrap { padding: 0 20px 20px !important; flex-shrink: 0 !important; }

.ssl-load-more {
  width: 100% !important;
  height: 40px !important;
  background: transparent !important;
  border: 1.5px dashed rgba(232,50,26,.25) !important;
  border-radius: 10px !important;
  font-family: var(--font-body) !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--fire) !important;
  cursor: pointer !important;
  display: none !important;
  transition: all .2s var(--ease) !important;
}

.ssl-load-more:hover {
  background: var(--glow-red) !important;
  border-color: var(--fire) !important;
  border-style: solid !important;
  box-shadow: 0 0 20px rgba(232,50,26,.15) !important;
}

/* ── MAP ──────────────────────────────────────────────────────────────────── */
.ssl-map {
  position: absolute !important;
  top: 0 !important; left: var(--panel-w) !important; right: 0 !important; bottom: 0 !important;
  z-index: 1 !important;
}

/* Protect Leaflet internals — let Leaflet control its own elements */
.ssl-map * {
  box-sizing: content-box !important;
}
.ssl-map .leaflet-pane,
.ssl-map .leaflet-tile,
.ssl-map .leaflet-marker-icon,
.ssl-map .leaflet-marker-shadow,
.ssl-map .leaflet-tile-container,
.ssl-map .leaflet-map-pane,
.ssl-map .leaflet-overlay-pane,
.ssl-map .leaflet-shadow-pane,
.ssl-map .leaflet-marker-pane,
.ssl-map .leaflet-tooltip-pane,
.ssl-map .leaflet-popup-pane,
.ssl-map .leaflet-control {
  margin: unset !important;
  padding: unset !important;
}

/* Prevent theme img resets from breaking Leaflet tiles */
.ssl-map img {
  max-width: none !important;
  max-height: none !important;
  height: auto !important;
  width: auto !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
  object-fit: unset !important;
}

/* ── LEAFLET CUSTOM STYLES ────────────────────────────────────────────────── */

/* Cluster override */
.ssl-wrapper .marker-cluster-small,
.ssl-wrapper .marker-cluster-medium,
.ssl-wrapper .marker-cluster-large {
  background: rgba(232,50,26,.18) !important;
  border: 2px solid rgba(232,50,26,.5) !important;
}

.ssl-wrapper .marker-cluster-small div,
.ssl-wrapper .marker-cluster-medium div,
.ssl-wrapper .marker-cluster-large div {
  background: linear-gradient(135deg, var(--fire), var(--flame)) !important;
  color: #fff !important;
  font-family: var(--font-body) !important;
  font-weight: 800 !important;
  font-size: 13px !important;
  box-shadow: 0 0 16px rgba(232,50,26,.4) !important;
}

/* Popup */
.fire-popup .leaflet-popup-content-wrapper {
  background: rgba(20, 14, 11, 0.95) !important;
  backdrop-filter: blur(20px) saturate(1.4) !important;
  -webkit-backdrop-filter: blur(20px) saturate(1.4) !important;
  border: 1px solid rgba(249, 115, 22, 0.35) !important;
  border-radius: 14px !important;
  box-shadow: 0 8px 40px rgba(0,0,0,.7), 0 0 0 1px rgba(249,115,22,.1) !important;
  padding: 0 !important;
  overflow: hidden !important;
  color: var(--text) !important;
}

.fire-popup .leaflet-popup-content {
  margin: 0 !important;
  color: var(--text) !important;
}

.fire-popup .leaflet-popup-tip {
  background: rgba(20, 14, 11, 0.95) !important;
  border: 1px solid rgba(249, 115, 22, 0.35) !important;
  border-top: none !important;
  border-left: none !important;
  box-shadow: none !important;
}
.fire-popup .leaflet-popup-close-button {
  color: var(--text) !important;
  font-size: 20px !important;
  font-weight: 300 !important;
  right: 10px !important;
  top: 8px !important;
  width: 24px !important;
  height: 24px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 50% !important;
  transition: background .15s ease, color .15s ease !important;
  text-decoration: none !important;
  opacity: .7 !important;
}

.fire-popup .leaflet-popup-close-button:hover {
  background: rgba(245,237,232,.1) !important;
  color: var(--flame) !important;
  opacity: 1 !important;
}

.ssl-popup-inner {
  font-family: var(--font-body) !important;
  padding: 16px 18px !important;
  min-width: 200px !important;
  max-width: 280px !important;
}

@media (max-width: 800px) {
  .ssl-popup-inner { min-width: 180px !important; max-width: 240px !important; padding: 12px 14px !important; }
  .ssl-popup-name { font-size: 13px !important; }
  .ssl-popup-addr { font-size: 11px !important; margin-bottom: 8px !important; }
  .ssl-popup-btn { height: 32px !important; font-size: 11px !important; padding: 0 10px !important; }
  .ssl-popup-badge { font-size: 9px !important; padding: 1px 6px !important; margin-bottom: 5px !important; }
}

/* Kill all inherited link styles inside popups */
.fire-popup a,
.fire-popup a:visited,
.fire-popup a:link,
.fire-popup a:hover,
.fire-popup a:focus {
  text-decoration: none !important;
}

.ssl-popup-badge {
  display: inline-block !important;
  font-size: 10px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: .1em !important;
  color: var(--flame) !important;
  background: rgba(249,115,22,.12) !important;
  border: 1px solid rgba(249,115,22,.2) !important;
  padding: 2px 8px !important;
  border-radius: 99px !important;
  margin-bottom: 7px !important;
}

.ssl-popup-name {
  font-size: 15px !important;
  font-weight: 700 !important;
  color: var(--text) !important;
  margin: 0 0 4px !important;
  padding: 0 !important;
  line-height: 1.3 !important;
}

.ssl-popup-addr {
  font-size: 12px !important;
  color: var(--text-muted) !important;
  margin: 0 0 12px !important;
  padding: 0 !important;
  line-height: 1.45 !important;
}

.ssl-popup-actions {
  display: flex !important;
  gap: 8px !important;
  padding-top: 12px !important;
  border-top: 1px solid rgba(232,50,26,.15) !important;
}

.ssl-popup-btn {
  flex: 1 !important;
  height: 34px !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  font-family: var(--font-body) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  border-radius: 7px !important;
  text-decoration: none !important;
  cursor: pointer !important;
  border: none !important;
  transition: all .18s var(--ease) !important;
  white-space: nowrap !important;
  padding: 0 14px !important;
  line-height: 1 !important;
}

.ssl-popup-btn-primary,
.ssl-popup-btn-primary:link,
.ssl-popup-btn-primary:visited,
.ssl-popup-btn-primary:hover,
.ssl-popup-btn-primary:focus {
  background: linear-gradient(135deg, var(--fire), var(--flame)) !important;
  color: #fff !important;
  box-shadow: 0 2px 12px rgba(232,50,26,.35) !important;
}

.ssl-popup-btn-primary:hover { opacity: .9 !important; }

.ssl-popup-btn-outline,
.ssl-popup-btn-outline:link,
.ssl-popup-btn-outline:visited {
  background: transparent !important;
  color: var(--flame) !important;
  border: 1.5px solid rgba(249,115,22,.3) !important;
}

.ssl-popup-btn-outline:hover,
.ssl-popup-btn-outline:focus {
  background: rgba(249,115,22,.08) !important;
  color: var(--ember) !important;
}

/* ── ZOOM CONTROLS ───────────────────────────────────────────────────────── */
.ssl-map .leaflet-control-zoom,
.ssl-detail-map .leaflet-control-zoom {
  border: 1px solid rgba(0,0,0,.12) !important;
  border-radius: 10px !important;
  overflow: hidden !important;
  box-shadow: 0 2px 12px rgba(0,0,0,.15) !important;
}

.ssl-map .leaflet-control-zoom a,
.ssl-detail-map .leaflet-control-zoom a {
  background: #fff !important;
  color: #333 !important;
  border-color: rgba(0,0,0,.08) !important;
  width: 34px !important;
  height: 34px !important;
  line-height: 34px !important;
  font-size: 16px !important;
  text-decoration: none !important;
}

.ssl-map .leaflet-control-zoom a:hover,
.ssl-detail-map .leaflet-control-zoom a:hover {
  background: #f5f5f5 !important;
  color: var(--fire) !important;
}

/* Leaflet attribution */
.ssl-map .leaflet-control-attribution,
.ssl-detail-map .leaflet-control-attribution {
  background: rgba(255,255,255,.75) !important;
  color: #666 !important;
  font-size: 10px !important;
}

.ssl-map .leaflet-control-attribution a,
.ssl-detail-map .leaflet-control-attribution a {
  color: #444 !important;
}

/* ── CUSTOM MARKER ────────────────────────────────────────────────────────── */
.heat-marker { background: none !important; border: none !important; cursor: pointer !important; }

/* Active pulse ring */
@keyframes ssl-pulse-ring {
  0%   { transform: scale(1) !important; opacity: .7 !important; }
  100% { transform: scale(2.8) !important; opacity: 0 !important; }
}

@keyframes ssl-pulse-ring2 {
  0%   { transform: scale(1) !important; opacity: .5 !important; }
  100% { transform: scale(2.2) !important; opacity: 0 !important; }
}

.ssl-user-icon {
  overflow: visible !important;
  background: none !important;
  border: none !important;
}

.ssl-user-dot {
  position: relative !important;
  width: 18px !important;
  height: 18px !important;
  display: block !important;
  margin: 13px !important;
}

/* Inner solid dot — Google-style location indicator in theme color */
.ssl-user-dot::before {
  content: '' !important;
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  transform: translate(-50%, -50%) !important;
  width: 16px !important;
  height: 16px !important;
  background: var(--fire, #E8321A) !important;
  border: 2.5px solid #fff !important;
  border-radius: 50% !important;
  box-shadow:
    0 0 0 3px rgba(232, 50, 26, 0.3),
    0 0 12px rgba(249, 115, 22, 0.5),
    0 2px 6px rgba(0, 0, 0, 0.4) !important;
  z-index: 2 !important;
}

/* Pulsing ring — radiates outward like Google Maps */
.ssl-user-dot::after {
  content: '' !important;
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  transform: translate(-50%, -50%) !important;
  width: 18px !important;
  height: 18px !important;
  border-radius: 50% !important;
  background: rgba(232, 50, 26, 0.25) !important;
  animation: ssl-user-pulse 2s ease-out infinite !important;
  z-index: 1 !important;
}

@keyframes ssl-user-pulse {
  0%   { transform: translate(-50%, -50%) scale(1) !important; opacity: .8 !important; }
  70%  { transform: translate(-50%, -50%) scale(3.5) !important; opacity: 0 !important; }
  100% { transform: translate(-50%, -50%) scale(3.5) !important; opacity: 0 !important; }
}

/* ── COORDINATES TOAST ────────────────────────────────────────────────────── */
.ssl-coord-toast {
  position: absolute !important;
  bottom: 24px !important;
  left: calc(var(--panel-w) + 24px) !important;
  background: rgba(255,255,255,.9) !important;
  backdrop-filter: blur(16px) !important;
  border: 1px solid rgba(0,0,0,.1) !important;
  border-radius: 10px !important;
  padding: 10px 16px !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  color: #555 !important;
  z-index: 800 !important;
  pointer-events: none !important;
  opacity: 0 !important;
  transform: translateY(8px) !important;
  transition: opacity .25s var(--ease), transform .25s var(--ease) !important;
  box-shadow: 0 2px 12px rgba(0,0,0,.1) !important;
}

.ssl-coord-toast.visible {
  opacity: 1 !important;
  transform: translateY(0) !important;
}

/* ── SKELETON LOADING ─────────────────────────────────────────────────────── */
.ssl-skeleton {
  background: var(--cinder) !important;
  border: 1.5px solid rgba(232,50,26,.1) !important;
  border-radius: 12px !important;
  padding: 14px 16px !important;
  flex-shrink: 0 !important;
}

.ssl-skeleton-line {
  height: 12px !important;
  border-radius: 6px !important;
  background: var(--cinder-mid) !important;
  animation: ssl-shimmer 1.5s ease infinite !important;
  margin-bottom: 8px !important;
}

.ssl-skeleton-line--title { width: 70% !important; height: 16px !important; }
.ssl-skeleton-line--addr  { width: 90% !important; }
.ssl-skeleton-line--meta  { width: 50% !important; }
.ssl-skeleton-line--btn   { width: 40% !important; height: 28px !important; border-radius: 7px !important; margin-top: 4px !important; margin-bottom: 0 !important; }

@keyframes ssl-shimmer {
  0%   { opacity: 1 !important; }
  50%  { opacity: .3 !important; }
  100% { opacity: 1 !important; }
}

/* ─────────────────────────────────────────────────────────────────────────────
   SINGLE STORE — DETAIL VIEW
   ───────────────────────────────────────────────────────────────────────────── */
.ssl-single-main {
  font-family: var(--font-body) !important;
  -webkit-font-smoothing: antialiased !important;
  background: var(--smoke) !important;
  color: var(--text) !important;
  min-height: 100vh !important;
  min-height: 100dvh !important;
  font-size: 14px !important;
  line-height: 1.5 !important;
  margin: 0 !important;
  padding: 0 !important;
  max-width: none !important;
  width: 100% !important;
  overflow-x: hidden !important;
}

.ssl-single-main a {
  text-decoration: none !important;
  color: inherit !important;
}

.ssl-single-store {
  margin: 0 !important;
  padding: 0 !important;
}

/* ── Map Hero ─────────────────────────────────────────────────────────────── */
.ssl-detail-map-wrap {
  position: relative !important;
  width: 100% !important;
  height: 420px !important;
  overflow: hidden !important;
}

.ssl-detail-map {
  width: 100% !important;
  height: 100% !important;
}

/* ── Content Container ────────────────────────────────────────────────────── */
.ssl-detail-content {
  max-width: 900px !important;
  margin: -60px auto 0 !important;
  padding: 0 24px 80px !important;
  position: relative !important;
  z-index: 10 !important;
}

/* ── Header Card (overlapping map) ────────────────────────────────────────── */
.ssl-detail-header-card {
  background: var(--cinder) !important;
  border: 1.5px solid rgba(232,50,26,.18) !important;
  border-radius: 16px !important;
  padding: 32px !important;
  margin-bottom: 24px !important;
  box-shadow: 0 8px 40px rgba(0,0,0,.5), 0 0 0 1px rgba(249,115,22,.06) !important;
  position: relative !important;
  overflow: hidden !important;
}

.ssl-detail-header-card::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important; left: 0 !important; right: 0 !important;
  height: 3px !important;
  background: linear-gradient(90deg, var(--fire), var(--flame), var(--ember)) !important;
}

.ssl-detail-header-top {
  display: flex !important;
  gap: 20px !important;
  align-items: flex-start !important;
  margin-bottom: 20px !important;
}

.ssl-detail-avatar {
  width: 72px !important;
  height: 72px !important;
  flex-shrink: 0 !important;
  border-radius: 14px !important;
  overflow: hidden !important;
  border: 2px solid rgba(249,115,22,.25) !important;
  box-shadow: 0 4px 16px rgba(0,0,0,.3) !important;
}

.ssl-detail-avatar img {
  width: 100% !important; height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}

.ssl-detail-header-info { flex: 1 !important; min-width: 0 !important; }

.ssl-detail-cats {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  margin-bottom: 8px !important;
}

.ssl-detail-cat {
  font-size: 10px !important;
  font-weight: 700 !important;
  padding: 3px 10px !important;
  border-radius: 99px !important;
  background: rgba(249,115,22,.12) !important;
  color: var(--flame) !important;
  border: 1px solid rgba(249,115,22,.2) !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  transition: all .2s var(--ease) !important;
}

.ssl-detail-cat:hover {
  background: rgba(249,115,22,.2) !important;
  color: var(--ember) !important;
}

.ssl-detail-title {
  font-family: var(--font-display) !important;
  font-size: clamp(26px, 4vw, 38px) !important;
  font-weight: 400 !important;
  margin: 0 0 8px !important;
  line-height: 1.05 !important;
  letter-spacing: .02em !important;
  color: var(--text) !important;
}

.ssl-detail-address {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  color: var(--text-muted) !important;
  font-size: 13px !important;
  margin: 0 !important;
  line-height: 1.4 !important;
}

.ssl-detail-address svg {
  flex-shrink: 0 !important;
  stroke: var(--flame) !important;
}

/* Action Buttons */
.ssl-detail-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  padding-top: 20px !important;
  border-top: 1px solid rgba(245,237,232,.08) !important;
}

.ssl-detail-btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: 7px !important;
  padding: 10px 20px !important;
  border-radius: 10px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  font-family: var(--font-body) !important;
  cursor: pointer !important;
  transition: all .2s var(--ease) !important;
  border: 1.5px solid transparent !important;
  white-space: nowrap !important;
}

.ssl-detail-btn svg { width: 15px !important; height: 15px !important; flex-shrink: 0 !important; }

.ssl-detail-btn-primary {
  background: linear-gradient(135deg, var(--fire), var(--flame)) !important;
  color: #fff !important;
  box-shadow: 0 3px 14px rgba(232,50,26,.35) !important;
}

.ssl-detail-btn-primary:hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 5px 20px rgba(232,50,26,.45) !important;
  color: #fff !important;
}

.ssl-detail-btn-secondary {
  background: rgba(245,237,232,.06) !important;
  color: var(--text-muted) !important;
  border-color: rgba(245,237,232,.12) !important;
}

.ssl-detail-btn-secondary:hover {
  border-color: rgba(249,115,22,.35) !important;
  color: var(--flame) !important;
  background: rgba(249,115,22,.08) !important;
}

/* ── Detail Cards Grid ────────────────────────────────────────────────────── */
.ssl-detail-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)) !important;
  gap: 16px !important;
  margin-bottom: 24px !important;
}

.ssl-detail-card {
  background: var(--cinder) !important;
  border: 1.5px solid rgba(232,50,26,.12) !important;
  border-radius: 14px !important;
  padding: 24px !important;
  transition: border-color .2s var(--ease), box-shadow .2s var(--ease) !important;
}

.ssl-detail-card:hover {
  border-color: rgba(249,115,22,.25) !important;
  box-shadow: 0 4px 20px rgba(0,0,0,.2) !important;
}

.ssl-detail-card-icon {
  width: 40px !important; height: 40px !important;
  border-radius: 10px !important;
  background: linear-gradient(135deg, rgba(232,50,26,.12), rgba(249,115,22,.08)) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin-bottom: 14px !important;
}

.ssl-detail-card-icon svg {
  stroke: var(--flame) !important;
}

.ssl-detail-card-title {
  font-size: 11px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: .1em !important;
  color: var(--text-dim) !important;
  margin: 0 0 12px !important;
  font-family: var(--font-body) !important;
  line-height: 1.3 !important;
}

.ssl-detail-card-body {
  font-size: 14px !important;
  color: var(--text) !important;
  line-height: 1.6 !important;
}

/* Contact rows */
.ssl-detail-contact-row {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 8px 0 !important;
}

.ssl-detail-contact-row + .ssl-detail-contact-row {
  border-top: 1px solid rgba(245,237,232,.06) !important;
}

.ssl-detail-contact-row svg {
  flex-shrink: 0 !important;
  stroke: var(--text-dim) !important;
}

.ssl-detail-contact-row a {
  color: var(--flame) !important;
  font-weight: 500 !important;
  transition: color .2s var(--ease) !important;
  word-break: break-all !important;
}

.ssl-detail-contact-row a:hover {
  color: var(--ember) !important;
}

/* Address block */
.ssl-detail-address-block {
  font-style: normal !important;
  font-size: 14px !important;
  line-height: 1.7 !important;
  color: var(--text) !important;
  margin-bottom: 12px !important;
}

.ssl-detail-directions-link {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  color: var(--flame) !important;
  padding: 6px 12px !important;
  border-radius: 6px !important;
  border: 1px solid rgba(249,115,22,.2) !important;
  transition: all .2s var(--ease) !important;
}

.ssl-detail-directions-link:hover {
  background: rgba(249,115,22,.08) !important;
  border-color: rgba(249,115,22,.4) !important;
  color: var(--ember) !important;
}

/* Hours table */
.ssl-detail-card-hours { grid-column: 1 / -1 !important; }

.ssl-detail-hours {
  width: 100% !important;
  border-collapse: collapse !important;
  font-size: 13px !important;
}

.ssl-detail-hours td { padding: 9px 0 !important; }
.ssl-detail-hours tr + tr td { border-top: 1px solid rgba(245,237,232,.06) !important; }

.ssl-detail-hours-day {
  color: var(--text-muted) !important;
  font-weight: 500 !important;
  width: 140px !important;
}

.ssl-detail-hours-time {
  color: var(--text) !important;
  font-weight: 600 !important;
  text-align: right !important;
}

.ssl-detail-today td { color: var(--flame) !important; }

.ssl-detail-today-badge {
  display: inline-block !important;
  font-size: 9px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
  background: rgba(249,115,22,.15) !important;
  color: var(--flame) !important;
  padding: 1px 6px !important;
  border-radius: 4px !important;
  margin-left: 6px !important;
  vertical-align: middle !important;
}

.ssl-detail-closed {
  color: var(--fire) !important;
  font-weight: 600 !important;
  font-size: 12px !important;
}

/* ── Description Section ──────────────────────────────────────────────────── */
.ssl-detail-description {
  background: var(--cinder) !important;
  border: 1.5px solid rgba(232,50,26,.12) !important;
  border-radius: 14px !important;
  padding: 28px 32px !important;
  margin-bottom: 24px !important;
}

.ssl-detail-section-title {
  font-family: var(--font-body) !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
  color: var(--text-dim) !important;
  margin: 0 0 16px !important;
  line-height: 1.3 !important;
}

.ssl-detail-description-body {
  font-size: 15px !important;
  line-height: 1.75 !important;
  color: var(--text-muted) !important;
}

.ssl-detail-description-body p { margin: 0 0 14px !important; }
.ssl-detail-description-body p:last-child { margin-bottom: 0 !important; }

/* ── Back Link ────────────────────────────────────────────────────────────── */
.ssl-detail-back {
  padding-top: 16px !important;
}

.ssl-detail-back a {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  color: var(--flame) !important;
  padding: 10px 16px !important;
  border-radius: 8px !important;
  border: 1.5px solid rgba(249,115,22,.15) !important;
  transition: all .2s var(--ease) !important;
}

.ssl-detail-back a:hover {
  background: rgba(249,115,22,.08) !important;
  border-color: rgba(249,115,22,.3) !important;
  color: var(--ember) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   RESPONSIVE — Multi-breakpoint support
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── TABLET (801–1024px): narrower panel ─────────────────────────────────── */
@media (max-width: 1024px) and (min-width: 801px) {
  .ssl-wrapper { --panel-w: 340px; }

  .ssl-panel-title { font-size: 34px !important; }
  .ssl-panel-subtitle { margin-bottom: 14px !important; }
  .ssl-search-input { height: 42px !important; font-size: 13px !important; }
  .ssl-filter-select { height: 36px !important; font-size: 11px !important; }
  .ssl-search-btn { height: 36px !important; padding: 0 14px !important; font-size: 12px !important; }
  .ssl-card { padding: 12px 14px !important; }
  .ssl-card-name { font-size: 13px !important; }
  .ssl-card-addr { font-size: 11px !important; }
  .ssl-card-btn { height: 32px !important; font-size: 11px !important; }

  /* Single store detail on tablet */
  .ssl-detail-content { max-width: 720px !important; padding: 0 20px 60px !important; }
  .ssl-detail-header-card { padding: 28px 24px !important; }
  .ssl-detail-description { padding: 24px 28px !important; }
}

/* ══════════════════════════════════════════════════════════════════════════
   MOBILE (≤800px): SPLIT-SCREEN — Map top · Results bottom
   Wrapper respects parent container. Flex column layout.
   ══════════════════════════════════════════════════════════════════════════ */
@media (max-width: 800px) {

  /* Wrapper: flex column, map on top, panel on bottom */
  .ssl-wrapper {
    --panel-w: 100%;
    display: flex !important;
    flex-direction: column !important;
    min-height: 0 !important;
  }

  /* ── MAP: top half ─────────────────────────────────────────────────────── */
  .ssl-map {
    position: relative !important;
    left: 0 !important;
    top: 0 !important;
    right: auto !important;
    bottom: auto !important;
    width: 100% !important;
    flex: 1 1 50% !important;
    min-height: 180px !important;
    order: -1 !important;
    z-index: 1 !important;
  }

  /* ── TOPBAR: overlay on map, compact ────────────────────────────────────── */
  .ssl-topbar {
    position: absolute !important;
    top: 0 !important; left: 0 !important; right: 0 !important;
    height: 44px !important;
    padding: 0 14px !important;
    z-index: 10 !important;
    background: linear-gradient(180deg, rgba(13,11,10,.85) 0%, transparent 100%) !important;
    pointer-events: none !important;
  }

  .ssl-topbar-brand { pointer-events: all !important; }
  .ssl-brand-flame svg { width: 18px !important; height: 22px !important; }
  .ssl-brand-name { font-size: 18px !important; }

  /* ── PANEL: bottom half, internal scroll ────────────────────────────────── */
  .ssl-panel {
    position: relative !important;
    top: auto !important; left: auto !important; bottom: auto !important;
    width: 100% !important;
    flex: 1 1 50% !important;
    min-height: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
    border-right: none !important;
    border-top: 1px solid var(--border) !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    z-index: 2 !important;
    background: var(--glass) !important;
    backdrop-filter: blur(24px) saturate(1.4) !important;
    -webkit-backdrop-filter: blur(24px) saturate(1.4) !important;
  }

  .ssl-panel::before { display: none !important; }
  .ssl-panel::after { display: none !important; }

  /* ── Hide big title — search IS the header on mobile ────────────────────── */
  .ssl-panel-header { display: none !important; }

  /* ── Compact search area ────────────────────────────────────────────────── */
  .ssl-search-wrap { padding: 8px 14px !important; flex-shrink: 0 !important; }

  .ssl-search-input {
    height: 42px !important;
    font-size: 16px !important; /* Prevents iOS zoom */
    padding: 0 44px 0 38px !important;
    border-radius: 10px !important;
    background: var(--cinder) !important;
  }

  .ssl-search-icon { left: 12px !important; }
  .ssl-search-icon svg { width: 14px !important; height: 14px !important; }
  .ssl-locate-btn { width: 34px !important; height: 34px !important; right: 6px !important; }

  .ssl-filters-row { gap: 6px !important; margin-bottom: 0 !important; }
  .ssl-filter-select { height: 34px !important; font-size: 12px !important; border-radius: 8px !important; flex: 1 1 auto !important; min-width: 0 !important; }
  .ssl-search-btn { height: 34px !important; padding: 0 14px !important; font-size: 12px !important; border-radius: 8px !important; flex: 0 0 auto !important; }

  .ssl-search-field { margin-bottom: 6px !important; }

  /* ── Divider → thin line ────────────────────────────────────────────────── */
  .ssl-panel-divider { margin: 0 14px 4px !important; }

  /* ── Results header ─────────────────────────────────────────────────────── */
  .ssl-results-header { padding: 0 14px 4px !important; flex-shrink: 0 !important; }
  .ssl-results-count { font-size: 10px !important; }
  .ssl-results-count strong { font-size: 12px !important; }

  /* ── Status message ─────────────────────────────────────────────────────── */
  .ssl-status-msg { margin: 0 14px 4px !important; flex-shrink: 0 !important; }

  /* ── Results list — THE scrollable area ─────────────────────────────────── */
  .ssl-results-list {
    flex: 1 !important;
    min-height: 0 !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
    padding: 0 14px 14px !important;
    gap: 6px !important;
  }

  .ssl-load-more-wrap { padding: 0 14px 14px !important; flex-shrink: 0 !important; }

  /* ── Cards — compact for more density ──────────────────────────────────── */
  .ssl-card {
    padding: 10px 12px !important;
    border-radius: 10px !important;
  }

  .ssl-card:hover { transform: none !important; }
  .ssl-card.is-active { transform: none !important; }

  .ssl-card-name { font-size: 13px !important; }
  .ssl-card-addr { font-size: 11px !important; margin-bottom: 4px !important; }
  .ssl-card-phone { font-size: 11px !important; margin-bottom: 6px !important; }
  .ssl-card-phone svg { width: 10px !important; height: 10px !important; }
  .ssl-card-actions { gap: 6px !important; padding-top: 6px !important; }
  .ssl-card-btn { height: 34px !important; font-size: 12px !important; border-radius: 7px !important; }

  /* ── Coord toast: hide on mobile ───────────────────────────────────────── */
  .ssl-coord-toast { display: none !important; }

  /* ── Single store — mobile ─────────────────────────────────────────────── */
  .ssl-detail-map-wrap { height: 260px !important; }
  .ssl-detail-content { margin-top: -40px !important; padding: 0 16px 60px !important; }
  .ssl-detail-header-card { padding: 24px 20px !important; }
  .ssl-detail-header-top { flex-direction: column !important; align-items: center !important; text-align: center !important; gap: 14px !important; }
  .ssl-detail-avatar { width: 64px !important; height: 64px !important; }
  .ssl-detail-title { text-align: center !important; }
  .ssl-detail-address { justify-content: center !important; flex-wrap: wrap !important; }
  .ssl-detail-actions { justify-content: center !important; flex-wrap: wrap !important; }
  .ssl-detail-btn { padding: 10px 16px !important; font-size: 13px !important; }
  .ssl-detail-grid { grid-template-columns: 1fr !important; }
  .ssl-detail-card-hours { grid-column: auto !important; }
  .ssl-detail-card { padding: 20px !important; }
  .ssl-detail-description { padding: 24px 20px !important; }
  .ssl-detail-description-body { font-size: 14px !important; }
}

/* ── SMALL MOBILE (≤480px): tighter spacing ─────────────────────────────── */
@media (max-width: 480px) {
  .ssl-search-wrap { padding: 6px 12px !important; }
  .ssl-search-input { height: 40px !important; padding: 0 42px 0 36px !important; }
  .ssl-filters-row { gap: 4px !important; }
  .ssl-filter-select { height: 32px !important; font-size: 11px !important; padding: 0 22px 0 8px !important; }
  .ssl-search-btn { height: 32px !important; padding: 0 12px !important; font-size: 11px !important; }

  .ssl-panel-divider { margin: 0 12px 3px !important; }
  .ssl-results-header { padding: 0 12px 3px !important; }
  .ssl-results-list { padding: 0 12px 12px !important; gap: 5px !important; }
  .ssl-load-more-wrap { padding: 0 12px 12px !important; }

  .ssl-card { padding: 8px 10px !important; border-radius: 8px !important; }
  .ssl-card-name { font-size: 12px !important; }
  .ssl-card-addr { font-size: 10px !important; margin-bottom: 3px !important; line-height: 1.3 !important; }
  .ssl-card-phone { display: none !important; }
  .ssl-card-actions { padding-top: 5px !important; gap: 5px !important; }
  .ssl-card-btn { height: 32px !important; font-size: 11px !important; }
  .ssl-card-dist { font-size: 9px !important; padding: 1px 6px !important; }

  /* Single store — small mobile */
  .ssl-detail-map-wrap { height: 200px !important; }
  .ssl-detail-content { margin-top: -30px !important; padding: 0 12px 40px !important; }
  .ssl-detail-header-card { padding: 20px 16px !important; border-radius: 12px !important; margin-bottom: 16px !important; }
  .ssl-detail-avatar { width: 56px !important; height: 56px !important; border-radius: 12px !important; }
  .ssl-detail-title { font-size: clamp(22px, 5vw, 28px) !important; }
  .ssl-detail-address { font-size: 12px !important; }
  .ssl-detail-actions { gap: 6px !important; padding-top: 14px !important; }
  .ssl-detail-btn { padding: 9px 14px !important; font-size: 12px !important; gap: 5px !important; border-radius: 8px !important; flex: 1 1 auto !important; justify-content: center !important; min-width: 0 !important; }
  .ssl-detail-btn svg { width: 14px !important; height: 14px !important; }
  .ssl-detail-grid { gap: 12px !important; margin-bottom: 16px !important; }
  .ssl-detail-card { padding: 16px !important; border-radius: 12px !important; }
  .ssl-detail-card-icon { width: 36px !important; height: 36px !important; border-radius: 8px !important; margin-bottom: 10px !important; }
  .ssl-detail-card-icon svg { width: 16px !important; height: 16px !important; }
  .ssl-detail-card-title { font-size: 10px !important; margin-bottom: 10px !important; }
  .ssl-detail-card-body { font-size: 13px !important; }
  .ssl-detail-hours td { padding: 7px 0 !important; }
  .ssl-detail-hours { font-size: 12px !important; }
  .ssl-detail-hours-day { width: 100px !important; }
  .ssl-detail-description { padding: 20px 16px !important; border-radius: 12px !important; margin-bottom: 16px !important; }
  .ssl-detail-section-title { font-size: 12px !important; margin-bottom: 12px !important; }
  .ssl-detail-description-body { font-size: 13px !important; line-height: 1.65 !important; }
  .ssl-detail-back a { font-size: 12px !important; padding: 9px 14px !important; }
}

/* ── EXTRA SMALL (≤380px): tightest ─────────────────────────────────────── */
@media (max-width: 380px) {
  .ssl-search-input { height: 38px !important; font-size: 15px !important; }
  .ssl-locate-btn { width: 28px !important; height: 28px !important; }
  .ssl-filter-select { height: 30px !important; font-size: 10px !important; }
  .ssl-search-btn { height: 30px !important; font-size: 10px !important; }

  .ssl-card { padding: 7px 9px !important; }
  .ssl-card-actions { flex-direction: column !important; gap: 3px !important; }
  .ssl-card-btn { height: 30px !important; font-size: 11px !important; }

  .ssl-detail-content { padding: 0 10px 32px !important; }
  .ssl-detail-header-card { padding: 16px 14px !important; }
  .ssl-detail-title { font-size: 20px !important; }
  .ssl-detail-btn { padding: 8px 12px !important; font-size: 11px !important; }
  .ssl-detail-card { padding: 14px !important; }
  .ssl-detail-description { padding: 16px 14px !important; }
}

/* ── LANDSCAPE PHONES (short + wide) ─────────────────────────────────────── */
@media (max-width: 900px) and (max-height: 500px) and (orientation: landscape) {
  .ssl-wrapper {
    --panel-w: 280px;
    display: flex !important;
    flex-direction: row !important;
  }

  .ssl-panel {
    position: relative !important;
    top: auto !important; left: auto !important; bottom: auto !important;
    flex: 0 0 var(--panel-w) !important;
    width: var(--panel-w) !important;
    height: 100% !important;
    border-right: 1px solid var(--border) !important;
    border-top: none !important;
    border-radius: 0 !important;
    order: 0 !important;
  }

  .ssl-panel::before { display: none !important; }
  .ssl-panel::after { display: block !important; }

  .ssl-map {
    position: relative !important;
    left: auto !important;
    flex: 1 !important;
    height: 100% !important;
    order: 1 !important;
  }

  .ssl-topbar { left: var(--panel-w) !important; padding: 0 16px !important; }
  .ssl-panel-header { display: block !important; padding-top: 48px !important; }
  .ssl-panel-title { font-size: 26px !important; }
  .ssl-search-input { height: 38px !important; font-size: 13px !important; }
  .ssl-filter-select { height: 34px !important; }
  .ssl-search-btn { height: 34px !important; }
  .ssl-card { padding: 10px 12px !important; }
  .ssl-card-name { font-size: 12px !important; }
  .ssl-card-btn { height: 30px !important; font-size: 11px !important; }

  .ssl-coord-toast { display: none !important; }
}

/* ── SINGLE STORE — WP block theme full-width override (all sizes) ───────── */
.ssl-single-main {
  max-width: none !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* WP block theme wrapper overrides for single store pages */
body:has(.ssl-single-main) .wp-site-blocks,
body:has(.ssl-single-main) .wp-site-blocks > *,
body:has(.ssl-single-main) .entry-content,
body:has(.ssl-single-main) .wp-block-post-content,
body.ssl-has-single-store .wp-site-blocks,
body.ssl-has-single-store .wp-site-blocks > *,
body.ssl-has-single-store .entry-content,
body.ssl-has-single-store .wp-block-post-content {
  max-width: none !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

body:has(.ssl-single-main) .wp-block-post-title,
body.ssl-has-single-store .wp-block-post-title {
  display: none !important;
}

/* ── Reduced motion ───────────────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  .ssl-wrapper *,
  .ssl-wrapper *::before,
  .ssl-wrapper *::after,
  .ssl-single-main *,
  .ssl-single-main *::before,
  .ssl-single-main *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* ── Print ────────────────────────────────────────────────────────────────── */
@media print {
  .ssl-topbar,
  .ssl-search-wrap,
  .ssl-status-msg,
  .ssl-load-more,
  .ssl-reset-btn,
  .ssl-coord-toast { display: none !important; }
  .ssl-map { position: static !important; height: 400px !important; }
  .ssl-panel { position: static !important; width: 100% !important; }
}
