/* =========================================================================
   MICROSITIO INMOBILIARIO — misma marca, layout propio
   ========================================================================= */

/* Cabecera propia */
.inmo-header__sub {
	color: var(--color-primary); font-weight: var(--fw-bold);
}
.inmo-header__back { font-size: 0.9rem; color: var(--color-text-light) !important; }

/* Hero del catálogo */
.inmo-hero {
	background: var(--color-secondary); color: var(--color-white);
	padding-block: clamp(2.5rem, 1.5rem + 4vw, 4.5rem);
	border-bottom: 4px solid var(--color-primary);
}
.inmo-hero h1 { color: var(--color-white); margin: 0.3rem 0; }
.inmo-hero p { color: var(--color-white-soft); margin: 0; }

/* Filtros */
.inmo-filters {
	display: flex; flex-wrap: wrap; gap: var(--space-sm); align-items: end;
	background: var(--color-bg-alt); border: 1px solid var(--color-border);
	border-radius: var(--radius-lg); padding: var(--space-md); margin-bottom: var(--space-lg);
}
.inmo-filters__field { display: flex; flex-direction: column; flex: 1 1 150px; min-width: 0; }
.inmo-filters__field label { font-family: var(--font-heading); text-transform: uppercase; font-size: 0.8rem; letter-spacing: 0.04em; margin-bottom: 0.3rem; color: var(--color-text-light); }
.inmo-filters__field select, .inmo-filters__field input {
	padding: 0.6em 0.7em; border: 1px solid var(--color-border); border-radius: var(--radius);
	font: inherit; background: var(--color-white);
}
.inmo-filters__actions {
	display: flex; gap: 0.65rem; flex: 0 0 auto; align-items: center;
	justify-content: flex-end; margin-left: auto;
}
.inmo-filters__actions .btn {
	justify-content: center; min-width: 118px; min-height: 42px; white-space: nowrap;
	padding: 0.62rem 1.15rem; line-height: 1; font-size: 0.9rem;
}
.inmo-filters__actions .btn--ghost { background: var(--color-white); }
.inmo-count { color: var(--color-text-light); margin-bottom: var(--space-sm); }

@media (max-width: 720px) {
	.inmo-filters__actions { flex-basis: 100%; margin-left: 0; }
	.inmo-filters__actions .btn { flex: 1 1 0; min-width: 0; }
}

/* Grilla de propiedades */
.prop-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: var(--space-md); }

.prop-card {
	background: var(--color-white); border: 1px solid var(--color-border);
	border-radius: var(--radius-lg); overflow: hidden; display: flex; flex-direction: column;
	transition: transform var(--transition), box-shadow var(--transition);
}
.prop-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.prop-card__media { position: relative; display: block; aspect-ratio: 3/2; background: var(--color-bg-alt); }
.prop-card__media img { width: 100%; height: 100%; object-fit: cover; }
.prop-card__noimg { position: absolute; inset: 0; display: grid; place-items: center; color: var(--color-text-light); }
.prop-card__op {
	position: absolute; top: 0.8rem; left: 0.8rem; background: var(--color-primary); color: #fff;
	font-family: var(--font-heading); text-transform: uppercase; font-size: 0.8rem; letter-spacing: 0.05em;
	padding: 0.25em 0.7em; border-radius: var(--radius);
}
.prop-card__estado {
	position: absolute; bottom: 0.8rem; right: 0.8rem; background: var(--color-secondary); color: #fff;
	font-size: 0.78rem; padding: 0.25em 0.6em; border-radius: var(--radius);
}
.prop-card__body { padding: var(--space-sm) var(--space-md) var(--space-md); display: flex; flex-direction: column; gap: 0.3rem; }
.prop-card__price { font-family: var(--font-heading); font-weight: var(--fw-bold); font-size: 1.4rem; color: var(--color-primary); margin: 0; }
.prop-card__title { font-size: 1.15rem; margin: 0; }
.prop-card__title a { color: var(--color-secondary); }
.prop-card__title a:hover { color: var(--color-primary); }
.prop-card__loc { color: var(--color-text-light); margin: 0; font-size: 0.95rem; }
.prop-card__specs { list-style: none; display: flex; flex-wrap: wrap; gap: 0.8rem; padding: 0.5rem 0 0; margin: 0; border-top: 1px solid var(--color-border); margin-top: 0.5rem; }
.prop-card__specs li { font-size: 0.9rem; color: var(--color-text); }

/* Paginación */
.inmo-pagination { margin-top: var(--space-lg); display: flex; justify-content: center; }
.inmo-pagination .page-numbers {
	display: inline-block; padding: 0.5em 0.9em; margin: 0 0.2em; border: 1px solid var(--color-border);
	border-radius: var(--radius); color: var(--color-secondary);
}
.inmo-pagination .page-numbers.current { background: var(--color-primary); color: #fff; border-color: var(--color-primary); }

.inmo-empty { text-align: center; padding: var(--space-xl) 0; }

/* ---------- FICHA ---------- */
.prop-single__back { color: var(--color-white-soft) !important; font-size: 0.9rem; }
.prop-single__head-row { display: flex; justify-content: space-between; align-items: flex-end; gap: var(--space-md); flex-wrap: wrap; }
.prop-single__op { position: static; display: inline-block; margin-bottom: 0.5rem; }
.prop-single__loc { color: var(--color-white-soft); margin: 0.3rem 0 0; }
.prop-single__price { font-family: var(--font-heading); font-weight: var(--fw-bold); font-size: clamp(1.8rem, 1.2rem + 2vw, 2.6rem); color: var(--color-primary); margin: 0; }

.prop-single__grid { display: grid; grid-template-columns: 1.7fr 1fr; gap: var(--space-lg); align-items: start; }

.prop-gallery__main img { width: 100%; border-radius: var(--radius-lg); aspect-ratio: 16/10; object-fit: cover; }
.prop-gallery__thumbs { display: grid; grid-template-columns: repeat(auto-fill, minmax(90px, 1fr)); gap: 0.5rem; margin-top: 0.6rem; }
.prop-gallery__thumb { padding: 0; border: 2px solid transparent; border-radius: var(--radius); overflow: hidden; cursor: pointer; background: none; }
.prop-gallery__thumb img { width: 100%; aspect-ratio: 1; object-fit: cover; display: block; }
.prop-gallery__thumb.is-active { border-color: var(--color-primary); }
.prop-single__desc { margin-top: var(--space-md); }

.card { background: var(--color-white); border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: var(--space-md); }
.prop-single__aside { display: grid; gap: var(--space-md); position: sticky; top: calc(var(--header-h) + 1rem); }
.prop-specs__list { list-style: none; padding: 0; margin: 0 0 var(--space-md); }
.prop-specs__list li { display: flex; justify-content: space-between; padding: 0.55em 0; border-bottom: 1px solid var(--color-border); }
.prop-specs__list span { color: var(--color-text-light); }
.prop-specs__wa { width: 100%; justify-content: center; }

@media (max-width: 980px) {
	.prop-single__grid { grid-template-columns: 1fr; }
	.prop-single__aside { position: static; }
}

/* ---------- Características por tipo (ficha técnica) ---------- */
.prop-extra { margin-top: var(--space-md); }
.prop-extra h3 { margin: 0 0 var(--space-sm); }
.prop-extra__line { display: flex; justify-content: space-between; gap: 1rem; padding: 0.5em 0; border-bottom: 1px solid var(--color-border); margin: 0; }
.prop-extra__line span { color: var(--color-text-light); }
.prop-extra__line strong { color: var(--color-secondary); text-align: right; }
.prop-extra__block { padding: 0.6em 0; border-bottom: 1px solid var(--color-border); }
.prop-extra__block > span { display: block; color: var(--color-text-light); font-weight: var(--fw-medium); margin-bottom: 0.5rem; }
.prop-extra__block p { margin: 0; }
.prop-extra__sino { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 0.4rem 1.2rem; }
.prop-extra__sino li { display: flex; align-items: center; gap: 0.5rem; }
.prop-extra__sino em { color: var(--color-text-light); font-style: normal; }
.prop-sino { display: inline-grid; place-items: center; width: 22px; height: 22px; border-radius: 50%; font-size: 0.8rem; flex-shrink: 0; }
.prop-sino--si { background: #e7f6ec; color: #1d7a3e; }
.prop-sino--no { background: var(--color-bg-alt); color: var(--color-text-light); }
