*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial;color:#111;background:#fff}
a{color:inherit;text-decoration:none}

.header{
  position:sticky;top:0;z-index:10;
  display:flex;align-items:center;gap:16px;
  padding:14px 18px;background:#fff;border-bottom:1px solid #eee
}
.brand{font-weight:900;letter-spacing:.2px}
.nav{display:flex;gap:10px;flex:1;flex-wrap:wrap;align-items:center}
.nav a{padding:8px 10px;border-radius:10px}
.nav a:hover{background:#f2f2f2}
.nav-cta{border:1px solid #111;background:#111;color:#fff}

.tools{display:flex;gap:10px;align-items:center}
select{padding:8px 10px;border:1px solid #ddd;border-radius:10px;background:#fff}
.burger{display:none;padding:8px 10px;border:1px solid #ddd;border-radius:10px;background:#fff}

.hero{
  padding:56px 18px;
  background:linear-gradient(180deg,#f4f7f5,#fff);
}
.hero-inner{max-width:1100px;margin:0 auto}
.hero h1{margin:0 0 10px;font-size:clamp(28px,4vw,46px)}
.hero p{margin:0 0 18px;color:#333;max-width:780px}
.cta{display:flex;gap:12px;flex-wrap:wrap}

.btn{display:inline-block;padding:12px 14px;border:1px solid #ddd;border-radius:14px}
.btn.primary{border-color:#111;background:#111;color:#fff}

.section{max-width:1100px;margin:0 auto;padding:34px 18px}
.section-head{display:flex;justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:14px}
.section h2{margin:0;font-size:22px}
.link{color:#0b5;font-weight:800}

.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.card{border:1px solid #eee;border-radius:18px;overflow:hidden;background:#fff}
.thumb{height:170px;background:#e9efe9}
.card-body{padding:14px}
.card-body h3{margin:0 0 8px;font-size:18px}
.card-body p{margin:0 0 10px;color:#333;line-height:1.35}
.badges{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0}
.badge{display:inline-block;padding:4px 8px;border:1px solid #ddd;border-radius:999px;font-size:12px;color:#444}
.price{font-weight:900;margin:8px 0 10px}
.muted{color:#666;font-size:14px}

.footer{border-top:1px solid #eee;padding:18px}
.footer-inner{max-width:1100px;margin:0 auto;display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}
.footer-right{color:#333}
.footer-note{max-width:1100px;margin:10px auto 0;color:#555;font-size:13px;padding:0 18px}

@media (max-width:860px){
  .nav{display:none}
  .burger{display:inline-block}
  .grid{grid-template-columns:1fr}
}
/* =========================
   Estilos extra para filtros + leadbox
========================= */
.filters{display:flex;gap:10px;flex-wrap:wrap;margin:12px 0 16px}
.input{padding:10px 12px;border:1px solid #ddd;border-radius:12px;min-width:220px}
.leadbox{
  margin-top:18px;padding:16px;border:1px solid rgba(0,187,85,.25);
  border-radius:18px;display:flex;justify-content:space-between;gap:12px;align-items:center;flex-wrap:wrap;
  background:linear-gradient(180deg, rgba(0,187,85,.06), rgba(0,0,0,0));
}
/* =========================
   PROPERTY DETAIL PAGE
========================= */
.detail{
  display:grid;
  grid-template-columns: 2fr 1fr;
  gap:16px;
  align-items:start;
}
.detail-hero{
  height:320px;
  border:1px solid #eee;
  border-radius:18px;
  background:#e9efe9;
  margin-bottom:14px;
}
.box{
  border:1px solid #eee;
  border-radius:18px;
  padding:14px;
  background:#fff;
  margin-bottom:14px;
}

@media (max-width:860px){
  .detail{grid-template-columns:1fr}
  .detail-hero{height:220px}
}
/* =========================
   CONTACT PAGE
========================= */
.contact-grid{
  display:grid;
  grid-template-columns: 2fr 1fr;
  gap:16px;
  align-items:start;
}
.form{
  border:1px solid #eee;
  border-radius:18px;
  padding:14px;
  background:#fff;
}
.label{display:block;margin:12px 0 6px;font-weight:700}
.textarea{
  width:100%;
  padding:10px 12px;
  border:1px solid #ddd;
  border-radius:12px;
  resize:vertical;
}
.mini{margin-top:14px}
@media (max-width:860px){
  .contact-grid{grid-template-columns:1fr}
}
/* =========================
   LOGO
========================= */

.logo{
  height:75px;
  width:auto;
}

.brand{
  display:flex;
  align-items:center;
}

/* =========================
   HEADER
========================= */

.header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:12px 20px;
  background:white;
  box-shadow:0 2px 8px rgba(0,0,0,0.05);
}
/* =========================
galeria
========================= */

.gallery{
 display:grid;
 grid-template-columns:repeat(4,1fr);
 gap:10px;
 margin-top:15px;
}

.gallery .thumb{
 height:90px;
 border-radius:10px;
}
.map{
  width:100%;
  height:260px;
  border:0;
  border-radius:16px;
}
