/* Zentrale · Objektkarte (Mockup 02) — kartenspezifische Styles.
   Tokens/Komponenten kommen aus design-system.css; hier nur Stage, Pins, POI, KPI, Legende.
   Leaflet selbst ist self-hosted (vendor/leaflet, CSP script-src 'self'). */

.stage{position:relative;min-width:0;overflow:hidden}
.stage #map{position:absolute;inset:0;background:var(--bg-2)}
/* ECHTE OSM-Tiles, per CSS ins CI eingefärbt (dunkel + warm/gold) — Mockup-02-Filter 1:1 */
.leaflet-tile-pane{filter:grayscale(.62) invert(.93) brightness(.92) contrast(.92) sepia(.42) hue-rotate(2deg) saturate(.8)}
:root[data-theme="light"] .leaflet-tile-pane{filter:grayscale(.35) sepia(.45) hue-rotate(-6deg) saturate(.85) brightness(1.02)}
.leaflet-container{background:var(--bg-2);font-family:var(--font-ui)}
.leaflet-control-zoom{margin:0 16px 16px 0!important;border:1px solid var(--border)!important;border-radius:10px!important;overflow:hidden;box-shadow:var(--shadow)}
.leaflet-control-zoom a{background:var(--surface)!important;color:var(--text)!important;border-color:var(--border)!important}
.leaflet-control-zoom a:hover{background:var(--surface-2)!important;color:var(--gold-soft)!important}
.leaflet-control-attribution{background:rgba(11,16,22,.6)!important;color:var(--mist-dim)!important}
.leaflet-control-attribution a{color:var(--mist)!important}
.map-glow{position:absolute;inset:0;pointer-events:none;z-index:400;background:radial-gradient(1200px 720px at 80% -12%,rgba(201,162,75,.12),transparent 55%),radial-gradient(900px 600px at 0% 110%,rgba(11,16,22,.55),transparent 60%)}

/* Topbar über der Karte */
.maptop{position:absolute;top:16px;left:16px;right:16px;z-index:450;display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.maptop .ttl{font-family:var(--font-display);font-weight:600;font-size:18px;color:var(--text);margin-right:auto;display:flex;align-items:center;gap:10px;white-space:nowrap}
.maptop .ttl .kick{font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-soft);font-weight:700}
.maptop .fchip{background:var(--topbar-bg);backdrop-filter:blur(10px);box-shadow:var(--shadow);padding:7px 12px}
.searchresults{max-height:62vh;overflow-y:auto;padding:8px}
.sempty{padding:22px;text-align:center;color:var(--mist-dim);font-size:13px}

/* KPI-Leiste unten links */
.kpibar{position:absolute;left:16px;bottom:16px;z-index:450;display:flex;gap:10px;flex-wrap:wrap;max-width:min(560px,calc(100% - 32px))}
.kpi{background:var(--topbar-bg);backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:14px;padding:11px 15px;box-shadow:var(--shadow)}
.kpi .lab{font-size:10px;letter-spacing:.07em;text-transform:uppercase;color:var(--mist-dim);font-weight:700}
.kpi .val{font-family:var(--font-display);font-size:23px;font-weight:600;line-height:1.1;margin-top:3px}
.kpi .val.gold{color:var(--gold-soft)}.kpi .val.red{color:var(--red)}

/* Legende unten rechts */
.maplegend{position:absolute;right:16px;bottom:116px;z-index:450;background:var(--topbar-bg);backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:14px;padding:11px 14px;box-shadow:var(--shadow);font-size:11.5px;color:var(--mist);display:flex;flex-direction:column;gap:7px}
.maplegend .row{display:flex;align-items:center;gap:8px}
.maplegend .dot{width:11px;height:11px;border-radius:50%;flex:0 0 auto}
.maplegend .dot.ok{background:linear-gradient(180deg,var(--gold-soft),var(--bronze))}
.maplegend .dot.warn{background:var(--warn)}
.maplegend .dot.red{background:var(--red)}

/* Custom Marker (Pins) */
.pin{width:34px;height:34px;border-radius:50% 50% 50% 2px;transform:rotate(-45deg);display:grid;place-items:center;border:2px solid rgba(255,255,255,.55);box-shadow:0 8px 18px -6px rgba(0,0,0,.6);cursor:pointer;transition:transform .15s}
.pin:hover{transform:rotate(-45deg) scale(1.08)}
.pin b{transform:rotate(45deg);font-size:11px;font-weight:800;color:#fff;font-variant-numeric:tabular-nums}
.pin.ok{background:linear-gradient(160deg,var(--gold-soft),var(--bronze))}
.pin.warn{background:linear-gradient(160deg,#d49a63,var(--warn))}
.pin.red{background:linear-gradient(160deg,#d4685e,var(--red));animation:pinpulse 1.8s ease-in-out infinite}
@keyframes pinpulse{0%,100%{box-shadow:0 8px 18px -6px rgba(0,0,0,.6),0 0 0 0 color-mix(in srgb,var(--red) 55%,transparent)}50%{box-shadow:0 8px 18px -6px rgba(0,0,0,.6),0 0 0 9px color-mix(in srgb,var(--red) 0%,transparent)}}
.pin.sel{outline:3px solid var(--gold);outline-offset:2px}

/* POI-Steckbrief — Overlay in der Stage (Meridian behält die rechte Grid-Spalte) */
.poi{position:absolute;right:0;top:0;bottom:0;width:min(380px,92%);z-index:460;display:flex;flex-direction:column;min-height:0;background:linear-gradient(180deg,var(--surface),var(--grad-card));border-left:1px solid var(--border);box-shadow:var(--shadow);transform:translateX(105%);transition:transform .28s cubic-bezier(.2,.7,.2,1)}
.poi.open{transform:translateX(0)}
.poi-img{height:150px;flex:0 0 auto;position:relative;background:linear-gradient(135deg,var(--surface-2),var(--bg-2));background-size:cover;background-position:center;border-bottom:1px solid var(--border)}
.poi-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent,rgba(13,20,28,.85))}
.poi-img .ph-emoji{position:absolute;inset:0;display:grid;place-items:center;font-size:44px;opacity:.5}
.poi-img .badge{position:absolute;left:14px;top:14px;z-index:2;display:inline-flex;align-items:center;gap:7px;font-size:11px;font-weight:700;padding:5px 11px;border-radius:999px;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.4)}
.poi-img .badge.ok{background:linear-gradient(180deg,var(--gold-soft),var(--bronze))}
.poi-img .badge.warn{background:var(--warn)}
.poi-img .badge.red{background:var(--red)}
.poi-img .close{position:absolute;right:12px;top:12px;z-index:2;width:32px;height:32px;border-radius:9px;border:1px solid rgba(255,255,255,.25);background:rgba(11,16,22,.5);color:#fff;font-size:17px}
.poi-img .ttl{position:absolute;left:16px;bottom:12px;z-index:2}
.poi-img .ttl h2{font-family:var(--font-display);font-weight:600;font-size:19px;margin:0;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.5)}
.poi-img .ttl .ad{font-size:12px;color:#e7e2d6;text-shadow:0 1px 3px rgba(0,0,0,.5)}
.poi-body{flex:1 1 auto;overflow-y:auto;padding:18px}
.poi-body .sec-h:first-child{margin-top:0}
.occ{margin-top:13px}
.occ .bar{height:10px;border-radius:999px;background:var(--bg);border:1px solid var(--border-2);overflow:hidden;display:flex}
.occ .bar span{display:block;height:100%}
.occ .bar .filled{background:linear-gradient(90deg,var(--bronze),var(--gold-soft))}
.occ .bar .free{background:color-mix(in srgb,var(--ok) 45%,transparent)}
.occ .lbl{display:flex;justify-content:space-between;font-size:11.5px;color:var(--mist-dim);margin-top:7px}
.occ .lbl b{color:var(--champagne)}
.vrow{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid var(--border)}
.vrow:last-child{border-bottom:0}
.vrow .sev{width:8px;height:8px;border-radius:50%;flex:0 0 auto;margin-top:5px}
.vrow .sev.red{background:var(--red)}.vrow .sev.warn{background:var(--warn)}.vrow .sev.ok{background:var(--gold-soft)}
.vrow .vt{flex:1 1 auto;min-width:0}
.vrow .vt .n{font-size:13px;font-weight:600;color:var(--text)}
.vrow .vt .s{font-size:11px;color:var(--mist-dim)}
.poi-foot{flex:0 0 auto;padding:14px 18px;border-top:1px solid var(--border);display:flex;gap:9px}
.poi-foot .btn{flex:1 1 0}
.poi-empty{flex:1 1 auto;display:grid;place-items:center;padding:30px;text-align:center;color:var(--mist-dim);font-size:13px}
