/* PronaAL Listings - Clean CSS */
:root {
  --bg: #f8f9fa;
  --card: #fff;
  --text: #1a1a2e;
  --muted: #6b7280;
  --border: #e5e7eb;
  --primary: #1e3a5f;
  --accent: #e53900;
  --radius: 12px;
  --sidebar-width: 300px;
}

* { margin:0;padding:0;box-sizing:border-box }
body { font-family:'Plus Jakarta Sans',sans-serif; background:var(--bg); color:var(--text) }

/* Header */
header { position:sticky; top:0; z-index:100; background:hsla(0,0%,100%,0.92); backdrop-filter:blur(12px); border-bottom:1px solid var(--border) }
.header-inner { max-width:1400px; margin:0 auto; padding:0 20px; display:flex; align-items:center; justify-content:space-between; height:60px }
.logo { display:flex; align-items:center; gap:8px; text-decoration:none; color:var(--text); font-weight:700; font-size:20px }
.logo-icon { width:36px; height:36px; background:var(--primary); border-radius:10px; display:flex; align-items:center; justify-content:center; color:#fff }
.header-right { display:flex; align-items:center; gap:10px }

/* Buttons */
.btn { display:inline-flex; align-items:center; gap:4px; padding:8px 16px; border-radius:8px; font-weight:600; font-size:13px; cursor:pointer; border:none; text-decoration:none; font-family:inherit; transition:all .15s }
.btn-primary { background:var(--primary); color:#fff }
.btn-primary:hover { opacity:.9 }
.btn-outline { background:transparent; border:1px solid var(--border); color:var(--text) }
.btn-outline:hover { border-color:var(--primary) }
.btn-sm { padding:5px 12px; font-size:12px }
.btn-apply { background:var(--accent); color:#fff; width:100%; justify-content:center; font-size:14px; padding:12px }
.btn-apply:hover { opacity:.9 }
.btn-icon { width:36px; height:36px; padding:0; justify-content:center; border-radius:10px }

/* Language dropdown */
.lang-dropdown { position:relative }
.lang-dropdown button { display:flex; align-items:center; gap:4px; padding:6px 12px; border:1px solid var(--border); border-radius:8px; background:#fff; cursor:pointer; font-size:13px; font-family:inherit }
.lang-menu { display:none; position:absolute; top:100%; right:0; background:#fff; border:1px solid var(--border); border-radius:8px; box-shadow:0 4px 12px rgba(0,0,0,.1); z-index:200; min-width:100px }
.lang-menu.show { display:block }
.lang-menu a { display:block; padding:8px 14px; font-size:13px; color:var(--text); text-decoration:none }
.lang-menu a:hover { background:#f3f4f6 }

/* Page layout */
.container { max-width:1400px; margin:0 auto; padding:0 20px }
.page-header { padding:24px 0; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap;gap:12px }
.page-title { font-size:26px; font-weight:700 }
.results-count { color:var(--muted); font-size:14px }
.header-controls { display:flex; align-items:center; gap:8px }

/* Mobile filter button */
.mobile-filter-btn { display:none }

/* View toggle */
.view-toggle { display:flex; background:var(--border); border-radius:8px; padding:2px }
.view-toggle button { padding:6px 12px; border:none; background:none; cursor:pointer; border-radius:6px; font-size:13px; color:var(--muted); font-family:inherit }
.view-toggle button.active { background:#fff; color:var(--text); box-shadow:0 1px 3px rgba(0,0,0,.1) }

/* Sort dropdown */
.sort-wrap { position:relative }
.sort-btn { padding:6px 12px; border:1px solid var(--border); border-radius:8px; background:#fff; cursor:pointer; font-size:13px; font-family:inherit; display:flex; align-items:center; gap:4px }
.sort-menu { display:none; position:absolute; top:100%; right:0; background:#fff; border:1px solid var(--border); border-radius:8px; box-shadow:0 4px 12px rgba(0,0,0,.1); z-index:200; min-width:150px }
.sort-menu.show { display:block }
.sort-menu button { display:block; width:100%; padding:8px 14px; border:none; background:none; cursor:pointer; font-size:13px; font-family:inherit; text-align:left }
.sort-menu button:hover { background:#f3f4f6 }

/* Main layout */
.main-layout { display:flex; gap:24px; padding-bottom:40px }

/* Sidebar filters */
.sidebar { width:var(--sidebar-width); flex-shrink:0; position:sticky; top:76px; align-self:flex-start; max-height:calc(100vh - 90px); overflow-y:auto }
.filter-group { margin-bottom:16px }
.filter-label { font-size:13px; font-weight:600; color:var(--muted); margin-bottom:6px }
.filter-input { width:100%; padding:8px 12px; border:1px solid var(--border); border-radius:8px; font-size:13px; font-family:inherit; outline:none }
.filter-input:focus { border-color:var(--primary) }
.filter-select { width:100%; padding:8px 12px; border:1px solid var(--border); border-radius:8px; font-size:13px; font-family:inherit; background:#fff }

/* Checkboxes */
.filter-checkboxes { display:flex; flex-direction:column; gap:4px }
.filter-checkboxes label { display:flex; align-items:center; gap:8px; padding:4px 0; font-size:13px; cursor:pointer }
.filter-checkboxes input[type="checkbox"] { width:16px; height:16px; accent-color:var(--primary) }

/* Range row */
.range-row { display:flex; gap:8px; align-items:center }
.range-row input { flex:1; min-width:0 }
.range-row span { color:var(--muted); font-size:13px }

/* Option buttons (rooms, bathrooms) */
.option-row { display:flex; gap:4px; flex-wrap:wrap }
.option-btn { padding:4px 10px; border:1px solid var(--border); border-radius:6px; background:#fff; font-size:12px; cursor:pointer; font-family:inherit }
.option-btn:hover { border-color:var(--primary) }
.option-btn.active { background:var(--primary); color:#fff; border-color:var(--primary) }

/* Draw area */
.draw-area-map { height:220px; border-radius:8px; margin-top:8px; background:#e5e7eb }
.draw-actions { display:flex; gap:8px; margin-top:8px }

/* Property grid */
.content { flex:1; min-width:0 }
.properties-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(270px,1fr)); gap:16px }

/* Property card */
.property-card { background:var(--card); border-radius:var(--radius); overflow:hidden; cursor:pointer; border:1px solid var(--border); transition:transform .2s,box-shadow .2s }
.property-card:hover { transform:translateY(-3px); box-shadow:0 8px 24px rgba(0,0,0,.1) }
.card-img { position:relative; aspect-ratio:4/3; background:#e5e7eb; overflow:hidden }
.card-img img { width:100%; height:100%; object-fit:cover }
.card-badges { position:absolute; top:8px; left:8px; display:flex; gap:4px }
.badge { padding:3px 8px; border-radius:4px; font-size:10px; font-weight:600 }
.badge-offer { background:rgba(0,0,0,.55); color:#fff }
.badge-featured { background:var(--accent); color:#fff }
.badge-new { background:#059669; color:#fff }
.card-body { padding:14px }
.card-price { font-size:20px; font-weight:700; color:var(--primary); margin-bottom:4px }
.card-title { font-size:14px; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; margin-bottom:4px }
.card-location { font-size:12px; color:var(--muted); margin-bottom:8px; display:flex; align-items:center; gap:4px }
.card-stats { display:flex; gap:12px; font-size:12px; color:var(--muted) }

/* Map view */
.map-container { height:500px; border-radius:var(--radius) }
.map-container.hidden { display:none }

/* Mobile sidebar overlay */
.mobile-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.4); z-index:150 }
.mobile-overlay.show { display:block }

/* Empty state */
.empty-state { text-align:center; padding:60px 20px; color:var(--muted) }
.empty-state .icon { font-size:48px; margin-bottom:16px }

/* Load more */
.load-more { display:flex; justify-content:center; padding:24px 0 }

@media (max-width:768px) {
  .mobile-filter-btn { display:flex !important }
  .sidebar { position:fixed; top:0; left:0; height:100vh; z-index:160; transform:translateX(-100%); transition:transform .3s; background:#fff; padding:20px; width:85%; max-width:320px }
  .sidebar.open { transform:translateX(0) }
  .main-layout { display:block }
  .properties-grid { grid-template-columns:1fr }
  .page-header { flex-direction:column; align-items:flex-start }
}
