/* ==========================================================================
   Page d'accueil - Le Clic à Vrac
   Sections, Carousel
   
   Note: .product-card est dans woocommerce.css (centralisé)
   ========================================================================== */

/* ==========================================================================
   Home Slider (Bandeau défilant)
   ========================================================================== */

.home-slider {
	background-color: var(--cav-primary);
	overflow: hidden;
}

.home-slider__track {
	display: flex;
	animation: home-slider-scroll 20s linear infinite;
}

.home-slider__track:hover {
	animation-play-state: paused;
}

@keyframes home-slider-scroll {
	0% {
		transform: translateX(0);
	}

	100% {
		transform: translateX(-50%);
	}
}

.home-slider__slide {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--cav-space-sm);
	flex-shrink: 0;
	padding: var(--cav-space-sm) var(--cav-space-xl);
	color: var(--cav-text-inverse);
	font-size: var(--cav-font-sm);
	font-weight: 600;
	text-decoration: none;
	white-space: nowrap;
	background: none;
	border: none;
	cursor: pointer;
	transition: opacity var(--cav-transition-fast);
}

.home-slider__slide:hover {
	opacity: 0.85;
	color: var(--cav-text-inverse);
}

.home-slider__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0.9;
}

.home-slider__text {
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.home-slider__slide::after {
	content: '•';
	margin-left: var(--cav-space-xl);
	opacity: 0.5;
}

/* ==========================================================================
   Home Sections (Nouveautés, Catégories)
   ========================================================================== */

.home-section {
	padding: var(--cav-space-sm) 0;
}

.home-section__header {
	margin-bottom: var(--cav-space-lg);
	display: flex;
	align-items: center;
	justify-content: flex-start;
	gap: var(--cav-space-md);
}

.home-section__title {
	margin: 0;
	font-family: var(--cav-font-heading);
	font-size: var(--cav-font-md);
	font-weight: 700;
	color: var(--cav-text);
	text-transform: uppercase;
	transition: color var(--cav-transition-fast);
}

.home-section__title-link {
	display: flex;
	align-items: center;
	gap: var(--cav-space-md);
	color: inherit;
	text-decoration: none;
}

.home-section__title-link:hover .home-section__title,
.home-section__title-link:hover .home-section__link {
	color: var(--cav-primary);
}

@media (min-width: 768px) {
	.home-section {
		padding: var(--cav-space-lg) 0 var(--cav-space-xl);
	}

	.home-section__header {
		max-width: var(--cav-container-max);
		margin-inline: auto;
		padding-inline: var(--cav-container-padding);
	}

	.home-section__title {
		font-size: var(--cav-font-xl);
	}
}

.home-section__link {
	display: inline-flex;
	align-items: center;
	gap: var(--cav-space-xs);
	font-size: var(--cav-font-sm);
	font-weight: 500;
	color: var(--cav-text-lighter);
	text-decoration: none;
	transition: color var(--cav-transition-fast);
}

.home-section__link:hover {
	color: var(--cav-primary);
}

@media (max-width: 768px) {
	.home-section {
		padding: var(--cav-space-sm) 0 var(--cav-space-lg);
	}

	.home-section .container {
		padding-inline: 0;
	}

	.home-section__header {
		padding-inline: var(--cav-container-padding);
		margin-bottom: var(--cav-space-xs);
	}
}

/* ==========================================================================
   Products Carousel
   ========================================================================== */

.products-carousel {
	position: relative;
	overflow: hidden;
}

.products-carousel__track {
	display: flex;
	align-items: stretch;
	gap: var(--cav-space-sm);
	overflow-x: auto;
	scroll-behavior: smooth;
	scroll-snap-type: x mandatory;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
	-ms-overflow-style: none;
	padding: var(--cav-space-sm) 0;
}

.products-carousel__track::-webkit-scrollbar {
	display: none;
}

/* Largeur fixe des slides */
.products-carousel__slide {
	flex: 0 0 160px;
	width: 160px;
	min-width: 160px;
	max-width: 160px;
	scroll-snap-align: start;
}

@media (min-width: 480px) {
	.products-carousel__slide {
		flex: 0 0 200px;
        width: 200px;
        min-width: 200px;
        max-width: 200px;
	}
}

@media (max-width: 768px) {
	.products-carousel {
		padding-inline-start: var(--cav-container-padding);
	}

	.products-carousel__track {
		padding-inline-end: var(--cav-container-padding);
	}
}

@media (min-width: 768px) {
	.products-carousel__track {
		gap: var(--cav-space-md);
	}

	.products-carousel__slide {
		flex: 0 0 240px;
		width: 240px;
		min-width: 240px;
		max-width: 240px;
	}
}

/* Carte produit dans carousel - forcer les dimensions */
.products-carousel__slide .product-card {
	width: 100%;
	height: 100%;
	max-width: 100%;
	overflow: hidden;
}

/* Image produit dans carousel */
.products-carousel__slide .product-card__image,
.products-carousel__slide .product-card__image-wrapper {
	position: relative;
	width: 100%;
	aspect-ratio: 1;
	overflow: hidden;
}

.products-carousel__slide .product-card__image img,
.products-carousel__slide .product-card img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	max-width: 100%;
	max-height: 100%;
}

/* Navigation du carrousel */
.products-carousel__nav {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	padding: 0;
	background-color: var(--cav-bg-alt);
	border: none;
	border-radius: var(--cav-radius-full);
	box-shadow: var(--cav-shadow-md);
	cursor: pointer;
	z-index: 10;
	transition: background-color var(--cav-transition-fast);
}

.products-carousel__nav:hover {
	background-color: var(--cav-primary);
	color: var(--cav-text-inverse);
}

.products-carousel__nav--prev {
	left: 0;
}

.products-carousel__nav--next {
	right: 0;
}

@media (max-width: 767px) {
	.products-carousel__nav {
		display: none;
	}
}

/* ==========================================================================
   Home Main (Fix padding)
   ========================================================================== */

.home .site-main {
	padding-top: 0;
}