/* ============================================================
   Property Card Component
   ============================================================ */

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

.property-card[hidden] { display: none; }

.property-card:hover {
	box-shadow: var(--shadow-md);
	transform: translateY(-2px);
}

/* ---- Media ------------------------------------------------ */

.property-card__media {
	position: relative;
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background: var(--color-gray-alt);
	flex-shrink: 0;
}

.property-card__image-link {
	display: block;
	width: 100%;
	height: 100%;
}

.property-card__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.5s ease;
}

.property-card:hover .property-card__image {
	transform: scale(1.04);
}

/* Placeholder */
.property-card__media--placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-gray-mid);
}

.property-card__placeholder-icon {
	width: 48px;
	height: 48px;
	opacity: 0.4;
}

/* ---- Badges ----------------------------------------------- */

.property-card__badge {
	position: absolute;
	top: var(--space-3);
	left: var(--space-3);
	padding: var(--space-1) var(--space-3);
	background: var(--color-primary);
	color: var(--color-white);
	font-size: 11px;
	font-weight: var(--weight-bold);
	text-transform: uppercase;
	letter-spacing: var(--tracking-wide);
	border-radius: var(--radius-full);
	line-height: 1.4;
}

.property-card__badge--reduction {
	background: var(--color-dark);
	top: calc(var(--space-3) + 28px);
}

.property-card__status {
	position: absolute;
	top: var(--space-3);
	right: var(--space-3);
	padding: var(--space-1) var(--space-3);
	background: rgba(17, 24, 32, 0.75);
	color: var(--color-white);
	font-size: 11px;
	font-weight: var(--weight-semibold);
	border-radius: var(--radius-full);
	line-height: 1.4;
	backdrop-filter: blur(4px);
}

/* ---- Body ------------------------------------------------- */

.property-card__body {
	padding: var(--space-5);
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
	flex: 1;
}

.property-card__title {
	font-size: var(--size-base);
	font-weight: var(--weight-bold);
	color: var(--color-text);
	margin: 0;
	line-height: var(--leading-snug);
}

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

.property-card__title a:hover {
	color: var(--color-primary);
}

.property-card__address {
	font-size: var(--size-sm);
	color: var(--color-text-muted);
	margin: 0;
	line-height: var(--leading-normal);
}

.property-card__price {
	font-size: var(--size-lg);
	font-weight: var(--weight-bold);
	color: var(--color-primary);
	margin: 0;
	display: flex;
	align-items: baseline;
	gap: var(--space-1);
}

.property-card__price-label {
	font-size: var(--size-sm);
	font-weight: var(--weight-regular);
	color: var(--color-text-muted);
}

/* ---- Specs ------------------------------------------------ */

.property-card__specs {
	display: flex;
	gap: var(--space-4);
	flex-wrap: wrap;
	list-style: none;
	padding: 0;
	margin: 0;
}

.property-card__spec {
	display: flex;
	align-items: center;
	gap: var(--space-2);
	font-size: var(--size-sm);
	color: var(--color-text-muted);
}

.property-card__spec-icon {
	width: 16px;
	height: 16px;
	flex-shrink: 0;
	color: var(--color-text-muted);
}

.property-card__spec-value {
	font-weight: var(--weight-semibold);
	color: var(--color-text);
}

/* ---- CTA -------------------------------------------------- */

.property-card__cta {
	align-self: flex-start;
	margin-top: auto;
	font-size: var(--size-sm);
}

/* ---- List View -------------------------------------------- */

@media (min-width: 640px) {
	.is-list-view .property-card {
		flex-direction: row;
	}

	.is-list-view .property-card .property-card__media {
		width: 240px;
		flex-shrink: 0;
		aspect-ratio: auto;
		align-self: stretch;
	}

	.is-list-view .property-card .property-card__image {
		height: 100%;
		aspect-ratio: auto;
	}
}
