/**
 * HP Blocksy Support — Listing Pages
 *
 * Listing cards, grid layout, search forms, and category pages.
 */

/* === Listing Cards === */
.hp-listing {
	border-radius: 8px;
	overflow: hidden;
	transition: box-shadow 0.2s ease, transform 0.2s ease;
	background: var(--hp-color-surface, #fff);
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
}

.hp-listing:hover {
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
	transform: translateY(-2px);
}

/* === Listing Images === */
.hp-listing__image,
.hp-listing__images {
	overflow: hidden;
	position: relative;
}

.hp-listing__image img,
.hp-listing__images img {
	width: 100%;
	height: auto;
	object-fit: cover;
	display: block;
}

/* === Listings Grid === */
.hp-listings {
	display: grid;
	gap: 24px;
}

.hp-listings--columns-2 {
	grid-template-columns: repeat(2, 1fr);
}

.hp-listings--columns-3 {
	grid-template-columns: repeat(3, 1fr);
}

.hp-listings--columns-4 {
	grid-template-columns: repeat(4, 1fr);
}

@media (max-width: 1024px) {
	.hp-listings--columns-4 {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (max-width: 768px) {
	.hp-listings--columns-3,
	.hp-listings--columns-4 {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 480px) {
	.hp-listings--columns-2,
	.hp-listings--columns-3,
	.hp-listings--columns-4 {
		grid-template-columns: 1fr;
	}
}

/* === Search Forms === */
.hp-form--listing-search,
.hp-form--vendor-search {
	background: var(--hp-color-surface, #f8f8f8);
	padding: 20px;
	border-radius: 10px;
	margin-bottom: 30px;
}

.hp-form--listing-search .hp-row,
.hp-form--vendor-search .hp-row {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	align-items: flex-end;
}

.hp-form--listing-search .hp-field,
.hp-form--vendor-search .hp-field {
	flex: 1;
	min-width: 200px;
}

/* === Category Page === */
.hp-listing-categories {
	display: grid;
	gap: 16px;
}

.hp-listing-category__link {
	display: flex;
	align-items: center;
	gap: 12px;
	text-decoration: none;
	padding: 12px 16px;
	border-radius: var(--hp-border-radius, 3px);
	background: var(--hp-color-surface, #f8f8f8);
	transition: background 0.2s ease;
}

.hp-listing-category__link:hover {
	background: var(--hp-color-border, #eee);
}

/* === Listing Single Page === */
.hp-listing--view-page .hp-listing__images-carousel {
	border-radius: 8px;
	overflow: hidden;
}

.hp-listing--view-page .hp-listing__title {
	font-size: 1.5rem;
	font-weight: 700;
	margin-bottom: 16px;
	font-family: var(--hp-font-heading, inherit);
}
