*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body { min-height: 100vh; line-height: 1.6; -webkit-font-smoothing: antialiased; }
img, picture, video, canvas, svg { display: block; max-width: 100%; height: auto; }
input, button, textarea, select { font: inherit; color: inherit; }
button { cursor: pointer; background: none; border: none; }
p, h1, h2, h3, h4, h5, h6 { overflow-wrap: break-word; }
ul[role="list"], ol[role="list"] { list-style: none; padding: 0; }
a { color: inherit; }
:focus-visible { outline: 3px solid var(--color-primary); outline-offset: 2px; }
@media (prefers-reduced-motion: reduce) {
html { scroll-behavior: auto; }
*, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
}:root { --color-primary: #2f6f4f;
--color-primary-dark: #1f4d36;
--color-accent: #d4a017;
--color-rent: #9a6700; --color-whatsapp: #25d366;
--color-ink: #1e2a23;
--color-muted: #5d6b63;
--color-line: #e2e6e3;
--color-surface: #ffffff;
--color-bg: #f6f7f5; --font-base: system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
--font-heading: Georgia, "Times New Roman", serif;
--fs-small: .875rem;
--fs-base: 1rem;
--fs-medium: 1.25rem;
--fs-large: 1.75rem;
--fs-xlarge: 2.5rem;
--fs-hero: clamp(2.25rem, 5vw, 3.75rem); --sp-xs: .5rem;
--sp-s: 1rem;
--sp-m: 1.5rem;
--sp-l: 2.5rem;
--sp-xl: 4rem; --container: 1200px;
--radius: 12px;
--radius-sm: 8px;
--shadow: 0 2px 8px rgba(30, 42, 35, .08);
--shadow-lg: 0 8px 28px rgba(30, 42, 35, .14);
--header-h: 72px;
--transition: .2s ease;
}body {
font-family: var(--font-base);
font-size: var(--fs-base);
color: var(--color-ink);
background: var(--color-bg);
}
h1, h2, h3, h4 { font-family: var(--font-heading); line-height: 1.2; color: var(--color-ink); }
h1 { font-size: var(--fs-xlarge); }
h2 { font-size: var(--fs-large); }
h3 { font-size: var(--fs-medium); }
p { margin-bottom: var(--sp-s); }
a { text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--color-primary-dark); }
small, .text-small { font-size: var(--fs-small); }
strong { font-weight: 700; }
.section__title { font-size: var(--fs-large); margin-bottom: var(--sp-m); }
.page-title { font-size: var(--fs-xlarge); margin-bottom: var(--sp-m); } .prop-descripcion, .page-content__body { max-width: 70ch; }
.prop-descripcion p, .page-content__body p { color: var(--color-muted); }.container { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: var(--sp-s); }
.site-main { min-height: 50vh; }
.section { padding-block: var(--sp-xl); }
.section--destacadas { background: var(--color-surface); }
.section__head { display: flex; align-items: baseline; justify-content: space-between; gap: var(--sp-s); margin-bottom: var(--sp-m); flex-wrap: wrap; }
.grid-propiedades {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
gap: var(--sp-m);
}
.link-more { color: var(--color-primary); font-weight: 600; }
.link-more:hover { color: var(--color-primary-dark); }
.tf-vacio { color: var(--color-muted); padding: var(--sp-l) 0; text-align: center; } .screen-reader-text {
position: absolute !important; width: 1px; height: 1px;
padding: 0; margin: -1px; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}
.skip-link {
position: absolute; left: -999px; top: 0; z-index: 1000;
background: var(--color-primary); color: #fff; padding: var(--sp-xs) var(--sp-s);
}
.skip-link:focus { left: var(--sp-s); top: var(--sp-s); } .pagination, .nav-links {
display: flex; gap: var(--sp-xs); flex-wrap: wrap; justify-content: center;
margin-top: var(--sp-l);
}
.pagination .page-numbers {
display: inline-flex; min-width: 42px; height: 42px; align-items: center; justify-content: center;
padding: 0 var(--sp-xs); border: 1px solid var(--color-line); border-radius: var(--radius-sm);
background: var(--color-surface); color: var(--color-ink);
}
.pagination .page-numbers.current { background: var(--color-primary); color: #fff; border-color: var(--color-primary); }
.pagination a.page-numbers:hover { border-color: var(--color-primary); } .breadcrumb { font-size: var(--fs-small); color: var(--color-muted); margin-bottom: var(--sp-s); display: flex; gap: .4rem; flex-wrap: wrap; }
.breadcrumb a { color: var(--color-primary); } .archive-layout { display: grid; grid-template-columns: 1fr; gap: var(--sp-l); padding-block: var(--sp-l); }
@media (min-width: 960px) {
.archive-layout { grid-template-columns: 300px 1fr; align-items: start; }
.archive-filtros { position: sticky; top: calc(var(--header-h) + var(--sp-s)); }
}.site-header {
position: sticky; top: 0; z-index: 100;
background: var(--color-surface);
border-bottom: 1px solid var(--color-line);
}
.site-header__inner {
max-width: var(--container); margin-inline: auto;
min-height: var(--header-h);
display: flex; align-items: center; justify-content: space-between;
padding-inline: var(--sp-s); gap: var(--sp-s);
}
.site-logo img,
.custom-logo { height: 44px; width: auto; display: block; }
.custom-logo-link { display: inline-block; line-height: 0; }
.site-nav { display: flex; align-items: center; gap: var(--sp-m); }
.site-nav .menu { display: flex; gap: var(--sp-m); list-style: none; padding: 0; margin: 0; align-items: center; }
.site-nav .menu a { font-weight: 600; color: var(--color-ink); padding: var(--sp-xs) 0; }
.site-nav .menu a:hover, .site-nav .menu .current-menu-item > a { color: var(--color-primary); }
.nav-toggle { display: none; flex-direction: column; gap: 5px; padding: var(--sp-xs); }
.nav-toggle__bar { width: 26px; height: 3px; background: var(--color-ink); border-radius: 2px; transition: transform var(--transition), opacity var(--transition); transform-origin: center; } .nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(1) { transform: translateY(8px)  rotate(45deg);  }
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }
@media (max-width: 860px) {
.nav-toggle { display: flex; } .site-header__brand,
.nav-toggle { position: relative; z-index: 2; } .site-nav {
position: fixed; top: 0; left: 0; right: 0;
z-index: 1; flex-direction: column; align-items: stretch;
background: var(--color-surface);
padding: calc(var(--header-h) + var(--sp-m)) var(--sp-m) var(--sp-m);
border-bottom: 1px solid var(--color-line);
transform: translateY(-100%);
transition: transform var(--transition);
box-shadow: var(--shadow-lg);
}
.site-nav.is-open { transform: translateY(0); }
.site-nav .menu { flex-direction: column; align-items: stretch; gap: var(--sp-s); }
.site-nav__cta { text-align: center; }
body.nav-open { overflow: hidden; }
}.site-footer { background: var(--color-ink); color: #cfd8d2; margin-top: var(--sp-xl); }
.cta-whatsapp-banda + .site-footer { margin-top: 0; }
.site-footer__inner {
max-width: var(--container); margin-inline: auto; padding: var(--sp-xl) var(--sp-s) var(--sp-l);
display: grid; gap: var(--sp-l);
grid-template-columns: 1fr;
}
@media (min-width: 720px) {
.site-footer__inner { grid-template-columns: 2fr 1fr 1fr; }
}
.site-footer__title { color: #fff; font-size: var(--fs-medium); margin-bottom: var(--sp-xs); }
.site-footer h3 { color: #fff; font-size: var(--fs-base); margin-bottom: var(--sp-s); text-transform: uppercase; letter-spacing: .04em; }
.site-footer a { color: #cfd8d2; }
.site-footer a:hover { color: #fff; }
.site-footer .menu,
.site-footer__contacto { list-style: none; padding: 0; margin: 0; display: grid; gap: var(--sp-xs); }
.site-footer__bottom {
border-top: 1px solid rgba(255,255,255,.12);
text-align: center; padding: var(--sp-s); font-size: var(--fs-small);
}
.site-footer__bottom p { margin: 0; }.btn {
display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
padding: .7rem 1.4rem; border-radius: var(--radius-sm);
font-weight: 700; line-height: 1; text-align: center;
border: 2px solid transparent; transition: var(--transition);
}
.btn--primary { background: var(--color-primary); color: #fff; }
.btn--primary:hover { background: var(--color-primary-dark); color: #fff; }
.btn--secondary { background: transparent; color: var(--color-primary); border-color: var(--color-primary); }
.btn--secondary:hover { background: var(--color-primary); color: #fff; }
.btn--whatsapp { background: var(--color-whatsapp); color: #fff; }
.btn--whatsapp:hover { background: #1da851; color: #fff; }
.btn--lg { padding: 1rem 2rem; font-size: var(--fs-medium); }
.btn--block { display: flex; width: 100%; } .badge {
display: inline-block; padding: .3rem .75rem; border-radius: 999px;
font-size: var(--fs-small); font-weight: 700; line-height: 1;
letter-spacing: .02em; color: #fff; box-shadow: 0 1px 4px rgba(15, 22, 18, .35);
}
.badge--venta { background: var(--color-primary); color: #fff; }
.badge--alquiler { background: var(--color-rent); color: #fff; }label { font-weight: 600; font-size: var(--fs-small); display: block; margin-bottom: .35rem; }
input, select, textarea {
width: 100%; padding: .65rem .8rem;
border: 1px solid var(--color-line); border-radius: var(--radius-sm);
background: var(--color-surface); color: var(--color-ink);
transition: border-color var(--transition);
}
input:focus, select:focus, textarea:focus { border-color: var(--color-primary); outline-offset: 1px; }
select { appearance: none; background-image: linear-gradient(45deg, transparent 50%, var(--color-muted) 50%), linear-gradient(135deg, var(--color-muted) 50%, transparent 50%); background-position: calc(100% - 18px) 1.1rem, calc(100% - 12px) 1.1rem; background-size: 6px 6px; background-repeat: no-repeat; padding-right: 2.2rem; } .buscador { background: var(--color-surface); border-radius: var(--radius); padding: var(--sp-m); box-shadow: var(--shadow); }
.buscador label { color: var(--color-ink); }
.buscador__row { display: grid; gap: var(--sp-s); grid-template-columns: 1fr; align-items: end; }
@media (min-width: 720px) {
.hero-home .buscador__row { grid-template-columns: repeat(4, 1fr); }
}
.buscador__submit { height: 46px; width: 100%; grid-column: 1 / -1; }
.buscador__limpiar { display: inline-block; margin-top: var(--sp-s); color: var(--color-muted); font-size: var(--fs-small); text-decoration: underline; }
.buscador__field.is-advanced { display: none; }
.buscador.show-advanced .buscador__field.is-advanced { display: block; }
.buscador__advanced-toggle-wrapper { grid-column: 1 / -1; display: flex; justify-content: flex-end; margin-top: var(--sp-xs); margin-bottom: var(--sp-xs); }
.btn-toggle-advanced { background: transparent; border: none; padding: 0; font-size: var(--fs-small); color: var(--color-ink); text-decoration: underline; cursor: pointer; font-weight: 700; font-family: inherit; } .buscador__precio-group { display: flex; }
.buscador__precio-group select.buscador__moneda { 
width: auto; 
min-width: 65px;
border-top-right-radius: 0; 
border-bottom-right-radius: 0; 
border-right: 0; 
}
.buscador__precio-group input#b-precio { 
flex: 1; 
border-top-left-radius: 0; 
border-bottom-left-radius: 0; 
}
.buscador__precio-group select.buscador__moneda:focus {
z-index: 1;
border-right: 1px solid var(--color-primary);
} .search-form { display: flex; gap: var(--sp-xs); }
.search-form__input { flex: 1; }
.search-form__btn { background: var(--color-primary); color: #fff; padding: .65rem 1.2rem; border-radius: var(--radius-sm); font-weight: 700; } .alertas-form {
background: var(--color-primary); color: #fff;
border-radius: var(--radius); padding: var(--sp-l);
display: grid; gap: var(--sp-m); grid-template-columns: 1fr;
}
@media (min-width: 860px) { .alertas-form { grid-template-columns: 1fr 1.4fr; align-items: center; } }
.alertas-form h2 { color: #fff; }
.alertas-form__text p { color: rgba(255,255,255,.85); margin: 0; }
.alertas-form__form { display: grid; gap: var(--sp-s); grid-template-columns: 1fr 1fr; }
.alertas-form__form .btn { grid-column: 1 / -1; }
.alertas-form label { color: rgba(255,255,255,.9); }
@media (max-width: 560px) { .alertas-form__form { grid-template-columns: 1fr; } }.card-propiedad {
background: var(--color-surface);
border: 1px solid var(--color-line);
border-radius: var(--radius);
overflow: hidden;
display: flex; flex-direction: column;
transition: transform var(--transition), box-shadow var(--transition);
}
.card-propiedad:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.card-propiedad--destacada { border-color: var(--color-accent); } .card-propiedad__image {
position: relative; display: block;
height: 240px; max-height: 240px;
overflow: hidden;
background: var(--color-bg);
}
.card-propiedad__image img,
.card-propiedad__image .custom-logo,
.card-propiedad__image picture {
display: block;
width: 100%; height: 100%; max-height: 100%;
object-fit: cover;
}
.card-propiedad__badge { position: absolute; top: var(--sp-xs); left: var(--sp-xs); }
.card-propiedad__star {
position: absolute; top: var(--sp-xs); right: var(--sp-xs);
background: var(--color-accent); color: var(--color-ink);
width: 30px; height: 30px; border-radius: 50%;
display: grid; place-items: center; font-size: var(--fs-small); font-weight: 700;
}
.card-propiedad__body { padding: var(--sp-s); flex: 1; }
.card-propiedad__price { font-family: var(--font-heading); font-size: var(--fs-medium); color: var(--color-primary); margin: 0 0 .25rem; }
.card-propiedad__title { font-size: var(--fs-base); margin: 0 0 .25rem; }
.card-propiedad__title a:hover { color: var(--color-primary); }
.card-propiedad__location { color: var(--color-muted); font-size: var(--fs-small); margin: 0 0 var(--sp-s); }
.card-propiedad__meta { display: flex; gap: var(--sp-s); flex-wrap: wrap; font-size: var(--fs-small); color: var(--color-muted); }
.card-propiedad__meta span { background: var(--color-bg); padding: .2rem .55rem; border-radius: 999px; }
.card-propiedad__footer {
display: flex; align-items: stretch; gap: var(--sp-xs);
padding: var(--sp-s); border-top: 1px solid var(--color-line);
} .card-propiedad__detail {
flex: 1;
display: inline-flex; align-items: center; justify-content: center; gap: .35rem;
background: var(--color-primary); color: #fff;
padding: .6rem 1rem; border-radius: var(--radius-sm);
font-weight: 700; font-size: var(--fs-small); line-height: 1;
transition: var(--transition);
}
.card-propiedad__detail:hover { background: var(--color-primary-dark); color: #fff; } .card-propiedad__wa {
flex: 0 0 auto;
display: inline-flex; align-items: center; justify-content: center;
width: 40px; border-radius: var(--radius-sm);
border: 1px solid var(--color-line);
color: var(--color-whatsapp); background: var(--color-surface);
transition: var(--transition);
}
.card-propiedad__wa:hover {
background: var(--color-whatsapp); color: #fff; border-color: var(--color-whatsapp);
}.text-center { text-align: center; }
.mt-0 { margin-top: 0; }
.mb-0 { margin-bottom: 0; }
.flow > * + * { margin-top: var(--sp-s); }
.hidden { display: none !important; } .tf-lightbox {
position: fixed; inset: 0; z-index: 1000;
background: rgba(15, 22, 18, .92);
display: grid; place-items: center; padding: var(--sp-m);
cursor: zoom-out;
}
.tf-lightbox img { max-width: 92vw; max-height: 92vh; border-radius: var(--radius-sm); } img[loading="lazy"] { background: var(--color-bg); } .cta-whatsapp { text-align: center; padding: var(--sp-l) 0; }.archive-hero {
background: linear-gradient(135deg, var(--color-primary-dark), var(--color-primary));
color: #fff; padding-block: var(--sp-l);
}
.archive-hero__title { color: #fff; font-size: var(--fs-xlarge); margin-bottom: .25rem; }
.archive-hero__subtitle { color: rgba(255,255,255,.9); margin: 0; }
.archive-filtros .buscador { box-shadow: var(--shadow); }
.archive-filtros .buscador__row { grid-template-columns: 1fr; }
.archive-resultados__header { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--sp-m); flex-wrap: wrap; gap: var(--sp-s); }
.archive-resultados__count { color: var(--color-muted); font-size: var(--fs-small); margin-bottom: 0; }
.archive-view-toggle { display: flex; gap: 0; border-radius: var(--radius-sm); overflow: hidden; border: 1px solid var(--color-border); }
.archive-view-toggle .btn { border: none; border-radius: 0; padding: .5rem 1rem; font-size: var(--fs-small); color: var(--color-ink); background: transparent; }
.archive-view-toggle .btn.is-active { background: var(--color-primary); color: #fff; }
#tf-global-map { width: 100%; height: 600px; border-radius: var(--radius-md); margin-bottom: var(--sp-l); z-index: 1; background: #f3f4f6; }
.archive-vacio { text-align: center; padding: var(--sp-xl) 0; display: grid; gap: var(--sp-m); justify-items: center; }
.archive-vacio p { color: var(--color-muted); margin: 0; }