/* ============================================================
   Property listings — search, filters, cards, detail, map
   ============================================================ */

/* Filter bar */
.filters { background: var(--paper); border: 1px solid var(--line-light); border-radius: var(--radius-lg); padding: 1rem; position: sticky; top: 84px; z-index: 30; }
.filters__row { display: grid; grid-template-columns: 1.6fr repeat(4, 1fr) auto; gap: .7rem; align-items: end; }
.filters .field label { font-family: var(--mono); text-transform: uppercase; letter-spacing: .1em; font-size: .6rem; color: var(--on-light-soft); }
.filters .field input, .filters .field select { font: inherit; font-size: .92rem; background: var(--cream); border: 1px solid var(--line-light); border-radius: 10px; padding: .6em .7em; color: var(--on-light); width: 100%; }
.filters .field input:focus, .filters .field select:focus { outline: none; border-color: var(--accent); }
.filters__more { display: none; grid-template-columns: repeat(4, 1fr); gap: .7rem; margin-top: .7rem; padding-top: .7rem; border-top: 1px solid var(--line-light); }
.filters__more.open { display: grid; }
.filters__btns { display: flex; gap: .5rem; }
.filters__toggle { font-family: var(--mono); font-size: .62rem; letter-spacing: .1em; text-transform: uppercase; color: var(--accent); margin-top: .6rem; }
@media (max-width: 900px){ .filters__row { grid-template-columns: 1fr 1fr; } .filters__more { grid-template-columns: 1fr 1fr; } }

/* Results header */
.results-head { display: flex; justify-content: space-between; align-items: center; gap: 1rem; margin: 2rem 0 1.2rem; flex-wrap: wrap; }
.results-head .count { font-family: var(--mono); font-size: .72rem; letter-spacing: .12em; text-transform: uppercase; color: var(--on-light-soft); }
.view-toggle { display: inline-flex; border: 1px solid var(--line-light); border-radius: 100px; overflow: hidden; }
.view-toggle button { padding: .5em 1em; font-family: var(--mono); font-size: .64rem; letter-spacing: .1em; text-transform: uppercase; color: var(--on-light-soft); }
.view-toggle button.is-active { background: var(--ink); color: var(--cream); }

/* Property grid */
.plist { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 1.3rem; }
.pcard { position: relative; background: var(--paper); border: 1px solid var(--line-light); border-radius: var(--radius-lg); overflow: hidden; display: flex; flex-direction: column; transition: transform .4s var(--ease), box-shadow .4s, border-color .4s; }
.pcard:hover { transform: translateY(-4px); box-shadow: 0 28px 56px -34px rgba(13,12,10,.45); border-color: rgba(13,12,10,.18); }
.pcard__media { position: relative; aspect-ratio: 3/2.1; overflow: hidden; background: var(--ink-2); }
.pcard__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 1s var(--ease); }
.pcard:hover .pcard__media img { transform: scale(1.06); }
.pcard__badge { position: absolute; top: 12px; left: 12px; font-family: var(--mono); text-transform: uppercase; letter-spacing: .1em; font-size: .6rem; padding: .4em .7em; border-radius: 6px; background: var(--accent); color: #fff; }
.pcard__badge.rent { background: var(--ink); }
.pcard__fav { position: absolute; bottom: 12px; right: 12px; top: auto; left: auto; width: 38px; height: 38px; border-radius: 50%; background: rgba(255,255,255,.85); backdrop-filter: blur(6px); display: grid; place-items: center; color: var(--ink); transition: background .3s, color .3s, transform .3s; }
.pcard__fav:hover { transform: scale(1.08); }
.pcard__fav.is-fav { background: var(--accent); color: #fff; }
.pcard__fav svg { width: 18px; height: 18px; }
.pd-save { display: inline-flex; align-items: center; gap: .55rem; line-height: 1; }
.pd-save svg { width: 15px; height: 17px; flex: none; }
.pd-save.is-fav { background: var(--accent); color: #fff; border-color: var(--accent); }
.pcard__body { padding: 1.2rem 1.3rem 1.4rem; display: flex; flex-direction: column; gap: .5rem; flex: 1; }
.pcard__price { font-family: var(--serif); font-size: var(--step-2); letter-spacing: -.01em; }
.pcard__title { font-weight: 600; font-size: .98rem; }
.pcard__loc { font-family: var(--mono); font-size: .64rem; letter-spacing: .1em; text-transform: uppercase; color: var(--on-light-soft); display: flex; align-items: center; gap: .4em; }
.pcard__loc svg { width: 12px; height: 12px; flex: 0 0 auto; color: var(--accent); }
.pcard__specs { margin-top: auto; padding-top: .9rem; border-top: 1px solid var(--line-light); display: flex; gap: 1.1rem; font-size: .8rem; color: var(--on-light-soft); }
.pcard__specs span { display: inline-flex; align-items: center; gap: .35em; }
.pcard__specs svg { width: 15px; height: 15px; color: var(--accent); }
.pcard__link { position: absolute; inset: 0; z-index: 1; }
.pcard__fav, .pcard a:not(.pcard__link) { position: relative; z-index: 2; }

/* Map */
#map { height: 70vh; min-height: 520px; border-radius: var(--radius-lg); overflow: hidden; border: 1px solid var(--line-light); }
.leaflet-popup-content-wrapper { border-radius: 14px; }
.map-pop { width: 200px; }
.map-pop img { width: 100%; height: 110px; object-fit: cover; border-radius: 10px; margin-bottom: .5rem; }
.map-pop b { font-family: var(--serif); font-size: 1.1rem; }
.map-pop span { display: block; font-size: .75rem; color: var(--on-light-soft); }
.map-pop a { color: var(--accent); font-family: var(--mono); font-size: .62rem; letter-spacing: .1em; text-transform: uppercase; }
.leaflet-marker-price { background: var(--ink); color: var(--cream); font-family: var(--mono); font-size: .62rem; letter-spacing: .04em; padding: .35em .6em; border-radius: 100px; white-space: nowrap; box-shadow: 0 4px 12px rgba(0,0,0,.3); transform: translate(-50%,-50%); }
.leaflet-marker-price.featured { background: var(--accent); }

.empty-state { text-align: center; padding: 4rem 1rem; color: var(--on-light-soft); }
.empty-state h3 { font-family: var(--serif); font-size: var(--step-2); color: var(--on-light); margin-bottom: .5rem; }
.skel { background: linear-gradient(100deg, var(--paper-2) 30%, var(--paper) 50%, var(--paper-2) 70%); background-size: 200% 100%; animation: skel 1.3s infinite; border-radius: var(--radius-lg); aspect-ratio: 3/3.4; }
@keyframes skel { to { background-position: -200% 0; } }

/* ---- Detail page ---- */
.pd-gallery { display: grid; grid-template-columns: 2fr 1fr; gap: .7rem; height: clamp(360px, 56vh, 640px); border-radius: var(--radius-lg); overflow: hidden; }
.pd-gallery__main { position: relative; overflow: hidden; cursor: zoom-in; }
.pd-gallery__main img { width: 100%; height: 100%; object-fit: cover; }
.pd-gallery__side { display: grid; grid-template-rows: 1fr 1fr; gap: .7rem; min-height: 0; }
.pd-gallery__main { min-height: 0; }
.pd-gallery__side .cell { position: relative; overflow: hidden; cursor: zoom-in; min-height: 0; }
.pd-gallery__side .cell img { width: 100%; height: 100%; object-fit: cover; }
.pd-gallery__more { position: absolute; inset: 0; background: rgba(13,12,10,.55); color: #fff; display: grid; place-items: center; font-family: var(--mono); letter-spacing: .1em; font-size: .8rem; }
@media (max-width: 760px){ .pd-gallery { grid-template-columns: 1fr; height: auto; } .pd-gallery__side { display: none; } .pd-gallery__main { height: 280px; } }

.pd-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 1.5rem; flex-wrap: wrap; margin: 2rem 0 1.5rem; }
.pd-head h1 { font-size: var(--step-3); }
.pd-head .loc { font-family: var(--mono); font-size: .7rem; letter-spacing: .12em; text-transform: uppercase; color: var(--on-light-soft); margin-top: .5rem; }
.pd-head .price { font-family: var(--serif); font-size: var(--step-3); text-align: right; }
.pd-head .ref { font-family: var(--mono); font-size: .64rem; letter-spacing: .1em; color: var(--on-light-faint); text-align: right; margin-top: .3rem; }

.pd-stats { display: flex; gap: 2.4rem; flex-wrap: wrap; padding: 1.4rem 0; border-block: 1px solid var(--line-light); margin-bottom: 2rem; }
.pd-stat { display: flex; flex-direction: column; gap: .2rem; }
.pd-stat b { font-family: var(--serif); font-size: var(--step-2); font-weight: 400; }
.pd-stat span { font-family: var(--mono); font-size: .62rem; letter-spacing: .1em; text-transform: uppercase; color: var(--on-light-soft); }

.pd-layout { display: grid; grid-template-columns: 1.7fr 1fr; gap: clamp(2rem,4vw,3.5rem); align-items: start; }
.pd-body h2 { font-size: var(--step-2); margin: 2rem 0 1rem; }
.pd-body p { color: var(--on-light-soft); line-height: 1.7; }
.pd-features { display: grid; grid-template-columns: repeat(2, 1fr); gap: .6rem 1.5rem; margin-top: 1rem; }
.pd-features li { display: flex; gap: .6em; align-items: center; color: var(--on-light-soft); font-size: .92rem; padding: .3rem 0; }
.pd-features li::before { content: ""; width: 7px; height: 7px; background: var(--accent); transform: skewX(-12deg); flex: 0 0 auto; }
.pd-map { height: 320px; border-radius: var(--radius-lg); overflow: hidden; border: 1px solid var(--line-light); margin-top: 1rem; }

.pd-aside { position: sticky; top: 96px; background: var(--paper); border: 1px solid var(--line-light); border-radius: var(--radius-lg); padding: 1.6rem; }
.pd-agent { display: flex; gap: .9rem; align-items: center; padding-bottom: 1.2rem; border-bottom: 1px solid var(--line-light); margin-bottom: 1.2rem; }
.pd-agent .av { width: 52px; height: 52px; border-radius: 50%; background: var(--ink); color: var(--cream); display: grid; place-items: center; font-family: var(--serif); font-size: 1.3rem; }
.pd-agent b { display: block; } .pd-agent span { font-size: .78rem; color: var(--on-light-soft); }
.pd-aside .btn { width: 100%; justify-content: center; margin-bottom: .6rem; }
.pd-aside textarea, .pd-aside input { font: inherit; width: 100%; background: var(--cream); border: 1px solid var(--line-light); border-radius: 10px; padding: .7em .8em; margin-bottom: .6rem; }
.pd-aside textarea:focus, .pd-aside input:focus { outline: none; border-color: var(--accent); }
@media (max-width: 900px){ .pd-layout { grid-template-columns: 1fr; } .pd-aside { position: static; } .pd-features { grid-template-columns: 1fr; } }

/* Lightbox */
.lightbox { position: fixed; inset: 0; z-index: 200; background: rgba(8,7,6,.95); display: none; place-items: center; padding: 4vw; }
.lightbox.open { display: grid; }
.lightbox img { max-width: 92vw; max-height: 86vh; object-fit: contain; border-radius: 10px; }
.lightbox__x, .lightbox__nav { position: absolute; color: #fff; background: rgba(255,255,255,.1); border-radius: 50%; width: 48px; height: 48px; display: grid; place-items: center; cursor: pointer; }
.lightbox__x { top: 4vw; right: 4vw; }
.lightbox__nav.prev { left: 3vw; top: 50%; transform: translateY(-50%); }
.lightbox__nav.next { right: 3vw; top: 50%; transform: translateY(-50%); }
