/*
 * ============================================================================
 * URBIFY · property-card.css
 * ============================================================================
 * Estilos de la tarjeta de propiedad reutilizable (.urb-card).
 *
 * Esta hoja se carga en TODAS las páginas del frontend porque la tarjeta
 * se reutiliza en homepage, archive, taxonomías, /favoritos y /comparador.
 * Antes vivía dentro de property-archive.css y solo se cargaba en archives,
 * lo que dejaba sin estilos a las cards en home y favoritos.
 *
 * Mobile-first.
 *
 * @package Divi_Child_Urbify
 * @since   1.1.0
 */

/* ============================================================================
   §1. CONTENEDOR
   ============================================================================ */

.urb-card {
	position: relative;
	display: flex;
	flex-direction: column;
	background: var(--urb-white);
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: var(--shadow-sm);
	transition: transform var(--transition-base), box-shadow var(--transition-base);
}

/* Hover y focus-within usan box-shadow porque respeta border-radius
   (a diferencia de outline, que recorta en cards con esquinas redondeadas). */
.urb-card:hover {
	transform: translateY( -3px );
	box-shadow: var(--shadow-lg);
}

/* Indicador de foco accesible para teclado: aplicado a la CARD entera, no a
   los enlaces internos. Evita el "borde verde cortado" del outline global del
   helper que usaba border-radius diferente al de la card. */
.urb-card:focus-within {
	transform: translateY( -3px );
	box-shadow: 0 0 0 2px var(--urb-mint-500), var(--shadow-lg);
}

/* Anular el outline global del helper en los enlaces que viven DENTRO de la card.
   El indicador visual de foco lo gestiona la card padre con :focus-within (arriba). */
.urb-card a:focus-visible,
.urb-card button:focus-visible {
	outline: none;
}

/* Estado: vendida → grayscale ligero sobre la imagen */
.urb-card--status-vendida .urb-card__media,
.urb-card--status-alquilada .urb-card__media {
	filter: grayscale( 30% );
}

/* Destacada: borde dorado sutil */
.urb-card--featured {
	box-shadow: 0 0 0 1.5px var(--urb-gold), var(--shadow-sm);
}

.urb-card--featured:hover {
	box-shadow: 0 0 0 1.5px var(--urb-gold), var(--shadow-lg);
}

/* Cuando una tarjeta destacada recibe foco, prima el verde menta del foco
   sobre el dorado del modificador (consistencia visual del indicador a11y). */
.urb-card--featured:focus-within {
	box-shadow: 0 0 0 2px var(--urb-mint-500), var(--shadow-lg);
}

/* ============================================================================
   §2. MEDIA (imagen + badges)
   ============================================================================ */

.urb-card__media {
	position: relative;
	display: block;
	width: 100%;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	background: var(--urb-gray-50);
}

.urb-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--transition-slow);
}

.urb-card:hover .urb-card__img {
	transform: scale( 1.04 );
}

.urb-card__img--placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--urb-gray-400);
}

/* ---- Badges sobre la imagen ---- */
.urb-card__op-badge {
	position: absolute;
	top: var(--space-3);
	right: var(--space-3);
	padding: 4px 10px;
	background: var(--urb-navy-900);
	color: var(--urb-white);
	font-size: 10px;
	font-weight: var(--fw-bold);
	letter-spacing: var(--tracking-wider);
	border-radius: var(--radius-sm);
}

.urb-card__op-badge--alquiler {
	background: var(--urb-mint-500);
}

.urb-card__status-badge {
	position: absolute;
	top: var(--space-3);
	left: var(--space-3);
}

.urb-card__featured-badge {
	position: absolute;
	bottom: var(--space-3);
	left: var(--space-3);
}

.urb-card__discount-badge {
	position: absolute;
	bottom: var(--space-3);
	right: var(--space-3);
}

/* ============================================================================
   §3. BODY
   ============================================================================ */

.urb-card__body {
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
	padding: var(--space-5) var(--space-5) var(--space-6);
}

.urb-card__ref {
	font-family: var(--font-mono);
	font-size: var(--text-xs);
	font-weight: var(--fw-medium);
	color: var(--urb-gray-400);
	letter-spacing: var(--tracking-wide);
}

.urb-card__title {
	margin: 0;
	font-family: var(--font-display);
	font-size: var(--text-lg);
	font-weight: var(--fw-semibold);
	line-height: var(--leading-snug);
	color: var(--urb-navy-900);

	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	text-overflow: ellipsis;
}

.urb-card__title a {
	color: inherit;
	text-decoration: none;
	transition: color var(--transition-fast);
}

.urb-card__title a::after {
	content: '';
	position: absolute;
	inset: 0;
	z-index: 1;
}

.urb-card__title a:hover,
.urb-card__title a:focus-visible {
	color: var(--urb-mint-500);
}

.urb-card__location {
	display: flex;
	align-items: center;
	gap: var(--space-2);
	margin: 0;
	font-size: var(--text-sm);
	color: var(--urb-gray-600);
	line-height: 1.4;
}

.urb-card__location-icon {
	color: var(--urb-mint-500);
	flex-shrink: 0;
}

.urb-card__price {
	display: flex;
	align-items: baseline;
	flex-wrap: wrap;
	gap: var(--space-2);
	margin-top: var(--space-2);
	font-family: var(--font-display);
	font-size: var(--text-xl);
	font-weight: var(--fw-bold);
	color: var(--urb-navy-900);
}

.urb-card__price-prev {
	font-size: var(--text-sm);
	font-weight: var(--fw-regular);
	color: var(--urb-gray-400);
	text-decoration: line-through;
}

.urb-card__price-period {
	font-size: var(--text-sm);
	font-weight: var(--fw-regular);
	color: var(--urb-gray-600);
}

/* ---- Specs (hab/baños/m²) ---- */
.urb-card__specs {
	list-style: none;
	margin: var(--space-3) 0 0;
	padding: var(--space-3) 0 0;
	border-top: 1px solid var(--urb-gray-200);
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-4);
}

.urb-card__spec {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	font-size: var(--text-sm);
	color: var(--urb-gray-600);
	font-weight: var(--fw-medium);
}

.urb-card__spec .urb-icon {
	color: var(--urb-navy-500);
	width: 18px;
	height: 18px;
}

/* ============================================================================
   §4. AJUSTES DEL BOTÓN DE FAVORITOS DE LA TARJETA
   ============================================================================
   Las reglas base de .urb-card__actions / .urb-card__action viven en
   engagement.css (que se carga después de este archivo). Aquí refinamos el
   acabado visual del corazón en las tarjetas: lo tintamos en verde menta para
   que se identifique como CTA y lo separamos visualmente de la imagen.
   Usamos doble clase (.urb-card .urb-card__action--fav) para ganar a la
   especificidad de engagement.css por orden de cascada. */

.urb-card .urb-card__action--fav {
	color: var(--urb-mint-500);
	border: 1px solid rgba(46, 204, 113, 0.25);
}

.urb-card .urb-card__action--fav:hover,
.urb-card .urb-card__action--fav:focus-visible {
	color: var(--urb-white);
	background: var(--urb-mint-500);
	border-color: var(--urb-mint-500);
	box-shadow: var(--shadow-md), 0 0 0 4px rgba(46, 204, 113, 0.18);
}

.urb-card .urb-card__action--fav:hover svg,
.urb-card .urb-card__action--fav:focus-visible svg {
	fill: var(--urb-white);
	stroke: var(--urb-white);
}

/* Estado activo (favorito ya guardado): corazón blanco sobre menta */
.urb-card .urb-card__action--fav.is-active {
	background: var(--urb-mint-500);
	color: var(--urb-white);
	border-color: var(--urb-mint-500);
}

.urb-card .urb-card__action--fav.is-active svg {
	fill: var(--urb-white);
	stroke: var(--urb-white);
}

