/* ==========================================================================
   Header & Footer - Le Clic à Vrac
   Styles complémentaires pour matcher la structure HTML
   ========================================================================== */

/* ==========================================================================
   Site Header Container
   ========================================================================== */

.site-header {
	position: sticky;
	top: 0;
	z-index: 100;
	background-color: var(--cav-bg-alt);
	box-shadow: var(--cav-shadow-md);
	transition: box-shadow var(--cav-transition-normal);
}

.site-header--scrolled {
	box-shadow: var(--cav-shadow-lg);
}

/* ==========================================================================
   Bouton Créneau (header principal)
   ========================================================================== */

.header__slot-btn {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 2px;
	font-family: inherit;
	font-size: var(--cav-font-sm);
	font-weight: 600;
	text-decoration: none;
	border: none;
	cursor: pointer;
	transition: background-color var(--cav-transition-fast);
}

/* Label "Prochain créneau disponible" - intégré dans le bouton */
.header__slot-label {
	font-size: var(--cav-font-sm);
	font-weight: 600;
	color: var(--cav-text);
	text-align: center;
	line-height: 1.2;
}

/* Contenu du bouton (icône + texte + chevron) */
.header__slot-content {
	display: flex;
	align-items: center;
	gap: var(--cav-space-xs);
}

.header__slot-text {
	display: inline;
}

/* Bouton créneau mobile */
.header__slot-btn--mobile {
	padding: var(--cav-space-xs) var(--cav-space-md);
	background-color: var(--cav-secondary);
	border: none;
	border-radius: var(--cav-radius-full);
}

.header__slot-btn--mobile .header__slot-label {
	font-size: var(--cav-font-xs);
}

.header__slot-btn--mobile .header__slot-content {
	font-size: var(--cav-font-xs);
	color: var(--cav-text-inverse);
}

.header__slot-btn--mobile:hover {
	background-color: var(--cav-secondary-dark);
}

.header__slot-btn--mobile .header__slot-text {
	max-width: 120px;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

/* Bouton créneau desktop (quand connecté) */
.header__slot-btn--desktop {
	padding: var(--cav-space-sm) var(--cav-space-lg);
	background-color: var(--cav-secondary);
	border-radius: var(--cav-radius-full);
}

.header__slot-btn--desktop:hover {
	background-color: var(--cav-secondary-dark);
}

.header__slot-btn--desktop .header__slot-content {
	color: var(--cav-text-inverse);
}

/* ==========================================================================
   Header Main
   ========================================================================== */

.header__main {
	background-color: var(--cav-bg-alt);
	border-bottom: 1px solid var(--cav-border);
}

/* Desktop : header principal avec fond primary */
@media (min-width: 768px) {
	.header__main {
		background-color: var(--cav-primary);
		border-bottom: none;
	}
}

.header__inner {
	padding: var(--cav-space-sm) 0;
	display: flex;
	align-items: center;
	gap: var(--cav-space-md);
	min-height: var(--cav-header-height);
}

/* Bouton S'inscrire / Se connecter */
.header__login-btn {
	display: inline-flex;
	align-items: center;
	padding: var(--cav-space-sm) var(--cav-space-lg);
	font-size: var(--cav-font-sm);
	font-weight: 600;
	color: var(--cav-text-inverse);
	background-color: var(--cav-secondary);
	border-radius: var(--cav-radius-full);
	text-decoration: none;
	white-space: nowrap;
	transition: background-color var(--cav-transition-fast);
}

.header__login-btn:hover {
	background-color: var(--cav-secondary-dark);
	color: var(--cav-text-inverse);
}

/* Bouton S'inscrire / Se connecter - version mobile */
.header__login-btn--mobile {
	padding: var(--cav-space-sm) var(--cav-space-md);
	font-size: var(--cav-font-xs);
	background-color: var(--cav-primary);
}

.header__login-btn--mobile:hover {
	background-color: var(--cav-primary-dark);
}

.header__logo {
	flex-shrink: 0;
}

.header__logo a,
.header__logo-link {
	display: flex;
	align-items: center;
}

.header__logo img,
.header__logo .custom-logo {
	height: 50px;
	width: auto;
}

@media (min-width: 768px) {
	.header__logo {
		background-color: var(--cav-bg-alt);
		border-radius: var(--cav-radius-full);
	}

	.header__logo img,
	.header__logo .custom-logo {
		height: 90px;
	}
}

.header__logo-text {
	font-family: var(--cav-font-heading);
	font-size: var(--cav-font-xl);
	font-weight: 700;
	color: var(--cav-primary);
}

.header__search {
	flex: 1;
	max-width: 500px;
	margin: 0 auto;
	display: none;
}

@media (min-width: 768px) {
	.header__search {
		display: block;
	}
}

.header__search-form {
	position: relative;
	display: flex;
	align-items: center;
}

.header__search-input {
	width: 100%;
	padding: var(--cav-space-md);
	padding-right: 44px;
	font-family: inherit;
	font-size: var(--cav-font-sm);
	color: var(--cav-text);
	background-color: var(--cav-bg-alt);
	border: 1px solid transparent;
	border-radius: var(--cav-radius-full);
	transition: border-color var(--cav-transition-fast), box-shadow var(--cav-transition-fast);
}

.header__search-input:focus {
	outline: none;
	border-color: var(--cav-primary);
	box-shadow: 0 0 0 3px rgb(59 154 156 / 0.1);
}

.header__search-input::placeholder {
	color: var(--cav-text-lighter);
}

.header__search-btn {
	position: absolute;
	right: var(--cav-space-sm);
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	padding: 0;
	color: var(--cav-text-inverse);
	background-color: var(--cav-primary);
	border: none;
	border-radius: var(--cav-radius-full);
	cursor: pointer;
	transition: background-color var(--cav-transition-fast);
}

.header__search-btn:hover {
	background-color: var(--cav-primary-dark);
}

/* Desktop : bouton recherche blanc, collé à droite */
@media (min-width: 768px) {
	.header__search-btn {
		right: var(--cav-space-sm);
		height: 100%;
		max-height: 100%;
		color: var(--cav-text);
		background-color: var(--cav-bg-alt);
		border-radius: 0 var(--cav-radius-full) var(--cav-radius-full) 0;
	}

	.header__search-btn:hover {
		background-color: var(--cav-border);
	}
}

.header__actions {
	display: flex;
	align-items: center;
	gap: var(--cav-space-xs);
	margin-left: auto;
}

@media (min-width: 768px) {
	.header__actions {
		gap: var(--cav-space-sm);
	}
}

.header__account-btn,
.header__cart-btn,
.header__favorites-btn {
	display: flex;
	align-items: center;
	gap: var(--cav-space-xs);
	padding: var(--cav-space-sm);
	color: var(--cav-text);
	background: none;
	border: none;
	border-radius: var(--cav-radius-md);
	text-decoration: none;
	cursor: pointer;
	font: inherit;
	transition: background-color var(--cav-transition-fast), color var(--cav-transition-fast);
}

.header__account-btn:hover,
.header__cart-btn:hover,
.header__favorites-btn:hover {
	background-color: var(--cav-bg);
	color: var(--cav-primary);
}

/* Desktop : icônes blanches sur fond primary, disposition verticale */
@media (min-width: 768px) {
	.header__account-btn,
	.header__cart-btn,
	.header__favorites-btn {
		flex-direction: column;
		align-items: center;
		gap: 2px;
		padding: var(--cav-space-xs) var(--cav-space-sm);
		color: var(--cav-text-inverse);
	}

	.header__account-btn svg,
	.header__cart-btn svg,
	.header__favorites-btn svg {
		width: 24px;
		height: 24px;
	}

	.header__account-btn:hover,
	.header__cart-btn:hover,
	.header__favorites-btn:hover {
		background-color: rgba(255, 255, 255, 0.15);
		color: var(--cav-text-inverse);
	}
}

@media (max-width: 767px) {
	.header__favorites-btn,
	.header__cart-btn {
		display: none;
	}
}

.header__account-text {
	display: none;
	font-size: var(--cav-font-sm);
	font-weight: 500;
	text-align: center;
}

/* Afficher le texte du compte en desktop */
@media (min-width: 768px) {
	.header__account-text {
		display: block;
	}
}

.header__icon {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
}

.header__icon-label {
	position: absolute;
	width: 1px;
	height: 1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
}

/* Afficher le texte sous les icônes en desktop */
@media (min-width: 768px) {
	.header__icon-label {
		position: static;
		width: auto;
		height: auto;
		overflow: visible;
		clip: auto;
		font-size: var(--cav-font-sm);
		font-weight: 500;
		text-align: center;
	}
}

.header__cart-count {
	position: absolute;
	top: -4px;
	right: -4px;
	min-width: 18px;
	height: 18px;
	padding: 0 4px;
	font-size: 11px;
	font-weight: 700;
	line-height: 18px;
	text-align: center;
	color: var(--cav-text-inverse);
	background-color: var(--cav-secondary);
	border-radius: var(--cav-radius-full);
}

/* ==========================================================================
   Header Categories Navigation
   ========================================================================== */

.header__categories {
	display: none;
	background-color: var(--cav-bg-alt);
	border-bottom: 1px solid var(--cav-border);
}

@media (min-width: 768px) {
	.header__categories {
		display: block;
	}
}

.header__categories-list {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--cav-space-md);
	max-width: var(--cav-container-max);
	margin: 0 auto;
	padding: var(--cav-space-sm) var(--cav-container-padding);
	list-style: none;
}

@media (min-width: 1024px) {
	.header__categories-list {
		gap: var(--cav-space-lg);
	}
}

.header__categories-item {
	position: relative;
}

.header__categories-link {
	display: flex;
	align-items: center;
	gap: var(--cav-space-xs);
	padding: var(--cav-space-sm) 0;
	font-size: var(--cav-font-base);
	font-weight: 700;
	color: var(--cav-text);
	text-decoration: none;
	text-transform: uppercase;
	letter-spacing: 0.03em;
	transition: color var(--cav-transition-fast);
}

.header__categories-link:hover {
	color: var(--cav-primary);
}

.header__categories-item--all .header__categories-link {
	color: var(--cav-primary);
}

/* Masquer les flèches indicateurs de sous-menu */
.header__categories-icon {
	display: none;
}

/* Sous-catégories dropdown */
.header__subcategories {
	position: absolute;
	top: 100%;
	left: 50%;
	transform: translateX(-50%);
	z-index: 50;
	min-width: 200px;
	padding-top: var(--cav-space-sm);
	opacity: 0;
	visibility: hidden;
	transition: opacity var(--cav-transition-fast), visibility var(--cav-transition-fast);
}

.header__categories-item:hover .header__subcategories {
	opacity: 1;
	visibility: visible;
}

.header__subcategories-inner {
	background-color: var(--cav-bg-alt);
	border-radius: var(--cav-radius-lg);
	box-shadow: var(--cav-shadow-lg);
	overflow: hidden;
}

.header__subcategories-list {
	margin: 0;
	padding: var(--cav-space-sm) 0;
	list-style: none;
}

.header__subcategories-item {
	margin: 0;
}

.header__subcategories-link {
	display: block;
	padding: var(--cav-space-sm) var(--cav-space-lg);
	font-size: var(--cav-font-sm);
	color: var(--cav-text);
	text-decoration: none;
	transition: background-color var(--cav-transition-fast), color var(--cav-transition-fast);
}

.header__subcategories-link:hover {
	background-color: var(--cav-bg);
	color: var(--cav-primary);
}

/* ==========================================================================
   Mobile Nav - Menu Rayons
   ========================================================================== */

.mobile-nav {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: var(--cav-mobile-nav-height);
	z-index: 150; /* En dessous de la bottom-nav (z-index: 200) */
	visibility: hidden;
	transition: visibility var(--cav-transition-base);
}

.mobile-nav[aria-hidden="false"] {
	visibility: visible;
}

.mobile-nav__overlay {
	position: absolute;
	inset: 0;
	background-color: rgba(0, 0, 0, 0.5);
	opacity: 0;
	transition: opacity var(--cav-transition-base);
}

.mobile-nav[aria-hidden="false"] .mobile-nav__overlay {
	opacity: 1;
}

.mobile-nav__panel {
	position: absolute;
	inset: 0;
	display: flex;
	flex-direction: column;
	background-color: var(--cav-bg);
	transform: translateX(-100%);
	transition: transform var(--cav-transition-base);
}

.mobile-nav[aria-hidden="false"] .mobile-nav__panel {
	transform: translateX(0);
}

/* Header : Recherche + Fermeture */
.mobile-nav__header {
	display: flex;
	align-items: center;
	gap: var(--cav-space-sm);
	padding: var(--cav-space-md);
	background-color: var(--cav-bg-alt);
	border-bottom: 1px solid var(--cav-border);
}

.mobile-nav__search-form {
	flex: 1;
	position: relative;
	display: flex;
	align-items: center;
}

.mobile-nav__search-input {
	width: 100%;
	padding: var(--cav-space-sm) var(--cav-space-md);
	padding-right: 48px;
	font-family: inherit;
	font-size: var(--cav-font-base);
	color: var(--cav-text);
	background-color: var(--cav-bg);
	border: 1px solid var(--cav-border);
	border-radius: var(--cav-radius-full);
	transition: border-color var(--cav-transition-fast);
}

.mobile-nav__search-input:focus {
	outline: none;
	border-color: var(--cav-primary);
}

.mobile-nav__search-btn {
	position: absolute;
	right: 4px;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	padding: 0;
	color: var(--cav-text-inverse);
	background-color: var(--cav-primary);
	border: none;
	border-radius: var(--cav-radius-full);
	cursor: pointer;
	transition: background-color var(--cav-transition-fast);
}

.mobile-nav__search-btn:hover {
	background-color: var(--cav-primary-dark);
}

.mobile-nav__close {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	padding: 0;
	color: var(--cav-text);
	background-color: transparent;
	border: none;
	border-radius: var(--cav-radius-md);
	cursor: pointer;
	transition: background-color var(--cav-transition-fast);
}

.mobile-nav__close:hover {
	background-color: var(--cav-bg);
}

/* Barre titre */
.mobile-nav__title-bar {
	display: flex;
	align-items: center;
	gap: var(--cav-space-sm);
	padding: var(--cav-space-md);
	background-color: transparent;
	border-bottom: 1px solid var(--cav-border);
}

.mobile-nav__back {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	padding: 0;
	color: var(--cav-text);
	background: transparent;
	border: none;
	border-radius: var(--cav-radius-md);
	cursor: pointer;
	transition: background-color var(--cav-transition-fast);
}

.mobile-nav__back:hover {
	background: var(--cav-bg-alt);
}

.mobile-nav__back[hidden] {
	display: none;
}

.mobile-nav__title {
	flex: 1;
	font-family: var(--cav-font-heading);
	font-size: var(--cav-font-lg);
	font-weight: 700;
	color: var(--cav-primary);
	text-transform: uppercase;
}

/* Content - Swiper */
.mobile-nav__content {
	flex: 1;
	overflow: hidden;
}

.mobile-nav__slider {
	height: 100%;
}

.mobile-nav__slider .swiper-wrapper {
	height: 100%;
}

.mobile-nav__slide {
	height: 100%;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
}

/* Liste des catégories */
.mobile-nav__list {
	margin: 0;
	padding: var(--cav-space-sm) 0;
	list-style: none;
}

.mobile-nav__item {
	display: flex;
	align-items: stretch;
}

.mobile-nav__link {
	flex: 1;
	display: flex;
	align-items: center;
	gap: var(--cav-space-md);
	padding: var(--cav-space-sm) var(--cav-space-md);
	font-size: var(--cav-font-base);
	font-weight: 600; /* Plus gras */
	color: var(--cav-text);
	text-decoration: none;
	transition: background-color var(--cav-transition-fast);
}

.mobile-nav__link:active {
	background-color: var(--cav-bg-alt);
}

/* Style bouton identique au lien */
.mobile-nav__link--button {
	border: none;
	background: none;
	cursor: pointer;
	text-align: left;
}

.mobile-nav__image {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	border-radius: var(--cav-radius-full);
	overflow: hidden;
	background-color: var(--cav-bg-alt);
}

.mobile-nav__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.mobile-nav__image--placeholder,
.mobile-nav__image--icon {
	color: var(--cav-text-light);
}

.mobile-nav__label {
	flex: 1;
}

.mobile-nav__count {
	font-size: var(--cav-font-sm);
	font-weight: 400;
	color: var(--cav-text-light);
}

.mobile-nav__arrow {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 56px;
	padding: 0;
	color: var(--cav-text-light);
	background-color: transparent;
	border: none;
	cursor: pointer;
	transition: color var(--cav-transition-fast);
}

.mobile-nav__arrow:hover,
.mobile-nav__arrow:focus {
	color: var(--cav-primary);
}

/* Body state */
body.mobile-nav-open {
	overflow: hidden;
}

/* Masquer sur desktop */
@media (min-width: 768px) {
	.mobile-nav {
		display: none;
	}
}

/* ==========================================================================
   Search Suggestions (Desktop + Mobile)
   ========================================================================== */

.search-suggestions {
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	z-index: 1000;
	background: var(--cav-bg);
	border-radius: var(--cav-radius-lg);
	box-shadow: var(--cav-shadow-lg);
	margin-top: var(--cav-space-xs);
	max-height: 400px;
	overflow-y: auto;
	opacity: 0;
	visibility: hidden;
	transform: translateY(-10px);
	transition: opacity var(--cav-transition-fast), transform var(--cav-transition-fast), visibility var(--cav-transition-fast);
}

.search-suggestions--visible {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.search-suggestions__loader {
	display: flex;
	align-items: center;
	gap: var(--cav-space-sm);
	padding: var(--cav-space-md);
	color: var(--cav-text-light);
	font-size: var(--cav-font-sm);
}

.search-suggestions__spinner {
	width: 16px;
	height: 16px;
	border: 2px solid var(--cav-border);
	border-top-color: var(--cav-primary);
	border-radius: 50%;
	animation: spin 0.6s linear infinite;
}

@keyframes spin {
	to {
		transform: rotate(360deg);
	}
}

.search-suggestions__empty {
	padding: var(--cav-space-md);
	text-align: center;
	color: var(--cav-text-light);
	font-size: var(--cav-font-sm);
}

.search-suggestions__item {
	border-bottom: 1px solid var(--cav-border);
}

.search-suggestions__item:last-of-type {
	border-bottom: none;
}

.search-suggestions__item--focused,
.search-suggestions__item:hover {
	background-color: var(--cav-bg-alt);
}

.search-suggestions__link {
	display: flex;
	align-items: center;
	gap: var(--cav-space-sm);
	padding: var(--cav-space-sm) var(--cav-space-md);
	text-decoration: none;
	color: inherit;
}

.search-suggestions__image {
	width: 50px;
	height: 50px;
	object-fit: cover;
	border-radius: var(--cav-radius-md);
	background: var(--cav-bg-alt);
	flex-shrink: 0;
}

.search-suggestions__info {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.search-suggestions__title {
	font-size: var(--cav-font-sm);
	font-weight: 600;
	color: var(--cav-text);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.search-suggestions__title mark {
	background: rgba(59, 154, 156, 0.2);
	color: var(--cav-primary);
	padding: 0 2px;
	border-radius: 2px;
}

.search-suggestions__price {
	font-size: var(--cav-font-xs);
	color: var(--cav-primary);
	font-weight: 600;
}

.search-suggestions__view-all {
	display: block;
	padding: var(--cav-space-sm) var(--cav-space-md);
	text-align: center;
	font-size: var(--cav-font-sm);
	color: var(--cav-primary);
	text-decoration: none;
	border-top: 1px solid var(--cav-border);
	background: var(--cav-bg-alt);
	border-radius: 0 0 var(--cav-radius-lg) var(--cav-radius-lg);
	transition: background-color var(--cav-transition-fast);
}

.search-suggestions__view-all:hover {
	background: var(--cav-border);
}

/* Mobile search suggestions specifics */
.mobile-nav__search-form .search-suggestions {
	left: calc(-1 * var(--cav-space-md));
	right: calc(-1 * var(--cav-space-md) - 60px);
	border-radius: 0;
	margin-top: 0;
	max-height: 50vh;
}

/* ==========================================================================
   Footer
   ========================================================================== */

.site-footer {
	background-color: var(--cav-bg);
	color: var(--cav-text);
}

/* Supprimer TOUTES les puces partout dans le footer */
.site-footer ul,
.site-footer li,
.footer__menu,
.footer__menu li,
.footer__contact-list,
.footer__contact-list li,
.footer__legal-menu,
.footer__legal-menu li {
	list-style: none !important;
	list-style-type: none !important;
	margin-left: 0 !important;
	padding-left: 0 !important;
}

.site-footer ul::before,
.site-footer li::before,
.site-footer li::marker {
	display: none !important;
	content: '' !important;
}

.footer__main {
	padding: var(--cav-space-lg) 0;
}

/* Grid footer */
.footer__grid {
	display: grid;
	gap: var(--cav-space-sm);
	grid-template-columns: 1fr;
}

@media (min-width: 576px) {
	.footer__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 767px) {
	.site-footer {
		padding-bottom: var(--cav-mobile-nav-height);
	}

	.single-product .site-footer {
		padding-bottom: calc(var(--cav-mobile-nav-height) + var(--cav-product-cta-height, 70px));
	}
}

@media (min-width: 992px) {
	.footer__grid {
		grid-template-columns: 1fr 1.5fr 1.5fr 1fr;
		gap: var(--cav-space-2xl);
	}
}

/* Logo */
.footer__col--brand {
	order: -1;
	display: flex;
	justify-content: center;
}

@media (max-width: 767px) {
	.footer__col--brand {
		margin-bottom: var(--cav-space-md);
	}
}

.footer__col--brand .footer__logo-link {
	display: flex;
	justify-content: center;
}

.footer__logo img,
.footer__logo .custom-logo {
	height: clamp(70px, 6.5rem, 140px);
	width: auto;
	object-fit: contain;
}

@media (max-width: 767px) {
	.footer__logo img,
	.footer__logo .custom-logo {
		height: 65px;
	}
}

/* Masquer newsletter */
.footer__col--newsletter {
	display: none !important;
}

/* Titres */
.footer__title {
	margin: 0 0 var(--cav-space-sm);
	font-family: var(--cav-font-heading);
	font-size: var(--cav-font-lg);
	font-weight: 700;
	font-style: italic;
	color: var(--cav-primary);
}

/* Contact */
.footer__contact-list {
	margin: 0;
	padding: 0;
}

.footer__contact-item {
	display: block;
	margin-bottom: var(--cav-space-sm);
	font-size: var(--cav-font-sm);
	color: var(--cav-text);
}

@media (min-width: 768px) {
	.footer__contact-item {
		font-size: var(--cav-font-base);
	}
}

.footer__contact-item svg {
	display: none;
}

.footer__contact-label {
	display: block;
	font-weight: 900;
	color: var(--cav-secondary);
	margin-bottom: var(--cav-space-xs);
}

.footer__contact-item a {
	color: var(--cav-text);
	text-decoration: none;
}

.footer__contact-item a:hover {
	color: var(--cav-primary);
}

/* Menu navigation */
.footer__menu {
	margin: 0;
	padding: 0;
}

.footer__menu a {
	font-size: var(--cav-font-base);
	font-weight: 500;
	color: var(--cav-text);
	text-decoration: none;
}

@media (min-width: 768px) {
	.footer__menu a {
		font-size: var(--cav-font-md);
	}
}

.footer__menu a:hover {
	color: var(--cav-primary);
}

/* Réseaux sociaux */
.footer__social {
	display: flex;
	gap: var(--cav-space-md);
}

.footer__social-link {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	color: var(--cav-text);
	background-color: rgba(255, 255, 255, 0.6);
	border-radius: var(--cav-radius-sm);
	text-decoration: none;
	transition: color var(--cav-transition-fast), background-color var(--cav-transition-fast);
}

.footer__social-link:hover {
	color: var(--cav-primary);
	background-color: rgba(255, 255, 255, 0.9);
}

.footer__social-link svg {
	width: 32px;
	height: 32px;
}

.footer__col--social {
	order: -1;
	text-align: center;
}

.footer__col--social .footer__social {
	justify-content: center;
}

@media (min-width: 768px) {
	.footer__title {
		margin: 0 0 var(--cav-space-md);
	}
}

@media (min-width: 992px) {
	.footer__col--brand {
		order: initial;
		text-align: left;
	}

	.footer__col--social {
		order: initial;
		align-self: center;
		text-align: center;
	}

	.footer__col--brand {
		justify-content: flex-start;
	}

	.footer__col--social .footer__social {
		justify-content: center;
	}

	.footer__logo img,
	.footer__logo .custom-logo {
		height: clamp(80px, 11.5rem, 150px);
	}
}

/* Footer bottom */
.footer__bottom {
	padding: 0 0 var(--cav-space-sm);
	border-top: none;
}

.footer__bottom-content {
	display: flex;
	justify-content: center;
	align-items: center;
}

.footer__copyright {
	display: none;
}

/* MENU LÉGAL - FORCÉ EN LIGNE HORIZONTALE */
.footer__legal-menu {
	display: flex !important;
	flex-direction: row !important;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 0;
	margin: 0;
	padding: 0;
}

.footer__legal-menu li {
	display: inline !important;
	margin: 0 !important;
	padding: 0 !important;
}

.footer__legal-menu li:not(:last-child)::after {
	content: ' - ' !important;
	display: inline !important;
	color: var(--cav-text-light);
}

.footer__legal-menu a {
	font-size: var(--cav-font-sm);
	color: var(--cav-text-light);
	text-decoration: none;
}

.footer__legal-menu a:hover {
	color: var(--cav-primary);
}

/* ==========================================================================
   Mobile Shell & Bottom Nav
   ========================================================================== */

.mobile-shell {
	z-index: 200;
	display: none;
}

@media (max-width: 767px) {
	.mobile-shell {
		display: block;
		position: fixed;
		bottom: 0;
		left: 0;
		right: 0;
		z-index: 100;
	}

	/* Zone CTA produit (vide par défaut, remplie sur page produit) */
	.mobile-shell__cta:empty {
		display: none;
	}

	.mobile-shell__cta {
		background-color: var(--cav-bg-alt);
		border-top: 1px solid var(--cav-border);
	}

	/* Navigation bottom */
	.mobile-bottom-nav {
		display: flex;
		align-items: stretch;
		justify-content: space-around;
		height: var(--cav-mobile-nav-height);
		background-color: var(--cav-primary);
		border-top: none;
		box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.1);
	}

	.mobile-bottom-nav__item {
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		flex: 1;
		gap: var(--cav-space-xs);
		padding: var(--cav-space-sm) var(--cav-space-xs);
		color: var(--cav-text-inverse);
		text-decoration: none;
		background: none;
		border: none;
		cursor: pointer;
		transition: opacity var(--cav-transition-fast);
	}

	.mobile-bottom-nav__item:hover,
	.mobile-bottom-nav__item--active {
		color: var(--cav-text-inverse);
		opacity: 0.8;
	}

	.mobile-bottom-nav__icon {
		position: relative;
		display: flex;
		align-items: center;
		justify-content: center;
	}

	.mobile-bottom-nav__label {
		font-size: var(--cav-font-xs);
		font-weight: 500;
		line-height: 1;
	}

	/* Badge panier */
	.mobile-bottom-nav__badge {
		position: absolute;
		top: -6px;
		right: -10px;
		min-width: 18px;
		height: 18px;
		padding: 0 4px;
		font-size: 11px;
		font-weight: 700;
		line-height: 18px;
		text-align: center;
		color: var(--cav-text-inverse);
		background-color: var(--cav-secondary);
		border-radius: var(--cav-radius-full);
	}
}

/* ==========================================================================
   Bandeau Retour - Page Produit Mobile
   ========================================================================== */

/* Masquer par défaut */
.product-mobile-header {
	display: none;
}

@media (max-width: 767px) {
	/* Masquer le header normal sur page produit */
	.single-product .site-header {
		display: none;
	}

	/* Afficher le bandeau retour */
	.product-mobile-header {
		display: flex;
		align-items: center;
		padding: var(--cav-space-sm) var(--cav-space-md);
		background-color: var(--cav-primary);
		color: var(--cav-text-inverse);
		position: sticky;
		top: 0;
		z-index: 100;
	}

	.product-mobile-header__back {
		display: flex;
		align-items: center;
		gap: var(--cav-space-xs);
		color: var(--cav-text-inverse);
		text-decoration: none;
		font-size: var(--cav-font-sm);
		font-weight: 500;
	}

	.product-mobile-header__back:hover {
		color: var(--cav-text-inverse);
		opacity: 0.8;
	}
}

/* ==========================================================================
   Bandeau Titre - Page Panier Mobile
   ========================================================================== */

/* Masquer par défaut */
.cart-mobile-header {
	display: none;
}

@media (max-width: 767px) {
	/* Masquer le header normal sur page panier */
	.woocommerce-cart .site-header {
		display: none;
	}

	/* Afficher le bandeau panier */
	.cart-mobile-header {
		display: flex;
		align-items: center;
		justify-content: center;
		padding: var(--cav-space-sm) var(--cav-space-md);
		background-color: var(--cav-primary);
		color: var(--cav-text-inverse);
		position: sticky;
		top: 0;
		z-index: 100;
	}

	.cart-mobile-header__title {
		margin: 0;
		font-size: var(--cav-font-md);
		font-weight: 600;
		text-transform: uppercase;
		letter-spacing: 0.05em;
	}
}