:root{
  --bg:#0f1419; --panel:#161c24; --panel2:#1d2530; --line:#2a3340;
  --txt:#e6edf3; --muted:#93a1b0; --accent:#4aa3ff; --accent2:#2d7dd2;
  --verejna:#3fb950; --soukroma:#f0883e; --cirkevni:#bc8cff;
  --chip:#222c38; --chipon:#1f4d73; --radius:12px;
  --shadow:0 4px 20px rgba(0,0,0,.35);
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  background:var(--bg);color:var(--txt);line-height:1.45;-webkit-font-smoothing:antialiased;
}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}

header.top{
  padding:14px 20px;border-bottom:1px solid var(--line);
  background:linear-gradient(180deg,#172029,#10151b);position:sticky;top:0;z-index:1200;
}
header.top h1{margin:0;font-size:19px;letter-spacing:.2px}
header.top p{margin:2px 0 0;color:var(--muted);font-size:13px}
header .brand{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
header .brand .pin{color:var(--accent)}

.layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.05fr);gap:0;height:calc(100vh - 60px)}
@media(max-width:900px){
  .layout{grid-template-columns:1fr;height:auto}
  #map{height:46vh !important;position:sticky;top:60px;z-index:500}
}

/* ---- left column ---- */
.left{display:flex;flex-direction:column;min-height:0;border-right:1px solid var(--line)}
.filters{padding:12px 16px;border-bottom:1px solid var(--line);background:var(--panel);position:sticky;top:0;z-index:20}
.frow{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:10px}
.frow:last-child{margin-bottom:0}
.search{flex:1;min-width:180px;display:flex;align-items:center;gap:8px;background:var(--panel2);border:1px solid var(--line);border-radius:9px;padding:7px 11px}
.search input{flex:1;background:none;border:none;color:var(--txt);font-size:14px;outline:none}
.slider-wrap{display:flex;align-items:center;gap:9px;flex:1;min-width:220px;background:var(--panel2);border:1px solid var(--line);border-radius:9px;padding:6px 12px}
.slider-wrap label{font-size:12px;color:var(--muted);white-space:nowrap}
.slider-wrap b{color:var(--accent);font-variant-numeric:tabular-nums}
input[type=range]{flex:1;accent-color:var(--accent)}
select.sort{background:var(--panel2);color:var(--txt);border:1px solid var(--line);border-radius:9px;padding:7px 9px;font-size:13px}

.chips{display:flex;gap:6px;flex-wrap:wrap}
.chip{
  font-size:12.5px;padding:5px 11px;border-radius:999px;background:var(--chip);
  border:1px solid var(--line);color:var(--muted);cursor:pointer;user-select:none;white-space:nowrap;transition:.12s;
}
.chip:hover{border-color:var(--accent2);color:var(--txt)}
.chip.on{background:var(--chipon);border-color:var(--accent);color:#fff}
.chip.f-verejna.on{background:#16341f;border-color:var(--verejna);color:#aef0bd}
.chip.f-soukroma.on{background:#3a2410;border-color:var(--soukroma);color:#ffd2a6}
.chip.f-cirkevni.on{background:#2e2440;border-color:var(--cirkevni);color:#e2cdff}
.section-label{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);margin:0 4px 0 0;align-self:center}
.btn-reset{background:none;border:1px solid var(--line);color:var(--muted);border-radius:8px;padding:6px 12px;cursor:pointer;font-size:12.5px}
.btn-reset:hover{color:var(--txt);border-color:var(--accent2)}

.count{font-size:13px;color:var(--muted);padding:8px 16px 2px}
.count b{color:var(--txt)}

.list{overflow-y:auto;padding:8px 14px 40px;min-height:0;flex:1}
.card{
  background:var(--panel);border:1px solid var(--line);border-left:4px solid var(--line);
  border-radius:var(--radius);padding:13px 15px;margin-bottom:11px;transition:.15s;cursor:pointer;
}
.card:hover{border-color:var(--accent2);transform:translateY(-1px)}
.card.active{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}
.card.f-verejna{border-left-color:var(--verejna)}
.card.f-soukroma{border-left-color:var(--soukroma)}
.card.f-cirkevni{border-left-color:var(--cirkevni)}
.card .chead{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.card h3{margin:0;font-size:15.5px;line-height:1.3}
.card h3 a{color:var(--txt)}
.card h3 a:hover{color:var(--accent)}
.dist{white-space:nowrap;font-size:12.5px;color:var(--muted);text-align:right;font-variant-numeric:tabular-nums}
.dist b{color:var(--accent);font-size:14px}
.badges{display:flex;gap:6px;flex-wrap:wrap;margin:8px 0 6px}
.badge{font-size:11px;padding:2px 8px;border-radius:6px;background:var(--panel2);color:var(--muted);border:1px solid var(--line)}
.badge.type{color:#cfe3ff}
.badge.f-verejna{color:#aef0bd;border-color:#1f5430}
.badge.f-soukroma{color:#ffd2a6;border-color:#5c3a16}
.badge.f-cirkevni{color:#e2cdff;border-color:#473461}
.tags{display:flex;gap:5px;flex-wrap:wrap;margin:7px 0}
.tag{font-size:11.5px;padding:2px 8px;border-radius:999px;background:#1a2734;color:#9fc4e8;border:1px solid #24384a}
.addr{font-size:12.5px;color:var(--muted);margin:5px 0}
.obory{font-size:12.5px;color:#b9c6d3;margin:5px 0 0;display:none}
.obory.show{display:block}
.cfoot{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px;align-items:center}
.lnk{font-size:12.5px;padding:5px 10px;border-radius:7px;border:1px solid var(--line);background:var(--panel2);color:var(--accent);display:inline-flex;gap:5px;align-items:center}
.lnk:hover{text-decoration:none;border-color:var(--accent);background:#1a2632}
.lnk.muted{color:var(--muted)}
.od{font-size:12px;color:#ffd2a6;margin-top:7px}
.od .date{background:#3a2410;border:1px solid #5c3a16;border-radius:6px;padding:1px 7px;margin-right:5px;display:inline-block}
.unver{font-size:11px;color:#8a6d2f}

/* ---- map ---- */
#map{height:100%;width:100%;background:#0b0f14;z-index:1}
.leaflet-popup-content-wrapper{background:var(--panel);color:var(--txt);border-radius:10px}
.leaflet-popup-content{margin:11px 13px;font-size:13px}
.leaflet-popup-tip{background:var(--panel)}
.leaflet-popup-content a{color:var(--accent)}
.popup-title{font-weight:600;font-size:14px;margin-bottom:3px}
.popup-meta{color:var(--muted);font-size:12px;margin:2px 0}

.empty{padding:40px 20px;text-align:center;color:var(--muted)}
.legend{display:flex;gap:14px;flex-wrap:wrap;font-size:12px;color:var(--muted);padding:2px 16px 10px}
.dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:5px;vertical-align:-1px}
.dot.v{background:var(--verejna)} .dot.s{background:var(--soukroma)} .dot.c{background:var(--cirkevni)}

footer.foot{padding:14px 20px;border-top:1px solid var(--line);color:var(--muted);font-size:12px}
footer.foot a{color:var(--muted);text-decoration:underline}
