:root{
  /* palette aligned to the reviewed page: ink-navy #0c2740 + gold */
  --navy:#0c2740; --navy-soft:#163a5c; --gold:#b0894e; --gold-deep:#8a6a36;
  --ink:#1c1c1a; --muted:#5a5952; --line:rgba(12,39,64,.13); --line-soft:rgba(12,39,64,.07);
  --bg:#f6f4ef; --card:#ffffff; --shadow:0 1px 2px rgba(12,39,64,.06),0 8px 24px rgba(12,39,64,.05);
  --serif:'Cormorant Garamond',Georgia,serif; --sans:'Mulish',-apple-system,sans-serif;
  /* Tobon filter-bar tokens (lifted from the approved prototype) */
  --navy-2:#16395c; --line-2:#d6cfc1; --paper:#f6f3ec; --r:999px; --r-panel:14px;
  --panel-shadow:0 18px 48px -20px rgba(14,42,68,.28);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--sans);color:var(--ink);background:var(--bg);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}

/* Header */
header{position:sticky;top:0;z-index:30;background:rgba(246,244,239,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line-soft);
  display:flex;align-items:center;justify-content:space-between;padding:14px 28px}
.brand{display:flex;flex-direction:column;line-height:1}
.brand b{font-family:var(--serif);font-weight:600;font-size:24px;letter-spacing:.04em;color:var(--navy)}
.brand span{font-size:9px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold-deep);margin-top:3px}
.head-cta{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:#fff;background:var(--navy);padding:11px 18px;border:0;display:inline-block}
.head-cta:hover{background:var(--navy-soft)}

/* Hero */
.hero{padding:30px 28px 18px;border-bottom:1px solid var(--line-soft)}
.hero h1{font-family:var(--serif);font-weight:500;font-size:38px;letter-spacing:.01em;color:var(--navy);margin:0}
.hero .sub{display:flex;align-items:center;gap:14px;margin-top:6px;color:var(--muted);font-size:13px;flex-wrap:wrap}
.hero .sub b{color:var(--gold-deep);font-weight:700}
.hero .rule{height:1px;width:54px;background:var(--gold);margin:14px 0 0}

/* ===== Tobon-style filter bar — markup/CSS lifted from the approved prototype;
   font mapped to the site face var(--sans), colors to the app palette, panel
   header class renamed .ph -> .phead to avoid clashing with the card photo .ph ===== */
.filters{position:sticky;top:63px;z-index:25;background:var(--card);border-bottom:1px solid var(--line);padding:12px 28px}
.bar{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.bar .loc{flex:1 1 280px;min-width:220px;display:flex;align-items:center;gap:10px;background:#fff;
  border:1px solid var(--line-2);border-radius:var(--r);padding:11px 16px}
.bar .loc .chip{display:inline-flex;align-items:center;gap:6px;background:var(--paper);border:1px solid var(--line-2);
  border-radius:var(--r);padding:4px 10px;font-size:13px;font-weight:600;white-space:nowrap}
.bar .loc .chip button{border:0;background:none;cursor:pointer;color:var(--muted);font-size:14px;line-height:1;padding:0}
.bar .loc input{border:0;outline:0;flex:1;font:500 14px/1 var(--sans);background:transparent;color:var(--ink);min-width:80px}
.bar .loc input::placeholder{color:#a7aeb8}
.ctrl{position:relative}
.btn{display:inline-flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line-2);border-radius:var(--r);
  padding:11px 16px;font:600 13.5px/1 var(--sans);color:var(--ink);cursor:pointer;transition:border-color .15s,box-shadow .15s}
.btn:hover{border-color:var(--navy)}
.btn.on{border-color:var(--navy);box-shadow:0 0 0 3px rgba(12,39,64,.08)}
.btn .chev{transition:transform .2s;opacity:.6}
.btn.on .chev{transform:rotate(180deg)}
.btn .ico{opacity:.7}
.btn.solid{background:var(--navy);color:#fff;border-color:var(--navy)}
.btn.solid:hover{background:var(--navy-2)}
.bar .spacer{flex:1}
/* Map / List toggle (pill) */
.toggle{display:inline-flex;border:1px solid var(--line-2);border-radius:var(--r);overflow:hidden;background:#fff}
.toggle button{border:0;background:none;padding:11px 16px;font:600 12px/1 var(--sans);letter-spacing:.08em;
  text-transform:uppercase;color:var(--muted);cursor:pointer}
.toggle button.sel{background:var(--navy);color:#fff}
/* popover panel */
.panel{position:absolute;top:calc(100% + 10px);left:0;min-width:300px;background:#fff;border:1px solid var(--line);
  border-radius:var(--r-panel);box-shadow:var(--panel-shadow);padding:18px;z-index:60;display:none}
.panel.open{display:block;animation:pop .16s ease}
@keyframes pop{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
.panel.right{left:auto;right:0}
.panel h4{margin:0;font:600 12px/1 var(--sans);letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.panel .phead{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.panel .phead .done{border:0;background:none;color:var(--navy);font:600 13px/1 var(--sans);cursor:pointer}
.radio,.checks{display:flex;flex-direction:column;gap:2px}
.radio label,.checks label{display:flex;align-items:center;gap:12px;padding:11px 6px;border-radius:8px;cursor:pointer;font-size:15px}
.radio label:hover,.checks label:hover{background:var(--paper)}
.radio input,.checks input{accent-color:var(--navy);width:17px;height:17px}
.range{display:flex;align-items:center;gap:12px}
.range .f{flex:1}
.range .f label{display:block;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.range .f .inp{display:flex;align-items:center;gap:6px;border:1px solid var(--line-2);border-radius:10px;padding:10px 12px}
.range .f .inp span{color:var(--muted)}
.range .f input,.range .f select{border:0;outline:0;width:100%;font:500 14px/1 var(--sans);background:transparent;color:var(--ink)}
.range .dash{color:var(--muted);margin-top:18px}
.blk{margin-bottom:16px}
.blk:last-of-type{margin-bottom:0}
.blk>.lbl{font:600 11px/1 var(--sans);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:9px}
.pfoot{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:18px;padding-top:14px;border-top:1px solid var(--line)}
.pfoot .reset{border:0;background:none;color:var(--muted);font:600 13px/1 var(--sans);cursor:pointer;text-decoration:underline;text-underline-offset:3px}
.viewbtn{flex:1;border:0;background:var(--navy);color:#fff;border-radius:var(--r);padding:13px 18px;font:700 14px/1 var(--sans);cursor:pointer;transition:background .15s}
.viewbtn:hover{background:var(--navy-2)}
.acc .row{border-top:1px solid var(--line)}
.acc .row:first-child{border-top:0}
.acc .row>button{width:100%;display:flex;align-items:center;justify-content:space-between;background:none;border:0;
  padding:14px 2px;font:600 14px/1 var(--sans);color:var(--ink);cursor:pointer}
.acc .row .body{display:none;padding:2px 2px 16px}
.acc .row.open .body{display:block}
.acc .row .chev{opacity:.5;transition:transform .2s}
.acc .row.open .chev{transform:rotate(180deg)}
.soon{font-size:11px;color:var(--gold-deep);font-weight:600;letter-spacing:.06em}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chips button{border:1px solid var(--line-2);background:#fff;border-radius:var(--r);padding:8px 14px;font:500 13px/1 var(--sans);cursor:pointer}
.chips button.sel{background:var(--navy);color:#fff;border-color:var(--navy)}
/* mobile: collapse controls into a drawer below 860px */
.m-filters{display:none}
.drawer{position:fixed;inset:0;z-index:80;display:none}
.drawer.open{display:block}
.drawer .scrim{position:absolute;inset:0;background:rgba(12,39,64,.4)}
.drawer .sheet{position:absolute;right:0;top:0;bottom:0;width:min(420px,90vw);background:#fff;padding:20px;overflow:auto;box-shadow:var(--panel-shadow)}
.drawer .sheet h3{font-family:var(--serif);font-weight:600;margin:0 0 8px;color:var(--navy)}
@media(max-width:860px){
  .bar .spacer,.bar .btn.solid{display:none}
  .bar .loc{flex:1 1 100%}                 /* search box gets its own row */
  .bar .toggle{display:inline-flex}        /* keep the Split/Map/List view-toggle on mobile */
  .bar .toggle button{padding:10px 13px}
  .m-filters{display:inline-flex;margin-left:auto}   /* Filters sits at the right of row 2 */
}
/* Functional mobile drawer: the 5 popover controls are relocated into #drawer-filters
   (<=860px) by syncBarLayout() and render as a stacked accordion — tap a row to expand,
   set values (live count updates), then the single bottom "View N" button applies. */
#drawer-filters{display:flex;flex-direction:column;margin:8px 0 4px}
#drawer-filters .ctrl{position:static;border-top:1px solid var(--line)}
#drawer-filters .ctrl:first-child{border-top:0}
#drawer-filters .ctrl>.btn{width:100%;justify-content:space-between;border:0;border-radius:0;background:none;padding:16px 2px;font-size:15px}
#drawer-filters .ctrl>.btn:hover{border:0}
#drawer-filters .ctrl>.btn.on{box-shadow:none}
#drawer-filters .panel{position:static;display:none;min-width:0;width:auto;box-shadow:none;border:0;border-radius:0;padding:0 2px 16px;animation:none}
#drawer-filters .panel.right{right:auto}
#drawer-filters .panel.open{display:block}
#drawer-filters .panel .phead{display:none}
#drawer-filters .panel .pfoot{display:none}
/* outline button reused by empty-state / retry */
.btn-line{background:transparent;border:1px solid var(--line);color:var(--navy);font-size:12px;letter-spacing:.06em;
  padding:8px 14px;border-radius:2px;text-transform:uppercase}
.btn-line:hover{border-color:var(--gold);color:var(--gold-deep)}

/* Split layout + view modes */
.layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.05fr)}
#map{position:sticky;top:128px;height:calc(100vh - 128px);background:#e7e4dc}
.results{padding:18px 24px 60px}
.resbar{display:flex;align-items:baseline;justify-content:flex-start;flex-wrap:wrap;margin:2px 4px 16px}
.resbar .count{font-size:13px;color:var(--muted)}
.resbar .count b{color:var(--navy);font-weight:700}
.grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.layout.mode-list{grid-template-columns:1fr}
.layout.mode-list #map{display:none}
.layout.mode-list .grid{grid-template-columns:repeat(3,1fr)}
.layout.mode-map{grid-template-columns:1fr}
.layout.mode-map .results{display:none}

/* Card */
.card{background:var(--card);border:1px solid var(--line-soft);border-radius:4px;overflow:hidden;box-shadow:var(--shadow);
  transition:transform .18s ease,box-shadow .18s ease;cursor:pointer}
.card:hover,.card.active{transform:translateY(-2px);box-shadow:0 2px 4px rgba(12,39,64,.08),0 16px 36px rgba(12,39,64,.10)}
.card.active{border-color:var(--gold)}
.ph{position:relative;aspect-ratio:16/10;background:#cfc8ba center/cover no-repeat;overflow:hidden}
.ph.noimg{background:linear-gradient(135deg,#1a3350,#0c2740)}
.ph.noimg::after{content:'Andres Jara';position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-size:18px;letter-spacing:.04em;color:rgba(255,255,255,.62)}
.ph .ph-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;background:#cfc8ba}
.ph .ph-meta{position:absolute;bottom:10px;left:11px;display:flex;gap:6px;align-items:center;z-index:3}
.ph .pill{background:rgba(12,39,64,.78);color:#fff;font-size:10px;padding:3px 8px;border-radius:2px}
.ph .pill.feat{background:rgba(255,255,255,.92);color:var(--gold-deep);letter-spacing:.05em;text-transform:uppercase}
.cb{padding:11px 15px 13px;display:grid;grid-template-columns:1fr auto;column-gap:14px;align-items:start}
.cb .price{font-family:var(--serif);font-weight:600;font-size:25px;color:var(--navy);line-height:1.05;grid-column:1;grid-row:1}
.cb .adr{font-size:13px;color:#34342f;margin-top:3px;grid-column:1;grid-row:2}
.cb .adr .city{color:var(--muted);display:block;font-size:12px;margin-top:1px}
.cb .right{grid-column:2;grid-row:1;display:flex;flex-direction:column;align-items:flex-end;text-align:right;gap:3px;min-width:120px}
.cb .bld{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-deep);font-weight:600;
  max-width:130px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cb .specs{font-size:12.5px;color:#44443f;white-space:nowrap}

/* Map markers */
.mk{font-family:var(--sans);font-size:13px;font-weight:700;color:#fff;background:var(--navy);
  padding:6px 11px;border-radius:15px;border:1.5px solid #fff;box-shadow:0 2px 7px rgba(0,0,0,.3);white-space:nowrap;cursor:pointer;transition:background .15s,transform .15s}
.mk:hover,.mk.active{background:var(--gold-deep);transform:scale(1.08)}
.maplibregl-popup-content{font-family:var(--sans);padding:0;border-radius:4px;overflow:hidden;box-shadow:0 8px 24px rgba(0,0,0,.2)}
.pop{width:200px}.pop .pop-ph{height:110px;background:#cfc8ba center/cover no-repeat}
.pop .pop-ph.noimg{background:linear-gradient(135deg,#1a3350,#0c2740)}
.pop .pop-b{padding:9px 11px}.pop .pop-pr{font-family:var(--serif);font-weight:600;font-size:18px;color:var(--navy)}
.pop .pop-ad{font-size:11px;color:var(--muted);margin-top:2px}
.pop .pop-sub{font-size:11px;color:var(--ink);margin-top:3px;font-weight:600}
a.pop{display:block;color:inherit}a.pop:hover .pop-pr{color:var(--gold-deep)}

/* States */
.empty{padding:60px 20px;text-align:center;color:var(--muted);grid-column:1/-1}
.empty .btn-line{margin-top:12px}
.pagination{display:flex;justify-content:center;gap:6px;margin-top:30px}
.pagination button{min-width:34px;height:34px;border:1px solid var(--line);background:#fff;color:var(--navy);border-radius:2px;font-size:13px}
.pagination button.on{background:var(--navy);color:#fff;border-color:var(--navy)}
.pagination button:disabled{opacity:.4;cursor:default}
body.busy .grid{opacity:.5;pointer-events:none;transition:opacity .15s}

@media(max-width:1000px){
  .layout{grid-template-columns:1fr}
  #map{position:relative;top:0;height:340px;order:-1}
  .layout.mode-list #map{display:none}
  .layout.mode-list .grid{grid-template-columns:1fr 1fr}
  .layout.mode-map #map{height:calc(100vh - 120px)}  /* "Map" view = near-fullscreen map (results hidden) */
}
@media(max-width:560px){ .grid,.layout.mode-list .grid{grid-template-columns:1fr} .hero h1{font-size:30px} .filters{padding:12px 16px} }

/* Card photo carousel (lazy: only the first photo loads until navigated) */
.ph .navarr{position:absolute;top:50%;transform:translateY(-50%);width:28px;height:28px;border-radius:50%;
  background:rgba(255,255,255,.86);border:0;color:var(--navy);font-size:17px;line-height:26px;text-align:center;
  padding:0;z-index:3;opacity:0;transition:opacity .15s;box-shadow:0 1px 4px rgba(12,39,64,.3)}
.card:hover .ph .navarr{opacity:.95}
.ph .navarr:hover{background:#fff}
.ph .navarr.prev{left:8px}.ph .navarr.next{right:8px}
.ph .ph-count{position:absolute;bottom:10px;right:10px;z-index:3;background:rgba(12,39,64,.72);color:#fff;
  font-size:10px;letter-spacing:.03em;padding:2px 7px;border-radius:10px}
@media(hover:none){ .ph .navarr{opacity:.95} }

/* Cluster marker (count) — gold disc, distinct from the navy price pills */
.mk.cluster{background:var(--gold-deep);min-width:36px;height:36px;border-radius:18px;padding:0 11px;
  display:flex;align-items:center;justify-content:center;font-size:13.5px}
.mk.cluster:hover{background:var(--navy);transform:scale(1.08)}

/* Coincident-units popup (same building/coords) — scrollable list */
.units{width:312px;max-height:392px;overflow-y:auto}
.units .units-h{font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-deep);font-weight:700;
  padding:11px 14px 9px;position:sticky;top:0;background:#fff;border-bottom:1px solid var(--line)}
.units a.unit{display:flex;gap:11px;padding:10px 14px;border-bottom:1px solid var(--line-soft);align-items:center;color:inherit}
.units a.unit:hover{background:var(--bg)}
.units .unit-ph{flex:0 0 auto;width:66px;height:52px;border-radius:4px;background:#cfc8ba center/cover no-repeat}
.units .unit-ph.noimg{background:linear-gradient(135deg,#1a3350,#0c2740)}
.units .unit-b{display:flex;flex-direction:column;min-width:0}
.units .unit-pr{font-family:var(--serif);font-weight:600;font-size:18px;color:var(--navy);line-height:1.1}
.units .unit-sub{font-size:12px;color:var(--muted)}
.units a.unit:hover .unit-pr{color:var(--gold-deep)}

/* ===== Page 5002 canvas trim =====================================================
 * The page is served via the theme's "Page without header, footer" template
 * (Elementor is not installed, so the old elementor_canvas value fell back to the
 * default template and rendered the theme nav-header twice). That template still
 * emits an empty #masthead shell and an 80px .site-content_wrap top margin. Scope
 * these to this page only (body.page-id-5002) so our own brand header sits flush
 * at the very top with no leftover theme chrome. */
body.page-id-5002 #masthead{display:none}
body.page-id-5002 .site-content_wrap{margin-top:0}
body.page-id-5002 .entry-header{padding:0;margin:0}
body.page-id-5002 #content,body.page-id-5002 .site-content{padding-top:0;margin-top:0}

/* ===== Accessibility: visible keyboard focus (WCAG 2.4.7) — added 2026-06 ===== */
.btn:focus-visible,.toggle button:focus-visible,.viewbtn:focus-visible,.reset:focus-visible,
.done:focus-visible,.chips button:focus-visible,.acc .row>button:focus-visible,
.pagination button:focus-visible,.btn-line:focus-visible,.head-cta:focus-visible,
.card:focus-visible,a.pop:focus-visible,.units a.unit:focus-visible,.navarr:focus-visible,
.bar .loc input:focus-visible,.range .f input:focus-visible,.range .f select:focus-visible,
.acc .body .inp input:focus-visible,.bar .loc .chip button:focus-visible{
  outline:2px solid var(--navy);outline-offset:2px;border-radius:4px}
.bar .loc:focus-within{border-color:var(--navy);box-shadow:0 0 0 3px rgba(12,39,64,.08)}

/* ===== Hide the mobile "Filters" drawer button on desktop (duplicates the in-bar filters; was leaking onto desktop and wrapping the bar to a 2nd row) — 2026-06 ===== */
@media (min-width:861px){ .filters .bar .m-filters{ display:none !important; } }

/* ===== Sort-by control in the results bar — 2026-06 ===== */
.resbar{align-items:center;gap:8px}
.resbar .sortby{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);white-space:nowrap;margin-left:auto}
.resbar .sortby select{font:600 13px/1 var(--sans);color:var(--navy);border:0;background:transparent;cursor:pointer;padding:4px 2px;outline:0}
.resbar .sortby select:focus-visible{outline:2px solid var(--navy);outline-offset:2px;border-radius:4px}

/* ===== Map basemap toggle (Map / Satellite) — 2026-06 ===== */
.aj-basemap{display:flex;overflow:hidden;border-radius:6px;box-shadow:0 1px 4px rgba(12,39,64,.30);font-family:var(--sans)}
.aj-basemap button{border:0;background:#fff;color:var(--muted);font:600 12px/1 var(--sans);letter-spacing:.02em;padding:8px 13px;cursor:pointer}
.aj-basemap button+button{border-left:1px solid var(--line)}
.aj-basemap button.on{background:var(--navy);color:#fff}

/* ===== Market Snapshot — inline in the results header — 2026-06 ===== */
.mkt-inline{display:inline-flex;align-items:center;gap:9px;font-size:12.5px;color:var(--navy);flex-wrap:wrap}
.mkt-sep{width:1px;height:14px;background:var(--line-2);display:inline-block}
.mkt-stat{white-space:nowrap;color:var(--navy)}
.mkt-stat b{font-weight:700}
.mkt-stat i{font-style:normal;color:var(--muted);font-size:11.5px}
.mkt-yoy{display:inline-flex;align-items:center;gap:3px;font-size:12px;font-weight:700;white-space:nowrap;cursor:help}
.mkt-yoy i{font-style:normal;font-weight:600;font-size:10px;opacity:.7;letter-spacing:.02em}
.mkt-yoy.up{color:#1c7c4a}
.mkt-yoy.down{color:#b3402f}
.mkt-i{color:var(--muted);opacity:.5;font-size:12px;cursor:help}
/* Market Report CTA — solid-navy overlay pill (matches the Map/Satellite toggle), centered atop the map */
.aj-map-report{position:absolute;top:12px;left:50%;transform:translateX(-50%);z-index:4;display:flex;align-items:center;gap:7px;max-width:min(64%,460px);font:600 13px/1.1 var(--sans);color:#fff;text-decoration:none;padding:9px 17px;border:1px solid rgba(255,255,255,.16);border-radius:999px;background:var(--navy);box-shadow:0 2px 10px rgba(12,39,64,.38);transition:filter .16s,border-color .16s,box-shadow .16s}
.aj-map-report:hover{filter:brightness(1.12);border-color:var(--gold,#b8956a);box-shadow:0 4px 16px rgba(12,39,64,.5)}
.aj-map-report .mr-ic{font-size:14px;line-height:1;flex:none}
.aj-map-report .mr-tx{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.aj-map-report b{font-weight:800;color:#dcc08a}
@media(max-width:560px){.mkt-inline{gap:9px;font-size:12px;width:100%;margin-top:6px}.mkt-sep{display:none}.aj-map-report{font-size:12px;padding:7px 13px;max-width:90%}}

/* the athome theme's full-page preloader lingers as an invisible overlay and intercepts clicks on the map controls/markers; this search page doesn't need it. */
body.page-id-5002 .preloader-page,body.page-id-5002 #cssload-wrapper,body.page-id-5002 .page-preloader-cover{display:none!important}

/* ===== Location autocomplete dropdown — 2026-06 ===== */
.bar .loc{position:relative}
.ac-pop{position:absolute;top:calc(100% + 8px);left:0;right:0;min-width:320px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--panel-shadow);z-index:70;max-height:380px;overflow:auto;padding:6px}
.ac-pop .ac-row{display:flex;align-items:center;gap:12px;width:100%;border:0;background:none;text-align:left;padding:10px 12px;border-radius:10px;cursor:pointer}
.ac-pop .ac-row:hover,.ac-pop .ac-row.on{background:var(--paper)}
.ac-pop .ac-ic{flex:0 0 36px;height:36px;border-radius:50%;background:var(--paper);display:flex;align-items:center;justify-content:center;color:var(--navy)}
.ac-pop .ac-tx{flex:1 1 auto;min-width:0;display:flex;flex-direction:column}
.ac-pop .ac-lb{font:600 14px/1.2 var(--sans);color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ac-pop .ac-sub{font-size:11.5px;color:var(--muted);margin-top:2px}
.ac-pop .ac-bd{flex:0 0 auto;font:700 9px/1 var(--sans);letter-spacing:.08em;color:var(--gold-deep);background:var(--paper);border:1px solid var(--line-2);padding:5px 8px;border-radius:999px}
.ac-pop .ac-row[data-i="0"] .ac-bd{color:#fff;background:var(--navy);border-color:var(--navy)}

/* ===== Property detail overlay (opens /property.html over the search page) — 2026-06 ===== */
.pdp-overlay{position:fixed;inset:0;z-index:1000;display:none}
.pdp-overlay.open{display:block}
.pdp-overlay .pdp-scrim{position:absolute;inset:0;background:rgba(12,39,64,.45);backdrop-filter:blur(2px)}
.pdp-overlay .pdp-sheet{position:absolute;top:32px;bottom:32px;left:0;right:0;margin:0 auto;width:min(1160px,92vw);background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 30px 80px -20px rgba(12,39,64,.55);display:flex;flex-direction:column;animation:pdpIn .18s ease}
@keyframes pdpIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.pdp-overlay .pdp-close{position:absolute;top:14px;right:16px;z-index:2;width:40px;height:40px;border-radius:50%;border:0;background:rgba(255,255,255,.94);box-shadow:0 2px 10px rgba(12,39,64,.28);font-size:24px;line-height:38px;text-align:center;color:var(--navy);cursor:pointer}
.pdp-overlay .pdp-close:hover{background:#fff}
.pdp-overlay .pdp-frame{flex:1 1 auto;width:100%;height:100%;border:0;display:block;background:#fff}
body.pdp-locked{overflow:hidden}
@media(max-width:680px){ .pdp-overlay .pdp-sheet{top:0;bottom:0;width:100%;border-radius:0} }
