@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600;700;800&display=swap');

:root {
  --primary:       #1a9cb7;   /* teal principal */
  --primary-light: #15859c;   /* teal hover (más oscuro) */
  --primary-dark:  #117d93;
  --accent:        #1a9cb7;   /* mismo teal para acentos */
  --whatsapp:      #25d366;
  --text:          #333;
  --text-light:    #666;
  --bg:            #f4f6f9;
  --white:         #fff;
  --border:        #e0e6ed;
  --shadow:        0 2px 15px rgba(0,0,0,0.09);
  --radius:        8px;
}

*  { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; }
body { font-family:'DM Sans',sans-serif; color:var(--text); background:var(--bg); }
a { text-decoration:none; }
img { max-width:100%; }

/* ── PRELOADER ───────────────────────────────── */
#preloader { position:fixed; inset:0; z-index:9999; background:#fff; display:flex; align-items:center; justify-content:center; transition:opacity .5s ease, visibility .5s ease; }
#preloader.hidden { opacity:0; visibility:hidden; }
.preloader-inner { display:flex; flex-direction:column; align-items:center; gap:22px; }
.preloader-inner img { width:90px; height:auto; animation:preloadPulse 1.4s ease-in-out infinite; }
@keyframes preloadPulse { 0%,100%{ transform:scale(1); opacity:1; } 50%{ transform:scale(1.12); opacity:.65; } }
.preloader-bar { width:160px; height:4px; background:#e6e9ee; border-radius:4px; overflow:hidden; }
.preloader-bar span { display:block; width:40%; height:100%; background:var(--primary); border-radius:4px; animation:preloadSlide 1.1s ease-in-out infinite; }
@keyframes preloadSlide { 0%{ transform:translateX(-100%); } 100%{ transform:translateX(350%); } }

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

/* ── TOP BAR ─────────────────────────────────── */
.top-bar { background:var(--primary); padding:7px 0; font-size:13px; color:#fff; }
.top-bar .container { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:6px; }
.top-bar .social a { color:#fff; margin-right:12px; font-size:14px; opacity:.85; transition:opacity .2s; }
.top-bar .social a:hover { opacity:1; }
.uf-value { font-size:13px; }
.uf-value span { opacity:.75; margin-right:4px; font-weight:400; }
.uf-value strong { font-weight:700; }

/* ── STICKY HEADER ───────────────────────────── */
.sticky-header { position:sticky; top:0; z-index:1000; background:#fff; box-shadow:0 2px 12px rgba(0,0,0,0.1); }

/* ── MAIN HEADER ─────────────────────────────── */
.main-header { padding:10px 0; }
.main-header .container { display:flex; align-items:center; gap:18px; flex-wrap:wrap; }

.logo-area { display:flex; align-items:center; gap:10px; flex:1 1 0; min-width:0; }
.logo-area img { width:40px; height:50px; object-fit:contain; }
.logo-text .one  { font-size:26px; font-weight:800; color:var(--primary); line-height:1; letter-spacing:-1px; }
.logo-text .sub  { font-size:9px;  font-weight:500; color:var(--text-light); text-transform:uppercase; letter-spacing:1.5px; }

.header-search { flex:0 1 480px; width:480px; min-width:200px; position:relative; display:flex; align-items:center; background:#f4f6f9; border:1.5px solid var(--border); border-radius:28px; padding:3px 4px 3px 0; transition:border-color .2s; }
.header-search:focus-within { border-color:var(--primary); }
.header-search .search-icon { position:absolute; left:15px; top:50%; transform:translateY(-50%); color:var(--text-light); font-size:14px; pointer-events:none; }
.header-search input {
  flex:1; width:100%; padding:9px 12px 9px 38px;
  border:none; background:transparent; border-radius:25px;
  font-family:'DM Sans',sans-serif; font-size:13px; outline:none;
}
.header-search button { background:var(--primary); color:#fff; border:none; padding:8px 20px; border-radius:22px; cursor:pointer; font-family:'DM Sans',sans-serif; font-size:13px; font-weight:600; transition:background .2s; white-space:nowrap; flex-shrink:0; }
.header-search button:hover { background:var(--primary-light); }

.header-actions { display:flex; align-items:center; gap:8px; flex:1 1 0; justify-content:flex-end; flex-wrap:wrap; }
.btn-currency { background:#fff; color:var(--text); border:1.5px solid var(--border); padding:8px 16px; border-radius:8px; font-family:'DM Sans',sans-serif; font-size:12px; font-weight:700; cursor:pointer; letter-spacing:.5px; transition:all .2s; white-space:nowrap; }
.btn-currency:hover { border-color:var(--primary); color:var(--primary); }
.btn-login { background:#fff; color:var(--text); border:1.5px solid var(--border); padding:8px 16px; border-radius:8px; font-family:'DM Sans',sans-serif; font-size:12px; font-weight:700; cursor:pointer; transition:all .2s; display:inline-flex; align-items:center; gap:7px; white-space:nowrap; }
.btn-login i { font-size:16px; color:var(--primary); }
.btn-login .lucide-dashboard { color:#000; flex-shrink:0; }
.btn-login:hover .lucide-dashboard { color:#000; }
.btn-login:hover { border-color:var(--primary); color:var(--primary); }
.btn-logout { background:#fff; color:var(--text-light); border:1.5px solid var(--border); padding:9px 12px; border-radius:8px; font-family:'DM Sans',sans-serif; font-size:13px; cursor:pointer; transition:all .2s; }
.btn-logout:hover { border-color:#e74c3c; color:#e74c3c; }

/* ── NAVBAR ──────────────────────────────────── */
.navbar { background:#fff; border-top:1px solid var(--border); }
.navbar .container { display:flex; justify-content:center; align-items:center; position:relative; }
.navbar ul { list-style:none; display:flex; }
.navbar ul li a { display:block; padding:14px 30px; color:var(--text); font-size:12px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; transition:color .2s,border-color .2s; border-bottom:3px solid transparent; }
.navbar ul li a:hover, .navbar ul li a.active { color:var(--primary); border-bottom-color:var(--primary); }
.hamburger { display:none; cursor:pointer; padding:10px 14px; background:none; border:none; align-items:center; gap:9px; }
.hamburger .ham-label { font-size:12px; font-weight:700; color:var(--primary); text-transform:uppercase; letter-spacing:1.5px; }
.hamburger .ham-icon { display:inline-block; }
.hamburger .ham-icon span { display:block; width:22px; height:2.5px; background:var(--primary); margin:5px 0; transition:.3s; border-radius:2px; }
.hamburger.open .ham-icon span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.hamburger.open .ham-icon span:nth-child(2) { opacity:0; }
.hamburger.open .ham-icon span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* ── HERO CAROUSEL ───────────────────────────── */
.hero { position:relative; height:580px; overflow:hidden; }
.hero-slide { position:absolute; inset:0; background-size:cover; background-position:center; opacity:0; transition:opacity 1s ease; }
.hero-slide.active { opacity:1; }
.hero-overlay { position:absolute; inset:0; background:rgba(0,0,0,.52); }
.hero-content { position:absolute; inset:0; display:flex; flex-direction:column; justify-content:center; align-items:flex-start; text-align:left; color:#fff; padding:20px 8%; z-index:2; }
.hero-badge { display:inline-flex; align-items:center; gap:8px; background:rgba(255,255,255,.18); backdrop-filter:blur(4px); border:1px solid rgba(255,255,255,.3); color:#fff; padding:7px 16px; border-radius:25px; font-size:13px; font-weight:600; margin-bottom:20px; }
.hero-content h1 { font-size:clamp(30px,5.5vw,58px); font-weight:800; text-shadow:0 2px 12px rgba(0,0,0,.5); margin-bottom:18px; line-height:1.08; max-width:760px; }
.hero-content p  { font-size:clamp(13px,1.8vw,16px); max-width:620px; margin-bottom:30px; opacity:.92; line-height:1.75; }
.hero-buttons { display:flex; gap:14px; flex-wrap:wrap; justify-content:flex-start; }

.btn-primary { background:var(--primary); color:#fff; padding:13px 26px; border-radius:30px; font-weight:700; font-size:13px; display:inline-flex; align-items:center; gap:7px; transition:background .2s,transform .2s; }
.btn-primary:hover { background:var(--primary-light); transform:translateY(-2px); }
.btn-secondary { background:transparent; color:#fff; padding:13px 26px; border-radius:30px; font-weight:700; font-size:13px; border:2px solid #fff; display:inline-flex; align-items:center; gap:7px; transition:all .2s; }
.btn-secondary:hover { background:rgba(255,255,255,.15); transform:translateY(-2px); }

.hero-dots { position:absolute; bottom:18px; left:50%; transform:translateX(-50%); display:flex; gap:7px; z-index:3; }
.hero-dots button { width:9px; height:9px; border-radius:50%; background:rgba(255,255,255,.45); border:none; cursor:pointer; transition:background .2s,transform .2s; padding:0; }
.hero-dots button.active { background:#fff; transform:scale(1.3); }

/* ── SERVICES ────────────────────────────────── */
.services-section { padding:70px 0; background:#fff; }
.section-label { text-align:center; font-size:11px; font-weight:700; color:var(--primary); letter-spacing:2.5px; text-transform:uppercase; margin-bottom:10px; }
.section-title { text-align:center; font-size:clamp(22px,3vw,30px); font-weight:800; color:var(--primary); margin-bottom:40px; }
.section-title span { color:var(--accent); }

.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.service-card { padding:28px 22px; border:1px solid var(--border); border-radius:var(--radius); transition:box-shadow .2s,transform .2s; }
.service-card:hover { box-shadow:var(--shadow); transform:translateY(-4px); }
.service-icon { display:flex; align-items:center; justify-content:center; margin:0 auto 16px; color:#000; }
.service-icon svg { width:44px; height:44px; }
.service-card h3 { font-size:13px; font-weight:800; color:var(--primary); margin-bottom:14px; text-transform:uppercase; letter-spacing:.5px; text-align:center; }
.service-sub { display:block; font-weight:500; font-size:11px; color:#888; text-transform:none; letter-spacing:.3px; margin-top:4px; }
.service-card ul { list-style:none; }
.service-card ul li { padding:6px 0; font-size:13px; color:var(--text-light); border-bottom:1px solid #f2f2f2; display:flex; align-items:center; gap:7px; }
.service-card ul li:last-child { border-bottom:none; }
.service-card ul li::before { content:'›'; color:var(--accent); font-weight:800; font-size:16px; }

/* ── SECTION HEADER ──────────────────────────── */
.section-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:36px; }
.section-header h2 { font-size:clamp(20px,2.5vw,26px); font-weight:800; color:var(--primary); }
.section-header h2 span { color:var(--accent); }
.section-header a { color:var(--primary); font-size:12px; font-weight:700; transition:opacity .2s; }
.section-header a:hover { opacity:.7; }

/* ── FEATURED ────────────────────────────────── */
.featured-section { padding:70px 0; background:var(--bg); }

/* ── PROPERTY CARD ───────────────────────────── */
.properties-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }

.prop-card { background:#fff; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); cursor:pointer; transition:transform .2s,box-shadow .2s; }
.prop-card:hover { transform:translateY(-5px); box-shadow:0 10px 30px rgba(0,0,0,.14); }

.prop-img { position:relative; height:195px; overflow:hidden; }
.prop-img img { width:100%; height:100%; object-fit:cover; transition:transform .35s; }
.prop-card:hover .prop-img img { transform:scale(1.06); }
.prop-img-placeholder { width:100%; height:100%; background:linear-gradient(135deg,#dde3ee,#c8d2e0); display:flex; align-items:center; justify-content:center; color:var(--text-light); font-size:36px; }

.prop-badges { position:absolute; top:10px; left:10px; display:flex; gap:5px; flex-wrap:wrap; max-width:62%; }
.prop-badges-right { position:absolute; top:10px; right:10px; }
.badge { padding:4px 9px; border-radius:20px; font-size:9.5px; font-weight:700; text-transform:uppercase; letter-spacing:.3px; white-space:nowrap; }
.badge-venta    { background:var(--primary); color:#fff; }
.badge-arriendo { background:var(--primary); color:#fff; }
.badge-disponible { background:#3ec46d; color:#fff; }
.badge-vendida, .badge-arrendada { background:#e74c3c; color:#fff; }
.badge-tipo { background:#fff; color:#333; }
.badge-clickable { cursor:pointer; transition:filter .15s,transform .15s; user-select:none; }
.badge-clickable:hover { filter:brightness(1.08); transform:scale(1.05); }

.prop-body { padding:16px 18px; }
.prop-price { font-size:22px; font-weight:800; color:var(--primary); margin-bottom:8px; }
.prop-price .currency-label { font-size:12px; font-weight:500; color:var(--text-light); margin-left:2px; }
.prop-title { font-size:16px; font-weight:700; color:var(--text); margin-bottom:8px; line-height:1.3; }
.prop-address { font-size:13px; font-weight:400; color:var(--text-light); margin-bottom:14px; display:flex; gap:6px; align-items:flex-start; line-height:1.45; }
.prop-address i { color:var(--primary); margin-top:3px; flex-shrink:0; }
.prop-address svg { width:16px; height:16px; color:var(--primary); margin-top:2px; flex-shrink:0; }

.prop-features { display:flex; justify-content:space-between; align-items:center; gap:8px; padding-top:14px; border-top:1px solid var(--border); }
.prop-feat { display:flex; align-items:center; justify-content:center; gap:6px; font-size:13px; color:var(--text-light); flex:1; }
.prop-feat i { color:var(--primary); font-size:14px; }
.prop-feat svg { width:17px; height:17px; color:var(--primary); flex-shrink:0; }

/* ── TEAM ────────────────────────────────────── */
.team-section { padding:70px 0; background:#fff; }
.team-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.team-card { background:#fff; border:1px solid var(--border); border-radius:16px; overflow:hidden; transition:transform .25s,box-shadow .25s; }
.team-card:hover { transform:translateY(-6px); box-shadow:0 14px 36px rgba(0,0,0,.12); }
.team-photo { position:relative; height:300px; overflow:hidden; }
.team-photo img { width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.team-card:hover .team-photo img { transform:scale(1.06); }
.team-socials { position:absolute; left:0; right:0; bottom:-50px; display:flex; justify-content:center; gap:10px; padding:14px; background:linear-gradient(transparent,rgba(0,0,0,.55)); transition:bottom .3s; }
.team-card:hover .team-socials { bottom:0; }
.team-socials a { width:36px; height:36px; background:rgba(255,255,255,.95); color:var(--primary); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:14px; transition:background .2s,color .2s; }
.team-socials a:hover { background:var(--primary); color:#fff; }
.team-body { padding:20px 22px 24px; text-align:center; }
.team-body h3 { font-size:18px; font-weight:700; color:var(--text); margin-bottom:4px; }
.team-role { display:inline-block; font-size:12px; font-weight:600; color:var(--primary); text-transform:uppercase; letter-spacing:.8px; margin-bottom:12px; }
.team-body p { font-size:13.5px; color:var(--text-light); line-height:1.65; }

/* ── FILTERS ─────────────────────────────────── */
.filter-accordion { background:#fff; border-radius:var(--radius); box-shadow:var(--shadow); margin-bottom:28px; overflow:hidden; }
.filter-toggle { width:100%; padding:15px 20px; background:var(--primary); color:#fff; border:none; font-family:'DM Sans',sans-serif; font-size:13px; font-weight:700; cursor:pointer; display:flex; justify-content:space-between; align-items:center; letter-spacing:.5px; }
.filter-toggle i { transition:transform .3s; }
.filter-toggle.open i { transform:rotate(180deg); }
.filter-body { display:none; padding:20px; }
.filter-body.open { display:block; animation:slideDown .25s ease; }
@keyframes slideDown { from{opacity:0;transform:translateY(-6px)} to{opacity:1;transform:translateY(0)} }

.filter-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(160px,1fr)); gap:14px; margin-bottom:14px; }
.filter-group label { display:block; font-size:10px; font-weight:700; color:var(--text-light); text-transform:uppercase; letter-spacing:.7px; margin-bottom:5px; }
.filter-group select, .filter-group input { width:100%; padding:9px 11px; border:1.5px solid var(--border); border-radius:6px; font-family:'DM Sans',sans-serif; font-size:12px; outline:none; transition:border-color .2s; background:#fff; }
.filter-group select:focus, .filter-group input:focus { border-color:var(--primary); }
.filter-actions { display:flex; gap:9px; justify-content:flex-end; }
.btn-filter { background:var(--primary); color:#fff; border:none; padding:10px 22px; border-radius:6px; font-family:'DM Sans',sans-serif; font-size:12px; font-weight:700; cursor:pointer; transition:background .2s; }
.btn-filter:hover { background:var(--primary-light); }
.btn-reset { background:#eaecef; color:var(--text); border:none; padding:10px 22px; border-radius:6px; font-family:'DM Sans',sans-serif; font-size:12px; font-weight:600; cursor:pointer; transition:background .2s; }
.btn-reset:hover { background:#dde1e6; }

.props-page { padding:50px 0; }
.props-count { font-size:13px; color:var(--text-light); margin-bottom:20px; }
.props-count strong { color:var(--primary); }

/* ── LAYOUT 2 COLUMNAS (listado + filtro derecha) ─── */
.props-layout { display:flex; gap:26px; align-items:flex-start; }
.props-main { flex:1; min-width:0; order:2; }
.props-filter-col { width:280px; max-width:280px; flex-shrink:0; order:1; position:sticky; top:130px; }
.props-filter-col .filter-accordion { margin-bottom:0; }

/* En escritorio: sin acordeón, filtro siempre visible */
.filter-toggle { display:none; }
.props-filter-col .filter-accordion { border:1px solid #eef0f3; border-radius:14px; box-shadow:0 4px 20px rgba(0,0,0,.05); }
.filter-desktop-title { display:flex; align-items:center; justify-content:space-between; padding:16px 18px; background:#fff; color:var(--text); font-size:16px; font-weight:700; border-radius:14px 14px 0 0; }
.filter-desktop-title .fdt-left { display:flex; align-items:center; gap:9px; }
.filter-desktop-title .fdt-left i { color:var(--text); font-size:15px; }
.fdt-clear { background:none; border:none; color:var(--text-light); font-family:'DM Sans',sans-serif; font-size:13px; font-weight:500; cursor:pointer; display:inline-flex; align-items:center; gap:6px; padding:4px 6px; border-radius:6px; transition:color .2s,background .2s; }
.fdt-clear:hover { color:var(--primary); background:#f4f6f9; }

.props-filter-col .filter-body { display:block; padding:6px 18px 18px; }
.props-filter-col .filter-grid { grid-template-columns:1fr; gap:18px; margin-bottom:0; }

/* Etiquetas */
.props-filter-col .filter-group label { font-size:13px; font-weight:500; color:var(--text-light); text-transform:none; letter-spacing:0; margin-bottom:7px; }

/* Selects tipo pastilla (ancho automático) */
.props-filter-col .filter-group select {
  width:auto; max-width:100%; display:inline-block;
  padding:9px 34px 9px 14px; border:1.5px solid #e6e9ee; border-radius:11px;
  background:#fff url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E") no-repeat right 11px center;
  -webkit-appearance:none; -moz-appearance:none; appearance:none;
  font-size:13.5px; color:var(--text); cursor:pointer;
}
.props-filter-col .filter-group select:focus { border-color:var(--primary); }

/* Inputs de precio (ancho completo) */
.props-filter-col .filter-group input {
  width:100%; padding:12px 14px; border:1.5px solid #e6e9ee; border-radius:11px;
  font-size:13.5px; color:var(--text);
}
.props-filter-col .filter-group input:focus { border-color:var(--primary); }
.props-filter-col .filter-group input::placeholder { color:#9aa3ad; }

/* Botón Limpiar inferior solo visible en móvil */
.props-filter-col .filter-actions { display:none; }

/* ── PAGINATION ──────────────────────────────── */
.pagination { display:flex; justify-content:center; gap:5px; margin-top:30px; flex-wrap:wrap; }
.pagination button { width:36px; height:36px; border:1.5px solid var(--border); background:#fff; border-radius:6px; font-family:'DM Sans',sans-serif; font-size:13px; cursor:pointer; transition:all .2s; }
.pagination button.active { background:var(--primary); border-color:var(--primary); color:#fff; }
.pagination button:hover:not(.active) { border-color:var(--primary); color:var(--primary); }

/* ── MODAL ───────────────────────────────────── */
.modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,.7); z-index:2000; display:flex; align-items:flex-start; justify-content:center; padding:20px; opacity:0; pointer-events:none; transition:opacity .3s; overflow-y:auto; }
.modal-overlay.open { opacity:1; pointer-events:all; }
.modal { background:#fff; border-radius:var(--radius); max-width:920px; width:100%; margin:auto; transform:translateY(20px); transition:transform .3s; }
.modal-overlay.open .modal { transform:translateY(0); }
.modal-head { padding:18px 22px; border-bottom:1px solid var(--border); display:flex; justify-content:space-between; align-items:center; position:sticky; top:0; background:#fff; z-index:1; border-radius:var(--radius) var(--radius) 0 0; }
.modal-head h2 { font-size:18px; color:var(--primary); font-weight:700; }
.modal-close { background:none; border:none; font-size:22px; cursor:pointer; color:var(--text-light); line-height:1; width:32px; height:32px; display:flex; align-items:center; justify-content:center; border-radius:50%; transition:background .2s; }
.modal-close:hover { background:#f0f0f0; }
.modal-body { padding:22px; }

.gallery-main { height:340px; border-radius:var(--radius); overflow:hidden; margin-bottom:9px; }
.gallery-main img { width:100%; height:100%; object-fit:cover; }
.gallery-thumbs { display:flex; gap:7px; overflow-x:auto; padding-bottom:4px; }
.gallery-thumbs img { width:75px; height:57px; object-fit:cover; border-radius:4px; cursor:pointer; border:2.5px solid transparent; transition:border-color .2s; flex-shrink:0; opacity:.75; transition:all .2s; }
.gallery-thumbs img:hover, .gallery-thumbs img.active { border-color:var(--primary); opacity:1; }

.modal-info-wrap { display:block; margin:20px 0; }
.modal-left .modal-price { font-size:28px; font-weight:800; color:var(--primary); margin-bottom:6px; }
.modal-left .modal-price .currency-label { font-size:14px; font-weight:500; color:var(--text-light); }
.modal-badges { display:flex; gap:7px; flex-wrap:wrap; margin-bottom:14px; }
.info-row { display:flex; gap:8px; align-items:flex-start; margin-bottom:9px; font-size:13px; }
.info-row i { color:var(--primary); margin-top:2px; flex-shrink:0; width:16px; }
.info-row strong { color:var(--text-light); font-weight:600; margin-right:3px; }

.modal-feats { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-bottom:22px; }
.mfeat { display:flex; align-items:center; gap:12px; padding:14px 16px; border:1.5px solid #eef0f3; border-radius:12px; background:#fff; }
.mfeat-icon { width:42px; height:42px; flex-shrink:0; background:#e8f4f8; border-radius:10px; display:flex; align-items:center; justify-content:center; color:var(--primary); }
.mfeat-icon svg { width:22px; height:22px; }
.mfeat-text { display:flex; flex-direction:column; gap:1px; min-width:0; }
.mfeat-text span { font-size:12px; color:var(--text-light); font-weight:500; }
.mfeat-text strong { font-size:16px; font-weight:700; color:var(--text); line-height:1.2; }

.modal-desc { font-size:14px; line-height:1.8; color:var(--text); margin-bottom:22px; }
.modal-section-title { font-size:13px; font-weight:700; color:var(--primary); margin-bottom:12px; text-transform:uppercase; letter-spacing:.7px; display:flex; align-items:center; gap:8px; }

#modal-map { height:270px; border-radius:var(--radius); margin-bottom:22px; }
.nearby-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(190px,1fr)); gap:7px; }
.nearby-item { display:flex; align-items:center; gap:9px; padding:8px 11px; background:var(--bg); border-radius:6px; }
.nearby-item i { color:var(--primary); flex-shrink:0; width:16px; text-align:center; }
.nearby-info .nearby-name { font-size:12px; font-weight:600; color:var(--text); }
.nearby-info .nearby-dist { font-size:11px; color:var(--text-light); }
.nearby-loading { font-size:13px; color:var(--text-light); padding:10px; }

/* ── CONTACT ─────────────────────────────────── */
.contact-page { padding:55px 0; }
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:start; }
#contact-map { height:280px; border-radius:var(--radius); margin-bottom:24px; }
.contact-form-box, .contact-info-box { background:#fff; border-radius:var(--radius); box-shadow:var(--shadow); padding:28px; }
.contact-box-title { font-size:18px; font-weight:700; color:var(--primary); margin-bottom:20px; }
.form-group { margin-bottom:14px; }
.form-group label { display:block; font-size:11px; font-weight:700; color:var(--text-light); text-transform:uppercase; letter-spacing:.7px; margin-bottom:5px; }
.form-group input, .form-group textarea { width:100%; padding:10px 13px; border:1.5px solid var(--border); border-radius:6px; font-family:'DM Sans',sans-serif; font-size:13px; outline:none; transition:border-color .2s; }
.form-group input:focus, .form-group textarea:focus { border-color:var(--primary); }
.form-group textarea { resize:vertical; min-height:110px; }
.btn-submit { width:100%; background:var(--primary); color:#fff; border:none; padding:13px; border-radius:6px; font-family:'DM Sans',sans-serif; font-size:14px; font-weight:700; cursor:pointer; transition:background .2s; }
.btn-submit:hover { background:var(--primary-light); }
.contact-item { display:flex; gap:13px; align-items:flex-start; margin-bottom:18px; }
.contact-item i { font-size:20px; color:var(--primary); margin-top:2px; flex-shrink:0; width:20px; text-align:center; }
.contact-item p { font-size:13px; color:var(--text); line-height:1.6; margin:0; }
.contact-item strong { display:block; font-weight:700; color:var(--primary); margin-bottom:2px; }
.contact-socials { display:flex; gap:9px; margin-top:20px; }
.contact-socials a { width:36px; height:36px; background:var(--primary); color:#fff; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:14px; transition:background .2s; }
.contact-socials a:hover { background:var(--accent); }

/* ── ALERTS ──────────────────────────────────── */
.alert { padding:11px 15px; border-radius:6px; font-size:13px; margin-bottom:14px; }
.alert-success { background:#d4edda; color:#155724; border:1px solid #c3e6cb; }
.alert-error   { background:#f8d7da; color:#721c24; border:1px solid #f5c6cb; }
.alert-info    { background:#d1ecf1; color:#0c5460; border:1px solid #bee5eb; }

/* ── LOGIN PAGE ──────────────────────────────── */
.login-wrap { min-height:calc(100vh - 150px); display:flex; align-items:center; justify-content:center; padding:40px 20px; }
.login-wrap-bg { background-size:cover; background-position:center; background-attachment:fixed; }
.login-card { background:#fff; padding:40px 36px; border-radius:var(--radius); box-shadow:0 8px 40px rgba(0,0,0,.12); text-align:center; max-width:420px; width:100%; }
.login-card .logo-area { justify-content:center; margin-bottom:24px; }
.login-card h2 { font-size:20px; font-weight:700; color:var(--primary); margin-bottom:8px; }
.login-card p { font-size:13px; color:var(--text-light); margin-bottom:24px; line-height:1.6; }
.btn-google { display:inline-flex; align-items:center; gap:10px; background:#fff; color:#333; border:1.5px solid #ddd; padding:12px 22px; border-radius:30px; font-family:'DM Sans',sans-serif; font-size:13px; font-weight:600; cursor:pointer; width:100%; justify-content:center; transition:box-shadow .2s,border-color .2s; }
.btn-google:hover { box-shadow:0 2px 12px rgba(0,0,0,.13); border-color:#bbb; }
.btn-google img { width:20px; height:20px; }
.login-note { font-size:11px; color:var(--text-light); margin-top:16px; }
.unauthorized-box { background:#fff3cd; border:1px solid #ffc107; padding:20px; border-radius:var(--radius); margin-top:20px; }
.unauthorized-box p { font-size:14px; color:#856404; font-weight:600; }

/* ── PANEL ───────────────────────────────────── */
.panel-layout { display:flex; min-height:calc(100vh - 220px); }
.panel-sidebar { width:230px; background:var(--primary); flex-shrink:0; }
.panel-sidebar .sidebar-user { padding:20px; border-bottom:1px solid rgba(255,255,255,.1); display:flex; align-items:center; gap:10px; }
.panel-sidebar .sidebar-user img { width:38px; height:38px; border-radius:50%; object-fit:cover; border:2px solid rgba(255,255,255,.3); }
.sidebar-name { font-size:12px; font-weight:700; color:#fff; }
.sidebar-rol  { font-size:10px; color:rgba(255,255,255,.6); text-transform:uppercase; letter-spacing:.5px; }
.panel-sidebar ul { list-style:none; padding:12px 0; }
.panel-sidebar ul li a { display:flex; align-items:center; gap:10px; padding:11px 20px; color:rgba(255,255,255,.75); font-size:12px; font-weight:600; transition:background .2s,color .2s; letter-spacing:.3px; }
.panel-sidebar ul li a:hover, .panel-sidebar ul li a.active { background:rgba(255,255,255,.14); color:#fff; }
.panel-sidebar ul li a i { width:16px; text-align:center; }

.panel-content { flex:1; padding:28px; background:var(--bg); min-width:0; }
.panel-page-title { font-size:20px; font-weight:700; color:var(--primary); margin-bottom:22px; display:flex; align-items:center; gap:10px; }

.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-bottom:28px; }
.stat-card { background:#fff; padding:20px 18px; border-radius:var(--radius); box-shadow:var(--shadow); }
.stat-card .stat-icon { font-size:26px; color:var(--primary); margin-bottom:10px; }
.stat-card .stat-num  { font-size:30px; font-weight:800; color:var(--primary); line-height:1; }
.stat-card .stat-label { font-size:11px; color:var(--text-light); text-transform:uppercase; letter-spacing:.7px; margin-top:4px; }

.panel-card { background:#fff; border-radius:var(--radius); box-shadow:var(--shadow); overflow:hidden; }
.panel-card-head { padding:14px 18px; border-bottom:1px solid var(--border); display:flex; justify-content:space-between; align-items:center; }
.panel-card-head h3 { font-size:15px; font-weight:700; color:var(--primary); }
.btn-add { background:var(--primary); color:#fff; border:none; padding:9px 16px; border-radius:6px; font-family:'DM Sans',sans-serif; font-size:12px; font-weight:700; cursor:pointer; display:inline-flex; align-items:center; gap:6px; transition:background .2s; }
.btn-add:hover { background:var(--primary-light); }

.table-wrap { overflow-x:auto; }
table { width:100%; border-collapse:collapse; font-size:13px; }
table th { background:var(--bg); padding:11px 14px; text-align:left; font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.7px; color:var(--text-light); white-space:nowrap; }
table td { padding:11px 14px; border-bottom:1px solid var(--border); vertical-align:middle; }
table tr:last-child td { border-bottom:none; }
table tr:hover td { background:#fafbfc; }
.action-btns { display:flex; gap:5px; }
.btn-edit, .btn-del, .btn-view { border:none; padding:5px 11px; border-radius:4px; font-family:'DM Sans',sans-serif; font-size:11px; font-weight:700; cursor:pointer; transition:opacity .2s; }
.btn-edit { background:var(--primary); color:#fff; }
.btn-del  { background:#e74c3c; color:#fff; }
.btn-view { background:#27ae60; color:#fff; }
.btn-edit:hover, .btn-del:hover, .btn-view:hover { opacity:.85; }

/* ── FORM MODAL (PANEL) ──────────────────────── */
.fmodal-overlay { position:fixed; inset:0; background:rgba(0,0,0,.65); z-index:3000; display:flex; align-items:flex-start; justify-content:center; padding:30px 16px; overflow-y:auto; opacity:0; pointer-events:none; transition:opacity .3s; }
.fmodal-overlay.open { opacity:1; pointer-events:all; }
.fmodal { background:#fff; border-radius:var(--radius); width:100%; max-width:720px; padding:28px; margin:auto; }
.fmodal h3 { font-size:17px; font-weight:700; color:var(--primary); margin-bottom:20px; padding-bottom:12px; border-bottom:1px solid var(--border); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-row-3 { display:grid; grid-template-columns:1fr 1fr 1fr; gap:14px; }
.fmodal .form-group label { font-size:10px; font-weight:700; color:var(--text-light); text-transform:uppercase; letter-spacing:.7px; margin-bottom:4px; display:block; }
.fmodal .form-group input,
.fmodal .form-group select,
.fmodal .form-group textarea { width:100%; padding:9px 12px; border:1.5px solid var(--border); border-radius:6px; font-family:'DM Sans',sans-serif; font-size:13px; outline:none; transition:border-color .2s; }
.fmodal .form-group input:focus,
.fmodal .form-group select:focus,
.fmodal .form-group textarea:focus { border-color:var(--primary); }
.fmodal .form-group textarea { resize:vertical; min-height:90px; }
.fmodal-actions { display:flex; gap:9px; justify-content:flex-end; margin-top:20px; padding-top:16px; border-top:1px solid var(--border); }
.btn-save { background:var(--primary); color:#fff; border:none; padding:11px 24px; border-radius:6px; font-family:'DM Sans',sans-serif; font-size:13px; font-weight:700; cursor:pointer; }
.btn-cancel { background:#eaecef; color:var(--text); border:none; padding:11px 24px; border-radius:6px; font-family:'DM Sans',sans-serif; font-size:13px; font-weight:600; cursor:pointer; }
.img-previews { display:flex; flex-wrap:wrap; gap:7px; margin-top:8px; }
.img-previews .img-prev-item { position:relative; }
.img-previews img { width:72px; height:54px; object-fit:cover; border-radius:4px; border:2px solid var(--border); }
.img-previews .del-img { position:absolute; top:-5px; right:-5px; width:18px; height:18px; background:#e74c3c; color:#fff; border:none; border-radius:50%; font-size:10px; cursor:pointer; display:flex; align-items:center; justify-content:center; }

/* Estrella de portada */
.star-btn { position:absolute; top:3px; right:3px; width:22px; height:22px; background:rgba(255,255,255,.9); border:none; border-radius:50%; cursor:pointer; display:flex; align-items:center; justify-content:center; font-size:12px; color:#222; box-shadow:0 1px 4px rgba(0,0,0,.25); transition:transform .15s,color .15s; padding:0; z-index:2; }
.star-btn:hover { transform:scale(1.15); }
.star-btn.active { color:#f5b50a; }
.img-prev-item, .eimg { position:relative; }
.existing-imgs { display:flex; flex-wrap:wrap; gap:7px; margin-bottom:8px; }
.existing-imgs .eimg { position:relative; }
.existing-imgs img { width:72px; height:54px; object-fit:cover; border-radius:4px; border:2px solid var(--border); }
.existing-imgs .del-eimg { position:absolute; top:-5px; right:-5px; width:18px; height:18px; background:#e74c3c; color:#fff; border:none; border-radius:50%; font-size:10px; cursor:pointer; display:flex; align-items:center; justify-content:center; }
.set-principal { position:absolute; bottom:2px; left:2px; background:rgba(0,0,0,.6); color:#fff; font-size:9px; border:none; border-radius:3px; cursor:pointer; padding:1px 4px; }

/* ── MESSAGES / BADGES ───────────────────────── */
.badge-unread { background:var(--accent); color:#fff; border-radius:10px; font-size:10px; font-weight:700; padding:2px 7px; margin-left:6px; }
.msg-preview { font-size:12px; color:var(--text-light); max-width:300px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.msg-unread td { font-weight:600; background:#fffdf5; }
.msg-detail { white-space:pre-wrap; font-size:13px; color:var(--text); line-height:1.7; }

/* ── NO RESULTS / LOADING ────────────────────── */
.no-results { text-align:center; padding:55px 20px; color:var(--text-light); }
.no-results i { font-size:44px; color:var(--border); display:block; margin-bottom:14px; }
.no-results p { font-size:14px; }
.loading-box { text-align:center; padding:40px; color:var(--text-light); font-size:13px; }
.spinner { width:36px; height:36px; border:3px solid var(--border); border-top-color:var(--primary); border-radius:50%; animation:spin .7s linear infinite; margin:0 auto 12px; }
@keyframes spin { to{transform:rotate(360deg)} }

/* ── FOOTER ──────────────────────────────────── */
footer { background:linear-gradient(120deg,#0a0e1a 0%,#141029 45%,#241430 75%,#2c1526 100%); color:rgba(255,255,255,.7); padding:50px 0 18px; }
.footer-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:28px; margin-bottom:36px; }
.footer-col h4 { color:#fff; font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:1.5px; margin-bottom:16px; padding-bottom:9px; border-bottom:2px solid rgba(255,255,255,.15); }
.footer-logo { display:flex; align-items:center; gap:10px; margin-bottom:12px; }
.footer-logo img { width:38px; height:48px; object-fit:contain; filter:brightness(10); }
.footer-logo .fone { font-size:20px; font-weight:800; color:#fff; }
.footer-logo .fsub { font-size:9px; color:rgba(255,255,255,.55); text-transform:uppercase; letter-spacing:1px; }
.footer-col p { font-size:12px; line-height:1.8; }
.footer-col ul { list-style:none; }
.footer-col ul li { margin-bottom:7px; }
.footer-col ul li a { color:rgba(255,255,255,.7); font-size:12px; transition:color .2s; }
.footer-col ul li a:hover { color:#fff; }
.footer-contact-item { display:flex; gap:11px; align-items:center; margin-bottom:13px; font-size:12px; }
.footer-contact-item i { color:rgba(255,255,255,.85); flex-shrink:0; width:34px; height:34px; background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.08); border-radius:9px; display:flex; align-items:center; justify-content:center; font-size:14px; }
.footer-socials { display:flex; gap:8px; margin-top:12px; }
.footer-socials a { width:32px; height:32px; background:rgba(255,255,255,.12); border-radius:50%; display:flex; align-items:center; justify-content:center; color:#fff; font-size:13px; transition:background .2s; }
.footer-socials a:hover { background:var(--accent); }
.footer-bottom { border-top:1px solid rgba(255,255,255,.1); padding-top:16px; text-align:center; font-size:11px; color:rgba(255,255,255,.4); }

/* ── TOAST ───────────────────────────────────── */
.toast-container { position:fixed; top:22px; left:50%; transform:translateX(-50%); z-index:5000; display:flex; flex-direction:column; gap:10px; align-items:center; pointer-events:none; }
.toast { min-width:300px; max-width:460px; padding:15px 20px; border-radius:11px; color:#fff; font-size:14px; font-weight:600; box-shadow:0 8px 30px rgba(0,0,0,.22); display:flex; align-items:center; gap:11px; animation:toastIn .3s ease; pointer-events:all; }
.toast.success { background:#27ae60; }
.toast.error   { background:#e74c3c; }
.toast i { font-size:20px; flex-shrink:0; }
.toast.hide { opacity:0; transform:translateY(-14px); transition:all .32s ease; }
@keyframes toastIn { from{opacity:0; transform:translateY(-14px);} to{opacity:1; transform:translateY(0);} }
@media (max-width:480px){ .toast { min-width:0; width:calc(100vw - 32px); } }

/* ── WHATSAPP FLOAT ──────────────────────────── */
.whatsapp-float { position:fixed; bottom:24px; right:24px; width:56px; height:56px; background:var(--whatsapp); color:#fff; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:28px; box-shadow:0 4px 18px rgba(37,211,102,.5); z-index:1500; transition:transform .2s,box-shadow .2s; }
.whatsapp-float:hover { transform:scale(1.1); box-shadow:0 6px 22px rgba(37,211,102,.65); color:#fff; }
@media (max-width:480px) { .whatsapp-float { width:50px; height:50px; font-size:25px; bottom:18px; right:18px; } }

/* ── RESPONSIVE ──────────────────────────────── */
@media (max-width:1024px) {
  .properties-grid { grid-template-columns:repeat(2,1fr); }
  .services-grid   { grid-template-columns:repeat(2,1fr); }
  .team-grid       { grid-template-columns:repeat(2,1fr); }
  .footer-grid     { grid-template-columns:repeat(2,1fr); }
  .stats-grid      { grid-template-columns:repeat(2,1fr); }
  .modal-info-wrap { grid-template-columns:1fr; }
  .modal-feats     { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:900px) {
  /* Filtro vuelve a acordeón arriba en móvil/tablet */
  .props-layout { flex-direction:column; }
  .props-main { order:2; width:100%; }
  .props-filter-col { width:100%; order:1; position:static; }
  .filter-toggle { display:flex; }
  .filter-desktop-title { display:none; }
  .props-filter-col .filter-body { display:none; }
  .props-filter-col .filter-body.open { display:block; }
  .props-filter-col .filter-grid { grid-template-columns:repeat(auto-fill,minmax(150px,1fr)); }
  .props-filter-col .filter-group select { width:100%; }
  .props-filter-col .filter-actions { display:flex; }
}

@media (max-width:768px) {
  .top-bar .container { justify-content:center; }
  .main-header .container { flex-wrap:wrap; gap:10px; }
  .header-search { order:3; max-width:100%; flex:0 0 100%; min-width:unset; }
  .header-actions { margin-left:0; }
  .hero { height:440px; }
  .services-grid { grid-template-columns:1fr; }
  .properties-grid { grid-template-columns:1fr; }
  .team-grid { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr 1fr; }
  .contact-grid { grid-template-columns:1fr; }
  .panel-layout { flex-direction:column; }
  .panel-sidebar { width:100%; }
  .panel-sidebar ul { display:flex; overflow-x:auto; padding:5px 0; }
  .panel-sidebar ul li a { white-space:nowrap; padding:9px 14px; }
  .form-row, .form-row-3 { grid-template-columns:1fr; }
  .navbar ul { display:none; flex-direction:column; background:#fff; width:100%; }
  .navbar ul li a { text-align:center; border-bottom:1px solid var(--border); }
  .navbar ul.open { display:flex; }
  .hamburger { display:flex; }
  .navbar .container { justify-content:center; min-height:48px; flex-wrap:wrap; }
  .nearby-grid { grid-template-columns:1fr; }
}
@media (max-width:480px) {
  .footer-grid { grid-template-columns:1fr; }
  .stats-grid  { grid-template-columns:repeat(2,1fr); }
  .hero-content h1 { font-size:24px; }
  .modal-feats { grid-template-columns:repeat(2,1fr); }
  .fmodal { padding:18px 14px; }
}
