:root{
  --bg:#0d1117; --panel:#161b22; --line:#2a313c; --txt:#e6edf3; --muted:#9aa7b4;
  --accent:#4aa3ff; --gold:#f5b301; --radius:12px;
  --top:58px; --foot:30px;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%;background:var(--bg);color:var(--txt)}
body{display:flex;flex-direction:column;min-height:100dvh}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

.topbar{display:flex;align-items:center;gap:16px;height:var(--top);padding:0 16px;
  background:var(--panel);border-bottom:1px solid var(--line);flex:0 0 auto;z-index:5}
.brand{display:flex;align-items:center;gap:10px;min-width:0}
.brand h1{font-size:16px;font-weight:800;letter-spacing:.2px;margin:0;white-space:nowrap}
.dot{width:11px;height:11px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent);flex:0 0 auto}
.search{flex:1 1 auto;display:flex;justify-content:center}
.search input{width:100%;max-width:420px;height:36px;padding:0 14px;border-radius:999px;
  border:1px solid var(--line);background:#0b0f14;color:var(--txt);font-size:14px;outline:none}
.search input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(74,163,255,.25)}
.count{margin:0;font-size:12px;color:var(--muted);white-space:nowrap;flex:0 0 auto;font-variant-numeric:tabular-nums}

main{position:relative;flex:1 1 auto;min-height:0}
#map{position:absolute;inset:0}
.status{position:absolute;top:12px;left:50%;transform:translateX(-50%);z-index:4;
  background:rgba(13,17,23,.92);border:1px solid var(--line);border-radius:999px;
  padding:7px 16px;font-size:13px;color:var(--muted);display:none}
.status.show{display:block}

.attrib{flex:0 0 auto;display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;
  height:auto;min-height:var(--foot);padding:6px 14px;background:var(--panel);
  border-top:1px solid var(--line);font-size:11px;color:var(--muted)}
.attrib a{color:var(--accent);text-decoration:none}
.attrib a:hover{text-decoration:underline}
.attrib .muted{color:#6b7785}

/* Popup */
.maplibregl-popup{max-width:300px!important}
.maplibregl-popup-content{background:var(--panel)!important;color:var(--txt)!important;
  border:1px solid var(--line);border-radius:var(--radius)!important;padding:0!important;
  box-shadow:0 12px 40px rgba(0,0,0,.55)!important;overflow:hidden}
.maplibregl-popup-close-button{color:var(--muted)!important;font-size:20px!important;padding:2px 8px!important}
.maplibregl-popup-tip{border-top-color:var(--line)!important;border-bottom-color:var(--line)!important}
.pop-img{width:100%;height:150px;object-fit:cover;display:block;background:#0b0f14}
.pop-body{padding:11px 13px 13px}
.pop-name{font-size:15px;font-weight:800;margin:0 0 6px;line-height:1.25}
.pop-rows{display:grid;grid-template-columns:auto 1fr;gap:2px 10px;font-size:12.5px;margin:6px 0}
.pop-rows dt{color:var(--muted)}
.pop-rows dd{margin:0;color:var(--txt)}
.pop-links{margin-top:9px;display:flex;gap:10px;font-size:12px}
.pop-links a{color:var(--accent);text-decoration:none}
.pop-links a:hover{text-decoration:underline}
.pop-noimg{padding-top:13px}

@media(max-width:640px){
  .topbar{flex-wrap:wrap;height:auto;padding:8px 12px;gap:8px}
  .brand h1{font-size:14px}
  .count{order:3;width:100%}
  .search{order:2}
}
