/* ── Results page ── */
.results-page { max-width: var(--max); margin: 0 auto; padding: 20px 20px 40px; }

/* ── View toggle ── */
.view-toggle {
  display: flex; background: var(--bg-alt); border: 1px solid var(--border);
  border-radius: var(--rsm); padding: 3px; gap: 2px; flex-shrink: 0;
}
.view-toggle-btn {
  padding: 6px 14px; border-radius: var(--rxs); border: none; background: none;
  font-size: .78rem; font-weight: 600; cursor: pointer; color: var(--muted);
  font-family: var(--font-display); transition: all .14s;
  display: flex; align-items: center; gap: 5px;
}
.view-toggle-btn.active { background: #fff; color: var(--navy); box-shadow: var(--shadow); }

/* ── Results top bar ── */
.results-bar { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; flex-wrap: wrap; }
.results-search {
  display: flex; flex: 1; min-width: 220px;
  background: #fff; border: 1.5px solid var(--border);
  border-radius: var(--rsm); overflow: hidden; transition: border-color .15s;
}
.results-search:focus-within { border-color: var(--accent); }
.results-search input {
  flex: 1; border: none; outline: none; font-size: .9rem;
  font-family: var(--font); padding: 9px 14px; color: var(--navy); background: transparent;
}
.results-search button {
  border: none; background: var(--navy); color: #fff; padding: 9px 18px;
  cursor: pointer; font-size: .82rem; font-weight: 600;
  font-family: var(--font-display); transition: background .14s; flex-shrink: 0;
}
.results-search button:hover { background: var(--navy-light); }
.sort-sel {
  border: 1.5px solid var(--border); border-radius: var(--rsm);
  padding: 8px 11px; font-size: .82rem; font-family: var(--font);
  background: #fff; cursor: pointer; color: var(--body); transition: border-color .14s;
}
.sort-sel:focus-visible {
  border-color: var(--accent); outline: none; box-shadow: 0 0 0 3px rgba(249,115,22,.15);
}
.res-count { font-size: .82rem; color: var(--muted); flex-shrink: 0; }
.res-count strong { color: var(--navy); font-family: var(--font-display); }
.filter-toggle-btn { display: none; }

/* ── Split layout ── */
.results-split { display: grid; grid-template-columns: 360px 1fr; gap: 16px; align-items: start; }
.results-split.list-only { grid-template-columns: 1fr; }
.results-list-col { display: flex; flex-direction: column; gap: 0; }

/* ── Filter panel ── */
.filter-panel {
  background: #fff; border: 1.5px solid var(--border);
  border-radius: var(--r); padding: 16px; margin-bottom: 12px;
}
.f-title {
  font-size: .69rem; font-weight: 600; text-transform: uppercase;
  letter-spacing: .1em; color: var(--muted); margin-bottom: 13px;
  font-family: var(--font-display); padding-bottom: 10px;
  border-bottom: 1px solid var(--border);
}
.f-group { margin-bottom: 16px; }
.f-lbl { font-size: .75rem; font-weight: 600; margin-bottom: 8px; color: var(--navy); font-family: var(--font-display); }
.f-opt { display: flex; align-items: center; gap: 7px; margin-bottom: 5px; cursor: pointer; }
.f-opt input { accent-color: var(--accent); cursor: pointer; width: 14px; height: 14px; }
.f-opt label { font-size: .8rem; color: var(--body); cursor: pointer; }
.f-div { height: 1px; background: var(--border); margin: 4px 0 14px; }

/* ── Service filter chips ── */
.filter-chip {
  font-size: .73rem; padding: 4px 11px; border-radius: 9999px;
  border: 1.5px solid var(--border); background: #fff; cursor: pointer;
  color: var(--body); font-family: var(--font); font-weight: 500;
  transition: background var(--t-fast), border-color var(--t-fast), color var(--t-fast), transform var(--t-fast);
}
.filter-chip:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-l); transform: translateY(-1px); }
.filter-chip.chip-on { background: var(--accent); color: #fff; border-color: var(--accent); font-weight: 600; transform: none; }
.filter-chip.chip-on:hover { background: var(--accent-d); border-color: var(--accent-d); }

/* ── Map column ── */
.map-col { position: sticky; top: 72px; }
#map {
  height: calc(100vh - 120px); min-height: 500px;
  border-radius: var(--r); border: 1.5px solid var(--border); overflow: hidden;
}
.map-placeholder {
  height: calc(100vh - 120px); min-height: 500px;
  border-radius: var(--r); border: 1.5px solid var(--border);
  background: var(--bg-alt); display: flex; align-items: center;
  justify-content: center; flex-direction: column; gap: 12px; color: var(--muted);
}

/* ── Leaflet overrides ── */
.leaflet-popup-content-wrapper {
  border-radius: 12px; box-shadow: 0 8px 32px rgba(0,0,0,.14);
  border: 1px solid #e5e7eb; padding: 0; overflow: hidden;
}
.leaflet-popup-content { margin: 0; width: 250px !important; }
.mv-popup .leaflet-popup-content-wrapper { border-radius: 12px; }
.leaflet-container { font-family: inherit; }
.map-popup { padding: 14px; }
.map-popup-logo { font-size: 1.6rem; margin-bottom: 6px; }
.map-popup-name { font-weight: 700; font-size: .9rem; margin-bottom: 3px; color: var(--text); }
.map-popup-loc { font-size: .75rem; color: var(--muted); margin-bottom: 7px; }
.map-popup-tags { display: flex; gap: 4px; flex-wrap: wrap; margin-bottom: 9px; }
.map-popup-tag {
  padding: 1px 7px; background: var(--bg-alt); border: 1px solid var(--border);
  border-radius: 4px; font-size: .7rem; color: var(--body);
}
.map-popup-meta { display: flex; align-items: center; justify-content: space-between; }
.map-popup-rating { font-size: .8rem; font-weight: 600; color: var(--accent); }
.leaflet-popup-tip-container { display: none; }
.leaflet-popup-close-button { color: var(--muted) !important; font-size: 16px !important; right: 8px !important; top: 6px !important; }

/* ── Custom map marker ── */
.map-marker {
  width: 34px; height: 34px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem; border: 2.5px solid #fff;
  box-shadow: 0 2px 8px rgba(0,0,0,.25); cursor: pointer;
  position: relative; transition: transform .15s;
}
.map-marker.feat { border-color: var(--accent); box-shadow: 0 2px 12px rgba(249,115,22,.4); }
.map-marker.highlight { transform: scale(1.25); z-index: 999 !important; }

/* ── Manufacturer card list ── */
.mfr-list { display: flex; flex-direction: column; gap: 8px; }
.mfr-card {
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--r); padding: 15px 16px; cursor: pointer;
  transition: box-shadow var(--t-base) var(--ease-out), transform var(--t-base) var(--ease-out), border-color var(--t-base);
  display: grid; grid-template-columns: 50px 1fr; gap: 12px;
  align-items: start; color: var(--text); position: relative; overflow: hidden;
}
.mfr-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 0;
  background: linear-gradient(90deg,var(--accent),var(--accent-d));
  transition: height var(--t-base) var(--ease-out); border-radius: var(--r) var(--r) 0 0;
}
.mfr-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); border-color: var(--border-d); }
.mfr-card:hover::before { height: 3px; }
.mfr-card:focus-visible { outline: 3px solid var(--accent); outline-offset: 2px; }
.mfr-card.feat { border: 1px solid var(--border); background: #fff; position: relative; }
.mfr-card.feat::before { height: 3px; }
.mfr-card.feat .card-name { color: var(--navy); }
.mfr-card.feat .card-loc { color: var(--muted); }
.mfr-card.feat .tag { background: var(--bg-alt); color: var(--body); border-color: var(--border); }
.mfr-card.feat .meta-i { color: var(--muted); }
.mfr-card.feat .stars-color { color: var(--accent); }
.mfr-card.feat:hover { box-shadow: var(--shadow-md); }
.mfr-card.active-card { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(249,115,22,.12),var(--shadow-md); }

.mfr-logo-sm {
  width: 50px; height: 50px; border-radius: 10px;
  background: var(--bg-alt); border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.3rem; flex-shrink: 0;
  transition: transform var(--t-base) var(--ease-out);
}
.mfr-card:hover .mfr-logo-sm { transform: scale(1.05); }

.card-body { min-width: 0; }
.card-top { display: flex; align-items: center; gap: 7px; margin-bottom: 3px; flex-wrap: wrap; }
.card-name { font-size: .95rem; font-weight: 600; line-height: 1.2; color: var(--navy); font-family: var(--font-display); }
.card-loc { font-size: .76rem; color: var(--muted); margin-bottom: 6px; }
.card-tags { display: flex; gap: 5px; flex-wrap: wrap; margin-bottom: 7px; }
.tag { padding: 2px 8px; border-radius: 4px; background: var(--bg-alt); color: var(--body); font-size: .71rem; font-weight: 500; border: 1px solid var(--border); }
.card-meta { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
.meta-i { font-size: .76rem; color: var(--muted); display: flex; align-items: center; gap: 3px; }
.stars-color { color: var(--accent); }

/* ── Responsive results ── */
@media (max-width: 960px) {
  .results-split { grid-template-columns: 1fr; }
  #map { height: 50vw; min-height: 300px; position: static; }
  .map-col { position: static; }
  .filter-toggle-btn { display: inline-flex; }
}
@media (max-width: 600px) {
  .results-page { padding: 12px 12px 32px; }
  .results-bar { flex-wrap: wrap; gap: 8px; }
  .results-search { flex: 1 1 100%; min-width: 0; }
  .sort-sel { font-size: .8rem; padding: 7px 10px; }
  .view-toggle-btn { font-size: .75rem; padding: 5px 9px; }
  .filter-chip { font-size: .72rem; padding: 3px 9px; }
  #map { height: 42vw; min-height: 240px; }
  .mfr-card { padding: 12px; }
  .mfr-logo-sm { width: 38px; height: 38px; font-size: 1.1rem; }
  .card-name { font-size: .88rem; }
}
