/* ============================================================
   osiedlo.pl — listing nieruchomości — style (mapa, filtry, karty)
   Wymaga: otoauta.css (tokeny) + listing.css (toolbar, grid, row-card, chipy, pages)
   ============================================================ */

/* ===== Breadcrumb + tytuł ===== */
.os-head { padding:14px 0 4px; }
.os-crumbs { font-size:.82rem; color:var(--muted-2); display:flex; flex-wrap:wrap; gap:6px; align-items:center; }
.os-crumbs a { color:var(--muted); }
.os-crumbs a:hover { color:var(--navy-700); }
.os-title { font-family:var(--font-display); font-weight:800; font-size:clamp(1.3rem,3vw,1.7rem); letter-spacing:-.02em; margin:4px 0 0; }
.os-title small { font-weight:700; font-size:.5em; color:var(--muted-2); }

/* ===== Segment transakcji ===== */
.os-seg { display:inline-flex; background:var(--bg-2); border-radius:12px; padding:4px; gap:3px; margin:12px 0 2px; }
.os-seg button { border:0; background:transparent; font-weight:700; font-size:.88rem; color:var(--muted); padding:.55rem 1.1rem; border-radius:9px; cursor:pointer; display:inline-flex; align-items:center; gap:7px; transition:.14s; }
.os-seg button.active { background:#fff; color:var(--navy-700); box-shadow:var(--shadow-sm); }
.os-seg button.active i { color:var(--orange-500); }

/* ===== Pasek filtrów (jak listing-b) — z dużym polem lokalizacji ===== */
.os-flt { background:#fff; border:1px solid var(--line); border-radius:16px; box-shadow:var(--shadow-sm); padding:14px; }
.os-flt__main, .os-flt__adv-in { min-width:0; }
.os-flt__main > *, .os-flt__adv-in > * { min-width:0; }
.os-flt .oa-select, .os-flt .oa-input { min-width:0; width:100%; }
.os-loc, .os-loc__field { min-width:0; }
.os-flt__main { display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr auto; gap:10px; align-items:end; }
.os-loc { position:relative; }
.os-loc__field { display:flex; align-items:center; gap:8px; border:1.5px solid var(--line); border-radius:11px; padding:.2rem .2rem .2rem .8rem; background:#fff; transition:border-color .15s, box-shadow .15s; }
.os-loc__field:focus-within { border-color:var(--navy-500); box-shadow:0 0 0 3px rgba(37,99,196,.12); }
.os-loc__field > i { color:var(--orange-500); font-size:1.05rem; }
.os-loc__field input { flex:1; border:0; outline:0; padding:.5rem 0; font-size:.92rem; font-weight:600; min-width:0; }
.os-loc__radius { flex:none; display:inline-flex; align-items:center; gap:5px; font-size:.78rem; font-weight:700; color:var(--navy-700); background:var(--navy-50); border:0; border-radius:8px; padding:.38rem .55rem; cursor:pointer; white-space:nowrap; }
.os-loc__radius:hover { background:var(--navy-100); }
.os-suggest { position:absolute; top:calc(100% + 6px); left:0; right:0; background:#fff; border:1px solid var(--line); border-radius:12px; box-shadow:var(--shadow-lg); z-index:80; overflow:hidden; display:none; }
.os-suggest.show { display:block; }
.os-suggest__hd { font-size:.7rem; font-weight:800; letter-spacing:.06em; text-transform:uppercase; color:var(--muted-2); padding:9px 13px 5px; }
.os-sug { display:flex; align-items:center; gap:10px; padding:9px 13px; cursor:pointer; font-size:.9rem; }
.os-sug:hover, .os-sug.active { background:var(--navy-50); }
.os-sug__ic { width:20px; color:var(--navy-600); flex:none; text-align:center; }
.os-sug__t { flex:1; min-width:0; }
.os-sug__t b { color:var(--navy-700); }
.os-sug__tag { font-size:.72rem; color:var(--muted-2); font-weight:700; }

.os-flt__adv { max-height:0; overflow:hidden; transition:max-height .35s ease; }
.os-flt__adv.open { max-height:600px; }
.os-flt__adv-in { display:grid; grid-template-columns:repeat(4,1fr); gap:10px; padding-top:13px; margin-top:13px; border-top:1px dashed var(--line); }
.os-flt__checks { display:flex; flex-wrap:wrap; gap:8px 16px; padding-top:12px; }
.os-flt__more { display:flex; align-items:center; justify-content:space-between; gap:12px; margin-top:12px; flex-wrap:wrap; }

/* ===== Toolbar: dodatkowy przycisk Mapa w view-toggle (z listing.css) ===== */

/* ===== Karta nieruchomości — cena za m² ===== */
.row-card__ppm { font-size:.78rem; color:var(--muted); font-weight:600; margin-top:2px; }
.rc-attrs { display:flex; flex-wrap:wrap; gap:7px; }
.rc-attr { display:inline-flex; align-items:center; gap:5px; font-size:.8rem; font-weight:600; color:var(--ink-2); background:var(--bg-2); border-radius:8px; padding:.32rem .6rem; }
.rc-attr i { color:var(--navy-600); font-size:.92rem; }

/* ===== WIDOK MAPY (split) ===== */
#osMap { position:absolute; inset:0; z-index:1; }
.leaflet-div-icon { background:transparent; border:0; }
.osm-pin { display:inline-block; background:#fff; color:var(--navy-800); border:1.5px solid var(--navy-700); border-radius:999px; font-family:var(--font-display); font-weight:800; font-size:.74rem; line-height:1; padding:.26rem .5rem; white-space:nowrap; box-shadow:0 2px 7px rgba(8,22,52,.28); transform:translate(-50%,-50%); cursor:pointer; transition:background .12s, color .12s, transform .12s; }
.osm-pin:hover, .osm-pin.active { background:var(--orange-500); color:#fff; border-color:var(--orange-600); transform:translate(-50%,-50%) scale(1.12); z-index:1000; }
.osm-pop { width:222px; }
.osm-pop img { width:100%; height:120px; object-fit:cover; display:block; }
.osm-pop__b { padding:9px 4px 2px; }
.osm-pop__t { font-family:var(--font-display); font-weight:700; font-size:.85rem; line-height:1.25; color:var(--ink); }
.osm-pop__p { font-family:var(--font-display); font-weight:800; color:var(--navy-800); margin-top:4px; }
.osm-pop__a { display:inline-block; margin-top:6px; font-weight:700; font-size:.82rem; color:var(--orange-600); }
.leaflet-popup-content { margin:0 !important; width:222px !important; }
.leaflet-popup-content-wrapper { padding:0; overflow:hidden; border-radius:14px; }
.fmap-area { position:absolute; top:12px; left:50%; transform:translateX(-50%); z-index:1001; background:#fff; border:1px solid var(--line); border-radius:999px; font-weight:700; font-size:.82rem; color:var(--navy-700); padding:.5rem .9rem; cursor:pointer; box-shadow:var(--shadow); display:inline-flex; align-items:center; gap:7px; white-space:nowrap; }
.fmap-area:hover { background:var(--navy-50); }
.os-mapwrap { display:none; }
body.view-map .os-listwrap { display:none; }
body.view-map .os-mapwrap { display:block; }
.os-split { display:grid; grid-template-columns:minmax(0,1fr) minmax(0,1.15fr); gap:16px; }
.os-split__list { height:calc(100vh - 150px); overflow-y:auto; padding-right:6px; display:flex; flex-direction:column; gap:12px; }
.os-split__map { height:calc(100vh - 150px); position:sticky; top:8px; border-radius:18px; overflow:hidden; border:1px solid var(--line); box-shadow:var(--shadow); }

/* faux-map */
.fmap { position:absolute; inset:0; background:
  radial-gradient(120% 90% at 20% 10%, #eef4ec 0%, #e8eef0 45%, #e4ebf1 100%); overflow:hidden; }
.fmap__svg { position:absolute; inset:0; width:100%; height:100%; }
.fmap__pins { position:absolute; inset:0; }
.fmap-pin { position:absolute; transform:translate(-50%,-100%); z-index:3; cursor:pointer; }
.fmap-pin__dot { background:#fff; color:var(--navy-800); border:1.5px solid var(--navy-700); border-radius:999px; font-family:var(--font-display); font-weight:800; font-size:.74rem; padding:.26rem .5rem; white-space:nowrap; box-shadow:0 3px 8px rgba(8,22,52,.22); transition:.14s; position:relative; }
.fmap-pin__dot::after { content:""; position:absolute; left:50%; bottom:-5px; transform:translateX(-50%); border:5px solid transparent; border-top-color:var(--navy-700); }
.fmap-pin:hover { z-index:6; }
.fmap-pin:hover .fmap-pin__dot, .fmap-pin.active .fmap-pin__dot { background:var(--orange-500); color:#fff; border-color:var(--orange-600); transform:scale(1.12); }
.fmap-pin:hover .fmap-pin__dot::after, .fmap-pin.active .fmap-pin__dot::after { border-top-color:var(--orange-600); }
.fmap-pin.cluster .fmap-pin__dot { background:var(--navy-700); color:#fff; }
.fmap__radius { position:absolute; border:2px dashed rgba(37,99,196,.55); background:rgba(37,99,196,.08); border-radius:50%; transform:translate(-50%,-50%); z-index:2; pointer-events:none; transition:width .3s, height .3s; }
.fmap__center { position:absolute; transform:translate(-50%,-50%); z-index:4; width:16px; height:16px; border-radius:50%; background:var(--navy-700); border:3px solid #fff; box-shadow:0 2px 6px rgba(8,22,52,.4); }
.fmap-city { position:absolute; transform:translate(-50%,-50%); z-index:1; font-size:.66rem; font-weight:700; color:var(--muted-2); letter-spacing:.01em; pointer-events:none; white-space:nowrap; text-shadow:0 1px 2px rgba(255,255,255,.8); }

/* karta przy pinie (popup) */
.fmap-pop { position:absolute; z-index:8; transform:translate(-50%,calc(-100% - 14px)); width:228px; background:#fff; border-radius:14px; box-shadow:var(--shadow-lg); overflow:hidden; display:none; }
.fmap-pop.show { display:block; }
.fmap-pop img { width:100%; height:110px; object-fit:cover; display:block; }
.fmap-pop__b { padding:9px 11px 11px; }
.fmap-pop__t { font-family:var(--font-display); font-weight:700; font-size:.82rem; line-height:1.2; color:var(--ink); display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.fmap-pop__p { font-family:var(--font-display); font-weight:800; color:var(--navy-800); margin-top:4px; }
.fmap-pop__x { position:absolute; top:7px; right:7px; width:26px; height:26px; border-radius:50%; border:0; background:rgba(255,255,255,.9); cursor:pointer; display:grid; place-items:center; }

/* kontrolki mapy */
.fmap-ctrl { position:absolute; right:12px; top:12px; z-index:5; display:flex; flex-direction:column; gap:7px; }
.fmap-ctrl button { width:40px; height:40px; border-radius:11px; border:1px solid var(--line); background:#fff; color:var(--navy-700); font-size:1.1rem; cursor:pointer; display:grid; place-items:center; box-shadow:var(--shadow-sm); }
.fmap-ctrl button:hover { background:var(--navy-50); }
.fmap-bar { position:absolute; left:12px; bottom:12px; top:auto; z-index:1001; display:flex; gap:8px; align-items:center; background:rgba(255,255,255,.94); -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px); border-radius:12px; padding:8px 12px; box-shadow:var(--shadow); flex-wrap:wrap; max-width:calc(100% - 90px); }
.fmap-bar__c { font-size:.82rem; font-weight:700; color:var(--ink); }
.fmap-bar__c b { color:var(--navy-700); }
.fmap-bar__rad { display:flex; align-items:center; gap:8px; font-size:.78rem; color:var(--muted); font-weight:600; }
.fmap-bar__rad input { width:96px; accent-color:var(--orange-500); }
.fmap-bar__rad b { color:var(--navy-700); white-space:nowrap; }
.fmap-card-list { } /* lista w split używa kompaktowych row-card */

/* lista w trybie mapy: kompaktowa karta */
.os-mini-row { flex:0 0 auto; display:grid; grid-template-columns:128px 1fr; gap:0; background:#fff; border:1px solid var(--line); border-radius:14px; overflow:hidden; cursor:pointer; transition:.14s; }
.os-mini-row:hover, .os-mini-row.active { border-color:var(--navy-500); box-shadow:var(--shadow); }
.os-mini-row__media { position:relative; aspect-ratio:1/1; background:var(--bg-2); }
.os-mini-row__media img { width:100%; height:100%; object-fit:cover; }
.os-mini-row__badges { position:absolute; top:7px; left:7px; display:flex; gap:4px; }
.os-mini-row__b { padding:10px 12px; display:flex; flex-direction:column; gap:5px; min-width:0; }
.os-mini-row__t { font-family:var(--font-display); font-weight:700; font-size:.88rem; line-height:1.25; color:var(--ink); display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.os-mini-row__attrs { display:flex; flex-wrap:wrap; gap:4px 9px; font-size:.74rem; color:var(--muted); }
.os-mini-row__attrs span { display:inline-flex; align-items:center; gap:4px; }
.os-mini-row__foot { margin-top:auto; display:flex; align-items:baseline; justify-content:space-between; gap:8px; }
.os-mini-row__price { font-family:var(--font-display); font-weight:800; font-size:1.02rem; color:var(--navy-800); }
.os-mini-row__price small { font-size:.62rem; font-weight:700; color:var(--muted); }
.os-mini-row__loc { font-size:.72rem; color:var(--muted-2); }

/* przycisk mapy mobilnej */
.os-map-fab { display:none; }

@media (max-width:1100px){ .os-flt__main { grid-template-columns:1.4fr 1fr 1fr auto; } .os-flt__main .os-field--rooms { display:none; } }
@media (max-width:991.98px){
  .os-flt__main { grid-template-columns:1fr 1fr; }
  .os-flt__adv-in { grid-template-columns:repeat(2,1fr); }
  .os-split { grid-template-columns:1fr; }
  .os-split__map { position:relative; height:62vh; order:-1; }
  .os-split__list { height:auto; overflow:visible; padding-right:0; }
}
@media (max-width:575.98px){
  .os-flt__main { grid-template-columns:1fr; }
  .os-flt__adv-in { grid-template-columns:1fr; }
  .os-split__map { height:54vh; }
  .fmap-bar { max-width:calc(100% - 70px); }
  .fmap-bar__rad input { width:72px; }
}

/* Stopka mini + przełącznik */
.lst-foot { background:var(--navy-950); color:#aab8d2; padding:26px 0; margin-top:30px; font-size:.85rem; }
.lst-foot a { color:#c4cee0; }
.lst-foot__in { display:flex; align-items:center; justify-content:space-between; gap:14px; flex-wrap:wrap; }
