:root { --slp-primary: #C8952A; --slp-btn-text: #FFFFFF; --slp-btn-outline: #C8952A; }

/* ── Wrapper ── */
.slp-wrap {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif !important;
  font-size: 14px !important;
  color: #222 !important;
  border: 1px solid #e5e7eb !important;
  border-radius: 10px !important;
  overflow: hidden !important;
  box-shadow: 0 2px 16px rgba(0,0,0,.07) !important;
  width: 100% !important;
  box-sizing: border-box !important;
  line-height: 1.5 !important;
}
.slp-wrap *, .slp-wrap *::before, .slp-wrap *::after {
  box-sizing: border-box !important;
}

/* ── Search bar ── */
.slp-wrap .slp-search-bar {
  display: flex !important;
  gap: 10px !important;
  padding: 12px 14px !important;
  background: #fff !important;
  border-bottom: 1px solid #e5e7eb !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  margin: 0 !important;
}
.slp-wrap .slp-search-input-wrap {
  flex: 1 1 180px !important;
  min-width: 0 !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  background: #f3f4f6 !important;
  border: 1px solid #e5e7eb !important;
  border-radius: 8px !important;
  padding: 0 12px !important;
  transition: border-color .2s !important;
  margin: 0 !important;
}
.slp-wrap .slp-search-input-wrap:focus-within {
  border-color: var(--slp-primary) !important;
}
.slp-wrap .slp-search-input-wrap svg {
  flex-shrink: 0 !important;
  color: #9ca3af !important;
  display: block !important;
}
.slp-wrap #slp-search {
  flex: 1 !important;
  min-width: 0 !important;
  border: none !important;
  background: transparent !important;
  padding: 10px 0 !important;
  font-size: 13.5px !important;
  outline: none !important;
  color: #111 !important;
  width: 100% !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  margin: 0 !important;
  line-height: 1.5 !important;
}
.slp-wrap #slp-country-filter {
  flex-shrink: 0 !important;
  padding: 9px 10px !important;
  border: 1px solid #d1d5db !important;
  border-radius: 8px !important;
  font-size: 13px !important;
  background: #fff !important;
  cursor: pointer !important;
  color: #374151 !important;
  outline: none !important;
  max-width: 160px !important;
  margin: 0 !important;
  box-shadow: none !important;
  line-height: 1.5 !important;
  height: auto !important;
}
.slp-wrap #slp-country-filter:focus {
  border-color: var(--slp-primary) !important;
}
.slp-wrap #slp-reset {
  flex-shrink: 0 !important;
  padding: 9px 16px !important;
  background: var(--slp-primary) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 8px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: opacity .2s !important;
  white-space: nowrap !important;
  margin: 0 !important;
  box-shadow: none !important;
  text-transform: none !important;
  letter-spacing: normal !important;
  line-height: 1.5 !important;
  display: inline-block !important;
  text-decoration: none !important;
  outline: none !important;
  height: auto !important;
  width: auto !important;
}
.slp-wrap #slp-reset:hover { opacity: .85 !important; background: var(--slp-primary) !important; }

/* ── Body ── */
.slp-wrap .slp-body {
  display: flex !important;
  overflow: hidden !important;
  width: 100% !important;
}

/* ── List panel ── */
.slp-wrap .slp-list-panel {
  width: 320px !important;
  min-width: 240px !important;
  max-width: 320px !important;
  flex-shrink: 0 !important;
  overflow-y: auto !important;
  background: #fafafa !important;
  border-right: 1px solid #e5e7eb !important;
  display: flex !important;
  flex-direction: column !important;
  margin: 0 !important;
  padding: 0 !important;
}
.slp-wrap .slp-results-count {
  padding: 8px 14px !important;
  font-size: 12px !important;
  color: #6b7280 !important;
  border-bottom: 1px solid #eee !important;
  background: #fff !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 5 !important;
  margin: 0 !important;
}
.slp-wrap #slp-count { font-weight: 700 !important; color: var(--slp-primary) !important; }

/* ── Store card ── */
.slp-wrap .slp-store-card {
  padding: 13px 14px !important;
  border-bottom: 1px solid #f0f0f0 !important;
  cursor: pointer !important;
  background: #fff !important;
  transition: background .15s, border-left .15s !important;
  border-left: 3px solid transparent !important;
  border-top: none !important;
  border-right: none !important;
  margin: 0 !important;
}
.slp-wrap .slp-store-card:hover,
.slp-wrap .slp-store-card.slp-active {
  background: #fffbf0 !important;
  border-left-color: var(--slp-primary) !important;
}
.slp-wrap .slp-store-card .slp-card-title {
  margin: 0 0 6px !important;
  padding: 0 !important;
  font-size: 13.5px !important;
  font-weight: 700 !important;
  color: #111827 !important;
  line-height: 1.3 !important;
  background: none !important;
  border: none !important;
  text-transform: none !important;
  letter-spacing: normal !important;
}
.slp-wrap .slp-store-card .slp-card-p {
  margin: 3px 0 !important;
  padding: 0 !important;
  font-size: 12px !important;
  color: #4b5563 !important;
  line-height: 1.45 !important;
  display: flex !important;
  align-items: flex-start !important;
  gap: 5px !important;
  word-break: break-word !important;
  background: none !important;
  border: none !important;
}
.slp-wrap .slp-si {
  flex-shrink: 0 !important;
  font-size: 11px !important;
  margin-top: 1px !important;
}
.slp-wrap .slp-link {
  color: var(--slp-primary) !important;
  text-decoration: none !important;
  word-break: break-all !important;
  background: none !important;
  border: none !important;
  padding: 0 !important;
  font-weight: normal !important;
}
.slp-wrap .slp-link:hover { text-decoration: underline !important; }
.slp-wrap .slp-store-card.slp-hidden { display: none !important; }

/* ── ACTION BUTTONS — fully isolated from theme ── */
.slp-wrap .slp-card-actions {
  display: flex !important;
  gap: 7px !important;
  margin-top: 10px !important;
  flex-wrap: wrap !important;
  padding: 0 !important;
  background: none !important;
  border: none !important;
}

.slp-wrap .slp-btn {
  display: inline-block !important;
  padding: 7px 14px !important;
  border-radius: 6px !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  line-height: 1.4 !important;
  transition: opacity .2s !important;
  vertical-align: middle !important;
  text-align: center !important;
  text-transform: none !important;
  letter-spacing: normal !important;
  outline: none !important;
  margin: 0 !important;
  -webkit-appearance: none !important;
  appearance: none !important;
}
.slp-wrap .slp-btn:hover { opacity: .82 !important; }
.slp-wrap .slp-btn:focus { outline: 2px solid var(--slp-primary) !important; outline-offset: 2px !important; }

.slp-wrap .slp-btn.slp-btn-primary {
  background-color: var(--slp-primary) !important;
  color: var(--slp-btn-text) !important;
  border: 2px solid var(--slp-primary) !important;
  box-shadow: none !important;
}
.slp-wrap .slp-btn.slp-btn-primary:hover {
  background-color: var(--slp-primary) !important;
  color: var(--slp-btn-text) !important;
  border-color: var(--slp-primary) !important;
}

.slp-wrap .slp-btn.slp-btn-outline {
  background-color: transparent !important;
  color: var(--slp-btn-outline) !important;
  border: 2px solid var(--slp-btn-outline) !important;
  box-shadow: none !important;
}
.slp-wrap .slp-btn.slp-btn-outline:hover {
  background-color: transparent !important;
  color: var(--slp-btn-outline) !important;
  border-color: var(--slp-btn-outline) !important;
}

/* ── Map panel ── */
.slp-wrap .slp-map-panel {
  flex: 1 1 0% !important;
  min-width: 0 !important;
  position: relative !important;
  overflow: hidden !important;
}
.slp-wrap #slp-map {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
}

/* ── Scroll hint ── */
.slp-wrap .slp-scroll-hint {
  position: absolute !important;
  bottom: 12px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  background: rgba(0,0,0,.55) !important;
  color: #fff !important;
  font-size: 11.5px !important;
  padding: 5px 12px !important;
  border-radius: 20px !important;
  pointer-events: none !important;
  white-space: nowrap !important;
  opacity: 0 !important;
  transition: opacity .4s !important;
  z-index: 500 !important;
}
.slp-wrap .slp-scroll-hint.visible { opacity: 1 !important; }
.slp-wrap .slp-scroll-hint kbd {
  background: rgba(255,255,255,.25) !important;
  border-radius: 3px !important;
  padding: 1px 5px !important;
  font-size: 11px !important;
  font-family: inherit !important;
  border: none !important;
  color: #fff !important;
  box-shadow: none !important;
}

/* ── Leaflet popup — colors controlled via JS config ── */
.leaflet-popup-content-wrapper { border-radius: 10px !important; box-shadow: 0 4px 20px rgba(0,0,0,.15) !important; }
.leaflet-popup-content { margin: 13px 15px !important; }
.slp-popup h4 { margin: 0 0 5px !important; font-size: 13.5px !important; font-weight: 700 !important; color: #111 !important; padding: 0 !important; background: none !important; border: none !important; }
.slp-popup p  { margin: 3px 0 !important; font-size: 12px !important; color: #555 !important; line-height: 1.4 !important; padding: 0 !important; background: none !important; }

/* Popup link and button colors set by JS using inline style */

/* ── Cluster ── */
.slp-cluster {
  width: 40px !important; height: 40px !important;
  border-radius: 50% !important;
  background: var(--slp-primary) !important;
  border: 3px solid #fff !important;
  box-shadow: 0 2px 8px rgba(0,0,0,.25) !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
}
.slp-cluster span {
  color: #fff !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  font-family: -apple-system, sans-serif !important;
  line-height: 1 !important;
}

.slp-wrap .leaflet-control-attribution {
  font-size: 10px !important;
  background: rgba(255,255,255,.8) !important;
  padding: 2px 6px !important;
  line-height: 1.4 !important;
}
.slp-wrap .leaflet-control-attribution a {
  color: #0078a8 !important;
  font-weight: normal !important;
}

/* ── Responsive ── */
@media (max-width: 768px) {
  .slp-wrap .slp-body { flex-direction: column !important; height: auto !important; }
  .slp-wrap .slp-list-panel { width: 100% !important; max-width: 100% !important; min-width: 0 !important; max-height: 340px !important; border-right: none !important; border-bottom: 1px solid #e5e7eb !important; }
  .slp-wrap .slp-map-panel { position: relative !important; height: 300px !important; flex: none !important; }
  .slp-wrap #slp-country-filter { max-width: 130px !important; }
  .slp-wrap .slp-scroll-hint { display: none !important; }
}
@media (max-width: 480px) {
  .slp-wrap .slp-search-bar { gap: 7px !important; padding: 10px !important; }
  .slp-wrap #slp-reset { padding: 9px 12px !important; }
  .slp-wrap .slp-map-panel { height: 260px !important; }
}
