/* ==========================================================================
   map.css — fullscreen kaart, filterpaneel, zoek, markers en popups.
   Gebruikt de tokens uit site.css (laad site.css vóór map.css).
   ========================================================================== */

html, body { height: 100%; }
body.map-page { overflow: hidden; }

.map-shell { position: fixed; inset: 0; display: flex; flex-direction: column; }

/* ---- compacte kaart-header ---- */
.map-bar {
  height: 60px; flex: none; display: flex; align-items: center; gap: .8rem;
  padding-inline: clamp(12px, 2vw, 20px);
  background: var(--fiets); color: #fff; z-index: 30;
  box-shadow: 0 2px 10px rgba(1,58,28,.25);
}
.map-bar a.back { display: inline-flex; align-items: center; gap: .5rem; color: #fff; font-weight: 600; padding: .4rem .6rem; border-radius: var(--r-pill); }
.map-bar a.back:hover { background: rgba(255,255,255,.15); }
.map-bar a.back svg { width: 20px; height: 20px; }
.map-bar .map-title { font-family: var(--display); font-weight: 800; text-transform: uppercase; letter-spacing: .04em; font-size: 1.05rem; font-variation-settings: "wdth" 112; }
.map-bar .brand-mini { margin-left: auto; display: inline-flex; align-items: center; gap: .5rem; }
.map-bar .brand-mini img { width: 30px; height: 30px; border-radius: 7px; }
.map-bar .brand-mini b { font-family: var(--display); text-transform: uppercase; font-size: .9rem; letter-spacing: .02em; }

/* ---- body: paneel + kaart ---- */
.map-body { position: relative; flex: 1; min-height: 0; }
#map { position: absolute; inset: 0; background: #e8ebe6; }
#map:focus-visible { outline: none; }

.map-error { position: absolute; inset: 0; display: grid; place-content: center; gap: .4rem; text-align: center; padding: 2rem; color: var(--muted); }
.map-error strong { font-family: var(--display); text-transform: uppercase; color: var(--forest); font-size: 1.2rem; }

/* ---- filterpaneel (links op desktop) ---- */
.panel {
  position: absolute; top: 14px; left: 14px; z-index: 20;
  width: 320px; max-height: calc(100% - 28px);
  display: flex; flex-direction: column;
  background: rgba(247,245,239,.96); backdrop-filter: blur(8px);
  border: 1px solid var(--line); border-radius: var(--r-lg);
  box-shadow: var(--shadow-lg); overflow: hidden;
}
.panel__head { padding: 14px 14px 10px; }
.panel__title { display: flex; align-items: baseline; justify-content: space-between; gap: .5rem; margin-bottom: 10px; }
.panel__title h2 { font-family: var(--display); font-size: 1rem; text-transform: uppercase; letter-spacing: .04em; font-variation-settings: "wdth" 108; }
.panel__title #result-count { font-size: .8rem; color: var(--muted); font-weight: 600; }

/* zoekveld */
.search { position: relative; }
.search input {
  width: 100%; padding: .72rem .9rem .72rem 2.4rem; font: inherit; font-size: .95rem;
  border: 1px solid var(--line); border-radius: var(--r-pill); background: #fff; color: var(--ink);
}
.search input:focus { outline: none; border-color: var(--fiets); box-shadow: 0 0 0 3px rgba(0,155,77,.18); }
.search .search-glass { position: absolute; left: .85rem; top: 50%; transform: translateY(-50%); width: 18px; height: 18px; color: var(--muted); pointer-events: none; }
.search-results { display: none; margin-top: 8px; background: #fff; border: 1px solid var(--line); border-radius: var(--r-md); overflow: hidden; box-shadow: var(--shadow-md); }
.search-results.is-open { display: block; }
.search-item { display: flex; align-items: center; gap: .7rem; width: 100%; text-align: left; padding: .6rem .8rem; background: none; border: 0; border-bottom: 1px solid var(--line-soft); }
.search-item:last-child { border-bottom: 0; }
.search-item:hover { background: var(--mist); }
.search-ic { width: 20px; height: 20px; color: var(--fiets-dark); flex: none; }
.search-text b { display: block; font-size: .92rem; font-weight: 600; }
.search-text small { display: block; font-size: .78rem; color: var(--muted); }

/* filterlijst */
.panel__scroll { overflow-y: auto; padding: 4px 14px 14px; }
.panel__label { font-family: var(--display); text-transform: uppercase; letter-spacing: .1em; font-size: .68rem; color: var(--fiets-dark); margin: 12px 0 8px; }
.filter-list { display: flex; flex-direction: column; gap: 6px; }
.filter-chip {
  display: flex; align-items: center; gap: .6rem; text-align: left; width: 100%;
  padding: .5rem .7rem; border: 1px solid var(--line); border-radius: var(--r-pill);
  background: #fff; color: var(--ink); font-size: .9rem; font-weight: 500; transition: .15s;
}
.filter-chip .filter-ic { flex: none; height: 26px; width: auto; }
.filter-chip:hover { border-color: var(--fiets); }
.filter-chip[aria-pressed="true"] { background: var(--fiets); border-color: var(--fiets); color: #fff; }
.panel__actions { display: flex; gap: 8px; margin-top: 12px; }
.panel__actions button {
  flex: 1; padding: .6rem; border-radius: var(--r-pill); border: 1px solid var(--line);
  background: #fff; font-weight: 600; font-size: .85rem; color: var(--forest); transition: .15s;
}
.panel__actions button:hover { border-color: var(--fiets); color: var(--fiets-dark); }
.panel__actions button[aria-pressed="true"] { background: var(--forest); color: #fff; border-color: var(--forest); }

/* mobiele bedien-knoppen */
.fab-row { display: none; position: absolute; left: 14px; right: 14px; bottom: 16px; z-index: 25; gap: 10px; }
.fab {
  flex: 1; display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
  padding: .85rem 1rem; border: 0; border-radius: var(--r-pill);
  background: var(--fiets); color: #fff; font-family: var(--display); text-transform: uppercase;
  letter-spacing: .03em; font-size: .85rem; box-shadow: var(--shadow-md);
}
.fab svg { width: 18px; height: 18px; }
.panel__close { display: none; }

/* ---- Mapbox-markers ---- */
.fa-marker { background: none; border: 0; padding: 0; line-height: 0; cursor: pointer; transition: transform .12s ease; transform-origin: bottom center; }
.fa-marker:hover, .fa-marker:focus-visible { transform: scale(1.12); z-index: 2; }
.fa-pin-img { display: block; filter: drop-shadow(0 3px 4px rgba(0,0,0,.28)); }

/* ---- popup ---- */
.fa-popup .mapboxgl-popup-content { padding: 0; border-radius: var(--r-md); overflow: hidden; box-shadow: var(--shadow-lg); border: 1px solid var(--line); }
.fa-popup .mapboxgl-popup-close-button { font-size: 20px; color: #fff; padding: 2px 8px; right: 2px; top: 2px; z-index: 3; }
.pp { font-family: var(--body); }
.pp-head { background: var(--cat, var(--fiets)); color: #fff; padding: 12px 14px; }
.pp-badge { display: inline-block; font-family: var(--display); text-transform: uppercase; letter-spacing: .06em; font-size: .64rem; font-weight: 700; background: rgba(255,255,255,.2); padding: 2px 8px; border-radius: var(--r-pill); }
.pp-head h3 { font-size: 1.08rem; margin-top: 6px; line-height: 1.15; }
.pp-body { padding: 12px 14px; }
.pp-desc { font-size: .9rem; color: #34423a; margin-bottom: 10px; }
.pp-desc p { margin: 0 0 .5rem; }
.pp-row { display: flex; gap: .6rem; align-items: flex-start; margin-top: 8px; }
.pp-ic { width: 18px; height: 18px; color: var(--cat, var(--fiets)); flex: none; margin-top: 2px; }
.pp-row small { display: block; font-size: .68rem; text-transform: uppercase; letter-spacing: .06em; color: var(--muted); margin-bottom: 2px; }
.pp-list { margin: 0; padding-left: 1.1rem; font-size: .9rem; color: #34423a; }
.pp-list li { margin: 2px 0; }
.pp-link { display: inline-flex; align-items: center; gap: .4rem; margin-top: 10px; font-size: .88rem; font-weight: 600; color: var(--cat, var(--fiets-dark)); }
.pp-link svg { width: 16px; height: 16px; }
.pp-foot { padding: 10px 14px 14px; border-top: 1px solid var(--line-soft); }
.pp-route {
  width: 100%; display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
  padding: .7rem; border: 0; border-radius: var(--r-pill); background: var(--forest); color: #fff;
  font-family: var(--display); text-transform: uppercase; letter-spacing: .03em; font-size: .85rem;
}
.pp-route:hover { background: #022a14; }
.pp-route svg { width: 16px; height: 16px; }

/* ---- responsive ---- */
@media (max-width: 820px) {
  .panel {
    top: auto; bottom: 0; left: 0; right: 0; width: auto; max-height: 78%;
    border-radius: var(--r-lg) var(--r-lg) 0 0; transform: translateY(102%);
    transition: transform .28s ease;
  }
  .panel.is-open { transform: translateY(0); }
  .panel__close {
    display: inline-flex; position: absolute; top: 10px; right: 12px; width: 34px; height: 34px;
    border: 1px solid var(--line); background: #fff; border-radius: 50%; align-items: center; justify-content: center;
  }
  .fab-row { display: flex; }
}
@media (prefers-reduced-motion: reduce) {
  .panel { transition: none; }
}
