/* Premier Custom Storage — interactive service-area map.
   Pairs with /lib/serviceMap.js. Uses the design tokens from /assets/site.css
   (--navy, --blue, --border, etc.) but does not require it — fallback values
   are baked in so the map can also be embedded standalone. */

.pcs-service-map {
  --pcs-navy:   var(--navy,   #0f172a);
  --pcs-blue:   var(--blue,   #2563eb);
  --pcs-blue2:  var(--blue2,  #1d4ed8);
  --pcs-border: var(--border, #e2e8f0);
  --pcs-bg:     var(--bg,     #f8f9fa);
  --pcs-text:   var(--text,   #111827);
  --pcs-text2:  var(--text2,  #4b5563);
  --pcs-muted:  var(--muted,  #94a3b8);
  --pcs-green:  var(--green,  #059669);
  --pcs-amber:  var(--amber,  #f59e0b);
  --pcs-red:    var(--red,    #dc2626);
  --pcs-green-lt: var(--green-lt, #d1fae5);
  --pcs-amber-lt: var(--amber-lt, #fef3c7);
  --pcs-red-lt:   var(--red-lt,   #fee2e2);
  --pcs-r:      var(--r, 12px);
  --pcs-shadow: var(--shadow,    0 2px 8px rgba(0,0,0,0.07));
  --pcs-shadow-lg: var(--shadow-lg, 0 8px 32px rgba(15,23,42,0.12));
  --pcs-bd:     var(--bd, 'DM Sans', system-ui, sans-serif);
  --pcs-hd:     var(--hd, 'Playfair Display', serif);

  display: block;
  width: 100%;
  font-family: var(--pcs-bd);
  color: var(--pcs-text);
}

/* ── Map canvas ───────────────────────────────────────────────────── */
.pcs-service-map__canvas {
  width: 100%;
  height: 500px;
  border-radius: var(--pcs-r);
  border: 1px solid var(--pcs-border);
  box-shadow: var(--pcs-shadow);
  overflow: hidden;
  background: #eaf2f8;
  position: relative;
  z-index: 0;
}

/* keep Leaflet's default UI looking on-brand */
.pcs-service-map .leaflet-control-zoom a {
  background: #fff;
  color: var(--pcs-navy);
  border-color: var(--pcs-border);
}
.pcs-service-map .leaflet-control-zoom a:hover {
  background: var(--pcs-bg);
  color: var(--pcs-blue);
}
.pcs-service-map .leaflet-control-attribution {
  background: rgba(255,255,255,0.85);
  font-size: 0.65rem;
}

/* ── ZIP lookup ───────────────────────────────────────────────────── */
.pcs-service-map__zip {
  background: var(--pcs-bg);
  border: 1px solid var(--pcs-border);
  border-radius: var(--pcs-r);
  padding: 18px 20px;
  margin-bottom: 18px;
  box-shadow: var(--pcs-shadow);
}
.pcs-service-map__zip-label {
  display: block;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--pcs-blue);
  margin-bottom: 10px;
}
.pcs-service-map__zip-row {
  display: flex;
  gap: 10px;
  align-items: stretch;
}
.pcs-service-map__zip-input {
  flex: 1 1 auto;
  min-width: 0;
  padding: 12px 14px;
  font: inherit;
  font-size: 1rem;
  letter-spacing: 1px;
  color: var(--pcs-text);
  background: #fff;
  border: 1.5px solid var(--pcs-border);
  border-radius: 8px;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.pcs-service-map__zip-input:focus {
  outline: none;
  border-color: var(--pcs-blue);
  box-shadow: 0 0 0 3px rgba(37,99,235,0.18);
}
.pcs-service-map__zip-btn {
  flex: 0 0 auto;
  padding: 0 22px;
  font: inherit;
  font-weight: 700;
  font-size: 0.85rem;
  letter-spacing: 0.5px;
  color: #fff;
  background: var(--pcs-blue);
  border: none;
  border-radius: 8px;
  cursor: pointer;
  transition: background 0.15s, transform 0.15s;
}
.pcs-service-map__zip-btn:hover { background: var(--pcs-blue2); transform: translateY(-1px); }
.pcs-service-map__zip-btn:active { transform: translateY(0); }

.pcs-service-map__zip-result {
  margin-top: 12px;
  font-size: 0.88rem;
  line-height: 1.5;
  color: var(--pcs-text2);
  min-height: 1.4em;
}
.pcs-service-map__zip-result:empty { display: none; }
.pcs-service-map__zip-result a { color: var(--pcs-blue); font-weight: 600; }

.pcs-service-map__zip-result--ok {
  background: var(--pcs-green-lt);
  color: #064e3b;
  border-left: 3px solid var(--pcs-green);
  padding: 10px 12px;
  border-radius: 6px;
}
.pcs-service-map__zip-result--warn {
  background: var(--pcs-amber-lt);
  color: #78350f;
  border-left: 3px solid var(--pcs-amber);
  padding: 10px 12px;
  border-radius: 6px;
}
.pcs-service-map__zip-result--error {
  background: var(--pcs-red-lt);
  color: #7f1d1d;
  border-left: 3px solid var(--pcs-red);
  padding: 10px 12px;
  border-radius: 6px;
}

/* ── Legend overlay ───────────────────────────────────────────────── */
.pcs-service-map__legend {
  background: rgba(255,255,255,0.96);
  backdrop-filter: blur(6px);
  border: 1px solid var(--pcs-border);
  border-radius: 10px;
  padding: 14px 16px;
  box-shadow: var(--pcs-shadow);
  min-width: 220px;
  max-width: 280px;
  font-size: 0.78rem;
  color: var(--pcs-text);
  line-height: 1.45;
}
.pcs-legend__title {
  font-family: var(--pcs-hd);
  font-size: 0.95rem;
  margin-bottom: 8px;
  color: var(--pcs-navy);
}
.pcs-legend__list {
  list-style: none;
  margin: 0; padding: 0;
  display: flex; flex-direction: column; gap: 6px;
}
.pcs-legend__row {
  display: flex; align-items: center; gap: 8px;
}
.pcs-legend__swatch {
  width: 14px; height: 14px;
  border-radius: 4px;
  border: 1px solid rgba(0,0,0,0.08);
  flex: 0 0 auto;
}
.pcs-legend__txt {
  color: var(--pcs-text2);
  font-size: 0.74rem;
}
.pcs-legend__hub {
  margin-top: 10px;
  padding-top: 8px;
  border-top: 1px solid var(--pcs-border);
  color: var(--pcs-text2);
  font-size: 0.74rem;
  display: flex; align-items: center; gap: 6px;
}
.pcs-legend__star {
  color: var(--pcs-blue);
  font-size: 1rem;
  line-height: 1;
}

/* ── Pins (custom div icons) ──────────────────────────────────────── */
.pcs-pin {
  display: flex !important;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  font-family: var(--pcs-bd);
  font-weight: 700;
  line-height: 1;
  pointer-events: auto;
}
.pcs-pin--hub {
  width: 32px; height: 32px;
  background: var(--pcs-blue);
  color: #fff;
  border: 3px solid #fff;
  box-shadow: 0 2px 10px rgba(37,99,235,0.55), 0 0 0 1px rgba(15,23,42,0.15);
  font-size: 0.95rem;
}
.pcs-pin--city {
  width: 18px; height: 18px;
  background: var(--pcs-navy);
  color: #fff;
  border: 2px solid #fff;
  box-shadow: 0 1px 4px rgba(15,23,42,0.4);
  font-size: 0.6rem;
}
.pcs-pin--lookup {
  width: 54px !important;
  height: 22px !important;
  border-radius: 6px;
  background: var(--pcs-navy);
  color: #fff;
  font-size: 0.72rem;
  letter-spacing: 0.5px;
  border: 2px solid #fff;
  box-shadow: 0 4px 12px rgba(15,23,42,0.35);
}

/* ── Tooltip styling ──────────────────────────────────────────────── */
.pcs-service-map .leaflet-tooltip {
  background: #fff;
  color: var(--pcs-text);
  border: 1px solid var(--pcs-border);
  border-radius: 6px;
  padding: 7px 10px;
  font-family: var(--pcs-bd);
  font-size: 0.78rem;
  line-height: 1.45;
  box-shadow: var(--pcs-shadow);
}
.pcs-service-map .leaflet-tooltip strong {
  color: var(--pcs-navy);
  font-weight: 700;
}
.pcs-service-map .pcs-tt-fee {
  color: var(--pcs-blue);
  font-weight: 600;
}
.pcs-service-map .pcs-tt-tier {
  color: var(--pcs-text2);
  font-size: 0.72rem;
}
.pcs-service-map .leaflet-tooltip-top:before { border-top-color: #fff; }
.pcs-service-map .leaflet-tooltip-bottom:before { border-bottom-color: #fff; }
.pcs-service-map .leaflet-tooltip-left:before { border-left-color: #fff; }
.pcs-service-map .leaflet-tooltip-right:before { border-right-color: #fff; }

/* ── Responsive ───────────────────────────────────────────────────── */
@media (max-width: 720px) {
  .pcs-service-map__canvas { height: 380px; }
  .pcs-service-map__legend { min-width: 180px; max-width: 220px; padding: 10px 12px; font-size: 0.72rem; }
  .pcs-legend__title { font-size: 0.85rem; }
  .pcs-legend__txt { font-size: 0.68rem; }
  .pcs-service-map__zip-row { flex-direction: column; }
  .pcs-service-map__zip-btn { padding: 12px 22px; }
}
@media (max-width: 420px) {
  .pcs-service-map__canvas { height: 320px; }
  .pcs-service-map__legend { display: none; } /* keep map readable on phones */
}

/* ── Reduced motion ───────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  .pcs-service-map__zip-btn { transition: none; }
}
