/**
 * Downloads List Shortcode Styles
 *
 * Styles for the [eddwp_downloads_list] shortcode.
 * Matches Figma design: 3-column grid of download cards.
 *
 * @package Core
 * @since <next-version>
 */

/* CSS Custom Properties */
.eddwp-downloads-grid {
	--eddwp-card-width: 277px;
	--eddwp-card-height: 357px;
	--eddwp-card-bg: #ffffff;
	--eddwp-card-border: #171717;
	--eddwp-image-height: 139px;
	--eddwp-image-bg: #ffc9c9;
	--eddwp-title-color: #171717;
	--eddwp-text-color: #292929;
	--eddwp-button-border: #737373;
	--eddwp-grid-gap: 31px;
	--eddwp-row-gap: 30px;
	--eddwp-content-padding: 23px;
	--eddwp-content-width: 229px;
	--eddwp-font-serif: 'IBM Plex Serif', Georgia, serif;
	--eddwp-font-sans: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
}

/* Grid Container */
.eddwp-downloads-grid {
	display: grid;
	grid-template-columns: repeat(3, var(--eddwp-card-width));
	gap: var(--eddwp-row-gap) var(--eddwp-grid-gap);
	justify-content: center;
	width: 100%;
	max-width: calc((var(--eddwp-card-width) * 3) + (var(--eddwp-grid-gap) * 2));
	margin: 0 auto;
}

/* Card */
.eddwp-download-card {
	position: relative;
	display: flex;
	flex-direction: column;
	width: var(--eddwp-card-width);
	height: var(--eddwp-card-height);
	background: var(--eddwp-card-bg);
	border: 1px solid var(--eddwp-card-border);
	overflow: hidden;
}

/* Image Area */
.eddwp-download-card__image {
	position: relative;
	width: 100%;
	height: var(--eddwp-image-height);
	background: var(--eddwp-image-bg);
	border-bottom: 1px solid var(--eddwp-card-border);
	overflow: hidden;
	flex-shrink: 0;
}

.eddwp-download-card__image img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* Content Area */
.eddwp-download-card__content {
	display: flex;
	flex-direction: column;
	gap: 12px;
	padding: 15px var(--eddwp-content-padding) 0;
	width: var(--eddwp-content-width);
	flex-grow: 1;
}

/* Title */
.eddwp-download-card__title {
	font-family: var(--eddwp-font-serif);
	font-size: 18px;
	font-weight: 500;
	line-height: 24px;
	color: var(--eddwp-title-color);
	margin: 0;
	overflow: hidden;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
}

/* Excerpt */
.eddwp-download-card__excerpt {
	font-family: var(--eddwp-font-sans);
	font-size: 14px;
	font-weight: 400;
	line-height: 18px;
	color: var(--eddwp-text-color);
	margin: 0;
	overflow: hidden;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
}

/* Button */
.eddwp-download-card__button {
	position: absolute;
	bottom: 23px;
	left: var(--eddwp-content-padding);
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0;
	width: var(--eddwp-content-width);
	padding: 8px 16px;
	background: var(--eddwp-card-bg);
	border: 1px solid var(--eddwp-button-border);
	border-radius: 12px;
	font-family: var(--eddwp-font-sans);
	font-size: 14px;
	font-weight: 600;
	line-height: 20px;
	letter-spacing: -0.25px;
	color: var(--eddwp-title-color);
	text-decoration: none;
	transition: background-color 0.2s ease, border-color 0.2s ease;
	box-sizing: border-box;
}

.eddwp-download-card__button:hover,
.eddwp-download-card__button:focus {
	background: #f5f5f5;
	border-color: var(--eddwp-card-border);
	text-decoration: none;
	color: var(--eddwp-title-color);
}

.eddwp-download-card__button svg {
	flex-shrink: 0;
	width: 24px;
	height: 24px;
}

/* Empty State */
.eddwp-downloads-empty {
	text-align: center;
	font-family: var(--eddwp-font-sans);
	font-size: 16px;
	color: var(--eddwp-text-color);
	padding: 40px 20px;
}

/* Responsive: Tablet (2 columns) */
@media (max-width: 920px) {
	.eddwp-downloads-grid {
		grid-template-columns: repeat(2, var(--eddwp-card-width));
		max-width: calc((var(--eddwp-card-width) * 2) + var(--eddwp-grid-gap));
	}
}

/* Responsive: Mobile (1 column, fluid width) */
@media (max-width: 620px) {
	.eddwp-downloads-grid {
		--eddwp-card-width: 100%;
		--eddwp-content-width: calc(100% - (var(--eddwp-content-padding) * 2));
		grid-template-columns: 1fr;
		max-width: 100%;
		gap: 24px;
		padding: 0 16px;
	}

	.eddwp-download-card {
		width: 100%;
		height: auto;
		min-height: var(--eddwp-card-height);
	}

	.eddwp-download-card__content {
		width: auto;
		padding-bottom: 80px;
	}

	.eddwp-download-card__button {
		width: calc(100% - (var(--eddwp-content-padding) * 2));
	}
}
