/**
 * Card — container primitives.
 *
 * Variants:
 *   .slist-card                    — solid surface card
 *   .slist-card--interactive       — adds hover lift
 *   .slist-card--lineup            — artist lineup row (event page)
 *   .slist-card--product           — product grid card (shop)
 */

.slist-card {
	background: var(--slist-surface);
	border: none;
	border-radius: var(--slist-radius-lg);  /* 16px */
	padding: var(--slist-space-4);
	color: var(--slist-text-primary);
	display: block;
	text-decoration: none;
	overflow: hidden;
}

.slist-card--interactive {
	transition:
		border-color var(--slist-transition-fast),
		transform var(--slist-transition-default);
}

.slist-card--interactive:hover,
.slist-card--interactive:focus-within {
	transform: translateY(-2px);
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);
}

/* ---- Lineup row — grid layout for event page ---- */

.slist-card--lineup {
	display: grid;
	grid-template-columns: 56px 1fr;
	grid-template-areas:
		"photo name"
		"photo socials";
	column-gap: var(--slist-space-3);
	row-gap: 2px;
	align-items: center;
	padding: var(--slist-space-3);
}

.slist-card--lineup.is-headliner {
	background: rgba(255, 255, 255, 0.04);
	border-color: var(--slist-separator-medium);
}

.slist-card--lineup.is-headliner + .slist-card--lineup:not(.is-headliner) {
	margin-top: var(--slist-space-2);
}

/* ---- Product card (shop grid) ---- */

.slist-card--product {
	padding: 0;
	display: flex;
	flex-direction: column;
	position: relative;
}

.slist-card__media {
	aspect-ratio: 1 / 1;
	background: rgba(255, 255, 255, 0.04);
	overflow: hidden;
	display: block;
}

.slist-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--slist-transition-slow);
}

.slist-card--product:hover .slist-card__media img {
	transform: scale(1.04);
}

.slist-card__body {
	padding: 20px;
	display: flex;
	flex-direction: column;
	gap: var(--slist-space-2);
	flex: 1;
}

.slist-card__title {
	font-family: var(--slist-font-display);
	font-size: var(--slist-text-title3);
	font-weight: var(--slist-weight-regular);
	margin: 0;
	color: var(--slist-text-primary);
}

.slist-card__price {
	font-family: var(--slist-font-body);
	font-size: var(--slist-text-callout);
	color: var(--slist-text-secondary);
	margin: 0;
}

.slist-card__price ins {
	color: var(--slist-text-primary);
	text-decoration: none;
	background: transparent;
	font-weight: var(--slist-weight-semibold);
}

.slist-card__price del {
	color: var(--slist-text-tertiary);
	margin-right: var(--slist-space-2);
}

.slist-card__cta {
	margin-top: auto;
}

/* Sale badge overlay on product cards */
.slist-card__badge-sale {
	position: absolute;
	top: 12px;
	right: 12px;
	z-index: 2;
}

/* ---- Responsive ---- */

@media (max-width: 767px) {
	.slist-card {
		border-radius: 12px;
	}
}
