/*
Theme Name: Maxhome Pro
Theme URI: https://maxhome.ro
Author: Maxhome
Description: Temă premium cu hartă interactivă Leaflet, design dark navy + auriu. Compatibilă cu plugin-urile Manager Proprietăți Imobiliare PRO și CRM Imobiliare Sync.
Version: 3.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 8.0
License: GNU General Public License v2 or later
Text Domain: maxhome-pro
*/

/* ── GOOGLE FONTS ── */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,700;0,800;1,700&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&display=swap');

/* ── CSS VARIABLES ── */
:root {
  --gold:       #c9a84c;
  --gold-l:     #f0d890;
  --gold-d:     #a8872e;
  --dark:       #0f1623;
  --dark2:      #1a2333;
  --dark3:      #243044;
  --slate:      #344258;
  --mid:        #5a6e8a;
  --light:      #8fa0b8;
  --border:     rgba(255,255,255,0.08);
  --border-l:   #e4e8f0;
  --bg:         #f4f6fb;
  --white:      #ffffff;
  --sale:       #16a34a;
  --sale-bg:    rgba(22,163,74,0.1);
  --rent:       #dc2626;
  --rent-bg:    rgba(220,38,38,0.1);
  --radius:     16px;
  --radius-sm:  10px;
  --radius-xs:  7px;
  --header-h:   68px;
  --trans:      0.2s ease;
  --shadow-sm:  0 2px 12px rgba(15,22,35,0.08);
  --shadow:     0 4px 24px rgba(15,22,35,0.12);
  --shadow-lg:  0 8px 40px rgba(15,22,35,0.18);
}

/* ── RESET ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  font-family: 'DM Sans', sans-serif;
  background: var(--bg);
  color: var(--dark);
  font-size: 15px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
a { color:inherit; text-decoration:none; transition:color var(--trans); }
img { max-width:100%; display:block; }
ul { list-style:none; }
input,select,textarea,button { font-family:inherit; font-size:inherit; }
::-webkit-scrollbar { width:6px; }
::-webkit-scrollbar-track { background:#eef0f8; }
::-webkit-scrollbar-thumb { background:var(--gold); border-radius:3px; }

/* ── CONTAINER ── */
.container { max-width:1360px; margin:0 auto; padding:0 28px; }

/* ══════════════════════════════════════
   HEADER
══════════════════════════════════════ */
.site-header {
  background: var(--dark);
  height: var(--header-h);
  position: sticky;
  top: 0;
  z-index: 900;
  border-bottom: 1px solid var(--border);
}
.header-inner {
  height: 100%;
  display: flex;
  align-items: center;
  gap: 24px;
}

/* Logo */
.site-logo { display:flex; align-items:center; gap:11px; flex-shrink:0; }
.logo-box {
  width:40px; height:40px;
  background: linear-gradient(135deg, var(--gold), #e0bc5a);
  border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  font-size:20px;
  box-shadow: 0 4px 16px rgba(201,168,76,0.35);
  flex-shrink:0;
}
.logo-name {
  font-family: 'Playfair Display', serif;
  font-size: 22px;
  font-weight: 800;
  color: var(--white);
  letter-spacing: -0.3px;
}
.logo-name span { color:var(--gold); }

/* Header Search */
.header-search {
  flex: 1;
  max-width: 440px;
}
.header-search form {
  display:flex; align-items:center;
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 10px;
  padding: 10px 14px;
  gap: 10px;
  transition: border-color var(--trans), box-shadow var(--trans);
}
.header-search form:focus-within {
  border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(201,168,76,0.14);
}
.header-search .hs-icon { color:rgba(255,255,255,0.35); font-size:15px; }
.header-search input {
  flex:1; background:none; border:none; outline:none;
  font-size:14px; color:var(--white);
}
.header-search input::placeholder { color:rgba(255,255,255,0.38); }

/* Header Nav */
.header-nav { display:flex; align-items:center; gap:4px; margin-left:auto; }
.nav-link {
  padding:8px 15px; border-radius:8px;
  font-size:14px; font-weight:500; color:rgba(255,255,255,0.65);
  transition:all var(--trans); white-space:nowrap;
}
.nav-link:hover { background:rgba(255,255,255,0.08); color:#fff; }
.nav-link.active { color:#fff; background:rgba(255,255,255,0.10); }

.btn-adauga-header {
  display:inline-flex; align-items:center; gap:7px;
  background: linear-gradient(135deg, var(--gold), #d4b060);
  color: var(--dark) !important;
  padding:9px 20px; border-radius:9px;
  font-size:14px; font-weight:700;
  box-shadow:0 4px 16px rgba(201,168,76,0.3);
  transition:all var(--trans);
}
.btn-adauga-header:hover {
  transform:translateY(-1px);
  box-shadow:0 6px 24px rgba(201,168,76,0.45);
}

/* Mobile toggle */
.mobile-toggle {
  display:none; background:none; border:none;
  font-size:22px; cursor:pointer; color:rgba(255,255,255,0.7);
  padding:6px; line-height:1;
}

/* Mobile nav */
.mobile-nav {
  display:none; flex-direction:column;
  background:var(--dark2); border-top:1px solid var(--border);
  padding:12px 0;
}
.mobile-nav.open { display:flex; }
.mobile-nav a {
  padding:12px 28px; font-size:15px; font-weight:500;
  color:rgba(255,255,255,0.8); border-bottom:1px solid var(--border);
  transition:background var(--trans);
}
.mobile-nav a:last-child { border-bottom:none; }
.mobile-nav a:hover { background:rgba(255,255,255,0.06); }

/* ══════════════════════════════════════
   HERO / MAP BANNER
══════════════════════════════════════ */
.hero-section {
  position:relative;
  height: calc(100vh - var(--header-h));
  min-height:600px;
  max-height:860px;
  display:flex;
  overflow:hidden;
}

#main-map {
  position:absolute; inset:0;
  z-index:1;
}

.hero-gradient {
  position:absolute;
  left:0; top:0; bottom:0;
  width:480px;
  background:linear-gradient(to right, rgba(15,22,35,0.97) 60%, rgba(15,22,35,0) 100%);
  z-index:2;
  pointer-events:none;
}

/* Search Panel */
.search-panel {
  position:relative; z-index:3;
  width:420px; flex-shrink:0;
  padding:40px 32px;
  display:flex; flex-direction:column; justify-content:center;
}

.hero-kicker {
  font-size:11px; font-weight:700;
  letter-spacing:2.5px; text-transform:uppercase;
  color:var(--gold); margin-bottom:14px;
}
.hero-title {
  font-family:'Playfair Display', serif;
  font-size:clamp(30px,3.2vw,44px);
  font-weight:800; color:var(--white);
  line-height:1.15; margin-bottom:10px;
}
.hero-title em { font-style:italic; color:var(--gold-l); }
.hero-sub {
  font-size:14px; color:rgba(255,255,255,0.5);
  margin-bottom:28px; line-height:1.55;
}

/* Search Form — Stacked */
.search-form {
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:var(--radius);
  padding:22px;
  backdrop-filter:blur(14px);
  display:flex; flex-direction:column; gap:14px;
}
.sf-field { display:flex; flex-direction:column; gap:5px; }
.sf-label {
  font-size:10.5px; font-weight:700;
  letter-spacing:1.4px; text-transform:uppercase;
  color:rgba(255,255,255,0.4);
}
.sf-field select,
.sf-field input[type=text],
.sf-field input[type=number] {
  background:rgba(255,255,255,0.09);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:var(--radius-sm);
  padding:11px 14px;
  font-size:14px; font-weight:500;
  color:var(--white);
  outline:none;
  transition:border-color var(--trans), box-shadow var(--trans);
  -webkit-appearance:none; appearance:none;
}
.sf-field select option { background:var(--dark2); color:var(--white); }
.sf-field select:focus,
.sf-field input:focus {
  border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(201,168,76,0.13);
}
.sf-price-row { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.sf-submit {
  background:linear-gradient(135deg, var(--gold), #d4b060);
  color:var(--dark); border:none;
  border-radius:var(--radius-sm);
  padding:13px 20px;
  font-size:15px; font-weight:700;
  cursor:pointer;
  transition:all var(--trans);
  box-shadow:0 4px 16px rgba(201,168,76,0.35);
  display:flex; align-items:center; justify-content:center; gap:8px;
  margin-top:2px;
}
.sf-submit:hover {
  transform:translateY(-1px);
  box-shadow:0 6px 24px rgba(201,168,76,0.5);
}

/* Map legend */
.map-legend { display:flex; gap:18px; margin-top:16px; }
.legend-item { display:flex; align-items:center; gap:7px; font-size:12px; font-weight:600; color:rgba(255,255,255,0.65); }
.legend-dot { width:12px; height:12px; border-radius:50%; flex-shrink:0; }
.legend-dot.sale { background:var(--sale); box-shadow:0 0 0 3px rgba(22,163,74,0.28); }
.legend-dot.rent { background:var(--rent); box-shadow:0 0 0 3px rgba(220,38,38,0.28); }

/* Hero stats */
.hero-stats { display:flex; gap:24px; margin-top:18px; }
.hero-stat { display:flex; flex-direction:column; gap:2px; }
.hero-stat .num { font-size:20px; font-weight:800; color:var(--white); letter-spacing:-0.5px; }
.hero-stat .lbl { font-size:10px; color:rgba(255,255,255,0.38); text-transform:uppercase; letter-spacing:1px; }

/* ── Leaflet overrides ── */
.leaflet-popup-content-wrapper {
  border-radius:14px !important;
  box-shadow:0 8px 40px rgba(0,0,0,0.28) !important;
  padding:0 !important; overflow:hidden;
  border:1px solid #e4e8f0;
}
.leaflet-popup-content { margin:0 !important; width:240px !important; }
.leaflet-popup-tip-container { display:none; }
.popup-img { width:100%; height:140px; object-fit:cover; display:block; }
.popup-body { padding:14px 16px; }
.popup-badge {
  display:inline-flex; align-items:center; gap:5px;
  padding:3px 10px; border-radius:20px;
  font-size:11px; font-weight:800; text-transform:uppercase; letter-spacing:0.5px;
  margin-bottom:9px;
}
.popup-badge.sale { background:var(--sale-bg); color:var(--sale); border:1px solid rgba(22,163,74,0.3); }
.popup-badge.rent { background:var(--rent-bg); color:var(--rent); border:1px solid rgba(220,38,38,0.3); }
.popup-title { font-size:14px; font-weight:700; color:var(--dark); margin-bottom:7px; line-height:1.35; }
.popup-details { display:flex; gap:10px; font-size:12px; color:var(--mid); margin-bottom:10px; flex-wrap:wrap; }
.popup-price { font-size:18px; font-weight:800; color:var(--dark); letter-spacing:-0.5px; margin-bottom:14px; }
.popup-price small { font-size:12px; font-weight:400; color:var(--mid); margin-left:3px; }
.popup-link {
  display:block; background:var(--dark); color:var(--white) !important;
  text-align:center; padding:10px; font-size:13px; font-weight:600;
  transition:background var(--trans);
}
.popup-link:hover { background:var(--dark3); }

/* ══════════════════════════════════════
   TYPE BAR
══════════════════════════════════════ */
.type-bar {
  background:var(--white);
  border-bottom:1px solid var(--border-l);
  position:sticky; top:var(--header-h); z-index:100;
  box-shadow:0 2px 10px rgba(0,0,0,0.05);
}
.type-bar-inner {
  display:flex; gap:0; overflow-x:auto; scrollbar-width:none;
}
.type-bar-inner::-webkit-scrollbar { display:none; }
.qt-link {
  display:flex; align-items:center; gap:7px;
  padding:13px 20px;
  font-size:13px; font-weight:600;
  color:var(--mid);
  white-space:nowrap;
  border-bottom:2.5px solid transparent;
  transition:all var(--trans);
}
.qt-link:hover { color:var(--dark); border-bottom-color:var(--gold); }
.qt-link.active { color:var(--dark); border-bottom-color:var(--gold); }

/* ══════════════════════════════════════
   BUTTONS
══════════════════════════════════════ */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:10px 22px; border-radius:var(--radius-sm);
  font-size:14px; font-weight:600;
  cursor:pointer; transition:all var(--trans); white-space:nowrap;
  border:none;
}
.btn-primary {
  background:linear-gradient(135deg, var(--gold), #d4b060);
  color:var(--dark);
  box-shadow:0 4px 16px rgba(201,168,76,0.3);
}
.btn-primary:hover { transform:translateY(-1px); box-shadow:0 6px 24px rgba(201,168,76,0.45); }
.btn-dark { background:var(--dark); color:var(--white); }
.btn-dark:hover { background:var(--dark2); transform:translateY(-1px); }
.btn-outline {
  background:transparent; color:var(--dark);
  border:1.5px solid var(--dark3);
}
.btn-outline:hover { background:var(--dark); color:var(--white); }
.btn-outline-w {
  background:transparent; color:rgba(255,255,255,0.8);
  border:1.5px solid rgba(255,255,255,0.25);
}
.btn-outline-w:hover { background:rgba(255,255,255,0.1); color:#fff; }
.btn-sm { padding:7px 16px; font-size:13px; }
.btn-xs { padding:5px 12px; font-size:12px; border-radius:6px; }
.btn-lg { padding:15px 36px; font-size:16px; font-weight:700; border-radius:12px; }

/* ══════════════════════════════════════
   ARCHIVE / FILTERS
══════════════════════════════════════ */
.archive-wrap { padding:36px 0 64px; }

.filters-section {
  background:var(--white);
  border:1px solid var(--border-l);
  border-radius:var(--radius);
  padding:22px 24px;
  margin-bottom:28px;
  box-shadow:var(--shadow-sm);
}
.filters-top {
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(150px, 1fr));
  gap:14px;
  align-items:end;
}
.filter-group { display:flex; flex-direction:column; gap:5px; }
.filter-group label { font-size:11px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--light); }
.filter-select {
  background:var(--bg); border:1.5px solid var(--border-l);
  border-radius:var(--radius-sm); padding:10px 14px;
  font-size:14px; color:var(--dark); outline:none;
  transition:border-color var(--trans), box-shadow var(--trans);
  -webkit-appearance:none; appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238fa0b8' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 12px center;
  padding-right:36px;
}
.filter-select:focus { border-color:var(--gold); box-shadow:0 0 0 3px rgba(201,168,76,0.12); }
.filter-input {
  background:var(--bg); border:1.5px solid var(--border-l);
  border-radius:var(--radius-sm); padding:10px 14px;
  font-size:14px; color:var(--dark); outline:none;
  transition:border-color var(--trans), box-shadow var(--trans);
}
.filter-input:focus { border-color:var(--gold); box-shadow:0 0 0 3px rgba(201,168,76,0.12); }

.archive-head {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:24px; flex-wrap:wrap; gap:14px;
}
.archive-title { font-family:'Playfair Display', serif; font-size:26px; font-weight:800; letter-spacing:-0.3px; }
.results-count { font-size:14px; color:var(--mid); margin-top:4px; }

/* ══════════════════════════════════════
   PROPERTY GRID & CARD
══════════════════════════════════════ */
.props-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(290px, 1fr));
  gap:24px;
}

.prop-card {
  background:var(--white);
  border-radius:var(--radius);
  overflow:hidden;
  border:1px solid var(--border-l);
  transition:transform .3s ease, box-shadow .3s ease;
  cursor:pointer;
  position:relative;
}
.prop-card:hover {
  transform:translateY(-6px);
  box-shadow:var(--shadow-lg);
}

/* Card Image */
.card-img {
  position:relative; height:210px; overflow:hidden;
  background:var(--bg);
}
.card-img img { width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.prop-card:hover .card-img img { transform:scale(1.07); }
.card-img-placeholder {
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  height:100%; gap:8px;
  background:linear-gradient(135deg, #eef0f8, #e2e6f0);
  color:var(--light);
  font-size:13px;
}
.card-img-placeholder span:first-child { font-size:36px; }

/* Badges on image */
.card-badge {
  position:absolute; top:12px; left:12px;
  display:inline-flex; align-items:center; gap:5px;
  padding:4px 11px; border-radius:20px;
  font-size:11px; font-weight:800; text-transform:uppercase; letter-spacing:0.5px;
  backdrop-filter:blur(10px);
}
.card-badge.inchiriere { background:rgba(220,38,38,0.85); color:#fff; }
.card-badge.casa,
.card-badge.vila { background:rgba(255,255,255,0.9); color:var(--dark); }
.card-badge { background:rgba(255,255,255,0.9); color:var(--dark); }

.card-op-badge {
  position:absolute; top:12px; right:44px;
  display:inline-flex; align-items:center;
  padding:4px 10px; border-radius:20px;
  font-size:11px; font-weight:700;
  backdrop-filter:blur(10px);
}
.card-op-badge.vanzare { background:rgba(22,163,74,0.9); color:#fff; }
.card-op-badge.inchiriere { background:rgba(220,38,38,0.9); color:#fff; }

.card-price {
  position:absolute; bottom:12px; left:12px;
  background:var(--dark); color:var(--white);
  padding:5px 13px; border-radius:8px;
  font-size:14px; font-weight:800;
  letter-spacing:-0.3px;
  box-shadow:0 2px 10px rgba(0,0,0,0.35);
}

.card-fav {
  position:absolute; top:12px; right:12px;
  width:34px; height:34px;
  background:rgba(255,255,255,0.9); backdrop-filter:blur(10px);
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:16px; cursor:pointer; border:none;
  transition:all var(--trans);
}
.card-fav:hover { background:#fff; transform:scale(1.1); }
.card-fav[data-active="1"] { color:var(--rent); }

/* Card Body */
.card-body { padding:18px 20px; }
.card-title a {
  font-size:15px; font-weight:700; color:var(--dark);
  line-height:1.4;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}
.card-title a:hover { color:var(--gold-d); }
.card-specs { display:flex; gap:14px; margin-top:10px; margin-bottom:10px; }
.card-spec { font-size:13px; color:var(--mid); font-weight:500; }
.card-location {
  font-size:13px; color:var(--light);
  padding-top:12px; border-top:1px solid var(--border-l);
  display:flex; align-items:center; gap:5px;
}

/* ══════════════════════════════════════
   SECTION HEADERS & MAIN PAGE
══════════════════════════════════════ */
.section-head {
  display:flex; align-items:flex-end; justify-content:space-between;
  margin-bottom:28px; flex-wrap:wrap; gap:14px;
}
.section-title {
  font-family:'Playfair Display', serif;
  font-size:28px; font-weight:800; color:var(--dark); letter-spacing:-0.4px;
}
.section-sub { font-size:14px; color:var(--mid); margin-top:5px; }

/* ══════════════════════════════════════
   CTA BANNER
══════════════════════════════════════ */
.cta-section {
  background:linear-gradient(135deg, var(--dark) 0%, var(--dark2) 60%, #1c2d50 100%);
  border-radius:24px; padding:64px 48px;
  margin-top:56px; position:relative; overflow:hidden;
  text-align:center;
}
.cta-section::before {
  content:''; position:absolute; top:-80px; right:-80px;
  width:320px; height:320px;
  background:radial-gradient(circle, rgba(201,168,76,0.14) 0%, transparent 70%);
  pointer-events:none;
}
.cta-section::after {
  content:''; position:absolute; bottom:-60px; left:-60px;
  width:240px; height:240px;
  background:radial-gradient(circle, rgba(67,97,238,0.1) 0%, transparent 70%);
  pointer-events:none;
}
.cta-section h2 {
  font-family:'Playfair Display', serif;
  font-size:clamp(26px, 3vw, 38px); font-weight:800; color:var(--white);
  margin-bottom:14px; position:relative; z-index:1;
}
.cta-section p {
  font-size:16px; color:rgba(255,255,255,0.5);
  margin-bottom:32px; max-width:480px; margin-left:auto; margin-right:auto;
  position:relative; z-index:1;
}
.cta-section .btn { position:relative; z-index:1; }

/* ══════════════════════════════════════
   SINGLE PROPERTY
══════════════════════════════════════ */
.single-wrap { padding:32px 0 64px; }
.breadcrumb { display:flex; align-items:center; gap:8px; font-size:13px; color:var(--mid); margin-bottom:24px; flex-wrap:wrap; }
.breadcrumb a:hover { color:var(--gold-d); }
.breadcrumb .sep { color:var(--border-l); }

.single-header-card {
  background:var(--white); border:1px solid var(--border-l);
  border-radius:var(--radius); padding:28px; margin-bottom:28px;
  box-shadow:var(--shadow-sm);
}
.single-price {
  font-family:'Playfair Display', serif;
  font-size:38px; font-weight:800; color:var(--dark); letter-spacing:-1px;
}
.single-price small { font-size:16px; font-weight:500; color:var(--mid); margin-left:4px; }

.prop-tags { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:16px; }
.ptag {
  display:inline-flex; align-items:center; gap:5px;
  padding:5px 13px; border-radius:20px; font-size:12px; font-weight:700;
}
.ptag-type { background:#f0f2fa; color:var(--dark3); }
.ptag-op.vanzare { background:var(--sale-bg); color:var(--sale); border:1px solid rgba(22,163,74,0.25); }
.ptag-op.inchiriere { background:var(--rent-bg); color:var(--rent); border:1px solid rgba(220,38,38,0.25); }
.ptag-status.disponibil { background:#e8f5ed; color:#1a7a3f; }
.ptag-status.rezervat { background:#fff8e6; color:#b45309; }
.ptag-status.vandut { background:#fee2e2; color:#991b1b; }

.specs-grid {
  display:grid; grid-template-columns:repeat(auto-fill, minmax(160px, 1fr)); gap:14px;
  margin:20px 0;
}
.spec-item {
  background:var(--bg); border:1px solid var(--border-l);
  border-radius:var(--radius-sm); padding:14px 16px;
}
.spec-item .spec-label { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:var(--light); margin-bottom:4px; }
.spec-item .spec-val { font-size:16px; font-weight:700; color:var(--dark); }

/* Gallery */
.prop-gallery { margin:28px 0; }
.gallery-main { position:relative; border-radius:var(--radius); overflow:hidden; height:420px; }
.gallery-main img { width:100%; height:100%; object-fit:cover; }
.gallery-thumbs { display:flex; gap:10px; margin-top:10px; overflow-x:auto; padding-bottom:4px; }
.gallery-thumbs img {
  height:80px; width:130px; object-fit:cover;
  border-radius:8px; cursor:pointer; flex-shrink:0;
  border:2px solid transparent; transition:all var(--trans);
}
.gallery-thumbs img.active { border-color:var(--gold); }
.gallery-thumbs img:hover { opacity:.85; }

/* Contact card */
.contact-card {
  background:var(--white); border:1px solid var(--border-l);
  border-radius:var(--radius); padding:24px; box-shadow:var(--shadow-sm);
  position:sticky; top:calc(var(--header-h) + 20px);
}
.contact-agent { display:flex; align-items:center; gap:14px; margin-bottom:20px; }
.agent-avatar {
  width:50px; height:50px; border-radius:50%;
  background:linear-gradient(135deg, var(--gold), #e0bc5a);
  display:flex; align-items:center; justify-content:center;
  font-size:22px; flex-shrink:0;
}
.agent-name { font-size:15px; font-weight:700; color:var(--dark); }
.agent-role { font-size:12px; color:var(--mid); margin-top:2px; }

/* ══════════════════════════════════════
   FORMS (login, register, add)
══════════════════════════════════════ */
.form-wrap {
  min-height:calc(100vh - var(--header-h));
  display:flex; align-items:center; justify-content:center;
  padding:40px 20px;
  background:linear-gradient(135deg, var(--dark) 0%, var(--dark2) 100%);
}
.form-card {
  background:var(--white); border-radius:20px;
  padding:40px; width:100%; max-width:460px;
  box-shadow:0 20px 60px rgba(0,0,0,0.3);
}
.form-card h1 {
  font-family:'Playfair Display', serif;
  font-size:28px; font-weight:800; color:var(--dark);
  margin-bottom:6px;
}
.form-card .form-sub { font-size:14px; color:var(--mid); margin-bottom:28px; }

.form-group { margin-bottom:18px; }
.form-label { display:block; font-size:12px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--mid); margin-bottom:7px; }
.form-control {
  width:100%; background:var(--bg); border:1.5px solid var(--border-l);
  border-radius:var(--radius-sm); padding:12px 16px;
  font-size:15px; color:var(--dark); outline:none;
  transition:border-color var(--trans), box-shadow var(--trans);
}
.form-control:focus { border-color:var(--gold); box-shadow:0 0 0 3px rgba(201,168,76,0.14); }
textarea.form-control { resize:vertical; min-height:120px; }
.form-error { font-size:13px; color:var(--rent); margin-top:6px; display:none; }
.form-msg {
  padding:12px 16px; border-radius:var(--radius-sm);
  font-size:14px; font-weight:600; margin-bottom:20px;
  display:none;
}
.form-msg.success { background:#e8f5ed; color:#1a7a3f; border:1px solid #b8dfc4; }
.form-msg.error { background:#fee2e2; color:#991b1b; border:1px solid #fca5a5; }

/* ══════════════════════════════════════
   PAGINATION
══════════════════════════════════════ */
.pagination { display:flex; justify-content:center; gap:8px; margin-top:48px; flex-wrap:wrap; }
.page-numbers {
  display:inline-flex; align-items:center; justify-content:center;
  width:42px; height:42px; border-radius:var(--radius-sm);
  font-size:14px; font-weight:600; color:var(--mid);
  background:var(--white); border:1.5px solid var(--border-l);
  transition:all var(--trans);
}
.page-numbers:hover { border-color:var(--gold); color:var(--dark); }
.page-numbers.current { background:var(--dark); color:var(--white); border-color:var(--dark); }
.page-numbers.dots { border:none; background:none; }

/* ══════════════════════════════════════
   EMPTY STATE
══════════════════════════════════════ */
.empty-state {
  text-align:center; padding:64px 24px; color:var(--mid);
}
.empty-state .ei { font-size:52px; margin-bottom:16px; }
.empty-state h3 { font-size:20px; font-weight:700; color:var(--dark); margin-bottom:8px; }
.empty-state p { font-size:14px; margin-bottom:24px; }

/* ══════════════════════════════════════
   FOOTER
══════════════════════════════════════ */
.site-footer {
  background:var(--dark);
  border-top:1px solid var(--border);
  padding:56px 0 0;
}
.footer-grid {
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:48px; margin-bottom:48px;
}
.footer-brand .fn {
  font-family:'Playfair Display', serif;
  font-size:20px; font-weight:800; color:var(--white);
  margin-bottom:12px;
}
.footer-brand p { font-size:13px; color:rgba(255,255,255,0.38); line-height:1.65; }
.footer-col h4 {
  font-size:11px; font-weight:700; letter-spacing:2px; text-transform:uppercase;
  color:var(--gold); margin-bottom:16px;
}
.footer-col a {
  display:block; font-size:14px; color:rgba(255,255,255,0.55);
  margin-bottom:10px; transition:color var(--trans);
}
.footer-col a:hover { color:var(--gold-l); }
.footer-bottom {
  border-top:1px solid var(--border);
  padding:20px 0;
  display:flex; align-items:center; justify-content:space-between;
  font-size:13px; color:rgba(255,255,255,0.28); flex-wrap:wrap; gap:10px;
}

/* ══════════════════════════════════════
   FADE-UP ANIMATION
══════════════════════════════════════ */
.fade-up { opacity:0; transform:translateY(20px); }
.fade-up.visible { opacity:1; transform:none; transition:opacity .4s ease, transform .4s ease; }

/* ══════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════ */
@media (max-width: 1100px) {
  .footer-grid { grid-template-columns:1fr 1fr; }
}
@media (max-width: 900px) {
  .hero-section { flex-direction:column; height:auto; max-height:none; }
  .hero-gradient { display:none; }
  .search-panel { width:100%; padding:28px 22px; background:var(--dark); }
  #main-map { position:relative; height:380px; }
  .header-search { display:none; }
  .mobile-toggle { display:block; }
  .header-nav > .nav-link { display:none; }
  .props-grid { grid-template-columns:repeat(auto-fill, minmax(260px, 1fr)); }
  .filters-top { grid-template-columns:1fr 1fr; }
  .cta-section { padding:44px 28px; }
  .single-header-card { padding:20px; }
}
@media (max-width: 600px) {
  .container { padding:0 16px; }
  .hero-title { font-size:28px; }
  .props-grid { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr; gap:28px; }
  .filters-top { grid-template-columns:1fr; }
  .cta-section { padding:36px 20px; }
}
