/** Shopify CDN: Minification failed

Line 88:16 Unexpected "{"
Line 88:25 Expected ":"
Line 88:32 Unexpected "{"

**/
/* ==========================================================
   STORE LOCATOR — FINAL (LIGHT MODE ONLY) — CLEAN (NO DUPES)
========================================================== */

/* .store-locator {
  --sl-bg: #ffffff;
  --sl-bg-soft: #f4f6f8;
  --sl-card-bg: #ffffff;
  --sl-border: rgba(0,0,0,0.12);
  --sl-text: #0b0d12;
  --sl-text-soft: rgba(0,0,0,0.6);
  --sl-accent: #5DB2DC;
  --sl-radius: 18px;
  --sl-shadow: 0 14px 36px rgba(0,0,0,0.12);

  background: var(--sl-bg);
  color: var(--sl-text);
} */

.store-locator {
  --sl-bg: rgb(var(--color-background));
  --sl-bg-soft: rgba(var(--color-background), 0.6);
  --sl-card-bg: rgb(var(--color-background));
  --sl-border: rgba(var(--color-border), 0.4);
  --sl-text: rgb(var(--color-foreground));
  --sl-text-soft: rgba(var(--color-foreground), 0.6);
  --sl-accent: rgb(var(--color-accent));
  --sl-radius: 18px;
  --sl-shadow: 0 14px 36px rgba(0,0,0,0.12);

  background: var(--sl-bg);
  color: var(--sl-text);
}

/* Search input */
.store-search-row input {
  background: var(--sl-bg-soft);
  color: var(--sl-text);
  border-color: var(--sl-border);
}

/* Detail panel */
.store-detail-panel {
  background: var(--sl-card-bg);
  border-color: var(--sl-border);
}

/* Close button */
#storeDetailClose {
  background: var(--sl-bg-soft);
  color: var(--sl-text);
}

/* Primary button */
.store-ui-btn--primary {
  background: var(--sl-accent);
  color: rgb(var(--color-foreground));
}

/* List item */
.store-locator-list-item {
  background: var(--sl-card-bg);
  border-color: var(--sl-border);
}

/* Mobile search input */
.store-locator .store-locator-side .store-search-row input {
  background: var(--sl-card-bg) !important;
  color: var(--sl-text) !important;
}

/* ==========================================================
   LAYOUT
========================================================== */

.store-locator-container {
  max-width: 1400px;
  margin: auto;
  padding: clamp(32px, 5vw, 80px) 24px;
}
#store-locator-{{ section.id }} {
  padding-top: 480px !important;
}

.store-locator-grid {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: 28px;
}

/* ==========================================================
   HERO
========================================================== */

.store-locator-hero {
  text-align: center;
  margin-bottom: 56px;
}

.store-locator-hero__image-wrapper {
  border-radius: var(--sl-radius);
  overflow: hidden;
  margin-bottom: 24px;
}

.store-locator-hero img {
  width: 100%;
  display: block;
}

.store-locator-hero h1 {
  font-size: clamp(28px, 5vw, 44px);
  margin-bottom: 10px;
}

.store-locator-hero p {
  max-width: 640px;
  margin: auto;
  color: var(--sl-text-soft);
}

/* ==========================================================
   MAP
========================================================== */

.store-locator-map {
  min-height: 480px;
  border-radius: 22px;
  border: 1.5px solid var(--sl-border);
  box-shadow: var(--sl-shadow);
  overflow: hidden;
  position: relative;
}

/* ==========================================================
   SIDE PANEL
========================================================== */

.store-locator-side {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

/* ==========================================================
   SEARCH (DESKTOP/TABLET BASE)
========================================================== */

.store-search-row {
  display: flex;
  gap: 14px;
}

.store-search-row input {
  flex: 1;
  height: 56px;
  padding: 0 18px;
  border-radius: 14px;
  border: 1.5px solid rgba(0, 0, 0, 0.54);
  background: var(--sl-bg-soft);
  font-size: 15px;
  color: var(--sl-text);
}

.store-search-row input:focus {
  outline: none;
  border-color: var(--sl-accent);
  background: #fff;
}

/* ==========================================================
   STORE LIST
========================================================== */

.store-locator-list {
  list-style: none;
  margin: 0;
  padding: 16px;
  border-radius: 22px;
  border: 1.5px solid var(--sl-border);
  background: var(--sl-bg-soft);
  display: flex;
  flex-direction: column;
  gap: 14px;
  max-height: 540px;
  overflow-y: auto;
}

.store-locator-list-item {
  background: var(--sl-card-bg);
  border: 1.5px solid rgba(0, 0, 0, 0.54);
  border-radius: 18px;
  padding: 18px;
  box-shadow: var(--sl-shadow);
  cursor: pointer;
  transition: border-color .2s ease, transform .15s ease;
}

.store-locator-list-item:hover {
  border-color: var(--sl-accent);
  transform: translateY(-2px);
}

.store-name {
  font-size: 16px;
  font-weight: 600;
}

.store-address,
.store-phone,
.store-distance {
  font-size: 14px;
  margin-top: 4px;
  color: var(--sl-text-soft);
}

/* ==========================================================
   DETAIL PANEL (MAP ATTACHED — DESKTOP/TABLET)
========================================================== */

.store-detail-panel {
  position: absolute;
  width: 360px;
  background: white;
  border-radius: 22px;
  border: 1.5px solid rgba(0, 0, 0, 0.75);
  box-shadow: var(--sl-shadow);
  padding: 22px;
  z-index: 10;
  transform: translate(-50%, -100%);
  pointer-events: auto;
}

.store-detail-panel::before {
  content: "";
  position: absolute;
  top: 28px;
  right: -10px;
  width: 20px;
  height: 20px;
  background: var(--sl-card-bg);
  border-right: 1.5px solid var(--sl-border);
  border-top: 1.5px solid var(--sl-border);
  transform: rotate(45deg);
}

.store-detail-panel[hidden] {
  display: none;
}

#storeDetailClose {
  position: absolute;
  top: 14px;
  right: 16px;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  border: none;
  background: var(--sl-bg-soft);
  font-size: 20px;
  cursor: pointer;
}

#storeDetailClose:hover {
  background: var(--sl-accent);
  color: #000000;
}

/* ==========================================================
   BUTTONS
========================================================== */

.store-ui-btn {
  height: 56px;
  padding: 0 22px;
  border-radius: 14px;
  font-size: 15px;
  font-weight: 600;
  border: 1.5px solid transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

/* PRIMARY */
.store-ui-btn--primary {
  background: #5DB2DC;
  color: #fff;
  border-color: rgba(0,0,0,0.15);
}

.store-ui-btn--primary:hover {
  background: #5DB2DC;
}

/* SECONDARY */
.store-ui-btn--secondary {
  /* background: #fff; */
  background: var(--sl-card-bg);
  color: var(--sl-text);
  border-color: var(--sl-border);
}

/* Detail panel — theme aware */
.store-detail-panel {
  background: rgb(var(--color-background)) !important;
  color: rgb(var(--color-foreground)) !important;
  border-color: rgba(var(--color-border), 0.4) !important;
}

.store-detail-panel h2,
.store-detail-panel p {
  color: rgb(var(--color-foreground)) !important;
}

#storeDetailClose {
  background: rgba(var(--color-border), 0.2) !important;
  color: rgb(var(--color-foreground)) !important;
}

/* List items — theme aware */
.store-locator-list-item {
  background: rgb(var(--color-background)) !important;
  border-color: rgba(var(--color-border), 0.4) !important;
  color: rgb(var(--color-foreground)) !important;
}

.store-name {
  color: rgb(var(--color-foreground)) !important;
}

.store-address,
.store-phone,
.store-distance {
  color: rgba(var(--color-foreground), 0.6) !important;
}

/* List container */
.store-locator-list {
  background: rgba(var(--color-background), 0.6) !important;
  border-color: rgba(var(--color-border), 0.4) !important;
}

/* Search input */
.store-search-row input {
  background: rgb(var(--color-background)) !important;
  color: rgb(var(--color-foreground)) !important;
  border-color: rgba(var(--color-border), 0.4) !important;
}

.store-ui-btn--secondary:hover {
  border-color: var(--sl-accent);
  color: var(--sl-accent);
}

/* Detail panel CTA */
.store-detail-panel .store-ui-btn {
  width: 100%;
  margin-top: 14px;
}

/* ==========================================================
   GOOGLE AUTOCOMPLETE (SOLID)
========================================================== */

.pac-container {
  background: #ffffff !important;
  border: 1.5px solid rgba(0,0,0,0.15);
  border-radius: 16px;
  box-shadow: 0 18px 40px rgba(0,0,0,0.2);
  z-index: 99999 !important;
}

.pac-item {
  padding: 12px 16px;
  margin: 4px 8px;
  border-radius: 10px;
  cursor: pointer;
}

.pac-item:hover,
.pac-item-selected {
  background: #f4f6f8;
}

.pac-icon {
  display: none;
}

.pac-container:after {
  content: "Powered by Google";
  display: block;
  text-align: right;
  padding: 8px 14px;
  font-size: 11px;
  opacity: .6;
}

/* ==========================================================
   RESPONSIVE
========================================================== */

@media (max-width: 1024px) {
  .store-locator-grid {
    grid-template-columns: 1fr;
  }
}

/* ==========================================================
   MOBILE (SINGLE SOURCE OF TRUTH) — NO DUPES
========================================================== */

@media (max-width: 768px) {
  .store-locator-container {
    padding: 24px 16px;
  }

  .store-locator-map {
    min-height: 360px;
    border-radius: 18px;
  }

  /* SEARCH CARD */
  .store-locator .store-locator-side .store-search-row {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;

    padding: 14px !important;
    border-radius: 18px !important;
    border: 1.5px solid var(--sl-border) !important;
    background: var(--sl-bg-soft) !important;
    box-shadow: var(--sl-shadow) !important;
  }

  .store-locator .store-locator-side .store-search-row input {
    width: 100% !important;
    height: 52px !important;
    padding: 0 16px !important;

    border-radius: 14px !important;
    border: 1.5px solid rgba(0,0,0,0.20) !important;
    background: #fff !important;

    font-size: 16px !important; /* stops iOS zoom */
    line-height: 52px !important;
    box-sizing: border-box !important;
  }

  .store-locator .store-locator-side .store-search-row input:focus {
    outline: none !important;
    border-color: var(--sl-accent) !important;
    box-shadow: 0 0 0 4px rgba(255,149,0,0.18) !important;
  }

  .store-locator .store-locator-side .store-search-row .store-ui-btn {
    width: 100% !important;
    height: 52px !important;
    border-radius: 14px !important;
  }

  /* LIST */
  .store-locator-list {
    padding: 12px;
    gap: 12px;
    max-height: 420px;
    -webkit-overflow-scrolling: touch;
  }

  .store-locator-list-item {
    padding: 16px;
    border-radius: 16px;
  }

  /* DETAIL PANEL -> BOTTOM SHEET */
  .store-detail-panel {
    position: fixed !important;
    left: 50% !important;
    right: auto !important;
    top: auto !important;
    bottom: 12px !important;

    width: calc(100vw - 24px) !important;
    max-width: 520px;
    transform: translateX(-50%) !important;

    padding: 18px 16px 16px !important;
    border-radius: 18px !important;

    z-index: 99990 !important;

    max-height: 55vh;
    overflow: auto;
    -webkit-overflow-scrolling: touch;
  }

  .store-detail-panel::before {
    display: none !important;
  }

  #storeDetailClose {
    top: 10px !important;
    right: 10px !important;
    width: 40px !important;
    height: 40px !important;
    font-size: 22px !important;
  }

  .store-detail-content h2 {
    font-size: 18px;
    line-height: 1.2;
    padding-right: 44px;
    margin-bottom: 8px;
  }

  .store-detail-content p {
    margin: 6px 0;
    font-size: 14px;
    line-height: 1.35;
  }

  .store-detail-panel .store-ui-btn {
    height: 52px;
    border-radius: 14px;
    margin-top: 12px;
  }
}

/* Super small phones */
@media (max-width: 390px) {
  .store-locator-hero h1 {
    font-size: 24px;
  }

  .store-locator-list {
    max-height: 360px;
  }

  .store-detail-panel {
    bottom: 10px !important;
    max-height: 60vh;
  }
}
.store-phone-link,
.store-phone a {
  color: inherit;
  text-decoration: underline;
}
/* Detail panel phone link */
/* #detailPhone { margin: 10px 0 0; } */

.store-phone-link {
  /* display: inline-flex;
  align-items: center;
  gap: 10px;

  padding: 10px 14px; */
  /* border-radius: 999px; */

  /* font-weight: 600;
  line-height: 1;

  text-decoration: none;
  color: inherit; */

  /* subtle button feel (no fixed colors) */
  /* border: 1px solid rgba(0,0,0,.12); */
  /* background: rgba(255,255,255,.65); */
  /* backdrop-filter: blur(10px); */
  /* -webkit-backdrop-filter: blur(10px); */

  /* transition: transform .15s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease; */
}
/* 
.store-phone-link:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 25px rgba(0,0,0,.08);
  border-color: rgba(0,0,0,.18);
  background: rgba(255,255,255,.8);
} */

.store-phone-link:active {
  transform: translateY(0);
  box-shadow: 0 6px 18px rgba(0,0,0,.06);
}

.store-phone-link:focus-visible {
  outline: 2px solid currentColor;
  outline-offset: 3px;
}

.store-phone-icon {
  display: inline-flex;
  width: 28px;
  height: 28px;
  align-items: center;
  justify-content: center;

  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.10);
  background: rgba(0,0,0,.04);
  font-size: 16px;
}

.store-phone-text {
  white-space: nowrap;
}
@media (max-width: 768px) {
  .store-phone-link { padding: 9px 12px; }
  .store-phone-icon { width: 26px; height: 26px; }
}
/* ===============================
   PHONE HOVER TOOLTIP
================================ */

.store-phone-wrapper {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

/* phone link style (optional) */
.store-phone-link {
  text-decoration: none;
  font-weight: 600;
  cursor: pointer;
}

/* tooltip hidden by default */
.phone-tooltip {
  position: absolute;
  bottom: 100%;
  left: 50%;
  transform: translateX(-50%) translateY(6px);
  background: rgba(20, 20, 20, 0.95);
  color: #fff;
  padding: 6px 10px;
  border-radius: 8px;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease, transform 0.2s ease;
  z-index: 20;
}

/* tooltip arrow */
.phone-tooltip::after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  border: 6px solid transparent;
  border-top-color: rgba(20, 20, 20, 0.95);
}

/* hover → show tooltip (DESKTOP ONLY) */
@media (hover: hover) and (pointer: fine) {
  .store-phone-wrapper:hover .phone-tooltip {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
    pointer-events: auto;
  }
}

/* copy button */
.phone-copy-btn {
  background: none;
  border: none;
  color: #fff;
  font-size: 13px;
  cursor: pointer;
  padding: 2px 4px;
}

.phone-copy-btn:hover {
  text-decoration: underline;
}
/* ===============================
   PHONE TOOLTIP (DETAIL PANEL)
================================ */

#detailPhone {
  position: relative;
  display: inline-block;
}

.store-phone-link {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-weight: 600;
  text-decoration: none;
  cursor: pointer;
}

/* tooltip bubble */
.store-phone-tooltip {
  position: absolute;
  bottom: 100%;
  left: 50%;
  transform: translateX(-50%) translateY(6px);
  background: rgba(20, 20, 20, 0.95);
  color: #fff;
  padding: 6px 10px;
  border-radius: 8px;
  font-size: 13px;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease, transform 0.2s ease;
  z-index: 50;
}

/* arrow */
.store-phone-tooltip::after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  border: 6px solid transparent;
  border-top-color: rgba(20, 20, 20, 0.95);
}

/* desktop hover only */
@media (hover: hover) and (pointer: fine) {
  .store-phone-link:hover .store-phone-tooltip {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
    pointer-events: auto;
  }
}

/* copy button */
.store-phone-tooltip button {
  background: none;
  border: none;
  color: #fff;
  font-size: 13px;
  cursor: pointer;
}

.store-phone-tooltip button:hover {
  text-decoration: underline;
}
