/* ===== INMAN REAL ESTATE — site.css ===== */
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --azul:#1a3a5c;--azul2:#1e5799;--oro:#c9a84c;--gris:#f5f5f5;--gris2:#e8e8e8;
  --texto:#222;--texto2:#555;--blanco:#fff;--sombra:0 2px 12px rgba(0,0,0,.1);
}
body{font-family:'Segoe UI',system-ui,sans-serif;color:var(--texto);background:#fff;font-size:15px;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%}

/* HEADER */
.site-header{background:var(--azul);color:#fff;padding:0 20px;display:flex;align-items:center;justify-content:space-between;height:70px;position:sticky;top:0;z-index:100;box-shadow:0 2px 8px rgba(0,0,0,.3)}
.site-logo img{height:48px;object-fit:contain}
.site-logo span{font-size:20px;font-weight:700;color:#fff;letter-spacing:-.5px}
.header-phone{font-size:14px;color:rgba(255,255,255,.85)}
.header-phone strong{color:#fff;font-size:16px}
.btn-contacto{background:var(--oro);color:#fff;border:none;padding:10px 20px;border-radius:4px;font-weight:700;cursor:pointer;font-size:14px;white-space:nowrap}
.btn-contacto:hover{background:#b8943e}

/* NAV */
.main-nav{background:var(--azul2);padding:0 20px}
.main-nav ul{display:flex;list-style:none;gap:0}
.main-nav a{display:block;padding:12px 18px;color:rgba(255,255,255,.85);font-size:14px;font-weight:500;transition:background .2s}
.main-nav a:hover,.main-nav a.active{background:rgba(255,255,255,.15);color:#fff}

/* HERO */
.hero{background:linear-gradient(135deg,var(--azul) 0%,var(--azul2) 100%);padding:60px 20px;text-align:center;color:#fff}
.hero h1{font-size:clamp(24px,4vw,42px);font-weight:800;margin-bottom:12px;line-height:1.2}
.hero p{font-size:16px;color:rgba(255,255,255,.8);margin-bottom:32px;max-width:600px;margin-left:auto;margin-right:auto}

/* SEARCH BOX */
.search-box{background:#fff;border-radius:8px;padding:20px;max-width:900px;margin:0 auto;box-shadow:0 4px 20px rgba(0,0,0,.2);display:grid;grid-template-columns:1fr 1fr 1fr 1fr auto;gap:12px;align-items:end}
.search-field label{display:block;font-size:12px;font-weight:600;color:var(--texto2);margin-bottom:5px}
.search-field select,.search-field input{width:100%;padding:10px 12px;border:1px solid var(--gris2);border-radius:4px;font-size:14px;color:var(--texto);background:#fff}
.btn-buscar{background:var(--azul);color:#fff;border:none;padding:11px 24px;border-radius:4px;font-weight:700;cursor:pointer;font-size:14px;white-space:nowrap;height:40px}
.btn-buscar:hover{background:var(--azul2)}

/* STATS BAR */
.stats-bar{background:var(--gris);padding:16px 20px;display:flex;justify-content:center;gap:40px;flex-wrap:wrap}
.stat-item{text-align:center}
.stat-num{font-size:28px;font-weight:800;color:var(--azul)}
.stat-label{font-size:12px;color:var(--texto2);font-weight:600;text-transform:uppercase;letter-spacing:.5px}

/* CONTAINER */
.container{max-width:1200px;margin:0 auto;padding:0 20px}
.section{padding:48px 0}
.section-title{font-size:24px;font-weight:800;color:var(--azul);margin-bottom:8px}
.section-sub{color:var(--texto2);margin-bottom:28px;font-size:14px}

/* FILTROS */
.filtros-bar{background:var(--gris);padding:16px 20px;border-radius:8px;margin-bottom:24px;display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.filtros-bar select,.filtros-bar input{padding:8px 12px;border:1px solid var(--gris2);border-radius:4px;font-size:13px;background:#fff}
.filtro-label{font-size:13px;font-weight:600;color:var(--texto2)}
.btn-limpiar{background:none;border:1px solid var(--gris2);padding:8px 14px;border-radius:4px;font-size:13px;cursor:pointer;color:var(--texto2)}
.btn-limpiar:hover{background:var(--gris2)}
.results-count{margin-left:auto;font-size:13px;color:var(--texto2);font-weight:600}

/* GRID DE PROPIEDADES */
.props-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}
.prop-card{background:#fff;border-radius:8px;overflow:hidden;box-shadow:var(--sombra);transition:transform .2s,box-shadow .2s;cursor:pointer}
.prop-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,.15)}
.prop-img{position:relative;height:200px;overflow:hidden;background:var(--gris)}
.prop-img img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.prop-card:hover .prop-img img{transform:scale(1.05)}
.prop-badge{position:absolute;top:10px;left:10px;background:var(--azul);color:#fff;font-size:11px;font-weight:700;padding:4px 10px;border-radius:3px;text-transform:uppercase}
.prop-badge.alquiler{background:#2e7d32}
.prop-badge.traspaso{background:#6a1b9a}
.prop-fotos{position:absolute;bottom:10px;right:10px;background:rgba(0,0,0,.6);color:#fff;font-size:11px;padding:3px 8px;border-radius:3px}
.prop-body{padding:16px}
.prop-tipo{font-size:11px;font-weight:700;color:var(--azul2);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}
.prop-titulo{font-size:15px;font-weight:700;color:var(--texto);margin-bottom:6px;line-height:1.3}
.prop-ubicacion{font-size:13px;color:var(--texto2);margin-bottom:12px;display:flex;align-items:center;gap:4px}
.prop-precio{font-size:22px;font-weight:800;color:var(--azul);margin-bottom:12px}
.prop-precio span{font-size:13px;font-weight:400;color:var(--texto2)}
.prop-features{display:flex;gap:12px;flex-wrap:wrap}
.prop-feat{font-size:12px;color:var(--texto2);display:flex;align-items:center;gap:3px}
.prop-ref{font-size:11px;color:#aaa;margin-top:10px}

/* FICHA DETALLE */
.ficha-header{background:var(--azul);color:#fff;padding:20px;border-radius:8px 8px 0 0}
.ficha-precio{font-size:32px;font-weight:800;color:var(--oro)}
.ficha-imgs{display:grid;grid-template-columns:2fr 1fr;gap:8px;margin-bottom:24px;border-radius:8px;overflow:hidden;max-height:420px}
.ficha-imgs img{width:100%;height:100%;object-fit:cover}
.ficha-imgs .img-main{grid-row:1/3}
.ficha-data{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:20px 0}
.ficha-dato{background:var(--gris);padding:14px;border-radius:6px}
.ficha-dato-label{font-size:11px;font-weight:700;color:var(--texto2);text-transform:uppercase;margin-bottom:4px}
.ficha-dato-val{font-size:18px;font-weight:700;color:var(--azul)}
.ficha-desc{line-height:1.7;color:var(--texto2);margin:16px 0}
.ficha-portales{display:flex;gap:8px;flex-wrap:wrap;margin:16px 0}
.portal-badge{padding:6px 14px;border-radius:4px;font-size:12px;font-weight:700;color:#fff}
.portal-badge.fotocasa{background:#e8001c}
.portal-badge.habitaclia{background:#f26522}
.portal-badge.milanuncios{background:#0072bc}

/* SIDEBAR FICHA */
.ficha-layout{display:grid;grid-template-columns:1fr 320px;gap:24px;align-items:start}
.ficha-layout > *:first-child{min-width:0;overflow:hidden}
.ficha-sidebar{position:sticky;top:80px}
.contact-card{background:#fff;border:1px solid var(--gris2);border-radius:8px;padding:20px;box-shadow:var(--sombra)}
.contact-card h3{font-size:16px;font-weight:700;color:var(--azul);margin-bottom:16px}
.contact-phone{display:block;background:var(--azul);color:#fff;padding:12px;border-radius:5px;text-align:center;font-weight:700;font-size:16px;margin-bottom:10px}
.contact-phone:hover{background:var(--azul2)}
.btn-whatsapp{display:block;background:#25d366;color:#fff;padding:12px;border-radius:5px;text-align:center;font-weight:700;font-size:14px;margin-bottom:10px}
.btn-whatsapp:hover{background:#1da851}
.btn-ia{display:block;background:var(--oro);color:#fff;padding:12px;border-radius:5px;text-align:center;font-weight:700;font-size:14px;cursor:pointer;border:none;width:100%}
.btn-ia:hover{background:#b8943e}

/* CATEGORIAS */
.cat-grid{display:grid;grid-auto-flow:column;grid-auto-columns:1fr;gap:12px;overflow-x:auto}
.cat-card{background:var(--azul);color:#fff;border-radius:8px;padding:16px 10px;text-align:center;cursor:pointer;transition:background .2s;min-width:110px}
.cat-card:hover{background:var(--azul2)}
.cat-icon{font-size:26px;margin-bottom:6px}
.cat-nombre{font-weight:700;font-size:13px;line-height:1.2}
.cat-count{font-size:11px;opacity:.8;margin-top:3px}

/* FOOTER */
footer{background:var(--azul);color:rgba(255,255,255,.8);padding:40px 20px 20px}
.footer-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;max-width:1200px;margin:0 auto 28px}
footer h4{color:#fff;font-size:14px;margin-bottom:14px}
footer p,footer a{font-size:13px;line-height:1.8}
footer a:hover{color:#fff}
.footer-bottom{text-align:center;font-size:12px;padding-top:20px;border-top:1px solid rgba(255,255,255,.15);max-width:1200px;margin:0 auto}
.social-links{display:flex;gap:12px;margin-top:10px}
.social-links a{background:rgba(255,255,255,.15);padding:6px 12px;border-radius:4px;font-size:13px;color:#fff}
.social-links a:hover{background:rgba(255,255,255,.3)}

/* PAGINACIÓN */
.paginacion{display:flex;justify-content:center;gap:6px;margin-top:36px;flex-wrap:wrap}
.paginacion button{padding:8px 14px;border:1px solid var(--gris2);background:#fff;border-radius:4px;cursor:pointer;font-size:14px}
.paginacion button.active{background:var(--azul);color:#fff;border-color:var(--azul)}
.paginacion button:hover:not(.active){background:var(--gris)}

/* MAPA PLACEHOLDER */
.mapa-placeholder{background:var(--gris);border-radius:8px;padding:40px;text-align:center;color:var(--texto2);margin:20px 0}

/* NO RESULTS */
.no-results{text-align:center;padding:60px 20px;color:var(--texto2)}
.no-results .emoji{font-size:48px;margin-bottom:12px}

/* RESPONSIVE — pantallas medias */
@media(max-width:1024px){
  .ficha-layout{grid-template-columns:1fr 280px;gap:16px}
}

/* RESPONSIVE — móvil */
@media(max-width:768px){
  .search-box{grid-template-columns:1fr 1fr;gap:10px}
  .search-box .btn-buscar{grid-column:1/-1}
  .stats-bar{gap:20px}
  .props-grid{grid-template-columns:1fr}
  .ficha-layout{grid-template-columns:1fr}
  .ficha-imgs{grid-template-columns:1fr;max-height:280px}
  .ficha-imgs .img-main{grid-row:auto}
  .footer-grid{grid-template-columns:1fr}
  .main-nav ul{flex-wrap:wrap}
  .main-nav a{padding:10px 12px;font-size:13px}
}
