/*
Theme Name: MaxView Pro
Theme URI: https://maxview.ro
Author: MaxView
Description: Temă premium MaxView pentru portal de anunțuri, cu design verde închis și auriu.
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: maxview-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;
  justify-content: space-between;
}

/* 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: 28px;
  cursor: pointer;
  color: #fff;
  padding: 8px 12px;
  line-height: 1;
  flex-shrink: 0;
}

/* 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 — stilizat direct în front-page.php via grid */
.hero-section {
  min-height: 600px;
  max-height: 900px;
}

/* Search Panel — positioned via CSS grid in front-page.php */
.search-panel {
  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; }


/* ══ SINGLE LAYOUT ══ */
.single-layout {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 32px;
  align-items: start;
}

/* ══════════════════════════════════════
   RESPONSIVE — TOATE PAGINILE
══════════════════════════════════════ */

/* ── TABLET MARE (max 1100px) ── */
@media (max-width: 1100px) {
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
  .single-layout { gap: 24px; }
}

/* ── TABLET (max 900px) ── */
@media (max-width: 900px) {

  /* HEADER */
  .header-search { display:none; }
  .header-nav { display:none !important; }
  .mobile-toggle { display:block !important; color:#fff !important; font-size:28px !important; }

  /* HERO homepage */
  .hero-wrap {
    grid-template-columns: 1fr !important;
    height: auto !important;
    max-height: none !important;
    overflow: visible !important;
    width: 100% !important;
  }
  .hero-left { padding: 32px 24px; order: 1; width: 100%; box-sizing: border-box; overflow: visible; }
  .hero-right { height: 320px; order: 2; width: 100%; }
  #main-map { height: 360px !important; }

  /* FORMULAR hero */
  .hero-title { font-size: 32px; }
  .sf-price-row { grid-template-columns: 1fr 1fr; }

  /* ARCHIVE */
  .archive-wrap { padding: 24px 0 48px; }
  .filters-top { grid-template-columns: 1fr 1fr; gap: 10px; }
  .props-grid { grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); }

  /* SINGLE PROPRIETATE */
  .single-wrap { padding: 20px 0 48px; }
  .single-layout {
    grid-template-columns: 1fr !important;
    gap: 20px;
  }
  .contact-card {
    position: static !important;
    top: auto !important;
  }
  .gallery-main { height: 280px; }
  .specs-grid { grid-template-columns: repeat(3, 1fr) !important; }
  .single-header-card { padding: 20px; }

  /* ADAUGĂ ANUNȚ */
  .adauga-wrap { padding: 24px 0 48px; }
  .adauga-inner { padding: 0 16px; }
  .form-steps { flex-direction: column; }
  .fstep { border-right: none; border-bottom: 1px solid var(--border-l); }
  .fg2, .fg3, .fg4 { grid-template-columns: 1fr 1fr !important; }
  .sec-bd { padding: 20px !important; }
  .sec-hd { padding: 16px 20px !important; }
  .submit-bar { flex-direction: column; align-items: stretch; }
  .submit-bar .info { text-align: center; }
  .submit-bar div:last-child { display: flex; flex-direction: column; gap: 10px; }
  #locPicker { height: 260px !important; }

  /* ANUNȚURILE MELE */
  .my-stats { grid-template-columns: repeat(3, 1fr); }
  .my-prop-row {
    grid-template-columns: 100px 1fr !important;
    gap: 12px;
  }
  .my-prop-thumb { width: 100px !important; height: 80px !important; }
  .my-prop-actions { grid-column: 1 / -1; justify-content: flex-start; }
  .my-prop-meta { display: none; }

  /* LOGIN / REGISTER */
  .auth-wrap { padding: 32px 20px; }
  .auth-card { padding: 28px 22px; max-width: 100%; }

  /* PROFIL */
  .profil-layout { grid-template-columns: 1fr !important; }
  .profil-sidebar { order: -1; }

  /* FOOTER */
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 28px; }
  .cta-section { padding: 44px 24px; }
  .cta-section h2 { font-size: 24px; }
}

/* ── MOBIL (max 600px) ── */
@media (max-width: 600px) {

  /* GENERAL */
  .container { padding: 0 14px; }

  /* HEADER */
  .site-header { padding: 0 14px; }
  .logo-text { font-size: 18px; }

  /* HERO */
  .hero-left { padding: 24px 16px; }
  .hero-title { font-size: 28px; line-height: 1.15; }
  .hero-sub { font-size: 12px; }
  .hero-right { height: 280px; }
  #main-map { height: 280px !important; }
  .hero-stats { gap: 14px; }
  .hero-stat .num { font-size: 17px; }
  .sf-price-row { grid-template-columns: 1fr; }

  /* TYPE BAR */
  .type-bar-inner { gap: 8px; }
  .qt-link { font-size: 12px; padding: 6px 12px; }

  /* CARDS */
  .props-grid { grid-template-columns: 1fr; }
  .card-img { height: 180px; }
  .section-head { flex-direction: column; gap: 12px; align-items: flex-start; }
  .section-title { font-size: 22px; }

  /* SINGLE */
  .single-header-card { padding: 16px; }
  .single-price { font-size: 28px; }
  .gallery-main { height: 220px; }
  .gallery-thumbs img { width: 60px; height: 45px; }
  .specs-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 8px; }
  .spec-item { padding: 10px 12px; }
  .spec-item .sv { font-size: 16px; }
  .breadcrumb { font-size: 12px; }
  #singleMap { height: 240px !important; }

  /* ADAUGĂ ANUNȚ */
  .page-head h1 { font-size: 22px; }
  .fg2, .fg3, .fg4 { grid-template-columns: 1fr !important; }
  .sec-bd { padding: 16px !important; }
  .fs-icon, .sec-ico { width: 36px !important; height: 36px !important; font-size: 17px !important; }
  .sec-hd h3 { font-size: 16px; }
  .upload-zone { padding: 28px 16px; }
  .coords-row { grid-template-columns: 1fr !important; }
  .map-coords-row { grid-template-columns: 1fr !important; }

  /* ANUNȚURILE MELE */
  .my-stats { grid-template-columns: 1fr; gap: 10px; }
  .my-prop-row { grid-template-columns: 80px 1fr !important; gap: 10px; }
  .my-prop-thumb { width: 80px !important; height: 65px !important; }
  .page-title { font-size: 22px; }

  /* LOGIN */
  .auth-card { padding: 22px 16px; border-radius: 12px; }
  .auth-card h2 { font-size: 22px; }

  /* CTA */
  .cta-section { padding: 32px 16px; border-radius: 16px; }
  .cta-section h2 { font-size: 20px; }
  .cta-section p { font-size: 13px; }

  /* FOOTER */
  .footer-grid { grid-template-columns: 1fr; gap: 24px; }
  .footer-bottom { flex-direction: column; text-align: center; gap: 6px; font-size: 12px; }
  .site-footer { padding: 36px 0 0; }

  /* MODAL */
  .modal-box { padding: 22px 18px; margin: 0 12px; }
}

/* ── MOBIL MIC (max 400px) ── */
@media (max-width: 400px) {
  .hero-title { font-size: 24px; }
  .btn-lg { padding: 13px 20px; font-size: 14px; }
  .single-price { font-size: 24px; }
  .specs-grid { grid-template-columns: 1fr 1fr !important; }
}

/* ══ MODAL ȘTERGERE ══ */
.modal-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.6);
  backdrop-filter: blur(4px);
  z-index: 9999;
  align-items: center;
  justify-content: center;
}
.modal-overlay.open {
  display: flex;
}
.modal-box {
  background: var(--white, #fff);
  border-radius: var(--radius, 14px);
  padding: 32px;
  max-width: 420px;
  width: 90%;
  box-shadow: 0 20px 60px rgba(0,0,0,0.3);
  position: relative;
  animation: modalIn .2s ease;
}
@keyframes modalIn {
  from { opacity:0; transform:scale(.95) translateY(10px); }
  to   { opacity:1; transform:scale(1)  translateY(0); }
}
.modal-hd {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
}
.modal-hd h3 {
  font-size: 18px;
  font-weight: 800;
  color: var(--dark, #0f1623);
}
.modal-close {
  background: none;
  border: none;
  font-size: 20px;
  cursor: pointer;
  color: var(--mid, #5a6e8a);
  line-height: 1;
  padding: 4px;
}
.modal-body {
  font-size: 14px;
  color: var(--mid, #5a6e8a);
  margin-bottom: 24px;
  line-height: 1.6;
}
.modal-ft {
  display: flex;
  gap: 10px;
  justify-content: flex-end;
}

/* ══════════════════════════════════════
   ANUNȚURILE MELE — listing rows
══════════════════════════════════════ */
.listing-row {
  background: var(--white);
  border: 1px solid var(--border-l);
  border-radius: var(--radius);
  display: grid;
  grid-template-columns: 160px 1fr auto;
  gap: 0;
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: box-shadow .2s;
}
.listing-row:hover { box-shadow: var(--shadow); }
.listing-thumb {
  width: 160px;
  height: 120px;
  overflow: hidden;
  background: var(--dark2);
  flex-shrink: 0;
}
.listing-thumb img { width:100%; height:100%; object-fit:cover; display:block; }
.listing-info {
  padding: 16px 18px;
  min-width: 0;
}
.listing-actions {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 14px 16px;
  justify-content: center;
  border-left: 1px solid var(--border-l);
  background: var(--bg);
  min-width: 90px;
}

@media (max-width: 700px) {
  .listing-row {
    grid-template-columns: 100px 1fr;
    grid-template-rows: auto auto;
  }
  .listing-thumb {
    width: 100px;
    height: 90px;
    grid-row: 1 / 3;
  }
  .listing-info { padding: 12px 12px 6px; }
  .listing-actions {
    flex-direction: row;
    border-left: none;
    border-top: 1px solid var(--border-l);
    padding: 10px 12px;
    grid-column: 2;
    background: transparent;
    min-width: 0;
    justify-content: flex-start;
    gap: 8px;
  }
  .listing-row > div:last-child { grid-column: 2; }
}

@media (max-width: 480px) {
  .listing-row {
    grid-template-columns: 80px 1fr;
  }
  .listing-thumb {
    width: 80px;
    height: 80px;
  }
  .listing-info { padding: 10px 10px 4px; font-size: 13px; }
  .listing-info > div:first-child { display: none; } /* ascunde badges pe mobil mic */
}

/* ══════════════════════════════════════
   AUTH PAGES (Login / Register)
══════════════════════════════════════ */
.auth-page {
  min-height: 100vh;
  background: var(--bg);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px 16px;
}
.auth-box {
  background: var(--white);
  border: 1px solid var(--border-l);
  border-radius: var(--radius);
  padding: 40px 36px;
  width: 100%;
  max-width: 440px;
  box-shadow: var(--shadow);
}
.auth-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  justify-content: center;
  margin-bottom: 28px;
}
.auth-logo .logo-box {
  width: 40px; height: 40px;
  background: var(--dark);
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-size: 20px;
}
.auth-logo .logo-name {
  font-family: 'Playfair Display', serif;
  font-size: 22px; font-weight: 800; color: var(--dark);
}
.auth-title {
  font-family: 'Playfair Display', serif;
  font-size: 24px; font-weight: 800;
  color: var(--dark); text-align: center; margin-bottom: 6px;
}
.auth-sub {
  font-size: 14px; color: var(--mid);
  text-align: center; margin-bottom: 28px;
}
.auth-box .form-group {
  display: flex; flex-direction: column; gap: 6px;
  margin-bottom: 16px;
}
.auth-box label {
  font-size: 11px; font-weight: 700;
  letter-spacing: 1px; text-transform: uppercase; color: var(--mid);
}
.auth-box .form-control {
  background: var(--bg);
  border: 1.5px solid var(--border-l);
  border-radius: var(--radius-sm);
  padding: 11px 14px;
  font-size: 14px; font-weight: 500; color: var(--dark);
  outline: none; width: 100%;
  transition: border-color .2s, box-shadow .2s;
}
.auth-box .form-control:focus {
  border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(201,168,76,.12);
  background: var(--white);
}
.pwd-wrap { position: relative; }
.pwd-wrap .form-control { padding-right: 44px; }
.pwd-toggle {
  position: absolute; right: 12px; top: 50%;
  transform: translateY(-50%);
  background: none; border: none;
  cursor: pointer; color: var(--mid); font-size: 16px;
}
.auth-remember {
  display: flex; align-items: center;
  justify-content: space-between; flex-wrap: wrap;
  gap: 8px; margin-bottom: 6px;
}
.auth-remember label {
  display: flex; align-items: center; gap: 7px;
  font-size: 13px; color: var(--mid);
  text-transform: none; letter-spacing: 0;
  cursor: pointer; font-weight: 500;
}
.auth-link { font-size: 13px; color: var(--gold); font-weight: 600; }
.auth-submit {
  width: 100%;
  background: linear-gradient(135deg, var(--gold), #d4b060);
  color: var(--dark); border: none;
  border-radius: var(--radius-sm);
  padding: 13px; font-size: 15px; font-weight: 800;
  cursor: pointer; margin-top: 8px;
  transition: opacity .2s;
}
.auth-submit:hover { opacity: .9; }
.auth-submit:disabled { opacity: .6; cursor: wait; }
.auth-footer {
  text-align: center; margin-top: 20px;
  font-size: 13px; color: var(--mid);
}
.auth-footer a { color: var(--gold); font-weight: 700; }
.auth-divider {
  text-align: center; margin-top: 16px;
  padding-top: 16px; border-top: 1px solid var(--border-l);
}
.auth-divider a { font-size: 13px; color: var(--mid); }

@media (max-width: 480px) {
  .auth-box { padding: 28px 20px; }
  .auth-title { font-size: 21px; }
}


/* ============================================================
   Maxhome 2026 Professional Redesign Overrides
   ============================================================ */
:root {
  --gold: #d6b85a;
  --gold-l: #ead79a;
  --gold-d: #aa8734;
  --dark: #111827;
  --dark2: #0f2f23;
  --dark3: #1f2937;
  --slate: #374151;
  --mid: #6b7280;
  --light: #9ca3af;
  --border: rgba(17,24,39,0.08);
  --border-l: #e5e7eb;
  --bg: #f6f7fb;
  --white: #ffffff;
  --sale: #0f7a44;
  --sale-bg: rgba(15,122,68,0.10);
  --rent: #b42318;
  --rent-bg: rgba(180,35,24,0.10);
  --radius: 22px;
  --radius-sm: 14px;
  --radius-xs: 10px;
  --header-h: 76px;
  --shadow-sm: 0 10px 30px rgba(17,24,39,0.06);
  --shadow: 0 18px 45px rgba(17,24,39,0.08);
  --shadow-lg: 0 24px 70px rgba(17,24,39,0.13);
}

body { background: #f6f7fb; color: #111827; }
.container { max-width: 1240px; }

.site-header {
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid #e5e7eb;
  box-shadow: 0 8px 26px rgba(17,24,39,0.05);
}
.header-inner { gap: 18px; }
.logo-box {
  width: 42px;
  height: 42px;
  border-radius: 14px;
  background: #0f2f23;
  color: #d6b85a;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: .4px;
  box-shadow: 0 14px 30px rgba(15,47,35,.18);
}
.logo-name { color: #111827; font-family: 'DM Sans', sans-serif; font-size: 20px; letter-spacing: -.4px; }
.logo-name span { color: #0f2f23; }
.header-search form {
  background: #f9fafb;
  border: 1px solid #e5e7eb;
  border-radius: 999px;
  padding: 11px 16px;
}
.header-search form:focus-within { border-color: #d6b85a; box-shadow: 0 0 0 4px rgba(214,184,90,.16); }
.header-search .hs-icon {
  width: 16px;
  height: 16px;
  display: inline-block;
  border: 2px solid #9ca3af;
  border-radius: 50%;
  position: relative;
  flex: 0 0 16px;
}
.header-search .hs-icon::after {
  content: '';
  width: 7px;
  height: 2px;
  background: #9ca3af;
  position: absolute;
  right: -5px;
  bottom: -3px;
  transform: rotate(45deg);
  border-radius: 2px;
}
.header-search input { color: #111827; }
.header-search input::placeholder { color: #9ca3af; }
.nav-link { color: #4b5563; border-radius: 999px; }
.nav-link:hover, .nav-link.active { background: #f3f4f6; color: #111827; }
.btn-adauga-header, .btn-primary, .sf-submit, .auth-submit {
  background: #d6b85a;
  color: #111827 !important;
  border-radius: 999px;
  box-shadow: 0 12px 28px rgba(214,184,90,.25);
}
.btn-adauga-header:hover, .btn-primary:hover, .sf-submit:hover, .auth-submit:hover {
  transform: translateY(-1px);
  box-shadow: 0 16px 34px rgba(214,184,90,.34);
}
.mobile-toggle {
  width: 44px;
  height: 44px;
  border: 1px solid #e5e7eb;
  border-radius: 14px;
  background: #fff;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 5px;
  padding: 0;
  color: #111827 !important;
}
.mobile-toggle span {
  width: 18px;
  height: 2px;
  background: #111827;
  border-radius: 999px;
  transition: transform .2s ease, opacity .2s ease;
}
.mobile-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.mobile-toggle.open span:nth-child(2) { opacity: 0; }
.mobile-toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
.mobile-nav {
  background: #fff;
  border-top: 1px solid #e5e7eb;
  box-shadow: 0 22px 45px rgba(17,24,39,.10);
}
.mobile-nav a { color: #111827; border-bottom: 1px solid #f3f4f6; }
.mobile-nav a:hover { background: #f9fafb; }

.btn { border-radius: 999px; min-height: 42px; }
.btn-outline { border: 1px solid #e5e7eb; color: #111827; background: #fff; }
.btn-outline:hover { background: #0f2f23; border-color: #0f2f23; color: #fff; }
.btn-dark { background: #0f2f23; }

.hero-wrap {
  width: min(1240px, calc(100% - 48px));
  margin: 32px auto 0;
  display: grid;
  grid-template-columns: minmax(340px, 420px) 1fr;
  gap: 24px;
  height: auto !important;
  min-height: 620px;
  max-height: none;
}
.hero-left {
  background: #fff !important;
  color: #111827;
  border: 1px solid #e5e7eb;
  border-radius: 24px;
  padding: 34px !important;
  box-shadow: var(--shadow-sm);
  justify-content: flex-start !important;
}
.hero-kicker { color: #0f2f23 !important; letter-spacing: 1.7px; }
.hero-title {
  color: #111827 !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: clamp(34px, 4vw, 52px) !important;
  letter-spacing: -1.4px;
}
.hero-title em { color: #d6b85a !important; font-style: normal !important; }
.hero-sub { color: #6b7280 !important; font-size: 15px !important; }
.sf-label { color: #6b7280 !important; letter-spacing: .9px !important; }
.sf-field select, .sf-field input, .filter-select, .filter-input, .form-control, .fl input, .fl select, .fl textarea {
  min-height: 48px;
  background-color: #f9fafb !important;
  border: 1px solid #e5e7eb !important;
  border-radius: 14px !important;
  color: #111827 !important;
}
.sf-field select:focus, .sf-field input:focus, .filter-select:focus, .filter-input:focus, .form-control:focus, .fl input:focus, .fl select:focus, .fl textarea:focus {
  border-color: #d6b85a !important;
  box-shadow: 0 0 0 4px rgba(214,184,90,.16) !important;
  background: #fff !important;
}
.sf-field select option { background: #fff !important; color: #111827 !important; }
.hero-right {
  min-height: 620px;
  background: #fff !important;
  border: 1px solid #e5e7eb;
  border-radius: 24px;
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}
#main-map { border-radius: 24px; }
.map-legend {
  background: #f9fafb;
  border: 1px solid #e5e7eb;
  border-radius: 999px;
  padding: 8px 12px;
  width: fit-content;
}
.legend-item { color: #6b7280 !important; }
.hero-stats { border-top: 1px solid #e5e7eb !important; gap: 18px !important; }
.hero-stat .num { color: #0f2f23 !important; }
.hero-stat .lbl { color: #6b7280 !important; }

.type-bar {
  position: static;
  margin: 24px auto 0;
  width: min(1240px, calc(100% - 48px));
  background: transparent;
  border: 0;
  box-shadow: none;
}
.type-bar .container { padding: 0; }
.type-bar-inner {
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 18px;
  padding: 8px;
  gap: 6px;
  box-shadow: var(--shadow-sm);
}
.qt-link {
  border: 0;
  border-radius: 999px;
  padding: 10px 16px;
  color: #6b7280;
}
.qt-link:hover, .qt-link.active { background: #f3f4f6; color: #111827; }

.section-head { margin-bottom: 22px; }
.section-title, .archive-title, .page-head h1, .sec-hd h3, .cta-section h2 { font-family: 'DM Sans', sans-serif !important; letter-spacing: -.7px; }
.props-grid { gap: 22px; }
.prop-card {
  border-radius: 22px;
  border: 1px solid #e5e7eb;
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  cursor: pointer;
}
.prop-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.card-img { height: 220px; }
.card-img-placeholder { background: #f3f4f6; color: #6b7280; }
.placeholder-mark {
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  background: #0f2f23;
  color: #d6b85a;
  font-weight: 900;
}
.card-badge, .card-op-badge {
  border-radius: 999px;
  padding: 6px 11px;
  font-size: 10px;
  box-shadow: 0 10px 22px rgba(17,24,39,.10);
}
.card-op-badge.vanzare { background: rgba(15,47,35,.92); }
.card-op-badge.inchiriere { background: rgba(180,35,24,.92); }
.card-price { background: #111827; border-radius: 999px; padding: 7px 14px; }
.card-fav { border: 1px solid rgba(229,231,235,.8); }
.card-body { padding: 18px; }
.card-title a { font-size: 16px; letter-spacing: -.2px; }
.card-specs { flex-wrap: wrap; gap: 8px; }
.card-spec {
  background: #f9fafb;
  border: 1px solid #e5e7eb;
  border-radius: 999px;
  padding: 5px 9px;
  color: #4b5563;
  font-size: 12px;
}
.card-location { color: #6b7280; gap: 8px; }
.card-location span {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #d6b85a;
  flex: 0 0 8px;
}
.filters-section, .single-header-card, .contact-card, .form-card, .auth-box {
  border-radius: 22px;
  border-color: #e5e7eb;
  box-shadow: var(--shadow-sm);
}
.filters-top { grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); }
.filter-group label, .form-label, .fl label { color: #6b7280; letter-spacing: .8px; }

.cta-section {
  background: #0f2f23;
  border-radius: 24px;
  box-shadow: var(--shadow);
}
.cta-section::before, .cta-section::after { display: none; }
.cta-section p { color: rgba(255,255,255,.72); }
.site-footer { background: #0f2f23; }

@media (max-width: 900px) {
  .mobile-toggle { display: flex !important; }
  .hero-wrap { width: min(100% - 28px, 720px); grid-template-columns: 1fr !important; margin-top: 20px; min-height: 0; }
  .hero-left { padding: 26px !important; }
  .hero-right { min-height: 380px; height: 380px !important; }
  #main-map { height: 380px !important; }
  .type-bar { width: min(100% - 28px, 720px); }
  .fg2, .fg3, .fg4 { grid-template-columns: 1fr 1fr !important; }
}
@media (max-width: 600px) {
  .site-header { padding: 0; }
  .logo-name { font-size: 18px; }
  .logo-box { width: 38px; height: 38px; border-radius: 12px; }
  .hero-wrap { width: calc(100% - 24px); gap: 14px; }
  .hero-left { padding: 22px !important; border-radius: 20px; }
  .hero-title { font-size: 32px !important; }
  .hero-right { min-height: 310px; height: 310px !important; border-radius: 20px; }
  #main-map { height: 310px !important; border-radius: 20px; }
  .type-bar { width: calc(100% - 24px); }
  .type-bar-inner { border-radius: 16px; }
  .qt-link { padding: 9px 12px; }
  .fg2, .fg3, .fg4, .coords-row { grid-template-columns: 1fr !important; }
  .submit-bar div:last-child { width: 100%; }
  .submit-bar .btn, .submit-bar button { width: 100%; }
}

/* Pagination layout fix for paginate_links(type=list) */
.pagination {
  width: 100%;
  display: flex;
  justify-content: center;
  margin-top: 48px;
}
.pagination ul.page-numbers {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.pagination ul.page-numbers li {
  display: flex;
  margin: 0;
  padding: 0;
  line-height: 1;
}
.pagination .page-numbers {
  flex: 0 0 auto;
  min-width: 42px;
  width: auto;
  height: 42px;
  padding: 0 14px;
  white-space: nowrap;
}
.pagination .page-numbers.prev,
.pagination .page-numbers.next {
  min-width: 92px;
  padding: 0 18px;
}
@media (max-width: 600px) {
  .pagination { margin-top: 34px; }
  .pagination ul.page-numbers { gap: 8px; }
  .pagination .page-numbers {
    min-width: 38px;
    height: 38px;
    padding: 0 12px;
    font-size: 13px;
  }
  .pagination .page-numbers.prev,
  .pagination .page-numbers.next {
    min-width: auto;
  }
}

/* Ensure pagination button styling does not apply to the generated UL */
.pagination ul.page-numbers {
  min-width: 0;
  width: auto;
  height: auto;
  background: transparent;
  border: 0;
  box-shadow: none;
}
.pagination ul.page-numbers > li > .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* MaxView main categories */
.mv-categories-section {
  padding: 28px 0 16px;
}
.mv-categories-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}
.mv-category-card {
  display: flex;
  align-items: center;
  gap: 14px;
  min-height: 108px;
  padding: 20px;
  background: #ffffff;
  border: 1px solid #e5e7eb;
  border-radius: 22px;
  box-shadow: 0 10px 30px rgba(17,24,39,.06);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.mv-category-card:hover {
  transform: translateY(-3px);
  border-color: rgba(214,184,90,.65);
  box-shadow: 0 20px 46px rgba(15,47,35,.12);
}
.mv-category-icon {
  width: 48px;
  height: 48px;
  flex: 0 0 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 16px;
  background: #0f2f23;
  color: #d6b85a;
  font-size: 24px;
  box-shadow: 0 12px 26px rgba(15,47,35,.16);
}
.mv-category-copy {
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.mv-category-copy strong {
  color: #111827;
  font-size: 15px;
  line-height: 1.25;
  letter-spacing: -.2px;
}
.mv-category-copy small {
  margin-top: 6px;
  color: #6b7280;
  font-size: 13px;
}
@media (max-width: 900px) {
  .mv-categories-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 600px) {
  .mv-categories-section { padding: 20px 0 8px; }
  .mv-categories-grid { grid-template-columns: 1fr; gap: 12px; }
  .mv-category-card { min-height: 92px; padding: 16px; border-radius: 18px; }
}


/* MaxView general classifieds */
.mv-listing-form-inner { max-width: 1080px; }
.mv-form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; }
.mv-form-field { display: flex; flex-direction: column; gap: 7px; }
.mv-form-field label { font-size: 12px; font-weight: 800; color: #374151; text-transform: uppercase; letter-spacing: .5px; }
.mv-form-field input, .mv-form-field select, .mv-form-field textarea {
  width: 100%; min-height: 48px; border: 1px solid #e5e7eb; border-radius: 14px; background: #f9fafb; color: #111827; padding: 12px 14px; font: inherit; outline: none;
}
.mv-form-field textarea { min-height: 150px; resize: vertical; }
.mv-form-field input:focus, .mv-form-field select:focus, .mv-form-field textarea:focus { border-color: #d6b85a; background: #fff; box-shadow: 0 0 0 4px rgba(214,184,90,.16); }
.mv-span-2 { grid-column: 1 / -1; }
.mv-specific-group { display: none; }
.mv-specific-empty { padding: 18px; border: 1px dashed #d1d5db; border-radius: 16px; color: #6b7280; background: #f9fafb; }
.mv-dropzone { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; min-height: 160px; border: 1.5px dashed #d6b85a; border-radius: 22px; background: #fffdf5; color: #111827; cursor: pointer; text-align: center; padding: 24px; }
.mv-dropzone input { display: none; }
.mv-dropzone strong { font-size: 18px; color: #0f2f23; }
.mv-dropzone span { color: #6b7280; font-size: 14px; }
.mv-existing-gallery, .mv-image-preview { display: grid; grid-template-columns: repeat(6, minmax(0, 1fr)); gap: 12px; margin-bottom: 16px; }
.mv-image-preview { margin-top: 16px; }
.mv-photo-choice { position: relative; display: block; border: 1px solid #e5e7eb; border-radius: 16px; overflow: hidden; background: #fff; cursor: pointer; }
.mv-photo-choice img { width: 100%; aspect-ratio: 1 / 1; object-fit: cover; display: block; }
.mv-photo-choice input[type=radio] { position: absolute; top: 8px; left: 8px; accent-color: #d6b85a; }
.mv-photo-choice span { display: block; padding: 7px; font-size: 11px; font-weight: 800; text-align: center; color: #0f2f23; }
.mv-terms { display: flex; gap: 10px; align-items: center; color: #374151; margin-bottom: 18px; }
.mv-submit { min-width: 260px; min-height: 54px; }
.mv-category-tabs { overflow-x: auto !important; }
.mv-listing-card .card-img { display: block; color: inherit; }
@media (max-width: 900px) { .mv-form-grid { grid-template-columns: 1fr; } .mv-existing-gallery, .mv-image-preview { grid-template-columns: repeat(3, minmax(0, 1fr)); } }
@media (max-width: 600px) { .mv-existing-gallery, .mv-image-preview { grid-template-columns: repeat(2, minmax(0, 1fr)); } .mv-submit { width: 100%; } }


/* MaxView UI reference redesign - homepage + add listing */
body.wp-theme-maxview-pro { background: #f4f6f2; }
.site-header {
  background: #0f2f23 !important;
  border-bottom: 0 !important;
  box-shadow: 0 10px 30px rgba(15,47,35,.18) !important;
}
.site-header .container { width: min(1240px, calc(100% - 40px)); }
.header-inner { min-height: 76px; gap: 20px !important; }
.logo-box { background: #d6b85a !important; color: #0f2f23 !important; border-radius: 14px !important; box-shadow: none !important; }
.logo-name { color: #fff !important; font-weight: 900 !important; letter-spacing: -.3px; }
.mv-header-search { flex: 1; max-width: 610px; }
.mv-header-search form {
  height: 48px !important;
  display: grid !important;
  grid-template-columns: 1fr 142px 92px;
  gap: 0;
  padding: 0 !important;
  background: #fff !important;
  border: 0 !important;
  border-radius: 999px !important;
  overflow: hidden;
  box-shadow: 0 12px 26px rgba(0,0,0,.14);
}
.mv-header-search .hs-icon { display: none !important; }
.mv-header-search input, .mv-header-search select {
  height: 48px !important;
  border: 0 !important;
  background: #fff !important;
  color: #111827 !important;
  font-size: 14px !important;
  padding: 0 18px !important;
  outline: 0 !important;
}
.mv-header-search select { border-left: 1px solid #e5e7eb !important; color: #4b5563 !important; }
.mv-header-search button {
  border: 0;
  background: #d6b85a;
  color: #0f2f23;
  font-weight: 900;
  cursor: pointer;
}
.header-nav { gap: 10px !important; }
.nav-link { color: rgba(255,255,255,.86) !important; font-weight: 700 !important; background: transparent !important; }
.nav-link:hover { color: #d6b85a !important; }
.btn-adauga-header { background: #d6b85a !important; color: #0f2f23 !important; border-radius: 999px !important; padding: 12px 18px !important; box-shadow: 0 12px 24px rgba(214,184,90,.22) !important; }
.mobile-toggle { border-color: rgba(255,255,255,.18) !important; background: rgba(255,255,255,.08) !important; }
.mobile-toggle span { background: #fff !important; }

.mv-home-categories { padding: 34px 0 10px !important; }
.section-head { margin-bottom: 22px !important; }
.section-title { font-size: 28px !important; color: #111827 !important; letter-spacing: -.7px !important; }
.section-sub { color: #6b7280 !important; }
.mv-categories-grid { gap: 18px !important; }
.mv-category-card {
  min-height: 112px !important;
  border-radius: 22px !important;
  border: 1px solid #e5e7eb !important;
  background: #fff !important;
  box-shadow: 0 10px 24px rgba(17,24,39,.06) !important;
  padding: 20px !important;
}
.mv-category-card:hover { transform: translateY(-3px); border-color: #d6b85a !important; box-shadow: 0 18px 40px rgba(15,47,35,.13) !important; }
.mv-category-icon { background: #eef5ee !important; color: #0f2f23 !important; box-shadow: none !important; font-size: 25px !important; }
.mv-category-copy strong { font-size: 15px !important; color: #111827 !important; }
.mv-category-copy small { color: #6b7280 !important; }
.mv-home-recent { padding: 30px 0 22px; }
.props-grid { gap: 22px !important; }
.prop-card.mv-listing-card {
  border-radius: 22px !important;
  overflow: hidden !important;
  border: 1px solid #e5e7eb !important;
  background: #fff !important;
  box-shadow: 0 10px 28px rgba(17,24,39,.07) !important;
}
.prop-card.mv-listing-card:hover { transform: translateY(-4px); box-shadow: 0 22px 46px rgba(15,47,35,.14) !important; }
.mv-listing-card .card-img { height: 235px !important; position: relative; background: #eef1ee; }
.mv-listing-card .card-img img { width: 100%; height: 100%; object-fit: cover; }
.mv-fav-dot { position: absolute; top: 14px; right: 14px; z-index: 3; width: 38px; height: 38px; border-radius: 999px; background: #fff; color: #0f2f23; display: inline-flex; align-items: center; justify-content: center; font-size: 20px; box-shadow: 0 8px 20px rgba(0,0,0,.12); }
.mv-listing-card .card-badge { top: 14px !important; left: 14px !important; background: #0f2f23 !important; color: #fff !important; border-radius: 999px !important; padding: 8px 11px !important; font-size: 10px !important; }
.mv-listing-card .card-op-badge { top: 58px !important; left: 14px !important; border-radius: 999px !important; background: #fff !important; color: #0f2f23 !important; }
.mv-listing-card .card-price { left: 16px !important; bottom: 14px !important; border-radius: 999px !important; background: #d6b85a !important; color: #0f2f23 !important; font-weight: 900 !important; box-shadow: 0 8px 18px rgba(0,0,0,.12); }
.mv-listing-card .card-body { padding: 18px !important; }
.mv-listing-card .card-title a { color: #111827 !important; font-size: 16px !important; font-weight: 900 !important; }
.mv-listing-card .card-specs { margin: 12px 0 !important; gap: 8px !important; }
.mv-listing-card .card-spec { border-radius: 999px !important; background: #f3f4f6 !important; color: #4b5563 !important; }
.mv-listing-card .card-location { color: #6b7280 !important; font-weight: 700 !important; }
.mv-home-cta { padding: 28px 0 64px; }
.cta-section { background: #0f2f23 !important; border-radius: 28px !important; padding: 44px 48px !important; box-shadow: 0 24px 50px rgba(15,47,35,.18) !important; }
.cta-section .btn { background: #d6b85a !important; color: #0f2f23 !important; border-radius: 999px !important; }
.site-footer { background: #0f2f23 !important; }

.mv-add-page { background: #f4f6f2 !important; padding: 30px 0 72px !important; }
.mv-listing-form-inner { max-width: 1180px !important; }
.mv-breadcrumb { display: flex; gap: 8px; align-items: center; color: #6b7280; font-size: 13px; font-weight: 700; margin-bottom: 20px; }
.mv-breadcrumb a { color: #0f2f23; }
.mv-add-head { margin-bottom: 22px !important; }
.mv-add-head h1 { font-size: 34px !important; color: #111827 !important; }
.mv-add-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 24px; }
.mv-add-steps div { display: flex; align-items: center; gap: 10px; background: #fff; border: 1px solid #e5e7eb; border-radius: 18px; padding: 14px 16px; box-shadow: 0 8px 22px rgba(17,24,39,.05); color: #6b7280; }
.mv-add-steps div.active { border-color: #d6b85a; color: #0f2f23; }
.mv-add-steps span { width: 30px; height: 30px; border-radius: 999px; display: inline-flex; align-items: center; justify-content: center; background: #eef5ee; color: #0f2f23; font-weight: 900; }
.mv-add-steps .active span { background: #d6b85a; }
.mv-add-steps strong { font-size: 13px; }
.mv-add-layout { display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: 26px; align-items: start; }
.mv-add-main .form-sec { border-radius: 24px !important; border: 1px solid #e5e7eb !important; box-shadow: 0 12px 30px rgba(17,24,39,.06) !important; margin-bottom: 22px !important; }
.mv-add-main .sec-hd { padding: 22px 26px !important; background: #fff !important; }
.mv-add-main .sec-ico { background: #0f2f23 !important; color: #d6b85a !important; border-radius: 16px !important; box-shadow: none !important; font-size: 15px !important; font-weight: 900; }
.mv-add-main .sec-bd { padding: 26px !important; }
.mv-form-grid { gap: 18px 20px !important; }
.mv-form-field input, .mv-form-field select, .mv-form-field textarea { border-radius: 16px !important; min-height: 52px !important; background: #f9fafb !important; }
.mv-form-field label { color: #374151 !important; }
.mv-dropzone { border-radius: 22px !important; background: #fffdf3 !important; }
.mv-submit { background: #d6b85a !important; color: #0f2f23 !important; border-radius: 999px !important; min-height: 54px !important; padding: 0 34px !important; box-shadow: 0 14px 28px rgba(214,184,90,.25) !important; }
.mv-add-sidebar { position: sticky; top: 96px; display: grid; gap: 18px; }
.mv-side-card { background: #fff; border: 1px solid #e5e7eb; border-radius: 24px; padding: 22px; box-shadow: 0 12px 30px rgba(17,24,39,.06); }
.mv-side-card h3 { margin: 0 0 16px; color: #111827; font-size: 18px; font-weight: 900; }
.mv-side-cats { display: grid; gap: 9px; max-height: 430px; overflow: auto; }
.mv-side-cats span { display: flex; align-items: center; gap: 10px; color: #374151; background: #f9fafb; border-radius: 14px; padding: 10px 12px; font-weight: 800; font-size: 13px; }
.mv-side-cats i { font-style: normal; width: 24px; text-align: center; }
.mv-tips-card ul { margin: 0; padding-left: 18px; color: #6b7280; line-height: 1.7; font-size: 14px; }
@media (max-width: 1050px) { .mv-header-search form { grid-template-columns: 1fr 112px 78px; } .header-nav .nav-link:first-child { display: none; } .mv-add-layout { grid-template-columns: 1fr; } .mv-add-sidebar { position: static; } }
@media (max-width: 900px) { .header-search { display: none !important; } .mv-add-steps { grid-template-columns: 1fr 1fr; } .mv-categories-grid { grid-template-columns: repeat(2, minmax(0,1fr)) !important; } }
@media (max-width: 600px) { .site-header .container { width: calc(100% - 24px); } .mv-categories-grid { grid-template-columns: 1fr !important; } .mv-add-steps { grid-template-columns: 1fr; } .mv-add-head h1 { font-size: 28px !important; } .cta-section { padding: 30px 22px !important; border-radius: 22px !important; } .mv-listing-card .card-img { height: 210px !important; } }
