/* /map — full-bleed seat-map hero (SEAT_MAP_SPEC refinements). Geo status classes live in styles.css §22. */
.leaflet-tooltip{font:inherit;font-size:12px;font-weight:600}
.leaflet-container a{color:var(--accent)}
.leaflet-control-attribution{font-size:10px}

.map-intro{padding-top:8px}
.map-intro .display{margin:6px 0 8px}
.map-intro .sub{max-width:64ch}

/* full-bleed hero — the map is the star */
.map-hero{position:relative;width:100%;height:min(80vh,760px);margin:18px 0 30px;background:var(--surface-sunken)}
.map-hero .geomap{position:absolute;inset:0;width:100%;height:100%;border:0;border-radius:0;background:var(--surface-sunken)}
/* muted street base — desaturate toward paper so the colored SMDs pop; must not lower label contrast */
.map-base{filter:grayscale(.55) contrast(.92) brightness(1.04) saturate(.85)}
/* street/neighborhood NAME tiles (own pane, above the fills): softened a touch so names read as
   part of the paper — never filtered like the base, or they'd wash out. */
.map-labels{opacity:.92}

/* floated controls ON the map */
.map-search{position:absolute;top:14px;left:14px;z-index:500;display:flex;gap:8px;background:var(--surface);
  border:2px solid var(--ink);border-radius:var(--r);padding:8px;box-shadow:var(--shadow-pop-sm);max-width:min(88vw,420px)}
.map-search input{flex:1;min-width:150px;font-size:16px;padding:9px 11px;border:1.5px solid var(--seat-line);border-radius:var(--r-sm);background:#fff}
.map-status{position:absolute;top:70px;left:14px;z-index:500;margin:0;font-size:12.5px;color:var(--ink-2);
  background:var(--surface);border-radius:var(--r-pill);padding:4px 12px;box-shadow:var(--shadow-pop-sm);max-width:min(88vw,420px)}
.map-status.is-warn{color:var(--secondary-strong,#C4145A)}
.map-legend{position:absolute;bottom:14px;left:14px;z-index:500;margin:0;background:var(--surface);
  border:2px solid var(--ink);border-radius:var(--r);padding:10px 14px;box-shadow:var(--shadow-pop-sm);
  flex-direction:column;gap:6px;align-items:flex-start;max-width:min(88vw,260px)}

/* slide-in side panel (the seat detail) */
.map-panel{position:absolute;top:0;right:0;z-index:600;width:min(92vw,360px);height:100%;
  border:0;border-left:2px solid var(--ink);border-radius:0;overflow:auto;
  transform:translateX(100%);transition:transform .22s ease;box-shadow:none}
.map-panel.is-open{transform:translateX(0)}
.map-panel__close{position:absolute;top:10px;right:12px;background:none;border:0;font-size:26px;line-height:1;
  color:var(--ink-2);cursor:pointer;padding:2px 6px}
.map-panel__close:hover{color:var(--ink)}
@media(prefers-reduced-motion:reduce){.map-panel{transition:none}}

/* the list is demoted to a collapsible "browse all" — kept as the a11y-complete equivalent */
.smd-browse{margin:8px 0 34px;border:2px solid var(--seat-line,#D9D5CC);border-radius:var(--r)}
.smd-browse>summary{cursor:pointer;padding:16px 20px;font-family:var(--font-display);font-weight:700;font-size:16px;list-style:none}
.smd-browse>summary::-webkit-details-marker{display:none}
.smd-browse>summary::after{content:"+";float:right;color:var(--accent);font-size:22px;line-height:1}
.smd-browse[open]>summary::after{content:"\2013"}
.smd-browse .smdlist-wrap{padding:0 20px 20px;margin-top:0}

@media(max-width:640px){
  .map-hero{height:72vh}
  .map-legend{font-size:11px;padding:8px 10px}
  .map-search{max-width:calc(100vw - 28px)}
  .map-panel{width:100%}
}

/* DC-only mask — evenodd punches the SMD holes out of the paper cover */
.dc-mask{fill-rule:evenodd}

/* "Back to all of DC" reset — appears after you zoom into a district */
.map-reset{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);z-index:550;font:inherit;font-size:13px;
  font-weight:600;background:var(--surface);border:2px solid var(--ink);border-radius:var(--r-pill);padding:8px 16px;
  cursor:pointer;box-shadow:var(--shadow-pop-sm)}
.map-reset:hover{background:var(--paper)}

/* QL1 district finder head (tokens only) */
.finder{margin:0 0 16px}
.finder-label{display:block;font-weight:600;font-size:14px;margin:0 0 6px;color:var(--ink)}
.finder > .field{width:100%;box-sizing:border-box;margin:0 0 10px}
.finder-row{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin:0 0 8px}
.finder-chips{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.finder-grouplbl{font-size:13px;font-weight:600;color:var(--ink-2)}
.finder .chipbtn{min-height:44px}
.finder .chipbtn.sm{min-height:44px;min-width:44px;padding:6px 12px}
.finder .chipbtn .smd-dot{margin-right:5px}
.finder-sort{width:auto;min-height:40px}
.finder-count{font-size:13px;color:var(--ink-2);margin:8px 0 0;font-weight:600}
