/* ── Map ──────────────────────────────────────────────────── */

.map {
  width: 100%;
  height: 500px;
}

/* ── Layout ──────────────────────────────────────────────── */

.locator-main {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.locator-results {
  border-radius: 0.5rem;
  border: 1px solid rgba(255, 255, 255, 0.1);
}

/* ── Location list items ─────────────────────────────────── */

.location-list-item {
  padding: 1rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.07);
  cursor: pointer;
  transition: background-color 0.15s ease;
}

.location-list-item:hover {
  background-color: var(--color-neutral-800);
}

.location-list-item:last-child {
  border-bottom: none;
}

.location-list-item .star-rating-bg {
  background-color: var(--color-neutral-900);
  transition: background-color 0.15s ease;
}

.location-list-item:hover .star-rating-bg {
  background-color: var(--color-neutral-800);
}

/* ── Store hours grid ────────────────────────────────────── */

.store-hours {
  border-radius: 0.375rem;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.store-hours img {
  height: 24px;
  width: 24px;
  display: block;
  margin: 0 auto;
  filter: brightness(0) invert(1);
}

.store-hours-header {
  font-weight: 600;
  color: var(--color-neutral-300);
  background-color: var(--color-neutral-700);
  padding: 0.375rem 0.25rem;
  text-align: center;
}

.store-hours-cell {
  color: var(--color-neutral-400);
  padding: 0.375rem 0.25rem;
  text-align: center;
  font-variant-numeric: tabular-nums;
}

/* ── Google Maps info window ─────────────────────────────── */

.gm-style-iw-ch {
  font-weight: 600;
  font-size: 125%;
}

.gm-style-iw.gm-style-iw-c {
  color: var(--color-neutral-900);
}

.gm-style-iw .gm-ui-hover-effect {
  background: none !important;
  border: none !important;
  box-shadow: none !important;
}

.gm-style-iw .gm-ui-hover-effect > span {
  background-color: #000 !important;
}

/* ── Filter sidebar ──────────────────────────────────────── */

.locator-filters {
  background: transparent;
}

.locator-filters__summary {
  list-style: none;
}

.locator-filters__summary::-webkit-details-marker {
  display: none;
}

.locator-filters .filter-toggle-icon {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
}

.locator-filters .filter-toggle-icon .chevron {
  width: 1.25rem;
  height: 1.25rem;
  color: var(--color-neutral-400);
}

.locator-filters .filter-toggle-icon .chevron-up {
  display: none;
}

.locator-filters[open] .filter-toggle-icon .chevron-down {
  display: none;
}

.locator-filters[open] .filter-toggle-icon .chevron-up {
  display: inline;
}

@media (min-width: 768px) {
  .locator-filters {
    display: block;
  }

  .locator-filters__summary {
    display: none;
  }

  .locator-filters__content {
    display: block;
  }
}

.filters-card {
  position: relative;
}

.inline-badge {
  position: absolute;
  top: -0.7rem;
  left: 1rem;
  padding: 0 0.5rem;
  color: var(--color-neutral-100);
  background: var(--color-neutral-900);
  font-weight: 200;
  font-size: 1rem;
  line-height: 1.5rem;
}

.locator-filters[open] summary {
  border-bottom: 1px solid var(--color-neutral-700);
}

.locator-filters summary::-webkit-details-marker {
  display: none;
}

/* ── Accordion animations ────────────────────────────────── */

@keyframes accordion-down {
  from { height: 0; opacity: 0; }
  to { height: var(--accordion-content-height); opacity: 1; }
}

@keyframes accordion-up {
  from { height: var(--accordion-content-height); opacity: 1; }
  to { height: 0; opacity: 0; }
}
