/* ═══════════════════════════════════════════════════════════
   HamaraMakaan — Main Stylesheet
   Design System: Playfair Display + DM Sans + Blue/Green palette
   ═══════════════════════════════════════════════════════════ */

:root {
  --blue:        #2563eb;
  --blue-light:  #4fa8f5;
  --blue-dark:   #1d4ed8;
  --green:       #1D9E75;
  --green-light: #5DCAA5;
  --text-primary: #1e3a5f;
  --text-muted:  #64748b;
  --bg:          #f8fafc;
  --card-border: #e2e8f0;
  --white:       #ffffff;
  --shadow-sm:   0 1px 3px rgba(0,0,0,.08);
  --shadow-md:   0 4px 16px rgba(37,99,235,.1);
  --shadow-lg:   0 8px 32px rgba(37,99,235,.15);
  --radius-sm:   8px;
  --radius-md:   14px;
  --radius-lg:   20px;
  --font-heading: 'Playfair Display', serif;
  --font-body:   'DM Sans', sans-serif;
  --gradient-hero: linear-gradient(135deg, #1e3a5f 0%, #1d4ed8 50%, #0ea5e9 100%);
  --gradient-btn:  linear-gradient(90deg, #4fa8f5 0%, #2563eb 100%);
  --gradient-card: linear-gradient(135deg, #e0f4ff 0%, #c2e8ff 50%, #b8c8ff 100%);
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font-body);
  background: var(--bg);
  color: var(--text-primary);
  line-height: 1.6;
}
h1,h2,h3,h4,h5 { font-family: var(--font-heading); color: var(--text-primary); }
a { text-decoration: none; }

/* ── Utilities ─────────────────────────────────────────── */
.fw-500 { font-weight: 500; }
.fw-600 { font-weight: 600; }
.text-blue  { color: var(--blue)!important; }
.text-green { color: var(--green)!important; }
.bg-blue    { background: var(--blue)!important; }
.bg-green   { background: var(--green)!important; }
.section-title {
  font-family: var(--font-heading);
  font-size: clamp(1.4rem, 3vw, 2rem);
  color: var(--text-primary);
  font-weight: 600;
}
.section-subtitle { color: var(--text-muted); font-size: .95rem; }

/* ── Buttons ───────────────────────────────────────────── */
.btn-hm-primary {
  background: var(--gradient-btn);
  color: #fff; border: none;
  border-radius: var(--radius-sm);
  font-weight: 500; font-family: var(--font-body);
  transition: opacity .2s, transform .1s;
}
.btn-hm-primary:hover { opacity:.88; color:#fff; transform:translateY(-1px); }

.btn-hm-green {
  background: var(--green);
  color: #fff; border: none;
  border-radius: var(--radius-sm);
  font-weight: 500; font-family: var(--font-body);
  transition: background .2s;
}
.btn-hm-green:hover { background: #178a65; color:#fff; }

.btn-outline-hm {
  border: 1.5px solid var(--blue);
  color: var(--blue);
  background: transparent;
  border-radius: var(--radius-sm);
  font-weight: 500; font-family: var(--font-body);
  transition: all .2s;
}
.btn-outline-hm:hover { background: var(--blue); color:#fff; }

/* ── Navbar ─────────────────────────────────────────────── */
.hm-navbar {
  background: rgba(255,255,255,.96);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--card-border);
  padding: .7rem 0;
  transition: box-shadow .3s;
  z-index: 1040;
}
.hm-navbar.scrolled { box-shadow: var(--shadow-md); }
.hm-logo { display:flex; align-items:center; gap:10px; }
.logo-icon {
  width:36px; height:36px;
  background: var(--gradient-btn);
  border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  font-size:18px; color:#fff; font-weight:700;
  font-family: var(--font-heading);
}
.logo-name { font-size:1rem; color:var(--text-primary); font-family:var(--font-body); }
.logo-name strong { color:var(--blue); }
.hm-navbar .nav-link {
  color: var(--text-primary)!important;
  font-weight: 500; padding: .4rem .8rem!important;
  border-radius: var(--radius-sm);
  transition: background .2s, color .2s;
}
.hm-navbar .nav-link:hover,
.hm-navbar .nav-link.active { background: #eff6ff; color: var(--blue)!important; }
.avatar-circle {
  width:28px; height:28px; border-radius:50%;
  background: var(--gradient-btn);
  color:#fff; font-size:.75rem; font-weight:600;
  display:flex; align-items:center; justify-content:center;
}

/* ── Hero Section ────────────────────────────────────────── */
.hm-hero {
  background: var(--gradient-hero);
  min-height: 560px;
  display: flex; align-items: center;
  position: relative; overflow: hidden;
  padding: 4rem 0;
}
.hm-hero::before {
  content:'';
  position:absolute; inset:0;
  background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1440 560"><path fill="rgba(255,255,255,0.04)" d="M0,320L80,288C160,256,320,192,480,186.7C640,181,800,235,960,234.7C1120,235,1280,181,1360,154.7L1440,128V560H0Z"/></svg>') no-repeat bottom/cover;
}
.hero-title {
  font-family: var(--font-heading);
  font-size: clamp(2rem, 5vw, 3.2rem);
  font-weight: 700; color:#fff; line-height:1.2;
}
.hero-subtitle { color:rgba(255,255,255,.8); font-size:1.05rem; }
.hero-search-card {
  background: rgba(255,255,255,.97);
  border-radius: var(--radius-lg);
  padding: 2rem;
  box-shadow: var(--shadow-lg);
}
.search-tabs { display:flex; gap:.5rem; margin-bottom:1.2rem; }
.search-tab {
  padding:.45rem 1.2rem; border-radius:50px;
  border:1.5px solid var(--card-border);
  background:transparent; font-size:.85rem; font-weight:500;
  color:var(--text-muted); cursor:pointer; transition:all .2s;
  font-family: var(--font-body);
}
.search-tab.active {
  background: var(--blue); border-color: var(--blue);
  color: #fff;
}
.search-tab:hover:not(.active) { border-color:var(--blue); color:var(--blue); }
.search-input-group {
  display:grid; grid-template-columns:1fr 1fr 1fr 1fr auto;
  gap:.75rem; align-items:end;
}
@media(max-width:900px) {
  .search-input-group { grid-template-columns:1fr 1fr; }
}
@media(max-width:576px) {
  .search-input-group { grid-template-columns:1fr; }
}
.search-field label {
  font-size:.75rem; font-weight:500; color:var(--text-muted);
  display:block; margin-bottom:.3rem;
}
.search-field select, .search-field input {
  width:100%; padding:.6rem .9rem;
  border:1.5px solid var(--card-border); border-radius:var(--radius-sm);
  font-size:.9rem; font-family:var(--font-body); color:var(--text-primary);
  background:#fff; outline:none; transition:border .2s;
}
.search-field select:focus, .search-field input:focus {
  border-color:var(--blue); box-shadow:0 0 0 3px rgba(37,99,235,.1);
}
.btn-search {
  background: var(--gradient-btn); color:#fff; border:none;
  border-radius:var(--radius-sm); padding:.7rem 2rem;
  font-size:1rem; font-weight:600; font-family:var(--font-body);
  cursor:pointer; transition:opacity .2s, transform .1s;
  white-space:nowrap; height:42px;
}
.btn-search:hover { opacity:.88; transform:translateY(-1px); }

/* ── Property Card ───────────────────────────────────────── */
.prop-card {
  background: #fff;
  border-radius: var(--radius-md);
  border: 1px solid var(--card-border);
  overflow: hidden;
  transition: transform .2s, box-shadow .2s;
  height: 100%;
}
.prop-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}
.prop-card-img {
  position:relative; overflow:hidden;
  height:200px; background:#e2e8f0;
  cursor:pointer;
}
.prop-img-slider {
  display:flex;
  height:200px;
  transition:transform .5s ease;
  will-change:transform;
}
.prop-img-slider img {
  min-width:100%; height:200px;
  object-fit:cover; flex-shrink:0;
}
.prop-img-dots {
  position:absolute; bottom:8px; left:50%;
  transform:translateX(-50%);
  display:flex; gap:5px; z-index:2;
  pointer-events:none;
}
.dot {
  width:6px; height:6px; border-radius:50%;
  background:rgba(255,255,255,.55);
  transition:background .25s, transform .25s;
}
.dot.active { background:#fff; transform:scale(1.3); }
.prop-badge {
  position:absolute; top:10px; left:10px;
  padding:.2rem .65rem; border-radius:50px;
  font-size:.7rem; font-weight:600; letter-spacing:.5px;
  text-transform:uppercase;
}
.badge-sale  { background:#2563eb; color:#fff; }
.badge-rent  { background:#1D9E75; color:#fff; }
.badge-new   { background:#f59e0b; color:#fff; }
.prop-save-btn {
  position:absolute; top:10px; right:10px;
  width:34px; height:34px; border-radius:50%;
  background:rgba(255,255,255,.9); border:none;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:all .2s; font-size:.95rem;
  color:#94a3b8;
}
.prop-save-btn:hover, .prop-save-btn.saved { color:#ef4444; background:#fff; }
.prop-premium-badge {
  position:absolute; bottom:10px; left:10px;
  background:linear-gradient(135deg,#f59e0b,#d97706);
  color:#fff; font-size:.68rem; font-weight:700;
  padding:.2rem .6rem; border-radius:50px;
  letter-spacing:.4px; text-transform:uppercase;
  box-shadow:0 2px 8px rgba(245,158,11,.4);
}
.prop-card-body { padding:1rem; }
.prop-price {
  font-size:1.25rem; font-weight:700; color:var(--text-primary);
  font-family:var(--font-heading);
}
.prop-price-sub { font-size:.75rem; color:var(--text-muted); font-weight:400; }
.prop-title {
  font-size:.9rem; font-weight:600; color:var(--text-primary);
  margin:.3rem 0 .3rem;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}
.prop-location { font-size:.8rem; color:var(--text-muted); }
.prop-location i { color:var(--blue); }
.prop-meta {
  display:flex; gap:.8rem; flex-wrap:wrap;
  font-size:.78rem; color:var(--text-muted);
  border-top:1px solid var(--card-border);
  padding-top:.6rem; margin-top:.6rem;
}
.prop-meta span { display:flex; align-items:center; gap:.3rem; }
.prop-meta i { color:var(--blue); font-size:.7rem; }
.prop-card-footer {
  padding:.6rem 1rem;
  border-top:1px solid var(--card-border);
  display:flex; gap:.5rem; align-items:center;
}
.prop-poster { font-size:.75rem; color:var(--text-muted); flex:1; }
.btn-view-details {
  font-size:.8rem; padding:.3rem .9rem;
  border-radius:var(--radius-sm);
  background:var(--gradient-btn); color:#fff; border:none;
  font-family:var(--font-body); font-weight:500; cursor:pointer;
  transition:opacity .2s;
}
.btn-view-details:hover { opacity:.85; }

/* ── List-view card ─────────────────────────────────────── */
.prop-card-list {
  background:#fff; border-radius:var(--radius-md);
  border:1px solid var(--card-border);
  overflow:hidden;
  display:flex; gap:0;
  transition: transform .15s, box-shadow .15s;
}
.prop-card-list:hover { box-shadow:var(--shadow-md); }
.prop-card-list .prop-card-img { width:260px; min-width:260px; height:auto; flex-shrink:0; }
@media(max-width:576px) {
  .prop-card-list { flex-direction:column; }
  .prop-card-list .prop-card-img { width:100%; height:180px; }
}
.prop-card-list-body { padding:1.2rem; flex:1; }

/* ── Skeleton ────────────────────────────────────────────── */
.skeleton {
  background: linear-gradient(90deg, #f0f0f0 25%, #e8e8e8 50%, #f0f0f0 75%);
  background-size: 200% 100%;
  animation: shimmer 1.4s infinite;
  border-radius: var(--radius-sm);
}
@keyframes shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}
.skeleton-card {
  background:#fff; border-radius:var(--radius-md);
  border:1px solid var(--card-border); overflow:hidden; padding:0;
}

/* ── City Cards ──────────────────────────────────────────── */
.city-card {
  border-radius:var(--radius-md); overflow:hidden;
  position:relative; height:160px; cursor:pointer;
  transition: transform .2s, box-shadow .2s;
}
.city-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.city-card-img {
  width:100%; height:100%; object-fit:cover;
  transition:transform .4s;
}
.city-card:hover .city-card-img { transform:scale(1.08); }
.city-card-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(30,58,95,.7) 0%, transparent 60%);
  display:flex; align-items:flex-end; padding:1rem;
}
.city-card-name { color:#fff; font-weight:600; font-size:1rem; }
.city-card-count { color:rgba(255,255,255,.7); font-size:.75rem; }

/* ── Stats Section ───────────────────────────────────────── */
.stats-section { background: var(--gradient-card); }
.stat-box { text-align:center; padding:1.5rem; }
.stat-number {
  font-family:var(--font-heading);
  font-size:2.4rem; font-weight:700; color:var(--blue);
  display:block;
}
.stat-label { color:var(--text-muted); font-size:.9rem; }

/* ── How it Works ────────────────────────────────────────── */
.step-card {
  background:#fff; border-radius:var(--radius-md);
  border:1px solid var(--card-border);
  padding:2rem 1.5rem; text-align:center;
  transition: transform .2s, box-shadow .2s;
}
.step-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }
.step-icon {
  width:70px; height:70px; border-radius:50%;
  background: var(--gradient-card);
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 1rem;
  font-size:1.6rem; color:var(--blue);
  border:2px solid rgba(37,99,235,.15);
}
.step-number {
  display:inline-flex; align-items:center; justify-content:center;
  width:22px; height:22px; border-radius:50%;
  background:var(--blue); color:#fff;
  font-size:.7rem; font-weight:700;
  position:absolute; top:-5px; right:-5px;
}

/* ── Testimonial ─────────────────────────────────────────── */
.testi-card {
  background:#fff; border-radius:var(--radius-md);
  border:1px solid var(--card-border);
  padding:1.5rem; position:relative;
}
.testi-card::before {
  content:'"'; font-family:var(--font-heading);
  font-size:4rem; color:var(--blue); opacity:.15;
  position:absolute; top:10px; left:16px; line-height:1;
}
.testi-avatar {
  width:46px; height:46px; border-radius:50%;
  background:var(--gradient-btn);
  display:flex; align-items:center; justify-content:center;
  color:#fff; font-weight:700; font-size:1.1rem;
}
.testi-stars { color:#f59e0b; font-size:.85rem; }

/* ── Filter Sidebar ──────────────────────────────────────── */
.filter-sidebar {
  background:#fff; border-radius:var(--radius-md);
  border:1px solid var(--card-border);
  padding:1.25rem;
  position:sticky; top:80px; max-height:calc(100vh - 100px); overflow-y:auto;
}
.filter-sidebar::-webkit-scrollbar { width:4px; }
.filter-sidebar::-webkit-scrollbar-track { background:#f1f5f9; }
.filter-sidebar::-webkit-scrollbar-thumb { background:var(--blue); border-radius:4px; }
.filter-section { padding-bottom:1rem; border-bottom:1px solid var(--card-border); margin-bottom:1rem; }
.filter-section:last-child { border-bottom:0; margin-bottom:0; padding-bottom:0; }
.filter-label {
  font-size:.8rem; font-weight:600; color:var(--text-primary);
  text-transform:uppercase; letter-spacing:.5px; margin-bottom:.7rem;
}
.filter-check { display:flex; align-items:center; gap:.5rem; cursor:pointer; }
.filter-check input { accent-color:var(--blue); }
.filter-check label { font-size:.85rem; color:var(--text-muted); cursor:pointer; }
.btn-group-filter .btn {
  font-size:.8rem; padding:.3rem .75rem;
  border-radius:var(--radius-sm); font-family:var(--font-body); font-weight:500;
}
.price-range-input { display:flex; gap:.5rem; align-items:center; }
.price-range-input input {
  flex:1; padding:.4rem .6rem;
  border:1.5px solid var(--card-border); border-radius:var(--radius-sm);
  font-size:.8rem; font-family:var(--font-body);
}

/* ── Sort/View Bar ───────────────────────────────────────── */
.listing-bar {
  background:#fff; border-radius:var(--radius-md);
  border:1px solid var(--card-border);
  padding:.75rem 1rem; margin-bottom:1rem;
  display:flex; align-items:center; justify-content:space-between;
  flex-wrap:wrap; gap:.5rem;
}
.listing-count { font-weight:600; color:var(--text-primary); font-size:.9rem; }
.listing-count span { color:var(--blue); }
.view-toggle .btn { padding:.3rem .65rem; font-size:.85rem; }
.view-toggle .btn.active { background:var(--blue); color:#fff; border-color:var(--blue); }

/* ── Property Detail ─────────────────────────────────────── */
.detail-gallery-main {
  border-radius:var(--radius-md); overflow:hidden;
  height:420px; background:#e2e8f0; position:relative;
}
.detail-gallery-main img { width:100%; height:100%; object-fit:cover; }
.gallery-counter {
  position:absolute; bottom:12px; right:12px;
  background:rgba(0,0,0,.55); color:#fff;
  padding:.2rem .6rem; border-radius:50px; font-size:.8rem;
}
.gallery-thumbs { display:flex; gap:.5rem; margin-top:.5rem; }
.gallery-thumb {
  width:80px; height:60px; border-radius:var(--radius-sm);
  overflow:hidden; cursor:pointer; flex-shrink:0;
  border:2px solid transparent; transition:border .2s;
}
.gallery-thumb.active { border-color:var(--blue); }
.gallery-thumb img { width:100%; height:100%; object-fit:cover; }
.detail-key-grid {
  display:grid; grid-template-columns:repeat(4,1fr); gap:1rem;
}
@media(max-width:768px) {
  .detail-key-grid { grid-template-columns:repeat(2,1fr); }
}
.detail-key-item {
  background:var(--bg); border-radius:var(--radius-sm);
  padding:.85rem 1rem; text-align:center;
  border:1px solid var(--card-border);
}
.detail-key-item i { color:var(--blue); font-size:1.1rem; }
.detail-key-label { font-size:.7rem; color:var(--text-muted); margin:.25rem 0 .1rem; text-transform:uppercase; letter-spacing:.5px; }
.detail-key-value { font-weight:600; font-size:.9rem; color:var(--text-primary); }
.amenity-pill {
  display:inline-flex; align-items:center; gap:.4rem;
  background:#eff6ff; color:var(--blue);
  border:1px solid #dbeafe; border-radius:50px;
  padding:.3rem .85rem; font-size:.8rem; font-weight:500;
  margin:.25rem;
}
.contact-card {
  background:#fff; border-radius:var(--radius-md);
  border:1px solid var(--card-border);
  padding:1.5rem;
  position:sticky; top:80px;
}
.seller-avatar {
  width:52px; height:52px; border-radius:50%;
  background:var(--gradient-btn);
  display:flex; align-items:center; justify-content:center;
  font-size:1.3rem; color:#fff; font-weight:700;
}
.role-badge {
  display:inline-block; padding:.15rem .6rem;
  border-radius:50px; font-size:.68rem; font-weight:600;
  text-transform:uppercase; letter-spacing:.5px;
}
.role-owner   { background:#dcfce7; color:#166534; }
.role-seller  { background:#f3e8ff; color:#7c3aed; }
.role-agent   { background:#dbeafe; color:#1d4ed8; }
.role-builder { background:#fef3c7; color:#92400e; }

/* ── Post Property Steps ─────────────────────────────────── */
.step-progress {
  display:flex; align-items:center; gap:0; margin-bottom:2rem;
}
.step-dot {
  width:32px; height:32px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:.8rem; font-weight:600; flex-shrink:0;
  border:2px solid var(--card-border);
  background:#fff; color:var(--text-muted);
  transition:all .3s; cursor:default; position:relative; z-index:1;
}
.step-dot.active { border-color:var(--blue); background:var(--blue); color:#fff; }
.step-dot.done   { border-color:var(--green); background:var(--green); color:#fff; }
.step-line {
  flex:1; height:2px; background:var(--card-border);
  transition:background .3s;
}
.step-line.done { background:var(--green); }
.step-panel { display:none; }
.step-panel.active { display:block; animation:fadeInUp .3s ease; }
@keyframes fadeInUp {
  from { opacity:0; transform:translateY(12px); }
  to   { opacity:1; transform:translateY(0); }
}
.type-card {
  border:2px solid var(--card-border); border-radius:var(--radius-md);
  padding:1.5rem 1rem; text-align:center; cursor:pointer;
  transition:all .2s; background:#fff;
}
.type-card:hover { border-color:var(--blue); box-shadow:var(--shadow-sm); }
.type-card.selected { border-color:var(--blue); background:#eff6ff; }
.type-card i { font-size:1.8rem; color:var(--text-muted); margin-bottom:.5rem; }
.type-card.selected i { color:var(--blue); }
.type-card-label { font-size:.85rem; font-weight:600; color:var(--text-muted); }
.type-card.selected .type-card-label { color:var(--blue); }
.btn-num-sel {
  width:44px; height:44px; border-radius:var(--radius-sm);
  border:1.5px solid var(--card-border); background:#fff;
  font-weight:600; font-size:.9rem; cursor:pointer; transition:all .2s;
  font-family:var(--font-body); color:var(--text-primary);
}
.btn-num-sel.selected { border-color:var(--blue); background:var(--blue); color:#fff; }
.btn-num-sel:hover:not(.selected) { border-color:var(--blue); color:var(--blue); }
.upload-zone {
  border:2.5px dashed var(--card-border); border-radius:var(--radius-md);
  padding:3rem; text-align:center; cursor:pointer;
  transition:border-color .2s, background .2s;
  background:#fafbff;
}
.upload-zone:hover, .upload-zone.dragover {
  border-color:var(--blue); background:#eff6ff;
}
.upload-zone i { font-size:2.5rem; color:var(--blue); }
.upload-preview { display:flex; flex-wrap:wrap; gap:.75rem; margin-top:1rem; }
.upload-thumb {
  width:120px; height:90px; border-radius:var(--radius-sm);
  overflow:hidden; position:relative;
  border:2px solid var(--card-border);
}
.upload-thumb img { width:100%; height:100%; object-fit:cover; }
.upload-thumb .del-btn {
  position:absolute; top:4px; right:4px;
  background:rgba(239,68,68,.85); color:#fff;
  border:none; border-radius:50%; width:22px; height:22px;
  font-size:.65rem; cursor:pointer; display:flex; align-items:center; justify-content:center;
}
.upload-thumb .primary-btn {
  position:absolute; bottom:4px; left:4px;
  background:rgba(37,99,235,.85); color:#fff;
  border:none; border-radius:4px; padding:1px 6px;
  font-size:.65rem; cursor:pointer;
}
.strength-meter { height:4px; border-radius:2px; margin-top:.3rem; transition:width .3s; }

/* ── Dashboard ────────────────────────────────────────────── */
.dash-sidebar {
  background:#fff; border-radius:var(--radius-md);
  border:1px solid var(--card-border); padding:1.5rem;
  position:sticky; top:80px;
}
.dash-user-info { text-align:center; padding-bottom:1.5rem; border-bottom:1px solid var(--card-border); margin-bottom:1rem; }
.dash-avatar {
  width:72px; height:72px; border-radius:50%;
  background:var(--gradient-btn);
  display:flex; align-items:center; justify-content:center;
  font-size:1.8rem; color:#fff; font-weight:700; margin:0 auto .8rem;
}
.dash-nav-link {
  display:flex; align-items:center; gap:.6rem;
  padding:.6rem .85rem; border-radius:var(--radius-sm);
  color:var(--text-muted); font-size:.9rem; font-weight:500;
  cursor:pointer; transition:all .2s; margin-bottom:.2rem;
  border:none; background:transparent; width:100%; text-align:left;
}
.dash-nav-link i { width:18px; text-align:center; }
.dash-nav-link:hover   { background:#eff6ff; color:var(--blue); }
.dash-nav-link.active  { background:#eff6ff; color:var(--blue); font-weight:600; }
.dash-nav-link.text-danger { color:#ef4444!important; }
.dash-nav-link.text-danger:hover { background:#fff0f0; }
.dash-tab { display:none; }
.dash-tab.active { display:block; animation:fadeInUp .2s ease; }
.listing-row {
  background:#fff; border-radius:var(--radius-md);
  border:1px solid var(--card-border);
  padding:1rem; display:flex; gap:1rem; align-items:center;
  margin-bottom:.75rem; transition:box-shadow .2s;
}
.listing-row:hover { box-shadow:var(--shadow-sm); }
.listing-thumb {
  width:80px; height:60px; border-radius:var(--radius-sm);
  overflow:hidden; flex-shrink:0; background:#e2e8f0;
}
.listing-thumb img { width:100%; height:100%; object-fit:cover; }
.status-badge {
  display:inline-block; padding:.15rem .55rem; border-radius:50px;
  font-size:.7rem; font-weight:600; text-transform:uppercase; letter-spacing:.4px;
}
.status-active   { background:#dcfce7; color:#166534; }
.status-inactive { background:#f1f5f9; color:#64748b; }
.status-sold     { background:#fef3c7; color:#92400e; }
.status-rented   { background:#dbeafe; color:#1d4ed8; }

/* ── Premium Cards ────────────────────────────────────────── */
.premium-upgrade-card {
  background:linear-gradient(135deg,#fffbeb,#fef3c7);
  border:1.5px solid #fcd34d; border-radius:12px;
}
.premium-active-card {
  background:linear-gradient(135deg,#fefce8,#fef9c3);
  border:1.5px solid #f59e0b; border-radius:12px;
}

/* ── Lightbox ─────────────────────────────────────────────── */
.lightbox-overlay {
  display:none; position:fixed; inset:0;
  background:rgba(0,0,0,.92); z-index:9990;
  align-items:center; justify-content:center;
}
.lightbox-overlay.show { display:flex; }
.lightbox-img { max-width:90vw; max-height:90vh; border-radius:var(--radius-sm); object-fit:contain; }
.lightbox-close {
  position:absolute; top:20px; right:24px;
  background:none; border:none; color:#fff; font-size:1.8rem; cursor:pointer;
}
.lightbox-prev, .lightbox-next {
  position:absolute; top:50%; transform:translateY(-50%);
  background:rgba(255,255,255,.15); border:none; color:#fff;
  width:44px; height:44px; border-radius:50%; font-size:1.1rem; cursor:pointer;
  transition:background .2s;
}
.lightbox-prev { left:20px; }
.lightbox-next { right:20px; }
.lightbox-prev:hover, .lightbox-next:hover { background:rgba(255,255,255,.3); }

/* ── Toast ────────────────────────────────────────────────── */
.hm-toast {
  min-width:280px; background:#fff;
  border-radius:var(--radius-sm); border-left:4px solid var(--blue);
  box-shadow:0 4px 20px rgba(0,0,0,.15);
  padding:.8rem 1rem; display:flex; gap:.65rem; align-items:center;
  animation:slideInRight .3s ease, fadeOut .3s ease 2.7s forwards;
  font-size:.88rem;
}
.hm-toast.success { border-left-color:var(--green); }
.hm-toast.error   { border-left-color:#ef4444; }
.hm-toast.info    { border-left-color:var(--blue); }
.hm-toast i { font-size:1rem; }
.hm-toast.success i { color:var(--green); }
.hm-toast.error   i { color:#ef4444; }
.hm-toast.info    i { color:var(--blue); }
@keyframes slideInRight {
  from { transform:translateX(100%); opacity:0; }
  to   { transform:translateX(0); opacity:1; }
}
@keyframes fadeOut {
  from { opacity:1; }
  to   { opacity:0; transform:translateY(-8px); }
}

/* ── No Results ───────────────────────────────────────────── */
.no-results {
  text-align:center; padding:4rem 2rem;
}
.no-results i { font-size:3.5rem; color:var(--card-border); margin-bottom:1rem; }

/* ── Pagination ───────────────────────────────────────────── */
.pagination .page-link {
  color:var(--blue); border-color:var(--card-border);
  font-family:var(--font-body); font-size:.88rem;
}
.pagination .page-item.active .page-link {
  background:var(--blue); border-color:var(--blue);
}
.pagination .page-link:hover { background:#eff6ff; color:var(--blue); }

/* ── Map View ─────────────────────────────────────────────── */
#mapView { height:600px; border-radius:var(--radius-md); overflow:hidden; }

/* ── Forms ────────────────────────────────────────────────── */
.hm-form-control {
  border:1.5px solid var(--card-border); border-radius:var(--radius-sm);
  padding:.55rem .85rem; font-size:.9rem; font-family:var(--font-body);
  width:100%; transition:border .2s;
}
.hm-form-control:focus {
  outline:none; border-color:var(--blue);
  box-shadow:0 0 0 3px rgba(37,99,235,.1);
}
.hm-form-label { font-size:.82rem; font-weight:500; color:var(--text-muted); margin-bottom:.3rem; display:block; }

/* ── Section Spacing ──────────────────────────────────────── */
.section-pad { padding: 4rem 0; }
.section-pad-sm { padding: 2.5rem 0; }

/* ── Responsive Nav ───────────────────────────────────────── */
@media(max-width:991px) {
  .filter-sidebar { position:fixed; top:0; left:-300px; width:280px; height:100%; border-radius:0; z-index:1050; transition:left .3s; overflow-y:auto; }
  .filter-sidebar.open { left:0; box-shadow:4px 0 20px rgba(0,0,0,.2); }
  .filter-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.4); z-index:1049; }
  .filter-overlay.show { display:block; }
}

/* ── Footer ───────────────────────────────────────────────── */
.hm-footer {
  background: linear-gradient(135deg, #0f172a 0%, #1e293b 60%, #0f172a 100%);
  padding: 3.5rem 0 2rem;
  margin-top: 4rem;
}
.hm-footer .logo-icon {
  background: linear-gradient(135deg, #4fa8f5, #2563eb);
  color: #fff;
  width: 36px; height: 36px;
  border-radius: 9px;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 1rem; font-weight: 700;
  font-family: var(--font-heading);
}
.hm-footer .logo-name {
  font-size: 1.05rem; font-weight: 500; color: #fff;
  font-family: var(--font-heading);
}
.hm-footer .logo-name strong { color: #60a5fa; }
.footer-links { margin: 0; padding: 0; }
.footer-links li { margin-bottom: .5rem; }
.footer-links a {
  color: rgba(255,255,255,.55);
  text-decoration: none;
  font-size: .85rem;
  transition: color .2s;
}
.footer-links a:hover { color: #60a5fa; }
.footer-social {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  display: inline-flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,.6);
  font-size: .8rem;
  text-decoration: none;
  transition: background .2s, color .2s;
}
.footer-social:hover { background: #2563eb; color: #fff; border-color: #2563eb; }
.hm-footer hr { border-color: rgba(255,255,255,.1) !important; }
.hm-footer .text-white-50 { color: rgba(255,255,255,.45) !important; }

/* ── Scrollbar global ─────────────────────────────────────── */
::-webkit-scrollbar { width:6px; }
::-webkit-scrollbar-track { background:#f1f5f9; }
::-webkit-scrollbar-thumb { background:#cbd5e1; border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background:var(--blue); }
