.category-container {
	display: flex;
	flex-direction: column;
	gap: 0;
}

/* ========================================
   CATEGORY HERO SECTION
   ======================================== */

.category-hero {
	position: relative;
	width: 100%;
	height: 400px;
	display: flex;
	align-items: center;
	justify-content: flex-start;
	overflow: hidden;
	margin-bottom: var(--padding-xlarge);
}

.category-hero-image {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: 1;
}

.category-hero-overlay {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: linear-gradient(
		to right,
		rgba(28, 46, 73, 0.9) 0%,
		rgba(28, 46, 73, 0.6) 50%,
		rgba(28, 46, 73, 0.4) 100%
	);
	z-index: 2;
}

.category-hero-content {
	position: relative;
	z-index: 3;
	max-width: var(--container-max-width);
	width: 100%;
	margin: 0 auto;
	padding: 0 5%;
	color: var(--color-white);
}

.category-breadcrumb {
	display: flex;
	align-items: center;
	gap: var(--padding-small);
	margin-bottom: var(--padding-default);
	font-size: var(--font-size-small);
	flex-wrap: wrap;
}

.category-breadcrumb a {
	color: var(--color-white);
	text-decoration: none;
	opacity: 0.9;
	transition: opacity var(--transition-fast);
}

.category-breadcrumb a:hover {
	opacity: 1;
	text-decoration: underline;
}

.category-breadcrumb-separator {
	opacity: 0.7;
}

.category-breadcrumb-current {
	opacity: 1;
	font-weight: var(--font-weight-medium);
}

.category-hero-title {
	font-size: 3rem;
	font-weight: var(--font-weight-bold);
	letter-spacing: -1.5px;
	line-height: 1.15;
	margin: 0 0 var(--padding-default) 0;
	color: var(--color-white);
}

.category-hero-description {
	font-size: var(--font-size-body);
	line-height: 1.6;
	margin: 0 0 var(--padding-default) 0;
	max-width: 600px;
	opacity: 0.95;
}

.category-hero-count {
	display: inline-flex;
	align-items: center;
	gap: var(--padding-small);
	padding: 10px 20px;
	background: rgba(255, 255, 255, 0.15);
	border-radius: 30px;
	font-size: var(--font-size-default);
	font-weight: var(--font-weight-medium);
	backdrop-filter: blur(10px);
}

.category-hero-count i {
	font-size: 1.1em;
}

/* Fallback Header (without hero image) */
.category-header {
	max-width: var(--container-max-width);
	margin: var(--padding-xlarge) auto;
	padding: 0 5%;
}

.category-header-title {
	font-size: 2.5rem;
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
	margin: var(--padding-default) 0;
}

.category-header-description {
	font-size: var(--font-size-body);
	line-height: 1.6;
	color: var(--color-text-secondary);
	margin-bottom: var(--padding-large);
}

/* Subcategories Section */
.category-subcategories {
	max-width: var(--container-max-width);
	margin: 0 auto var(--padding-xlarge) auto;
	padding: 0 5%;
}

.category-subcategories h3 {
	font-size: var(--font-size-h3);
	font-weight: var(--font-weight-semibold);
	color: var(--color-primary);
	margin-bottom: var(--padding-default);
}

.category-categoryList {
	display: flex;
	flex-direction: row;
	gap: var(--padding-default);
	flex-wrap: wrap;
}

.category-categoryList span.badge {
	font-size: var(--font-size-h5);
	font-weight: var(--font-weight-medium);
	padding: 10px 20px;
	transition: transform var(--transition-fast);
}

.category-categoryList a:hover span.badge {
	transform: translateY(-2px);
}

/* ========================================
   PRODUCTS SECTION
   ======================================== */

.category-relatedProducts {
	max-width: var(--container-max-width);
	margin: 0 auto var(--padding-xlarge) auto;
	padding: 0 5%;
}

.category-relatedProducts h2 {
	font-size: var(--font-size-h2);
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
	margin-bottom: var(--padding-large);
}

/* Responsive Product Grid - 1 to 6 columns */
.category-relatedProductsGrid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: var(--padding-large);
	margin-bottom: var(--padding-large);
}

.category-relatedProductCard {
	position: relative;
	display: flex;
	flex-direction: column;
	width: 100%;
	min-height: 340px;
	background: var(--color-white);
	border-radius: 20px;
	overflow: hidden;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
	transition: all var(--transition-default);
	text-decoration: none;
	color: inherit;
}

.category-relatedProductCard:hover {
	transform: translateY(-8px);
	box-shadow: 0 12px 24px rgba(0, 0, 0, 0.15);
	text-decoration: none;
}

.category-relatedProductCard .imgContainer {
	width: 100%;
	height: 240px;
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--color-background);
	padding: var(--padding-default);
}

.category-relatedProductCard img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	transition: transform var(--transition-default);
}

.category-relatedProductCard:hover img {
	transform: scale(1.05);
}

.category-relatedProductCard-body {
	display: flex;
	flex-direction: column;
	width: 100%;
	padding: var(--padding-large);
	background: var(--color-white);
	gap: var(--padding-small);
	flex: 1 1 auto;
}

.category-relatedProductCard-title {
	font-size: var(--font-size-h5);
	font-weight: 700;
	color: var(--color-primary);
	line-height: 1.3;
	margin: 0;
	overflow: hidden;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
}

/* Kategoria-värikoodit tuotekorteille */
.category-relatedProductCard[data-category="1"]::before,
.category-relatedProductCard[data-category="turquoise"]::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 6px;
	background: var(--color-category-1);
	z-index: 1;
}

.category-relatedProductCard[data-category="2"]::before,
.category-relatedProductCard[data-category="orange"]::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 6px;
	background: var(--color-category-2);
	z-index: 1;
}

.category-relatedProductCard[data-category="3"]::before,
.category-relatedProductCard[data-category="blue"]::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 6px;
	background: var(--color-category-3);
	z-index: 1;
}

.category-relatedProductCard[data-category="4"]::before,
.category-relatedProductCard[data-category="green"]::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 6px;
	background: var(--color-category-4);
	z-index: 1;
}

.category-relatedProductCard[data-category="5"]::before,
.category-relatedProductCard[data-category="purple"]::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 6px;
	background: var(--color-category-5);
	z-index: 1;
}

.category-relatedProductCard[data-category="6"]::before,
.category-relatedProductCard[data-category="red"]::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 6px;
	background: var(--color-category-6);
	z-index: 1;
}

/* ========================================
   EMPTY STATE
   ======================================== */

.category-empty-state {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: var(--padding-xlarge) var(--padding-default);
	min-height: 400px;
}

.category-empty-icon {
	font-size: 6rem;
	color: var(--color-grey);
	margin-bottom: var(--padding-large);
	opacity: 0.5;
}

.category-empty-title {
	font-size: var(--font-size-h3);
	font-weight: var(--font-weight-semibold);
	color: var(--color-primary);
	margin-bottom: var(--padding-default);
}

.category-empty-description {
	font-size: var(--font-size-body);
	color: var(--color-text-secondary);
	margin-bottom: var(--padding-large);
	max-width: 500px;
}

.category-empty-cta {
	display: inline-flex;
	align-items: center;
	gap: var(--padding-small);
}

/* ========================================
   RESPONSIVE BREAKPOINTS
   ======================================== */

/* XL Desktop: 6 columns (1920px+) */
@media (min-width: 1920px) {
	.category-relatedProductsGrid {
		grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
		gap: var(--padding-large);
	}
}

/* Large Desktop: 5 columns (1440px - 1919px) */
@media (min-width: 1440px) and (max-width: 1919px) {
	.category-relatedProductsGrid {
		grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
		gap: var(--padding-large);
	}
}

/* Desktop: 4 columns (1024px - 1439px) */
@media (min-width: 1024px) and (max-width: 1439px) {
	.category-relatedProductsGrid {
		grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
		gap: var(--padding-default);
	}

	.category-hero {
		height: 350px;
	}

	.category-hero-title {
		font-size: 2.5rem;
	}
}

/* Tablet: 3 columns (768px - 1023px) */
@media (min-width: 768px) and (max-width: 1023px) {
	.category-relatedProductsGrid {
		grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
		gap: var(--padding-default);
	}

	.category-hero {
		height: 300px;
	}

	.category-hero-title {
		font-size: 2rem;
	}

	.category-hero-description {
		font-size: var(--font-size-default);
	}

	.category-relatedProductCard {
		min-height: 320px;
	}

	.category-relatedProductCard .imgContainer {
		height: 200px;
	}
}

/* Large Mobile: 2 columns (480px - 767px) */
@media (min-width: 480px) and (max-width: 767px) {
	.category-relatedProductsGrid {
		grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
		gap: var(--padding-default);
	}

	.category-hero {
		height: 250px;
	}

	.category-hero-title {
		font-size: 1.75rem;
	}

	.category-hero-description {
		font-size: var(--font-size-default);
		margin-bottom: var(--padding-small);
	}

	.category-breadcrumb {
		font-size: 0.75rem;
	}

	.category-relatedProductCard {
		min-height: 300px;
	}

	.category-relatedProductCard .imgContainer {
		height: 180px;
	}

	.category-relatedProductCard-body {
		padding: var(--padding-default);
	}

	.category-relatedProductCard-title {
		font-size: var(--font-size-default);
	}
}

/* Mobile: 1 column (< 480px) */
@media (max-width: 479px) {
	.category-relatedProductsGrid {
		grid-template-columns: 1fr;
		gap: var(--padding-default);
	}

	.category-hero {
		height: 250px;
	}

	.category-hero-content {
		padding: 0 var(--padding-default);
	}

	.category-hero-title {
		font-size: 1.5rem;
		letter-spacing: -0.5px;
	}

	.category-hero-description {
		font-size: var(--font-size-small);
		margin-bottom: var(--padding-small);
	}

	.category-breadcrumb {
		font-size: 0.7rem;
		gap: 4px;
	}

	.category-hero-count {
		font-size: var(--font-size-small);
		padding: 8px 16px;
	}

	.category-subcategories,
	.category-relatedProducts {
		padding: 0 var(--padding-default);
	}

	.category-relatedProductCard {
		min-height: 320px;
	}

	.category-relatedProductCard .imgContainer {
		height: 200px;
	}

	.category-relatedProductCard-body {
		padding: var(--padding-default);
	}

	.category-relatedProductCard-title {
		font-size: var(--font-size-default);
	}

	.category-empty-state {
		padding: var(--padding-large) var(--padding-default);
	}

	.category-empty-icon {
		font-size: 4rem;
	}

	.category-empty-title {
		font-size: var(--font-size-h4);
	}

	.category-empty-description {
		font-size: var(--font-size-default);
	}
}
