/* ============================================
   WooCommerce Styles
   ============================================ */

/* Products Grid — override WooCommerce layout (float + 22% width) so cards fill grid cells */
.woocommerce ul.products {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--spacing-md);
	list-style: none;
	margin: 0;
	padding: 0;
	justify-content: start;
	justify-items: start;
}

.woocommerce ul.products li.product {
	width: 100% !important;
	float: none !important;
	margin: 0 !important;
	min-width: 0;
}

/* Single product in grid: align to first column (left) */
.woocommerce ul.products li.product:only-child {
	grid-column: 1;
}

@media (max-width: 1023px) {
	.woocommerce ul.products {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 767px) {
	.woocommerce ul.products {
		grid-template-columns: 1fr;
	}
}

/* ============================================
   Product Card — Premium Style
   ============================================ */

.woocommerce .product-card {
	list-style: none;
	margin: 0;
	background: white;
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04), 0 1px 3px rgba(0, 0, 0, 0.03);
	transition: 
		transform 0.45s cubic-bezier(0.23, 1, 0.32, 1),
		box-shadow 0.45s cubic-bezier(0.23, 1, 0.32, 1);
}

.woocommerce .product-card:hover {
	transform: translateY(-6px);
	box-shadow: 
		0 16px 32px rgba(0, 0, 0, 0.08),
		0 4px 12px rgba(0, 0, 0, 0.05);
}

.product-card__link {
	display: flex;
	flex-direction: column;
	height: 100%;
	text-decoration: none;
	color: inherit;
}

/* Image */
.product-card__image-wrap {
	position: relative;
	overflow: hidden;
	background: var(--color-bg-light);
}

.product-card__image {
	width: 100%;
	aspect-ratio: 1;
	object-fit: cover;
	display: block;
	transition: transform 0.6s cubic-bezier(0.23, 1, 0.32, 1);
}

.product-card:hover .product-card__image {
	transform: scale(1.08);
}

/* Sale badge */
.product-card__badge {
	position: absolute;
	top: 12px;
	left: 12px;
	padding: 4px 12px;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	border-radius: var(--radius-full);
	z-index: 2;
}

.product-card__badge--sale {
	background: #e53e3e;
	color: white;
}

/* Content */
.product-card__content {
	padding: var(--spacing-sm) var(--spacing-sm) 0;
	flex: 1;
	display: flex;
	flex-direction: column;
}

.product-card__title {
	font-size: 1rem;
	font-weight: 600;
	color: var(--color-heading);
	margin: 0 0 6px;
	line-height: 1.35;
	transition: color 0.3s ease;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.product-card:hover .product-card__title {
	color: var(--color-primary);
}

.product-card__excerpt {
	font-size: 0.8125rem;
	color: var(--color-text-light);
	line-height: 1.45;
	margin: 0 0 8px;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.product-card__price {
	font-size: 1.125rem;
	font-weight: 700;
	color: var(--color-primary);
	margin-top: auto;
}

.product-card__price del {
	color: var(--color-text-muted);
	font-weight: normal;
	font-size: 0.875rem;
	margin-right: var(--spacing-xs);
}

.product-card__price ins {
	text-decoration: none;
}

/* Footer / CTA area */
.product-card__footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--spacing-sm);
	border-top: 1px solid #f0f0f0;
	margin-top: var(--spacing-sm);
}

.product-card__cta {
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--color-primary);
	transition: color 0.3s ease;
}

.product-card:hover .product-card__cta {
	color: var(--color-primary-dark);
}

.product-card__arrow {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	background: var(--color-bg-light);
	border-radius: 50%;
	color: var(--color-primary);
	transition: all 0.3s ease;
	flex-shrink: 0;
}

.product-card:hover .product-card__arrow {
	background: var(--color-primary);
	color: white;
	transform: translateX(3px);
}

.product-card__arrow svg {
	transition: transform 0.3s ease;
}

.product-card:hover .product-card__arrow svg {
	transform: translateX(2px);
}

/* Responsive grid fix */
@media (max-width: 767px) {
	.woocommerce ul.products {
		grid-template-columns: repeat(2, 1fr);
		gap: var(--spacing-sm);
	}
	
	.product-card__content {
		padding: var(--spacing-xs) var(--spacing-xs) 0;
	}
	
	.product-card__title {
		font-size: 0.875rem;
	}
	
	.product-card__price {
		font-size: 1rem;
	}
	
	.product-card__footer {
		padding: var(--spacing-xs);
	}
	
	.product-card__cta {
		font-size: 0.75rem;
	}
}

@media (max-width: 400px) {
	.woocommerce ul.products {
		grid-template-columns: 1fr;
	}
}

/* Single Product */
.single-product-content {
	margin-top: var(--spacing-lg);
}

.single-product__grid {
	display: grid;
	grid-template-columns: 1.15fr 0.85fr;
	gap: var(--spacing-xl);
	margin-bottom: var(--spacing-xl);
}

@media (max-width: 767px) {
	.single-product__grid {
		grid-template-columns: 1fr;
	}
}

.single-product__images {
	position: sticky;
	top: 100px;
	align-self: start;
}

.woocommerce-product-gallery {
	margin-bottom: var(--spacing-md);
}

.woocommerce-product-gallery__image {
	margin-bottom: 0;
}

/* Main image: crisp rendering when scaled down from large size */
.woocommerce-product-gallery__image img {
	width: 100%;
	height: auto;
	border-radius: 0;
	display: block;
}

/* Thumbnails: small gap below main image, strictly square previews, image contained (no crop) */
.woocommerce-product-gallery .flex-control-thumbs,
.single-product-content .woocommerce-product-gallery .flex-control-thumbs {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin-top: 20px !important;
	margin-bottom: 0;
	list-style: none;
	padding: 0;
}

/* Override WooCommerce % width and float so thumbnails stay square and a good size (80px) */
.woocommerce-product-gallery .flex-control-thumbs li,
.woocommerce div.product div.images .woocommerce-product-gallery .flex-control-thumbs li {
	margin: 0 !important;
	width: 80px !important;
	height: 80px !important;
	min-width: 80px !important;
	min-height: 80px !important;
	max-width: 80px !important;
	max-height: 80px !important;
	float: none !important;
	flex-shrink: 0;
	aspect-ratio: 1;
	display: flex !important;
	align-items: center;
	justify-content: center;
	background: var(--color-bg-light);
	overflow: hidden;
	box-sizing: border-box;
}

.woocommerce-product-gallery .flex-control-thumbs li a {
	display: flex !important;
	align-items: center;
	justify-content: center;
	width: 100% !important;
	height: 100% !important;
	max-width: 80px;
	max-height: 80px;
	box-sizing: border-box;
}

/* Square box filled by image, no gray gaps (cover fills the box) */
.woocommerce-product-gallery .flex-control-thumbs img {
	display: block !important;
	width: 100% !important;
	height: 100% !important;
	max-width: 100% !important;
	max-height: 100% !important;
	object-fit: cover !important;
	object-position: center;
}

.woocommerce-product-gallery__trigger {
	position: absolute;
	top: var(--spacing-sm);
	right: var(--spacing-sm);
	background-color: rgba(255, 255, 255, 0.9);
	border: none;
	border-radius: 0;
	padding: var(--spacing-xs);
	cursor: pointer;
}

.single-product__summary {
	padding: var(--spacing-md);
}

.woocommerce .product_title {
	font-size: 2rem;
	margin-bottom: var(--spacing-md);
	color: var(--color-heading);
}

.woocommerce .price {
	font-size: 1.5rem;
	font-weight: 600;
	color: var(--color-primary);
	margin-bottom: var(--spacing-md);
}

.woocommerce .price del {
	color: var(--color-text-muted);
	font-weight: normal;
	font-size: 1rem;
	margin-right: var(--spacing-xs);
}

.woocommerce .woocommerce-product-details__short-description {
	margin-bottom: var(--spacing-md);
	color: var(--color-text-light);
	line-height: 1.7;
}

.woocommerce form.cart {
	margin-bottom: var(--spacing-lg);
}

.woocommerce .quantity {
	margin-right: var(--spacing-sm);
}

.woocommerce .quantity input[type="number"] {
	width: 80px;
	padding: 0.625rem;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	text-align: center;
}

.woocommerce .single_add_to_cart_button {
	padding: 0.875rem 2rem;
	background-color: var(--color-primary);
	color: white;
	border: none;
	border-radius: var(--radius-md);
	font-size: 1rem;
	font-weight: 500;
	cursor: pointer;
	transition: all var(--transition-base);
}

.woocommerce .single_add_to_cart_button:hover {
	background-color: var(--color-primary-dark);
	transform: translateY(-1px);
	box-shadow: var(--shadow-md);
}

.woocommerce .product_meta {
	margin-top: var(--spacing-lg);
	padding-top: var(--spacing-lg);
	border-top: 1px solid var(--color-border);
	font-size: 0.875rem;
	color: var(--color-text-light);
}

.woocommerce .product_meta span {
	display: block;
	margin-bottom: var(--spacing-xs);
}

.woocommerce .product_meta a {
	color: var(--color-primary);
	text-decoration: none;
}

.woocommerce .product_meta a:hover {
	text-decoration: underline;
}

/* Product Tabs */
.woocommerce-tabs {
	margin-top: var(--spacing-xl);
}

.woocommerce-tabs ul.tabs {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	border-bottom: 2px solid var(--color-border);
	margin-bottom: var(--spacing-md);
}

.woocommerce-tabs ul.tabs li {
	margin-right: var(--spacing-md);
}

.woocommerce-tabs ul.tabs li a {
	display: block;
	padding: var(--spacing-sm) 0;
	color: var(--color-text-light);
	text-decoration: none;
	font-weight: 500;
	border-bottom: 2px solid transparent;
	margin-bottom: -2px;
	transition: color var(--transition-base);
}

.woocommerce-tabs ul.tabs li.active a,
.woocommerce-tabs ul.tabs li a:hover {
	color: var(--color-primary);
	border-bottom-color: var(--color-primary);
}

.woocommerce-tabs .panel {
	padding: var(--spacing-md) 0;
}

.woocommerce-tabs .panel h2 {
	font-size: 1.25rem;
	margin-bottom: var(--spacing-sm);
}

/* ============================================
   Cart Block Tweaks
   ============================================ */

/* Hide duplicate calculator attributes if any legacy entries remain */
.wc-block-cart__main .wc-block-components-product-details__cup-size,
.wc-block-cart__main .wc-block-components-product-details__wall,
.wc-block-cart__main .wc-block-components-product-details__material {
	display: none;
}

/* Hide quantity selector; editing is done via calculator/product page */
.wc-block-cart__main .wc-block-components-quantity-selector {
	display: none;
}

/* Optional: style custom edit links if added later */
.lpc-cart-edit-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 4px 10px;
	border-radius: 999px;
	border: 1px solid var(--color-border);
	font-size: 0.8125rem;
	color: var(--color-text);
	text-decoration: none;
	margin-top: 4px;
}

.lpc-cart-edit-link:hover {
	border-color: var(--color-primary);
	color: var(--color-primary);
}

/* Shop Toolbar */
/* Hide result count and sorting on category/shop archives */
.woocommerce .woocommerce-result-count {
	display: none !important;
}

.woocommerce .woocommerce-ordering {
	display: none !important;
}

.woocommerce .woocommerce-ordering select {
	padding: 0.625rem 1rem;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	font-size: 0.875rem;
	background-color: white;
}

.woocommerce-result-count {
	margin-bottom: var(--spacing-md);
	color: var(--color-text-light);
	font-size: 0.875rem;
}

/* Buttons */
.woocommerce .button,
.woocommerce button.button,
.woocommerce input.button {
	background-color: var(--color-primary);
	color: white;
	border: none;
	padding: 0.75rem 1.5rem;
	border-radius: var(--radius-md);
	font-size: 0.875rem;
	font-weight: 500;
	cursor: pointer;
	transition: all var(--transition-base);
	text-decoration: none;
	display: inline-block;
}

.woocommerce .button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover {
	background-color: var(--color-primary-dark);
	color: white;
	transform: translateY(-1px);
	box-shadow: var(--shadow-sm);
}

.woocommerce .button.alt {
	background-color: var(--color-accent);
}

.woocommerce .button.alt:hover {
	background-color: var(--color-accent-dark);
}

/* Messages */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
	padding: var(--spacing-sm) var(--spacing-md);
	margin-bottom: var(--spacing-md);
	border-radius: var(--radius-md);
	border-left: 4px solid;
}

.woocommerce-message {
	background-color: #e8f5e9;
	border-color: var(--color-primary);
	color: #2e7d32;
}

.woocommerce-info {
	background-color: #e3f2fd;
	border-color: #2196f3;
	color: #1565c0;
}

.woocommerce-error {
	background-color: #ffebee;
	border-color: #f44336;
	color: #c62828;
}

/* Related Products */
.woocommerce .related {
	margin-top: var(--spacing-2xl);
	padding-top: var(--spacing-xl);
	border-top: 1px solid var(--color-border);
}

.woocommerce .related h2 {
	margin-bottom: var(--spacing-lg);
}

/* Star Rating */
.woocommerce .star-rating {
	color: #ffc107;
	font-size: 1rem;
	overflow: hidden;
	position: relative;
	height: 1em;
	line-height: 1;
	width: 5.4em;
	font-family: star;
}

.woocommerce .star-rating::before {
	content: "\73\73\73\73\73";
	float: left;
	top: 0;
	left: 0;
	position: absolute;
}

.woocommerce .star-rating span {
	overflow: hidden;
	float: left;
	top: 0;
	left: 0;
	position: absolute;
	padding-top: 1.5em;
}

.woocommerce .star-rating span::before {
	content: "\53\53\53\53\53";
	top: 0;
	position: absolute;
	left: 0;
}

/* ============================================
   Subcategories Grid - Animated Cards
   ============================================ */

/* Keyframe Animations */
@keyframes fadeInUp {
	from {
		opacity: 0;
		transform: translateY(30px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes shimmer {
	0% {
		background-position: -200% 0;
	}
	100% {
		background-position: 200% 0;
	}
}

@keyframes pulse-glow {
	0%, 100% {
		box-shadow: 0 4px 15px rgba(122, 155, 122, 0.1);
	}
	50% {
		box-shadow: 0 8px 30px rgba(122, 155, 122, 0.25);
	}
}

/* Section Container */
.subcategories-section {
	margin-bottom: var(--spacing-xl);
	padding-bottom: var(--spacing-lg);
	border-bottom: 1px solid var(--color-border);
}

.subcategories-section__title {
	font-size: 1.25rem;
	font-weight: 600;
	color: var(--color-heading);
	margin-bottom: var(--spacing-md);
	position: relative;
	padding-left: var(--spacing-sm);
}

.subcategories-section__title::before {
	content: '';
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 4px;
	height: 70%;
	background: linear-gradient(180deg, var(--color-primary), var(--color-accent));
	border-radius: 2px;
}

/* Grid Layout */
.subcategories-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--spacing-md);
}

@media (max-width: 1199px) {
	.subcategories-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (max-width: 991px) {
	.subcategories-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 575px) {
	.subcategories-grid {
		grid-template-columns: 1fr;
		gap: var(--spacing-sm);
	}
}

/* Individual Card */
.subcategory-card {
	display: flex;
	flex-direction: column;
	background: white;
	border-radius: var(--radius-lg);
	overflow: hidden;
	text-decoration: none;
	color: inherit;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04), 0 4px 20px rgba(0, 0, 0, 0.02);
	transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
	animation: fadeInUp 0.6s ease-out forwards;
	animation-delay: var(--animation-delay, 0s);
	opacity: 0;
	position: relative;
}

.subcategory-card::before {
	content: '';
	position: absolute;
	inset: 0;
	border-radius: var(--radius-lg);
	padding: 2px;
	background: linear-gradient(135deg, transparent 40%, var(--color-primary) 100%);
	-webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
	mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
	-webkit-mask-composite: xor;
	mask-composite: exclude;
	opacity: 0;
	transition: opacity 0.4s ease;
}

.subcategory-card:hover {
	transform: translateY(-8px) scale(1.02);
	box-shadow: 0 12px 40px rgba(122, 155, 122, 0.15), 0 4px 12px rgba(0, 0, 0, 0.08);
}

.subcategory-card:hover::before {
	opacity: 1;
}

/* Image Wrapper */
.subcategory-card__image-wrapper {
	position: relative;
	overflow: hidden;
	background: var(--color-bg-light);
}

.subcategory-card__image {
	width: 100%;
	height: auto;
	display: block;
	transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.subcategory-card:hover .subcategory-card__image {
	transform: scale(1.1);
}

/* Overlay Effect */
.subcategory-card__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		to bottom,
		transparent 0%,
		transparent 50%,
		rgba(0, 0, 0, 0.03) 100%
	);
	transition: background 0.4s ease;
}

.subcategory-card:hover .subcategory-card__overlay {
	background: linear-gradient(
		to bottom,
		rgba(122, 155, 122, 0.05) 0%,
		rgba(122, 155, 122, 0.1) 50%,
		rgba(122, 155, 122, 0.15) 100%
	);
}

/* Badge for subcategories count */
.subcategory-card__badge {
	position: absolute;
	top: var(--spacing-sm);
	right: var(--spacing-sm);
	display: flex;
	align-items: center;
	gap: 4px;
	background: white;
	color: var(--color-primary);
	font-size: 0.75rem;
	font-weight: 600;
	padding: 6px 10px;
	border-radius: var(--radius-full);
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
	transition: all 0.3s ease;
}

.subcategory-card:hover .subcategory-card__badge {
	background: var(--color-primary);
	color: white;
	transform: scale(1.05);
}

.subcategory-card__badge svg {
	flex-shrink: 0;
}

/* Card Content */
.subcategory-card__content {
	padding: var(--spacing-sm);
	flex: 1;
	display: flex;
	flex-direction: column;
}

.subcategory-card__title {
	font-size: 1rem;
	font-weight: 600;
	color: var(--color-heading);
	margin: 0;
	transition: color 0.3s ease;
	line-height: 1.3;
}

.subcategory-card:hover .subcategory-card__title {
	color: var(--color-primary);
}

.subcategory-card__description {
	font-size: 0.8125rem;
	color: var(--color-text-light);
	line-height: 1.4;
	margin: 4px 0 0;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* Footer with count and arrow */
.subcategory-card__footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-top: var(--spacing-xs);
	padding-top: var(--spacing-xs);
	border-top: 1px solid var(--color-border-light, #f0f0f0);
}

.subcategory-card__count {
	font-size: 0.8125rem;
	color: var(--color-text-muted);
	font-weight: 500;
	position: relative;
}

.subcategory-card__count::before {
	content: '';
	display: inline-block;
	width: 6px;
	height: 6px;
	background: var(--color-primary);
	border-radius: 50%;
	margin-right: 8px;
	vertical-align: middle;
	animation: pulse-glow 2s ease-in-out infinite;
}

.subcategory-card__arrow {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	background: var(--color-bg-light);
	border-radius: 50%;
	color: var(--color-primary);
	transition: all 0.3s ease;
}

.subcategory-card:hover .subcategory-card__arrow {
	background: var(--color-primary);
	color: white;
	transform: translateX(4px);
}

.subcategory-card__arrow svg {
	transition: transform 0.3s ease;
}

.subcategory-card:hover .subcategory-card__arrow svg {
	transform: translateX(2px);
}

/* Shimmer loading effect (optional) */
.subcategory-card--loading .subcategory-card__image-wrapper {
	background: linear-gradient(
		90deg,
		#f0f0f0 25%,
		#e0e0e0 50%,
		#f0f0f0 75%
	);
	background-size: 200% 100%;
	animation: shimmer 1.5s infinite;
}

/* Alternative compact style for many subcategories */
@media (min-width: 992px) {
	.subcategories-grid--compact {
		grid-template-columns: repeat(5, 1fr);
	}
	
	.subcategories-grid--compact .subcategory-card__image-wrapper {
		aspect-ratio: 1;
	}
	
	.subcategories-grid--compact .subcategory-card__description {
		display: none;
	}
}
