/* Category Tiles Block - Frontend Styles */

.wp-block-upjau-theme-category-tiles {
	position: relative;
	--upjau-category-tiles-pad-top: var(--upjau-section-space-lg);
	--upjau-category-tiles-pad-bottom: var(--upjau-section-space-lg);
	padding-top: var(--upjau-category-tiles-pad-top);
	padding-bottom: var(--upjau-category-tiles-pad-bottom);

	--upjau-category-tiles-gap: var(--wp--preset--spacing--4);
	--upjau-category-tile-aspect: 1 / 1;
	--upjau-category-tile-label-size: clamp(18px, 4.8vw, 26px);
	--upjau-category-tile-label-shadow: 0 2px 10px rgba(15, 26, 20, 0.28);
	--upjau-category-tile-scrim-from: rgba(0, 77, 37, 0.62);
	--upjau-category-tile-scrim-to: rgba(0, 77, 37, 0);
}

.upjau-category-tiles__header {
	text-align: center;
	margin-bottom: var(--wp--preset--spacing--6);
}

.upjau-category-tiles__subheading {
	font-size: var(--wp--preset--font-size--lg);
	font-weight: 400;
	margin-top: 0;
	margin-bottom: var(--wp--preset--spacing--2);
}

.upjau-category-tiles__heading {
	font-size: clamp(24px, 5.6vw, 32px);
	font-weight: 700;
	margin-top: 0;
	margin-bottom: 0;
}

.upjau-category-tiles__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: var(--upjau-category-tiles-gap);
}

@media (min-width: 782px) {
	.wp-block-upjau-theme-category-tiles {
		--upjau-category-tiles-gap: var(--wp--preset--spacing--6);
	}

	.upjau-category-tiles__grid {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}
}

.upjau-category-tile {
	position: relative;
}

.upjau-category-tile__link {
	position: relative;
	display: block;
	border-radius: var(--radius-lg);
	overflow: hidden;
	text-decoration: none;
	color: inherit;
	box-shadow: var(--upjau-shadow-lg);
	background: var(--wp--preset--color--surface);
	transform: translateZ(0);
	transition:
		transform var(--upjau-transition-normal),
		box-shadow var(--upjau-transition-normal);
}

.upjau-category-tile__link--clickable {
	cursor: pointer;
}

.upjau-category-tile__link--nolink {
	cursor: default;
}

.upjau-category-tile__link--clickable:hover,
.upjau-category-tile__link--clickable:focus-visible {
	text-decoration: none;
}

.upjau-category-tile__link--clickable:focus-visible {
	outline: var(--upjau-focus-outline-width) solid var(--upjau-focus-outline-color);
	outline-offset: var(--upjau-focus-outline-offset-loose);
}

.upjau-category-tile__media {
	position: relative;
	aspect-ratio: var(--upjau-category-tile-aspect);
	background: var(--wp--preset--color--forest-50);
}

.upjau-category-tile__image {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover;
	transition: transform var(--upjau-transition-slow);
	will-change: transform;
}

.upjau-category-tile__placeholder {
	width: 100%;
	height: 100%;
	background:
		linear-gradient(135deg, rgba(0, 77, 37, 0.08), rgba(22, 137, 47, 0.06)),
		radial-gradient(circle at 30% 20%, rgba(22, 137, 47, 0.12), rgba(0, 77, 37, 0) 60%);
}

.upjau-category-tile__link::after {
	content: '';
	position: absolute;
	inset: 0;
	pointer-events: none;
	background: linear-gradient(
		to bottom,
		var(--upjau-category-tile-scrim-from) 0%,
		var(--upjau-category-tile-scrim-to) 62%
	);
	opacity: 0.95;
	transition:
		opacity var(--upjau-transition-normal),
		background var(--upjau-transition-normal);
}

.upjau-category-tile__link--clickable::before {
	content: '';
	position: absolute;
	inset: 0;
	z-index: 1;
	pointer-events: none;
	border: 1px solid rgba(255, 255, 255, 0.24);
	border-radius: inherit;
	opacity: 0;
	transition:
		opacity var(--upjau-transition-normal),
		transform var(--upjau-transition-normal);
}

.upjau-category-tile__label {
	position: absolute;
	top: var(--wp--preset--spacing--4);
	left: var(--wp--preset--spacing--4);
	right: var(--wp--preset--spacing--4);
	z-index: 2;
	pointer-events: none;
}

.upjau-category-tile__title {
	color: var(--wp--preset--color--surface);
	font-weight: 700;
	font-size: var(--upjau-category-tile-label-size);
	line-height: 1.1;
	text-shadow: var(--upjau-category-tile-label-shadow);
	text-wrap: balance;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	overflow: hidden;
	transition: transform var(--upjau-transition-normal);
}

.upjau-category-tile__link--clickable:hover,
.upjau-category-tile__link--clickable:focus-visible {
	transform: translateY(-8px) scale(1.01);
	box-shadow: var(--upjau-shadow-xl);
}

.upjau-category-tile__link--clickable:hover::after,
.upjau-category-tile__link--clickable:focus-visible::after {
	opacity: 1;
	background: linear-gradient(
		to bottom,
		rgba(0, 77, 37, 0.54) 0%,
		rgba(0, 77, 37, 0.08) 72%
	);
}

.upjau-category-tile__link--clickable:hover::before,
.upjau-category-tile__link--clickable:focus-visible::before {
	opacity: 1;
	transform: scale(0.97);
}

.upjau-category-tile__link--clickable:hover .upjau-category-tile__image,
.upjau-category-tile__link--clickable:focus-visible .upjau-category-tile__image {
	transform: scale(1.08);
}

.upjau-category-tile__link--clickable:hover .upjau-category-tile__title,
.upjau-category-tile__link--clickable:focus-visible .upjau-category-tile__title {
	transform: translateY(3px);
}

.upjau-category-tile__link--nolink:hover {
	transform: none;
	box-shadow: var(--upjau-shadow-lg);
}

.upjau-category-tile__link--nolink:hover .upjau-category-tile__image {
	transform: none;
}

@media (prefers-reduced-motion: reduce) {
	.upjau-category-tile__link,
	.upjau-category-tile__image,
	.upjau-category-tile__title,
	.upjau-category-tile__link::after,
	.upjau-category-tile__link--clickable::before {
		transition: none;
	}

	.upjau-category-tile__link--clickable:hover,
	.upjau-category-tile__link--clickable:focus-visible {
		transform: none;
	}

	.upjau-category-tile__link--clickable:hover .upjau-category-tile__image,
	.upjau-category-tile__link--clickable:focus-visible .upjau-category-tile__image,
	.upjau-category-tile__link--clickable:hover .upjau-category-tile__title,
	.upjau-category-tile__link--clickable:focus-visible .upjau-category-tile__title {
		transform: none;
	}
}
